/* https://piccalil.li/blog/a-css-project-boilerplate/ */

.transform{
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
}

.filter{
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
}

/* if logged in, change nav so we can see it */

body.admin-bar {
  /* #wpadminbar {
    opacity: 0.5;
    &:hover {
      opacity: 1;
    }
  } */
}

body.admin-bar .site-header-inner {
    padding-top: 32px;
  }

/* Modern reset: https://piccalil.li/blog/a-more-modern-css-reset/ */

/* Box sizing rules */

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

/* Prevent font size inflation */

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

/* Remove default margin in favour of better control in authored CSS */

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin-block-end: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */

ul[role='list'],
ol[role='list'] {
  list-style: none;
}

/* Set core body defaults */

body {
  min-height: 100vh;
  line-height: 1.5;
}

/* Set shorter line heights on headings and interactive elements */

h1,
h2,
h3,
h4,
button,
input,
label {
  line-height: 1.1;
}

/* Balance text wrapping on headings */

h1,
h2,
h3,
h4 {
  text-wrap: balance;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
  text-decoration-skip-ink: auto;
  color: currentColor;
}

/* Make images easier to work with */

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

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
  font: inherit;
}

/* Make sure textareas without a rows attribute are not tiny */

textarea:not([rows]) {
  min-height: 10em;
}

/* Anything that has been anchored to should have extra scroll margin */

:target {
  scroll-margin-block: 5ex;
}

body {
  margin: 0;
}

/* ============================================================================
   TYPOGRAPHY SYSTEM - Canon's Wharf
   ============================================================================

   Quick Reference - Figma Text Styles:

   NAVIGATION (Proxima Nova Semibold, 16px, UPPERCASE, 10% letter-spacing)
   → .font-navigation or .button

   HEADLINES (Larken Light, -2% letter-spacing):
   → .font-h0  (56-96px fluid)   | Display heading | Supports md:font-h0
   → h1, .h1, .font-h1  (40-64px fluid)   | Page title | Supports md:font-h1
   → h2, .h2, .font-h2  (28-40px fluid)   | Section heading | Supports md:font-h2
   → h3, .h3, .font-h3  (24-32px fluid)   | Subsection heading | Supports md:font-h3
   → h4, .h4, .font-h4  (20-24px fluid)   | Small heading | Supports md:font-h4

   ALL UTILITIES SUPPORT RESPONSIVE PREFIXES: sm:, md:, lg:, xl:, 2xl:

   BODY TEXT (Work Sans Regular, 0 letter-spacing, 1.5 line-height):
   → .font-body-large    (20-24px fluid)
   → .font-body-medium   (16-20px fluid)
   → .font-body-small    (14-16px fluid)
   → .font-body-xsmall   (12px)

   SIZE-ONLY UTILITIES (apply size only, no other properties):
   → .size-step-5   (56-96px)
   → .size-step-4   (40-64px)
   → .size-step-3   (28-40px)
   → .size-step-2   (24-32px)
   → .size-step-1   (20-24px)
   → .size-step-0   (16-20px)
   → .size-step-00  (14-16px)
   → .size-step--1  (12px)

   FONT FAMILY:
   → .font-base     (Proxima Nova) - changed to calibre
   → .font-heading  (Larken)

   FONT WEIGHT:
   → .font-light     (300)
   → .font-regular   (400)
   → .font-medium    (500)
   → .font-semibold  (600)
   → .font-bold      (700)

   ============================================================================ */

body {
  text-rendering: optimizeLegibility !important;
  -webkit-font-smoothing: antialiased !important;
  font-weight: var(--font-regular);
  font-size: var(--size-step-0);
  font-family: var(--font-base);
}

/* Remove user agent top margins from all block-level elements within blocks
   Using :where() for 0 specificity so .flow utility can easily override */

:where([class*="-block"]) h1, :where([class*="-block"]) h2, :where([class*="-block"]) h3, :where([class*="-block"]) h4, :where([class*="-block"]) h5, :where([class*="-block"]) h6, :where([class*="-block"]) p, :where([class*="-block"]) ul, :where([class*="-block"]) ol, :where([class*="-block"]) dl, :where([class*="-block"]) blockquote, :where([class*="-block"]) figure, :where([class*="-block"]) pre, :where([class*="-block"]) hr, :where([class*="-block"]) fieldset {
    margin-top: 0;
  }

/* Links */

a {
  color: var(--color-orange);
}

/* Heading defaults */

:where(h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6) {
  font-family: var(--font-heading);
  font-weight: var(--font-light);
  letter-spacing: -0.02em;
}

/* Specific heading sizes */

h1, .h1, .font-h1 {
  font-size: var(--size-step-4);
  line-height: 1.1;
}

h2, .h2, .font-h2 {
  font-size: var(--size-step-3);
  line-height: 1.2;
}

h3, .h3, .font-h3 {
  font-size: var(--size-step-2);
  line-height: 1.2;
}

h4, .h4, .font-h4 {
  font-size: var(--size-step-1);
  line-height: 1.3;
}

/* ==========================================================================
   RESPONSIVE FONT UTILITIES (Tailwind layer for md:, lg:, etc. support)
   ========================================================================== */

/* Button inherits navigation typography (outside @layer to maintain specificity) */

.button {
  font-family: var(--font-base);
  font-weight: var(--font-semibold);
  font-size: 16px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

:root {
  --gutter: var(--space-s-l);  /* --space-s --space-s-m */
  --transition-base: 250ms ease;
  --transition-movement: 200ms linear;
  --transition-fade: 300ms ease;
  --transition-bounce: 500ms cubic-bezier(0.5, 0.05, 0.2, 1.5);
  --leading-standard: 1.5;

  --nav-height: 70px; /* change */
  --double-nav-height: 140px; /* change */
  --flow-space: var(--space-s);
  --flow-space--half: calc( var(--flow-space) / 2 );
  --flow-space--third: calc( var(--flow-space) / 3 );
  --flow-space--double: calc( var(--flow-space) * 2 );
  --block-spacing: var(--space-xl);
  --block-spacing--double: calc( var(--block-spacing) * 2 );

}

.site-block p {
    margin-bottom: 1rem;
  }

.wp-block-heading {
  margin-top: 2rem;
}

.\!container{
  width: 100% !important;
}

@media (min-width: 330px){

  .\!container{
    max-width: 330px !important;
  }
}

@media (min-width: 760px){

  .\!container{
    max-width: 760px !important;
  }
}

@media (min-width: 1230px){

  .\!container{
    max-width: 1230px !important;
  }
}

:root{
  --color-dark: #030303;
  --color-light: #ffffff;
  --color-black: #000000;
  --color-white: #ffffff;
  --color-green: #73a192;
  --color-yellow: #e6b24c;
  --color-primary: #da7733;
  --color-orange: #da7733;
  --space-zero: clamp(0rem, -0.02rem + 0.11vw, 0.0625rem);
  --space-3xs: clamp(0.3125rem, 0.29rem + 0.11vw, 0.375rem);
  --space-2xs: clamp(0.5625rem, 0.49rem + 0.33vw, 0.75rem);
  --space-xs: clamp(0.875rem, 0.78rem + 0.44vw, 1.125rem);
  --space-s: clamp(1.125rem, 0.99rem + 0.67vw, 1.5rem);
  --space-m: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
  --space-l: clamp(2.25rem, 1.98rem + 1.33vw, 3rem);
  --space-xl: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
  --space-2xl: clamp(4.5rem, 3.95rem + 2.67vw, 6rem);
  --space-3xl: clamp(6.75rem, 5.92rem + 4.00vw, 9rem);
  --space-4xl: clamp(9rem, 7.90rem + 5.33vw, 12rem);
  --space-3xs-2xs: clamp(0.3125rem, 0.15rem + 0.78vw, 0.75rem);
  --space-2xs-xs: clamp(0.5625rem, 0.36rem + 1.00vw, 1.125rem);
  --space-xs-s: clamp(0.875rem, 0.65rem + 1.11vw, 1.5rem);
  --space-s-m: clamp(1.125rem, 0.71rem + 2.00vw, 2.25rem);
  --space-m-l: clamp(1.6875rem, 1.21rem + 2.33vw, 3rem);
  --space-l-xl: clamp(2.25rem, 1.42rem + 4.00vw, 4.5rem);
  --space-xl-2xl: clamp(3.375rem, 2.41rem + 4.67vw, 6rem);
  --space-2xl-3xl: clamp(4.5rem, 2.85rem + 8.00vw, 9rem);
  --space-3xl-4xl: clamp(6.75rem, 4.83rem + 9.33vw, 12rem);
  --space-s-l: clamp(1.125rem, 0.44rem + 3.33vw, 3rem);
  --space-s-xl: clamp(1.125rem, -0.11rem + 6.00vw, 4.5rem);
  --size-step-00: clamp(0.9375rem, 0.91rem + 0.11vw, 1rem);
  --size-step-0: clamp(1.125rem, 1.08rem + 0.22vw, 1.25rem);
  --size-step-1: clamp(1.35rem, 1.27rem + 0.38vw, 1.5625rem);
  --size-step-2: clamp(1.62rem, 1.50rem + 0.59vw, 1.953125rem);
  --size-step-3: clamp(1.94375rem, 1.76rem + 0.88vw, 2.44125rem);
  --size-step-4: clamp(2.44125rem, 2.22rem + 1.09vw, 3.051875rem);
  --size-step-5: clamp(3.424375rem, 2.82rem + 2.92vw, 5.065rem);
  --leading-flat: 1;
  --leading-fine: 1.15;
  --leading-standard: 1.5;
  --leading-loose: 1.7;
  --font-base: Inter,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;
  --font-heading: Larken,serif;
  --font-regular: 400;
  --font-medium: 500;
  --font-bold: 700;
}

/* 
  Global styles 

  Low-specificity, global styles that apply to the whole 
  project: https://cube.fyi/css.html
*/

body {
  background: var(--color-light);
  color: var(--color-black);
  font-size: var(--size-step-0);
  font-family: var(--font-base);
  line-height: var(--leading-standard);
}

ol[role=list], ul[role=list] {
    list-style: none;
    margin-bottom: 0;
    padding: 0;
}

/* STYLING GUIDE */

/* https://photoswipe.com/styling/ */

/*! PhotoSwipe main CSS by Dmytro Semenov | photoswipe.com */

.pswp {
  --pswp-bg: #000;
  --pswp-placeholder-bg: #222;
  

  --pswp-root-z-index: 100000;
  
  --pswp-preloader-color: rgba(79, 79, 79, 0.4);
  --pswp-preloader-color-secondary: rgba(255, 255, 255, 0.9);
  
  /* defined via js:
  --pswp-transition-duration: 333ms; */
  
  --pswp-icon-color: #fff;
  --pswp-icon-color-secondary: #4f4f4f;
  --pswp-icon-stroke-color: #4f4f4f;
  --pswp-icon-stroke-width: 2px;

  --pswp-error-text-color: var(--pswp-icon-color);
}

/*
	Styles for basic PhotoSwipe (pswp) functionality (sliding area, open/close transitions)
*/

.pswp {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: var(--pswp-root-z-index);
	display: none;
	touch-action: none;
	outline: 0;
	opacity: 0.003;
	contain: layout style size;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

/* Prevents focus outline on the root element,
  (it may be focused initially) */

.pswp:focus {
  outline: 0;
}

.pswp * {
  box-sizing: border-box;
}

.pswp img {
  max-width: none;
}

.pswp--open {
	display: block;
}

.pswp,
.pswp__bg {
	transform: translateZ(0);
	will-change: opacity;
}

.pswp__bg {
  opacity: 0.005;
	background: var(--pswp-bg);
}

.pswp,
.pswp__scroll-wrap {
	overflow: hidden;
}

.pswp__scroll-wrap,
.pswp__bg,
.pswp__container,
.pswp__item,
.pswp__content,
.pswp__img,
.pswp__zoom-wrap {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.pswp__img,
.pswp__zoom-wrap {
	width: auto;
	height: auto;
}

.pswp--click-to-zoom.pswp--zoom-allowed .pswp__img {
	cursor: -webkit-zoom-in;
	cursor: -moz-zoom-in;
	cursor: zoom-in;
}

.pswp--click-to-zoom.pswp--zoomed-in .pswp__img {
	cursor: move;
	cursor: -webkit-grab;
	cursor: -moz-grab;
	cursor: grab;
}

.pswp--click-to-zoom.pswp--zoomed-in .pswp__img:active {
  cursor: -webkit-grabbing;
  cursor: -moz-grabbing;
  cursor: grabbing;
}

/* :active to override grabbing cursor */

.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img,
.pswp--no-mouse-drag.pswp--zoomed-in .pswp__img:active,
.pswp__img {
	cursor: -webkit-zoom-out;
	cursor: -moz-zoom-out;
	cursor: zoom-out;
}

/* Prevent selection and tap highlights */

.pswp__container,
.pswp__img,
.pswp__button,
.pswp__counter {
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.pswp__item {
	/* z-index for fade transition */
	z-index: 1;
	overflow: hidden;
}

.pswp__hidden {
	display: none !important;
}

/* Allow to click through pswp__content element, but not its children */

.pswp__content {
  pointer-events: none;
}

.pswp__content > * {
  pointer-events: auto;
}

/*

  PhotoSwipe UI

*/

/*
	Error message appears when image is not loaded
	(JS option errorMsg controls markup)
*/

.pswp__error-msg-container {
  display: grid;
}

.pswp__error-msg {
	margin: auto;
	font-size: 1em;
	line-height: 1;
	color: var(--pswp-error-text-color);
}

/*
class pswp__hide-on-close is applied to elements that
should hide (for example fade out) when PhotoSwipe is closed
and show (for example fade in) when PhotoSwipe is opened
 */

.pswp .pswp__hide-on-close {
	opacity: 0.005;
	will-change: opacity;
	transition: opacity var(--pswp-transition-duration) cubic-bezier(0.4, 0, 0.22, 1);
	z-index: 10; /* always overlap slide content */
	pointer-events: none; /* hidden elements should not be clickable */
}

/* class pswp--ui-visible is added when opening or closing transition starts */

.pswp--ui-visible .pswp__hide-on-close {
	opacity: 1;
	pointer-events: auto;
}

/* <button> styles, including css reset */

.pswp__button {
	position: relative;
	display: block;
	width: 50px;
	height: 60px;
	padding: 0;
	margin: 0;
	overflow: hidden;
	cursor: pointer;
	background: none;
	border: 0;
	box-shadow: none;
	opacity: 0.85;
	-webkit-appearance: none;
	-webkit-touch-callout: none;
}

.pswp__button:hover,
.pswp__button:active,
.pswp__button:focus {
  transition: none;
  padding: 0;
  background: none;
  border: 0;
  box-shadow: none;
  opacity: 1;
}

.pswp__button:disabled {
  opacity: 0.3;
  cursor: auto;
}

.pswp__icn {
  fill: var(--pswp-icon-color);
  color: var(--pswp-icon-color-secondary);
  position: absolute;
  top: 14px;
  left: 9px;
  width: 32px;
  height: 32px;
  overflow: hidden;
  pointer-events: none;
}

.pswp__icn-shadow {
  stroke: var(--pswp-icon-stroke-color);
  stroke-width: var(--pswp-icon-stroke-width);
  fill: none;
}

.pswp__icn:focus {
	outline: 0;
}

/*
	div element that matches size of large image,
	large image loads on top of it,
	used when msrc is not provided
*/

div.pswp__img--placeholder,
.pswp__img--with-bg {
	background: var(--pswp-placeholder-bg);
}

.pswp__top-bar {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 60px;
	display: flex;
  flex-direction: row;
  justify-content: flex-end;
	z-index: 10;

	/* allow events to pass through top bar itself */
	pointer-events: none !important;
}

.pswp__top-bar > * {
  pointer-events: auto;
  /* this makes transition significantly more smooth,
     even though inner elements are not animated */
  will-change: opacity;
}

/*

  Close button

*/

.pswp__button--close {
  margin-right: 6px;
}

/*

  Arrow buttons

*/

.pswp__button--arrow {
  position: absolute;
  top: 0;
  width: 75px;
  height: 100px;
  top: 50%;
  margin-top: -50px;
}

.pswp__button--arrow:disabled {
  display: none;
  cursor: default;
}

.pswp__button--arrow .pswp__icn {
  top: 50%;
  margin-top: -30px;
  width: 60px;
  height: 60px;
  background: none;
  border-radius: 0;
}

.pswp--one-slide .pswp__button--arrow {
  display: none;
}

/* hide arrows on touch screens */

.pswp--touch .pswp__button--arrow {
  visibility: hidden;
}

/* show arrows only after mouse was used */

.pswp--has_mouse .pswp__button--arrow {
  visibility: visible;
}

.pswp__button--arrow--prev {
  right: auto;
  left: 0px;
}

.pswp__button--arrow--next {
  right: 0px;
}

.pswp__button--arrow--next .pswp__icn {
  left: auto;
  right: 14px;
  /* flip horizontally */
  transform: scale(-1, 1);
}

/*

  Zoom button

*/

.pswp__button--zoom {
  display: none;
}

.pswp--zoom-allowed .pswp__button--zoom {
  display: block;
}

/* "+" => "-" */

.pswp--zoomed-in .pswp__zoom-icn-bar-v {
  display: none;
}

/*

  Loading indicator

*/

.pswp__preloader {
  position: relative;
  overflow: hidden;
  width: 50px;
  height: 60px;
  margin-right: auto;
}

.pswp__preloader .pswp__icn {
  opacity: 0;
  transition: opacity 0.2s linear;
  animation: pswp-clockwise 600ms linear infinite;
}

.pswp__preloader--active .pswp__icn {
  opacity: 0.85;
}

@keyframes pswp-clockwise {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/*

  "1 of 10" counter

*/

.pswp__counter {
  height: 30px;
  margin-top: 15px;
  margin-inline-start: 20px;
  font-size: 14px;
  line-height: 30px;
  color: var(--pswp-icon-color);
  text-shadow: 1px 1px 3px var(--pswp-icon-color-secondary);
  opacity: 0.85;
}

.pswp--one-slide .pswp__counter {
  display: none;
}

.glightbox-container {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999999 !important;
  overflow: hidden;
  -ms-touch-action: none;
  touch-action: none;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  outline: none;
}

.glightbox-container.inactive {
  display: none;
}

.glightbox-container .gcontainer {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 9999;
  overflow: hidden;
}

.glightbox-container .gslider {
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
  transition: transform 0.4s ease, -webkit-transform 0.4s ease;
  height: 100%;
  left: 0;
  top: 0;
  width: 100%;
  position: relative;
  overflow: hidden;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.glightbox-container .gslide {
  width: 100%;
  position: absolute;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0;
}

.glightbox-container .gslide.current {
  opacity: 1;
  z-index: 99999;
  position: relative;
}

.glightbox-container .gslide.prev {
  opacity: 1;
  z-index: 9999;
}

.glightbox-container .gslide-inner-content {
  width: 100%;
}

.glightbox-container .ginner-container {
  position: relative;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  max-width: 100%;
  margin: auto;
  height: 100vh;
}

.glightbox-container .ginner-container.gvideo-container {
  width: 100%;
}

.glightbox-container .ginner-container.desc-bottom,
        .glightbox-container .ginner-container.desc-top {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.glightbox-container .ginner-container.desc-left,
        .glightbox-container .ginner-container.desc-right {
  max-width: 100% !important;
}

.gslide iframe,
    .gslide video {
  outline: none !important;
  border: none;
  min-height: 165px;
  -webkit-overflow-scrolling: touch;
  -ms-touch-action: auto;
  touch-action: auto;
}

.gslide:not(.current) {
  pointer-events: none;
}

.gslide-image {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.gslide-image img {
  max-height: 100vh;
  display: block;
  padding: 0;
  float: none;
  outline: none;
  border: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  max-width: 100vw;
  width: auto;
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  -ms-touch-action: none;
  touch-action: none;
  margin: auto;
  min-width: 200px;
}

.desc-top .gslide-image img,
        .desc-bottom .gslide-image img {
  width: auto;
}

.desc-left .gslide-image img,
        .desc-right .gslide-image img {
  width: auto;
  max-width: 100%;
}

.gslide-image img.zoomable {
  position: relative;
}

.gslide-image img.dragging {
  cursor: -webkit-grabbing !important;
  cursor: grabbing !important;
  -webkit-transition: none;
  transition: none;
}

.gslide-video {
  position: relative;
  max-width: 100vh;
  width: 100% !important;
}

.gslide-video .plyr__poster-enabled.plyr--loading .plyr__poster {
  display: none;
}

.gslide-video .gvideo-wrapper {
  width: 100%;
        /* max-width: 160vmin; */
  margin: auto;
}

.gslide-video::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(255, 0, 0, 0.34);
  display: none;
}

.gslide-video.playing::before {
  display: none;
}

.gslide-video.fullscreen {
  max-width: 100% !important;
  min-width: 100%;
  height: 75vh;
}

.gslide-video.fullscreen video {
  max-width: 100% !important;
  width: 100% !important;
}

.gslide-inline {
  background: #fff;
  text-align: left;
  max-height: calc(100vh - 40px);
  overflow: auto;
  max-width: 100%;
  margin: auto;
}

.gslide-inline .ginlined-content {
  padding: 20px;
  width: 100%;
}

.gslide-inline .dragging {
  cursor: -webkit-grabbing !important;
  cursor: grabbing !important;
  -webkit-transition: none;
  transition: none;
}

.ginlined-content {
  overflow: auto;
  display: block !important;
  opacity: 1;
}

.gslide-external {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  min-width: 100%;
  background: #fff;
  padding: 0;
  overflow: auto;
  max-height: 75vh;
  height: 100%;
}

.gslide-media {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: auto;
}

.zoomed .gslide-media {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
}

.desc-top .gslide-media,
    .desc-bottom .gslide-media {
  margin: 0 auto;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.gslide-description {
  position: relative;
  -webkit-box-flex: 1;
  -ms-flex: 1 0 100%;
  flex: 1 0 100%;
}

.gslide-description.description-left,
    .gslide-description.description-right {
  max-width: 100%;
}

.gslide-description.description-bottom,
    .gslide-description.description-top {
  margin: 0 auto;
  width: 100%;
}

.gslide-description p {
  margin-bottom: 12px;
}

.gslide-description p:last-child {
  margin-bottom: 0;
}

.zoomed .gslide-description {
  display: none;
}

.glightbox-button-hidden {
  display: none;
}

/*
 * Description for mobiles
 * something like facebook does the description
 * for the photos
*/

.glightbox-mobile .glightbox-container .gslide-description {
  height: auto !important;
  width: 100%;
  position: absolute;
  bottom: 0;
  padding: 19px 11px;
  max-width: 100vw !important;
  -webkit-box-ordinal-group: 3 !important;
  -ms-flex-order: 2 !important;
  order: 2 !important;
  max-height: 78vh;
  overflow: auto !important;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.75)));
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.75) 100%);
  -webkit-transition: opacity 0.3s linear;
  transition: opacity 0.3s linear;
  padding-bottom: 50px;
}

.glightbox-mobile .glightbox-container .gslide-title {
  color: #fff;
  font-size: 1em;
}

.glightbox-mobile .glightbox-container .gslide-desc {
  color: #a1a1a1;
}

.glightbox-mobile .glightbox-container .gslide-desc a {
  color: #fff;
  font-weight: bold;
}

.glightbox-mobile .glightbox-container .gslide-desc * {
  color: inherit;
}

.glightbox-mobile .glightbox-container .gslide-desc .desc-more {
  color: #fff;
  opacity: 0.4;
}

.gdesc-open .gslide-media {
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  opacity: 0.4;
}

.gdesc-open .gdesc-inner {
  padding-bottom: 30px;
}

.gdesc-closed .gslide-media {
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
  opacity: 1;
}

.greset {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.gabsolute {
  position: absolute;
}

.grelative {
  position: relative;
}

.glightbox-desc {
  display: none !important;
}

.glightbox-open {
  overflow: hidden;
}

.gloader {
  height: 25px;
  width: 25px;
  -webkit-animation: lightboxLoader 0.8s infinite linear;
  animation: lightboxLoader 0.8s infinite linear;
  border: 2px solid #fff;
  border-right-color: transparent;
  border-radius: 50%;
  position: absolute;
  display: block;
  z-index: 9999;
  left: 0;
  right: 0;
  margin: 0 auto;
  top: 47%;
}

.goverlay {
  width: 100%;
  height: calc(100vh + 1px);
  position: fixed;
  top: -1px;
  left: 0;
  background: #000;
  will-change: opacity;
}

.glightbox-mobile .goverlay {
  background: #000;
}

.gprev,
.gnext,
.gclose {
  z-index: 99999;
  cursor: pointer;
  width: 26px;
  height: 44px;
  border: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.gprev svg,
.gnext svg,
.gclose svg {
  display: block;
  width: 25px;
  height: auto;
  margin: 0;
  padding: 0;
}

.gprev.disabled,
.gnext.disabled,
.gclose.disabled {
  opacity: 0.1;
}

.gprev .garrow,
.gnext .garrow,
.gclose .garrow {
  stroke: #fff;
}

.gbtn.focused {
  outline: 2px solid #0f3d81;
}

iframe.wait-autoplay {
  opacity: 0;
}

.glightbox-closing .gnext,
    .glightbox-closing .gprev,
    .glightbox-closing .gclose {
  opacity: 0 !important;
}

/*Skin */

.glightbox-clean .gslide-description {
  background: #fff;
}

.glightbox-clean .gdesc-inner {
  padding: 22px 20px;
}

.glightbox-clean .gslide-title {
  font-size: 1em;
  font-weight: normal;
  font-family: arial;
  color: #000;
  margin-bottom: 19px;
  line-height: 1.4em;
}

.glightbox-clean .gslide-desc {
  font-size: 0.86em;
  margin-bottom: 0;
  font-family: arial;
  line-height: 1.4em;
}

.glightbox-clean .gslide-video {
  background: #000;
}

.glightbox-clean .gprev,
    .glightbox-clean .gnext,
    .glightbox-clean .gclose {
  background-color: rgba(0, 0, 0, 0.75);
  border-radius: 4px;
}

.glightbox-clean .gprev path,
.glightbox-clean .gnext path,
.glightbox-clean .gclose path {
  fill: #fff;
}

.glightbox-clean .gprev {
  position: absolute;
  top: -100%;
  left: 30px;
  width: 40px;
  height: 50px;
}

.glightbox-clean .gnext {
  position: absolute;
  top: -100%;
  right: 30px;
  width: 40px;
  height: 50px;
}

.glightbox-clean .gclose {
  width: 35px;
  height: 35px;
  top: 15px;
  right: 10px;
  position: absolute;
}

.glightbox-clean .gclose svg {
  width: 18px;
  height: auto;
}

.glightbox-clean .gclose:hover {
  opacity: 1;
}

/*CSS Animations*/

.gfadeIn {
  -webkit-animation: gfadeIn 0.5s ease;
  animation: gfadeIn 0.5s ease;
}

.gfadeOut {
  -webkit-animation: gfadeOut 0.5s ease;
  animation: gfadeOut 0.5s ease;
}

.gslideOutLeft {
  -webkit-animation: gslideOutLeft 0.3s ease;
  animation: gslideOutLeft 0.3s ease;
}

.gslideInLeft {
  -webkit-animation: gslideInLeft 0.3s ease;
  animation: gslideInLeft 0.3s ease;
}

.gslideOutRight {
  -webkit-animation: gslideOutRight 0.3s ease;
  animation: gslideOutRight 0.3s ease;
}

.gslideInRight {
  -webkit-animation: gslideInRight 0.3s ease;
  animation: gslideInRight 0.3s ease;
}

.gzoomIn {
  -webkit-animation: gzoomIn 0.5s ease;
  animation: gzoomIn 0.5s ease;
}

.gzoomOut {
  -webkit-animation: gzoomOut 0.5s ease;
  animation: gzoomOut 0.5s ease;
}

@-webkit-keyframes lightboxLoader {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@keyframes lightboxLoader {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@-webkit-keyframes gfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes gfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@-webkit-keyframes gfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

@keyframes gfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

@-webkit-keyframes gslideInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-60%, 0, 0);
    transform: translate3d(-60%, 0, 0);
  }
  to {
    visibility: visible;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes gslideInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-60%, 0, 0);
    transform: translate3d(-60%, 0, 0);
  }
  to {
    visibility: visible;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@-webkit-keyframes gslideOutLeft {
  from {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  to {
    -webkit-transform: translate3d(-60%, 0, 0);
    transform: translate3d(-60%, 0, 0);
    opacity: 0;
    visibility: hidden;
  }
}

@keyframes gslideOutLeft {
  from {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  to {
    -webkit-transform: translate3d(-60%, 0, 0);
    transform: translate3d(-60%, 0, 0);
    opacity: 0;
    visibility: hidden;
  }
}

@-webkit-keyframes gslideInRight {
  from {
    opacity: 0;
    visibility: visible;
    -webkit-transform: translate3d(60%, 0, 0);
    transform: translate3d(60%, 0, 0);
  }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes gslideInRight {
  from {
    opacity: 0;
    visibility: visible;
    -webkit-transform: translate3d(60%, 0, 0);
    transform: translate3d(60%, 0, 0);
  }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@-webkit-keyframes gslideOutRight {
  from {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  to {
    -webkit-transform: translate3d(60%, 0, 0);
    transform: translate3d(60%, 0, 0);
    opacity: 0;
  }
}

@keyframes gslideOutRight {
  from {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  to {
    -webkit-transform: translate3d(60%, 0, 0);
    transform: translate3d(60%, 0, 0);
    opacity: 0;
  }
}

@-webkit-keyframes gzoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 1;
  }
}

@keyframes gzoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 1;
  }
}

@-webkit-keyframes gzoomOut {
  from {
    opacity: 1;
  }
  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 0;
  }
}

@keyframes gzoomOut {
  from {
    opacity: 1;
  }
  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 0;
  }
}

@media (min-width: 769px) {
  .glightbox-container .ginner-container {
    width: auto;
    height: auto;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }
  .glightbox-container .ginner-container.desc-top .gslide-description {
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }
  .glightbox-container .ginner-container.desc-top .gslide-image,
                .glightbox-container .ginner-container.desc-top .gslide-image img {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
  .glightbox-container .ginner-container.desc-left .gslide-description {
    -webkit-box-ordinal-group: 1;
    -ms-flex-order: 0;
    order: 0;
  }
  .glightbox-container .ginner-container.desc-left .gslide-image {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
  .gslide-image img {
    max-height: 97vh;
    max-width: 100%;
  }
  .gslide-image img.zoomable {
    cursor: -webkit-zoom-in;
    cursor: zoom-in;
  }
  .zoomed .gslide-image img.zoomable {
    cursor: -webkit-grab;
    cursor: grab;
  }
  .gslide-inline {
    max-height: 95vh;
  }
  .gslide-external {
    max-height: 100vh;
  }
  .gslide-description.description-left,
    .gslide-description.description-right {
    max-width: 275px;
  }
  .glightbox-open {
    height: auto;
  }
  .goverlay {
    background: rgba(0, 0, 0, 0.92);
  }
  .glightbox-clean .gslide-media {
    -webkit-box-shadow: 1px 2px 9px 0px rgba(0, 0, 0, 0.65);
    box-shadow: 1px 2px 9px 0px rgba(0, 0, 0, 0.65);
  }
  .glightbox-clean .description-left .gdesc-inner,
.glightbox-clean .description-right .gdesc-inner {
    position: absolute;
    height: 100%;
    overflow-y: auto;
  }
  .glightbox-clean .gprev,
    .glightbox-clean .gnext,
    .glightbox-clean .gclose {
    background-color: rgba(0, 0, 0, 0.32);
  }
  .glightbox-clean .gprev:hover,
.glightbox-clean .gnext:hover,
.glightbox-clean .gclose:hover {
    background-color: rgba(0, 0, 0, 0.7);
  }
  .glightbox-clean .gprev {
    top: 45%;
  }
  .glightbox-clean .gnext {
    top: 45%;
  }
}

@media (min-width: 992px) {
  .glightbox-clean .gclose {
    opacity: 0.7;
    right: 20px;
  }
}

@media screen and (max-height: 420px) {
  .goverlay {
    background: #000;
  }
}

/*!
 * Hamburgers
 * @description Tasty CSS-animated hamburgers
 * @author Jonathan Suh @jonsuh
 * @site https://jonsuh.com/hamburgers
 * @link https://github.com/jonsuh/hamburgers
 */

.hamburger {
  padding: 15px 15px;
  display: inline-block;
  cursor: pointer;
  transition-property: opacity, filter;
  transition-duration: 0.15s;
  transition-timing-function: linear;
  font: inherit;
  color: inherit;
  text-transform: none;
  background-color: transparent;
  border: 0;
  margin: 0;
  overflow: visible; }

.hamburger:hover {
    opacity: 0.7; }

.hamburger.is-active:hover {
    opacity: 0.7; }

.hamburger.is-active .hamburger-inner,
  .hamburger.is-active .hamburger-inner::before,
  .hamburger.is-active .hamburger-inner::after {
    background-color: #000; }

.hamburger-box {
  width: 40px;
  height: 24px;
  display: inline-block;
  position: relative; }

.hamburger-inner {
  display: block;
  top: 50%;
  margin-top: -2px; }

.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
    width: 40px;
    height: 4px;
    background-color: #000;
    border-radius: 4px;
    position: absolute;
    transition-property: transform;
    transition-duration: 0.15s;
    transition-timing-function: ease; }

.hamburger-inner::before, .hamburger-inner::after {
    content: "";
    display: block; }

.hamburger-inner::before {
    top: -10px; }

.hamburger-inner::after {
    bottom: -10px; }

/*
   * 3DX
   */

.hamburger--3dx .hamburger-box {
  perspective: 80px; }

.hamburger--3dx .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dx .hamburger-inner::before, .hamburger--3dx .hamburger-inner::after {
    transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dx.is-active .hamburger-inner {
  background-color: transparent !important;
  transform: rotateY(180deg); }

.hamburger--3dx.is-active .hamburger-inner::before {
    transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--3dx.is-active .hamburger-inner::after {
    transform: translate3d(0, -10px, 0) rotate(-45deg); }

/*
   * 3DX Reverse
   */

.hamburger--3dx-r .hamburger-box {
  perspective: 80px; }

.hamburger--3dx-r .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dx-r .hamburger-inner::before, .hamburger--3dx-r .hamburger-inner::after {
    transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dx-r.is-active .hamburger-inner {
  background-color: transparent !important;
  transform: rotateY(-180deg); }

.hamburger--3dx-r.is-active .hamburger-inner::before {
    transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--3dx-r.is-active .hamburger-inner::after {
    transform: translate3d(0, -10px, 0) rotate(-45deg); }

/*
   * 3DY
   */

.hamburger--3dy .hamburger-box {
  perspective: 80px; }

.hamburger--3dy .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dy .hamburger-inner::before, .hamburger--3dy .hamburger-inner::after {
    transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dy.is-active .hamburger-inner {
  background-color: transparent !important;
  transform: rotateX(-180deg); }

.hamburger--3dy.is-active .hamburger-inner::before {
    transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--3dy.is-active .hamburger-inner::after {
    transform: translate3d(0, -10px, 0) rotate(-45deg); }

/*
   * 3DY Reverse
   */

.hamburger--3dy-r .hamburger-box {
  perspective: 80px; }

.hamburger--3dy-r .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dy-r .hamburger-inner::before, .hamburger--3dy-r .hamburger-inner::after {
    transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dy-r.is-active .hamburger-inner {
  background-color: transparent !important;
  transform: rotateX(180deg); }

.hamburger--3dy-r.is-active .hamburger-inner::before {
    transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--3dy-r.is-active .hamburger-inner::after {
    transform: translate3d(0, -10px, 0) rotate(-45deg); }

/*
   * 3DXY
   */

.hamburger--3dxy .hamburger-box {
  perspective: 80px; }

.hamburger--3dxy .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dxy .hamburger-inner::before, .hamburger--3dxy .hamburger-inner::after {
    transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dxy.is-active .hamburger-inner {
  background-color: transparent !important;
  transform: rotateX(180deg) rotateY(180deg); }

.hamburger--3dxy.is-active .hamburger-inner::before {
    transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--3dxy.is-active .hamburger-inner::after {
    transform: translate3d(0, -10px, 0) rotate(-45deg); }

/*
   * 3DXY Reverse
   */

.hamburger--3dxy-r .hamburger-box {
  perspective: 80px; }

.hamburger--3dxy-r .hamburger-inner {
  transition: transform 0.15s cubic-bezier(0.645, 0.045, 0.355, 1), background-color 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dxy-r .hamburger-inner::before, .hamburger--3dxy-r .hamburger-inner::after {
    transition: transform 0s 0.1s cubic-bezier(0.645, 0.045, 0.355, 1); }

.hamburger--3dxy-r.is-active .hamburger-inner {
  background-color: transparent !important;
  transform: rotateX(180deg) rotateY(180deg) rotateZ(-180deg); }

.hamburger--3dxy-r.is-active .hamburger-inner::before {
    transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--3dxy-r.is-active .hamburger-inner::after {
    transform: translate3d(0, -10px, 0) rotate(-45deg); }

/*
   * Arrow
   */

.hamburger--arrow.is-active .hamburger-inner::before {
  transform: translate3d(-8px, 0, 0) rotate(-45deg) scale(0.7, 1); }

.hamburger--arrow.is-active .hamburger-inner::after {
  transform: translate3d(-8px, 0, 0) rotate(45deg) scale(0.7, 1); }

/*
   * Arrow Right
   */

.hamburger--arrow-r.is-active .hamburger-inner::before {
  transform: translate3d(8px, 0, 0) rotate(45deg) scale(0.7, 1); }

.hamburger--arrow-r.is-active .hamburger-inner::after {
  transform: translate3d(8px, 0, 0) rotate(-45deg) scale(0.7, 1); }

/*
   * Arrow Alt
   */

.hamburger--arrowalt .hamburger-inner::before {
  transition: top 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1); }

.hamburger--arrowalt .hamburger-inner::after {
  transition: bottom 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1); }

.hamburger--arrowalt.is-active .hamburger-inner::before {
  top: 0;
  transform: translate3d(-8px, -10px, 0) rotate(-45deg) scale(0.7, 1);
  transition: top 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22); }

.hamburger--arrowalt.is-active .hamburger-inner::after {
  bottom: 0;
  transform: translate3d(-8px, 10px, 0) rotate(45deg) scale(0.7, 1);
  transition: bottom 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22); }

/*
   * Arrow Alt Right
   */

.hamburger--arrowalt-r .hamburger-inner::before {
  transition: top 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1); }

.hamburger--arrowalt-r .hamburger-inner::after {
  transition: bottom 0.1s 0.1s ease, transform 0.1s cubic-bezier(0.165, 0.84, 0.44, 1); }

.hamburger--arrowalt-r.is-active .hamburger-inner::before {
  top: 0;
  transform: translate3d(8px, -10px, 0) rotate(45deg) scale(0.7, 1);
  transition: top 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22); }

.hamburger--arrowalt-r.is-active .hamburger-inner::after {
  bottom: 0;
  transform: translate3d(8px, 10px, 0) rotate(-45deg) scale(0.7, 1);
  transition: bottom 0.1s ease, transform 0.1s 0.1s cubic-bezier(0.895, 0.03, 0.685, 0.22); }

/*
   * Arrow Turn
   */

.hamburger--arrowturn.is-active .hamburger-inner {
  transform: rotate(-180deg); }

.hamburger--arrowturn.is-active .hamburger-inner::before {
    transform: translate3d(8px, 0, 0) rotate(45deg) scale(0.7, 1); }

.hamburger--arrowturn.is-active .hamburger-inner::after {
    transform: translate3d(8px, 0, 0) rotate(-45deg) scale(0.7, 1); }

/*
   * Arrow Turn Right
   */

.hamburger--arrowturn-r.is-active .hamburger-inner {
  transform: rotate(-180deg); }

.hamburger--arrowturn-r.is-active .hamburger-inner::before {
    transform: translate3d(-8px, 0, 0) rotate(-45deg) scale(0.7, 1); }

.hamburger--arrowturn-r.is-active .hamburger-inner::after {
    transform: translate3d(-8px, 0, 0) rotate(45deg) scale(0.7, 1); }

/*
   * Boring
   */

.hamburger--boring .hamburger-inner, .hamburger--boring .hamburger-inner::before, .hamburger--boring .hamburger-inner::after {
  transition-property: none; }

.hamburger--boring.is-active .hamburger-inner {
  transform: rotate(45deg); }

.hamburger--boring.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0; }

.hamburger--boring.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(-90deg); }

/*
   * Collapse
   */

.hamburger--collapse .hamburger-inner {
  top: auto;
  bottom: 0;
  transition-duration: 0.13s;
  transition-delay: 0.13s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--collapse .hamburger-inner::after {
    top: -20px;
    transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), opacity 0.1s linear; }

.hamburger--collapse .hamburger-inner::before {
    transition: top 0.12s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--collapse.is-active .hamburger-inner {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
  transition-delay: 0.22s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--collapse.is-active .hamburger-inner::after {
    top: 0;
    opacity: 0;
    transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), opacity 0.1s 0.22s linear; }

.hamburger--collapse.is-active .hamburger-inner::before {
    top: 0;
    transform: rotate(-90deg);
    transition: top 0.1s 0.16s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.25s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Collapse Reverse
   */

.hamburger--collapse-r .hamburger-inner {
  top: auto;
  bottom: 0;
  transition-duration: 0.13s;
  transition-delay: 0.13s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--collapse-r .hamburger-inner::after {
    top: -20px;
    transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), opacity 0.1s linear; }

.hamburger--collapse-r .hamburger-inner::before {
    transition: top 0.12s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--collapse-r.is-active .hamburger-inner {
  transform: translate3d(0, -10px, 0) rotate(45deg);
  transition-delay: 0.22s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--collapse-r.is-active .hamburger-inner::after {
    top: 0;
    opacity: 0;
    transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), opacity 0.1s 0.22s linear; }

.hamburger--collapse-r.is-active .hamburger-inner::before {
    top: 0;
    transform: rotate(90deg);
    transition: top 0.1s 0.16s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.25s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Elastic
   */

.hamburger--elastic .hamburger-inner {
  top: 2px;
  transition-duration: 0.275s;
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55); }

.hamburger--elastic .hamburger-inner::before {
    top: 10px;
    transition: opacity 0.125s 0.275s ease; }

.hamburger--elastic .hamburger-inner::after {
    top: 20px;
    transition: transform 0.275s cubic-bezier(0.68, -0.55, 0.265, 1.55); }

.hamburger--elastic.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(135deg);
  transition-delay: 0.075s; }

.hamburger--elastic.is-active .hamburger-inner::before {
    transition-delay: 0s;
    opacity: 0; }

.hamburger--elastic.is-active .hamburger-inner::after {
    transform: translate3d(0, -20px, 0) rotate(-270deg);
    transition-delay: 0.075s; }

/*
   * Elastic Reverse
   */

.hamburger--elastic-r .hamburger-inner {
  top: 2px;
  transition-duration: 0.275s;
  transition-timing-function: cubic-bezier(0.68, -0.55, 0.265, 1.55); }

.hamburger--elastic-r .hamburger-inner::before {
    top: 10px;
    transition: opacity 0.125s 0.275s ease; }

.hamburger--elastic-r .hamburger-inner::after {
    top: 20px;
    transition: transform 0.275s cubic-bezier(0.68, -0.55, 0.265, 1.55); }

.hamburger--elastic-r.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(-135deg);
  transition-delay: 0.075s; }

.hamburger--elastic-r.is-active .hamburger-inner::before {
    transition-delay: 0s;
    opacity: 0; }

.hamburger--elastic-r.is-active .hamburger-inner::after {
    transform: translate3d(0, -20px, 0) rotate(270deg);
    transition-delay: 0.075s; }

/*
   * Emphatic
   */

.hamburger--emphatic {
  overflow: hidden; }

.hamburger--emphatic .hamburger-inner {
    transition: background-color 0.125s 0.175s ease-in; }

.hamburger--emphatic .hamburger-inner::before {
      left: 0;
      transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, left 0.125s 0.175s ease-in; }

.hamburger--emphatic .hamburger-inner::after {
      top: 10px;
      right: 0;
      transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, right 0.125s 0.175s ease-in; }

.hamburger--emphatic.is-active .hamburger-inner {
    transition-delay: 0s;
    transition-timing-function: ease-out;
    background-color: transparent !important; }

.hamburger--emphatic.is-active .hamburger-inner::before {
      left: -80px;
      top: -80px;
      transform: translate3d(80px, 80px, 0) rotate(45deg);
      transition: left 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1); }

.hamburger--emphatic.is-active .hamburger-inner::after {
      right: -80px;
      top: -80px;
      transform: translate3d(-80px, 80px, 0) rotate(-45deg);
      transition: right 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1); }

/*
   * Emphatic Reverse
   */

.hamburger--emphatic-r {
  overflow: hidden; }

.hamburger--emphatic-r .hamburger-inner {
    transition: background-color 0.125s 0.175s ease-in; }

.hamburger--emphatic-r .hamburger-inner::before {
      left: 0;
      transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, left 0.125s 0.175s ease-in; }

.hamburger--emphatic-r .hamburger-inner::after {
      top: 10px;
      right: 0;
      transition: transform 0.125s cubic-bezier(0.6, 0.04, 0.98, 0.335), top 0.05s 0.125s linear, right 0.125s 0.175s ease-in; }

.hamburger--emphatic-r.is-active .hamburger-inner {
    transition-delay: 0s;
    transition-timing-function: ease-out;
    background-color: transparent !important; }

.hamburger--emphatic-r.is-active .hamburger-inner::before {
      left: -80px;
      top: 80px;
      transform: translate3d(80px, -80px, 0) rotate(-45deg);
      transition: left 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1); }

.hamburger--emphatic-r.is-active .hamburger-inner::after {
      right: -80px;
      top: 80px;
      transform: translate3d(-80px, -80px, 0) rotate(45deg);
      transition: right 0.125s ease-out, top 0.05s 0.125s linear, transform 0.125s 0.175s cubic-bezier(0.075, 0.82, 0.165, 1); }

/*
   * Minus
   */

.hamburger--minus .hamburger-inner::before, .hamburger--minus .hamburger-inner::after {
  transition: bottom 0.08s 0s ease-out, top 0.08s 0s ease-out, opacity 0s linear; }

.hamburger--minus.is-active .hamburger-inner::before, .hamburger--minus.is-active .hamburger-inner::after {
  opacity: 0;
  transition: bottom 0.08s ease-out, top 0.08s ease-out, opacity 0s 0.08s linear; }

.hamburger--minus.is-active .hamburger-inner::before {
  top: 0; }

.hamburger--minus.is-active .hamburger-inner::after {
  bottom: 0; }

/*
   * Slider
   */

.hamburger--slider .hamburger-inner {
  top: 2px; }

.hamburger--slider .hamburger-inner::before {
    top: 10px;
    transition-property: transform, opacity;
    transition-timing-function: ease;
    transition-duration: 0.15s; }

.hamburger--slider .hamburger-inner::after {
    top: 20px; }

.hamburger--slider.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--slider.is-active .hamburger-inner::before {
    transform: rotate(-45deg) translate3d(-5.71429px, -6px, 0);
    opacity: 0; }

.hamburger--slider.is-active .hamburger-inner::after {
    transform: translate3d(0, -20px, 0) rotate(-90deg); }

/*
   * Slider Reverse
   */

.hamburger--slider-r .hamburger-inner {
  top: 2px; }

.hamburger--slider-r .hamburger-inner::before {
    top: 10px;
    transition-property: transform, opacity;
    transition-timing-function: ease;
    transition-duration: 0.15s; }

.hamburger--slider-r .hamburger-inner::after {
    top: 20px; }

.hamburger--slider-r.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(-45deg); }

.hamburger--slider-r.is-active .hamburger-inner::before {
    transform: rotate(45deg) translate3d(5.71429px, -6px, 0);
    opacity: 0; }

.hamburger--slider-r.is-active .hamburger-inner::after {
    transform: translate3d(0, -20px, 0) rotate(90deg); }

/*
   * Spin
   */

.hamburger--spin .hamburger-inner {
  transition-duration: 0.22s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spin .hamburger-inner::before {
    transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in; }

.hamburger--spin .hamburger-inner::after {
    transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spin.is-active .hamburger-inner {
  transform: rotate(225deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--spin.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0;
    transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out; }

.hamburger--spin.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(-90deg);
    transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Spin Reverse
   */

.hamburger--spin-r .hamburger-inner {
  transition-duration: 0.22s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spin-r .hamburger-inner::before {
    transition: top 0.1s 0.25s ease-in, opacity 0.1s ease-in; }

.hamburger--spin-r .hamburger-inner::after {
    transition: bottom 0.1s 0.25s ease-in, transform 0.22s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spin-r.is-active .hamburger-inner {
  transform: rotate(-225deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--spin-r.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0;
    transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out; }

.hamburger--spin-r.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(90deg);
    transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Spring
   */

.hamburger--spring .hamburger-inner {
  top: 2px;
  transition: background-color 0s 0.13s linear; }

.hamburger--spring .hamburger-inner::before {
    top: 10px;
    transition: top 0.1s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spring .hamburger-inner::after {
    top: 20px;
    transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spring.is-active .hamburger-inner {
  transition-delay: 0.22s;
  background-color: transparent !important; }

.hamburger--spring.is-active .hamburger-inner::before {
    top: 0;
    transition: top 0.1s 0.15s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 10px, 0) rotate(45deg); }

.hamburger--spring.is-active .hamburger-inner::after {
    top: 0;
    transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 10px, 0) rotate(-45deg); }

/*
   * Spring Reverse
   */

.hamburger--spring-r .hamburger-inner {
  top: auto;
  bottom: 0;
  transition-duration: 0.13s;
  transition-delay: 0s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spring-r .hamburger-inner::after {
    top: -20px;
    transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), opacity 0s linear; }

.hamburger--spring-r .hamburger-inner::before {
    transition: top 0.1s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1), transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--spring-r.is-active .hamburger-inner {
  transform: translate3d(0, -10px, 0) rotate(-45deg);
  transition-delay: 0.22s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--spring-r.is-active .hamburger-inner::after {
    top: 0;
    opacity: 0;
    transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333), opacity 0s 0.22s linear; }

.hamburger--spring-r.is-active .hamburger-inner::before {
    top: 0;
    transform: rotate(90deg);
    transition: top 0.1s 0.15s cubic-bezier(0.33333, 0, 0.66667, 0.33333), transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Stand
   */

.hamburger--stand .hamburger-inner {
  transition: transform 0.075s 0.15s cubic-bezier(0.55, 0.055, 0.675, 0.19), background-color 0s 0.075s linear; }

.hamburger--stand .hamburger-inner::before {
    transition: top 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--stand .hamburger-inner::after {
    transition: bottom 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--stand.is-active .hamburger-inner {
  transform: rotate(90deg);
  background-color: transparent !important;
  transition: transform 0.075s 0s cubic-bezier(0.215, 0.61, 0.355, 1), background-color 0s 0.15s linear; }

.hamburger--stand.is-active .hamburger-inner::before {
    top: 0;
    transform: rotate(-45deg);
    transition: top 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--stand.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(45deg);
    transition: bottom 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Stand Reverse
   */

.hamburger--stand-r .hamburger-inner {
  transition: transform 0.075s 0.15s cubic-bezier(0.55, 0.055, 0.675, 0.19), background-color 0s 0.075s linear; }

.hamburger--stand-r .hamburger-inner::before {
    transition: top 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--stand-r .hamburger-inner::after {
    transition: bottom 0.075s 0.075s ease-in, transform 0.075s 0s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--stand-r.is-active .hamburger-inner {
  transform: rotate(-90deg);
  background-color: transparent !important;
  transition: transform 0.075s 0s cubic-bezier(0.215, 0.61, 0.355, 1), background-color 0s 0.15s linear; }

.hamburger--stand-r.is-active .hamburger-inner::before {
    top: 0;
    transform: rotate(-45deg);
    transition: top 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--stand-r.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(45deg);
    transition: bottom 0.075s 0.1s ease-out, transform 0.075s 0.15s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Squeeze
   */

.hamburger--squeeze .hamburger-inner {
  transition-duration: 0.075s;
  transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--squeeze .hamburger-inner::before {
    transition: top 0.075s 0.12s ease, opacity 0.075s ease; }

.hamburger--squeeze .hamburger-inner::after {
    transition: bottom 0.075s 0.12s ease, transform 0.075s cubic-bezier(0.55, 0.055, 0.675, 0.19); }

.hamburger--squeeze.is-active .hamburger-inner {
  transform: rotate(45deg);
  transition-delay: 0.12s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }

.hamburger--squeeze.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0;
    transition: top 0.075s ease, opacity 0.075s 0.12s ease; }

.hamburger--squeeze.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(-90deg);
    transition: bottom 0.075s ease, transform 0.075s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1); }

/*
   * Vortex
   */

.hamburger--vortex .hamburger-inner {
  transition-duration: 0.2s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1); }

.hamburger--vortex .hamburger-inner::before, .hamburger--vortex .hamburger-inner::after {
    transition-duration: 0s;
    transition-delay: 0.1s;
    transition-timing-function: linear; }

.hamburger--vortex .hamburger-inner::before {
    transition-property: top, opacity; }

.hamburger--vortex .hamburger-inner::after {
    transition-property: bottom, transform; }

.hamburger--vortex.is-active .hamburger-inner {
  transform: rotate(765deg);
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1); }

.hamburger--vortex.is-active .hamburger-inner::before, .hamburger--vortex.is-active .hamburger-inner::after {
    transition-delay: 0s; }

.hamburger--vortex.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0; }

.hamburger--vortex.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(90deg); }

/*
   * Vortex Reverse
   */

.hamburger--vortex-r .hamburger-inner {
  transition-duration: 0.2s;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1); }

.hamburger--vortex-r .hamburger-inner::before, .hamburger--vortex-r .hamburger-inner::after {
    transition-duration: 0s;
    transition-delay: 0.1s;
    transition-timing-function: linear; }

.hamburger--vortex-r .hamburger-inner::before {
    transition-property: top, opacity; }

.hamburger--vortex-r .hamburger-inner::after {
    transition-property: bottom, transform; }

.hamburger--vortex-r.is-active .hamburger-inner {
  transform: rotate(-765deg);
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1); }

.hamburger--vortex-r.is-active .hamburger-inner::before, .hamburger--vortex-r.is-active .hamburger-inner::after {
    transition-delay: 0s; }

.hamburger--vortex-r.is-active .hamburger-inner::before {
    top: 0;
    opacity: 0; }

.hamburger--vortex-r.is-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(-90deg); }

/* offside-js 1.4.0 26-03-2018
* Minimal JavaScript kit without library dependencies to push things off-canvas using just class manipulation
* https://github.com/toomuchdesign/offside.git
*
* by Andrea Carraro
* Available under the MIT license
*/

:root {
  --offside-width: 400px;  /* --space-s --space-s-m */
  --offside-inverted-width: -400px;  /* --space-s --space-s-m */
  --offside-width--desktop: 800px;  /* --space-s --space-s-m */
  --offside-inverted-width--desktop: -800px;  /* --space-s --space-s-m */
  /* for really small screens.. */
  --offside-max-width: 80vw;  /* --space-s --space-s-m */
}

/* When site loads, nav appears briefly before being hidden by offside. Adding in a class to hide this unwanted flash */

.off-canvas {
    display: none;
}

.offside-js--init .off-canvas {
        display: block;
    }

/* Off-canvas element CSS */

.offside {
    position: fixed; /* Does not play well with some old browsers (see: README) */
    width: var(--offside-width);
    max-width: var(--offside-max-width);
    height: 100%;
    top: 0;
    z-index: 9999;
    overflow: auto;
    -webkit-overflow-scrolling: touch; /* enables momentum scrolling in iOS overflow elements */
}

/* Left off-canvas elements default status: out of the page */

.offside,
.offside--left {
    left: var(--offside-inverted-width);
}

/* Right off-canvas elements default status: out of the page */

.offside,
.offside--right {
    left: auto;
    right: var(--offside-inverted-width);
}

/*
 * Left off-canvas element is open:
 * - off-canvas element slides in
 * - container elements slides out
 */

.offside--left.is-open,
.offside-js--is-left .offside-sliding-element {
    -webkit-transform: translate3d(var(--offside-width), 0, 0);
    -moz-transform: translate3d(var(--offside-width), 0, 0);
    -ms-transform: translate3d(var(--offside-width), 0, 0);
    -o-transform: translate3d(var(--offside-width), 0, 0);
    transform: translate3d(var(--offside-width), 0, 0);
}

/*
 * Right off-canvas element is open:
 * - off-canvas element slides in
 * - container elements slides out
 */

.offside--right.is-open,
.offside-js--is-right .offside-sliding-element {
    -webkit-transform: translate3d(var(--offside-inverted-width), 0, 0);
    -moz-transform: translate3d(var(--offside-inverted-width), 0, 0);
    -ms-transform: translate3d(var(--offside-inverted-width), 0, 0);
    -o-transform: translate3d(var(--offside-inverted-width), 0, 0);
    transform: translate3d(var(--offside-inverted-width), 0, 0);
}

/* Elements Transitions */

.offside-js--interact .offside,
.offside-js--interact .offside-sliding-element {
    -webkit-transition: -webkit-transform .2s cubic-bezier(.16, .68, .43, .99);
    -moz-transition: -moz-transform .2s cubic-bezier(.16, .68, .43, .99);
    -o-transition: -o-transform .2s cubic-bezier(.16, .68, .43, .99);
    transition: transform .2s cubic-bezier(.16, .68, .43, .99);
    
    /* improves performance issues on mobile*/
    -webkit-backface-visibility: hidden;
    /* -webkit-perspective: 1000;  // removed due to appearing nav glitch */
}

/* Body overflow */

.offside-js--init {
    overflow-x: hidden;
}

/* Fallback movements for browser not supporting CSS 3d Transitions
----------------------------------------------- */

/* Modernizr false negative csstransforms3d fix, reset CSS 3d Transitions */

.no-csstransforms3d .offside {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.no-csstransforms3d .offside-sliding-element {
    overflow-x: hidden;
    position: relative;
}

/* Element is open: off-canvas element slides in */

.no-csstransforms3d .offside--left.is-open {
    left: 0;
}

.no-csstransforms3d .offside--right.is-open {
    right: 0;
}

/* Element is open: container elements slide out */

.no-csstransforms3d > .offside-js--is-left .offside-sliding-element {
    right: var(--offside-inverted-width);
}

.no-csstransforms3d > .offside-js--is-right .offside-sliding-element {
    left: var(--offside-inverted-width);
}

@media (min-width: 50em) {
    /* DESKTOP */
    .offside {
        width: var(--offside-width--desktop);
    }

    .offside,
    .offside--left {
        left: var(--offside-inverted-width--desktop);
    }

    .offside--right {
        left: unset;
        right: var(--offside-inverted-width--desktop);
    }

    .offside--left.is-open,
    .offside-js--is-left .offside-sliding-element {
        -webkit-transform: translate3d(var(--offside-width--desktop), 0, 0);
        -moz-transform: translate3d(var(--offside-width--desktop), 0, 0);
        -ms-transform: translate3d(var(--offside-width--desktop), 0, 0);
        -o-transform: translate3d(var(--offside-width--desktop), 0, 0);
        transform: translate3d(var(--offside-width--desktop), 0, 0);
    }

    .offside--right.is-open,
    .offside-js--is-right .offside-sliding-element {
        -webkit-transform: translate3d(var(--offside-inverted-width--desktop), 0, 0);
        -moz-transform: translate3d(var(--offside-inverted-width--desktop), 0, 0);
        -ms-transform: translate3d(var(--offside-inverted-width--desktop), 0, 0);
        -o-transform: translate3d(var(--offside-inverted-width--desktop), 0, 0);
        transform: translate3d(var(--offside-inverted-width--desktop), 0, 0);
    }

    /* Element is open: container elements slide out */
    .no-csstransforms3d > .offside-js--is-left .offside-sliding-element {
        right: var(--offside-inverted-width--desktop);
    }

    .no-csstransforms3d > .offside-js--is-right .offside-sliding-element {
        left: var(--offside-inverted-width--desktop);
    }
}

/**
 * Swiper 11.0.7
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2024 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: February 27, 2024
 */

/* FONT_START */

@font-face {
  font-family: 'swiper-icons';
  src: url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA');
  font-weight: 400;
  font-style: normal;
}

/* FONT_END */

:root {
  --swiper-theme-color: #007aff;
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  --swiper-wrapper-transition-timing-function: initial;
  */
}

:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
  display: block;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
}

.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-horizontal {
  touch-action: pan-y;
}

.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

/* Auto Height */

.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

/* 3D Effects */

.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  perspective: 1200px;
}

.swiper-3d .swiper-slide,
.swiper-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}

/* CSS Mode */

.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-css-mode.swiper-vertical > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none;
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none;
}

.swiper-css-mode.swiper-centered > .swiper-wrapper::before {
  content: '';
  flex-shrink: 0;
  order: 9999;
}

.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

/* Slide styles start */

/* 3D Shadows */

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* Slide styles end */

.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size);
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}

:root {
  --swiper-navigation-size: 44px;
  /*
  --swiper-navigation-top-offset: 50%;
  --swiper-navigation-sides-offset: 10px;
  --swiper-navigation-color: var(--swiper-theme-color);
  */
}

.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: var(--swiper-navigation-top-offset, 50%);
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}

.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}

.swiper-navigation-disabled .swiper-button-prev,
.swiper-navigation-disabled .swiper-button-next {
  display: none !important;
}

.swiper-button-prev svg,
.swiper-button-next svg {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transform-origin: center;
}

.swiper-rtl .swiper-button-prev svg,
.swiper-rtl .swiper-button-next svg {
  transform: rotate(180deg);
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 10px);
  right: auto;
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}

.swiper-button-lock {
  display: none;
}

/* Navigation font start */

.swiper-button-prev:after,
.swiper-button-next:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  content: 'prev';
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}

.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  content: 'next';
}

/* Navigation font end */

:root {
  /*
  --swiper-pagination-color: var(--swiper-theme-color);
  --swiper-pagination-left: auto;
  --swiper-pagination-right: 8px;
  --swiper-pagination-bottom: 8px;
  --swiper-pagination-top: auto;
  --swiper-pagination-fraction-color: inherit;
  --swiper-pagination-progressbar-bg-color: rgba(0,0,0,0.25);
  --swiper-pagination-progressbar-size: 4px;
  --swiper-pagination-bullet-size: 8px;
  --swiper-pagination-bullet-width: 8px;
  --swiper-pagination-bullet-height: 8px;
  --swiper-pagination-bullet-border-radius: 50%;
  --swiper-pagination-bullet-inactive-color: #000;
  --swiper-pagination-bullet-inactive-opacity: 0.2;
  --swiper-pagination-bullet-opacity: 1;
  --swiper-pagination-bullet-horizontal-gap: 4px;
  --swiper-pagination-bullet-vertical-gap: 6px;
  */
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 300ms opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination-disabled > .swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}

/* Common Styles */

.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: var(--swiper-pagination-bottom, 8px);
  top: var(--swiper-pagination-top, auto);
  left: 0;
  width: 100%;
}

/* Bullets */

.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
          appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none !important;
}

.swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-vertical > .swiper-pagination-bullets,
.swiper-pagination-vertical.swiper-pagination-bullets {
  right: var(--swiper-pagination-right, 8px);
  left: var(--swiper-pagination-left, auto);
  top: 50%;
  transform: translate3d(0px, -50%, 0);
}

.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}

.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}

.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 200ms transform,
        200ms top;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform,
        200ms left;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform,
    200ms right;
}

/* Fraction */

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit);
}

/* Progress */

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.25));
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: var(--swiper-pagination-progressbar-size, 4px);
  left: 0;
  top: 0;
}

.swiper-vertical > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
  width: var(--swiper-pagination-progressbar-size, 4px);
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-lock {
  display: none;
}

:root {
  /*
  --swiper-scrollbar-border-radius: 10px;
  --swiper-scrollbar-top: auto;
  --swiper-scrollbar-bottom: 4px;
  --swiper-scrollbar-left: auto;
  --swiper-scrollbar-right: 4px;
  --swiper-scrollbar-sides-offset: 1%;
  --swiper-scrollbar-bg-color: rgba(0, 0, 0, 0.1);
  --swiper-scrollbar-drag-bg-color: rgba(0, 0, 0, 0.5);
  --swiper-scrollbar-size: 4px;
  */
}

.swiper-scrollbar {
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  position: relative;
  touch-action: none;
  background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, 0.1));
}

.swiper-scrollbar-disabled > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: var(--swiper-scrollbar-sides-offset, 1%);
  bottom: var(--swiper-scrollbar-bottom, 4px);
  top: var(--swiper-scrollbar-top, auto);
  z-index: 50;
  height: var(--swiper-scrollbar-size, 4px);
  width: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-vertical > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-vertical {
  position: absolute;
  left: var(--swiper-scrollbar-left, auto);
  right: var(--swiper-scrollbar-right, 4px);
  top: var(--swiper-scrollbar-sides-offset, 1%);
  z-index: 50;
  width: var(--swiper-scrollbar-size, 4px);
  height: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5));
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

/* Zoom container styles start */

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.swiper-zoom-container > img,
.swiper-zoom-container > svg,
.swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

/* Zoom container styles end */

.swiper-slide-zoomed {
  cursor: move;
  touch-action: none;
}

/* a11y */

.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-fade .swiper-slide-active {
  pointer-events: auto;
}

.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube {
  overflow: visible;
}

.swiper-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-next,
.swiper-cube .swiper-slide-prev {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: 0.6;
  z-index: 0;
}

.swiper-cube .swiper-cube-shadow:before {
  content: '';
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  filter: blur(50px);
}

.swiper-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible;
}

/* Cube slide shadows start */

.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top,
.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom,
.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left,
.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

/* Cube slide shadows end */

.swiper-flip {
  overflow: visible;
}

.swiper-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  z-index: 1;
}

.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-flip .swiper-slide-active,
.swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

/* Flip slide shadows start */

.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top,
.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom,
.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left,
.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}

/* Flip slide shadows end */

.swiper-creative .swiper-slide {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  overflow: hidden;
  transition-property: transform, opacity, height;
}

.swiper-cards {
  overflow: visible;
}

.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  overflow: hidden;
}

/* Import team member block styles */

/* Team Member Block - Minimal Styling with CSS Variables */

.team-member-block {
    /* Container variables */
    --team-block-padding: var(--space-m-l, 2rem);
    --team-block-max-width: var(--wrapper-max-width, 1200px);
}

.team-member-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--team-card-min-width, 280px)), 1fr));
    gap: var(--team-grid-gap, var(--space-m-l, 2rem));
}

/* Single column override */

.team-member-block[data-columns="1"] .team-member-grid {
    grid-template-columns: 1fr;
    max-width: var(--team-single-max-width, 600px);
    margin-inline: auto;
}

/* Two column override */

.team-member-block[data-columns="2"] .team-member-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--team-card-min-width-2col, 320px)), 1fr));
}

/* Team member card */

.team-member-card {
    /* Card variables */
    --team-card-padding: var(--space-s-m, 1.5rem);
    --team-card-bg: var(--color-surface, transparent);
    --team-card-border: var(--border-width, 0) solid var(--color-border, transparent);
    --team-card-radius: var(--radius-m, 0);
    --team-card-shadow: var(--shadow-card, none);
    
    padding: var(--team-card-padding);
    background: var(--team-card-bg);
    border: var(--team-card-border);
    border-radius: var(--team-card-radius);
    box-shadow: var(--team-card-shadow);
}

/* Image */

.team-member-image {
    --team-image-margin: 0 0 var(--space-s, 1rem) 0;
    --team-image-radius: var(--radius-full, 50%);
    --team-image-size: var(--size-2xl, 200px);
    
    margin: var(--team-image-margin);
}

.team-member-photo {
    width: var(--team-image-size);
    height: var(--team-image-size);
    object-fit: cover;
    border-radius: var(--team-image-radius);
}

/* Content */

.team-member-content {
    --team-content-align: var(--text-align, left);
    text-align: var(--team-content-align);
}

/* Typography */

.team-member-name {
    --team-name-size: var(--step-1, 1.25rem);
    --team-name-weight: var(--font-weight-bold, 700);
    --team-name-color: var(--color-heading, inherit);
    --team-name-margin: 0 0 var(--space-xs, 0.5rem) 0;
    
    font-size: var(--team-name-size);
    font-weight: var(--team-name-weight);
    color: var(--team-name-color);
    margin: var(--team-name-margin);
}

.team-member-position {
    --team-position-size: var(--step-0, 1rem);
    --team-position-color: var(--color-text-muted, inherit);
    --team-position-margin: 0 0 var(--space-s, 1rem) 0;
    --team-position-style: var(--font-style, normal);
    
    font-size: var(--team-position-size);
    color: var(--team-position-color);
    margin: var(--team-position-margin);
    font-style: var(--team-position-style);
}

.team-member-bio {
    --team-bio-size: var(--step--1, 0.875rem);
    --team-bio-color: var(--color-text, inherit);
    --team-bio-margin: var(--space-s, 1rem) 0;
    
    font-size: var(--team-bio-size);
    color: var(--team-bio-color);
    margin: var(--team-bio-margin);
}

/* Contact info */

.team-member-contact {
    --team-contact-margin: var(--space-s, 1rem) 0;
    --team-contact-gap: var(--space-xs, 0.5rem);
    
    display: flex;
    flex-direction: column;
    gap: var(--team-contact-gap);
    margin: var(--team-contact-margin);
}

.team-member-email,
.team-member-phone {
    --team-contact-color: var(--color-link, inherit);
    --team-contact-hover-color: var(--color-link-hover, inherit);
    --team-contact-decoration: var(--link-decoration, none);
    --team-contact-hover-decoration: var(--link-hover-decoration, underline);
    
    color: var(--team-contact-color);
    text-decoration: var(--team-contact-decoration);
    transition: color var(--transition-base, 0.2s ease);
}

.team-member-email:hover,
.team-member-phone:hover {
    color: var(--team-contact-hover-color);
    text-decoration: var(--team-contact-hover-decoration);
}

/* Social links */

.team-member-social {
    --team-social-margin: var(--space-s, 1rem) 0 0 0;
    --team-social-gap: var(--space-xs, 0.5rem);
    
    display: flex;
    gap: var(--team-social-gap);
    margin: var(--team-social-margin);
    padding: 0;
    list-style: none;
}

.team-member-social-link {
    --team-social-size: var(--size-m, 2.5rem);
    --team-social-bg: var(--color-surface-alt, transparent);
    --team-social-color: var(--color-text, inherit);
    --team-social-hover-bg: var(--color-primary, transparent);
    --team-social-hover-color: var(--color-primary-contrast, inherit);
    --team-social-radius: var(--radius-s, 0.25rem);
    
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--team-social-size);
    height: var(--team-social-size);
    background: var(--team-social-bg);
    color: var(--team-social-color);
    border-radius: var(--team-social-radius);
    transition: all var(--transition-base, 0.2s ease);
}

.team-member-social-link:hover {
    background: var(--team-social-hover-bg);
    color: var(--team-social-hover-color);
}

.team-member-social-link svg {
    width: var(--team-social-icon-size, 1.25rem);
    height: var(--team-social-icon-size, 1.25rem);
    fill: currentColor;
}

/* Alignment variations */

.alignwide {
    max-width: var(--align-wide-width, 1400px);
    margin-inline: auto;
}

.alignfull {
    max-width: none;
}

/* Center aligned variation */

.team-member-block.is-style-centered .team-member-content {
    --team-content-align: center;
}

.team-member-block.is-style-centered .team-member-image {
    --team-image-margin: 0 auto var(--space-s, 1rem) auto;
}

.team-member-block.is-style-centered .team-member-social {
    justify-content: center;
}

/* Utility classes */

.visually-hidden {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}

/* Import pricing table block styles */

/* Pricing Table Block - Minimal Styling with CSS Variables */

.pricing-table-block {
    --pricing-gap: var(--space-m, 1.5rem);
    --pricing-border-radius: var(--radius-m, 0.5rem);
    --pricing-transition: var(--transition-base, 0.2s ease);
}

/* Mobile Cards View (default) */

.pricing-table-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--pricing-card-min-width, 280px)), 1fr));
    gap: var(--pricing-gap);
}

.pricing-plan-card {
    --card-padding: var(--space-m-l, 2rem);
    --card-bg: var(--color-surface, #fff);
    --card-border: var(--border-width, 1px) solid var(--color-border, #e0e0e0);
    --card-shadow: var(--shadow-card, 0 2px 4px rgba(0, 0, 0, 0.1));
    
    position: relative;
    padding: var(--card-padding);
    background: var(--card-bg);
    border: var(--card-border);
    border-radius: var(--pricing-border-radius);
    box-shadow: var(--card-shadow);
    display: flex;
    flex-direction: column;
}

/* Featured plan */

.pricing-plan-card.is-featured {
    --card-border: var(--border-width-thick, 2px) solid var(--color-primary, #007cba);
    --card-shadow: var(--shadow-card-hover, 0 4px 8px rgba(0, 0, 0, 0.15));
}

/* Badge */

.pricing-plan-badge {
    --badge-bg: var(--color-primary, #007cba);
    --badge-color: var(--color-primary-contrast, #fff);
    --badge-padding: var(--space-xs, 0.5rem) var(--space-s, 1rem);
    --badge-font-size: var(--step--1, 0.875rem);
    
    position: absolute;
    top: 0;
    right: var(--card-padding);
    transform: translateY(-50%);
    background: var(--badge-bg);
    color: var(--badge-color);
    padding: var(--badge-padding);
    border-radius: var(--pricing-border-radius);
    font-size: var(--badge-font-size);
    font-weight: var(--font-weight-bold, 700);
}

/* Header */

.pricing-plan-header {
    --header-margin: 0 0 var(--space-m, 1.5rem) 0;
    margin: var(--header-margin);
}

.pricing-plan-name {
    --name-size: var(--step-2, 1.5rem);
    --name-color: var(--color-heading, inherit);
    --name-margin: 0 0 var(--space-xs, 0.5rem) 0;
    
    font-size: var(--name-size);
    color: var(--name-color);
    margin: var(--name-margin);
}

.pricing-plan-description {
    --desc-size: var(--step--1, 0.875rem);
    --desc-color: var(--color-text-muted, #666);
    --desc-margin: 0 0 var(--space-s, 1rem) 0;
    
    font-size: var(--desc-size);
    color: var(--desc-color);
    margin: var(--desc-margin);
}

/* Price */

.pricing-plan-price {
    --price-align: var(--text-align, left);
    --price-margin: var(--space-s, 1rem) 0 0 0;
    
    display: flex;
    align-items: baseline;
    gap: var(--space-xs, 0.25rem);
    text-align: var(--price-align);
    margin: var(--price-margin);
}

.pricing-currency {
    --currency-size: var(--step-0, 1rem);
    --currency-color: var(--color-text-muted, #666);
    
    font-size: var(--currency-size);
    color: var(--currency-color);
}

.pricing-amount {
    --amount-size: var(--step-3, 2rem);
    --amount-color: var(--color-heading, inherit);
    --amount-weight: var(--font-weight-bold, 700);
    
    font-size: var(--amount-size);
    color: var(--amount-color);
    font-weight: var(--amount-weight);
}

.pricing-period {
    --period-size: var(--step--1, 0.875rem);
    --period-color: var(--color-text-muted, #666);
    
    font-size: var(--period-size);
    color: var(--period-color);
}

/* Features */

.pricing-plan-features {
    --features-margin: var(--space-m, 1.5rem) 0;
    --features-padding: var(--space-m, 1.5rem) 0;
    --features-border-top: var(--border-width, 1px) solid var(--color-border-light, #f0f0f0);
    
    flex: 1;
    margin: var(--features-margin);
    padding: var(--features-padding);
    border-top: var(--features-border-top);
}

.pricing-features-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.pricing-feature {
    --feature-padding: var(--space-xs, 0.5rem) 0;
    --feature-gap: var(--space-xs, 0.5rem);
    
    display: flex;
    align-items: flex-start;
    gap: var(--feature-gap);
    padding: var(--feature-padding);
}

.pricing-feature.is-excluded {
    --feature-opacity: 0.5;
    opacity: var(--feature-opacity);
}

.pricing-feature-icon {
    --icon-size: var(--size-s, 1.25rem);
    --icon-included-color: var(--color-success, #22c55e);
    --icon-excluded-color: var(--color-error, #ef4444);
    
    flex-shrink: 0;
    width: var(--icon-size);
    height: var(--icon-size);
    color: var(--icon-included-color);
}

.pricing-feature.is-excluded .pricing-feature-icon {
    color: var(--icon-excluded-color);
}

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

.pricing-feature-text {
    --text-size: var(--step--1, 0.875rem);
    --text-color: var(--color-text, inherit);
    
    font-size: var(--text-size);
    color: var(--text-color);
    flex: 1;
}

/* Tooltip */

.pricing-feature-tooltip {
    --tooltip-size: var(--size-xs, 1rem);
    --tooltip-bg: var(--color-surface-alt, #f5f5f5);
    --tooltip-color: var(--color-text, inherit);
    --tooltip-border: var(--border-width, 1px) solid var(--color-border, #e0e0e0);
    
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--tooltip-size);
    height: var(--tooltip-size);
    margin-left: var(--space-2xs, 0.25rem);
    background: var(--tooltip-bg);
    color: var(--tooltip-color);
    border: var(--tooltip-border);
    border-radius: 50%;
    font-size: calc(var(--tooltip-size) * 0.7);
    cursor: help;
    position: relative;
}

/* Tooltip popup */

.pricing-tooltip-popup {
    --popup-bg: var(--color-surface-dark, #333);
    --popup-color: var(--color-surface-dark-contrast, #fff);
    --popup-padding: var(--space-xs, 0.5rem) var(--space-s, 0.75rem);
    --popup-font-size: var(--step--2, 0.75rem);
    --popup-max-width: 200px;
    
    position: absolute;
    bottom: calc(100% + var(--space-xs, 0.5rem));
    left: 50%;
    transform: translateX(-50%);
    background: var(--popup-bg);
    color: var(--popup-color);
    padding: var(--popup-padding);
    border-radius: var(--radius-s, 0.25rem);
    font-size: var(--popup-font-size);
    max-width: var(--popup-max-width);
    white-space: normal;
    text-align: left;
    z-index: 10;
    box-shadow: var(--shadow-tooltip, 0 2px 8px rgba(0, 0, 0, 0.2));
}

.pricing-tooltip-popup[aria-hidden="true"] {
    display: none;
}

.pricing-tooltip-popup::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: var(--popup-bg);
}

/* CTA */

.pricing-plan-footer {
    --footer-margin: var(--space-m, 1.5rem) 0 0 0;
    margin: var(--footer-margin);
}

.pricing-plan-cta {
    --cta-padding: var(--space-s, 0.75rem) var(--space-m, 1.5rem);
    --cta-bg: var(--color-surface-alt, #f5f5f5);
    --cta-color: var(--color-text, inherit);
    --cta-border: var(--border-width, 1px) solid var(--color-border, #e0e0e0);
    --cta-hover-bg: var(--color-primary, #007cba);
    --cta-hover-color: var(--color-primary-contrast, #fff);
    --cta-hover-border-color: var(--color-primary, #007cba);
    
    display: inline-block;
    width: 100%;
    padding: var(--cta-padding);
    background: var(--cta-bg);
    color: var(--cta-color);
    border: var(--cta-border);
    border-radius: var(--pricing-border-radius);
    text-align: center;
    text-decoration: none;
    font-weight: var(--font-weight-medium, 500);
    transition: all var(--pricing-transition);
}

.pricing-plan-cta:hover,
.pricing-plan-cta:focus {
    background: var(--cta-hover-bg);
    color: var(--cta-hover-color);
    border-color: var(--cta-hover-border-color);
}

.pricing-plan-cta.is-primary {
    --cta-bg: var(--color-primary, #007cba);
    --cta-color: var(--color-primary-contrast, #fff);
    --cta-border: var(--border-width, 1px) solid var(--color-primary, #007cba);
    --cta-hover-bg: var(--color-primary-dark, #005a8c);
    --cta-hover-border-color: var(--color-primary-dark, #005a8c);
}

/* Desktop Table View */

.pricing-table-desktop {
    --table-display: none;
    display: var(--table-display);
}

@media (min-width: 768px) {
    .pricing-table-desktop {
        --table-display: block;
    }
    
    .pricing-table-cards {
        display: none;
    }
}

.pricing-table-row {
    display: grid;
    grid-template-columns: minmax(200px, 1fr) repeat(var(--plan-count, 3), 1fr);
    align-items: center;
}

.pricing-table-cell {
    --cell-padding: var(--space-s-m, 1rem);
    --cell-border: var(--border-width, 1px) solid var(--color-border-light, #f0f0f0);
    
    padding: var(--cell-padding);
    border-right: var(--cell-border);
    border-bottom: var(--cell-border);
}

.pricing-table-cell:first-child {
    border-left: var(--cell-border);
}

.pricing-table-cell.is-header {
    --header-bg: var(--color-surface-alt, #f9f9f9);
    --header-padding: var(--space-m, 1.5rem) var(--space-s-m, 1rem);
    
    background: var(--header-bg);
    padding: var(--header-padding);
    border-top: var(--cell-border);
    position: relative;
}

.pricing-table-cell.is-feature {
    --feature-font-size: var(--step--1, 0.875rem);
    --feature-font-weight: var(--font-weight-medium, 500);
    
    font-size: var(--feature-font-size);
    font-weight: var(--feature-font-weight);
}

.pricing-table-cell.is-featured {
    --featured-bg: var(--color-primary-light, #f0f8ff);
    background: var(--featured-bg);
}

/* Table indicators */

.pricing-feature-indicator {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.pricing-feature-indicator.is-included {
    color: var(--color-success, #22c55e);
}

.pricing-feature-indicator.is-excluded {
    color: var(--color-error, #ef4444);
}

.pricing-feature-indicator svg {
    width: var(--size-s, 1.25rem);
    height: var(--size-s, 1.25rem);
    fill: currentColor;
}

/* Responsive adjustments */

@media (min-width: 1024px) {
    .pricing-table-block[data-plan-count="4"] .pricing-table-row,
    .pricing-table-block[data-plan-count="5"] .pricing-table-row {
        grid-template-columns: minmax(150px, 0.75fr) repeat(var(--plan-count), 1fr);
    }
}

/* Alignment variations */

.alignwide {
    max-width: var(--align-wide-width, 1400px);
    margin-inline: auto;
}

.alignfull {
    max-width: none;
}

/* Utility classes */

.visually-hidden {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}

/* Import timeline block styles */

/* Timeline Block - Minimal Styling with CSS Variables */

.timeline-block {
    --timeline-spacing: var(--space-l, 2rem);
    --timeline-item-spacing: var(--space-xl, 3rem);
    --timeline-connector-width: var(--border-width-thick, 2px);
    --timeline-connector-color: var(--color-border, #e0e0e0);
    --timeline-marker-size: var(--size-m, 2.5rem);
    --timeline-dot-size: var(--size-xs, 1rem);
    --timeline-content-gap: var(--space-m, 1.5rem);
    
    position: relative;
}

/* Connector line */

.timeline-connector {
    position: absolute;
    background: var(--timeline-connector-color);
}

/* Vertical layout (default) */

.timeline-block.is-vertical .timeline-connector {
    width: var(--timeline-connector-width);
    height: 100%;
    left: var(--timeline-marker-size);
    transform: translateX(-50%);
    top: 0;
}

/* Horizontal layout */

.timeline-block.is-horizontal {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.timeline-block.is-horizontal .timeline-items {
    display: flex;
    gap: var(--timeline-item-spacing);
    padding-bottom: var(--timeline-spacing);
}

.timeline-block.is-horizontal .timeline-connector {
    height: var(--timeline-connector-width);
    width: 100%;
    top: var(--timeline-marker-size);
    transform: translateY(-50%);
    left: 0;
}

/* Timeline items container */

.timeline-items {
    position: relative;
}

/* Individual timeline item */

.timeline-item {
    display: flex;
    gap: var(--timeline-content-gap);
    margin-bottom: var(--timeline-item-spacing);
    position: relative;
}

.timeline-item:last-child {
    margin-bottom: 0;
}

/* Marker (icon or dot) */

.timeline-item-marker {
    flex-shrink: 0;
    width: var(--timeline-marker-size);
    height: var(--timeline-marker-size);
    position: relative;
    z-index: 1;
}

.timeline-item-icon {
    --icon-bg: var(--color-primary, #007cba);
    --icon-color: var(--color-primary-contrast, #fff);
    --icon-size: calc(var(--timeline-marker-size) * 0.5);
    
    width: 100%;
    height: 100%;
    background: var(--icon-bg);
    color: var(--icon-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-marker, 0 2px 4px rgba(0, 0, 0, 0.1));
}

.timeline-item-icon svg {
    width: var(--icon-size);
    height: var(--icon-size);
    fill: currentColor;
}

.timeline-icon-fallback {
    font-size: var(--icon-size);
    font-weight: var(--font-weight-bold, 700);
    text-transform: uppercase;
}

.timeline-item-dot {
    --dot-bg: var(--color-surface, #fff);
    --dot-border: var(--border-width-thick, 2px) solid var(--color-primary, #007cba);
    
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: var(--timeline-dot-size);
    height: var(--timeline-dot-size);
    background: var(--dot-bg);
    border: var(--dot-border);
    border-radius: 50%;
}

/* Content */

.timeline-item-content {
    flex: 1;
    min-width: 0; /* Prevent overflow */
}

.timeline-item-date {
    --date-color: var(--color-text-muted, #666);
    --date-size: var(--step--1, 0.875rem);
    --date-margin: 0 0 var(--space-xs, 0.5rem) 0;
    
    display: block;
    color: var(--date-color);
    font-size: var(--date-size);
    margin: var(--date-margin);
}

.timeline-item-title {
    --title-size: var(--step-1, 1.25rem);
    --title-color: var(--color-heading, inherit);
    --title-margin: 0 0 var(--space-s, 1rem) 0;
    
    font-size: var(--title-size);
    color: var(--title-color);
    margin: var(--title-margin);
}

.timeline-item-description {
    --desc-color: var(--color-text, inherit);
    --desc-margin: 0 0 var(--space-s, 1rem) 0;
    
    color: var(--desc-color);
    margin: var(--desc-margin);
}

.timeline-item-image {
    --image-margin: var(--space-s, 1rem) 0;
    --image-radius: var(--radius-m, 0.5rem);
    
    margin: var(--image-margin);
}

.timeline-image {
    width: 100%;
    height: auto;
    border-radius: var(--image-radius);
}

.timeline-item-cta {
    --cta-margin: var(--space-s, 1rem) 0 0 0;
    margin: var(--cta-margin);
}

.timeline-cta-link {
    --link-color: var(--color-link, #007cba);
    --link-hover-color: var(--color-link-hover, #005a8c);
    --link-decoration: var(--link-decoration, underline);
    --link-hover-decoration: var(--link-hover-decoration, underline);
    
    color: var(--link-color);
    text-decoration: var(--link-decoration);
    transition: color var(--transition-base, 0.2s ease);
}

.timeline-cta-link:hover,
.timeline-cta-link:focus {
    color: var(--link-hover-color);
    text-decoration: var(--link-hover-decoration);
}

/* Alternating layout for vertical timeline */

.timeline-block.has-alternating-items .timeline-connector {
    left: 50%;
}

.timeline-block.has-alternating-items .timeline-item {
    justify-content: flex-end;
    padding-right: calc(50% + var(--timeline-content-gap));
}

.timeline-block.has-alternating-items .timeline-item.is-alternate {
    flex-direction: row-reverse;
    padding-right: 0;
    padding-left: calc(50% + var(--timeline-content-gap));
}

.timeline-block.has-alternating-items .timeline-item-marker {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.timeline-block.has-alternating-items .timeline-item.is-alternate .timeline-item-content {
    text-align: right;
}

/* Horizontal specific styles */

.timeline-block.is-horizontal .timeline-item {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 0;
    min-width: 200px;
}

.timeline-block.is-horizontal .timeline-item-marker {
    margin-bottom: var(--timeline-content-gap);
}

/* Scroll indicator for horizontal timeline */

.timeline-scroll-indicator {
    --indicator-bg: var(--color-surface-dark, rgba(0, 0, 0, 0.8));
    --indicator-color: var(--color-surface-dark-contrast, #fff);
    --indicator-padding: var(--space-xs, 0.5rem) var(--space-s, 1rem);
    
    position: absolute;
    bottom: var(--space-s, 1rem);
    right: var(--space-s, 1rem);
    background: var(--indicator-bg);
    color: var(--indicator-color);
    padding: var(--indicator-padding);
    border-radius: var(--radius-s, 0.25rem);
    font-size: var(--step--1, 0.875rem);
    pointer-events: none;
    transition: opacity var(--transition-base, 0.2s ease);
}

/* Animation styles */

.timeline-item--animated {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity var(--transition-slow, 0.6s ease), 
                transform var(--transition-slow, 0.6s ease);
}

.timeline-item--animated.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Alternating animation */

.timeline-block.has-alternating-items .timeline-item--animated {
    transform: translateX(-20px);
}

.timeline-block.has-alternating-items .timeline-item--animated.is-alternate {
    transform: translateX(20px);
}

.timeline-block.has-alternating-items .timeline-item--animated.is-visible {
    transform: translateX(0);
}

/* Responsive adjustments */

@media (max-width: 768px) {
    /* Force vertical layout on mobile */
    .timeline-block.has-alternating-items .timeline-connector {
        left: var(--timeline-marker-size);
        transform: translateX(-50%);
    }
    
    .timeline-block.has-alternating-items .timeline-item,
    .timeline-block.has-alternating-items .timeline-item.is-alternate {
        flex-direction: row;
        justify-content: flex-start;
        padding: 0;
    }
    
    .timeline-block.has-alternating-items .timeline-item-marker {
        position: relative;
        left: auto;
        transform: none;
    }
    
    .timeline-block.has-alternating-items .timeline-item.is-alternate .timeline-item-content {
        text-align: left;
    }
}

/* Wide alignment */

.alignwide {
    max-width: var(--align-wide-width, 1400px);
    margin-inline: auto;
}

.alignfull {
    max-width: none;
}

/* Utility classes */

.visually-hidden {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
}

/* Import contact form block styles */

/* Contact Form Block Styles */

.contact-form-block {
    --form-gap: var(--space-m, 1.5rem);
    --field-gap: var(--space-s, 1rem);
    --field-padding: var(--space-xs, 0.75rem);
    --field-border-width: 1px;
    --field-border-color: var(--color-gray-300, #d1d5db);
    --field-border-radius: var(--radius-s, 0.375rem);
    --field-bg: var(--color-white, #ffffff);
    --field-focus-color: var(--color-primary, #3b82f6);
    --field-focus-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    --label-color: var(--color-gray-700, #374151);
    --label-font-weight: var(--font-weight-medium, 500);
    --button-padding: var(--space-xs, 0.75rem) var(--space-m, 1.5rem);
    --error-color: var(--color-red-600, #dc2626);
    --success-color: var(--color-green-600, #16a34a);
}

.contact-form-block__inner {
    container-type: inline-size;
}

/* Form Styles */

.contact-form-block .forminator-custom-form {
    display: grid;
    gap: var(--form-gap);
}

/* Field Row Styles */

.contact-form-block .forminator-row {
    display: grid;
    gap: var(--field-gap);
}

/* Column Layouts */

.contact-form-block--columns-2 .forminator-row {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.contact-form-block--columns-3 .forminator-row {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

/* Field Styles */

.contact-form-block .forminator-field {
    display: flex;
    flex-direction: column;
    gap: var(--space-2xs, 0.5rem);
}

.contact-form-block .forminator-label {
    color: var(--label-color);
    font-weight: var(--label-font-weight);
    font-size: var(--text-sm, 0.875rem);
    line-height: 1.2;
}

.contact-form-block .forminator-input,
.contact-form-block .forminator-textarea,
.contact-form-block .forminator-select {
    padding: var(--field-padding);
    border: var(--field-border-width) solid var(--field-border-color);
    border-radius: var(--field-border-radius);
    background-color: var(--field-bg);
    font-size: var(--text-base, 1rem);
    line-height: 1.5;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    width: 100%;
}

.contact-form-block .forminator-input:focus,
.contact-form-block .forminator-textarea:focus,
.contact-form-block .forminator-select:focus {
    outline: none;
    border-color: var(--field-focus-color);
    box-shadow: var(--field-focus-shadow);
}

/* Textarea specific */

.contact-form-block .forminator-textarea {
    min-height: 120px;
    resize: vertical;
}

/* Select specific */

.contact-form-block .forminator-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236b7280'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");
    background-position: right var(--field-padding) center;
    background-repeat: no-repeat;
    background-size: 1.25rem;
    padding-right: calc(var(--field-padding) * 3);
}

/* Radio and Checkbox */

.contact-form-block .forminator-radio,
.contact-form-block .forminator-checkbox {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2xs, 0.5rem);
}

.contact-form-block .forminator-radio input[type="radio"],
.contact-form-block .forminator-checkbox input[type="checkbox"] {
    margin-top: 0.125rem;
    flex-shrink: 0;
}

/* Button Styles */

.contact-form-block .forminator-button-submit {
    padding: var(--button-padding);
    border-radius: var(--field-border-radius);
    font-weight: var(--font-weight-medium, 500);
    transition: all 0.2s ease;
    cursor: pointer;
    border: 2px solid transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2xs, 0.5rem);
}

/* Button Styles - Primary */

.contact-form-block--button-primary .forminator-button-submit {
    background-color: var(--color-primary, #3b82f6);
    color: var(--color-white, #ffffff);
}

.contact-form-block--button-primary .forminator-button-submit:hover {
    background-color: var(--color-primary-dark, #2563eb);
}

/* Button Styles - Secondary */

.contact-form-block--button-secondary .forminator-button-submit {
    background-color: var(--color-gray-200, #e5e7eb);
    color: var(--color-gray-800, #1f2937);
}

.contact-form-block--button-secondary .forminator-button-submit:hover {
    background-color: var(--color-gray-300, #d1d5db);
}

/* Button Styles - Outline */

.contact-form-block--button-outline .forminator-button-submit {
    background-color: transparent;
    color: var(--color-primary, #3b82f6);
    border-color: var(--color-primary, #3b82f6);
}

.contact-form-block--button-outline .forminator-button-submit:hover {
    background-color: var(--color-primary, #3b82f6);
    color: var(--color-white, #ffffff);
}

/* Button Styles - Ghost */

.contact-form-block--button-ghost .forminator-button-submit {
    background-color: transparent;
    color: var(--color-primary, #3b82f6);
}

.contact-form-block--button-ghost .forminator-button-submit:hover {
    background-color: var(--color-gray-100, #f3f4f6);
}

/* Button Sizes */

.contact-form-block--button-small .forminator-button-submit {
    padding: var(--space-2xs, 0.5rem) var(--space-s, 1rem);
    font-size: var(--text-sm, 0.875rem);
}

.contact-form-block--button-large .forminator-button-submit {
    padding: var(--space-s, 1rem) var(--space-l, 2rem);
    font-size: var(--text-lg, 1.125rem);
}

/* Button Full Width */

.contact-form-block--button-full .forminator-button-submit {
    width: 100%;
}

/* Form Spacing Variations */

.contact-form-block--spacing-compact {
    --form-gap: var(--space-s, 1rem);
    --field-gap: var(--space-xs, 0.75rem);
    --field-padding: var(--space-2xs, 0.5rem);
}

.contact-form-block--spacing-spacious {
    --form-gap: var(--space-l, 2rem);
    --field-gap: var(--space-m, 1.5rem);
    --field-padding: var(--space-s, 1rem);
}

/* Form Style Variations */

/* Modern Style */

.contact-form-block--style-modern {
    --field-border-color: transparent;
    --field-bg: var(--color-gray-100, #f3f4f6);
    --field-border-radius: var(--radius-m, 0.5rem);
}

.contact-form-block--style-modern .forminator-input:focus,
.contact-form-block--style-modern .forminator-textarea:focus,
.contact-form-block--style-modern .forminator-select:focus {
    --field-bg: var(--color-white, #ffffff);
    border-color: var(--field-focus-color);
}

/* Minimal Style */

.contact-form-block--style-minimal {
    --field-border-color: transparent;
    --field-border-width: 0 0 1px 0;
    --field-border-radius: 0;
    --field-padding: var(--space-2xs, 0.5rem) 0;
    --field-bg: transparent;
}

/* Bordered Style */

.contact-form-block--style-bordered {
    --field-border-width: 2px;
    --field-border-color: var(--color-gray-900, #111827);
    --field-border-radius: 0;
}

/* No Labels */

.contact-form-block--no-labels .forminator-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Placeholder Labels */

.contact-form-block--placeholder-labels .forminator-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Error Messages */

.contact-form-block .forminator-error-message {
    color: var(--error-color);
    font-size: var(--text-sm, 0.875rem);
    margin-top: var(--space-2xs, 0.5rem);
}

.contact-form-block .forminator-field.forminator-has_error .forminator-input,
.contact-form-block .forminator-field.forminator-has_error .forminator-textarea,
.contact-form-block .forminator-field.forminator-has_error .forminator-select {
    border-color: var(--error-color);
}

/* Success Messages */

.contact-form-block .forminator-response-message {
    padding: var(--space-s, 1rem);
    border-radius: var(--field-border-radius);
    margin-top: var(--space-m, 1.5rem);
}

.contact-form-block .forminator-success {
    background-color: var(--color-green-50, #f0fdf4);
    color: var(--success-color);
    border: 1px solid var(--color-green-200, #bbf7d0);
}

.contact-form-block .forminator-error {
    background-color: var(--color-red-50, #fef2f2);
    color: var(--error-color);
    border: 1px solid var(--color-red-200, #fecaca);
}

/* Loading State */

.contact-form-block .forminator-loading {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2xs, 0.5rem);
}

.contact-form-block .forminator-loading::before {
    content: "";
    width: 1rem;
    height: 1rem;
    border: 2px solid var(--color-gray-300, #d1d5db);
    border-top-color: var(--color-primary, #3b82f6);
    border-radius: 50%;
    animation: forminator-spin 0.6s linear infinite;
}

@keyframes forminator-spin {
    to {
        transform: rotate(360deg);
    }
}

/* Required Fields */

.contact-form-block .forminator-required {
    color: var(--error-color);
}

/* File Upload */

.contact-form-block .forminator-upload {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-m, 1.5rem);
    border: 2px dashed var(--field-border-color);
    border-radius: var(--field-border-radius);
    background-color: var(--color-gray-50, #f9fafb);
    transition: all 0.2s ease;
}

.contact-form-block .forminator-upload:hover {
    border-color: var(--field-focus-color);
    background-color: var(--color-blue-50, #eff6ff);
}

.contact-form-block .forminator-upload input[type="file"] {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

/* Progress Bar */

.contact-form-block .forminator-progress {
    height: 4px;
    background-color: var(--color-gray-200, #e5e7eb);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: var(--space-m, 1.5rem);
}

.contact-form-block .forminator-progress-bar {
    height: 100%;
    background-color: var(--field-focus-color);
    transition: width 0.3s ease;
}

/* GDPR/Consent */

.contact-form-block .forminator-consent {
    display: flex;
    align-items: flex-start;
    gap: var(--space-xs, 0.75rem);
    font-size: var(--text-sm, 0.875rem);
    line-height: 1.5;
}

.contact-form-block .forminator-consent input[type="checkbox"] {
    margin-top: 0.125rem;
    flex-shrink: 0;
}

/* Error Block */

.contact-form-block__error {
    padding: var(--space-m, 1.5rem);
    background-color: var(--color-gray-100, #f3f4f6);
    border: 1px solid var(--color-gray-300, #d1d5db);
    border-radius: var(--field-border-radius);
    text-align: center;
    color: var(--color-gray-600, #4b5563);
}

/* Responsive */

@media (max-width: 640px) {
    .contact-form-block--columns-2 .forminator-row,
    .contact-form-block--columns-3 .forminator-row {
        grid-template-columns: 1fr;
    }
    
    .contact-form-block--button-full .forminator-button-submit {
        width: 100%;
    }
}

.site-block {
	margin-bottom: var(--block-spacing, 4rem);
}

/* .block-hero,
.block-copy_and_image,
.block-statement,
.block-collections,
.block-gallery,
.block-cards,
.block-testimonials,
.block-cta,

.block-image,
.card-grid,
.single-post-intro,
.related-posts,
.block-classic,
.block-copy {
	margin-bottom: var(--block-spacing, 4rem);
}

.block-stonesoverview,
.block-process,
.block-facts,
.block-statement,
.related-posts {
	padding-top: var(--block-spacing, 4rem);
	padding-bottom: var(--block-spacing, 4rem);
}

.block-resources {
	padding-top: var(--block-spacing--double, 8rem);
	padding-bottom: var(--block-spacing--double, 8rem);
} */

/* Accordion Block Styles */

.accordion-block {
  --accordion-border-color: var(--color-border);
  --accordion-bg: var(--color-surface);
  --accordion-hover-bg: var(--color-gray-50);
  --accordion-active-bg: var(--color-primary);
  --accordion-active-color: var(--color-text-inverse);
  --accordion-radius: var(--radius-md);
  --accordion-spacing: var(--space-s);
}

.accordion-block__heading {
  margin-block-end: var(--space-m-l);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
}

.accordion-block__items {
  --flow-space: var(--accordion-spacing);
}

/* Accordion Item */

.accordion-item {
  background: var(--accordion-bg);
  border: 1px solid var(--accordion-border-color);
  border-radius: var(--accordion-radius);
  overflow: hidden;
  transition: box-shadow var(--duration-fast) var(--ease-out);
}

.accordion-item:hover {
  box-shadow: var(--shadow-sm);
}

/* Trigger Button */

.accordion-item__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-m);
  font-size: var(--text-lg);
  font-weight: var(--font-medium);
  text-align: left;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background-color var(--duration-fast) var(--ease-out);
}

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

.accordion-item__trigger:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
}

/* Icon */

.accordion-item__icon {
  flex-shrink: 0;
  margin-inline-start: var(--space-s);
  transition: transform var(--duration-normal) var(--ease-out);
}

.accordion-item__trigger[aria-expanded="true"] .accordion-item__icon {
  transform: rotate(180deg);
}

/* Content */

.accordion-item__content {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--duration-normal) var(--ease-out);
}

.accordion-item__content[data-expanded] {
  grid-template-rows: 1fr;
}

.accordion-item__body {
  overflow: hidden;
  padding: 0 var(--space-m);
}

.accordion-item__content[data-expanded] .accordion-item__body {
  padding-bottom: var(--space-m);
}

/* Style Variations */

/* Minimal Style */

.accordion-block--minimal .accordion-item {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--accordion-border-color);
  border-radius: 0;
}

.accordion-block--minimal .accordion-item:last-child {
  border-bottom: none;
}

.accordion-block--minimal .accordion-item__trigger {
  padding-inline: 0;
}

.accordion-block--minimal .accordion-item__trigger:hover {
  background: transparent;
  color: var(--color-primary);
}

/* Filled Style */

.accordion-block--filled .accordion-item {
  background: var(--color-gray-100);
  border: none;
}

.accordion-block--filled .accordion-item__trigger:hover {
  background: var(--color-gray-200);
}

/* Compact Style */

.accordion-block--compact .accordion-item__trigger {
  padding: var(--space-s) var(--space-m);
  font-size: var(--text-base);
}

.accordion-block--compact .accordion-item__body {
  font-size: var(--text-sm);
}

/* Active State Highlight */

.accordion-item__trigger[aria-expanded="true"] {
  font-weight: var(--font-semibold);
}

.accordion-block--highlight .accordion-item__trigger[aria-expanded="true"] {
  background: var(--accordion-active-bg);
  color: var(--accordion-active-color);
}

.accordion-block--highlight .accordion-item__trigger[aria-expanded="true"]:hover {
  background: var(--color-primary-dark);
}

/* Reduced Motion */

@media (prefers-reduced-motion: reduce) {
  .accordion-item__icon,
  .accordion-item__content {
    transition: none;
  }
}

/* Responsive */

@media (max-width: 768px) {
  .accordion-item__trigger {
    padding: var(--space-s-m);
    font-size: var(--text-base);
  }
  
  .accordion-item__body {
    padding-inline: var(--space-s-m);
  }
}

/* Print Styles */

@media print {
  .accordion-item__content {
    display: block !important;
    grid-template-rows: auto !important;
  }
  
  .accordion-item__trigger {
    font-weight: var(--font-bold);
  }
  
  .accordion-item__icon {
    display: none;
  }
}

/* Centered WYSIWYG Block Styles */

.centered-wysiwyg {
  --centered-wysiwyg-gap: var(--space-m);

  max-inline-size: 50%;
  margin-inline: auto;
  text-align: center;
}

/* Background color variants */

.centered-wysiwyg.bg-orange,
.centered-wysiwyg.bg-green,
.centered-wysiwyg.bg-yellow,
.centered-wysiwyg.bg-dark {
  padding: var(--space-l);
  border-radius: var(--space-s);
}

.centered-wysiwyg__heading {
  font-size: var(--size-step-3);
  line-height: var(--leading-tight);
  margin-block-end: var(--centered-wysiwyg-gap);
  color: var(--color-dark);
}

.centered-wysiwyg__copy {
  --flow-space: var(--space-s);
  font-size: var(--size-step-1);
  line-height: var(--leading-normal);
  /* color: var(--color-dark); */
}

.centered-wysiwyg__copy > * + * {
  margin-block-start: var(--flow-space);
}

.centered-wysiwyg__copy h2 {
  font-size: var(--size-step-2);
  line-height: var(--leading-tight);
  margin-block-start: var(--space-m);
  margin-block-end: var(--space-xs);
}

.centered-wysiwyg__copy h3 {
  font-size: var(--size-step-1);
  line-height: var(--leading-tight);
  margin-block-start: var(--space-s);
  margin-block-end: var(--space-xs);
}

.centered-wysiwyg__copy p {
  margin-block-end: var(--space-s);
}

.centered-wysiwyg__copy a {
  color: var(--color-orange);
  text-decoration: underline;
  transition: color var(--transition-base);
}

.centered-wysiwyg__copy a:hover {
  color: var(--color-dark);
}

.centered-wysiwyg__copy ul,
.centered-wysiwyg__copy ol {
  text-align: left;
  margin-inline: auto;
  max-inline-size: 80%;
  padding-inline-start: var(--space-m);
}

.centered-wysiwyg__copy li {
  margin-block-end: var(--space-2xs);
}

/* Responsive adjustments */

@media (max-width: 1024px) {
  .centered-wysiwyg {
    max-inline-size: 66.666%;
  }
}

@media (max-width: 768px) {
  .centered-wysiwyg {
    max-inline-size: 100%;
  }

  .centered-wysiwyg__heading {
    font-size: var(--size-step-2);
  }

  .centered-wysiwyg__copy {
    font-size: var(--size-step-0);
  }

  .centered-wysiwyg__copy ul,
  .centered-wysiwyg__copy ol {
    max-inline-size: 100%;
  }
}

/* Contact Details Block Styles */

.contact-details-block {
  --contact-details-gap: var(--space-l);
  gap: var(--contact-details-gap);
  align-items: center;
}

.contact-details-block__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-m);
}

.contact-details-block__eyebrow {
  color: var(--color-orange);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.contact-details-block__heading {
  color: var(--color-dark);
  margin-block-end: var(--space-xs);
}

.contact-details-block__copy {
  color: var(--color-dark);
  opacity: 0.8;
}

/* Contact Methods */

.contact-details-block__methods {
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
  margin-block-start: var(--space-m);
}

.contact-details-block__method {
  display: flex;
  align-items: flex-start;
  gap: var(--space-xs);
  padding: var(--space-xs);
  border-radius: var(--space-3xs);
  transition: background-color var(--transition-base);
}

.contact-details-block__method:hover {
  background-color: var(--color-light);
}

.contact-details-block__method svg {
  flex-shrink: 0;
  margin-block-start: 0.125rem;
  color: var(--color-orange);
}

.contact-details-block__method-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-3xs);
  flex: 1;
}

.contact-details-block__method-label {
  font-size: var(--size-step-0);
  color: var(--color-dark);
}

.contact-details-block__method-value {
  font-size: var(--size-step-0);
  color: var(--color-dark);
  text-decoration: none;
  transition: color var(--transition-base);
  word-break: break-word;
}

.contact-details-block__method-value:hover {
  color: var(--color-orange);
  text-decoration: underline;
}

/* Social Links Section */

.contact-details-block__social {
  margin-block-start: var(--space-l);
  padding-block-start: var(--space-m);
  border-block-start: 1px solid var(--color-dark);
  opacity: 0.2;
}

/* Image */

.contact-details-block__image {
  overflow: hidden;
  border-radius: var(--space-s);
}

.contact-details-block__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4/3;
}

/* Responsive adjustments */

@media (max-width: 768px) {
  .contact-details-block {
    --contact-details-gap: var(--space-m);
    grid-template-columns: 1fr;
  }

  .contact-details-block__image {
    order: -1;
  }

  .contact-details-block__heading {
    font-size: var(--size-step-2);
  }
}

/* CTA Block Styles */

.cta-block {
  --cta-padding: var(--space-xl-2xl);
  --cta-bg: var(--color-surface);
  --cta-color: var(--color-text);
  
  padding-block: var(--cta-padding);
  background: var(--cta-bg);
  color: var(--cta-color);
}

/* Background variations */

.cta-block--bg-primary {
  --cta-bg: var(--color-primary);
  --cta-color: var(--color-text-inverse);
}

.cta-block--bg-accent {
  --cta-bg: var(--color-accent);
  --cta-color: var(--color-text-inverse);
}

.cta-block--bg-gray {
  --cta-bg: var(--color-gray-100);
  --cta-color: var(--color-text);
}

.cta-block--bg-gradient {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  --cta-color: var(--color-text-inverse);
}

/* Content container */

.cta-block__content {
  --flow-space: var(--space-m);
  max-inline-size: var(--measure-wide, 80ch);
  margin-inline: auto;
}

/* Alignment variations */

.cta-block--align-left .cta-block__content {
  margin-inline-start: 0;
  text-align: left;
}

.cta-block--align-center .cta-block__content {
  text-align: center;
}

.cta-block--align-right .cta-block__content {
  margin-inline-end: 0;
  text-align: right;
  margin-inline-start: auto;
}

/* Typography */

.cta-block__heading {
  font-size: var(--text-3xl);
  line-height: var(--leading-tight);
  font-weight: var(--font-bold);
  color: inherit;
}

.cta-block__subheading {
  font-size: var(--text-xl);
  line-height: var(--leading-normal);
  color: inherit;
  opacity: 0.9;
}

.cta-block__description {
  margin-inline: auto;
}

/* Button group */

.cta-block__buttons {
  --cluster-gap: var(--space-s);
  margin-block-start: var(--space-m-l);
}

/* Button adjustments for CTA context */

.cta-block--bg-primary .button[data-variant="primary"],
.cta-block--bg-accent .button[data-variant="primary"],
.cta-block--bg-gradient .button[data-variant="primary"] {
  --button-bg: var(--color-surface);
  --button-color: var(--color-text);
  --button-hover-bg: var(--color-gray-100);
}

.cta-block--bg-primary .button[data-variant="secondary"],
.cta-block--bg-accent .button[data-variant="secondary"],
.cta-block--bg-gradient .button[data-variant="secondary"] {
  --button-bg: transparent;
  --button-color: var(--color-text-inverse);
  --button-border: 2px solid currentColor;
  --button-hover-bg: rgba(255, 255, 255, 0.1);
}

/* Focus states with good contrast */

.cta-block .button:focus-visible {
  outline: 3px solid var(--cta-color);
  outline-offset: 2px;
}

/* Dark background focus adjustment */

.cta-block--bg-primary .button:focus-visible,
.cta-block--bg-accent .button:focus-visible,
.cta-block--bg-gradient .button:focus-visible {
  outline-color: var(--color-surface);
}

/* Responsive adjustments */

@media (max-width: 768px) {
  .cta-block {
    --cta-padding: var(--space-l-xl);
  }
  
  .cta-block__heading {
    font-size: var(--text-2xl);
  }
  
  .cta-block__subheading {
    font-size: var(--text-lg);
  }
  
  .cta-block__buttons {
    flex-direction: column;
    align-items: stretch;
  }
  
  .cta-block__buttons .button {
    width: 100%;
    justify-content: center;
  }
}

/* FAQs Block Styles */

.faqs-block {
  --faqs-gap: var(--space-l);
}

.faqs-block__intro {
  text-align: center;
  max-inline-size: 75ch;
  margin-inline: auto;
  margin-block-end: var(--faqs-gap);
}

.faqs-block__intro-eyebrow {
  color: var(--color-orange);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--font-bold);
  margin-block-end: var(--space-xs);
}

.faqs-block__intro-heading {
  font-size: var(--size-step-3);
  line-height: var(--leading-tight);
  margin-block-end: var(--space-s);
  color: var(--color-dark);
}

.faqs-block__intro-copy {
  font-size: var(--size-step-1);
  line-height: var(--leading-normal);
  color: var(--color-dark);
}

.faqs-block__items {
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
  margin-block-end: var(--faqs-gap);
}

.faqs-block__item {
  background-color: rgba(0, 0, 0, 0.02);
  border-radius: var(--space-xs);
  border: 1px solid rgba(0, 0, 0, 0.1);
  transition: box-shadow var(--transition-base);
}

.faqs-block__item:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.faqs-block__item[open] {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.faqs-block__question {
  padding: var(--space-m);
  font-size: var(--size-step-1);
  font-weight: var(--font-bold);
  color: var(--color-dark);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-s);
  list-style: none;
  user-select: none;
  transition: color var(--transition-base);
}

.faqs-block__question:hover {
  color: var(--color-orange);
}

.faqs-block__question::-webkit-details-marker {
  display: none;
}

.faqs-block__icon {
  flex-shrink: 0;
  transition: transform var(--transition-base);
  color: var(--color-orange);
}

.faqs-block__item[open] .faqs-block__icon {
  transform: rotate(180deg);
}

.faqs-block__answer {
  --flow-space: var(--space-s);
  padding: 0 var(--space-m) var(--space-m);
  font-size: var(--size-step-0);
  line-height: var(--leading-normal);
  color: var(--color-dark);
}

.faqs-block__answer > * + * {
  margin-block-start: var(--flow-space);
}

.faqs-block__answer p {
  margin-block-end: var(--space-s);
}

.faqs-block__answer strong {
  font-weight: var(--font-bold);
}

.faqs-block__answer ul,
.faqs-block__answer ol {
  padding-inline-start: var(--space-m);
  margin-block: var(--space-s);
}

.faqs-block__answer li {
  margin-block-end: var(--space-2xs);
}

.faqs-block__answer a {
  color: var(--color-orange);
  text-decoration: underline;
  transition: color var(--transition-base);
}

.faqs-block__answer a:hover {
  color: var(--color-dark);
}

.faqs-block__outro {
  text-align: center;
  max-inline-size: 75ch;
  margin-inline: auto;
  padding-block-start: var(--space-l);
  border-block-start: 1px solid rgba(0, 0, 0, 0.1);
}

.faqs-block__outro-copy {
  font-size: var(--size-step-1);
  line-height: var(--leading-normal);
  color: var(--color-dark);
  margin-block-end: var(--space-m);
}

.faqs-block__buttons {
  --cluster-gap: var(--space-s);
  justify-content: center;
}

/* Responsive adjustments */

@media (max-width: 768px) {
  .faqs-block {
    --faqs-gap: var(--space-m);
  }

  .faqs-block__intro-heading {
    font-size: var(--size-step-2);
  }

  .faqs-block__intro-copy {
    font-size: var(--size-step-0);
  }

  .faqs-block__question {
    padding: var(--space-s);
    font-size: var(--size-step-0);
  }

  .faqs-block__answer {
    padding: 0 var(--space-s) var(--space-s);
  }

  .faqs-block__outro-copy {
    font-size: var(--size-step-0);
  }
}

.block--gallery img {
	width: 100%;
}

/* LAYOUT A */

.block--gallery.layout-a .image-gallery-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-template-rows: repeat(2, 1fr);
	grid-column-gap: var(--space-3xs, 1rem);
	grid-row-gap: var(--space-3xs, 1rem);
	grid-auto-flow: row;
}

.block--gallery.layout-a .image-gallery-grid picture,
.block--gallery.layout-a .image-gallery-grid img { height: 100%; }

.block--gallery.layout-a .image-gallery-grid img { object-fit: cover; }

.block--gallery.layout-a .image-gallery-grid > *:nth-child(4n+1) { 
	grid-column-start: 1;
	grid-column-end: 4;
}

.block--gallery.layout-a .image-gallery-grid > *:nth-child(4n+2) {
	grid-column-start: 4;
	grid-column-end: 6;
}

.block--gallery.layout-a .image-gallery-grid > *:nth-child(4n+3) { 
	grid-column-start: 1;
	grid-column-end: 3;
}

.block--gallery.layout-a .image-gallery-grid > *:nth-child(4n+4) { 
	grid-column-start: 3;
	grid-column-end: 6;
}

/* LAYOUT B */

.block--gallery.layout-b .image-gallery-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	/* grid-template-rows: repeat(2, 1fr); */
	grid-column-gap: var(--space-3xs, 1rem);
	grid-row-gap: var(--space-3xs, 1rem);
	grid-auto-flow: row;
}

.block--gallery.layout-b .image-gallery-grid picture,
.block--gallery.layout-b .image-gallery-grid img { height: 100%; }

.block--gallery.layout-b .image-gallery-grid img { object-fit: cover; }

.block--gallery.layout-b .image-gallery-grid > *:nth-child(3n+1) { 
	grid-column-start: 1;
	grid-column-end: 7;
}

.block--gallery.layout-b .image-gallery-grid > *:nth-child(3n+2) {
	grid-column-start: 1;
	grid-column-end: 4;
}

.block--gallery.layout-b .image-gallery-grid > *:nth-child(3n+3) { 
	grid-column-start: 4;
	grid-column-end: 7;
}

.block--hero {
	/* aspect-ratio: 16/9; */
	position: relative;
	
}

.block--hero .hero-content {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	margin: 6rem 0;
}

.block--hero .hero-content > * {
		margin-bottom: 2rem;
	}

.block--hero .hero-content{
	max-width: 900px;
}

.block--hero .hero-background {
	z-index: -10;
	/* width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0; */
}

.hero-background .hero_bg_colour,
.hero-background .hero_image,
.hero-background .hero_slideshow, 
.hero-background .hero_video {
	/* position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%; */
}

.hero-background .hero_bg_colour {
	z-index: -8;
}

.hero-background .hero_image {
	z-index: -5;
}

.hero-background .hero_image picture,
.hero-background .hero_image img {
	width: 100%;
	height: 100%;
	object-fit: cover
}

.hero-background .hero_slideshow {
	z-index: -3;
}

.hero-background .hero_slideshow picture,
.hero-background .hero_slideshow img {
	width: 100%;
	height: 100%;
	object-fit: cover
}

.hero-background .hero_video {
	z-index: -1;
}

.hero-background .hero_video iframe {
	width: 100%;
	height: 100%;
}

.block--image img {
	width: 100%;
}

/* Main CTA Block Styles */

.main-cta-block {
  --main-cta-padding: var(--space-m);
  --main-cta-gap: var(--space-m);
  --main-cta-bg: transparent;
  --main-cta-text-color: var(--color-dark);

  padding: var(--main-cta-padding) 0;
  border-radius: var(--space-xs);
  background: var(--main-cta-bg);
  color: var(--main-cta-text-color);
}

/* Background color variations */

.main-cta-block--bg-orange {
  --main-cta-bg: var(--color-orange);
  --main-cta-text-color: var(--color-light);
}

.main-cta-block--bg-green {
  --main-cta-bg: var(--color-green);
  --main-cta-text-color: var(--color-light);
}

.main-cta-block--bg-yellow {
  --main-cta-bg: var(--color-yellow);
  --main-cta-text-color: var(--color-dark);
}

.main-cta-block--bg-dark {
  --main-cta-bg: var(--color-dark);
  --main-cta-text-color: var(--color-light);
}

/* Content styling */

.main-cta-block__content {
  display: flex;
  flex-direction: column;
  gap: var(--main-cta-gap);
  color: inherit;
}

.main-cta-block__eyebrow {
  color: inherit;
  opacity: 0.9;
}

.main-cta-block__heading {
  color: inherit;
}

.main-cta-block__copy {
  color: inherit;
}

.main-cta-block__buttons {
  /* margin-block-start: var(--space-s); */
  margin-bottom: 2rem;
}

/* Image styling */

.main-cta-block__image {
  display: flex;
  align-items: center;
}

.main-cta-block__image img {
  width: 100%;
  height: auto;
  border-radius: var(--space-xs);
  aspect-ratio: 1/1;
  object-fit: cover;
}

/* Button adjustments for colored backgrounds */

.main-cta-block--bg-orange .button[data-variant="primary"],
.main-cta-block--bg-green .button[data-variant="primary"],
.main-cta-block--bg-dark .button[data-variant="primary"] {
  --button-bg: var(--color-light);
  --button-color: var(--color-dark);
}

.main-cta-block--bg-yellow .button[data-variant="primary"] {
  --button-bg: var(--color-dark);
  --button-color: var(--color-light);
}

/* Responsive adjustments */

@media (max-width: 768px) {
  .main-cta-block {
    --main-cta-padding: var(--space-s);
  }
}

/* Packages Block Styles */

.packages-block {
  --packages-gap: var(--space-xl);
}

.packages-block__intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-l);
  align-items: center;
  margin-block-end: var(--packages-gap);
}

.packages-block__intro-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
}

.packages-block__intro-eyebrow {
  color: var(--color-orange);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: var(--font-bold);
}

.packages-block__intro-heading {
  font-size: var(--size-step-3);
  line-height: var(--leading-tight);
  color: var(--color-dark);
}

.packages-block__intro-copy {
  font-size: var(--size-step-1);
  line-height: var(--leading-normal);
  color: var(--color-dark);
}

.packages-block__intro-image {
  display: flex;
  align-items: center;
  justify-content: center;
}

.packages-block__intro-image img {
  width: 100%;
  height: auto;
  border-radius: var(--space-xs);
}

.packages-block__items {
  display: flex;
  flex-direction: column;
  gap: var(--space-l);
}

.packages-block__item {
  padding: var(--space-l);
  background-color: rgba(0, 0, 0, 0.02);
  border-radius: var(--space-s);
  /* border-inline-start: 4px solid var(--color-orange); */
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

/* .packages-block__item:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
  transform: translateY(-0.25rem);
} */

.packages-block__item-name {
  font-size: var(--size-step-3);
  line-height: var(--leading-tight);
  color: var(--color-orange);
  margin-block-end: var(--space-s);
}

.packages-block__item-description {
  font-size: var(--size-step-0);
  line-height: var(--leading-normal);
  color: var(--color-dark);
  margin-block-end: var(--space-m);
  /* font-style: italic; */
}

.packages-block__item-details {
  --flow-space: var(--space-s);
  font-size: var(--size-step-0);
  line-height: var(--leading-normal);
  color: var(--color-dark);
  margin-block-end: var(--space-m);
}

.packages-block__item-details > * + * {
  margin-block-start: var(--flow-space);
}

.packages-block__item-details strong {
  color: var(--color-dark);
  font-weight: var(--font-bold);
}

.packages-block__item-details ul,
.packages-block__item-details ol {
  padding-inline-start: var(--space-m);
  margin-block: var(--space-s);
}

.packages-block__item-details li {
  margin-block-end: var(--space-2xs);
}

.packages-block__item-investment {
  font-size: var(--size-step-1);
  /* font-weight: var(--font-bold); */
  /* color: var(--color-orange); */
  margin-block: var(--space-m);
  padding-top: var(--space-s);
  text-align: center;
  /* border-block-start: 1px solid rgba(0, 0, 0, 0.1); */
  /* border-block-end: 1px solid rgba(0, 0, 0, 0.1); */
}

.packages-block__item-footer {
  --flow-space: var(--space-xs);
  font-size: var(--size-step-0);
  line-height: var(--leading-normal);
  color: var(--color-dark);
  margin-block-start: var(--space-l);
  padding: var(--space-m);
  /* margin-top: var(--space-s); */
  background-color: rgba(0, 0, 0, 0.03);
  border-radius: var(--space-xs);
}

.packages-block__item-footer > * + * {
  margin-block-start: var(--flow-space);
}

.packages-block__item-footer strong {
  /* display: block; */
  /* font-size: var(--size-step-1); */
  /* margin-block-end: var(--space-xs); */
}

/* Responsive adjustments */

@media (max-width: 768px) {
  .packages-block {
    --packages-gap: var(--space-l);
  }

  .packages-block__intro {
    grid-template-columns: 1fr;
  }

  .packages-block__intro-heading {
    font-size: var(--size-step-2);
  }

  .packages-block__intro-copy {
    font-size: var(--size-step-0);
  }

  .packages-block__item {
    padding: var(--space-m);
  }

  .packages-block__item-name {
    font-size: var(--size-step-2);
  }

  .packages-block__item-description {
    font-size: var(--size-step-0);
  }

  .packages-block__item-investment {
    font-size: var(--size-step-1);
  }
}

/**
 * Block Padding System
 *
 * Global padding management for all blocks.
 * Follows CUBE CSS methodology - values defined once, applied consistently.
 *
 * Structure:
 * 1. Default padding for standard content blocks
 * 2. Explicit no-padding for full-bleed blocks
 * 3. Utility classes (has-padding--*, has-spacing--*) - override defaults
 *
 * Order matters: defaults first, then utilities to override them.
 */

/* ==========================================================================
   DEFAULT BLOCK PADDING - Standard content blocks
   ========================================================================== */

/* Content blocks that should have standard top/bottom padding */

/* .feature-block, */

.feature-cards-block,
.regular-intro-block,
.usp-cards-block,
.our-spaces-cards-block,
.facilities-cards-block,
.sustainability-usps-block,
.sustainability-plan-cards-block,
.targets-performance-block,
.companies-list-block,
.walking-times-block,
.copy-gallery-block,
.copy-data-table-block,
.contact-details-block,
.events-block,
.latest-block,
.office-stats-block,
.waterfront-profile-block,
.before-after-slider-block,
.panorama-360-block,
/* .page-hero-block--contained-in-shape, */
.full-bleed-media-in-shape-block,
.form-block {
	padding-top: var(--block-spacing);
	padding-bottom: var(--block-spacing);
}

/* CTA blocks typically need standard padding */

.page-cta-block,
.enquiry-cta-block,
.offices-cta-block,
.office-feature-intro-block {
	padding-top: var(--block-spacing);
	padding-bottom: var(--block-spacing);
}

/* ==========================================================================
   DOUBLE PADDING
   ========================================================================== */

.availability-cta-block {
	padding-top: var(--block-spacing--double);
	padding-bottom: var(--block-spacing--double);
}

/* ==========================================================================
   NO PADDING - Full-bleed and hero blocks
   ========================================================================== */

/* Full-bleed blocks should have no padding by default */

.full-bleed-slider-block,
.big-intro-block,
/* .full-bleed-media-in-shape-block, */
.page-hero-block.not(.page-hero-block--contained-in-shape),
.home-hero-block,
.hero-gallery-block {
	padding-top: 0;
	padding-bottom: 0;
}

/* just padding on bottom */

.page-hero-block--contained-in-shape {
	padding-bottom: var(--block-spacing);
}

/* ==========================================================================
   UTILITY CLASSES - Override defaults when applied via ACF
   ========================================================================== */

/*
 * These classes override the block-specific defaults above.
 * Applied via ACF fields for per-instance customization.
 *
 * Order: These come AFTER block defaults to ensure proper cascade.
 */

.has-padding--none {
	padding-top: 0;
	padding-bottom: 0;
}

.has-padding--half {
	padding-top: calc(var(--block-spacing) / 2);
	padding-bottom: calc(var(--block-spacing) / 2);
}

.has-padding--standard {
	padding-top: var(--block-spacing);
	padding-bottom: var(--block-spacing);
}

.has-padding--large {
	padding-top: var(--block-spacing--double);
	padding-bottom: var(--block-spacing--double);
}

/* Individual padding-top utilities */

.has-padding-top--none {
	padding-top: 0;
}

.has-padding-top--half {
	padding-top: calc(var(--block-spacing) / 2);
}

.has-padding-top--standard {
	padding-top: var(--block-spacing);
}

.has-padding-top--large {
	padding-top: var(--block-spacing--double);
}

/* Individual padding-bottom utilities */

.has-padding-bottom--none {
	padding-bottom: 0;
}

.has-padding-bottom--half {
	padding-bottom: calc(var(--block-spacing) / 2);
}

.has-padding-bottom--standard {
	padding-bottom: var(--block-spacing);
}

.has-padding-bottom--large {
	padding-bottom: var(--block-spacing--double);
}

.has-spacing--half {
	margin-bottom: calc(var(--block-spacing) / 2);
}

.has-spacing--standard {
	margin-bottom: var(--block-spacing);
}

.has-spacing--large {
	margin-bottom: var(--block-spacing--double);
}

/* ==========================================================================
   RESPONSIVE PADDING UTILITIES - Apply padding at specific breakpoints
   ========================================================================== */

/*
 * Responsive padding utilities following Tailwind-style prefix pattern.
 * Apply padding only at specified breakpoint and above.
 *
 * Usage: Add class to block in ACF or template
 * Example: class="md:has-padding--standard lg:has-padding--large"
 */

/* Medium screens and up (768px+) */

@media (min-width: 760px) {
	.md\:has-padding--none {
		padding-top: 0;
		padding-bottom: 0;
	}

	.md\:has-padding--half {
		padding-top: calc(var(--block-spacing) / 2);
		padding-bottom: calc(var(--block-spacing) / 2);
	}

	.md\:has-padding--standard {
		padding-top: var(--block-spacing);
		padding-bottom: var(--block-spacing);
	}

	.md\:has-padding--large {
		padding-top: var(--block-spacing--double);
		padding-bottom: var(--block-spacing--double);
	}

	/* Individual padding-top utilities */
	.md\:has-padding-top--none {
		padding-top: 0;
	}

	.md\:has-padding-top--half {
		padding-top: calc(var(--block-spacing) / 2);
	}

	.md\:has-padding-top--standard {
		padding-top: var(--block-spacing);
	}

	.md\:has-padding-top--large {
		padding-top: var(--block-spacing--double);
	}

	/* Individual padding-bottom utilities */
	.md\:has-padding-bottom--none {
		padding-bottom: 0;
	}

	.md\:has-padding-bottom--half {
		padding-bottom: calc(var(--block-spacing) / 2);
	}

	.md\:has-padding-bottom--standard {
		padding-bottom: var(--block-spacing);
	}

	.md\:has-padding-bottom--large {
		padding-bottom: var(--block-spacing--double);
	}

	.md\:has-spacing--half {
		margin-bottom: calc(var(--block-spacing) / 2);
	}

	.md\:has-spacing--standard {
		margin-bottom: var(--block-spacing);
	}

	.md\:has-spacing--large {
		margin-bottom: var(--block-spacing--double);
	}
}

/* Large screens and up (1024px+) */

@media (min-width: 1230px) {
	.lg\:has-padding--none {
		padding-top: 0;
		padding-bottom: 0;
	}

	.lg\:has-padding--half {
		padding-top: calc(var(--block-spacing) / 2);
		padding-bottom: calc(var(--block-spacing) / 2);
	}

	.lg\:has-padding--standard {
		padding-top: var(--block-spacing);
		padding-bottom: var(--block-spacing);
	}

	.lg\:has-padding--large {
		padding-top: var(--block-spacing--double);
		padding-bottom: var(--block-spacing--double);
	}

	/* Individual padding-top utilities */
	.lg\:has-padding-top--none {
		padding-top: 0;
	}

	.lg\:has-padding-top--half {
		padding-top: calc(var(--block-spacing) / 2);
	}

	.lg\:has-padding-top--standard {
		padding-top: var(--block-spacing);
	}

	.lg\:has-padding-top--large {
		padding-top: var(--block-spacing--double);
	}

	/* Individual padding-bottom utilities */
	.lg\:has-padding-bottom--none {
		padding-bottom: 0;
	}

	.lg\:has-padding-bottom--half {
		padding-bottom: calc(var(--block-spacing) / 2);
	}

	.lg\:has-padding-bottom--standard {
		padding-bottom: var(--block-spacing);
	}

	.lg\:has-padding-bottom--large {
		padding-bottom: var(--block-spacing--double);
	}

	.lg\:has-spacing--half {
		margin-bottom: calc(var(--block-spacing) / 2);
	}

	.lg\:has-spacing--standard {
		margin-bottom: var(--block-spacing);
	}

	.lg\:has-spacing--large {
		margin-bottom: var(--block-spacing--double);
	}
}

/* if block is the first block, we might need to add padding */

.page-content div:nth-child(1) h1.first-gutenberg-block,
	.page-content div:nth-child(1) h2.first-gutenberg-block,
	.page-content div:nth-child(1) h3.first-gutenberg-block,
	.page-content div:nth-child(1) h4.first-gutenberg-block,
	.page-content div:nth-child(1) h5.first-gutenberg-block,
	.page-content div:nth-child(1) h6.first-gutenberg-block,
	.page-content div:nth-child(1) p.first-gutenberg-block {
		padding-top: var(--block-spacing);
	}

/* Remove padding-top from blocks that follow gutenberg-blocks-wrapper */

.page-content .gutenberg-blocks-wrapper + div,
.page-content .gutenberg-blocks-wrapper + section,
.page-content .gutenberg-blocks-wrapper + article {
	padding-top: 0 !important;
}

/* blog content spacing */

body.single-post #main {
	margin-top: var(--block-spacing); 
}

body.single-post #main > *,
body.single-post #main div > * {
	margin-bottom: calc(var(--block-spacing) / 2);
}

/* USP Block Styles */

.usp-block {
  --usp-gap: var(--space-l);
}

.usp-block__intro {
  text-align: center;
  max-inline-size: 75ch;
  margin-inline: auto;
  margin-block-end: var(--usp-gap);
}

.usp-block__intro-heading {
  font-size: var(--size-step-3);
  line-height: var(--leading-tight);
  margin-block-end: var(--space-s);
  color: var(--color-dark);
}

.usp-block__intro-copy {
  font-size: var(--size-step-1);
  line-height: var(--leading-normal);
  color: var(--color-dark);
}

.usp-block__items {
  --grid-gap: var(--space-m);
}

.usp-block__item {
  display: flex;
  flex-direction: column;
  gap: var(--space-s);
  padding: var(--space-m);
  background-color: rgba(0, 0, 0, 0.02);
  border-radius: var(--space-xs);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.usp-block__item:hover {
  /* transform: translateY(-0.25rem); */
  /* box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); */
}

.usp-block__item-heading {
  font-size: var(--size-step-2);
  line-height: var(--leading-tight);
  color: var(--color-orange);
}

.usp-block__item-copy {
  font-size: var(--size-step-0);
  line-height: var(--leading-normal);
  color: var(--color-dark);
}

/* Responsive adjustments */

@media (max-width: 768px) {
  .usp-block {
    --usp-gap: var(--space-m);
  }

  .usp-block__intro-heading {
    font-size: var(--size-step-2);
  }

  .usp-block__intro-copy {
    font-size: var(--size-step-0);
  }

  .usp-block__item {
    padding: var(--space-s);
  }

  .usp-block__item-heading {
    font-size: var(--size-step-1);
  }
}

.block--video iframe,
.block--video img {
	width: 100%;
	aspect-ratio: 16 / 9;
}

.video-thumb {
	aspect-ratio: 16 / 9;
	position: relative;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}

.video-thumb > * {
	position: absolute;
	width: 100%;
}

.video-thumb iframe {
	pointer-events: none;
}

.video-thumb svg {
	width: 8em;
	height: 8em;
	filter: invert(100%);
	mix-blend-mode: difference;
}

.forminator-button,
.button {
    align-items: center;
    background: var(--color-primary);
    border: 1px solid var(--color-primary);
    color: var(--color-light);
    cursor: pointer;
    display: inline-flex;
    flex-shrink: 0;
    font-size: var(--size-step-0);
    font-weight: var(--font-bold);
    gap: 0 var(--space-2xs);
    justify-content: center;
    line-height: 1;
    padding: .6em 2em;
    text-align: center;
    text-decoration: none;
    font-family: var(--font-base);
    text-transform: none;
    font-weight: 500;
    letter-spacing: normal;
    transition: all 0.2s ease;
}

.button.button--outline {
    background-color: var(--color-light);
    color: var(--color-green);
    border: 1px solid var(--color-green);
}

.forminator-button svg,
.button svg {
    height: auto;
    transform: rotate(0deg);
    width: 1.85ex
}

.forminator-button span+svg,
.button span+svg {
    width: 1.5ex
}

.forminator-button:not([data-type=naked]):hover,
.forminator-button[data-type=secondary],
.button:not([data-type=naked]):hover,
.button[data-type=secondary] {
    background: var(--color-green);
    color: var(--color-light);
    border: 1px solid var(--color-green);
}

.forminator-button[data-type=secondary],
.button[data-type=secondary] {
    border: 1px solid var(--color-dark)
}

.forminator-button[data-type=naked],
.button[data-type=naked] {
    background: transparent;
    border: none;
    color: var(--color-dark);
    padding: 0
}

.forminator-button[data-type=badge],
.button[data-type=badge] {
    border-radius: 2em;
    padding: var(--space-2xs) var(--space-s)
}

.button[forminator-data-type=naked]:hover svg,
.button[data-type=naked]:hover svg {
    transform: rotate(-45deg);
    transition: transform var(--transition-base)
}

.forminator-button[data-theme=dark],
.button[data-theme=dark] {
    background-color: var(--color-dark);
    color: var(--color-light)
}

.buttonforminator-[data-type=secondary]:hover,.button[data-theme=dark]:hover,
.button[data-type=secondary]:hover {
    background-color: var(--color-quaternary);
    color: var(--color-dark)
}

.forminator-button[data-theme=ghost],
.button[data-theme=ghost] {
    background: var(--color-light-shade);
    border: 1px solid var(--color-mid-glare);
    color: var(--color-dark)
}

.buttonforminator-[data-theme=ghost] svg,
.button[data-theme=ghost] svg {
    color: var(--color-primary)
}

.buttonforminator-[data-theme=ghost]:hover,
.button[data-theme=ghost]:hover {
    background: var(--color-primary-glare);
    border-color: var(--color-primary);
    color: var(--color-dark)
}

.card {
    backface-visibility: hidden;
    /* background-color: var(--color-pink); */
    color: var(--color-dark);
    display: flex;
    flex-direction: column;
    gap: var(--space-s);
    /* padding: 3px; */
    position: relative;
    text-align: left;
    text-decoration: none;
}

.card img {
        transition: opacity 0.3s ease-in-out;
    }

.card:not([data-type=featured]):nth-last-child(n+1):nth-last-child(-n+2):first-child,
.card:not([data-type=featured]):nth-last-child(n+1):nth-last-child(-n+2):first-child~.card:not([data-type=featured]) {
    max-width: 20rem;
}

.card:not([data-type=featured]):hover {
    /* transform: translateY(-.2em) scale(1.01); */
    /* transition: transform var(--transition-bounce); */
}

.card__content,
.card__media {
    position: relative;
}

.card__content {
    padding: 0 var(--space-s) var(--space-s);
    z-index: 1;
}

.card img {
    aspect-ratio: 1/1;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.card>svg {
    height: auto;
    margin: auto var(--space-xs) var(--space-xs) auto;
    position: relative;
    width: 1.85ex;
    z-index: 1;
}

.card:hover>svg {
    transform: rotate(-45deg);
    transition: transform var(--transition-base);
}

.card:hover img {
    /* filter: grayscale(1); */
    opacity: 0.8;
}

/* .card.testimonial_cpt:hover img { */

/* filter: grayscale(1); */

/* opacity: 1; */

/* } */

.testimonial_cpt blockquote {
        margin: 0 !important;
    }

.card .tags {
    margin-bottom: 0!important;
    margin-top: auto;
}

.card[data-type=featured] {
    --grid-placement: auto-fit;
    --grid-min-item-size: clamp(16rem,50vw,33rem);
    background-color: unset;
    display: grid;
    gap: var(--gutter,var(--space-s-l));
    grid-template-columns: repeat(var(--grid-placement,auto-fill),minmax(var(--grid-min-item-size,16rem),1fr));
    padding: 0;
}

.card[data-type=featured]>div:first-child {
    box-shadow: 0 4px 23px 0 rgba(0,0,0,.2);
    display: flex;
    flex-direction: column;
}

.card[data-type=featured]>div:last-child .button {
    margin-top: var(--space-s-l);
}

.card.grunge:before {
    background-color: var(--color-secondary);
}

@media (min-width: 50em) {
    .card[data-type=featured]>div:last-child {
        padding-right:calc(var(--space-s-l)*2)
    };
}

/* Using forminator... Set CSS to none */

:root {
    --button-bg-color: transparent;
    --button-text-color: var(--color-dark);
    --button-bg-color--hover: transparent;
    --button-text-color--hover: var(--color-primary);
}

.forminator-ui {
  
/*   .forminator-button {

  } */

}

.forminator-ui fieldset {
    padding: var(--flow-space, 1em) var(--flow-space, 1em);
    margin: var(--flow-space, 1em) 0;
  }

.forminator-ui legend {
    padding: 0;
    font-weight: bold;
    font-size: 1.2em;
  }

.forminator-ui .forminator-error-message,
  .forminator-ui label {
    display: block;
    margin: var(--flow-space, 1em) 0;
  }

.forminator-ui .forminator-error-message textarea, .forminator-ui .forminator-error-message select, .forminator-ui .forminator-error-message input[type="text"], .forminator-ui .forminator-error-message input[type="email"], .forminator-ui .forminator-error-message input[type="search"], .forminator-ui .forminator-error-message input[type="tel"], .forminator-ui .forminator-error-message input[type="url"], .forminator-ui .forminator-error-message input[type="password"], .forminator-ui .forminator-error-message input[type="color"], .forminator-ui .forminator-error-message input[type="file"], .forminator-ui .forminator-error-message input[type="color"], .forminator-ui .forminator-error-message input[type="number"], .forminator-ui .forminator-error-message input[type="range"], .forminator-ui .forminator-error-message input[type="date"], .forminator-ui .forminator-error-message input[type="month"], .forminator-ui .forminator-error-message input[type="week"], .forminator-ui .forminator-error-message input[type="time"], .forminator-ui .forminator-error-message input[type="datetime"], .forminator-ui .forminator-error-message input[type="datetime-local"], .forminator-ui label textarea, .forminator-ui label select, .forminator-ui label input[type="text"], .forminator-ui label input[type="email"], .forminator-ui label input[type="search"], .forminator-ui label input[type="tel"], .forminator-ui label input[type="url"], .forminator-ui label input[type="password"], .forminator-ui label input[type="color"], .forminator-ui label input[type="file"], .forminator-ui label input[type="color"], .forminator-ui label input[type="number"], .forminator-ui label input[type="range"], .forminator-ui label input[type="date"], .forminator-ui label input[type="month"], .forminator-ui label input[type="week"], .forminator-ui label input[type="time"], .forminator-ui label input[type="datetime"], .forminator-ui label input[type="datetime-local"] {
      display: block;
      width: 100%;
    }

.forminator-ui textarea, .forminator-ui select, .forminator-ui input[type="text"], .forminator-ui input[type="email"], .forminator-ui input[type="search"], .forminator-ui input[type="tel"], .forminator-ui input[type="url"], .forminator-ui input[type="password"], .forminator-ui input[type="color"], .forminator-ui input[type="file"], .forminator-ui input[type="color"], .forminator-ui input[type="number"], .forminator-ui input[type="range"], .forminator-ui input[type="date"], .forminator-ui input[type="month"], .forminator-ui input[type="week"], .forminator-ui input[type="time"], .forminator-ui input[type="datetime"], .forminator-ui input[type="datetime-local"] {
      margin: .2em 0;
      padding: .25em .4em;
      border: 1px solid #ddd;
      max-width: 100%; 
  }

.forminator-ui input[type="search"] { 
    box-sizing: border-box;
  }

.forminator-ui input[type="file"] { 
    border-width: 0;
    padding: 0;
  }

.forminator-ui input[type="image"] {
    vertical-align: bottom;
  }

.forminator-ui .forminator-button {
    background-color: var(--button-bg-color);
    color: var(--button-text-color);
  }

.forminator-ui .forminator-button:hover {
    background-color: var(--button-bg-color--hover);
    color: var(--button-text-color--hover);
  }

/* :root {
    --color-fui-black-rgba: rgba(0, 0, 0, 0);
    --color-fui-error: #E04562;
    --color-fui-error-rgba: rgba(224, 69, 98, 0.3);
    --color-fui-success: #1ABCA1;
    --color-fui-gray-dark: #888888; 
    --color-fui-gray: #777777; 
    --color-fui-gray-light: #999;
    --color-fui-gray-lighter: #b7b7b7;
    --color-fui-primary: var(--color-orange);
    --color-fui-primary-hover: var(--color-orangeburnt);
    --color-fui-background: #F8F8F8;
    --color-fui-background-lighter: #EDEDED;
    --color-fui-background-lightest: #E6E6E6;
    --color-fui-background-hover: #DDDDDD;
    --color-fui-white: #FFFFFF;
    --color-fui-button-success: #1ABCA1;
    --color-fui-button-success-hover: #159C85;
    --color-fui-delete-background: rgba(0, 0, 0, 0);
    --color-fui-delete-background-hover: #F9E4E8;
}

.forminator-ui:not(.select2-dropdown),
.forminator-ui .forminator-response-message,
.forminator-ui .forminator-response-message p,
.forminator-ui .forminator-description,
.forminator-ui .forminator-description p,
.forminator-ui .forminator-error-message,
.forminator-ui .forminator-input,
.forminator-ui .forminator-input input,
.forminator-ui .forminator-input::placeholder,
.forminator-ui .forminator-input:-moz-placeholder,
.forminator-ui .forminator-input::-moz-placeholder,
.forminator-ui .forminator-input:-ms-input-placeholder,
.forminator-ui .forminator-input::-webkit-input-placeholder,
.forminator-ui .forminator-select,
.forminator-ui .forminator-select--arrow,
.forminator-ui .forminator-calculation,
.forminator-ui .forminator-calculation span,
.forminator-ui .forminator-pagination-footer,
.forminator-ui .forminator-pagination-footer .forminator-button-submit,
.forminator-ui .forminator-pagination-footer .forminator-button-next,
.forminator-ui .forminator-pagination-footer .forminator-button-back,
.forminator-ui .forminator-field.fui-acceptance .forminator-checkbox label,
.forminator-ui .forminator-select2-container--default .forminator-select2-selection--single,
.forminator-ui .forminator-select2-container--default .forminator-select2-selection--multiple,
.forminator-ui .forminator-select2-container--default.forminator-select2-container--focus .forminator-select2-selection--single,
.forminator-ui .forminator-select2-container--default.forminator-select2-container--focus .forminator-select2-selection--multiple,
.forminator-ui .forminator-select2-container--default .forminator-select2-selection--single .forminator-select2-selection__arrow b,
.forminator-ui .forminator-select2-container--default .forminator-select2-selection--multiple .forminator-select2-selection__arrow b,
.forminator-ui .forminator-select2-container--default .forminator-select2-results__option--highlighted[aria-selected],
.forminator-ui .forminator-select2-container--default .forminator-select2-results__option--highlighted[aria-selected]:hover,
.forminator-ui .forminator-select2-container .forminator-select2-selection__choice,
.forminator-ui .forminator-select2-container .forminator-select2-selection__choice__remove {
    font-family: inherit;
    font-weight: 400;
}

.forminator-error-message {
    font-size: 16px !important;
}

#forminator-module-361 {
    padding: 0;
    border: 0 none;
    border-radius: 0;
    border-color: var(--color-fui-black-rgba) !important;
    background-color: var(--color-fui-black-rgba) !important;
}

.forminator-ui .forminator-response-message.forminator-error,
.forminator-ui .forminator-response-message.forminator-success {
    box-shadow: inset 4px 0 0 0 var(--color-fui-error), 1px 1px 4px 0 var(--color-fui-error-rgba) !important;
}

.forminator-ui .forminator-response-message.forminator-error:hover,
.forminator-ui .forminator-response-message.forminator-error:focus,
.forminator-ui .forminator-response-message.forminator-error:active,
.forminator-ui .forminator-response-message.forminator-success:hover,
.forminator-ui .forminator-response-message.forminator-success:focus,
.forminator-ui .forminator-response-message.forminator-success:active {
    box-shadow: inset 4px 0 0 0 var(--color-fui-error), 1px 1px 4px 0 var(--color-fui-error-rgba) !important;
}

.forminator-ui .forminator-response-message.forminator-error,
.forminator-ui .forminator-response-message.forminator-error p,
.forminator-ui .forminator-response-message.forminator-success,
.forminator-ui .forminator-response-message.forminator-success p {
    color: var(--color-fui-gray-dark) !important;
}

.forminator-ui .forminator-response-message.forminator-loading {
    background-color: var(--color-fui-background) !important;
    color: var(--color-fui-gray) !important;
}

.forminator-ui .forminator-title {
    font-size: 45px;
    text-align: left;
    color: var(--color-fui-gray-dark) !important;
}

.forminator-ui .forminator-subtitle {
    font-size: 18px;
    text-align: left;
    color: var(--color-fui-gray-dark) !important;
}

.forminator-ui .forminator-label[class*="forminator-floating-"] {
    font-size: 16px;
    color: var(--color-fui-gray-light) !important;
}

.forminator-ui .forminator-label:not([class*="forminator-floating-"]) {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-fui-gray-lighter) !important;
}

.forminator-ui .forminator-is_filled .forminator-label[class*="forminator-floating-"],
.forminator-ui .forminator-is_active .forminator-label[class*="forminator-floating-"] {
    font-size: 14px;
    font-weight: 700;
    color: var(--color-fui-gray-lighter) !important;
}

.forminator-ui .forminator-label:not([class*="forminator-floating-"]) .forminator-required,
.forminator-ui .forminator-is_filled .forminator-label[class*="forminator-floating-"] .forminator-required,
.forminator-ui .forminator-is_active .forminator-label[class*="forminator-floating-"] .forminator-required,
.forminator-ui .forminator-is_filled.forminator-has_error .forminator-label[class*="forminator-floating-"],
.forminator-ui .forminator-is_active.forminator-has_error .forminator-label[class*="forminator-floating-"] {
    color: var(--color-fui-error) !important;
}

.forminator-ui .forminator-description a,
.forminator-ui .forminator-description a:hover,
.forminator-ui .forminator-description a:focus,
.forminator-ui .forminator-description a:active,
.forminator-ui .forminator-select2-container .forminator-select2-selection__choice__remove {
    box-shadow: none;
    text-decoration: none;
}

.forminator-ui .forminator-description a {
    color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-description a:hover,
.forminator-ui .forminator-description a:active {
    color: var(--color-fui-primary-hover) !important;
}

.forminator-ui .forminator-input,
.forminator-ui .forminator-input input,
.forminator-ui .forminator-select {
    font-size: 16px;
    border-color: var(--color-fui-gray-lighter) !important;
    color: var(--color-white) !important;
}

.forminator-ui .forminator-input:disabled,
.forminator-ui .forminator-calculation:disabled,
.forminator-ui .forminator-select:disabled {
    -webkit-text-fill-color: #000;
    opacity: 1;
}

.forminator-ui .forminator-input::placeholder,
.forminator-ui .forminator-input:-moz-placeholder,
.forminator-ui .forminator-input::-moz-placeholder,
.forminator-ui .forminator-input:-ms-input-placeholder,
.forminator-ui .forminator-input::-webkit-input-placeholder {
    color: var(--color-fui-gray-light) !important;
}

.forminator-ui .forminator-input--wrap:after,
.forminator-ui .forminator-is_active .forminator-input--wrap:after,
.forminator-ui .forminator-is_active .forminator-input--wrap:after {
    background-color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-has_error .forminator-input--wrap:after {
    background-color: var(--color-fui-error) !important;
}

.forminator-ui .forminator-checkbox input:checked + label:before,
.forminator-ui .forminator-radio input:checked + label:before {
    background-color: var(--color-fui-primary) !important;
    border-color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-checkbox input + label:before,
.forminator-ui .forminator-radio input + label:before {
    border-color: var(--color-fui-gray-light) !important;
}

.forminator-ui .forminator-radio .forminator-radio-bullet {
    background-color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-select--arrow,
.forminator-ui .forminator-select--arrow:before,
.forminator-ui .forminator-select--arrow:after,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon:before,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon span,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon span:before,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-label,
.forminator-ui .forminator-pagination-footer .forminator-button-submit,
.forminator-ui .forminator-pagination-footer .forminator-button-next,
.forminator-ui .forminator-pagination-footer .forminator-button-back,
.forminator-ui .forminator-button-submit,
.forminator-ui .forminator-button-back,
.forminator-ui .forminator-button-delete {
    background-color: var(--color-fui-primary) !important;
    border-color: var(--color-fui-primary) !important;
    color: var(--color-fui-white) !important;
    text-align: center;
    margin-top: 10px;
    margin-right: 5px;
    margin-bottom: 0;
    margin-left: 5px;
    font-weight: 700;
    text-transform: none;
    padding: 10px 20px;
    height: auto;
    line-height: 1.5;
    box-shadow: none;
    border-radius: 5px;
}

.forminator-ui .forminator-pagination-header .forminator-pagination-steps,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon:before {
    color: var(--color-fui-white) !important;
}

.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon {
    color: var(--color-fui-primary) !important;
    border-color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon span,
.forminator-ui .forminator-pagination-header .forminator-pagination-steps .forminator-step-icon span:before {
    background-color: var(--color-fui-primary) !important;
    color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-button-submit:hover,
.forminator-ui .forminator-button-submit:focus,
.forminator-ui .forminator-button-submit:active,
.forminator-ui .forminator-button-back:hover,
.forminator-ui .forminator-button-back:focus,
.forminator-ui .forminator-button-back:active,
.forminator-ui .forminator-button-delete:hover,
.forminator-ui .forminator-button-delete:focus,
.forminator-ui .forminator-button-delete:active {
    background-color: var(--color-fui-primary-hover) !important;
    border-color: var(--color-fui-primary-hover) !important;
    color: var(--color-fui-white) !important;
}

.forminator-ui .forminator-button-back {
    font-size: 14px;
    border-color: var(--color-fui-background-lighter) !important;
    background-color: var(--color-fui-background-lighter) !important;
    color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-button-back:hover,
.forminator-ui .forminator-button-back:focus,
.forminator-ui .forminator-button-back:active {
    background-color: var(--color-fui-background-hover) !important;
    border-color: var(--color-fui-background-hover) !important;
    color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-button-delete {
    font-size: 14px;
    border-color: var(--color-fui-delete-background) !important;
    background-color: var(--color-fui-delete-background) !important;
    color: var(--color-fui-error) !important;
}

.forminator-ui .forminator-button-delete:hover,
.forminator-ui .forminator-button-delete:focus,
.forminator-ui .forminator-button-delete:active {
    background-color: var(--color-fui-delete-background !important-hover);
    border-color: var(--color-fui-delete-background !important-hover);
    color: var(--color-fui-error) !important;
}

.forminator-ui .forminator-field.fui-acceptance .forminator-checkbox label {
    font-size: 16px;
    color: var(--color-fui-gray-light) !important;
}

.forminator-ui .forminator-select2-container--default .forminator-select2-selection--single,
.forminator-ui .forminator-select2-container--default .forminator-select2-selection--multiple,
.forminator-ui .forminator-select2-container--default.forminator-select2-container--focus .forminator-select2-selection--single,
.forminator-ui .forminator-select2-container--default.forminator-select2-container--focus .forminator-select2-selection--multiple,
.forminator-ui .forminator-select2-container--default .forminator-select2-results__option--highlighted[aria-selected],
.forminator-ui .forminator-select2-container--default .forminator-select2-results__option--highlighted[aria-selected]:hover,
.forminator-ui .forminator-select2-container .forminator-select2-selection__choice {
    border-color: var(--color-fui-gray-lighter) !important;
    background-color: var(--color-fui-background-lighter) !important;
    color: var(--color-fui-primary) !important;
}

.forminator-ui .forminator-select2-container .forminator-select2-selection__choice__remove {
    color: var(--color-fui-primary) !important;
}

.forminator-ui button.forminator-button {
    align-items: center !important;
    background: var(--color-primary) !important;
    border: 1px solid var(---color-primary) !important;
    color: var(--color-light) !important;
    cursor: pointer !important;
    display: inline-flex !important;
    flex-shrink: 0 !important;
    font-size: var(--size-step-0) !important;
    font-family: var(--font-bold) !important;
    gap: 0 var(--space-2xs) !important;
    justify-content: center !important;
    line-height: 1 !important;
    padding: .4em 2em !important;
    text-align: center !important;
    text-decoration: none !important;
    border-radius: 5rem !important;
    text-transform: uppercase !important;
    transition: all 0.2s !important;
}
 */

ul.menu.off-canvas-menu {
  margin: 3rem 0;
}

ul.menu.off-canvas-menu li {
    margin-bottom: 1rem;
  }

.off-canvas__social .social-links svg path, .off-canvas__social .social-links svg circle {
      fill: var(--color-light)
    }

.off-canvas__social .social-links svg {
    width: 2rem;
    height: 2rem;
  }

.off-canvas {
    background-color: var(--color-primary);
    color: var(--color-light);
    padding: var(--flow-space, 3rem);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.off-canvas__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    gap: var(--space-m);
}

.off-canvas__contact {
    margin-block-start: var(--space-m);
}

.off-canvas__contact li {
    margin-block-end: var(--space-xs);
}

.off-canvas__social {
    padding-block-start: var(--space-m);
    border-block-start: 1px solid rgba(255, 255, 255, 0.2);
}

.off-canvas__social .social-links {
    justify-content: center;
}

.off-canvas__social svg rect,
.off-canvas__social svg path {
    fill: var(--color-light);
}

.site-overlay {
    z-index: 1;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #000;
    visibility: hidden;
    opacity: 0;
    cursor: pointer;

    -webkit-transition: visibility 0s ease, opacity .2s ease;
    -moz-transition: visibility 0s ease, opacity .2s ease;
    -o-transition: visibility 0s ease, opacity .2s ease;
    transition: visibility 0s ease, opacity .2s ease;
}

/* Just few cosmetic CSS for overlay fade in/out */

.offside-js--is-open .site-overlay {
    visibility: visible;
    opacity: .7;
    -webkit-transition-delay: delay 0s;
    -o-transition-delay: delay 0s;
    transition-delay: delay 0s;
}

.pill {
    background-color: var(--color-white);
    color: var(--color-green);
    display: inline-block;
    font-size: var(--size-step-00);
    padding: var(--space-3xs) var(--space-2xs);
    text-decoration: none;
    outline: solid 1px var(--color-green);
    /* text-transform: uppercase; */
    border-radius: 5px;
}

.prose {
  --flow-space: var(--space-m);
  /* font-size: var(--size-step-3); */
}

/* Single Post Styles */

.single-post {
  /* --single-post-spacing: var(--space-l); */
  /* padding-block: var(--single-post-spacing); */
}

.single-post__back-link {
  margin: var(--space-m) 0;
}

.back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  color: var(--color-dark);
  text-decoration: none;
  font-size: var(--size-step-0);
  transition: transform var(--transition-base), color var(--transition-base);
}

.back-link:hover {
  transform: translateX(-0.25rem);
  color: var(--color-orange);
}

.back-link svg {
  width: 1rem;
  height: 1rem;
  transition: transform var(--transition-base);
}

/* Header Section */

.single-post__header {
  margin-block-end: var(--space-l);
  padding-block-end: var(--space-m);
  border-block-end: 1px solid rgba(0, 0, 0, 0.1);
}

.single-post__title {
  font-size: var(--size-step-4);
  line-height: var(--leading-tight);
  margin-block-end: var(--space-s);
  color: var(--color-dark);
}

.single-post__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-xs);
  font-size: var(--size-step-0);
  color: var(--color-dark);
  opacity: 0.7;
}

.single-post__separator {
  opacity: 0.5;
}

.single-post__categories {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
}

/* Featured Image */

.single-post__featured-image {
  margin-block-end: var(--space-l);
}

.single-post__featured-image img {
  width: 100%;
  height: auto;
  border-radius: var(--space-xs);
}

/* Content Section */

.single-post__content {
  --flow-space: var(--space-m);
  max-inline-size: 75ch;
  margin-inline: auto;
  font-size: var(--size-step-1);
  line-height: var(--leading-loose);
}

.single-post__content > * + * {
  margin-block-start: var(--flow-space);
}

.single-post__content h2 {
  font-size: var(--size-step-3);
  line-height: var(--leading-tight);
  margin-block-start: var(--space-l);
  margin-block-end: var(--space-s);
  color: var(--color-dark);
}

.single-post__content h3 {
  font-size: var(--size-step-2);
  line-height: var(--leading-tight);
  margin-block-start: var(--space-m);
  margin-block-end: var(--space-xs);
  color: var(--color-dark);
}

.single-post__content h4 {
  font-size: var(--size-step-1);
  line-height: var(--leading-normal);
  margin-block-start: var(--space-m);
  margin-block-end: var(--space-xs);
  color: var(--color-dark);
}

.single-post__content p {
  margin-block-end: var(--space-s);
}

.single-post__content a {
  color: var(--color-orange);
  text-decoration: underline;
  transition: color var(--transition-base);
}

.single-post__content a:hover {
  color: var(--color-dark);
}

.single-post__content ul,
.single-post__content ol {
  padding-inline-start: var(--space-m);
  margin-block-end: var(--space-s);
}

.single-post__content li {
  margin-block-end: var(--space-2xs);
}

.single-post__content blockquote {
  padding: var(--space-m);
  margin-block: var(--space-m);
  border-inline-start: 4px solid var(--color-orange);
  background-color: rgba(0, 0, 0, 0.02);
  font-style: italic;
}

.single-post__content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--space-xs);
  margin-block: var(--space-m);
}

.single-post__content pre {
  padding: var(--space-m);
  background-color: var(--color-dark);
  color: var(--color-light);
  border-radius: var(--space-xs);
  overflow-x: auto;
  margin-block: var(--space-m);
}

.single-post__content code {
  font-family: 'Courier New', monospace;
  font-size: 0.9em;
}

.single-post__content pre code {
  color: var(--color-light);
}

/* Responsive adjustments */

@media (max-width: 768px) {
  .single-post {
    --single-post-spacing: var(--space-m);
  }

  .single-post__title {
    font-size: var(--size-step-3);
  }

  .single-post__content {
    font-size: var(--size-step-0);
    max-inline-size: 100%;
  }

  .single-post__content h2 {
    font-size: var(--size-step-2);
  }

  .single-post__content h3 {
    font-size: var(--size-step-1);
  }
}

.footer-logo {
  width: 18rem;
}

.site-footer {
  background-color: var(--color-green);
}

.site-footer * {
    color: var(--color-white);
  }

.site-footer svg path {
    fill: var(--color-white) !important;
  }

.site-footer .social-links svg {
    width: 2rem;
    height: 2rem;
  }

.site-footer .social-links svg circle {
      fill: var(--color-white)
    }

.footer-nav a {
  text-decoration: none;
}

/* Footer Logos */

.footer-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-m);
  margin-block-start: var(--space-xl);
  padding-block-start: var(--space-l);
  border-block-start: 1px solid var(--color-white);
  /* opacity: 0.3; */
}

.footer-logos__item {
  max-inline-size: 8rem;
  opacity: 1;
  transition: opacity var(--transition-base);
}

.footer-logos__item:hover {
  /* opacity: 1; */
}

.footer-logos__item img {
  width: 100%;
  height: auto;
  display: block;
  /* filter: brightness(0) invert(1); */
}

@media (max-width: 768px) {
  .footer-logos {
    gap: var(--space-s);
  }

  .footer-logos__item {
    max-inline-size: 6rem;
  }
}

/*** Site Header / Nav Styles ***/

.nav-logo {
  width: 10rem;
}

.menu a {
    letter-spacing: .04ch;
    text-decoration: none;
}

@media (max-width: 31em) {

.site-header .nav-button-wrapper .button {
      padding: 0.2rem
  }
    }

.site-header .nav-button-wrapper span {
    display: none;
  }

@media (min-width: 31em) {

.site-header .nav-button-wrapper span {
      display: block
  }
    }

@media (max-width: 31em) {

.site-header .nav-button-wrapper svg {
      width: 1.6rem
  }
    }

@media (min-width: 31em) {

.site-header .nav-button-wrapper svg {
      display: none
  }
    }

/*** Header Options: ***/

/*** 1 - Sticky header ***/

.site-header {
  z-index: 10;
  position: sticky;
  top: 0;
}

/*** 1 - Auto Hide Header on Scroll - Need to add JS ***/

/* .site-header-inner {
  z-index: 10;
  position: fixed;
  transition: all 0.2s;
  width: 100%;
  height: var(--nav-height, 100px);
  top: 0;
}

.site-header-content-wrapper {
  height: var(--nav-height, 100px);
}

.site-header-bg {
  position: absolute;
  width: 100%;
  background-color: var(--color-light);
  height: var(--nav-height, 100px);
} */

/* html.page-is-at-top body.first-block-is-hero {
  .site-header-bg {
    background-color: transparent;
    background-image: linear-gradient(to top, rgba(0,0,0,0), rgba(0,0,0,0.1), rgba(0,0,0,0.1), rgba(0,0,0,0.1));
  }
  .site-header-inner {
    color: var(--color-light);
  }
  .nav-logo svg path {
    fill: var(--color-light);
  }
  .menu-item a {
    background: linear-gradient(0deg, var(--color-light), var(--color-light)) no-repeat right bottom / 0 var(--bg-h);
    transition: background-size 350ms;
    --bg-h: 2px;
    padding-bottom: 2px;
  }
  .menu-item a:where(:hover, :focus-visible) {
    background-size: 100% var(--bg-h);
    background-position-x: left;
  }
} */

@media (min-width: 50em) {

html.nav-is-hidden:not(.page-is-at-top) body:not(.offside-js--is-open) .site-header-inner {
      transform: translateY(-150%)
  }
    }

html.nav-is-visible .site-header-inner, html.nav-is-hidden body.offside-js--is-open .site-header-inner {
      transform: none;
  }

.site-header-inner {
  transition: all 0.2s;
}

/* body:not(.first-block-is-hero):not(.offside-js--is-open) {
  margin-top: var(--nav-height, 100px);
}

body:not(.offside-js--is-open).post-type-archive-stone_cpt,
body:not(.offside-js--is-open).blog,
body:not(.offside-js--is-open).first-block-is-copy {
  margin-top: var(--double-nav-height, 100px);
}

body.first-block-is-hero .site-header {
  position: absolute;
}
body.first-block-is-hero .block-hero {
  &:before {
    content: "";
    display: block;
    height: var(--nav-height, 100px);
  }
} */

/* 
MENU - AUTO HIDE - Remove if not using (also JS)
Auto hiding nav on scroll down and reveal on scroll up
*/

/* .site-header-inner {
  z-index: 10;
  position: fixed;
  transition: all 0.2s;
  width: 100%;
  height: var(--nav-height, 100px);
  top: 0;
}

.site-header-content-wrapper {
  height: var(--nav-height, 100px);
}

.site-header-bg {
  position: absolute;
  width: 100%;
  background-color: var(--color-light);
  height: var(--nav-height, 100px);
}

html.page-is-at-top body.first-block-is-hero {
  .site-header-bg {
    background-color: transparent;
    background-image: linear-gradient(to top, rgba(0,0,0,0), rgba(0,0,0,0.1), rgba(0,0,0,0.1), rgba(0,0,0,0.1));
  }
  .site-header-inner {
    color: var(--color-light);
  }
  .nav-logo svg path {
    fill: var(--color-light);
  }
  .menu-item a {
    background: linear-gradient(0deg, var(--color-light), var(--color-light)) no-repeat right bottom / 0 var(--bg-h);
    transition: background-size 350ms;
    --bg-h: 2px;
    padding-bottom: 2px;
  }
  .menu-item a:where(:hover, :focus-visible) {
    background-size: 100% var(--bg-h);
    background-position-x: left;
  }
}

html.nav-is-hidden body:not(.menu-is-open) {
  .site-header-inner {
    @media (min-width: 50em) {
      transform: translateY(-150%);
    }
  }
}

html.nav-is-visible,
html.nav-is-hidden body.offside-js--is-open {
  .site-header-inner {
      transform: none;
  }
} */

.social-links svg {
  width: 3rem;
  height: 3rem;
}

.social-links svg rect,
.social-links svg path {
  fill: var(--color-dark);
}

/*
CLUSTER
More info: https://every-layout.dev/layouts/cluster/
A layout that lets you distribute items with consitent
spacing, regardless of their size

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--cluster-horizontal-alignment (flex-start) How items should align
horizontally. Can be any acceptable flexbox aligmnent value.

--cluster-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, var(--space-s-m));
  justify-content: var(--cluster-horizontal-alignment, flex-start);
  align-items: var(--cluster-vertical-alignment, center);
}

/* 
FLOW COMPOSITION 
Like the Every Layout stack: https://every-layout.dev/layouts/stack/
Info about this implementation: https://piccalil.li/quick-tip/flow-utility/ 
*/

.flow > * + * {
  margin-top: var(--flow-space, 1em);
}

/* AUTO GRID
Related Every Layout: https://every-layout.dev/layouts/grid/
More info on the flexible nature: https://piccalil.li/tutorial/create-a-responsive-grid-layout-with-no-media-queries-using-css-grid/
A flexible layout that will create an auto-fill grid with
configurable grid item sizes

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--grid-min-item-size (14rem): How large each item should be
ideally, as a minimum.

--grid-placement (auto-fill): Set either auto-fit or auto-fill
to change how empty grid tracks are handled */

.grid {
  display: grid;
  grid-template-columns: repeat(
    var(--grid-placement, auto-fill),
    minmax(var(--grid-min-item-size, 16rem), 1fr)
  );
  gap: var(--gutter, var(--space-s-l));
}

/* A split 50/50 layout */

.grid[data-layout='50-50'] {
  --grid-placement: auto-fit;
  --grid-min-item-size: clamp(16rem, 50vw, 33rem);
}

/* Three column grid layout */

.grid[data-layout='thirds'] {
  --grid-placement: auto-fit;
  --grid-min-item-size: clamp(16rem, 33%, 20rem);
}

/* Twelve column grid layout */

.grid[data-layout='twelfths'] {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
}

/* Special layout for larger devices. Used on home page intro */

.grid[data-layout='lg:10/2'] {
  grid-template-columns: 100%;
}

@media (min-width: 760px) {
  .grid[data-layout='lg:10/2'] {
    grid-template-columns: clamp(40rem, 80vw, 60rem);
  }
}

@media (min-width: 1230px) {
  .grid[data-layout='lg:10/2'] {
    grid-template-columns: 10fr 2fr;
  }
}

/*
REPEL
A little layout that pushes items away from each other where
there is space in the viewport and stacks on small viewports

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--repel-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/

.repel {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: var(--repel-vertical-alignment, center);
  gap: var(--gutter, var(--space-s-m));
}

.repel[data-nowrap] {
  flex-wrap: nowrap;
}

/* 
SIDEBAR
More info: https://every-layout.dev/layouts/sidebar/
A layout that allows you to have a flexible main content area
and a "fixed" width sidebar that sits on the left or right.
If there is not enough viewport space to fit both the sidebar
width *and* the main content minimum width, they will stack
on top of each other

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-size-1)): This defines the space
between the sidebar and main content.

--sidebar-target-width (20rem): How large the sidebar should be

--sidebar-content-min-width(50%): The minimum size of the main content area

EXCEPTIONS
.sidebar[data-direction='rtl']: flips the sidebar to be on the right 
*/

.sidebar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, var(--space-s-l));
}

.sidebar > :first-child {
  flex-basis: var(--sidebar-target-width, 20rem);
  flex-grow: 1;
}

.sidebar > :last-child {
  flex-basis: 0;
  flex-grow: 999;
  min-width: var(--sidebar-content-min-width, 50%);
}

/*
SWITCHER
More info: https://every-layout.dev/layouts/switcher/
A layout that allows you to lay **2** items next to each other
until there is not enough horizontal space to allow that.

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-size-1)): This defines the space
between each item

--switcher-target-container-width (40rem): How large the container
needs to be to allow items to sit inline with each other

--switcher-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/

.switcher {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, var(--space-s-l));
  align-items: var(--switcher-vertical-alignment, flex-start);
}

.switcher > * {
  flex-grow: 1;
  flex-basis: calc((var(--switcher-target-container-width, 40rem) - 100%) * 999);
}

/* Max 2 items,
so anything greater than 2 is ful width */

.switcher > :nth-child(n + 3) {
  flex-basis: 100%;
}

/*
WRAPPER COMPOSITION 
A common wrapper/container
*/

.wrapper {
  margin-inline: auto;
  max-width: clamp(16rem, var(--wrapper-max-width, 100vw), 80rem);  /* clamp(min, val, max) */
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  position: relative;
}

/* 
ABSOLUTE FULL
position absolutely, top, bottom, left, right 0 and 100% height and width
*/

.absolute-full {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}

.img-wrapper {
	position: relative;
}

.img-wrapper picture, .img-wrapper img {
		position: absolute;
		top: 0;
		left: 0;
		height: 100%;
		width: 100%;
		object-fit: cover;
	}

.aspect-ratio--1-1 	{ aspect-ratio: 1 / 1; }

.aspect-ratio--3-2 	{ aspect-ratio: 2 / 3; }

.aspect-ratio--4-3 	{ aspect-ratio: 3 / 4; }

.aspect-ratio--16-9 { aspect-ratio: 16 / 9; }

/* Breadcrumbs utility */

.breadcrumbs {
  --breadcrumb-separator: "/";
  --breadcrumb-gap: var(--space-xs);
  font-size: var(--text-sm, 0.875rem);
}

.breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--breadcrumb-gap);
  list-style: none;
  padding: 0;
  margin: 0;
}

.breadcrumbs__item {
  display: flex;
  align-items: center;
  gap: var(--breadcrumb-gap);
}

/* Add separator between items */

.breadcrumbs__item:not(:last-child)::after {
  content: var(--breadcrumb-separator);
  color: var(--color-gray-400, #9ca3af);
  font-weight: 300;
}

.breadcrumbs__item a {
  color: var(--color-primary, #3b82f6);
  text-decoration: none;
  transition: color 0.2s ease;
}

.breadcrumbs__item a:hover {
  color: var(--color-primary-dark, #2563eb);
  text-decoration: underline;
}

.breadcrumbs__item--current {
  color: var(--color-gray-600, #4b5563);
  font-weight: 500;
}

/* Accessibility - ensure good contrast */

@media (prefers-contrast: high) {
  .breadcrumbs__item a {
    text-decoration: underline;
  }
}

/* 
MENU UTILITY
Push away from each other but wrap when not enough space (For Nav)
*/

.menu ul,
ul.menu {
    --gutter: var(--space-2xs) var(--space-s-m);
    margin: 0
}

/* 
REGION UTILITY
Consistent block padding for page sections
*/

.region {
  padding-block: var(--region-space, var(--space-xl-2xl));
}

.width-10ch {  max-width: 10ch; }

.width-20ch {  max-width: 20ch; }

.width-30ch {  max-width: 30ch; }

.width-40ch {  max-width: 40ch; }

.width-50ch {  max-width: 50ch; }

.width-60ch {  max-width: 60ch; }

.width-70ch {  max-width: 70ch; }

.width-80ch {  max-width: 80ch; }

.width-90ch {  max-width: 90ch; }

.width-100ch {  max-width: 100ch; }

/* 
TINY IMAGE IN A CIRCLE - e.g. TESIMONIAL / AUTHOR IMAGE
*/

.tiny-circle-image {
    width: 3rem;
    height: 3rem;
    
}

.tiny-circle-image img,
.tiny-circle-image picture {
    object-fit: cover;
    height: 100%;
    width: 100%;
    border-radius: 50%;
}

/* Underlined Utility - Stylized textured underline using brand SVG */

.underlined {
  position: relative;
  display: inline;
  text-decoration: none;
  background-image: url('../../dist/svg/inline-underline-charcoal.svg');
  background-repeat: repeat-x;
  background-position: 0 100%;
  /* background-size: auto 0.3em; */
    background-size: auto;
  padding-block-end: 0.2em;
  transition: background-size var(--transition-base);
}

/* .underlined:hover {
  background-size: auto 0.35em;
} */

/* Thicker variant */

/* .underlined--thick {
  background-size: auto 0.4em;
  padding-block-end: 0.25em;
}

.underlined--thick:hover {
  background-size: auto 0.45em;
} */

/* 
VISUALLY HIDDEN UTILITY
Info: https://piccalil.li/quick-tip/visually-hidden/ 
*/

.visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 0;
  margin: 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}

.display-none {
  display: none;
}

.hide-on-mobile {
  display: none;
}

@media (min-width: 760px) {

.hide-on-mobile {
    display: unset
}

.hide-on-desktop {
    display: none
}
  }

.fixed{
  position: fixed;
}

.relative{
  position: relative;
}

.sticky{
  position: sticky;
}

.mt-2xl{
  margin-top: clamp(4.5rem, 3.95rem + 2.67vw, 6rem);
}

.block{
  display: block;
}

.inline{
  display: inline;
}

.flex{
  display: flex;
}

.table{
  display: table;
}

.grid{
  display: grid;
}

.hidden{
  display: none;
}

.transform{
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.resize{
  resize: both;
}

.flex-col{
  flex-direction: column;
}

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

.gap-xs{
  gap: clamp(0.875rem, 0.78rem + 0.44vw, 1.125rem);
}

.rounded{
  border-radius: 0.25rem;
}

.bg-black{
  background-color: #000000;
}

.bg-dark{
  background-color: #030303;
}

.bg-green{
  background-color: #73a192;
}

.bg-light{
  background-color: #ffffff;
}

.bg-orange{
  background-color: #da7733;
}

.bg-primary{
  background-color: #da7733;
}

.bg-white{
  background-color: #ffffff;
}

.bg-yellow{
  background-color: #e6b24c;
}

.p-xs-s{
  padding: clamp(0.875rem, 0.65rem + 1.11vw, 1.5rem);
}

.py-2xs{
  padding-top: clamp(0.5625rem, 0.49rem + 0.33vw, 0.75rem);
  padding-bottom: clamp(0.5625rem, 0.49rem + 0.33vw, 0.75rem);
}

.py-l{
  padding-top: clamp(2.25rem, 1.98rem + 1.33vw, 3rem);
  padding-bottom: clamp(2.25rem, 1.98rem + 1.33vw, 3rem);
}

.py-m{
  padding-top: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
  padding-bottom: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
}

.text-step-00{
  font-size: clamp(0.9375rem, 0.91rem + 0.11vw, 1rem);
}

.underline{
  text-decoration-line: underline;
}

.no-underline{
  text-decoration-line: none;
}

.opacity-70{
  opacity: 0.7;
}

.outline{
  outline-style: solid;
}

.filter{
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.transition{
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.gutter-xs{
  --gutter: clamp(0.875rem, 0.78rem + 0.44vw, 1.125rem);
}

.bg-dark{
  background-color: #030303;
}

.bg-light{
  background-color: #ffffff;
}

.bg-black{
  background-color: #000000;
}

.bg-white{
  background-color: #ffffff;
}

.bg-green{
  background-color: #73a192;
}

.bg-yellow{
  background-color: #e6b24c;
}

.bg-primary{
  background-color: #da7733;
}

.bg-orange{
  background-color: #da7733;
}

.color-dark{
  color: #030303;
}

.color-light{
  color: #ffffff;
}

.color-black{
  color: #000000;
}

.color-white{
  color: #ffffff;
}

.color-green{
  color: #73a192;
}

.color-yellow{
  color: #e6b24c;
}

.color-primary{
  color: #da7733;
}

.color-orange{
  color: #da7733;
}

/* Display heading (H0) */

.font-h0 {
    font-family: var(--font-heading);
    font-weight: var(--font-light);
    font-size: var(--size-step-5);
    letter-spacing: -0.02em;
    line-height: 1;
    hyphens: auto;
  }

/* Heading utilities with full styling */

.font-h2 {
    font-family: var(--font-heading);
    font-weight: var(--font-light);
    font-size: var(--size-step-3);
    letter-spacing: -0.02em;
    line-height: 1.2;
  }

.font-h4 {
    font-family: var(--font-heading);
    font-weight: var(--font-light);
    font-size: var(--size-step-1);
    letter-spacing: -0.02em;
    line-height: 1.3;
  }

/* Size utilities (just size, no other properties) */

.size-step-3 { font-size: var(--size-step-3); }

.size-step-1 { font-size: var(--size-step-1); }

/* Font family utilities */

/* Font weight utilities */

.font-semibold { font-weight: var(--font-semibold); }

/* Text transform utilities */

/* Navigation & Button typography */

.font-navigation,
  .font-eyebrow {
    font-family: var(--font-base);
    font-weight: var(--font-semibold);
    font-size: 16px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }

:where(.font-eyebrow) {
    margin-top: 0;
  }

/* Body text variants */

.font-body-large {
    font-family: var(--font-base);
    font-weight: var(--font-regular);
    font-size: var(--size-step-2);
    line-height: 1.5;
  }

.font-body-medium {
    font-family: var(--font-base);
    font-weight: var(--font-regular);
    font-size: var(--size-step-0);
    line-height: 1.5;
  }

.font-body-small {
    font-family: var(--font-base);
    font-weight: var(--font-regular);
    font-size: var(--size-step-00);
    line-height: 1.5;
  }

/* Debug styles - only in development */

/* @import '../css-utils/debug.css'; */

/* @import '../css-utils/a11y-check.css'; */

@media (min-width: 760px){

  .md\:flex-row{
    flex-direction: row;
  }
}