/*
Theme Name: Flowio
Author: KingsDesign
Author URI: kingsdesign.com.au
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: 0.3
Text Domain: flowio
*/
/* -- | | \/ { -- */
/* 
*  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
------------------------------------------------- */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
  scroll-padding: 5rem;
}

html {
  scroll-behavior: smooth;
}

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

/* 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 images easier to work with */
img {
  display: block;
  width: 100%;
  height: auto;
  object-position: var(--focus);
  opacity: 0;
  transition: opacity 0.9s;
}

img.loaded {
  opacity: 1;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

button {
  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;
  }
}

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

/* ------------------------------------------------- 
2.0 Font Imports 
------------------------------------------------- */
@font-face {
  font-family: "Bebas";
  src: local("Bebas Neue"), local("Bebas-Neue"),
    url("./fonts/BebasNeue-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

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

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

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

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

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

/* ------------------------------------------------- 
3.0 Custom Properties
------------------------------------------------- */
:root {
  --heading-font: "Bebas", sans-serif;
  --body-font: "MyriadPro", sans-serif;
  --gray-50: #f6f8f8;
  --gray-100: #d7dddf;
  --gray-200: #b8c2c7;
  --gray-300: #98a7ae;
  --gray-400: #798c95;
  --gray-500: #61727a;
  --gray-600: #48555b;
  --gray-700: #343d41;
  --gray-800: #1d2325;
  --gray-900: #121517;
  --primary-50: #f1fdfe;
  --primary-100: #bcf6fb;
  --primary-200: #8fe8ef;
  --primary-300: #63dae3;
  --primary-400: #38d0dc;
  --primary-500: #1bb4c0;
  --primary-600: #0a939e;
  --primary-700: #07676e;
  --primary-800: #043a3e;
  --primary-900: #022426;
  --secondary-50: #f1fdfe;
  --secondary-100: #bcf6fb;
  --secondary-200: #8fe8ef;
  --secondary-300: #63dae3;
  --secondary-400: #38d0dc;
  --secondary-500: #1bb4c0;
  --secondary-600: #0a939e;
  --secondary-700: #07676e;
  --secondary-800: #043a3e;
  --secondary-900: #022426;
  --content-width: 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%;
  --entry-top-margin: 4rem;
  --entry-bottom-margin: 0;
  --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);
  --s-c2: calc(2.5 * 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);
  font-weight: 400;
  line-height: 1.25;
}

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

.fs-2,
h4 {
  font-size: clamp(1.125rem, 1.09rem + 0.18vw, 1.25rem);
}
.fs-3,
h3 {
  font-size: clamp(1.25rem, 1.11rem + 0.71vw, 1.75rem);
}
.fs-4,
h2 {
  font-size: clamp(1.5rem, 1.29rem + 1.07vw, 2.25rem);
}
.fs-5,
h1 {
  font-size: clamp(1.75rem, 1.39rem + 1.79vw, 3rem);
}
.fs-6 {
  font-size: clamp(2.25rem, 1.82rem + 2.14vw, 3.75rem);
}

p,
a {
  line-height: 1.9;
}

.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
-------- */
.theme-header {
  transition: background 0.6s, box-shadow 0.3s;
}

.overlayHeader.enabled {
  position: fixed;
  top: 0;
  z-index: 11;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(3px);
}

.theme-header.enabled:not(.overlayHeader) {
  background: white;
  z-index: 10000;
  width: 100%;
  position: fixed;
  box-shadow: rgb(50 50 93 / 10%) 0px 2px 5px -1px,
    rgb(0 0 0 / 15%) 0px 1px 3px -1px;
}

.overlayHeader {
  position: absolute;
  z-index: 10000;
  width: 100%;
  background: none;
}

.callout {
  color: white;
  text-align: center;
  padding: 0.5rem;
  background: var(--primary-600);
  transition: all 0.6s;
  overflow: hidden;
  max-height: 5rem;
  font-size: 0.875rem;
}

.callout p {
  line-height: 1;
  font-size: 0.875rem;
}

.enabled .callout {
  max-height: 0;
  padding: 0;
}

.enabled .callout > * {
  opacity: 0;
}

.theme-header > .callout > p a {
  color: white;
}

.theme-header > .callout > p a:hover {
  color: var(--primary-100);
}

.header-content {
  width: var(--content-width);
  padding: 1.5rem 0;
  max-width: var(--w-2xl);
  display: flex;
  gap: 2rem;
  justify-content: space-between;
  align-items: center;
  margin: auto;
  transition: padding 0.5s;
}

.enabled .header-content {
  padding: 0.75rem 0;
}

.brand {
  color: var(--primary-700);
  text-decoration: none;
  display: flex;
  align-items: center;
  height: 2rem;
  transition: color 0.4s, height 0.5s;
}

.enabled .brand {
  height: 1.5rem;
}

.overlayHeader .brand {
  color: white;
}

.overlayHeader .brand:hover,
.overlayHeader .brand:active {
  color: var(--primary-600);
}

.logo-text {
  display: none;
  margin-left: 0.5rem;
}

.brand:hover,
.brand:active {
  color: var(--primary-800);
}

.curtain-menu-button {
  display: flex;
  padding: 0.25rem;
}

#curtain-menu {
  visibility: hidden;
  position: fixed;
  z-index: 10001;
  background-color: white;
  color: var(--gray-800);
  height: 100vh;
  width: 0;
  transition: visibility, width 0.3s ease-out;
  overflow-y: scroll;
}

.curtain-button-placer {
  max-width: var(--xxl);
  width: var(--content-width);
  position: relative;
  display: flex;
  justify-content: flex-end;
  margin: auto;
  z-index: 10002;
  top: 1.6em;
  right: 0.45rem;
}

#close-curtain-button {
  opacity: 0;
  transition: opacity 0.3s ease-out;
}

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

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

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

.menu-item a {
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--gray-800);
}

.overlayHeader .menu-item a {
  color: white;
}

.desktop-nav a {
  transition: color 0.3s;
}

.desktop-nav a:hover {
  color: var(--primary-500);
}

.menu-item > a:hover,
a:active {
  text-decoration: underline 1px solid var(--primary-600);
}

#curtain-menu-container .sub-menu {
  margin-left: 1rem;
  margin-top: 0.6rem;
  padding-left: 0.75rem;
  border-left: 2px solid var(--secondary-600);
}

#curtain-menu-container ul.nav {
  padding: 0;
}

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

.desktop-nav {
  margin-right: 1rem;
  display: none;
}

.desktop-nav > div > ul {
  display: flex;
  gap: 1.25rem;
  row-gap: 0.25rem;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.desktop-nav .sub-menu > * + * {
  margin-top: 0.5rem;
}

.desktop-nav .menu-item a {
  letter-spacing: 0.05em;
  font-weight: 600;
  font-size: clamp(0.875rem, 1.5vw, 1.05rem);
  display: block;
}

.desktop-nav .sub-menu {
  visibility: hidden;
  opacity: 0;
  margin-top: 0;
  top: 0;
  transition: opacity 0.4s;
  position: absolute;
  z-index: 11;
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(8px);
  overflow: hidden;
  padding: 0.7rem 2rem;
  border-right: 6px solid var(--secondary-700);
  border-left: 0;
  right: -1rem;
  text-align: end;
  display: flex;
  gap: 0.25rem;
  flex-direction: column;
  align-items: flex-end;
}

.desktop-nav .sub-menu a {
  color: var(--primary-900);
  transition: color 0.3s;
  display: block;
  width: max-content;
  max-width: 13rem;
  line-height: 1.25;
}

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

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

@media screen and (min-width: 48rem) {
  .logo-text {
    display: block;
  }
  .desktop-nav {
    display: block;
  }
  #open-curtain-button {
    display: none;
  }
}

.header-buttons {
  display: flex;
  align-items: center;
}

.header-buttons > * + * {
  margin-left: 1rem;
}

.desktop-nav .menu-item-has-children {
  margin-right: 1rem;
  transition: color 0.3s;
  display: flex;
  line-height: 0.75;
}

.desktop-nav .menu-item-has-children > a {
  transition: color 0.3s;
  line-height: inherit;
}

.desktop-nav .menu-item-has-children:hover > a {
  color: rgba(0, 0, 0, 0);
}

.desktop-nav .menu-item-has-children:hover::after {
  opacity: 0;
}

.desktop-nav .menu-item-has-children::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-left: 0.35rem solid transparent;
  border-right: 0.35rem solid transparent;
  border-top: 0.5rem solid var(--secondary-200);
  position: absolute;
  right: -1rem;
  transition: transform 0.2s, opacity 0.3s;
}

.desktop-nav .menu-item-has-children:hover::after,
.desktop-nav .menu-item-has-children:active::after,
.desktop-nav .menu-item-has-children:focus-within::after {
  transform: rotate(180deg);
}

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

.entry-content {
  padding: var(--entry-top-margin) 0 var(--entry-bottom-margin);
}

.entry-bottom-padding {
  --entry-bottom-margin: 6rem;
}

.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);
}

.wp-block-flowio-section-block a,
footer a {
  color: inherit;
}

/* 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(1),
nf-fields-wrap nf-field:nth-child(4),
nf-fields-wrap nf-field:nth-child(5),
nf-fields-wrap nf-field:last-child {
  grid-column: span 2;
}

html div.nf-field-container {
  margin-bottom: 0;
}
/* --------
End Entry Content
-------- */
/* --------
5.3 Footer
-------- */
.theme-footer {
  background: var(--primary-700);
  color: white;
}

.footer-content {
  display: grid;
  padding: 6rem 0;
  gap: 3rem;
  row-gap: 4.5rem;
}

.theme-footer ul {
  padding: 0;
}

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

.footer-first-col {
  text-align: center;
}

.footer-brand {
  width: clamp(15rem, 8rem + 20vw, 24rem);
  display: block;
  margin: auto;
  color: white;
  transition: color 0.3s;
}

.footer-brand:hover {
  color: var(--primary-400);
}

.footer-content nav .nav > * + * {
  margin-top: 1.25rem;
}

.footer-content nav a {
  color: white;
  transition: color 0.3s;
}

.footer-content nav a:hover {
  color: white;
  color: var(--primary-400);
}

.signup-placer {
  justify-content: center;
}

.icons-container {
  display: flex;
  justify-content: center;
}

.icons-container > * + * {
  margin-left: 0.5rem;
}

.icons-container > a {
  color: white;
  background: var(--primary-600);
  padding: 0.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 9999px;
  transition: color 0.3s, background 0.3s;
}

.icons-container > a:hover,
.icons-container > a:focus {
  background: var(--primary-700);
}

@media screen and (min-width: 38rem) {
  .footer-content {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-first-col {
    grid-column: span 2;
  }
  #mce-EMAIL {
    width: 15rem;
  }
}

@media screen and (min-width: 60rem) {
  .footer-content {
    grid-template-columns: repeat(4, 1fr);
  }
  .footer-first-col {
    text-align: left;
  }
  .footer-brand {
    margin: 0;
  }
  .signup-placer,
  .icons-container {
    justify-content: start;
  }
}

.copyright {
  color: white;
  background-color: var(--gray-700);
  padding: 0.5rem;
  font-size: 0.875rem;
}

.copyright a {
  color: white;
}

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

/* ------------------------------------------------- 
End Areas
------------------------------------------------- */
/* ------------------------------------------------- 
6.0 Utilities
------------------------------------------------- */
/* Flow */
.flow > * + * {
  margin-block-start: var(--flow, 2rem);
}

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

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

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

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

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

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

.flow-xxl {
  --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-2xs {
  margin-block-start: var(--s-2xs);
}

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

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

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

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

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

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

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

.mt-none {
  margin-block-start: 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-c2 {
  padding-block-start: var(--s-c2);
  padding-block-end: var(--s-c2);
}

.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-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;
}
/* ------------------------------------------------- 
End Utilities
------------------------------------------------- */
/* ------------------------------------------------- 
7.0 Buttons
------------------------------------------------- */
html .btn,
html input[type="submit"],
html .linkbtn > a,
html body input[id^="nf-"][type="button"] {
  font-family: var(--heading-font);
  color: var(--color, white);
  background: var(--background, var(--primary-700));
  border: var(--border, 2px solid var(--primary-700));
  border-radius: var(--borderRadius, 0);
  padding: var(--padding, 0.5rem 1rem);
  transform: var(--transform, none);
  display: inline-flex;
  width: max-content;
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 400;
  letter-spacing: 0.15em;
  transition: background 0.55s, color 0.55s, border 0.55s;
}

html .btn:hover,
html input[type="submit"]:hover,
.linkbtn > a:hover,
html body input[id^="nf-"][type="button"]:hover {
  color: var(--hColor, var(--primary-500));
  background: var(--hBackground, none);
  border: var(--hBorder, 2px solid var(--primary-500));
  border-radius: var(--hBorderRadius, 0);
  padding: var(--hPadding, 0.5rem 1rem);
  transform: var(--hTransform, none);
  cursor: pointer;
}

html .btn:focus,
html input[type="submit"]:focus,
.linkbtn > a:focus,
html body input[id^="nf-"][type="button"]:focus {
  color: var(--fColor, var(--primary-500));
  background: var(--fBackground, none);
  border: var(--fBorder, 2px solid var(--primary-500));
  border-radius: var(--fBorderRadius, 0);
  padding: var(--fPadding, 0.5rem 1rem);
  transform: var(--fTransform, none);
  outline: none;
}

html .btn:active,
html input[type="submit"]:active,
.linkbtn > a:active,
html body input[id^="nf-"][type="button"]:active {
  color: var(--aColor, var(--primary-500));
  background: var(--aBackground, none);
  border: var(--aBorder, 2px solid var(--primary-500));
  border-radius: var(--aBorderRadius, 0);
  padding: var(--aPadding, 0.5rem 1rem);
  transform: var(--aTransform, none);
}

.btn-primary-outline {
  --color: white;
  --hColor: var(--primary-400);
  --fColor: var(--primary-600);
  --aColor: var(--seconary-600);
  --background: var(--primary-600);
  --hBackground: none;
  --fBackground: none;
  --aBackground: none;
  --border: 2px solid var(--primary-600);
  --hBorder: 2px solid var(--primary-400);
  --fBorder: 2px solid var(--primary-600);
  --aBorder: 2px solid var(--secondary-900);
  --transform: none;
  --hTransform: none;
  --fTransform: none;
  --aTransform: scale(0.95);
}

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

.header-button-overlay {
  --color: var(--primary-700);
  --hColor: var(--primary-700);
  --fColor: var(--primary-700);
  --aColor: var(--primary-300);
  --background: white;
  --hBackground: var(--primary-50);
  --fBackground: var(--primary-50);
  --aBackground: var(--primary-50);
  --border: none;
  --hBorder: none;
  --fBorder: none;
  --aBorder: none;
  --padding: 0.45rem;
  --hPadding: 0.45rem;
  --fPadding: 0.45rem;
  --aPadding: 0.45rem;
  --transform: none;
  --hTransform: none;
  --fTransform: none;
  margin-left: 0.75rem;
}

.white-outline-primary {
  --color: white;
  --hColor: var(--primary-600);
  --fColor: var(--primary-600);
  --aColor: var(--primary-300);
  --background: none;
  --hBackground: none;
  --fBackground: none;
  --aBackground: none;
  --border: 2px solid white;
  --hBorder: 2px solid var(--primary-600);
  --fBorder: 2px solid var(--primary-600);
  --aBorder: 2px solid var(--primary-600);
  --transform: none;
  --hTransform: none;
  --fTransform: none;
}

.white-fill-gray {
  --color: var(--primary-700);
  --hColor: var(--primary-700);
  --fColor: var(--primary-700);
  --aColor: var(--primary-300);
  --background: white;
  --hBackground: var(--gray-100);
  --fBackground: var(--gray-100);
  --aBackground: var(--gray-100);
  --border: 2px solid white;
  --hBorder: 2px solid var(--gray-100);
  --fBorder: 2px solid var(--gray-100);
  --aBorder: 2px solid var(--gray-100);
  --transform: none;
  --hTransform: none;
  --fTransform: none;
}

.trip-button-fix {
  background: var(--primary-700) !important;
}

.trip-button-fix:hover {
  cursor: pointer;
  background: var(--primary-600) !important;
  color: white !important;
}

.header-button.magnifying {
  --padding: 0.5rem;
  --hPadding: 0.5rem;
  --fPadding: 0.5rem;
  --aPadding: 0.5rem;
  --background: white;
  --hBackground: var(--primary-300);
  --fBackground: var(--primary-300);
  --aBackground: var(--primary-300);
}

.magnifying::after {
  content: "";
  width: 1.375rem;
  aspect-ratio: 1;
  height: 100%;
  background-size: cover;
  background-image: url("data:image/svg+xml, %3Csvg stroke='currentColor' fill='none' stroke-width='0' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z' /%3E%3C/svg%3E");
}
/* ------------------------------------------------- 
End Buttons
------------------------------------------------- */
/* ------------------------------------------------- 
8.0 Gutenberg Conditionals
------------------------------------------------- */
/* Top of Page Blocks */
.entry-content > .first-block-negative-margin:first-child,
.entry-content > .wp-block-lazyblock-trip-banner:first-child {
  margin-block-start: calc(-1 * var(--entry-top-margin));
}
/* ------------------------------------------------- 
End Gutenberg Conditionals
------------------------------------------------- */
.nf-form-layout .nf-form-content {
  padding: 0;
}

.blurbg {
  overflow: hidden;
}

.blurbg > img {
  filter: blur(5px);
  transform: scale(1.15);
}

html .sticker,
.double-sticker .flayout-inner-child {
  position: sticky;
  top: 6rem;
}

html div.imghover {
  overflow: hidden;
}

.imghover > img {
  transition: transform 0.5s ease-out;
}

.imghover:hover > img {
  transform: scale(1.06);
}

.leftbtn.linkbtn {
  width: inherit;
}

.sentinel {
  height: 1px;
  position: absolute;
  top: 2px;
  left: 0;
  right: 0;
  z-index: -999;
}

.holder {
  background: var(--primary-700);
}

div.not-auto-rows > .flowio-layout-inner {
  grid-auto-rows: unset;
}

@media screen and (min-width: 42rem) {
  .wp-block-flowio-split-content.two-one-split {
    grid-template-columns: 2fr 1fr;
  }
}

.home-hero {
  min-height: clamp(40rem, 30rem + 50vh, 100vh);
  clip-path: polygon(50% 96%, 100% 83%, 100% 0, 0 0, 0 83%);
  margin-block-start: -4rem;
}

.home-hero > div.flow {
  height: max-content;
  align-self: center;
  padding: var(--s-c2) 0;
}

.child-hover > .flowio-layout-inner > .wp-block-flowio-inner-content {
  transition: transform 0.3s ease-out;
}

.child-hover > .flowio-layout-inner > .wp-block-flowio-inner-content:hover {
  transform: scale(1.05);
  outline: 1px solid var(--primary-100);
  outline-offset: 1rem;
}

/* 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 */

/* Fixed Badge */
.subscribe-badge {
  position: fixed;
  left: auto;
  top: auto;
  right: 0%;
  bottom: 0%;
  display: block;
  margin-right: 10px;
  margin-bottom: 10px;
  padding: 9px 18px;
  background-color: var(--primary-600);
  border: 2px solid #fff;
  text-transform: uppercase;
  color: #fff;
  text-decoration: none;
  font-family: var(--heading-font);
  letter-spacing: 1px;
  transition: all 500ms;
}

.subscribe-badge:hover {
  background-color: var(--primary-700);
}

/* Modal Popup */
@import url("https://fonts.googleapis.com/css?family=Poppins");

.overlay {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.7);
  transition: opacity 500ms;
  z-index: 99999;
  visibility: hidden;
  opacity: 0;
  /* visibility: visible;
  opacity: 1; */
}

/* .overlay:target {
  visibility: visible;
  opacity: 1;
} */
.overlay.hidden {
  visibility: hidden;
  opacity: 0;
}
.overlay.active {
  visibility: visible;
  opacity: 1;
}
#popup1 {
  font-family: poppins;
  color: black;
}

#popup1 .popup {
  margin: 0px auto;
  /* padding: 3rem min(10vw, 8rem); */
  background: #fff;
  border-radius: 0px;
  width: min(690px, 90%);
  position: relative;
  text-align: center;
  top: 50% !important;
  position: fixed !important;
  z-index: 99;
  -moz-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 0px;
  left: 0;
  max-height: 80vh;
  overflow: auto;
}

/* #popup1 .popup .close {
  position: absolute;
  top: 0px;
  right: 0px;
  transition: all 200ms;
  font-size: 30px;
  font-weight: normal;
  text-decoration: none;
  text-align: center;
  background: #fff;
  border-radius: 0;
  cursor: pointer;
  float: right;
  padding: 0;
  color: var(--primary-600);
  margin-top: 0;
  margin-right: 0;
  height: 40px;
  width: 40px;
  line-height: 45px;
  } */
#popup1 .popup .close {
  color: #000;
  background-color: #fff;
  border: 2px solid #000;
  border-radius: 4px;
  transition: all 0.23s ease-in-out 0s;
  cursor: pointer;
  display: inline-block;
  font-size: 15px;
  font-weight: normal;
  height: 32px;
  line-height: 32px;
  margin: 0 5px 10px 0;
  padding: 0 22px;
  text-align: center;
  text-decoration: none;
  vertical-align: top;
  white-space: nowrap;
  width: fit-content;
}

#popup1 .popup .close:hover {
  background: #000;
  color: #fff;
}

.popup-content--container {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  align-items: center;
}

.popup-content--container input::placeholder {
  font-size: 0.85rem;
}
.modal-img {
  overflow: hidden;
  max-height: 16rem;
}
.modal-img img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  /* margin-top: 3rem; */
  margin-bottom: 2rem;
  object-position: bottom;
}
#mc_embed_signup .mc-field-group.input-group ul {
  display: grid;
  gap: 0.5rem;
  row-gap: 0;
  grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
}
#mc_embed_signup .mc-field-group {
  padding-bottom: 0.5rem;
}

html :where(.editor-styles-wrapper) div.imghover {
  overflow: visible;
}
:where(.editor-styles-wrapper) .home-hero {
  clip-path: unset;
}
