/*
Theme Name: Foolhat FSE
Author: Foolhat
Author URI: foolhat.party
Description: A block-based WordPress theme designed to provide a great editing experience that minimises the visual gap between the frontend and backend. This theme also has a focus on consistent spacing & frontend performance.
Version: 1.0
Text Domain: foolhat
*/

/* 
*  CSS TABLE OF CONTENTS
*   
*  1.0 - Reset
*  2.0 - Fonts
*  3.0 - Custom Properties
*  4.0 - General Typography
*  5.0 - Areas
*    5.1 - Header
*    5.2 - Entry Content
* 6.0 - Utilities
*  7.0 - Buttons
*  8.0 - Gutenberg Conditionals
*/

/* ------------------------------------------------- 
1.0 Reset
------------------------------------------------- */
html {
	scroll-behavior: smooth;
	overflow-wrap: break-word;
	color: var(--black);
}

::selection {
	background: var(--black);
	color: var(--white);
}

/* Box sizing rules */
*,
*::before,
*::after {
	box-sizing: border-box;
	scroll-padding: 6rem;
}

/* Add default focus style */
*:focus-visible {
	outline: 1px solid var(--primary-200);
}

/* Remove default padding */
ul,
ol {
	padding: 0;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
li,
figure,
figcaption,
blockquote,
dl,
dd {
	margin: 0;
}

/* Make media easier to work with */
img,
picture,
video,
canvas,
svg {
	display: block;
}

img {
	width: 100%;
	height: auto;
	background: var(--gray-100);
	object-position: var(--focus);
	object-fit: cover;
	opacity: 0;
	overflow: hidden;
	transition: opacity 0.95s;
}

img.loaded {
	opacity: 1;
}

img[src*=".png"],
img[src$=".svg"] {
	background: 0 0;
}

/* Inherit fonts for inputs and buttons */
input,
textarea,
select,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
	font: inherit;
	width: 100%;
	padding: 0.5rem;
	border: 1px solid currentColor;
	background: unset;
	color: currentColor;
}

input[type="checkbox"] {
	width: fit-content;
}

input[type="checkbox"] {
	-webkit-appearance: none;
	appearance: none;
	background-color: #fff;
	margin: 0;
	font: inherit;
	color: currentColor;
	width: 1.5em;
	height: 1.5em;
	border: 1px solid var(--gray-100);
	border-radius: 0;
	transform: translateY(-0.075em);
	display: grid;
	place-content: center;
}

input[type="checkbox"]::before {
	content: "";
	width: 0.65em;
	height: 0.65em;
	transform: scale(0);
	transition: 120ms transform ease-in-out;
	box-shadow: inset 1em 1em var(--primary-400);
	transform-origin: bottom left;
	clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

input[type="checkbox"]:focus {
	outline: max(2px, 0.15em) solid currentColor;
	outline-offset: max(2px, 0.15em);
}

input[type="checkbox"]:checked::before {
	transform: scale(1);
}

button {
	font: inherit;
	padding: 0;
	cursor: pointer;
	border: none;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
	* {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

.screen-reader-text {
	visibility: hidden;
	position: fixed;
}

/* ------------------------------------------------- 
End Reset 
------------------------------------------------- */

/* ------------------------------------------------- 
2.0 Font Imports 
------------------------------------------------- */
@font-face {
	font-family: "Merriweather";
	src: local("Merriweather Light"), local("Merriweather-Light"),
		url("./fonts/Merriweather-Light.woff2") format("woff2");
	font-weight: 300;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Merriweather";
	src: local("Merriweather Regular"), local("Merriweather-Regular"),
		url("./fonts/Merriweather-Regular.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Merriweather";
	src: local("Merriweather Bold"), local("Merriweather-Bold"),
		url("./fonts/Merriweather-Bold.woff2") format("woff2");
	font-weight: bold;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Merriweather";
	src: local("Merriweather Black"), local("Merriweather-Black"),
		url("./fonts/Merriweather-Black.woff2") format("woff2");
	font-weight: 800;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat Regular"), local("Montserrat-Regular"),
		url("./fonts/Montserrat-Regular.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat Thin"), local("Montserrat-Thin"),
		url("./fonts/Montserrat-Thin.woff2") format("woff2");
	font-weight: 200;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat Light"), local("Montserrat-Light"),
		url("./fonts/Montserrat-Light.woff2") format("woff2");
	font-weight: 300;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat Regular"), local("Montserrat-Regular"),
		url("./fonts/Montserrat-Regular.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat Medium"), local("Montserrat-Medium"),
		url("./fonts/Montserrat-Medium.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat SemiBold"), local("Montserrat-SemiBold"),
		url("./fonts/Montserrat-SemiBold.woff2") format("woff2");
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat Bold"), local("Montserrat-Bold"),
		url("./fonts/Montserrat-Bold.woff2") format("woff2");
	font-weight: bold;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat ExtraBold"), local("Montserrat-ExtraBold"),
		url("./fonts/Montserrat-ExtraBold.woff2") format("woff2");
	font-weight: 800;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Montserrat";
	src: local("Montserrat Black"), local("Montserrat-Black"),
		url("./fonts/Montserrat-Black.woff2") format("woff2");
	font-weight: 800;
	font-style: normal;
	font-display: swap;
}

/* ------------------------------------------------- 
End Font Imports 
------------------------------------------------- */

/* ------------------------------------------------- 
3.0 Custom Properties
------------------------------------------------- */
:root {
	--heading-font: "Merriweather", sans-serif;
	--body-font: "Montserrat", sans-serif;
	--white: #fff;
	--black: #4c4c4c;
	--gray-50: #f5f5f5;
	--gray-100: #ddd;
	--gray-200: #bebebe;
	--gray-300: #9d9d9d;
	--gray-400: #858585;
	--gray-500: #6a6a6a;
	--gray-600: #525252;
	--gray-700: #383838;
	--gray-800: #1e1e1e;
	--gray-900: #141414;
	--primary-50: #d3d6e9;
	--primary-100: #b1b7d8;
	--primary-200: #8e97c7;
	--primary-300: #6c78b6;
	--primary-400: #4f5ca0;
	--primary-500: #3e477e;
	--primary-600: #2d345b;
	--primary-700: #222744;
	--primary-800: #1a1d33;
	--primary-900: #0e101b;
	--content-width: min(calc(100% - 3.5rem), 87%);
	--w-3xs: 22.5rem;
	--w-2xs: 30rem;
	--w-xs: 33.5rem;
	--w-sm: 40rem;
	--w-md: 48rem;
	--w-lg: 60rem;
	--w-xl: 72rem;
	--w-2xl: 80rem;
	--w-3xl: 96rem;
	--w-4xl: 120rem;
	--w-full: 100%;
	--spacing: 1rem;
	--s-3xs: calc(clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem) * 0.25);
	--s-2xs: calc(clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem) * 0.5);
	--s-xs: calc(clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem) * 0.75);
	--s-sm: clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem);
	--s-md: calc(clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem) * 1.5);
	--s-lg: calc(clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem) * 2);
	--s-xl: calc(clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem) * 2.5);
	--s-2xl: calc(clamp(0.875rem, 0.3rem + 2vh + 2vw, 2.25rem) * 3.5);
	--s-c1: clamp(3.5rem, 2vh + 6vw, 6.5rem);
	font-family: var(--body-font);
}

/* ------------------------------------------------- 
End Custom Properties
------------------------------------------------- */

/* ------------------------------------------------- 
4.0 General Typography
------------------------------------------------- */
h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--heading-font);
	line-height: 1.3;
	font-weight: 400;
}

.fs-0,
.has-0-font-size,
h6 {
	font-size: clamp(0.75rem, 0.71rem + 0.18vw, 0.875rem);
}

.fs-1,
.has-1-font-size,
h5 {
	font-size: clamp(1rem, 0.96rem + 0.18vw, 1.125rem);
}

.fs-2,
.has-2-font-size,
h4 {
	font-size: clamp(1.125rem, 1.09rem + 0.18vw, 1.25rem);
}

.fs-3,
.has-3-font-size,
h3 {
	font-size: clamp(1.25rem, 1.11rem + 0.71vw, 1.75rem);
}

.fs-4,
.has-4-font-size,
h2 {
	font-size: clamp(1.5rem, 1.29rem + 1.07vw, 2.25rem);
}

.fs-5,
.has-5-font-size,
h1 {
	font-size: clamp(1.75rem, 1.39rem + 1.79vw, 3rem);
}

.fs-6,
.has-6-font-size {
	font-size: clamp(2.25rem, 1.82rem + 2.14vw, 3.75rem);
}

p {
	line-height: 1.9;
}

html main a:not(.btn, .button, .woocommerce-LoopProduct-link, .wc-block-grid__product-link, .woof_btn_default, ),
html .wp-block-flowio-section-block a:not(.btn, .button, .woocommerce-LoopProduct-link, .wc-block-grid__product-link, .woof_btn_default, ) {
	color: currentColor;
	transition: filter 0.3s;
}

html main a:not(.btn, .button, .woocommerce-LoopProduct-link, .wc-block-grid__product-link, .woof_btn_default, ):hover,
html .wp-block-flowio-section-block a:not(.btn, .button, .woocommerce-LoopProduct-link, .wc-block-grid__product-link, .woof_btn_default, ):hover {
	filter: hue-rotate(30deg) brightness(1.5);
}

.heading-font {
	font-family: var(--heading-font);
}

.body-font {
	font-family: var(--body-font);
}

/* style lists */
ul,
ol {
	padding-left: 2rem;
	line-height: 1.75;
}

/* ------------------------------------------------- 
End General Typography
------------------------------------------------- */

/* ------------------------------------------------- 
5.0 Areas
------------------------------------------------- */
/* --------
5.1 Header
-------- */
.wp-site-blocks,
.site-header.wp-block-template-part,
.wp-block-lazyblock-header {
	display: contents;
}

.theme-header ul,
.theme-header ol {
	padding-left: 0;
}

.theme-header {
	width: 100%;
	color: white;
	background-color: var(--white);
	transition: background 0.5s;
}

.theme-header.enabled {
	position: sticky;
	top: 0;
	z-index: 69240;
	box-shadow: 0 4px 16px rgb(0 0 0 / 25%);
}

.theme-header.enabled .brand {
	height: 3.8rem;
}

.header-content {
	display: grid;
	grid-template-columns: auto auto;
	gap: 2rem;
	justify-content: space-between;
}

.brand {
	color: white;
	text-decoration: none;
	display: flex;
	gap: 0.5rem;
	align-items: center;
	height: 6.5rem;
	transition: height 0.3s, margin 0.3s;
	align-self: center;
	margin-block: 1rem;
}

.brand>svg {
	height: 100%;
	transition: color 0.4s, opacity 0.4s, backdrop-filter 0.4s;
}

.brand:hover>svg,
.brand:active>svg {
	color: var(--primary-200);
	opacity: 0.7;
	backdrop-filter: blur(20px);
}

@media screen and (min-width: 38rem) {
	.brand>svg:nth-of-type(2) {
		display: block;
	}
}

.menu-item {
	list-style: none;
	position: relative;
}

.menu-item a,
.menu-item button {
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-weight: 600;
	font-size: 0.875rem;
	color: white;
	transition: color 0.3s;
}

.menu-item>a:hover,
a:active {
	color: var(--primary-400);
}

.navigation-items {
	display: grid;
	align-items: center;
}

.desktop-nav {
	display: none;
	height: 100%;
	color: var(--black);
}

.desktop-nav>div>ul>li {
	display: grid;
	align-items: center;
}

.desktop-nav>div>ul {
	display: flex;
	flex-wrap: wrap;
	margin-block: 1rem;
	justify-content: flex-end;
	align-items: center;
	transition: margin 0.3s;
}

.desktop-nav .sub-menu a:hover {
	color: var(--primary-400);
}

.desktop-nav .menu-item-has-children:hover>.sub-menu,
.desktop-nav .menu-item-has-children:focus-within>.sub-menu {
	opacity: 1;
	visibility: visible;
}

#menuButton {
	margin: 1rem 0;
	z-index: 69469;
}

#menuButton svg {
	height: 1.5rem;
}

#menuButton rect,
#menuButton svg {
	transition: all 0.35s;
}

#menuButton[aria-expanded="true"] svg {
	transform: translate(-3%, -2%);
}

#menuButton[aria-expanded="true"] rect:nth-of-type(1) {
	opacity: 0;
}

#menuButton[aria-expanded="true"] rect:nth-of-type(2) {
	transform: rotate(45deg) translateX(25%) translateY(-25%);
}

#menuButton[aria-expanded="true"] rect:nth-of-type(3) {
	transform: rotate(-45deg) translateX(-50%) translateY(-0%);
}

.theme-header.enabled #menuButton {
	margin: 0.5rem 0;
}

@media screen and (min-width: 48rem) {
	.desktop-nav {
		display: flex;
		align-items: center;
	}

	#menuButton {
		display: none;
	}
}

#menu-primary_navigation {
	padding: 0;
	display: flex;
	align-items: center;
}

#menu-primary_navigation li {
	white-space: nowrap;
	position: relative;
	height: 100%;
	line-height: 1;
	transition: all 0.3s;
}

#menu-primary_navigation li.menu-item-has-children button::after {
	content: "";
	display: inline-block;
	position: absolute;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' width='24' height='24' stroke='white ' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round' class='css-i6dzq1'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-size: cover;
	width: 0.875rem;
	height: 0.875rem;
	right: 0.35rem;
	transition: transform 0.3s;
	filter: invert(1);
}

#menu-primary_navigation li.menu-item-has-children:hover button::after {
	filter: unset;
}

#menu-primary_navigation li.menu-item-has-children>button[aria-expanded="true"] {
	background: var(--primary-700);
	color: var(--white);
}

#menu-primary_navigation li.menu-item-has-children>button[aria-expanded="true"]::after {
	transform: rotate(180deg);
	filter: unset;
}

#menu-primary_navigation>li:hover {
	background: var(--primary-800);
	color: var(--white);
	cursor: pointer;
}

#menu-primary_navigation>li>a,
#menu-primary_navigation>li>button {
	background: none;
	display: inline-block;
	line-height: 1;
	text-decoration: none;
	color: inherit;
	padding: 0.75rem 0.5rem;
	transition: padding 0.5s;
}

.theme-header.enabled .brand,
.theme-header.enabled .desktop-nav>div>ul {
	margin-block: 0.5rem;
}

#menu-primary_navigation li.menu-item-has-children>a,
#menu-primary_navigation li.menu-item-has-children>button {
	padding-right: 1.5rem;
}

.theme-header.enabled #menu-primary_navigation>li.menu-item-has-children>a,
.theme-header.enabled #menu-primary_navigation>li.menu-item-has-children>button {
	padding-right: 1.5rem;
}

#menu-primary_navigation .sub-menu {
	display: none;
	position: absolute;
	padding: 0;
	margin: 0;
	background: white;
	z-index: 10;
	top: 100%;
	right: 0;
	min-width: 8rem;
	text-align: end;
	border: 1px solid var(--primary-100);
}

#menu-primary_navigation .sub-menu[aria-hidden="false"] {
	display: block;
}

#menu-primary_navigation .sub-menu li {
	padding: 0;
	white-space: nowrap;
}

#menu-primary_navigation .sub-menu>*+* {
	border-top: 1px solid var(--primary-100);
}

#menu-primary_navigation .sub-menu li a {
	display: block;
	padding: 1.15rem 1rem;
	width: 100%;
	height: 100%;
	text-decoration: none;
	color: var(--black);
	transition: all 0.25s;
	line-height: 1;
}

#menu-primary_navigation .sub-menu li a:hover {
	background: var(--primary-700);
	color: var(--white);
}

#curtain-menu {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 69468;
	background: var(--white);
	color: var(--black);
	min-height: 100vh;
	width: 100vw;
	max-width: 0;
	display: none;
	transition: all 0.3s ease-out;
	overflow-y: scroll;
}

#curtain-menu-container {
	opacity: 0;
	width: var(--content-width);
	max-width: var(--width-medium);
	margin: auto;
	padding: 3rem 0;
	transition: opacity 0.3s ease;
}

#curtain-menu-container.fade-in {
	opacity: 1;
}

#curtain-menu-container ul {
	font-size: 1.25rem;
	padding-left: 0;
}

#curtain-menu-container ul>*+* {
	margin-block-start: 0.6rem;
}

#curtain-menu-container .sub-menu {
	margin-left: 1rem;
	margin-block-start: 0.6rem;
	padding-left: 0.75rem;
	border-left: 2px solid var(--primary-300);
}

#curtain-menu-container .menu-item-has-children>a[href="#"] {
	pointer-events: none;
	opacity: 0.75;
}

#curtain-menu .menu-item a {
	color: inherit;
}

#curtain-menu.active {
	display: block;
}

#curtain-menu.mw-full {
	max-width: 100%;
}

#curtain-content {
	opacity: 0;
	transition: opacity 0.3s;
	padding-block: 5rem;
}

#curtain-content.fade-in {
	opacity: 1;
}

/* --------
End Header
-------- */
/* --------
5.2 Entry Content
-------- */
div[class^="wp-block-lazy"] {
	width: 100%;
	max-width: 100%;
}

.auto-child-width>* {
	max-width: var(--auto-child-max-width, var(--w-sm));
	width: var(--auto-child-width, var(--content-width));
	margin-inline-start: auto;
	margin-inline-end: auto;
}

p>a {
	color: var(--primary-700);
	transition: color 0.3s;
}

p>a:hover,
p>a:focus {
	color: var(--primary-500);
}

/* Ninja Forms */
.nf-form-layout .nf-before-form-content {
	border-bottom: 1px solid var(--primary-100);
	padding-bottom: 1rem;
}

.nf-form-layout .nf-form-content {
	padding: 0;
	margin-top: 1rem;
}

nf-fields-wrap {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

/*** This is to select which elements should span multiple columns ***/
nf-fields-wrap nf-field:nth-child(3) {
	grid-column: span 2;
}

/* --------
End Entry Content
-------- */
/* --------
5.3 Footer
-------- */
.theme-footer ul,
.theme-footer ol {
	padding-left: 0;
}


.theme-footer .heading-font {
	border-bottom: 2px solid var(--primary-500);
	padding-bottom: 0.5rem;
}

.footer-top-buttons {
	display: flex;
	gap: 0.5rem;
}

.footer-top-button {
	height: 2.25rem;
	width: 2.25rem;
	padding: 0.5rem;
	border-radius: 9999px;
	background: var(--primary-500);
	color: #fff;
	transition: all .3s;
	display: flex;
	justify-content: center;
}

.footer-top-button:hover {
	background: var(--primary-300);
}

.footer-top-button svg {
	fill: currentColor;
}

.theme-footer a {
	color: white;
}

/* --------
Emd Footer
-------- */

/* ------------------------------------------------- 
End Areas
------------------------------------------------- */
/* ------------------------------------------------- 
6.0 Utilities
------------------------------------------------- */
/* Flow */
.flow,
.inner-flow,
.ff-final {
	--flow: 2rem;
}

.flow>*+* {
	margin-block-start: var(--flow, 2rem);
}

.inner-flow>*+* {
	margin-block-start: var(--inner-flow, var(--flow, 2rem));
}

.flex-flow {
	display: flex;
	flex-direction: column;
	gap: var(--flow, 2rem);
}

.ff-final {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: end;
}

.flow-none {
	--flow: 0;
}

.flow-2xs {
	--flow: 0.25rem;
}

.flow-xs {
	--flow: 0.5rem;
}

.flow-sm {
	--flow: 1rem;
}

.flow-md {
	--flow: 1.5rem;
}

.flow-lg {
	--flow: 2rem;
}

.flow-xl {
	--flow: 2.5rem;
}

.flow-2xl {
	--flow: 3rem;
}

/* Margins */
.m-3xs {
	margin: var(--s-3xs);
}

.m-2xs {
	margin: var(--s-2xs);
}

.m-xs {
	margin: var(--s-xs);
}

.m-sm {
	margin: var(--s-sm);
}

.m-md {
	margin: var(--s-md);
}

.m-lg {
	margin: var(--s-lg);
}

.m-xl {
	margin: var(--s-xl);
}

.m-2xl {
	margin: var(--s-2xl);
}

.m-c1 {
	margin: var(--s-c1);
}

.m-none {
	margin: 0;
}

.my-3xs {
	margin-block-start: var(--s-3xs);
	margin-block-end: var(--s-3xs);
}

.my-2xs {
	margin-block-start: var(--s-2xs);
	margin-block-end: var(--s-2xs);
}

.my-xs {
	margin-block-start: var(--s-xs);
	margin-block-end: var(--s-xs);
}

.my-sm {
	margin-block-start: var(--s-sm);
	margin-block-end: var(--s-sm);
}

.my-md {
	margin-block-start: var(--s-md);
	margin-block-end: var(--s-md);
}

.my-lg {
	margin-block-start: var(--s-lg);
	margin-block-end: var(--s-lg);
}

.my-xl {
	margin-block-start: var(--s-xl);
	margin-block-end: var(--s-xl);
}

.my-2xl {
	margin-block-start: var(--s-2xl);
	margin-block-end: var(--s-2xl);
}

.my-c1 {
	margin-block-start: var(--s-c1);
	margin-block-end: var(--s-c1);
}

.my-none {
	margin-block-start: 0;
	margin-block-end: 0;
}

.mx-3xs {
	margin-inline-start: var(--s-3xs);
	margin-inline-end: var(--s-3xs);
}

.mx-2xs {
	margin-inline-start: var(--s-2xs);
	margin-inline-end: var(--s-2xs);
}

.mx-xs {
	margin-inline-start: var(--s-xs);
	margin-inline-end: var(--s-xs);
}

.mx-sm {
	margin-inline-start: var(--s-sm);
	margin-inline-end: var(--s-sm);
}

.mx-md {
	margin-inline-start: var(--s-md);
	margin-inline-end: var(--s-md);
}

.mx-lg {
	margin-inline-start: var(--s-lg);
	margin-inline-end: var(--s-lg);
}

.mx-xl {
	margin-inline-start: var(--s-xl);
	margin-inline-end: var(--s-xl);
}

.mx-2xl {
	margin-inline-start: var(--s-2xl);
	margin-inline-end: var(--s-2xl);
}

.mx-c1 {
	margin-inline-start: var(--s-c1);
	margin-inline-end: var(--s-c1);
}

.mx-auto {
	margin-inline-start: auto;
	margin-inline-end: auto;
}

.mt-3xs {
	margin-block-start: var(--s-3xs);
	--mt: var(--s-3xs);
}

.mt-2xs {
	margin-block-start: var(--s-2xs);
	--mt: var(--s-2xs);
}

.mt-xs {
	margin-block-start: var(--s-xs);
	--mt: var(--s-xs);
}

.mt-sm {
	margin-block-start: var(--s-sm);
	--mt: var(--s-sm);
}

.mt-md {
	margin-block-start: var(--s-md);
	--mt: var(--s-md);
}

.mt-lg {
	margin-block-start: var(--s-lg);
	--mt: var(--s-lg);
}

.mt-xl {
	margin-block-start: var(--s-xl);
	--mt: var(--s-xl);
}

.mt-2xl {
	margin-block-start: var(--s-2xl);
	--mt: var(--s-2xl);
}

.mt-c1 {
	margin-block-start: var(--s-c1);
	--mt: var(--s-c1);
}

.mt-none {
	margin-block-start: 0;
	--mt: 0;
}

.mb-3xs {
	margin-block-end: var(--s-3xs);
}

.mb-2xs {
	margin-block-end: var(--s-2xs);
}

.mb-xs {
	margin-block-end: var(--s-xs);
}

.mb-sm {
	margin-block-end: var(--s-sm);
}

.mb-md {
	margin-block-end: var(--s-md);
}

.mb-lg {
	margin-block-end: var(--s-lg);
}

.mb-xl {
	margin-block-end: var(--s-xl);
}

.mb-2xl {
	margin-block-end: var(--s-2xl);
}

.mb-c1 {
	margin-block-end: var(--s-c1);
}

.mb-none {
	margin-block-end: 0;
}

.ml-3xs {
	margin-inline-start: var(--s-3xs);
}

.ml-2xs {
	margin-inline-start: var(--s-2xs);
}

.ml-xs {
	margin-inline-start: var(--s-xs);
}

.ml-sm {
	margin-inline-start: var(--s-sm);
}

.ml-md {
	margin-inline-start: var(--s-md);
}

.ml-lg {
	margin-inline-start: var(--s-lg);
}

.ml-xl {
	margin-inline-start: var(--s-xl);
}

.ml-2xl {
	margin-inline-start: var(--s-2xl);
}

.ml-c1 {
	margin-inline-start: var(--s-c1);
}

.ml-none {
	margin-inline-start: 0;
}

.mr-3xs {
	margin-inline-end: var(--s-3xs);
}

.mr-2xs {
	margin-inline-end: var(--s-2xs);
}

.mr-xs {
	margin-inline-end: var(--s-xs);
}

.mr-sm {
	margin-inline-end: var(--s-sm);
}

.mr-md {
	margin-inline-end: var(--s-md);
}

.mr-lg {
	margin-inline-end: var(--s-lg);
}

.mr-xl {
	margin-inline-end: var(--s-xl);
}

.mr-2xl {
	margin-inline-end: var(--s-2xl);
}

.mr-c1 {
	margin-inline-end: var(--s-c1);
}

.mr-none {
	margin-inline-end: 0;
}

/*Padding*/
.p-3xs {
	padding: var(--s-3xs);
}

.p-2xs {
	padding: var(--s-2xs);
}

.p-xs {
	padding: var(--s-xs);
}

.p-sm {
	padding: var(--s-sm);
}

.p-md {
	padding: var(--s-md);
}

.p-lg {
	padding: var(--s-lg);
}

.p-xl {
	padding: var(--s-xl);
}

.p-2xl {
	padding: var(--s-2xl);
}

.p-c1 {
	padding: var(--s-c1);
}

.p-none {
	padding: 0;
}

.py-3xs {
	padding-block-start: var(--s-3xs);
	padding-block-end: var(--s-3xs);
}

.py-2xs {
	padding-block-start: var(--s-2xs);
	padding-block-end: var(--s-2xs);
}

.py-xs {
	padding-block-start: var(--s-xs);
	padding-block-end: var(--s-xs);
}

.py-sm {
	padding-block-start: var(--s-sm);
	padding-block-end: var(--s-sm);
}

.py-md {
	padding-block-start: var(--s-md);
	padding-block-end: var(--s-md);
}

.py-lg {
	padding-block-start: var(--s-lg);
	padding-block-end: var(--s-lg);
}

.py-xl {
	padding-block-start: var(--s-xl);
	padding-block-end: var(--s-xl);
}

.py-2xl {
	padding-block-start: var(--s-2xl);
	padding-block-end: var(--s-2xl);
}

.py-c1 {
	padding-block-start: var(--s-c1);
	padding-block-end: var(--s-c1);
}

.py-none {
	padding-block-start: 0;
	padding-block-end: 0;
}

.px-3xs {
	padding-inline-start: var(--s-3xs);
	padding-inline-end: var(--s-3xs);
}

.px-2xs {
	padding-inline-start: var(--s-2xs);
	padding-inline-end: var(--s-2xs);
}

.px-xs {
	padding-inline-start: var(--s-xs);
	padding-inline-end: var(--s-xs);
}

.px-sm {
	padding-inline-start: var(--s-sm);
	padding-inline-end: var(--s-sm);
}

.px-md {
	padding-inline-start: var(--s-md);
	padding-inline-end: var(--s-md);
}

.px-lg {
	padding-inline-start: var(--s-lg);
	padding-inline-end: var(--s-lg);
}

.px-xl {
	padding-inline-start: var(--s-xl);
	padding-inline-end: var(--s-xl);
}

.px-2xl {
	padding-inline-start: var(--s-2xl);
	padding-inline-end: var(--s-2xl);
}

.px-c1 {
	padding-inline-start: var(--s-c1);
	padding-inline-end: var(--s-c1);
}

.px-auto {
	padding-inline-start: auto;
	padding-inline-end: auto;
}

.pt-3xs {
	padding-block-start: var(--s-3xs);
}

.pt-2xs {
	padding-block-start: var(--s-2xs);
}

.pt-xs {
	padding-block-start: var(--s-xs);
}

.pt-sm {
	padding-block-start: var(--s-sm);
}

.pt-md {
	padding-block-start: var(--s-md);
}

.pt-lg {
	padding-block-start: var(--s-lg);
}

.pt-xl {
	padding-block-start: var(--s-xl);
}

.pt-2xl {
	padding-block-start: var(--s-2xl);
}

.pt-c1 {
	padding-block-start: var(--s-c1);
}

.pt-none {
	padding-block-start: 0;
}

.pb-3xs {
	padding-block-end: var(--s-3xs);
}

.pb-2xs {
	padding-block-end: var(--s-2xs);
}

.pb-xs {
	padding-block-end: var(--s-xs);
}

.pb-sm {
	padding-block-end: var(--s-sm);
}

.pb-md {
	padding-block-end: var(--s-md);
}

.pb-lg {
	padding-block-end: var(--s-lg);
}

.pb-xl {
	padding-block-end: var(--s-xl);
}

.pb-2xl {
	padding-block-end: var(--s-2xl);
}

.pb-c1 {
	padding-block-end: var(--s-c1);
}

.pb-none {
	padding-block-end: 0;
}

.pl-3xs {
	padding-inline-start: var(--s-3xs);
}

.pl-2xs {
	padding-inline-start: var(--s-2xs);
}

.pl-xs {
	padding-inline-start: var(--s-xs);
}

.pl-sm {
	padding-inline-start: var(--s-sm);
}

.pl-md {
	padding-inline-start: var(--s-md);
}

.pl-lg {
	padding-inline-start: var(--s-lg);
}

.pl-xl {
	padding-inline-start: var(--s-xl);
}

.pl-2xl {
	padding-inline-start: var(--s-2xl);
}

.pl-c1 {
	padding-inline-start: var(--s-c1);
}

.pl-none {
	padding-inline-start: 0;
}

.pr-3xs {
	padding-inline-end: var(--s-3xs);
}

.pr-2xs {
	padding-inline-end: var(--s-2xs);
}

.pr-xs {
	padding-inline-end: var(--s-xs);
}

.pr-sm {
	padding-inline-end: var(--s-sm);
}

.pr-md {
	padding-inline-end: var(--s-md);
}

.pr-lg {
	padding-inline-end: var(--s-lg);
}

.pr-xl {
	padding-inline-end: var(--s-xl);
}

.pr-2xl {
	padding-inline-end: var(--s-2xl);
}

.pr-c1 {
	padding-inline-end: var(--s-c1);
}

.pr-none {
	padding-inline-end: 0;
}

/* Block Widths */
.mw-3xs {
	max-width: var(--w-3xs);
}

.mw-2xs {
	max-width: var(--w-2xs);
}

.mw-xs {
	max-width: var(--w-xs);
}

.mw-sm {
	max-width: var(--w-sm);
}

.mw-md {
	max-width: var(--w-md);
}

.mw-lg {
	max-width: var(--w-lg);
}

.mw-xl {
	max-width: var(--w-xl);
}

.mw-2xl {
	max-width: var(--w-2xl);
}

.mw-3xl {
	max-width: var(--w-3xl);
}

.mw-4xl {
	max-width: var(--w-4xl);
}

.mw-content {
	max-width: var(--content-width);
}

.mw-full {
	max-width: 100%;
}

.w-content {
	width: var(--content-width);
}

.w-full {
	width: 100%;
}

.cmw-3xs {
	--auto-child-max-width: var(--w-3xs);
}

.cmw-2xs {
	--auto-child-max-width: var(--w-2xs);
}

.cmw-xs {
	--auto-child-max-width: var(--w-xs);
}

.cmw-sm {
	--auto-child-max-width: var(--w-sm);
}

.cmw-md {
	--auto-child-max-width: var(--w-md);
}

.cmw-lg {
	--auto-child-max-width: var(--w-lg);
}

.cmw-xl {
	--auto-child-max-width: var(--w-xl);
}

.cmw-2xl {
	--auto-child-max-width: var(--w-2xl);
}

.cmw-3xl {
	--auto-child-max-width: var(--w-3xl);
}

.cmw-4xl {
	--auto-child-max-width: var(--w-4xl);
}

.cmw-full {
	--auto-child-max-width: 100%;
}

.cw-content {
	--auto-child-width: var(--content-width);
}

.cw-full {
	--auto-child-width: 100%;
}

/* Other Utilities */
.ta-l,
.has-text-align-left {
	text-align: left;
}

.ta-c,
.has-text-align-center {
	text-align: center;
}

.ta-r,
.has-text-align-right {
	text-align: right;
}

.fw-1 {
	font-weight: 100;
}

.fw-2 {
	font-weight: 200;
}

.fw-3 {
	font-weight: 300;
}

.fw-4 {
	font-weight: 400;
}

.fw-5 {
	font-weight: 500;
}

.fw-6 {
	font-weight: 600;
}

.fw-7 {
	font-weight: 700;
}

.fw-8 {
	font-weight: 800;
}

.fw-9 {
	font-weight: 900;
}

.stack {
	display: grid;
	grid-template-areas: "stack";
	position: relative;
}

.stack>* {
	grid-area: stack;
	position: relative;
}

.stack>img {
	position: absolute;
	object-fit: cover;
	height: 100%;
}

.stack>.overlay {
	width: 100%;
	height: 100%;
	background: var(--overlay, rgba(0, 0, 0, 0.5));
}

/* Colour Utilities */
.col-p-50,
.has-primary-50-color {
	color: var(--primary-50);
}

.col-p-100,
.has-primary-100-color {
	color: var(--primary-100);
}

.col-p-200,
.has-primary-200-color {
	color: var(--primary-200);
}

.col-p-300,
.has-primary-300-color {
	color: var(--primary-300);
}

.col-p-400,
.has-primary-400-color {
	color: var(--primary-400);
}

.col-p-500,
.has-primary-500-color {
	color: var(--primary-500);
}

.col-p-600,
.has-primary-600-color {
	color: var(--primary-600);
}

.col-p-700,
.has-primary-700-color {
	color: var(--primary-700);
}

.col-p-800,
.has-primary-800-color {
	color: var(--primary-800);
}

.col-p-900,
.has-primary-900-color {
	color: var(--primary-900);
}

.col-s-50,
.has-secondary-50-color {
	color: var(--primary-50);
}

.col-s-100,
.has-secondary-100-color {
	color: var(--primary-100);
}

.col-s-200,
.has-secondary-200-color {
	color: var(--primary-200);
}

.col-s-300,
.has-secondary-300-color {
	color: var(--primary-300);
}

.col-s-400,
.has-secondary-400-color {
	color: var(--primary-400);
}

.col-s-500,
.has-secondary-500-color {
	color: var(--primary-500);
}

.col-s-600,
.has-secondary-600-color {
	color: var(--primary-600);
}

.col-s-700,
.has-secondary-700-color {
	color: var(--primary-700);
}

.col-s-800,
.has-secondary-800-color {
	color: var(--primary-800);
}

.col-s-900,
.has-secondary-900-color {
	color: var(--primary-900);
}

.col-white,
.has-white-color {
	color: var(--white);
}

.col-black,
.has-black-color {
	color: var(--black);
}

.col-g-50,
.has-gray-50-color {
	color: var(--gray-50);
}

.col-g-100,
.has-gray-100-color {
	color: var(--gray-100);
}

.col-g-200,
.has-gray-200-color {
	color: var(--gray-200);
}

.col-g-300,
.has-gray-300-color {
	color: var(--gray-300);
}

.col-g-400,
.has-gray-400-color {
	color: var(--gray-400);
}

.col-g-500,
.has-gray-500-color {
	color: var(--gray-500);
}

.col-g-600,
.has-gray-600-color {
	color: var(--gray-600);
}

.col-g-700,
.has-gray-700-color {
	color: var(--gray-700);
}

.col-g-800,
.has-gray-800-color {
	color: var(--gray-800);
}

.col-g-900,
.has-gray-900-color {
	color: var(--gray-900);
}

.bg-p-50,
.has-primary-50-background-color {
	background-color: var(--primary-50);
}

.bg-p-100,
.has-primary-100-background-color {
	background-color: var(--primary-100);
}

.bg-p-200,
.has-primary-200-background-color {
	background-color: var(--primary-200);
}

.bg-p-300,
.has-primary-300-background-color {
	background-color: var(--primary-300);
}

.bg-p-400,
.has-primary-400-background-color {
	background-color: var(--primary-400);
}

.bg-p-500,
.has-primary-500-background-color {
	background-color: var(--primary-500);
}

.bg-p-600,
.has-primary-600-background-color {
	background-color: var(--primary-600);
}

.bg-p-700,
.has-primary-700-background-color {
	background-color: var(--primary-700);
}

.bg-p-800,
.has-primary-800-background-color {
	background-color: var(--primary-800);
}

.bg-p-900,
.has-primary-900-background-color {
	background-color: var(--primary-900);
}

.bg-s-50,
.has-secondary-50-background-color {
	background-color: var(--primary-50);
}

.bg-s-100,
.has-secondary-100-background-color {
	background-color: var(--primary-100);
}

.bg-s-200,
.has-secondary-200-background-color {
	background-color: var(--primary-200);
}

.bg-s-300,
.has-secondary-300-background-color {
	background-color: var(--primary-300);
}

.bg-s-400,
.has-secondary-400-background-color {
	background-color: var(--primary-400);
}

.bg-s-500,
.has-secondary-500-background-color {
	background-color: var(--primary-500);
}

.bg-s-600,
.has-secondary-600-background-color {
	background-color: var(--primary-600);
}

.bg-s-700,
.has-secondary-700-background-color {
	background-color: var(--primary-700);
}

.bg-s-800,
.has-secondary-800-background-color {
	background-color: var(--primary-800);
}

.bg-s-900,
.has-secondary-900-background-color {
	background-color: var(--primary-900);
}

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

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

.bg-g-50,
.has-gray-50-background-color {
	background-color: var(--gray-50);
}

.bg-g-100,
.has-gray-100-background-color {
	background-color: var(--gray-100);
}

.bg-g-200,
.has-gray-200-background-color {
	background-color: var(--gray-200);
}

.bg-g-300,
.has-gray-300-background-color {
	background-color: var(--gray-300);
}

.bg-g-400,
.has-gray-400-background-color {
	background-color: var(--gray-400);
}

.bg-g-500,
.has-gray-500-background-color {
	background-color: var(--gray-500);
}

.bg-g-600,
.has-gray-600-background-color {
	background-color: var(--gray-600);
}

.bg-g-700,
.has-gray-700-background-color {
	background-color: var(--gray-700);
}

.bg-g-800,
.has-gray-800-background-color {
	background-color: var(--gray-800);
}

.bg-g-900,
.has-gray-900-background-color {
	background-color: var(--gray-900);
}

.flex-layout {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gap, 2rem);
	row-gap: var(--row-gap, var(--gap, 2rem));
	justify-content: var(--justify);
	align-items: var(--align);
}

.flex-layout>* {
	flex: var(--flex-base, 17rem) var(--flex-grow, 1) var(--flex-shrink, 1);
	max-width: var(--flex-child-max-width);
	min-width: var(--flex-child-min-width);
}

.fb-2 {
	--flex-base: 2rem;
}

.fb-4 {
	--flex-base: 4rem;
}

.fb-6 {
	--flex-base: 6rem;
}

.fb-8 {
	--flex-base: 8rem;
}

.fb-10 {
	--flex-base: 10rem;
}

.fb-12 {
	--flex-base: 12rem;
}

.fb-14 {
	--flex-base: 14rem;
}

.fb-16 {
	--flex-base: 16rem;
}

.fb-18 {
	--flex-base: 18rem;
}

.fb-20 {
	--flex-base: 20rem;
}

.fb-24 {
	--flex-base: 24rem;
}

.fb-28 {
	--flex-base: 28rem;
}

.fb-32 {
	--flex-base: 32rem;
}

.fb-40 {
	--flex-base: 40rem;
}

.gap-none {
	--gap: 0;
}

.gap-2xs {
	--gap: 0.25rem;
}

.gap-xs {
	--gap: 0.5rem;
}

.gap-sm {
	--gap: 1rem;
}

.gap-md {
	--gap: 1.5rem;
}

.gap-lg {
	--gap: 2rem;
}

.gap-xl {
	--gap: 2.5rem;
}

.gap-2xl {
	--gap: 3rem;
}

.row-gap-none {
	--row-gap: 0;
}

.row-gap-2xs {
	--row-gap: 0.25rem;
}

.row-gap-xs {
	--row-gap: 0.5rem;
}

.row-gap-sm {
	--row-gap: 1rem;
}

.row-gap-md {
	--row-gap: 1.5rem;
}

.row-gap-lg {
	--row-gap: 2rem;
}

.row-gap-xl {
	--row-gap: 2.5rem;
}

.row-gap-2xl {
	--row-gap: 3rem;
}

.mw-2 {
	max-width: 2rem;
}

.mw-4 {
	max-width: 4rem;
}

.mw-6 {
	max-width: 6rem;
}

.mw-8 {
	max-width: 8rem;
}

.mw-10 {
	max-width: 10rem;
}

.mw-12 {
	max-width: 12rem;
}

.mw-14 {
	max-width: 14rem;
}

.mw-16 {
	max-width: 16rem;
}

.mw-18 {
	max-width: 18rem;
}

.mw-20 {
	max-width: 20rem;
}

.mw-24 {
	max-width: 24rem;
}

.mw-28 {
	max-width: 28rem;
}

.mw-32 {
	max-width: 32rem;
}

.mw-40 {
	max-width: 40rem;
}

.fcmw-2 {
	--flex-child-max-width: 2rem;
}

.fcmw-4 {
	--flex-child-max-width: 4rem;
}

.fcmw-6 {
	--flex-child-max-width: 6rem;
}

.fcmw-8 {
	--flex-child-max-width: 8rem;
}

.fcmw-10 {
	--flex-child-max-width: 10rem;
}

.fcmw-12 {
	--flex-child-max-width: 12rem;
}

.fcmw-14 {
	--flex-child-max-width: 14rem;
}

.fcmw-16 {
	--flex-child-max-width: 16rem;
}

.fcmw-18 {
	--flex-child-max-width: 18rem;
}

.fcmw-20 {
	--flex-child-max-width: 20rem;
}

.fcmw-24 {
	--flex-child-max-width: 24rem;
}

.fcmw-28 {
	--flex-child-max-width: 28rem;
}

.fcmw-32 {
	--flex-child-max-width: 32rem;
}

.fcmw-40 {
	--flex-child-max-width: 40rem;
}

.h-full {
	height: 100%;
}

.grid-layout {
	display: grid;
	grid-template-columns: repeat(var(--col-fill, auto-fit),
			minmax(var(--col-min, 15rem), var(--col-max, 1fr)));
	grid-auto-rows: var(--grid-auto-rows, 1fr);
	gap: var(--gap, 2rem);
}

.justify-start {
	--justify: start;
}

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

.justify-end {
	--justify: end;
}

.justify-around {
	--justify: space-around;
}

.justify-between {
	--justify: space-between;
}

.align-start {
	--align: start;
}

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

.align-end {
	--align: end;
}

.align-around {
	--align: space-around;
}

.align-between {
	--align: space-between;
}

.as-start {
	align-self: start;
}

.as-center {
	align-self: center;
}

.as-end {
	align-self: end;
}

.js-start {
	justify-self: start;
}

.js-center {
	justify-self: center;
}

.js-end {
	justify-self: end;
}

.ttu {
	text-transform: uppercase;
}

.ls-md {
	letter-spacing: 0.2em;
}

/* ------------------------------------------------- 
End Utilities
------------------------------------------------- */
/* ------------------------------------------------- 
7.0 Buttons
------------------------------------------------- */
.btn,
html .woocommerce .button,
html .woocommerce button.button,
html .woocommerce button.button.alt,
html .woocommerce button.button.alt.disabled,
html .woocommerce a.button.checkout-button,
html .woof_btn_default,
.linkbtn>a,
html body input[id^="nf-"][type="button"],
button[type="submit"],
.hbook-wrapper input[type="submit"],
input[type="submit"][value="Book now!"] {
	color: var(--color, var(--white));
	background: var(--background, var(--primary-600));
	border: var(--border, 2px solid var(--primary-600));
	border-radius: var(--borderRadius, 0);
	padding: var(--padding, 0.5rem 1rem);
	transform: var(--transform, none);
	display: inline-flex;
	width: fit-content;
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 700;
	font-size: 0.875rem;
	letter-spacing: 0.15em;
	transition: background 0.55s, color 0.55s, border 0.55s;
}

.btn:hover,
html .woocommerce .button:hover,
html .woocommerce button.button:hover,
html .woocommerce button.button.alt:hover,
html .woocommerce button.button.alt.disabled:hover,
html .woocommerce a.button.checkout-button:hover,
html .woof_btn_default:hover,
.linkbtn>a:hover,
html body input[id^="nf-"][type="button"]:hover,
button[type="submit"]:hover,
.hbook-wrapper input[type="submit"]:hover,
input[type="submit"][value="Book now!"]:hover {
	color: var(--hColor, var(--white));
	background: var(--hBackground, var(--primary-800));
	border: var(--hBorder, 2px solid var(--primary-800));
	border-radius: var(--hBorderRadius, 0);
	padding: var(--hPadding, 0.5rem 1rem);
	transform: var(--hTransform, none);
	cursor: pointer;
}

.btn:focus,
html .woocommerce .button:focus,
html .woocommerce button.button:focus,
html .woocommerce button.button.alt:focus,
html .woocommerce button.button.alt.disabled:focus,
html .woocommerce a.button.checkout-button:focus,
html .woof_btn_default:focus,
.linkbtn>a:focus,
html body input[id^="nf-"][type="button"]:focus,
button[type="submit"]:focus,
.hbook-wrapper input[type="submit"]:focus,
input[type="submit"][value="Book now!"]:focus {
	color: var(--fColor, var(--white));
	background: var(--fBackground, var(--primary-800));
	border: var(--fBorder, 2px solid var(--primary-800));
	border-radius: var(--fBorderRadius, 0);
	padding: var(--fPadding, 0.5rem 1rem);
	transform: var(--fTransform, var(--primary-800));
	outline: none;
}

.btn:active,
html .woocommerce .button:active,
html .woocommerce button.button:active,
html .woocommerce button.button.alt:active,
html .woocommerce button.button.alt.disabled:active,
html .woocommerce a.button.checkout-button:active,
html .woof_btn_default:active,
.linkbtn>a:active,
html body input[id^="nf-"][type="button"]:active,
button[type="submit"]:active,
.hbook-wrapper input[type="submit"]:active,
input[type="submit"][value="Book now!"]:active {
	color: var(--aColor, var(--white));
	background: var(--aBackground, var(--primary-800));
	border: var(--aBorder, 2px solid var(--primary-800));
	border-radius: var(--aBorderRadius, 0);
	padding: var(--aPadding, 0.5rem 1rem);
	transform: var(--aTransform, none);
}

.header-button {
	--color: white;
	--hColor: white;
	--fColor: white;
	--aColor: var(--primary-300);
	--background: var(--primary-700);
	--hBackground: var(--primary-800);
	--fBackground: var(--primary-900);
	--aBackground: var(--primary-700);
	--border: none;
	--hBorder: none;
	--fBorder: none;
	--aBorder: none;
	--padding: 0.25rem;
	--hPadding: 0.25rem;
	--fPadding: 0.25rem;
	--aPadding: 0.25rem;
}

.altbtn {
	--color: var(--white);
	--hColor: var(--white);
	--fColor: var(--white);
	--aColor: var(--white);
	--background: var(--primary-700);
	--hBackground: var(--primary-600);
	--fBackground: var(--primary-600);
	--aBackground: var(--primary-600);
	--border: 2px solid var(--primary-700);
	--hBorder: 2px solid var(--primary-600);
	--fBorder: 2px solid var(--primary-600);
	--aBorder: 2px solid var(--primary-600);
}

.black-outline-black-fill {
	--color: var(--black);
	--hColor: var(--white);
	--fColor: var(--white);
	--aColor: var(--white);
	--background: none;
	--hBackground: var(--black);
	--fBackground: var(--black);
	--aBackground: var(--black);
	--border: 2px solid var(--black);
	--hBorder: 2px solid var(--black);
	--fBorder: 2px solid var(--black);
	--aBorder: 2px solid var(--black);
}

.black-fill-black-outline {
	--color: var(--white);
	--hColor: var(--black);
	--fColor: var(--black);
	--aColor: var(--black);
	--background: var(--black);
	--hBackground: none;
	--fBackground: none;
	--aBackground: none;
	--border: 2px solid var(--black);
	--hBorder: 2px solid var(--black);
	--fBorder: 2px solid var(--black);
	--aBorder: 2px solid var(--black);
}

.white-outline-white-fill {
	--color: var(--white);
	--hColor: var(--black);
	--fColor: var(--black);
	--aColor: var(--black);
	--background: none;
	--hBackground: var(--white);
	--fBackground: var(--white);
	--aBackground: var(--white);
	--border: 2px solid var(--white);
	--hBorder: 2px solid var(--white);
	--fBorder: 2px solid var(--white);
	--aBorder: 2px solid var(--white);
}

.white-fill-white-outline {
	--color: var(--black);
	--hColor: var(--white);
	--fColor: var(--white);
	--aColor: var(--white);
	--background: var(--white);
	--hBackground: none;
	--fBackground: none;
	--aBackground: none;
	--border: 2px solid var(--white);
	--hBorder: 2px solid var(--white);
	--fBorder: 2px solid var(--white);
	--aBorder: 2px solid var(--white);
}

.black-outline-white-fill {
	--color: var(--black);
	--hColor: var(--black);
	--fColor: var(--black);
	--aColor: var(--black);
	--background: none;
	--hBackground: var(--white);
	--fBackground: var(--white);
	--aBackground: var(--white);
	--border: 2px solid var(--black);
	--hBorder: 2px solid var(--white);
	--fBorder: 2px solid var(--white);
	--aBorder: 2px solid var(--white);
}

.white-outline-black-fill {
	--color: var(--white);
	--hColor: var(--white);
	--fColor: var(--white);
	--aColor: var(--white);
	--background: none;
	--hBackground: var(--black);
	--fBackground: var(--black);
	--aBackground: var(--black);
	--border: 2px solid var(--white);
	--hBorder: 2px solid var(--black);
	--fBorder: 2px solid var(--black);
	--aBorder: 2px solid var(--black);
}

/* ------------------------------------------------- 
End Buttons
------------------------------------------------- */
/* ------------------------------------------------- 
8.0 Gutenberg Extras
------------------------------------------------- */
.buttons-block {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: var(--bbj);
	align-items: var(--bba);
}

.bbj-start {
	--bbj: start;
}

.bbj-center {
	--bbj: center;
}

.bbj-end {
	--bbj: end;
}

.bba-start {
	--bba: start;
}

.bba-center {
	--bba: center;
}

.bba-end {
	--bba: end;
}

/* ------------------------------------------------- 
End Gutenberg Conditionals
------------------------------------------------- */
.search-form {
	display: grid;
	grid-template-columns: 1fr auto;
	height: fit-content;
}

.search-form .search-field {
	height: 100%;
	width: 100%;
	border: 1px solid var(--gray-200);
	border-radius: 0;
	padding: 0.5rem;
}

.wp-block-search__input {
	border: 1px solid currentColor;
}

hr.wp-block-separator {
	border: none;
	margin-left: auto;
	margin-right: auto;
	height: 1px;
	background: currentColor;
}

/* ------------------------------------------------- 
WooCommerce Styles
------------------------------------------------- */
.wc-block-components-product-image img,
img.pswp__img {
	opacity: 1;
}

/* WC Dashboard Styles */
/* .woocommerce nav.woocommerce-MyAccount-navigation ul {
	padding: 0;
	display: flex;
	list-style: none;
	gap: 0.5rem;
} */

/* Attribute Filter Block */
.wp-block-woocommerce-attribute-filter>.wc-block-attribute-filter {
	display: flex;
	align-items: start;
	margin-bottom: unset;
}

.wp-block-woocommerce-attribute-filter h1,
.wp-block-woocommerce-attribute-filter h2,
.wp-block-woocommerce-attribute-filter h3,
.wp-block-woocommerce-attribute-filter h4,
.wp-block-woocommerce-attribute-filter h5,
.wp-block-woocommerce-attribute-filter h6 {
	font-size: clamp(1.125rem, 1.09rem + 0.18vw, 1.25rem);
}

.wp-block-woocommerce-attribute-filter .wc-block-checkbox-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	row-gap: 0;
	margin-block-start: 1rem;
}

.wp-block-woocommerce-attribute-filter .wc-block-checkbox-list>li {
	display: flex;
	align-items: center;
	gap: 0.25rem;
}

.wp-block-woocommerce-attribute-filter .wc-block-checkbox-list>li>input[type="checkbox"] {
	-webkit-appearance: none;
	appearance: none;
	background-color: #fff;
	margin: 0;
	font: inherit;
	color: currentColor;
	width: 1.5em;
	height: 1.5em;
	border: 1px solid var(--gray-100);
	border-radius: 0;
	transform: translateY(-0.075em);
	display: grid;
	place-content: center;
}

.wp-block-woocommerce-attribute-filter .wc-block-checkbox-list>li>input[type="checkbox"]::before {
	content: "";
	width: 0.65em;
	height: 0.65em;
	transform: scale(0);
	transition: 120ms transform ease-in-out;
	box-shadow: inset 1em 1em var(--primary-400);
	transform-origin: bottom left;
	clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
}

.wp-block-woocommerce-attribute-filter .wc-block-checkbox-list>li>input[type="checkbox"]::outline {
	outline: max(2px, 0.15em) solid currentColor;
	outline-offset: max(2px, 0.15em);
}

.wp-block-woocommerce-attribute-filter .wc-block-checkbox-list>li>input[type="checkbox"]:checked::before {
	transform: scale(1);
}

/* Price Filter Block */
.wp-block-woocommerce-price-filter .wc-block-components-price-slider__range-input-progress {
	--range-color: var(--primary-400);
}

.wp-block-woocommerce-price-filter .wc-block-price-filter__controls input {
	border-color: var(--gray-100) !important;
}

/* Product List */
ul.products {
	padding: 0;
}

.woocommerce ul.products li.product .added_to_cart {
	margin-inline-start: 0.5rem;
}

.woocommerce ul.products li.product img {
	transition: all 0.5s;
}

.woocommerce ul.products li.product:hover img {
	filter: grayscale(0.8);
}

.woocommerce ul.products li.product>a.woocommerce-loop-product__link {
	color: inherit;
}

.woocommerce ul.products li.product .price {
	color: var(--gray-600);
}

.woocommerce-loop-product__title {
	color: inherit;
}

.woocommerce ul.products li.product .button {
	margin-top: 0.25rem;
}

/* Product Page */
.woocommerce-product-details__short-description {
	display: grid;
	gap: 1.5rem;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--primary-600);
}

.single-product .summary.entry-summary {
	display: grid;
	gap: 1.5rem;
}

.single-product .product_meta {
	display: none;
}

button[name="add-to-cart"] {
	height: 100%;
	display: grid;
	align-items: center;
}

/* Login page */
.woocommerce-form-login__rememberme {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

/* Account Pages */
.woocommerce-edit-address .woocommerce-MyAccount-content>p {
	border: 1px solid var(--gray-100);
	padding: 0.5rem;
	margin-block-end: 1rem;
}

/* Gutenberg product grids */
.wc-block-grid__products .wc-block-grid__product-image img {
	width: 100%;
}

.wc-block-grid__product-link {
	text-decoration: none;
	transition: all 0.5s;
	color: inherit;
}

.wc-block-grid__product-link:hover {
	filter: grayscale(0.8);
}

.wc-block-grid__product-title {
	font-size: clamp(1.125rem, 1.09rem + 0.18vw, 1.25rem);
	font-weight: 400;
}

/* ------------------------------------------------- 
End WooCommerce Styles
------------------------------------------------- */

/* Scroll reveal */

.sr {
	transition: transform var(--sr-time, 0.85s) cubic-bezier(0.215, 0.61, 0.355, 1),
		opacity var(--sr-time, 0.85s) cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: var(--sr-delay, 0.1s);
	opacity: 0;
}

.sr-slide-up {
	transform: translateY(50px);
}

.sr-slide-down {
	transform: translateY(-50px);
}

.sr-slide-left {
	transform: translateX(50px);
}

.sr-slide-right {
	transform: translateX(-50px);
}

.sr-t-2 {
	transition-duration: 0.2s;
}

.sr-t-3 {
	transition-duration: 0.3s;
}

.sr-t-4 {
	transition-duration: 0.4s;
}

.sr-t-5 {
	transition-duration: 0.5s;
}

.sr-t-6 {
	transition-duration: 0.6s;
}

.sr-t-7 {
	transition-duration: 0.7s;
}

.sr-t-8 {
	transition-duration: 0.8s;
}

.sr-t-9 {
	transition-duration: 0.9s;
}

.sr-d-2 {
	transition-delay: 0.2s;
}

.sr-d-3 {
	transition-delay: 0.3s;
}

.sr-d-4 {
	transition-delay: 0.4s;
}

.sr-d-5 {
	transition-delay: 0.5s;
}

.sr-d-6 {
	transition-delay: 0.6s;
}

.sr-d-7 {
	transition-delay: 0.7s;
}

.sr-d-8 {
	transition-delay: 0.8s;
}

.sr-d-9 {
	transition-delay: 0.9s;
}

.sr-s-2 {
	--sr-scale: 2;
}

.sr-s-3 {
	--sr-scale: 3;
}

.sr-s-4 {
	--sr-scale: 4;
}

.sr-s-5 {
	--sr-scale: 5;
}

.sr-s-6 {
	--sr-scale: 6;
}

.sr-s-7 {
	--sr-scale: 7;
}

.sr-s-8 {
	--sr-scale: 8;
}

.sr-s-9 {
	--sr-scale: 9;
}

[data-sr-slide] {
	opacity: 1;
	transform: translateY(0);
}

[data-sr-fade] {
	opacity: 1;
}

/* end scroll reveal */

.desktop-nav .btn {
	--padding: 0;
	--hPadding: 0;
	--fPadding: 0;
	--aPadding: 0;
}

.feature-list {
	padding: 0;
	list-style: none;
	columns: 3 14rem;
	gap: 4rem;
	column-rule: 2px solid var(--gray-300);
}

.feature-list>li {
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
	break-inside: avoid;
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.5rem;
}

.feature-list>*+* {
	margin-block-start: 1rem;
}

.feature-list>li::before {
	content: '';
	display: block;
	width: 1rem;
	height: 1rem;
	clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
	background: var(--primary-200);
	transform: translateY(0.25rem);
}

.hb-title.hb-title-search-form {
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--gray-200);
	margin-bottom: 2rem;
}

.hb-search-fields input {
	line-height: 1;
}

.hbook-wrapper .hb-accom-list {
	max-width: unset;
	margin-top: 2rem !important;
}

.hbook-wrapper .hb-accom-list>.hb-accom {
	padding-block: 2rem;
}

.hbook-wrapper .hb-options-form {
	margin-block: 2rem;
}

.hbook-wrapper .hb-options-form .hb-title-extra {
	margin-bottom: 1rem;
}

.hbook-wrapper .hb-options-form .hb-checkbox-wrapper {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.hbook-wrapper .hb-details-fields>.hb-title {
	margin: 2rem 0 1rem;
}

.hbook-wrapper .hb-coupons-area .hb-title-coupons {
	margin-top: 2rem;
}

.hbook-wrapper .hb-coupons-area p.hb-clearfix {
	display: flex;
}

.hbook-wrapper .hb-summary-wrapper {
	margin-top: 2rem;
}

.hbook-wrapper .hb-policies-area>p:first-of-type {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.5rem;
	margin-top: 1rem;
}

.hbook-wrapper .hb-payment-info-wrapper {
	margin-block: 2rem;
}

.hbook-wrapper .hb-payment-info-wrapper>*+* {
	margin-top: 0.75rem;
}

.hbook-wrapper .hb-confirm-button {
	margin: 1rem 0 2rem;
}

.hbook-wrapper .hb-search-submit-wrapper input[type="submit"] {
	width: 100%;
	display: block;
	text-align: center;
}

.hbook-wrapper .hb-bottom-area img {
	width: initial;
	display: initial;
}

.hb-thumbnail-link>img {
	margin-bottom: 1rem;
}

.hb-accom-listing-desc h2 {
	font-size: 1.5rem;
}

.hb-accom-listing-desc h2 a {
	color: inherit;
	text-decoration: underline;
}

.hb-accom-listing-desc>p:last-child {
	margin-top: 1rem;
}

.hb-accom-listing-actions-wrapper {
	margin-top: 1.25rem;
}

.hbook-wrapper .hb-options-form .hb-options-multi-accoms {
	display: grid !important;
}

.hb-options-multi-accoms>.hb-single-option:has(label[for="hb-option-20-multi-accom-1"]) {
	order: -1;
}

.home-collage {
	display: grid;
	--gap: 1rem;
	grid-template-columns: 1fr;
}

.home-collage>div:nth-child(odd)>div {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.home-collage>div:nth-child(2)>div {
	min-height: 35rem;
}

@media (min-width: 768px) {
	.home-collage {
		grid-template-columns: 1fr 1.6fr 1fr;
	}

	.home-collage>div:nth-child(odd)>div {
		grid-template-columns: 1fr;
	}

	.home-collage>div:nth-child(2)>div {
		min-height: unset;
	}
}