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

.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 {
  .site-header-inner {
    padding-top: 32px;
  }
 /*  #wpadminbar {
    opacity: 0.5;
    &:hover {
      opacity: 1;
    }
  } */
}

/* 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;
  text-rendering: optimizeLegibility !important;
  -webkit-font-smoothing: antialiased !important;
}

/* @font-face here */

/* albra-medium */

@font-face {
  font-family: 'albra-medium';
  src:  url('../fonts/albra-medium.woff2') format('woff2'),
        url('../fonts/albra-medium.woff') format('woff');
}

/* albra-semi */

@font-face {
  font-family: 'albra-semi';
  src:  url('../fonts/albra-semi.woff2') format('woff2'),
        url('../fonts/albra-semi.woff') format('woff');
}

@font-face {
  font-family: 'satoshi-regular';
  src: url('../fonts/satoshi-regular.woff2') format('woff2'),
       url('../fonts/satoshi-regular.woff') format('woff'),
       url('../fonts/satoshi-regular.ttf') format('truetype');
  font-weight: 400;
  font-display: swap;
  font-style: normal;
}

@font-face {
  font-family: 'satoshi-bold';
  src: url('../fonts/satoshi-bold.woff2') format('woff2'),
       url('../fonts/satoshi-bold.woff') format('woff'),
       url('../fonts/satoshi-bold.ttf') format('truetype');
  font-weight: 400;
  font-display: swap;
  font-style: normal;
}

/* h1, .h1,
h2, .h2 */

body
/* input, */
/* label  */
{
  font-weight: var(--font-regular);
  font-size: var(--size-step-0);
  font-family: var(--font-base);
  -webkit-font-smoothing: antialiased;
}

h1 {
	font-size: var(--size-step-2);
}

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

/* h1, .h1, */

/* h2, .h2 */

/* h3, .h3,
h4, .h4,
h5, .h5,
h6, .h6
button, .button */

/* input, */

/* label  */

/* {
  font-weight: var(--font-thin);
} */

/* .font-thin { font-weight: var(--font-thin); } */

// orange span of text in titles...
h1,h2,h3,h4,h5,h6 {
  span { color: var(--color-orange); }
}

.block--statement a {
  color: var(--color-orange);
}

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

.font-bold {
  font-weight: unset;
  font-family: var(--font-bold);
}

h1,h2,h3,h4,h5,h6,
.h1,.h2,.h3,.h4,.h5,.h6 { font-family: var(--font-albra-semi); }

.font-albra { font-family: var(--font-albra-semi); }

/* .font-albra { font-family: var(--font-albra-medium); } */

/* .font-albra-semi { 	font-family: var(--font-albra-semi); } */

.uppercase,
.text-uppercase,
.font-uppercase { text-transform: uppercase; }

.size-step-5 {
	font-size: var(--size-step-5);
	letter-spacing: -0.2rem;
	line-height: 0.9em;
  
  -webkit-hyphens: auto;
  -moz-hyphens: auto;
  -ms-hyphens: auto;
  hyphens: auto;
}

.size-step-4 {
  font-size: var(--size-step-4);
  /* letter-spacing: -0.1rem; */
  line-height: 0.86em;
}

.size-step-3 {
  font-size: var(--size-step-3);
  /* line-height: 0; */
}

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

/* p, */

.size-step-1 {
  font-size: var(--size-step-1);
  /* line-height: 0; */
}

.size-step-0 {
  font-size: var(--size-step-0);
  /* line-height: 0; */
}

.size-step-00 {
  font-size: var(--size-step-00);
  /* line-height: 0; */
}

:root {
  --color-dark: #050505;
  --color-light: #f9f9f9;
  --color-orange: #f15924;
  --color-primary: #f15924;
  --color-orangeburnt: #ff482c;
  --color-orangemid: #ff752a;
  --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.6875rem, 0.66rem + 0.11vw, 0.75rem);
  --size-step-0: clamp(0.875rem, 0.83rem + 0.22vw, 1rem);
  --size-step-1: clamp(1.125rem, 1.08rem + 0.22vw, 1.25rem);
  --size-step-2: clamp(1.62rem, 1.38rem + 1.15vw, 2.265625rem);
  --size-step-3: clamp(1.94375rem, 1.28rem + 3.21vw, 3.75rem);
  --size-step-4: clamp(4.6875rem, 4.21rem + 2.33vw, 6rem);
  --size-step-5: clamp(4.375rem, 3.23rem + 5.56vw, 7.5rem);
  --leading-flat: 1;
  --leading-fine: 1.15;
  --leading-loose: 1.7;
  --font-base: satoshi-regular,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;
  --font-bold: satoshi-bold,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;
  --font-albra-medium: albra-medium,serif;
  --font-albra-semi: albra-semi,serif;
  --font-regular: 400;
  --font-medium: 500;
  --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--quarter: calc( var(--flow-space) / 4 );
  --flow-space--double: calc( var(--flow-space) * 2 );
  --flow-space--triple: calc( var(--flow-space) * 3 );
  --flow-space--quadruple: calc( var(--flow-space) * 4 );
  --block-spacing: var(--space-xl);
  --block-spacing--double: calc( var(--block-spacing) * 2 );
  --border-radius: 0.5rem;
}

/* 
  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-dark);
  font-size: var(--size-step-1);
  font-family: var(--font-base);
  line-height: var(--leading-standard);
}

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

/* found this adding space to h1, should be added to reset? */

* {
    margin-block-start: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
}

main > article {
  padding-bottom: var(--flow-space--double);
}

a {
  text-decoration: none;
}

a:hover {
  
}

/* 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.7);
  }
  .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 0 15px 15px;
  display: inline-flex;
  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;
  transition: 0.2s all;
}

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

.hamburger:hover {
    /* opacity: 0.7; */
    color: var(--color-orange);

    .hamburger-inner,
    .hamburger-inner::before,
    .hamburger-inner::after {
      /* background-color: var(--color-orange); */
    }
  }

.hamburger.is-active:hover {
    color: var(--color-orange);
    /* 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: 22px;
  height: 24px;
  display: inline-block;
  position: relative; }

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

.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
    width: 22px;
    height: 2px;
    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: -6px; }

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

/*
   * 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; 
  --offside-inverted-width: -400px; 
  /* --offside-width--desktop: 400px;  */
  /* --offside-inverted-width--desktop: -400px;  */
}

/* Off-canvas element CSS */

.offside {
    position: fixed; /* Does not play well with some old browsers (see: README) */
    min-height: var(--offside-width);
    width: 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 {
    top: var(--offside-inverted-width);
}

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

/* .offside--right {
    top: 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(0, var(--offside-width), 0);
    -moz-transform: translate3d(0, var(--offside-width), 0);
    -ms-transform: translate3d(0, var(--offside-width), 0);
    -o-transform: translate3d(0, var(--offside-width), 0);
    transform: translate3d(0, var(--offside-width), 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 {
    top: 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 {
    top: var(--offside-inverted-width);
}

/* DESKTOP */

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

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


    .no-csstransforms3d > .offside-js--is-right .offside-sliding-element {
        top: 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;
}

a {
	color: var(--color-black, black);
	text-decoration: none;
	border-bottom: 1px solid var(--color-orange);
	transition: 0.2s all;
}

a.no-underline {
	border-bottom: 1px solid transparent;
}

/* .service-card a {
	
} */

.off-canvas-menu,
.site-header {
	a {
		border-bottom: 1px solid transparent;
	}
}

.team-member-content,
.nav-menu-area,
.off-canvas-menu {
	a:hover {
		color: var(--color-orange);
	}
}

.social-links {
	a {
		border-bottom: 1px solid transparent;
	}
	a:hover {
   		border-bottom: 1px solid var(--color-orange);
  	}
}

.site-footer {
  a:not(.button) {
    text-decoration: none;
    border-bottom: 1px solid transparent;
    /* transition: 0.2s border; */
  }
  a:not(.button):hover {
    border-bottom: 1px solid var(--color-orange);
  }
}

.footer-logo {
	a:hover {
	  border-bottom: 1px solid transparent;
	}
}

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

.blog,
.archive {
	main > article {
		padding-top: var(--flow-space--quadruple);
	}
	.card {
		/* margin-bottom: var(--flow-space--double); */
	}
}

.block--copy-and-image-rows {

}

@media (min-width: 50em) {
    .row[data-state="reversed"] {
        /* flex-direction: row-reversed; */
        /* > * { */
        /* } */
    }
}

.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; */
	/* max-height: 805px; */
	width: 100%;
	position: relative;
}

.hero-container {
	position: relative;

	aspect-ratio: 16 / 9;
	max-height: 70vh;
	width: 100%;
}

.block--hero .hero-content {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
}

.gradient-hero-content {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.arrow-graphic-wrapper {
	svg {
		max-width: 50vw;
		g path {
			stroke: var(--color-light);
		}
	}
	display: flex;
	justify-content: center;
	width: 100%;
	margin: var(--flow-space--double) 0;
}

.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--homepage-hero {
	position: relative;

}

.homehero-bg {
	position: absolute;
	height: 70%;
	width: 100%;
}

.home-gallery-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-template-rows: repeat(14, 1fr);
	grid-column-gap: 0.4rem;
	grid-row-gap: 0.4rem;
	aspect-ratio: 1/1;

	>:nth-child(1) { grid-area: 3 / 1 / 7 / 2; }
	>:nth-child(2) { grid-area: 1 / 2 / 5 / 3; }
	>:nth-child(3) { grid-area: 2 / 3 / 6 / 4; }
	>:nth-child(4) { grid-area: 3 / 4 / 7 / 5; }
	>:nth-child(5) { grid-area: 7 / 1 / 12 / 2; }
	>:nth-child(6) { grid-area: 5 / 2 / 10 / 3; }
	>:nth-child(7) { grid-area: 6 / 3 / 9 / 4; }
	>:nth-child(8) { grid-area: 7 / 4 / 11 / 5; }
	>:nth-child(9) { grid-area: 9 / 3 / 14 / 4; }
	>:nth-child(10) { grid-area: 10 / 2 / 13 / 3; }

	@media (min-width: 50em) {
		grid-template-columns: repeat(5, 1fr);
		grid-template-rows: repeat(15, 1fr);
		grid-column-gap: var(--flow-space--half);
		grid-row-gap: var(--flow-space--half);
		/* height: 100vh; */
		aspect-ratio: 3/2;

		>:nth-child(1) { grid-area: 5 / 1 / 10 / 2; }
		>:nth-child(2) { grid-area: 2 / 2 / 8 / 3; }
		>:nth-child(3) { grid-area: 8 / 2 / 14 / 3; }
		>:nth-child(4) { grid-area: 1 / 3 / 7 / 4; }
		>:nth-child(5) { grid-area: 7 / 3 / 12 / 4; }
		>:nth-child(6) { grid-area: 12 / 3 / 16 / 4; }
		>:nth-child(7) { grid-area: 3 / 4 / 11 / 5; }
		>:nth-child(8) { grid-area: 11 / 4 / 15 / 5; }
		>:nth-child(9) { grid-area: 2 / 5 / 7 / 6; }
		>:nth-child(10) { grid-area: 7 / 5 / 13 / 6; }
	}

	* {
		height: 100%;
		border-radius: var(--border-radius, 0.5rem);
	}
	> * {
		/* temp */
		/* max-width: 240px; */

	}
	img {
		object-fit: cover;
		width: 100%;
	}
	.iframe-wrapper {
		background-color: var(--color-dark);
		height: 100%;
		width: 100%;
		overflow: hidden;
		position: relative;
		iframe {
			/* position: absolute;
			height: 100%;
			width: 100%; */
			aspect-ratio: 16 / 9;
			position: absolute;
			margin-left: auto;
			left: 50%;
			transform: translateX(-50%);
		}
        
	}
}

.homehero--default {
	display: flex;
	flex-direction: column;
	align-items: center;
	.homehero-title {
		padding: var(--flow-space) 0 var(--flow-space);
		@media (min-width: 30em) {
			padding: var(--flow-space--triple) 0 var(--flow-space--double);
		}
		width: 100%;
		max-width: 960px;
	}
	.homehero-title--wrapper {
		/* width: 100%; */
	}
	.homehero_copy {
		/* font-weight: var(--font-bold); */
		/* transform: translateY(-100%); */
		@media (min-width: 30em) {
			transform: translateY(-110%);
		}
		@media (min-width: 50em) {
			transform: translateY(-180%);
		}
		@media (min-width: 70em) {
			transform: translateY(-240%);
		}
		
		line-height: 1.2em;
		a {
			border-color: transparent;	
	        text-decoration: underline;
		}

	}
	svg {
		g {
			stroke: var(--color-light);
		}
	}
}

.home-gallery-grid {
	max-width: 1600px;
	width: 100%;
	padding: var(--flow-space--double) 0 var(--flow-space) 0;
	@media (min-width: 30em) {
		padding: var(--flow-space--double) 0 var(--flow-space--quadruple) 0;
	}
}

.block--image img {
	width: 100%;
}

.block--logo-wall {
	&.logo_size--large {
		.logo-gallery--logo {
			height: 100px;
		}
	}
}

/* .block--statement {
	> div {
		
	}
}
 */

.block--talk-to-us {
	/* * { outline: teal 1px solid; }  */
	.forminator-input {
		border-color: var(--color-dark) !important;
		color: var(--color-dark) !important;
	}
	a {
		border-bottom-width: 5px;
	}
	a:hover {
		border-bottom-color: var(--color-dark);
	}
}

.talktous_email_wrapper {
	p {
		transform: translateY(8px);
		@media (min-width: 1230px) {
			transform: translateY(15px);
		}
	}
}

.single-testimonial-in-slider,
.block--testimonial {
	padding: var(--flow-space--quadruple) 0;
	background-color: var(--color-dark);

	svg {
		max-width: 60px;
		margin-bottom: var(--flow-space--double);
	}

	figcaption {
		margin-top: var(--flow-space--triple);
	}
}

.testimonial-background-image {
	opacity: 0.5;
}

.single-testimonial-in-slider {
	position: relative;
	height: auto;
}

.values-copy-grid {
	@media (min-width: 1230px) {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		> * {
			flex: 25% 0 0;
			margin: 0 4% var(--flow-space);
		}
	}	
}

.values-layout--image {
	
	@media (min-width: 760px) {
		.row {
			row-gap: 0;
		}
		.value-img-wrapper {
			position: relative;
			* {
				position: absolute;
				top: 0;
				right: 0;
				height: 100%;
				width: 40vw;
				max-width: 700px;
				object-fit: cover;
			}
		}
	}
}

.block--video iframe,
.block--video img {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}

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

/* blockquote {
	padding-left: var(--flow-space);
	border-left: 5px;
} */

.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-family: var(--font-bold);
    gap: 0 var(--space-2xs);
    justify-content: center;
    line-height: 1;
    padding: .4em 2em;
    text-align: center;
    text-decoration: none;
    border-radius: 5rem;
    text-transform: uppercase;
    transition: all 0.2s;
}

.button.button--small {
    font-size: var(--size-step-00);
}

.button svg {
    height: auto;
    transform: rotate(0deg);
    width: 1.85ex
}

.button span+svg {
    width: 1.5ex
}

.button:not([data-type=naked]):hover,.button[data-type=secondary] {
    background: var(--color-dark);
    /* color: var(--color-orangeburnt); */
}

.button[data-type=secondary] {
    border: 1px solid var(--color-dark)
}

.button[data-type=naked] {
    background: transparent;
    border: none;
    color: var(--color-dark);
    padding: 0
}

.button[data-type=badge] {
    border-radius: 2em;
    padding: var(--space-2xs) var(--space-s)
}

.button[data-type=naked]:hover svg {
    transform: rotate(-45deg);
    transition: transform var(--transition-base)
}

.button[data-theme=dark] {
    background-color: var(--color-dark);
    color: var(--color-light)
}

.button[data-theme=dark]:hover,.button[data-type=secondary]:hover {
    background-color: var(--color-quaternary);
    color: var(--color-dark);
}

.button[data-theme=ghost] {
    background: var(--color-light);
    border: 1px solid var(--color-orange);
    color: var(--color-dark);
}

.button[data-theme=ghost].current,
.button[data-theme=ghost]:hover {
    background: var(--color-orange);
    border: 1px solid var(--color-orange);
    color: var(--color-light);
}

.button[data-theme=ghost] svg {
    color: var(--color-primary)
}

.button[data-theme=footer-cta] {
    background: transparent;
    border: 1px solid var(--color-light);
    color: var(--color-light);
    text-transform: none;
    font-size: var(--step-size-5);
    padding: var(--flow-space) var(--flow-space--double);
}

/* .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; */
    /* border-radius: var(----border-radius); */
    width: 100%;
}

.card-work_cpt {
    overflow: hidden;
    picture {
        overflow: hidden;
        border-radius: var(--border-radius);
    }  
    p {
        width: 30ch;
    }
    /* outline: 1px solid teal; */
    margin-bottom: var(--flow-space--double);
}

.card-work_cpt img {
    aspect-ratio: 11/9;
    width: 100%;
    transition: 0.2s all;
}

/* diff aspect ratio on featured work block */

.block--featured-work .card-work_cpt img {
    aspect-ratio: 10/11;
    p { width: 20ch; }
}

.card-work_cpt:hover {
     img {
        transform: scale(1.02);
     } 
}

.card-team_cpt,
.card-post {
    border-radius: var(--border-radius);
    overflow: hidden;
    aspect-ratio: unset;
    padding-top: var(--flow-space--double);

    height: 100%;
    margin-bottom: var(--flow-space);
    /* position: relative; */

    @media (min-width: 760px) {
        padding-top: unset;
        aspect-ratio: 2 / 3;
    }
    @media (min-width: 1230px) {
        aspect-ratio: 9 / 14;
    }
    position: relative;
    .card--media {
        picture,
        img {
            height: 100%;
            width: 100%;
            object-fit: cover;
        }
    }
    .card--content {
        height: 100%;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        position: relative;
        transition: all 0.2s;
        &:after {
            position: absolute;
            content: "";
            height: 70%;
            width: 100%;
            left: 0;
            bottom: 0;
            z-index: -1;
            --grad1: rgba(0,0,0,0.6) 0%;
            --grad2: rgba(0,0,0,0.2) 43%;
            --grad3: rgba(0,0,0,0) 64%;
            --grad4: rgba(0,0,0,0) 100%;
            background: rgb(0,0,0);
            background: linear-gradient(0deg, var(--grad1), var(--grad2), var(--grad3), var(--grad4));
            transition: all 0.2s;
        }
    }
    &:hover {
        .card--content:after {
            height: 100%;
        }
        .card--content {
            padding-bottom: 3rem;
        }
    }
}

.ginlined-content.team-member-content {

    /* display: flex !important; */
    /* align-items: center; */
    /* justify-content: center; */
    margin-top: var(--flow-space--double);
    margin-bottom: var(--flow-space--double);
    max-width: unset !important;

    blockquote {
        /* background-color: teal; */
        padding-left: var(--flow-space);
        border-left: 5px solid #d8d8d8;
    }

    picture,
    img {
        /* aspect-ratio: 1/1; */
        /* object-fit: cover; */
        width: 100%;
    }

}

body.archive,
body.blog {
    .card-post {
        aspect-ratio: 1 / 1; 
    }
}

/* .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: 16/9;
    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:not(:hover) img {
    filter: grayscale(1);
}

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

.footer-logo {
  width: 10rem;
}

.site-footer {
  position: relative;
  background-color: var(--color-dark);
  padding: calc(var(--flow-space) + 8px ) 0 var(--flow-space);
}

.site-footer:before {
  content: "";
  width: 100%;
  height: 8px;
  display: inline-block;
  position: absolute;
  top: -8px;
  background: linear-gradient(270deg, #FF482C 0%, #FF752A 100%);
  /* margin-top: var(--flow-space--double); */
}

.footer-background-image {
  opacity: 0.2;
}

.footer-nav.footer-nav--primary {
    display: flex;
    flex-wrap: wrap;
    > * { flex: 50% 0 0; }
    padding-bottom: var(--flow-space);
}

.footer_company_statement {
  margin-bottom: var(--flow-space--quadruple);
  @media (min-width: 50em) {
    margin-bottom: var(--flow-space--double);
  }
}

.footer_newsletter_copy {
  span {
    color: var(--color-orange);
  }
}

: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: #888888;
    --color-fui-gray-lighter: #777777;
    --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: #000;
}

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

.image_logo_overlay {
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	svg {
		/* width: 200px; */
		/* height: 200px; */
		width: 22vw;
		height: 22vw;
		max-width: 400px;
		max-height: 400px;
	}
}

.image_logo_overlay.icon--logo,
.image_logo_overlay.icon--logo_white {
	svg {
		width: 50vw;
		height: 50vw;
		max-width: 600px;
		max-height: 600px;
	}
}

.nav-logo {
  a { display: flex; }
  svg { width: 7rem; }
  @media (min-width: 30em) {
    svg { width: 12rem; }
  }
}

.menu a {
    /* color: var(--color-light); */
    /* font-size: var(--size-step-00); */
    /* font-weight: 500; */
    letter-spacing: .04ch;
    text-decoration: none;
    /* text-transform: uppercase; */
}

body:not(.first-block-is-homehero):not(.first-block-is-hero_gradient):not(.single-service_cpt) {
  /* added to offset nav height */
  margin-top: var(--nav-height, 100px);
  /* margin-top: var(--double-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);
}

/* if first block is hero, add space to top of block to allow for nav overlay */

body.single-service_cpt .site-header,
body.first-block-is-hero_gradient .site-header,
body.first-block-is-homehero .site-header {
  position: absolute;
}

body.single-service_cpt .service-single-hero,
body.first-block-is-hero_gradient .hero-type--gradient .hero-content,
body.first-block-is-homehero .block--homepage-hero .homehero-content {
  &:before {
    content: "";
    display: block;
    height: var(--nav-height, 100px); /* added to offset nav height */
  }
}

.site-header .nav-button-wrapper {
  .button {
    @media (max-width: 31em) {
      padding: 0.2rem;
    }
  }
  span {
    display: none;
    @media (min-width: 31em) {
      display: block;
    }
  }
  svg {
    @media (max-width: 31em) {
      width: 1.6rem;
    }
    /* display: block; */
    @media (min-width: 31em) {
      display: none;
    }
  }
}

.hamburger {
  display: flex;
  align-items: center;
  .hamburger--label { margin-right: var(--flow-space--half); }
  .hamburger--label__open { display: none; }
  .hamburger--label__closed { display: inline-block; }
}

.hamburger.is-active {
  .hamburger--label__open { display: inline-block; }
  .hamburger--label__closed { display: none; }
}

.hamburger--label__open {
  color: var(--color-dark);
}

.nav-menu-area {
  padding-top: 6px;
}

.off-canvas-menu {
  display: flex;
  flex-wrap: wrap;
  > * {
    flex: 1 1 50%;
    margin-bottom: var(--flow-space--half);
  }
}

.off-canvas {

    /* background-color: var(--color-primary); */
    /* color: var(--color-light); */
    /* padding: var(--flow-space, 3rem); */

    /* padding-top: var(--nav-height, 100px); */
    padding-top: calc(var(--nav-height, 100px) + var(--flow-space--triple));
    > * {
        /* padding-top: var(--flow-space--double); */
    }
    
    /* background-color: black !important; */
    
    /* hacky - font different size on mobile / tablet */
    /* .off-canvas-menu-wrapper { font-size: var(--size-step-2); }
    @media screen(lg) {
        .size-step-3 { font-size: var(--size-step-3); }
    } */

    .social-links {
        padding-top: 0;
        @media (min-width: 760px) {
            padding-top: var(--flow-space--triple);
        }
    }

    .social-links a {
        text-decoration: none;
    }

    .social-links svg {
      width: 0.7em;
      height: 0.7em;
      margin-left: 0.3em;
      path {
        fill: var(--color-dark);
      }
    }

}

.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: .1;
    -webkit-transition-delay: delay 0s;
    -o-transition-delay: delay 0s;
    transition-delay: delay 0s;
}

.offside-js--is-open .nav-priority-links {
    display: none;
}

/* need to hide off-canvas on load */

/* set this inline? */

/* .off-canvas { opacity: 0; } */

body.js--nav-height-set {
    .off-canvas {
        opacity: 1 !important;
    }
}

.pill {
    background-color: var(--color-dark);
    color: var(--color-light);
    display: inline-block;
    font-size: var(--size-step-00);
    padding: var(--space-3xs) var(--space-2xs);
    text-decoration: none;
}

.prose {
  --flow-space: var(--space-m);
  /* font-size: var(--size-step-3); */
}

.single-post-content {
	.wrapper {
		padding: 0;
	}
	.wp-block-heading {
		padding-top: var(--flow-space);
	}
}

.core_wrapper {
	margin: var(--flow-space) 0;
}

.wp-block-heading {
	padding-top: var(--flow-space--double);
}

.social-links svg {
  width: 0.7em;
  height: 0.7em;
  margin-left: 0.3em;
}

/* .social-links svg rect,
.social-links svg path {
  fill: var(--color-dark);
} */

/* .social-links {
  a {

  }
} */

:root {

  --swiper-theme-color: var(--color-orange);

  --swiper-preloader-color: var(--swiper-theme-color);
  --swiper-wrapper-transition-timing-function: initial;
  --swiper-centered-offset-before: auto;
  --swiper-centered-offset-after: auto;
  --swiper-virtual-size: auto;
  --swiper-navigation-size: 44px;
  --swiper-navigation-top-offset: 50%;
  --swiper-navigation-sides-offset: 10px;
  --swiper-navigation-color: var(--swiper-theme-color);
  --swiper-pagination-color: var(--swiper-theme-color);
  --swiper-pagination-left: auto;
  --swiper-pagination-right: 10px;
  --swiper-pagination-bottom: 10px;
  --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: 10px;
  --swiper-pagination-bullet-width: 10px;
  --swiper-pagination-bullet-height: 10px;
  --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-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;
}

.centered {
	display: flex;
	justify-content: center;
}

.centered-vertically {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/*
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);
}

.flow.flow-space--half > * + * {
  margin-top: var(--flow-space--half, 1em);
}

.flow.flow-space--third > * + * {
  margin-top: var(--flow-space--third, 1em);
}

.flow.flow-space--quarter > * + * {
  margin-top: var(--flow-space--quarter, 1em);
}

.flow.flow-space--double > * + * {
  margin-top: var(--flow-space--double, 1em);
}

.flow.flow-space--triple > * + * {
  margin-top: var(--flow-space--triple, 1em);
}

.flow.flow-space--quadruple > * + * {
  margin-top: var(--flow-space--quadruple, 1em);
}

.flow-mob-only > * + * {
  margin-top: var(--flow-space, 1em);
  @media (min-width: 760px) {
    margin-top: 0;
  }
}

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

/* Chris Fernandini - 12 / 16 col grid https://gomakethings.com/how-to-build-a-reusable-grid-system-with-css-grid/ */

.row {
    /* display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 1fr auto;
    row-gap: var(--flow-space--half);
    column-gap: var(--flow-space--half);
    width: 100%; */
    /* display: flex; */
    /* gap: 10%; */
    /* gap: 2.5%; */
    /* gap: var(--flow-space); */
    /* flex-direction: column; */
    /* flex-wrap: wrap; */

    > * {
      /* flex: 100% 0 0; */
    }

}

/* @media screen(sm) { */

/* .mob--col-fourth {
  flex-basis: 25%;
  margin-bottom: var(--flow-space);
}
.mob--col-half {
  flex-basis: 47%;
  margin-bottom: var(--flow-space);
  margin-right: 3%;
} */

/* } */

@media (min-width: 760px) {

  /* .mob--col-fourth,
  .mob--col-half {
    flex-basis: unset;
    margin-bottom: unset;
    margin-right: unset ;
  } */

/*   .row {
    display: grid;
    grid-template-columns: repeat(16, 1fr);
    grid-template-rows: 1fr auto;
    row-gap: var(--flow-space--half);
    column-gap: var(--flow-space--half);
    width: 100%;
  } */

  .row {
    display: grid;
    grid-template-columns: repeat(16, 1fr);
    grid-template-rows: 1fr auto;
    row-gap: var(--flow-space--half);
    column-gap: var(--flow-space--half);
    width: 100%;
  }

  .col-fourth {         grid-column: auto / span 4; }
  .col-half {           grid-column: auto / span 8; }

  /* .col-third {          grid-column: auto / span 4; } */
  /* .col-two-thirds {     grid-column: auto / span 8; } */
  /* .col-three-fourths {  grid-column: auto / span 9; } */

  .col-1 {    grid-column: auto / span 1; }
  .col-2 {    grid-column: auto / span 2; }
  .col-3 {    grid-column: auto / span 3; }
  .col-4 {    grid-column: auto / span 4; }
  .col-5 {    grid-column: auto / span 5; }
  .col-6 {    grid-column: auto / span 6; }
  .col-7 {    grid-column: auto / span 7; }
  .col-8 {    grid-column: auto / span 8; }
  .col-9 {    grid-column: auto / span 9; }
  .col-10 {   grid-column: auto / span 10; }
  .col-11 {   grid-column: auto / span 11; }
  .col-12 {   grid-column: auto / span 12; }
  .col-13 {   grid-column: auto / span 13; }
  .col-14 {   grid-column: auto / span 14; }
  .col-15 {   grid-column: auto / span 15; }

  [class*="col-start-"] {     grid-row-start: 1; }

  .col-start-1 {    grid-column-start: 1; }
  .col-start-2 {    grid-column-start: 2; }
  .col-start-3 {    grid-column-start: 3; }
  .col-start-4 {    grid-column-start: 4; }
  .col-start-5 {    grid-column-start: 5; }
  .col-start-6 {    grid-column-start: 6; }
  .col-start-7 {    grid-column-start: 7; }
  .col-start-8 {    grid-column-start: 8; }
  .col-start-9 {    grid-column-start: 9; }
  .col-start-half { grid-column-start: 9; }
  .col-start-10 {   grid-column-start: 10; }
  .col-start-11 {   grid-column-start: 11; }
  .col-start-12 {   grid-column-start: 12; }
  .col-start-13 {   grid-column-start: 13; }
  .col-start-14 {   grid-column-start: 14; }
  .col-start-15 {   grid-column-start: 15; }

  /* .col-start-fourth {         grid-column-start: 4; } */
  /* .col-start-third {          grid-column-start: 5; } */
  /* .col-start-two-thirds {     grid-column-start: 9; } */
  /* .col-start-three-fourths {  grid-column-start: 10; } */
}

/*
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), 90rem);  /* 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;
	picture, 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; }

.aspect-ratio--3-1 { aspect-ratio: 3 / 1; }

/* 
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 {
  /* z-index: -1; */
  position: absolute;
  width: 100%;
  background-color: var(--color-light);
  height: var(--nav-height, 100px);
}

html.page-is-at-top body.single-service_cpt,
html.page-is-at-top body.first-block-is-hero_gradient:not(.offside-js--is-open),
html.page-is-at-top body.first-block-is-homehero:not(.offside-js--is-open) {
  .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) !important;
  }

   .hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
      background-color: 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.page-is-at-top body.first-block-is-hero_gradient.offside-js--interact,
html.page-is-at-top body.first-block-is-homehero.offside-js--interact {
  .nav-logo svg path {
    fill: unset;
  }
} */

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

.border-radius {
	border-radius: var(--border-radius, 0.5rem);
	overflow: hidden;
}

.width--30ch { width: 30ch; }

.width--20ch { width: 20ch; }

/* 
CLUSTER UTILITY
*/

.cluster {
    display: flex;
    flex-wrap: wrap;
    align-items: var(--cluster-vertical-alignment, center);
    gap: var(--gutter,var(--space-s-m));
    justify-content: var(--cluster-horizontal-alignment, flex-start)
}

.gradient-bg {
	background-size: 100% 100%;
	background-position: 0px 0px,0px 0px,0px 0px,0px 0px,0px 0px;
	background-image: radial-gradient(49% 81% at 45% 47%, #FFE20345 0%, #073AFF00 100%),radial-gradient(113% 91% at 17% -2%, #FF5A00FF 1%, #FF000000 99%),radial-gradient(142% 91% at 83% 7%, #FFDB00FF 1%, #FF000000 99%),radial-gradient(142% 91% at -6% 74%, #FF0049FF 1%, #FF000000 99%),radial-gradient(142% 91% at 111% 84%, #FF7000FF 0%, #FF0000FF 100%);
}

/* 
GRID UTILITY
Consistent block padding for page sections
*/

/*
    UPDATE TO THIS?:
    add this in for grids: https://codepen.io/tommiehansen/pen/NWmNbyr
*/

.grid {
    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))
}

.grid[data-layout="50-50"] {
    --grid-placement: auto-fit;
    --grid-min-item-size: clamp(16rem,50vw,33rem)
}

.grid[data-layout=thirds] {
    --grid-placement: auto-fit;
    --grid-min-item-size: clamp(16rem,33%,20rem)
}

.grid[data-layout=thirds]:has(>:nth-child(2):last-child) {
    --grid-placement: auto-fill
}

.grid[data-layout=twelfths] {
    display: grid;
    grid-template-columns: repeat(12,1fr)
}

.grid[data-layout="lg:10/2"] {
    grid-template-columns: 100%
}

@media (min-width: 50em) {
    .grid[data-layout="lg:10/2"] {
        grid-template-columns:clamp(40rem,80vw,60rem)
    }
}

@media (min-width: 80em) {
    .grid[data-layout="lg:10/2"] {
        grid-template-columns:10fr 2fr
    }
}

.grid[data-state="reversed"] {
    direction: rtl;
}

.logo-gallery {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4%;
	justify-content: center;
	.logo-gallery--logo {
		/* flex: 20% 0 1; */
		display: flex;
		align-items: center;
		height: 70px;
		aspect-ratio: 16 / 9;
		position: relative;
		margin-bottom: var(--flow-space--double);
	}
	picture,
	img {
		object-fit: contain;
		/* aspect-ratio: 16 / 9; */
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		position: absolute;
		mix-blend-mode: multiply;
	}
}

.max-height-half-screen {
	max-height: 50vh;
}

/* 
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));
}

/* 
REPEL UTILITY
Push away from each other but wrap when not enough space (For Nav)
*/

.repel {
    align-items: var(--repel-vertical-alignment, center);
    display: flex;
    flex-wrap: wrap;
    gap: var(--gutter, var(--space-s-m));
    justify-content: space-between;
}

/* 
TINY IMAGE IN A CIRCLE - e.g. TESIMONIAL / AUTHOR IMAGE
*/

.tiny-circle-image {
    width: 5rem;
    height: 5rem;
    
}

.tiny-circle-image img,
.tiny-circle-image picture {
    object-fit: cover;
    height: 100%;
    width: 100%;
    border-radius: 50%;
}

/* 
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) {
    display: unset;
  }
}

.hide-on-desktop {
  @media (min-width: 760px) {
    display: none;
  }
}

.visible {
  visibility: visible;
}

.fixed {
  position: fixed;
}

.relative {
  position: relative;
}

.sticky {
  position: sticky;
}

.z-10 {
  z-index: 10;
}

.z-40 {
  z-index: 40;
}

.z-50 {
  z-index: 50;
}

.col-start-10 {
  grid-column-start: 10;
}

.col-start-11 {
  grid-column-start: 11;
}

.col-start-2 {
  grid-column-start: 2;
}

.col-start-3 {
  grid-column-start: 3;
}

.col-start-4 {
  grid-column-start: 4;
}

.col-start-5 {
  grid-column-start: 5;
}

.col-start-7 {
  grid-column-start: 7;
}

.col-start-8 {
  grid-column-start: 8;
}

.col-start-9 {
  grid-column-start: 9;
}

.my-m {
  margin-top: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
  margin-bottom: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
}

.my-xl {
  margin-top: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
  margin-bottom: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
}

.mb-2xl {
  margin-bottom: clamp(4.5rem, 3.95rem + 2.67vw, 6rem);
}

.mb-m {
  margin-bottom: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
}

.mb-xl {
  margin-bottom: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
}

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

.w-full {
  width: 100%;
}

.resize {
  resize: both;
}

.flex-col {
  flex-direction: column;
}

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

.gap-3xs {
  gap: clamp(0.3125rem, 0.29rem + 0.11vw, 0.375rem);
}

.gap-xs {
  gap: clamp(0.875rem, 0.78rem + 0.44vw, 1.125rem);
}

.rounded {
  border-radius: 0.25rem;
}

.bg-dark {
  background-color: #050505;
}

.bg-light {
  background-color: #f9f9f9;
}

.object-cover {
  object-fit: cover;
}

.p-m {
  padding: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
}

.py-3xl {
  padding-top: clamp(6.75rem, 5.92rem + 4.00vw, 9rem);
  padding-bottom: clamp(6.75rem, 5.92rem + 4.00vw, 9rem);
}

.py-m {
  padding-top: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
  padding-bottom: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
}

.py-xl {
  padding-top: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
  padding-bottom: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
}

.pb-2xl {
  padding-bottom: clamp(4.5rem, 3.95rem + 2.67vw, 6rem);
}

.pb-l {
  padding-bottom: clamp(2.25rem, 1.98rem + 1.33vw, 3rem);
}

.pb-m {
  padding-bottom: clamp(1.6875rem, 1.48rem + 1.00vw, 2.25rem);
}

.pb-xl {
  padding-bottom: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
}

.pt-xl {
  padding-top: clamp(3.375rem, 2.96rem + 2.00vw, 4.5rem);
}

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

.font-base {
  font-family: satoshi-regular, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
}

.font-bold {
  font-family: satoshi-bold, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
}

.uppercase {
  text-transform: uppercase;
}

.no-underline {
  text-decoration-line: none;
}

.opacity-50 {
  opacity: 0.5;
}

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

.bg-dark {
  background-color: #050505;
}

.bg-light {
  background-color: #f9f9f9;
}

.color-dark {
  color: #050505;
}

.color-light {
  color: #f9f9f9;
}

.color-orange {
  color: #f15924;
}

/* @import '../css-utils/debug.css'; */

/* @import '../css-utils/a11y-check.css'; */