@charset "UTF-8";
/******************************************************************

Stylesheet: Main Stylesheet

******************************************************************/
/* =============================================================================
  Helpers
========================================================================== */
/* =============================================================================
  Browser Resets - https://piccalil.li/blog/a-modern-css-reset/
========================================================================== */
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin and padding */
blockquote, body, dd, dl, dt, fieldset, figure, h1, h2, h3, h4, h5, h6, hr, html, iframe, legend, li, ol, p, pre, textarea, ul, form {
  margin: 0;
  padding: 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 root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
  text-decoration-skip-ink: auto;
}

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

/* List stuff */
ul, ol {
  list-style: none;
}

/* Table Stuff */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* Pre Stuff */
pre {
  white-space: pre-wrap;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/* =============================================================================
  Utils
========================================================================== */
/* =============================================================================
  Text
========================================================================== */
.text-center {
  text-align: center;
}

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

/* =============================================================================
  Colours
========================================================================== */
/* =============================================================================
  Colour
========================================================================== */
.primary {
  color: var(--color-primary) !important;
}

.secondary {
  color: var(--color-secondary) !important;
}

.accent {
  color: var(--color-accent) !important;
}

.seg {
  color: var(--color-seg) !important;
}

.black {
  color: var(--color-black) !important;
}

.dark {
  color: var(--color-dark) !important;
}

.medium {
  color: var(--color-medium) !important;
}

.light {
  color: var(--color-light) !important;
}

.white {
  color: var(--color-white) !important;
}

.success {
  color: var(--color-success) !important;
}

.alert {
  color: var(--color-alert) !important;
}

.error {
  color: var(--color-error) !important;
}

/* =============================================================================
  Background Colour
========================================================================== */
.bg-primary {
  background-color: var(--color-primary) !important;
}

.bg-secondary {
  background-color: var(--color-secondary) !important;
}

.bg-accent {
  background-color: var(--color-accent) !important;
}

.bg-seg {
  background-color: var(--color-seg) !important;
}

.bg-black {
  background-color: var(--color-black) !important;
}

.bg-dark {
  background-color: var(--color-dark) !important;
}

.bg-medium {
  background-color: var(--color-medium) !important;
}

.bg-light {
  background-color: var(--color-light) !important;
}

.bg-white {
  background-color: var(--color-white) !important;
}

.bg-success {
  background-color: var(--color-success) !important;
}

.bg-alert {
  background-color: var(--color-alert) !important;
}

.bg-danger, .bg-error {
  background-color: var(--color-error) !important;
}

/******************************************************************

Stylesheet: Mixins & Constants Stylesheet

This is where you can take advantage of Sass' great features:
Mixins & Constants.

******************************************************************/
/*********************
TOOLS
*********************/
.image-replacement {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}

/*********************
COLORS
*********************/
/* =============================================================================
	Forms
========================================================================== */
/* =============================================================================
Padding
========================================================================== */
/* =============================================================================
Aspect Ratio
========================================================================== */
/* =============================================================================
Clearfix
========================================================================== */
/* =============================================================================
Hover shadow
========================================================================== */
/* =============================================================================
Site Margins
========================================================================== */
/*********************
TYPOGRAPHY
*********************/
span.amp {
  font-family: Baskerville, "Goudy Old Style", Palatino, "Book Antiqua", serif !important;
  font-style: italic;
}

/* =============================================================================
	Fluid Type
========================================================================== */
/*
$min_width: map-get($breakpoints, medium)
$max_width: map-get($breakpoints, xxlarge)
$min_font: 16px;
$max_font: 24px;

.large-fluid {
  @include fluid-type($min_width, $max_width, $min_font, $max_font);
}
*/
/* =============================================================================
	Fluid Padding
========================================================================== */
/*
$direction: vertical,horizontal,both;
$min-vw: map-get($breakpoints, medium)
$max-vw: map-get($breakpoints, xxlarge);
$min-padding: 16px;
$max-padding: 38px;


*/
/* =============================================================================
	Fluid Attribute
========================================================================== */
/*
$attribute: margin-bottom;
$min-vw: map-get($breakpoints, medium);
$max-vw: map-get($breakpoints, xxlarge);
$min-value: 16px;
$max-value: 38px;


*/
/*********************
CSS3 GRADIENTS.
*********************/
/* @include css-gradient(#dfdfdf,#f8f8f8); */
/* =============================================================================
	Burgers
========================================================================== */
/* =============================================================================
  Spacing
========================================================================== */
.mt {
  margin-top: var(--layout-spacing);
}
.mt-sm {
  margin-top: calc(var(--layout-spacing) * 0.5);
}
.mt-lg {
  margin-top: calc(var(--layout-spacing) * 1.5);
}

.mb {
  margin-bottom: var(--layout-spacing);
}
.mb-sm {
  margin-bottom: calc(var(--layout-spacing) * 0.5);
}
.mb-lg {
  margin-bottom: calc(var(--layout-spacing) * 1.5);
}

.pt {
  padding-top: var(--layout-spacing);
}
.pt-sm {
  padding-top: calc(var(--layout-spacing) * 0.5);
}
.pt-lg {
  padding-top: calc(var(--layout-spacing) * 1.5);
}

.pb {
  padding-bottom: var(--layout-spacing);
}
.pb-sm {
  padding-bottom: calc(var(--layout-spacing) * 0.5);
}
.pb-lg {
  padding-bottom: calc(var(--layout-spacing) * 1.5);
}

.pad {
  padding: var(--layout-spacing);
}
.pad-sm {
  padding: calc(var(--layout-spacing) * 0.5);
}
.pad-lg {
  padding: calc(var(--layout-spacing) * 1.5);
}

.mt-05 {
  margin-top: 0.5rem;
}

.mt-1 {
  margin-top: 1rem;
}

.mb-1 {
  margin-bottom: 1rem;
}

.nmt {
  margin-top: 0 !important;
}

.nmb {
  margin-bottom: 0 !important;
}

.npb {
  padding-bottom: 0 !important;
}

/* =============================================================================
Animations
========================================================================== */
.animate-in {
  opacity: 0;
  transform: scale(0.9);
  transition: 0.5s ease-out transform, 0.5s ease-in opacity;
  transition-delay: var(--transition-delay, 0ms);
}
.animate-in.in-viewport {
  opacity: 1;
  transform: scale(1);
}

/* =============================================================================
  Settings
========================================================================== */
/* =============================================================================
  Breakpoints & Flexbox Grid (http://sassflexboxgrid.com/views/classes.html)
========================================================================== */
/* =============================================================================
    CSS Variables
  ========================================================================== */
:root {
  --breakpoint-smmax: 63.9375rem;
  --breakpoint-mdstart: 64rem;
  /* =============================================================================
    Colours
  ========================================================================== */
  --color-primary: #56C8E1;
  --color-secondary: #323D4F;
  --color-accent: #7E92B2;
  --color-seg: #F08139;
  --color-white: #ffffff;
  --color-black: #000000;
  --color-light: #EFF0F1;
  --color-medium: #B4B9BC;
  --color-dark: #353A3D;
  --color-pony-club: #202c4e;
  --color-info: #e86b03;
  --color-success: #77D289;
  --color-alert: #F3A540;
  --color-error: #E46161;
  accent-color: var(--color-primary);
  /* =============================================================================
  Spacing
  ========================================================================== */
  --layout-spacing: 2rem;
  /* =============================================================================
    Layout
  ========================================================================== */
  --layout-container-padding: 2rem;
  --layout-container-margin: auto;
  --layout-container-max-width: 102.5rem;
  --layout-header-height: 3.75rem;
  --layout-header-logo-height: 25px;
  --layout-anchor-offset: 5rem;
  --layout-border-radius: 6px;
  --header-bg-color: var(--color-white);
  --header-border-color: transparent;
  --header-burger-height: 25px;
  --header-burger-color: var(--color-dark);
  --hero-bg-color: var(--color-secondary);
  --hero-padding: calc(var(--layout-spacing) * 1.5);
  --hero-overline-color: var(--color-accent);
  /* =============================================================================
    Components
  ========================================================================== */
  --layout-grid-gap: 1.25rem;
  --layout-border-radius: 6px;
  --element-block-spacing: 2rem;
  --element-box-padding: 1rem;
  --accordion-summary-pad: 1rem;
  --element-card-background: var(--color-light);
  --panel-title-color: var(--color-dark);
  --panel-title-em-color: var(--color-primary);
  --panel-subtitle-color: var(--color-accent);
  --panel-text-color: var(--color-dark);
  --navbar-link-color: var(--color-black);
  --navbar-link-current-color: var(--color-primary);
  --mega-menu-padding: 2rem;
  --horsebox-padding: 2rem;
  --horsebox-head-size: 100%;
  --horsebox-head-maxwidth: 9.375rem;
  --table-striped-bg-color: var(--color-light);
  --table-padding: 1rem;
  --table-padding-compact: 0.5rem;
  /* =============================================================================
  Typography
  ========================================================================== */
  --typography-header-font: "Mulish",sans-serif;
  --typography-header-weight: 600;
  --typography-header-line-height: 1.2;
  --typography-header-margin-bottom: clamp(1rem,0.5em,1.875rem);
  --typography-h1-size: 2rem;
  --typography-h2-size: 1.875rem;
  --typography-h3-size: 1.75rem;
  --typography-h4-size: 1.625rem;
  --typography-h5-size: 1.5rem;
  --typography-h6-size: 1.375rem;
  --typography-body-font: "Mulish",sans-serif;
  --typography-body-colour: var(--color-dark);
  --typography-body-weight: normal;
  --typography-body-size: 100%;
  --typography-body-line-height: 1.2;
  --typography-bold-weight: 600;
  --typography-paragraph-margin: 1em;
  --typography-lead-size: 1.125rem;
  /* =============================================================================
    Forms
  ========================================================================== */
  --form-input-radius: 6px;
  --form-input-border-color: var(--color-dark);
  --form-box-shadow: 0 2px 2px -2px rgba(34, 47, 62, 0.1), 0 8px 8px -4px rgba(34, 47, 62,0.07);
  --form-focus-box-shadow: 0 0 0 4px var(--color-accent);
  --form-disabled-bg-color: #DEDEDE;
  --form-switch-height: 30px;
  --form-switch-bg-color: var(--color-medium);
  --form-switch-active-bg-color: var(--color-primary);
  /* =============================================================================
    Custom
  ========================================================================== */
  --focus-drop-shadow: 6px 6px 6px -2px rgba(143, 143, 143,0.6);
}

/* =============================================================================
  Responsive Vars
========================================================================== */
@media (min-width: 73.75rem) {
  :root {
    --layout-header-logo-height: 33px;
    --layout-anchor-offset: 10rem;
  }
}
@media (min-width: 75.625rem) {
  :root {
    --layout-spacing: 3rem;
    --layout-grid-gap: 1.875rem;
    --layout-header-height: auto;
    --typography-h1-size: 2.5rem;
    --typography-h2-size: 2rem;
    --typography-h3-size: 1.75rem;
    --typography-h4-size: 1.625rem;
    --typography-h5-size: 1.5rem;
    --typography-h6-size: 1.375rem;
    --element-box-padding: 1.5rem;
    --typography-lead-size: 1.25rem;
  }
}
@media (min-width: 106.3125rem) {
  :root {
    --horsebox-head-size: 6rem;
    --typography-lead-size: 1.375rem;
  }
}
/* =============================================================================
  Helpers
========================================================================== */
/* =============================================================================
  Grid
========================================================================== */
.grid {
  display: grid;
}
.grid:not(.no-gap):not(.gap-h) {
  gap: var(--layout-grid-gap);
}
.grid.gap-h {
  grid-column-gap: var(--layout-grid-gap);
}
.grid:not([class*=" grid-col-"]) {
  grid-template-columns: repeat(12, 1fr);
}
.grid:not([class*=" grid-col-"]) > :not([class*=" col-"]):not([class*=col-]) {
  grid-column-end: span 12;
}
.grid.grid-col-2 {
  grid-template-columns: 1fr 1fr;
}
.grid.grid-col-3 {
  grid-template-columns: 1fr 1fr 1fr;
}
.grid.grid-col-1-4 {
  grid-template-columns: 1fr;
}

.col-xs-1 {
  grid-column-end: span 1;
}

.col-xs-offset-1 {
  grid-column-start: 1;
}

.col-xs-2 {
  grid-column-end: span 2;
}

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

.col-xs-3 {
  grid-column-end: span 3;
}

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

.col-xs-4 {
  grid-column-end: span 4;
}

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

.col-xs-5 {
  grid-column-end: span 5;
}

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

.col-xs-6 {
  grid-column-end: span 6;
}

.col-xs-offset-6 {
  grid-column-start: 6;
}

.col-xs-7 {
  grid-column-end: span 7;
}

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

.col-xs-8 {
  grid-column-end: span 8;
}

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

.col-xs-9 {
  grid-column-end: span 9;
}

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

.col-xs-10 {
  grid-column-end: span 10;
}

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

.col-xs-11 {
  grid-column-end: span 11;
}

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

.col-xs-12 {
  grid-column-end: span 12;
}

.col-xs-offset-12 {
  grid-column-start: 12;
}

@media (min-width: 41.75rem) {
  .grid.grid-col-1-4 {
    grid-template-columns: 1fr 1fr;
  }
  .col-sm-1 {
    grid-column-end: span 1;
  }
  .col-sm-offset-1 {
    grid-column-start: 1;
  }
  .col-sm-2 {
    grid-column-end: span 2;
  }
  .col-sm-offset-2 {
    grid-column-start: 2;
  }
  .col-sm-3 {
    grid-column-end: span 3;
  }
  .col-sm-offset-3 {
    grid-column-start: 3;
  }
  .col-sm-4 {
    grid-column-end: span 4;
  }
  .col-sm-offset-4 {
    grid-column-start: 4;
  }
  .col-sm-5 {
    grid-column-end: span 5;
  }
  .col-sm-offset-5 {
    grid-column-start: 5;
  }
  .col-sm-6 {
    grid-column-end: span 6;
  }
  .col-sm-offset-6 {
    grid-column-start: 6;
  }
  .col-sm-7 {
    grid-column-end: span 7;
  }
  .col-sm-offset-7 {
    grid-column-start: 7;
  }
  .col-sm-8 {
    grid-column-end: span 8;
  }
  .col-sm-offset-8 {
    grid-column-start: 8;
  }
  .col-sm-9 {
    grid-column-end: span 9;
  }
  .col-sm-offset-9 {
    grid-column-start: 9;
  }
  .col-sm-10 {
    grid-column-end: span 10;
  }
  .col-sm-offset-10 {
    grid-column-start: 10;
  }
  .col-sm-11 {
    grid-column-end: span 11;
  }
  .col-sm-offset-11 {
    grid-column-start: 11;
  }
  .col-sm-12 {
    grid-column-end: span 12;
  }
  .col-sm-offset-12 {
    grid-column-start: 12;
  }
}
@media (min-width: 64rem) {
  .grid.grid-col-1-4 {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .col-md-1 {
    grid-column-end: span 1;
  }
  .col-md-offset-1 {
    grid-column-start: 1;
  }
  .col-md-2 {
    grid-column-end: span 2;
  }
  .col-md-offset-2 {
    grid-column-start: 2;
  }
  .col-md-3 {
    grid-column-end: span 3;
  }
  .col-md-offset-3 {
    grid-column-start: 3;
  }
  .col-md-4 {
    grid-column-end: span 4;
  }
  .col-md-offset-4 {
    grid-column-start: 4;
  }
  .col-md-5 {
    grid-column-end: span 5;
  }
  .col-md-offset-5 {
    grid-column-start: 5;
  }
  .col-md-6 {
    grid-column-end: span 6;
  }
  .col-md-offset-6 {
    grid-column-start: 6;
  }
  .col-md-7 {
    grid-column-end: span 7;
  }
  .col-md-offset-7 {
    grid-column-start: 7;
  }
  .col-md-8 {
    grid-column-end: span 8;
  }
  .col-md-offset-8 {
    grid-column-start: 8;
  }
  .col-md-9 {
    grid-column-end: span 9;
  }
  .col-md-offset-9 {
    grid-column-start: 9;
  }
  .col-md-10 {
    grid-column-end: span 10;
  }
  .col-md-offset-10 {
    grid-column-start: 10;
  }
  .col-md-11 {
    grid-column-end: span 11;
  }
  .col-md-offset-11 {
    grid-column-start: 11;
  }
  .col-md-12 {
    grid-column-end: span 12;
  }
  .col-md-offset-12 {
    grid-column-start: 12;
  }
}
@media (min-width: 75.625rem) {
  .grid.grid-col-1-4 {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .col-lg-1 {
    grid-column-end: span 1;
  }
  .col-lg-offset-1 {
    grid-column-start: 1;
  }
  .col-lg-2 {
    grid-column-end: span 2;
  }
  .col-lg-offset-2 {
    grid-column-start: 2;
  }
  .col-lg-3 {
    grid-column-end: span 3;
  }
  .col-lg-offset-3 {
    grid-column-start: 3;
  }
  .col-lg-4 {
    grid-column-end: span 4;
  }
  .col-lg-offset-4 {
    grid-column-start: 4;
  }
  .col-lg-5 {
    grid-column-end: span 5;
  }
  .col-lg-offset-5 {
    grid-column-start: 5;
  }
  .col-lg-6 {
    grid-column-end: span 6;
  }
  .col-lg-offset-6 {
    grid-column-start: 6;
  }
  .col-lg-7 {
    grid-column-end: span 7;
  }
  .col-lg-offset-7 {
    grid-column-start: 7;
  }
  .col-lg-8 {
    grid-column-end: span 8;
  }
  .col-lg-offset-8 {
    grid-column-start: 8;
  }
  .col-lg-9 {
    grid-column-end: span 9;
  }
  .col-lg-offset-9 {
    grid-column-start: 9;
  }
  .col-lg-10 {
    grid-column-end: span 10;
  }
  .col-lg-offset-10 {
    grid-column-start: 10;
  }
  .col-lg-11 {
    grid-column-end: span 11;
  }
  .col-lg-offset-11 {
    grid-column-start: 11;
  }
  .col-lg-12 {
    grid-column-end: span 12;
  }
  .col-lg-offset-12 {
    grid-column-start: 12;
  }
}
@media (min-width: 106.3125rem) {
  .col-xl-1 {
    grid-column-end: span 1;
  }
  .col-xl-offset-1 {
    grid-column-start: 1;
  }
  .col-xl-2 {
    grid-column-end: span 2;
  }
  .col-xl-offset-2 {
    grid-column-start: 2;
  }
  .col-xl-3 {
    grid-column-end: span 3;
  }
  .col-xl-offset-3 {
    grid-column-start: 3;
  }
  .col-xl-4 {
    grid-column-end: span 4;
  }
  .col-xl-offset-4 {
    grid-column-start: 4;
  }
  .col-xl-5 {
    grid-column-end: span 5;
  }
  .col-xl-offset-5 {
    grid-column-start: 5;
  }
  .col-xl-6 {
    grid-column-end: span 6;
  }
  .col-xl-offset-6 {
    grid-column-start: 6;
  }
  .col-xl-7 {
    grid-column-end: span 7;
  }
  .col-xl-offset-7 {
    grid-column-start: 7;
  }
  .col-xl-8 {
    grid-column-end: span 8;
  }
  .col-xl-offset-8 {
    grid-column-start: 8;
  }
  .col-xl-9 {
    grid-column-end: span 9;
  }
  .col-xl-offset-9 {
    grid-column-start: 9;
  }
  .col-xl-10 {
    grid-column-end: span 10;
  }
  .col-xl-offset-10 {
    grid-column-start: 10;
  }
  .col-xl-11 {
    grid-column-end: span 11;
  }
  .col-xl-offset-11 {
    grid-column-start: 11;
  }
  .col-xl-12 {
    grid-column-end: span 12;
  }
  .col-xl-offset-12 {
    grid-column-start: 12;
  }
}
/* =============================================================================
  Align
========================================================================== */
.col-justify-center {
  justify-items: center;
}

/* =============================================================================
  Remove gaps on cells
========================================================================== */
.no-gap-t {
  margin-top: calc(var(--layout-grid-gap) * -1);
}

.no-gap-b {
  margin-bottom: calc(var(--layout-grid-gap) * -1);
}

.no-gap-l {
  margin-left: calc(var(--layout-grid-gap) * -1);
}

.no-gap-r {
  margin-right: calc(var(--layout-grid-gap) * -1);
}

/* =============================================================================
  Flexbox related
========================================================================== */
.is-flex {
  display: flex !important;
}

.flex-grid {
  display: flex !important;
  flex-flow: row wrap;
}
.flex-grid.margin-x {
  margin-left: calc(var(--layout-grid-gap) * -1);
  width: calc(100% + var(--layout-grid-gap));
}
.flex-grid.margin-x > * {
  padding-left: var(--layout-grid-gap);
}
.flex-grid.gap {
  display: inline-flex !important;
  flex-wrap: wrap;
  gap: var(--layout-grid-gap);
}

.cell {
  flex: 1 1 100%;
  min-height: 0;
  min-width: 0;
}

.xs-1 {
  flex: 0 0 8.3333333333%;
  max-width: 8.3333333333%;
}

.xs-2 {
  flex: 0 0 16.6666666667%;
  max-width: 16.6666666667%;
}

.xs-3 {
  flex: 0 0 25%;
  max-width: 25%;
}

.xs-4 {
  flex: 0 0 33.3333333333%;
  max-width: 33.3333333333%;
}

.xs-5 {
  flex: 0 0 41.6666666667%;
  max-width: 41.6666666667%;
}

.xs-6 {
  flex: 0 0 50%;
  max-width: 50%;
}

.xs-7 {
  flex: 0 0 58.3333333333%;
  max-width: 58.3333333333%;
}

.xs-8 {
  flex: 0 0 66.6666666667%;
  max-width: 66.6666666667%;
}

.xs-9 {
  flex: 0 0 75%;
  max-width: 75%;
}

.xs-10 {
  flex: 0 0 83.3333333333%;
  max-width: 83.3333333333%;
}

.xs-11 {
  flex: 0 0 91.6666666667%;
  max-width: 91.6666666667%;
}

.xs-12 {
  flex: 0 0 100%;
  max-width: 100%;
}

.shrink, .xs-shrink {
  flex: 0 0 auto;
  width: auto;
}

.auto, .xs-auto {
  flex: 1 1 0;
  width: auto;
}

@media (min-width: 41.75rem) {
  .sm-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .sm-order-1 {
    order: 1;
  }
  .sm-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .sm-order-2 {
    order: 2;
  }
  .sm-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .sm-order-3 {
    order: 3;
  }
  .sm-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .sm-order-4 {
    order: 4;
  }
  .sm-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .sm-order-5 {
    order: 5;
  }
  .sm-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .sm-order-6 {
    order: 6;
  }
  .sm-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .sm-order-7 {
    order: 7;
  }
  .sm-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .sm-order-8 {
    order: 8;
  }
  .sm-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .sm-order-9 {
    order: 9;
  }
  .sm-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .sm-order-10 {
    order: 10;
  }
  .sm-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .sm-order-11 {
    order: 11;
  }
  .sm-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .sm-order-12 {
    order: 12;
  }
  .sm-shrink {
    flex: 0 0 auto;
    width: auto;
  }
  .sm-auto {
    flex: 1 1 0;
    width: auto;
  }
}
@media (min-width: 64rem) {
  .md-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .md-order-1 {
    order: 1;
  }
  .md-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .md-order-2 {
    order: 2;
  }
  .md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .md-order-3 {
    order: 3;
  }
  .md-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .md-order-4 {
    order: 4;
  }
  .md-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .md-order-5 {
    order: 5;
  }
  .md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .md-order-6 {
    order: 6;
  }
  .md-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .md-order-7 {
    order: 7;
  }
  .md-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .md-order-8 {
    order: 8;
  }
  .md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .md-order-9 {
    order: 9;
  }
  .md-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .md-order-10 {
    order: 10;
  }
  .md-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .md-order-11 {
    order: 11;
  }
  .md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .md-order-12 {
    order: 12;
  }
  .md-shrink {
    flex: 0 0 auto;
    width: auto;
  }
  .md-auto {
    flex: 1 1 0;
    width: auto;
  }
}
@media (min-width: 75.625rem) {
  .lg-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .lg-order-1 {
    order: 1;
  }
  .lg-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .lg-order-2 {
    order: 2;
  }
  .lg-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .lg-order-3 {
    order: 3;
  }
  .lg-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .lg-order-4 {
    order: 4;
  }
  .lg-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .lg-order-5 {
    order: 5;
  }
  .lg-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .lg-order-6 {
    order: 6;
  }
  .lg-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .lg-order-7 {
    order: 7;
  }
  .lg-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .lg-order-8 {
    order: 8;
  }
  .lg-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .lg-order-9 {
    order: 9;
  }
  .lg-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .lg-order-10 {
    order: 10;
  }
  .lg-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .lg-order-11 {
    order: 11;
  }
  .lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .lg-order-12 {
    order: 12;
  }
  .lg-shrink {
    flex: 0 0 auto;
    width: auto;
  }
  .lg-auto {
    flex: 1 1 0;
    width: auto;
  }
}
@media (min-width: 106.3125rem) {
  .xl-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .xl-order-1 {
    order: 1;
  }
  .xl-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .xl-order-2 {
    order: 2;
  }
  .xl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .xl-order-3 {
    order: 3;
  }
  .xl-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .xl-order-4 {
    order: 4;
  }
  .xl-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .xl-order-5 {
    order: 5;
  }
  .xl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .xl-order-6 {
    order: 6;
  }
  .xl-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .xl-order-7 {
    order: 7;
  }
  .xl-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .xl-order-8 {
    order: 8;
  }
  .xl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .xl-order-9 {
    order: 9;
  }
  .xl-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .xl-order-10 {
    order: 10;
  }
  .xl-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .xl-order-11 {
    order: 11;
  }
  .xl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .xl-order-12 {
    order: 12;
  }
  .xl-shrink {
    flex: 0 0 auto;
    width: auto;
  }
  .xl-auto {
    flex: 1 1 0;
    width: auto;
  }
}
/* =============================================================================
  Full width
========================================================================== */
.has-fullwidth {
  display: flex;
  flex-direction: column;
}

/* =============================================================================
  Align
========================================================================== */
.align-bottom {
  align-items: flex-end;
}

.align-top {
  align-items: flex-start;
}

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

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

.align-left {
  justify-content: flex-start;
}

.align-right {
  justify-content: flex-end;
}

.align-self-bottom {
  align-self: flex-end;
}

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

.push {
  margin-left: auto;
}

/* =============================================================================
  Generica Elements
========================================================================== */
/* =============================================================================
  Close
========================================================================== */
.close {
  display: block;
  font-size: 2rem;
  height: 2rem;
  width: 2rem;
  color: var(--color-white);
  background-color: transparent;
  position: relative;
  cursor: pointer;
}
.close:after {
  font-family: "he-icons";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  content: "\e801";
}

/* =============================================================================
  Block
========================================================================== */
.block:not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}

/* =============================================================================
  Box
========================================================================== */
.box {
  padding: 0;
}
.box-header {
  background-color: var(--color-secondary);
  color: var(--color-white);
  margin-bottom: var(--element-box-padding);
  padding: var(--element-box-padding);
  font-size: 1.125rem;
}
.box.has-bg {
  padding: var(--element-box-padding);
  background-color: var(--color-light);
}
.box.has-bg .box-header {
  background-color: var(--color-accent);
  margin: calc(var(--element-box-padding) * -1);
  margin-bottom: var(--element-box-padding);
}
.box.has-bg .box-footer {
  margin: calc(var(--element-box-padding) * -1);
  margin-top: var(--element-box-padding);
}
.box.has-bg table.cover {
  margin: calc(var(--element-box-padding) * -1);
  width: calc(100% + var(--element-box-padding) * 2);
}
.box.has-bg.is-danger .box-header {
  background-color: var(--color-error);
}

.box-header {
  display: flex;
}

/* =============================================================================
  // Filter bar
========================================================================== */
.filter-bar {
  background-color: var(--color-light);
  padding: 1rem;
  margin-bottom: 1rem;
  border-radius: var(--layout-border-radius);
}

/* =============================================================================
  Widescreen Videos
========================================================================== */
iframe[src*="youtube.com"], iframe[src*="youtu.be"], iframe[src*="vimeo.com"] {
  width: 100%;
  height: 100%;
  aspect-ratio: 16/9;
}

@media (min-width: 75.625rem) {
  .box-header {
    font-size: 1.375rem;
  }
}
.button {
  -webkit-user-select: none;
  user-select: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  align-items: center;
  border: 2px solid transparent;
  border-radius: var(--layout-border-radius);
  box-shadow: none;
  display: inline-flex;
  font-size: 1rem;
  min-height: 2.5em;
  cursor: pointer;
  justify-content: center;
  padding-bottom: calc(0.5em - 1px);
  padding-left: 1em;
  padding-right: 1em;
  padding-top: calc(0.5em - 1px);
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  border-color: transparent;
  color: var(--color-primary);
  background-color: currentColor;
  outline: none !important;
}
.button span {
  color: var(--color-white);
}
.button:hover {
  opacity: 0.8;
}
.button:focus {
  border-color: var(--color-dark);
}
.button:active {
  opacity: 1;
  transform: translate(1px, 1px);
}
.button.is-small {
  font-size: 0.875rem;
}
.button.is-vsmall {
  font-size: 0.75rem;
}
.button.is-large {
  font-size: 1.5rem;
}
.button.is-form {
  line-height: 1;
  font-size: 1.125rem;
  padding-top: var(--form-input-padding, 1rem);
  padding-bottom: var(--form-input-padding, 1rem);
  height: auto;
}
.button.is-fullwidth {
  display: flex;
}
.button.is-secondary {
  color: var(--color-secondary);
}
.button.is-secondary:focus {
  border-color: var(--color-primary);
}
.button.is-secondary [class^=icon-], .button.is-secondary [class*=icon-] {
  color: var(--color-primary);
}
.button.is-accent {
  color: var(--color-accent);
}
.button.is-accent:focus {
  border-color: var(--color-secondary);
}
.button.is-accent [class^=icon-], .button.is-accent [class*=icon-] {
  color: var(--color-black);
}
.button.is-light {
  color: var(--color-light);
}
.button.is-light span {
  color: var(--color-secondary);
}
.button.is-light [class^=icon-], .button.is-light [class*=icon-] {
  color: var(--color-black);
}
.button.is-white {
  color: var(--color-white);
}
.button.is-white span {
  color: var(--color-dark);
}
.button.is-white [class^=icon-], .button.is-white [class*=icon-] {
  color: var(--color-dark);
}
.button.is-dark {
  color: var(--color-dark);
}
.button.is-dark span {
  color: var(--color-white);
}
.button.is-dark [class^=icon-], .button.is-dark [class*=icon-] {
  color: var(--color-primary);
}
.button.is-medium {
  color: var(--color-medium);
}
.button.is-medium span {
  color: var(--color-dark);
}
.button.is-medium [class^=icon-], .button.is-medium [class*=icon-] {
  color: var(--color-white);
}
.button.is-danger {
  color: var(--color-error);
}
.button.is-danger span {
  color: var(--color-white);
}
.button.is-danger [class^=icon-], .button.is-danger [class*=icon-] {
  color: var(--color-white);
}
.button.is-success {
  color: var(--color-success);
}
.button.is-success span {
  color: var(--color-white);
}
.button.is-success [class^=icon-], .button.is-success [class*=icon-] {
  color: var(--color-white);
}
.button.is-pony-club {
  color: var(--color-pony-club);
}
.button.is-pony-club span {
  color: var(--color-white);
}
.button.is-pony-club [class^=icon-], .button.is-pony-club [class*=icon-] {
  color: var(--color-white);
}
.button [class^=icon-], .button [class*=icon-] {
  height: 1.5em;
  width: 1.5em;
  align-items: center;
  display: inline-flex;
  justify-content: center;
  color: var(--color-secondary);
}
.button [class^=icon-]:first-child:not(:last-child), .button [class*=icon-]:first-child:not(:last-child) {
  margin-left: calc(-0.5em - 1px);
  margin-right: 0.5em;
}
.button [class^=icon-]:last-child:not(:first-child), .button [class*=icon-]:last-child:not(:first-child) {
  margin-left: 0.5em;
  margin-right: calc(-0.5em - 1px);
}
.button.is-loading, .button.is-submitting {
  cursor: not-allowed;
  position: relative;
}
.button.is-loading:not(.is-error) span, .button.is-submitting:not(.is-error) span {
  opacity: 0;
  position: relative;
  color: currentColor;
}
.button.is-loading:not(.is-error):after, .button.is-submitting:not(.is-error):after {
  display: block;
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  height: 1.2em;
  width: 1.2em;
  transform: translate(-50%, -50%);
  background: transparent url("data:image/svg+xml,%3Csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 38 38' style='enable-background:new 0 0 38 38;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:none;stroke:%23FFFFFF;stroke-width:6;stroke-opacity:0.5;%7D .st1%7Bfill:none;stroke:%23FFFFFF;stroke-width:6;%7D%0A%3C/style%3E%3Cg%3E%3Cg transform='translate(1 1)'%3E%3Ccircle class='st0' cx='18' cy='18' r='15.9'/%3E%3Cpath class='st1' d='M33.9,18c0-8.8-7.1-15.9-15.9-15.9 '%3E%3CanimateTransform accumulate='none' additive='replace' attributeName='transform' calcMode='linear' dur='1s' fill='remove' from='0 18 18' repeatCount='indefinite' restart='always' to='360 18 18' type='rotate'%3E%3C/animateTransform%3E%3C/path%3E%3C/g%3E%3C/g%3E%3C/svg%3E") center no-repeat;
  background-size: contain;
}
.button.is-alert {
  color: var(--color-alert);
}
.button.is-error {
  color: var(--color-error);
  opacity: 1;
  filter: saturate(100%);
}
.button.is-error span {
  position: relative;
  color: currentColor;
  min-width: 7em;
}
.button.is-error span:after {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  content: "Error!";
  color: var(--color-white);
}
.button.is-error span i {
  opacity: 0;
}
.button[disabled], .button.disabled {
  pointer-events: none;
  cursor: not-allowed;
  opacity: 0.5;
}
.button.is-icon-only {
  margin: 0;
  border: none;
  font-size: 2em;
  cursor: pointer;
  opacity: 0.75;
  background-color: transparent;
}
.button.is-icon-only:hover {
  opacity: 1;
}

.button.is-icon-only, button.is-icon-only {
  margin: 0;
  border: none;
  font-size: 2em;
  cursor: pointer;
  opacity: 0.75;
  background-color: transparent;
  padding: 0;
  height: auto;
}
.button.is-icon-only:hover, button.is-icon-only:hover {
  opacity: 1;
}
.button.is-icon-only i, button.is-icon-only i {
  font-size: 1em !important;
}

button.is-fullwidth {
  width: 100%;
}

.cart-button[data-count] {
  position: relative;
  padding-right: 1.5em;
}
.cart-button[data-count] i {
  max-width: 0;
  overflow: hidden;
}
.cart-button[data-count]:before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  height: 1.5em;
  width: 1.5em;
  background-color: var(--color-secondary);
  border-radius: 50%;
  transform: translateY(-50%);
}
.cart-button[data-count]:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  width: 1.5em;
  text-align: center;
  content: attr(data-count);
  color: var(--color-white);
  transform: translate(-0.15em, -50%);
  line-height: 1.5em;
  font-weight: var(--typography-bold-weight);
  font-size: 0.875em;
}
.cart-button[data-count] > span {
  padding-right: 1em;
}
.cart-button .cart-number {
  margin-left: 1rem;
  height: 1.25rem;
  width: 1.25rem;
  color: var(--color-white);
  line-height: 1.2em;
  font-size: 0.875rem;
  transform: scale(1.5);
  border-radius: 50%;
  border: 1px solid white;
}

.buttons-wrapper {
  margin-top: 1rem;
  display: flex;
  flex-flow: row wrap;
  margin-bottom: calc(var(--layout-grid-gap) - 1);
}
.buttons-wrapper:not(.auto-width) > * {
  width: 100%;
  margin-bottom: 1.25rem;
}
.buttons-wrapper .is-right {
  margin-left: auto !important;
}
.buttons-wrapper.text-center {
  justify-content: space-around;
}

/* =============================================================================
  Button Group
========================================================================== */
.button-group {
  position: relative;
  display: flex;
}

/* =============================================================================
  Split Button
========================================================================== */
.has-split {
  display: inline-flex;
}
.has-split .button {
  margin: 0;
}
.has-split .button:focus {
  border-color: transparent;
}
.has-split .button:focus.split-button {
  border-left: 1px solid var(--color-light);
}
.has-split > .button:not(.split-button) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.has-split .split-button {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-left: 1px solid var(--color-light);
}
.has-split.dropup .split-dropdown {
  top: auto;
  bottom: calc(100% + 6px);
}
.has-split .toggle-split-button:hover + button {
  opacity: 0.8;
}

.split-button {
  position: relative;
  padding-left: 1.4em;
  padding-right: 1.2em;
}
.split-button[aria-expanded=true] + .split-dropdown {
  display: block;
}
.split-button:before {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  font-family: "he-icons";
  content: "\e813";
  font-size: 0.5em;
  transform: translate(-50%, -50%);
  height: 0.5em;
  color: var(--color-white);
}
.split-button.is-white:before {
  color: var(--color-dark);
}
.split-button:active {
  transform: none;
}
.split-button + ul.split-dropdown {
  margin: 0;
  list-style: none;
}

.split-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 1000;
  display: none;
  min-width: 10rem;
  font-size: 1rem;
  text-align: right;
  background-color: var(--color-white);
  background-clip: padding-box;
  border: 1px solid var(--color-dark);
  border-radius: var(--layout-border-radius);
}
.split-dropdown li {
  margin: 0;
  padding: 0;
}
.split-dropdown li.divider {
  border-bottom: 1px solid var(--color-light);
}
.split-dropdown a {
  display: block;
  padding: 0.625rem 1.25rem;
  color: var(--color-dark);
  transition: none;
  white-space: nowrap;
}
.split-dropdown a:hover {
  color: var(--color-white);
  text-decoration: none;
  background-color: var(--color-accent);
}
.split-dropdown a:active {
  color: var(--color-white);
  text-decoration: none;
  background-color: var(--color-dark);
}

/* =============================================================================
  Button Group
========================================================================== */
.dropdown-button {
  position: relative;
  display: flex;
}

.dropdown-button-toggle[aria-expanded=true] + .button-dropdown {
  display: block;
}
.dropdown-button-toggle span:after {
  display: inline-block;
  width: 0;
  height: 0;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-bottom: 0;
  border-left: 0.3em solid transparent;
}

.button-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1000;
  display: none;
  float: left;
  min-width: 10rem;
  padding: 0.5rem 0;
  margin: 0.125rem 0 0;
  font-size: 1rem;
  color: #212529;
  text-align: left;
  list-style: none;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 0.25rem;
}
.button-dropdown.is-top {
  top: auto;
  bottom: 100%;
}
.button-dropdown.is-right {
  left: auto;
  right: 0;
}

.button-dropdown-item {
  display: block;
  width: 100%;
  padding: 0.25rem 1.5rem;
  clear: both;
  font-weight: 400;
  color: #212529;
  text-align: inherit;
  white-space: nowrap;
  background-color: transparent;
  border: 0;
}
.button-dropdown-item:active {
  color: #16181b;
  text-decoration: none;
  background-color: #f8f9fa;
}
.button-dropdown-item:hover {
  color: #fff;
  text-decoration: none;
  background-color: #007bff;
}

/* =============================================================================
Breakpoints
========================================================================== */
@media (min-width: 41.75rem) {
  /* =============================================================================
    Buttons wrapper
  ========================================================================== */
  .buttons-wrapper {
    margin-bottom: calc(var(--layout-grid-gap) * -1);
  }
  .buttons-wrapper:not(.has-fullwidth) {
    display: flex;
    flex-flow: row wrap;
    margin-left: calc(var(--layout-grid-gap) * -1);
  }
  .buttons-wrapper:not(.has-fullwidth) > * {
    width: auto;
    margin-left: var(--layout-grid-gap);
    margin-bottom: var(--layout-grid-gap);
  }
  .buttons-wrapper:not(.has-fullwidth).small-spacing {
    margin-left: calc(var(--layout-grid-gap) * -0.5);
  }
  .buttons-wrapper:not(.has-fullwidth).small-spacing > * {
    width: auto;
    margin-left: calc(var(--layout-grid-gap) * -0.5);
  }
}
/* =============================================================================
  Tabs
========================================================================== */
/*:root {
  --tab-padding: 2rem 3rem;
}*/
.tabs-wrapper:not(.simple) .tabs {
  border-bottom: var(--tabs-border-bottom, 2px solid var(--color-dark));
}
.tabs-wrapper:not(.simple) .tab {
  cursor: pointer;
  border: none;
  border-radius: 0;
  background-color: var(--color-light);
  padding: var(--tab-padding, 0.625rem 1.5rem);
}
.tabs-wrapper:not(.simple) .tab.is-active {
  background-color: var(--color-dark);
  color: var(--color-white);
  text-decoration: none;
}

.tabs {
  margin-bottom: var(--tabs-margin-bottom, 1rem);
}

.tab {
  border: none;
  background: none;
  border-radius: 0;
}
.tab.is-active {
  text-decoration: underline;
}

.content-tabs {
  margin-bottom: var(--content-tabs-margin-bottom, 1rem);
}

.content-tab {
  display: none;
}
.content-tab.is-active {
  display: block;
}

/* =============================================================================
Table Styles
========================================================================== */
table {
  width: 100%;
}
table:not(.simple) td, table:not(.simple) th {
  padding: var(--table-padding);
}
table:not(.simple) .table-advert-row td {
  padding: 0;
  padding-top: var(--table-padding-compact);
  padding-bottom: var(--table-padding-compact);
}
table:not(.simple) thead th, table:not(.simple) tfoot th {
  background-color: var(--color-dark);
  color: var(--color-white);
}
table:not(.simple) thead th:not([align]), table:not(.simple) tfoot th:not([align]) {
  text-align: inherit;
}
table:not(.simple) thead .table-title th, table:not(.simple) tfoot .table-title th {
  background-color: var(--color-accent);
}
table:not(.simple):not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}
table.has-headers tr:first-child td {
  background-color: var(--color-dark);
  color: var(--color-white);
}
table.has-headers tr:first-child td:not([align]) {
  text-align: inherit;
}
table.align-top td, table.align-top th {
  vertical-align: top;
}
table.is-border {
  border: 1px solid var(--color-dark);
  border-radius: var(--layout-border-radius);
  border-collapse: unset;
}
table .actions {
  text-align: right;
}
table tr[data-href]:hover td {
  background-color: var(--color-medium) !important;
  color: var(--color-white);
  cursor: pointer;
}
table.striped tr:nth-child(even) td {
  background-color: var(--table-striped-bg-color);
}
table.simple.space-y td, table.simple.space-y th {
  padding-top: var(--table-padding-compact);
  padding-bottom: var(--table-padding-compact);
}
table.simple.space-x td, table.simple.space-x th {
  padding-left: var(--table-padding-compact);
  padding-right: var(--table-padding-compact);
}

.cell-title {
  font-size: 0.875em;
  color: var(--color-black);
  font-weight: var(--typography-bold-weight);
  margin-bottom: 0.25em;
  text-transform: uppercase;
}

[data-order] {
  cursor: pointer;
}

.orderby-active {
  color: var(--color-primary);
  font-weight: var(--typography-bold-weight);
}
.orderby-active.DESC:after {
  content: "▼";
  padding-left: 0.5em;
}
.orderby-active.ASC:after {
  content: "▲";
  padding-left: 0.5em;
}

/* =============================================================================
  Breakponts
========================================================================== */
@media (max-width: 41.6875rem) {
  table.stack-on-xs td {
    display: block;
    background-color: transparent !important;
  }
}
/* =============================================================================
  Banner CSS
========================================================================== */
.banner {
  padding: calc(var(--layout-spacing) * 0.5);
  background-color: var(--color-light);
  border-radius: var(--layout-border-radius);
  border-left: 10px solid var(--color-dark);
  position: relative;
}
.banner:not([class^=mb-]):not([class*=" mb-"]) {
  margin-bottom: var(--layout-spacing);
}
.banner a:not(.button) {
  color: var(--color-accent);
}
.banner > *:first-child {
  margin-bottom: 0;
}
.banner > *:not(:first-child) {
  margin-top: 1rem;
}
.banner.is-primary {
  background-color: var(--color-primary);
  border-color: var(--color-secondary);
  color: var(--color-white);
}
.banner.is-primary p {
  color: var(--color-white);
}
.banner.is-primary a:not(.button) {
  color: var(--color-secondary);
}
.banner.is-dark {
  background-color: var(--color-dark);
  border-color: var(--color-primary);
  color: var(--color-white);
}
.banner.is-dark p {
  color: var(--color-white);
}
.banner.is-dark a:not(.button) {
  color: var(--color-secondary);
}
.banner.bg-alert {
  border-color: var(--color-black);
  background-color: var(--color-error);
}
.banner.bg-alert p {
  color: var(--color-black);
}
.banner.bg-error {
  border-color: var(--color-error);
  background-color: var(--color-error);
}
.banner.bg-error p, .banner.bg-error .h3, .banner.bg-error ul, .banner.bg-error ol {
  color: var(--color-white);
}
.banner.is-error {
  border-color: var(--color-error);
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 64rem) {
  .banner {
    display: flex;
    align-items: center;
    flex-flow: row wrap;
  }
  .banner > *:first-child {
    flex: 1 1 0;
    width: auto;
  }
  .banner > *:last-child {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
  }
  .banner > *:last-child:not(:first-child) {
    margin-top: 0;
    margin-left: 1.875rem;
  }
  .banner.text-center {
    justify-content: center;
  }
  .banner.is-info, .banner.is-alert {
    padding-left: calc(3em + var(--layout-spacing));
  }
  .banner.is-info:before, .banner.is-alert:before {
    position: absolute;
    top: 50%;
    left: calc(var(--layout-spacing) * 0.5);
    font-size: 3em;
    font-family: "he-icons";
    content: "\e81b";
    display: block;
    transform: translateY(-50%);
  }
  .banner.is-alert:before {
    content: "\e808";
  }
}
/* =============================================================================
Card
========================================================================== */
.card {
  background-color: var(--element-card-background);
  max-width: 100%;
  position: relative;
  border-radius: var(--card-radius, 6px);
}
.card:not(.allow-overflow) {
  overflow: hidden;
}
.card.align-center {
  display: flex;
  align-items: center;
}
.card.align-center > * {
  width: 100%;
}

.card-image {
  display: block;
  position: relative;
}
.card-image figure {
  aspect-ratio: 3/2;
}
.card-image figure img, .card-image figure video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card-content {
  display: block;
  background-color: transparent;
  padding: var(--card-spacing, 1.5rem);
  font-size: 0.875rem;
}
.card-content > div, .card-content > a, .card-content > img {
  display: inherit;
}

.card-media {
  align-items: flex-start;
  display: flex;
  text-align: inherit;
}
.card-media .image {
  width: 3rem;
  height: 3rem;
}
.card-media:not(:last-child) {
  margin-bottom: 1.5rem;
}

.card-media-left {
  flex-basis: auto;
  flex-grow: 0;
  flex-shrink: 0;
  margin-right: 1rem;
}

.card-media-content {
  flex-basis: auto;
  flex-grow: 1;
  flex-shrink: 1;
  text-align: inherit;
}

.card-title {
  display: block;
  color: var(--color-dark);
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.125;
}
.card-title:not(:last-child) {
  margin-bottom: 1.25rem;
}
.card-title:not(.is-spaced) + .card-subtitle {
  margin-top: -1.25rem;
}

.card-subtitle {
  color: var(--color-primary);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.25;
}

.card-meta {
  margin-top: var(--card-spacing, 1.5rem);
}

.card-footer {
  display: block;
  background-color: var(--color-dark);
  padding: var(--card-spacing, 1.5rem);
}

time {
  font-style: italic;
}

/* =============================================================================
  Boxes
========================================================================== */
.boxes-wrapper {
  display: grid;
  gap: var(--layout-grid-gap);
}

.horse-box {
  padding: var(--horsebox-padding, 2rem);
  color: var(--color-white);
  position: relative;
  border-radius: 0.375rem;
}
.horse-box:before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  max-width: var(--horsebox-head-maxwidth);
  opacity: 0.3;
  background-image: url(../images/horse-head.svg);
  background-size: var(--horsebox-head-size, 50px) auto;
  background-position: right var(--horsebox-padding, 1rem);
  background-repeat: no-repeat;
}
.horse-box.bg-primary .button, .horse-box.bg-accent .button {
  color: var(--color-secondary);
}
.horse-box.bg-primary .button:hover, .horse-box.bg-accent .button:hover {
  color: var(--color-dark);
}
.horse-box .title-wrapper {
  display: block;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 106.3125rem) {
  .horse-box:before {
    opacity: 1;
  }
  .horse-box .title-wrapper > * {
    display: block;
    max-width: calc(100% - var(--horsebox-head-size, 50px) - 10px + var(--horsebox-padding, 2rem));
    margin-left: 0;
  }
}
/* =============================================================================
  Accordion
========================================================================== */
.accordion details summary {
  cursor: pointer;
  background-color: var(--color-secondary);
  color: var(--color-white);
  margin-bottom: var(--layout-spacing);
  padding: calc(var(--accordion-summary-pad) * 0.5) var(--accordion-summary-pad);
  padding-right: 2.5em !important;
  position: relative;
}
.accordion details summary:after {
  display: block;
  position: absolute;
  top: 50%;
  right: var(--accordion-summary-pad);
  font-size: 0.75em;
  font-family: "he-icons";
  content: "\e806";
  transform: translateY(-50%) rotate(180deg);
}
.accordion details summary::-webkit-details-marker {
  display: none;
  content: "";
}
.accordion details summary::marker {
  display: none;
  content: "";
}
.accordion details.has-bg summary {
  margin: calc(var(--accordion-summary-pad) * -1);
  margin-bottom: var(--accordion-summary-pad);
}
.accordion details.has-bg .accordion-content {
  padding: var(--accordion-summary-pad);
}
.accordion details.has-bg.is-bg-white .accordion-content {
  background-color: var(--color-white);
}
.accordion details[open] summary {
  margin-bottom: var(--accordion-summary-pad);
}
.accordion details[open] summary:after {
  transform: translateY(-50%);
}
.accordion details[open] .accordion-content {
  margin-bottom: var(--layout-spacing);
}

/* =============================================================================
  Header
========================================================================== */
#header {
  top: -0.5px;
  margin-top: 0;
  background-color: var(--header-bg-color);
  height: var(--layout-header-height, 100px);
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--header-border-color);
  z-index: 60;
}
#header.is-stuck {
  border-bottom-color: var(--color-secondary);
}
#header > div {
  width: 100%;
}

#header-logo {
  max-height: var(--layout-header-logo-height, 80px);
  height: auto;
  max-width: 100%;
}

.header-button {
  border-radius: 0;
}

#hero {
  background-color: var(--hero-bg-color);
}
#hero .overline, #hero a.overline {
  font-size: 1.125rem;
  color: var(--hero-overline-color);
}

#hero-inner {
  padding-top: var(--hero-padding);
  padding-bottom: var(--hero-padding);
}

.hero-image-wrapper {
  display: none;
}
.hero-image-wrapper img {
  max-height: 11.875rem;
  border-radius: 1rem;
  overflow: hidden;
}

#sub-hero .items.is-flex {
  flex-flow: row wrap;
  gap: 1rem;
}
#sub-hero .items.is-flex > .item {
  display: block;
}
#sub-hero .items > * {
  margin-right: 1.25rem;
}

#sub-hero a:not(.button), #sub-hero a:not(.button):visited, .hero-additional a:not(.button), .hero-additional a:not(.button):visited {
  color: var(--color-white);
}
#sub-hero a:not(.button):hover, #sub-hero a:not(.button):visited:hover, .hero-additional a:not(.button):hover, .hero-additional a:not(.button):visited:hover {
  color: var(--color-light);
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 73.75rem) {
  #menu-main-menu li a:not(.button), #menu-secondary-menu li a:not(.button) {
    padding-bottom: 1rem;
  }
  #menu-main-menu {
    margin-left: 1rem;
  }
  #menu-main-menu > li > a {
    text-transform: uppercase;
    font-weight: var(--typography-bold-weight);
    font-size: 1.125rem;
  }
  #menu-secondary-menu {
    margin-top: 1rem;
  }
}
@media (min-width: 41.75rem) {
  .hero-image-wrapper {
    display: flex;
    justify-content: flex-end;
  }
}
@media (min-width: 64rem) {
  #sub-hero .items .md-is-right {
    margin-left: auto;
    margin-right: 0;
  }
}
@media (min-width: 106.3125rem) {
  #menu-main-menu > li > a {
    font-size: 1.25rem;
  }
}
/* =============================================================================
  Footer
========================================================================== */
#footer .cards-accepted {
  width: auto;
  max-width: none;
  max-height: 1.875rem;
}

.footer-top {
  background-color: var(--color-dark);
  color: var(--color-white);
}
.footer-top a:not(.button):link, .footer-top a:not(.button):visited {
  color: var(--color-white);
}
.footer-top a:not(.button):link:hover, .footer-top a:not(.button):visited:hover {
  color: var(--color-medium);
}
.footer-top a.menu-title {
  display: block;
  color: var(--color-primary) !important;
  margin-bottom: calc(var(--layout-spacing) * 0.5);
}

.footer-bottom {
  margin: 0.625rem 0;
}

.footer-links-wrapper {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  font-size: 0.875rem;
}
.footer-links-wrapper a:not(.button):link, .footer-links-wrapper a:not(.button):visited {
  color: var(--typography-body-colour);
}
.footer-links-wrapper a:not(.button):link:hover, .footer-links-wrapper a:not(.button):visited:hover {
  color: var(--color-primary);
}
.footer-links-wrapper > *:not(:first-child):before {
  position: relative;
  content: "|";
  display: inline-block;
  margin-left: 0.375rem;
  margin-right: 0.375rem;
}

.indigo-credits {
  align-items: center;
}

/* =============================================================================
  Footer Actions Bar
========================================================================== */
#footer-actions-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 1.25rem 0;
  background-color: var(--color-dark);
  border-top: 6px solid var(--color-white);
  z-index: 60;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 75.625rem) {
  .indigo-credits {
    display: inline-flex !important;
  }
  .cards-accepted-wrapper {
    justify-content: flex-end;
  }
}
/* =============================================================================
  Burgess
========================================================================== */
.burger {
  position: relative;
  margin-top: 8px;
  margin-bottom: 8px;
  -webkit-user-select: none;
  user-select: none;
  cursor: pointer;
  display: block;
  /*&.is-active {
    @include burger-to-cross;
  }*/
}
.burger, .burger:before, .burger:after {
  display: block;
  width: var(--header-burger-height);
  height: 3px;
  background-color: var(--header-burger-color);
  transition-property: background-color, transform;
  transition-duration: 0.3s;
}
.burger:before, .burger:after {
  position: absolute;
  content: "";
}
.burger:before {
  top: -8px;
}
.burger:after {
  top: 8px;
}

/* =============================================================================
  Navigation
========================================================================== */
.navbar {
  position: relative;
  z-index: 30;
  align-items: stretch;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.navbar .navbar-item a:not(.button), .navbar .navbar-link {
  color: var(--navbar-link-color);
  display: block;
  line-height: 1.5;
  padding: 0.5rem 0.75rem;
  cursor: pointer;
}
.navbar .navbar-item, .navbar .navbar-item a, .navbar .navbar-link {
  position: relative;
}
.navbar .navbar-item {
  flex-grow: 0;
  flex-shrink: 0;
}
.navbar .navbar-item.has-dropdown {
  padding: 0;
}
.navbar .navbar-item.has-dropdown > a {
  align-items: center;
  display: flex;
}
.navbar .navbar-item.has-dropdown > a:after {
  border: 2px solid transparent;
  border-radius: 2px;
  border-right: 0;
  border-top: 0;
  content: " ";
  display: block;
  height: 0.625em;
  pointer-events: none;
  position: absolute;
  bottom: 0.5rem;
  transform: translate(-50%, -100%) rotate(-45deg);
  transform-origin: center;
  width: 0.625em;
  border-color: var(--navbar-link-color);
  left: calc(50% + 0.175em);
  margin-top: 0;
  opacity: 0;
}
.navbar .navbar-item.has-dropdown:not(.is-active) > a:after {
  transition: opacity 250ms ease, bottom 250ms ease;
}
.navbar .navbar-item.has-dropdown:not(.is-active) > a:hover:not(.button):after {
  bottom: 0;
  opacity: 1;
}
.navbar .navbar-item.has-dropdown.is-active > a:after {
  transform: rotate(135deg);
  margin-top: -0.375em;
}
.navbar .navbar-item.is-current > a, .navbar .navbar-item.is-current-ancestor > a {
  color: var(--navbar-link-current-color);
}
.navbar .navbar-item.pc-rally-link > a {
  display: inline-block !important;
}
.navbar .navbar-item.pc-rally-link > a:after {
  content: "";
  line-height: inherit;
  position: relative;
  display: inline-block;
  background: transparent url(../images/pc-favicon.png) center center no-repeat;
  background-size: contain;
  top: 0.25em;
  width: 1.4em;
  height: 1.4em;
  margin-left: 0.5em;
}
.navbar .navbar-item.is-button {
  padding-top: 0.25rem;
}

.navbar-brand, .navbar-tabs {
  align-items: stretch;
  display: flex;
  flex-shrink: 0;
  min-height: calc(var(--layout-header-height, 100px) / 2);
}

.navbar-menu {
  display: none;
}

.navbar-dropdown {
  font-size: 1rem;
  padding-bottom: 0.5rem;
  padding-top: 0.5rem;
}

.nav-buttons {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
  align-items: center;
}
.nav-buttons a, .nav-buttons a:visited, .nav-buttons a:hover {
  color: var(--header-burger-color);
}
.nav-buttons a i, .nav-buttons a:visited i, .nav-buttons a:hover i {
  font-size: var(--header-burger-height);
}

/* =============================================================================
  Menu
========================================================================== */
.menu {
  display: flex;
  flex-flow: row wrap;
  list-style-type: none;
  margin-left: 0;
}
.menu li.is-current > a, .menu li.is-current-ancestor > a {
  color: var(--color-primary);
}
.menu:not(.vertical):not(.is-accordion-dropdown):not(.navbar-dropdown) > li:not(:first-child) {
  margin-left: 0.5rem;
}
.menu.vertical {
  flex-flow: column nowrap;
}
.menu.vertical li:not(:first-child) {
  margin-top: 0.5em;
}
.menu.vertical .navbar-dropdown {
  display: none;
}
.menu .navbar-dropdown {
  margin-left: 0.5em;
}

/* =============================================================================
Mega Menu
========================================================================== */
.is-mega > .has-dropdown > .navbar-dropdown {
  padding: var(--mega-menu-padding);
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  background-color: var(--color-white);
  border-bottom-left-radius: 6px;
  border-bottom-right-radius: 6px;
  box-shadow: 0 8px 8px rgba(10, 10, 10, 0.1);
  border-top: 4px solid var(--color-accent);
}
.is-mega > .has-dropdown > .navbar-dropdown .column {
  width: calc(25% - var(--mega-menu-padding));
  display: flex;
  flex-flow: column nowrap;
}
.is-mega > .has-dropdown > .navbar-dropdown .column.width-33 {
  width: calc(33.333% - var(--mega-menu-padding));
}
.is-mega > .has-dropdown > .navbar-dropdown .column:not(:last-child) {
  margin-right: var(--mega-menu-padding);
}
.is-mega > .has-dropdown > .navbar-dropdown .column.widget-location:last-child {
  margin-left: var(--mega-menu-padding);
}
.is-mega > .has-dropdown > .navbar-dropdown .column > a {
  display: none;
}
.is-mega > .has-dropdown > .navbar-dropdown .column > ul > ul > *:not(:last-child) {
  margin-bottom: 1.5rem;
}
.is-mega > .has-dropdown > .navbar-dropdown .column.width-50 {
  width: calc(50% - 2rem);
}
.is-mega > .has-dropdown > .navbar-dropdown .column.width-50 > ul ul {
  display: flex !important;
  flex-flow: row wrap;
}
.is-mega > .has-dropdown > .navbar-dropdown .column.width-50 > ul ul > li {
  width: 33%;
}
.is-mega > .has-dropdown > .navbar-dropdown .column .navbar-item {
  display: block;
}
.is-mega > .has-dropdown > .navbar-dropdown .navbar-dropdown {
  margin-left: 0;
  padding-top: 0;
}
.is-mega > .has-dropdown.is-active > .navbar-dropdown {
  display: flex !important;
  flex-flow: row wrap;
}
.is-mega > .has-dropdown .has-dropdown > a:after {
  display: none;
}
.is-mega > .has-dropdown li:not(.column) {
  margin-left: 0 !important;
}
.is-mega > .has-dropdown li:not(.column) > a:not(.button) {
  padding-left: 0 !important;
  padding-bottom: 0.25rem !important;
}
.is-mega .has-dropdown {
  position: static;
}
.is-mega .title {
  font-size: 1.25rem;
}
.is-mega .title > a {
  color: var(--color-accent) !important;
}

/* =============================================================================
  Menu Image
========================================================================== */
.menu-image-wrapper {
  border-radius: 6px;
  overflow: hidden;
}

/* =============================================================================
  Submenu Active
========================================================================== */
body .content-overlay {
  position: relative;
  z-index: -1;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-black);
  opacity: 0;
}
body.submenu-active .content-overlay {
  transition: opacity 250ms ease-out;
  z-index: 20;
  opacity: 0.6;
}

/* =============================================================================
  Accordion Menu
========================================================================== */
.is-accordion-dropdown {
  margin-left: 0 !important;
}
.is-accordion-dropdown li {
  margin-left: 0;
}
.is-accordion-dropdown li:before {
  display: inline-block;
  content: "–";
  position: relative;
  font-size: 1em;
  color: var(--color-primary);
  margin-right: 0.75em;
  font-weight: var(--typography-bold-weight);
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 75.625rem) {
  .is-mega .navbar-dropdown .title {
    font-size: 1.375rem;
  }
  .is-mega .navbar-dropdown li:not(.title) {
    font-size: 1.125rem;
  }
}
/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 73.75rem) {
  header {
    height: auto;
  }
  .navbar-burger, .nav-buttons {
    display: none;
  }
  .navbar, .navbar-menu, .navbar-start {
    align-items: stretch;
    display: flex;
  }
  .navbar-menu {
    flex-grow: 1;
    flex-shrink: 0;
    align-items: center;
    align-items: flex-end;
  }
  .navbar-start {
    justify-content: flex-start;
    margin-right: auto;
  }
  .navbar-end {
    display: flex;
    flex-flow: column nowrap;
    align-items: flex-end;
  }
  .navbar .navbar-item, .navbar .navbar-link {
    align-items: center;
    display: flex;
  }
  .navbar .navbar-item.has-dropdown {
    align-items: stretch;
  }
  .navbar .navbar-item.has-dropdown.is-active .navbar-dropdown {
    display: block;
  }
  .end-top {
    display: grid;
    align-items: center;
    grid-auto-flow: column;
    gap: var(--layout-grid-gap);
  }
  .navbar-dropdown {
    display: none;
  }
  .is-menu:not(.is-mega) > .has-dropdown > .navbar-dropdown {
    background-color: var(--color-white);
    border-bottom-left-radius: 6px;
    border-bottom-right-radius: 6px;
    box-shadow: 0 8px 8px rgba(10, 10, 10, 0.1);
    border-top: 2px solid #dbdbdb;
    left: 0;
    min-width: 12.5rem;
    position: absolute;
    top: 100%;
    z-index: 20;
  }
  .is-menu:not(.is-mega) > .has-dropdown > .navbar-dropdown.user-menu {
    background-color: var(--color-light);
  }
  .is-menu:not(.is-mega) > .has-dropdown > .navbar-dropdown.user-menu .is-current > a {
    color: var(--color-black);
    font-weight: var(--typography-bold-weight);
  }
}
/* =============================================================================
  Modal
========================================================================== */
.modal {
  align-items: center;
  display: none;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  top: 0;
  z-index: 61;
}
.modal.is-activating {
  display: flex;
}
.modal.is-active {
  display: flex;
}
.modal.is-active .modal-background {
  opacity: 1;
  transition-delay: 0s;
}
.modal.is-active .modal-card, .modal.is-active .modal-content {
  transition: transform 250ms ease, opacity 150ms ease;
  transition-delay: 250ms;
  transform: translateY(0) scale(1);
  opacity: 1;
}
.modal.is-active.is-closing .modal-card, .modal.is-active.is-closing .modal-content {
  transform: translateY(-150px) scale(0.5);
  opacity: 0;
  transition-delay: 0s;
}
.modal.is-active.is-closing .modal-background {
  opacity: 0;
  transition-delay: 250ms;
}
.modal.is-active .close {
  margin: 0 auto 1.875rem;
  outline: none !important;
  border: none !important;
}
.modal.is-active .close:focus-visible {
  outline: none;
}
.modal.image-modal .modal-content {
  display: flex;
  flex-flow: column;
  height: 100%;
  max-width: 90vw;
  max-height: 90vh;
  width: auto;
  text-align: center;
}
.modal.image-modal .modal-content img {
  object-fit: contain;
  max-width: 100%;
  max-height: 100%;
}
.modal.image-modal .modal-content:has(figcaption) img {
  max-height: calc(100% - 40px);
}
.modal.image-modal .modal-img-wrapper {
  flex: 1;
  justify-content: center;
  display: flex;
  flex-flow: column;
  overflow: hidden;
}
.modal.text-modal .modal-content {
  max-width: 90vw;
  width: auto;
  text-align: left;
  overflow: clip;
}
.modal.text-modal .text-content {
  padding: 1.875rem;
  background-color: var(--color-white);
  border-radius: 6px;
  max-height: 70svh;
  overflow-Y: auto;
}
.modal.text-modal .text-content p:not(:last-child) {
  margin-bottom: 1rem;
}
.modal.is-modal-md .modal-content {
  width: 90vw;
  max-width: 75rem;
}
.modal iframe {
  display: none;
  border: none !important;
  outline: none !important;
}
.modal.is-iframe .text-content {
  margin: 0;
  padding: 0;
  overflow: auto;
}
.modal.is-iframe iframe {
  display: block;
}

.modal-background {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  background-color: rgba(10, 10, 10, 0.86);
  opacity: 0;
  transition: opacity 250ms ease;
  transition-delay: 250ms;
}

.modal-card, .modal-content {
  display: block;
  margin: 0 20px;
  max-height: calc(100vh - 160px);
  overflow: auto;
  position: relative;
  width: 100%;
  transform: translateY(-150px) scale(0.5);
  opacity: 0;
  transition: transform 250ms ease, opacity 150ms ease;
  transition-delay: 0s;
}
.modal-card figcaption, .modal-content figcaption {
  margin-top: 1rem;
  color: var(--color-white);
}

@media (min-width: 75.625rem) {
  .modal-card, .modal-content {
    margin: 0 auto;
    max-height: calc(100vh - 40px);
    width: 640px;
  }
}
@media (min-width: 106.3125rem) {
  .modal.text-modal .modal-content, .modal.image-modal .modal-content {
    max-width: 62.5rem;
  }
}
/* =============================================================================
  Pagination
========================================================================== */
.pagination-ellipsis, .pagination-link, .pagination-next, .pagination-previous, .pagination-all {
  -moz-appearance: none;
  -webkit-appearance: none;
  align-items: center;
  border: 1px solid transparent;
  border-radius: 0.375em;
  box-shadow: none;
  display: inline-flex;
  font-size: 1rem;
  height: 2.5em;
  line-height: 1.5;
  padding-bottom: calc(0.5em - 1px);
  padding-left: calc(0.75em - 1px);
  padding-right: calc(0.75em - 1px);
  padding-top: calc(0.5em - 1px);
  position: relative;
  vertical-align: top;
  justify-content: center;
  margin: 0.25rem;
  text-align: center;
}
.pagination-ellipsis.is-current, .pagination-link.is-current, .pagination-next.is-current, .pagination-previous.is-current, .pagination-all.is-current {
  border-color: var(--color-secondary);
  background-color: var(--color-secondary);
  color: var(--color-white);
}

.pagination, .pagination-list, .pagination-content {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  text-align: center;
}

ul.pagination-list {
  list-style: none;
}

.pagination {
  justify-content: space-between;
  margin-bottom: 0;
  margin-top: 0;
}

.pagination-link, .pagination-next, .pagination-previous, .pagination-all {
  border-color: var(--color-dark);
  color: var(--color-dark);
  min-width: 2.5em;
}
.pagination-link:not(.disabled):not(.pagination-link), .pagination-next:not(.disabled):not(.pagination-link), .pagination-previous:not(.disabled):not(.pagination-link), .pagination-all:not(.disabled):not(.pagination-link) {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
  color: var(--color-white);
}
.pagination-link.disabled, .pagination-next.disabled, .pagination-previous.disabled, .pagination-all.disabled {
  opacity: 0.4;
}

.pagination-next, .pagination-previous {
  padding-left: 0.75em;
  padding-right: 0.75em;
  white-space: nowrap;
}

@media (min-width: 75.625rem) {
  /*.pagination-list {
    flex-grow: 1;
    flex-shrink: 1;
    //justify-content: flex-start;
    order: 1;
  }
  .pagination-previous {
    order:2;
  }
  .pagination-next {
    order:3;
  }*/
}
/*! Flickity v2.1.1
https://flickity.metafizzy.co
---------------------------------------------- */
.flickity-enabled {
  position: relative;
}

.flickity-enabled:focus {
  outline: none;
}

.flickity-viewport {
  overflow: hidden;
  position: relative;
  height: 100%;
}

.flickity-slider {
  position: absolute;
  width: 100%;
  height: 100%;
  margin-bottom: 1.875rem;
}

/* draggable */
.flickity-enabled.is-draggable {
  -webkit-tap-highlight-color: transparent;
  tap-highlight-color: transparent;
  -webkit-user-select: none;
  user-select: none;
}

.flickity-enabled.is-draggable .flickity-viewport {
  cursor: move;
  cursor: grab;
}

.flickity-enabled.is-draggable .flickity-viewport.is-pointer-down {
  cursor: grabbing;
}

/* ---- flickity-button ---- */
.flickity-button {
  position: relative;
  display: inline-block;
  /*position: absolute;
  background: hsla(0, 0%, 100%, 0.75);
  border: none;
  color: #333;*/
}

.flickity-button:hover {
  background: white;
  cursor: pointer;
}

.flickity-button:focus {
  outline: none;
  box-shadow: 0 0 0 5px #19F;
}

.flickity-button:active {
  opacity: 0.6;
}

.flickity-button:disabled {
  opacity: 0.3;
  cursor: auto;
  /* prevent disabled button from capturing pointer up event. #716 */
  pointer-events: none;
}

.flickity-button-icon {
  fill: #333;
}

/* ---- previous/next buttons ---- */
.flickity-prev-next-button {
  width: 44px;
  height: 44px;
  /* vertically center */
}

.flickity-prev-next-button.previous {
  left: 10px;
}

.flickity-prev-next-button.next {
  right: 10px;
}

/* right to left */
.flickity-rtl .flickity-prev-next-button.previous {
  left: auto;
  right: 10px;
}

.flickity-rtl .flickity-prev-next-button.next {
  right: auto;
  left: 10px;
}

.flickity-prev-next-button .flickity-button-icon {
  position: absolute;
  left: 20%;
  top: 20%;
  width: 60%;
  height: 60%;
}

/* ---- page dots ---- */
.flickity-page-dots {
  position: absolute;
  width: auto;
  bottom: -25px;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
  line-height: 1;
}

.flickity-rtl .flickity-page-dots {
  direction: rtl;
}

.flickity-page-dots .dot {
  display: inline-block;
  width: 16px;
  height: 16px;
  margin: 0 8px 0 0;
  background: var(--color-white);
  border-radius: 50%;
  cursor: pointer;
}

.flickity-page-dots .dot.is-selected {
  background: var(--color-dark);
}

/* =============================================================================
  Offcanvas
========================================================================== */
.offcanvas {
  z-index: 999;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: var(--color-secondary);
  color: var(--color-white);
  flex-flow: column nowrap;
  display: none;
  transform: translateY(-30%);
  opacity: 0;
  transition: transform 250ms ease, opacity 250ms ease;
  transition-delay: 0s;
}
.offcanvas.is-activating, .offcanvas.is-closing {
  display: flex;
}
.offcanvas.is-active {
  display: flex;
  transform: translateY(0);
  opacity: 1;
  transition: transform 250ms ease, opacity 250ms ease;
  transition-delay: 50ms;
}
.offcanvas.is-closing {
  transform: translateY(-30%);
  opacity: 0;
}
.offcanvas .menu a {
  color: var(--color-white);
}

.event-manager-view .offcanvas {
  background-color: var(--color-dark);
}

.offcanvas-header {
  background-color: var(--color-white);
  padding: calc(var(--offcanvas-padding, 2rem) * 0.5) var(--offcanvas-padding, 2rem);
}
.offcanvas-header .offcanvas-link {
  font-size: calc(var(--offcanvas-close, 2rem) * 0.75);
  display: inline-block;
  color: var(--color-accent);
}
.offcanvas-header .offcanvas-link:not(:last-child) {
  margin-right: 1rem;
}
.offcanvas-header .offcanvas-close {
  color: var(--color-dark);
  font-size: var(--offcanvas-close, 2rem);
  display: block;
  width: var(--offcanvas-close, 2rem);
}

.offcanvas-inner {
  overflow: auto;
  overscroll-behavior: contain;
}

.offcanvas-content {
  padding: var(--offcanvas-padding, 2rem);
}

.offcanvas-buttons {
  margin-bottom: var(--offcanvas-padding, 2rem);
}

.offcanvas-button {
  font-size: 1.125rem;
  padding: 0.75em;
  color: var(--color-white);
  background-color: var(--color-primary);
  display: block;
  text-align: center;
  text-transform: uppercase;
}
.offcanvas-button:first-child {
  margin-right: 1px;
}
.offcanvas-button:last-child {
  margin-left: 1px;
}

/*.offcanvas-fixed-footer {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: -1;
  &:before {
    display: block;
    content:"";
    position: absolute;
    top: 50%;
    right: var(--offcanvas-padding,2rem);
    width: 50vw;
    transform: translateY(-100%);
    aspect-ratio:1/1;
    background-image: url(../images/horse-dressage.svg);
    background-image: url(../images/horse-jumping.svg);
    background-repeat:no-repeat;
    background-size:contain;
    opacity: 0.2;
  }
}*/
/* =============================================================================
  Menus
========================================================================== */
#offcanvas-main-menu {
  margin-top: var(--offcanvas-padding, 2rem);
  font-size: 1.25rem;
  text-transform: uppercase;
}
#offcanvas-main-menu li {
  padding: 0;
}
#offcanvas-main-menu li :link, #offcanvas-main-menu li :visited {
  color: var(--color-white);
}
#offcanvas-main-menu li.is-current > a, #offcanvas-main-menu li.is-current-ancestor > a {
  color: var(--color-primary);
}
#offcanvas-main-menu > li > a {
  display: block;
  background-color: rgba(255, 255, 255, 0.1);
  padding: calc(var(--offcanvas-padding, 2rem) * 0.5) var(--offcanvas-padding, 2rem);
  transition: background-color 250ms linear;
}
#offcanvas-main-menu > li:not(:first-child) {
  margin-top: 2px;
}
#offcanvas-main-menu > li.is-active:not(.is-current-ancestor) > a {
  color: var(--color-white);
  background-color: var(--color-accent);
}
#offcanvas-main-menu > li.is-current-ancestor > a, #offcanvas-main-menu > li.is-current > a {
  color: var(--color-white);
  background-color: var(--color-accent);
}
#offcanvas-main-menu > li > ul {
  position: relative;
  margin-left: var(--offcanvas-padding, 2rem) !important;
  margin-right: var(--offcanvas-padding, 2rem);
  margin-bottom: calc(var(--offcanvas-padding, 2rem) * 0.5);
}
#offcanvas-main-menu > li > ul:before {
  display: block;
  content: "";
  padding-top: calc(var(--offcanvas-padding, 2rem) * 0.25);
}
#offcanvas-main-menu > li > ul:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 2px;
  height: calc(100% - 1.5em);
  background-color: var(--color-accent);
  display: block;
  content: "";
}
#offcanvas-main-menu > li > ul > li {
  margin-top: 0.5rem;
  padding-left: 1rem;
  position: relative;
  /*&.is-current,&:active,&:hover {
    position: relative;
    &:after {
      position: absolute;
      display: block;
      content:"";
      left: 0;
      top:0;
      width: 4px;
      height: 100%;
      background-color: var(--color-white);
      z-index:3;
      transform: translateX(-1px);
    }
  }*/
}
#offcanvas-main-menu > li > ul > li:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 10px;
  height: 2px;
  background-color: var(--color-accent);
  transform: translateY(-50%);
}
#offcanvas-main-menu > li > ul > li:last-child:after {
  position: absolute;
  top: 50%;
  left: 0;
  width: 4px;
  height: 10px;
  content: "";
  background-color: var(--color-secondary);
  z-index: 2;
  transform: translateY(1px);
}
#offcanvas-main-menu > li > ul > li > a {
  display: inline-block;
  padding: 0.375rem 1rem 0.375rem 0.125rem;
}

#offcanvas-secondary-menu li {
  line-height: 2;
}

/* =============================================================================
  Toast Styles
========================================================================== */
/* =============================================================================
  Toast
========================================================================== */
#toast {
  visibility: hidden;
  width: calc(100vw - 60px);
  max-width: 31.25rem;
  background-color: var(--color-success);
  color: var(--color-white) !important;
  text-align: center;
  border-radius: 0.375rem;
  padding: 1rem;
  position: fixed;
  z-index: 1007;
  left: 50%;
  bottom: 30px;
  transform: translateX(-50%);
  box-shadow: rgba(0, 0, 0, 0.6) 0px 20px 50px 0px;
}
#toast a:not(.button) {
  text-decoration: underline;
  color: var(--color-white) !important;
}
#toast.info {
  background-color: var(--color-dark);
}
#toast.warning {
  background-color: var(--color-alert);
}
#toast.error {
  background-color: var(--color-error);
}

@keyframes toastIn {
  from {
    bottom: 0;
    opacity: 0;
  }
  to {
    bottom: 30px;
    opacity: 1;
  }
}
@keyframes toastOut {
  from {
    bottom: 30px;
    opacity: 1;
  }
  to {
    bottom: 0;
    opacity: 0;
  }
}
body.toast-active div, body.toast-active a, body.toast-active label {
  animation: toastErrorCursor 1000ms;
}
body.toast-active #toast {
  --toast_timing: var(--toast_timing, 2500ms);
  visibility: visible;
  animation: toastIn 0.5s;
}
body.toast-active #toast:not(.persist) {
  animation: toastIn 0.5s, toastOut 0.5s var(--toast_timing);
}

@keyframes toastErrorCursor {
  0% {
    cursor: default;
  }
  1% {
    cursor: not-allowed;
  }
  99% {
    cursor: not-allowed;
  }
  100% {
    cursor: default;
  }
}
body.toast-active:has(#toast.persist):after {
  content: "";
  display: block;
  z-index: 1006;
  position: fixed;
  background-color: rgba(0, 0, 0, 0.4);
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 75.625rem) {
  #toast {
    font-size: 1.125rem;
  }
}
/* =============================================================================
  Message Bar
========================================================================== */
#message-bar {
  max-height: 0;
  transition: max-height 0.5s ease-in-out;
  overflow: hidden;
}
#message-bar.active {
  max-height: 6.25rem;
}
#message-bar .msg-close {
  background: none;
  border: none;
  margin-top: 0.625rem;
  color: var(--color-white);
  font-size: 1.2em;
}

/* =============================================================================
  Social stuff
========================================================================== */
.indigo-social {
  margin-top: calc(var(--layout-spacing) * 0.5);
  display: flex;
  flex-flow: row wrap;
}

.indigo-sharing {
  background-color: var(--color-white);
  width: 1.875rem;
  height: 1.875rem;
  border-radius: 0.25rem;
  position: relative;
  display: block;
  transition: background-color 250ms ease;
}
.indigo-sharing:not(:last-child) {
  margin-right: 0.625rem;
}
.indigo-sharing:hover {
  background-color: var(--color-medium);
}
.indigo-sharing i {
  position: absolute;
  top: 50%;
  left: 50%;
  color: var(--color-dark);
  transform: translate(-50%, -50%);
  font-size: 1.3em;
}

.monthpicker-wrapper {
  position: relative;
}
.monthpicker-wrapper [type=text].opened {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  box-shadow: 0 0 0 4px var(--color-accent);
}
.monthpicker-wrapper [type=text].opened ~ .monthpicker-popup-wrapper {
  display: flex;
  box-shadow: 0 4px 0 4px var(--color-accent);
}
.monthpicker-wrapper [type=text].opened:not(:placeholder-shown) ~ .js-clear {
  display: block;
}
.monthpicker-wrapper [type=text][readonly] {
  opacity: 1;
  background-color: var(--color-white);
  cursor: pointer;
}
.monthpicker-wrapper:after {
  position: absolute;
  top: calc(var(--form-input-padding, 1rem) / 2);
  right: var(--form-input-padding, 1rem);
  font-size: 1.875rem;
  color: var(--color-secondary);
  font-family: "he-icons";
  content: "\e804";
  z-index: 1;
}
.monthpicker-wrapper .js-clear {
  cursor: pointer;
  background-color: var(--color-white);
  color: var(--color-secondary);
  position: absolute;
  top: calc(var(--form-input-padding, 1rem) / 2);
  right: var(--form-input-padding, 1rem);
  margin-right: -1px;
  font-size: 1.875rem;
  display: none;
  z-index: 2;
}
.monthpicker-wrapper .js-clear:after {
  font-family: "he-icons";
  content: "\e801";
}

.monthpicker-popup-wrapper {
  align-items: center;
  margin-top: calc(var(--form-spacing, 30px) * -1 - 1px);
  background-color: var(--color-white);
  display: none;
  flex-flow: column nowrap;
  padding: 5px;
  position: absolute;
  z-index: 1;
  border-top: none;
  border-bottom-left-radius: var(--form-input-radius, 0px);
  border-bottom-right-radius: var(--form-input-radius, 0px);
}
.monthpicker-years-wrapper {
  margin-top: 1rem;
  border-radius: 0.25rem;
  padding: 6px 3px;
  background-color: var(--color-dark);
  color: var(--color-white);
  align-items: center;
  display: flex;
  justify-content: space-between;
  width: calc(100% - 20px);
}
.monthpicker-years-wrapper > span {
  border: 1px solid transparent;
  border-radius: 5px;
  cursor: pointer;
  height: max-content;
  padding: 5px;
  text-align: center;
  -webkit-user-select: none;
  user-select: none;
}
.monthpicker-years-wrapper > span:hover {
  border: 1px solid var(--color-medium);
}
.monthpicker-years-wrapper > span:active {
  color: #a7a7a7;
}

.months-wrapper {
  border-spacing: 0.625rem;
  border-collapse: inherit;
  padding-top: 5px;
  table-layout: fixed;
  width: 100%;
}
.months-wrapper > tr > td {
  border: 1px solid transparent;
  cursor: pointer;
  font-size: 1.125rem;
  line-height: 2em;
  text-align: center;
  width: 3.5em;
  border-radius: 4px;
  background-color: var(--color-medium);
  padding: 0;
}
.months-wrapper > tr > td.disabled {
  background-color: var(--color-medium);
  border: 1px solid var(--color-medium);
  color: var(--color-white);
  pointer-events: none;
  cursor: not-allowed;
  opacity: 0.5;
}
.months-wrapper > tr > td.selected {
  border: 1px solid var(--color-dark);
  color: #fff;
  font-weight: 700;
  background-color: var(--color-dark);
}
.months-wrapper > tr > td:not(.selected):hover {
  opacity: 0.9;
  border: 1px solid #ddd;
}

input.nbm.month-picker + .monthpicker-wrapper > input {
  margin-bottom: 0 !important;
}

/* =============================================================================
  Maps Stuff
========================================================================== */
.map {
  background-color: var(--color-light);
  min-height: 24.375rem;
  position: relative;
}
.map:after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  transform: translate(-50%, -50%);
  text-transform: uppercase;
}
.map.is-empty:after {
  content: "";
}
.map.is-loading:after {
  content: "Loading...";
}
.map.is-error > div {
  display: none;
}
.map.is-error:after {
  content: "ERROR.";
  color: #ff0000;
}

/* =============================================================================
Image Uploader Stuff
========================================================================== */
.file-uploader {
  --max-width: 23.4375rem;
  aspect-ratio: var(--aspect-ratio, 1/1);
  width: 100%;
  border-radius: var(--layout-border-radius);
  background-color: var(--color-light);
  border: 2px dashed var(--color-medium);
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: var(--max-width, none);
}
.file-uploader:after {
  display: block;
  position: absolute;
  top: 50%;
  width: 80%;
  left: 50%;
  text-align: center;
  transform: translate(-50%, -50%);
  color: var(--color-dark);
  font-size: 1rem;
  content: "Drop image here or click to select";
}
.file-uploader.dragging {
  border-color: transparent;
  outline: none;
  box-shadow: var(--form-focus-box-shadow);
}
.file-uploader.dragging:after {
  content: "Drop to upload";
}
.file-uploader.error {
  border: 2px dashed var(--color-error);
}
.file-uploader.dropped {
  background-color: transparent;
}
.file-uploader.dropped:after {
  content: "";
}
.file-uploader.dropped .uploader-reset, .file-uploader.dropped .uploader-progress {
  display: block;
}
.file-uploader img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  display: block;
}
.file-uploader input {
  display: none;
}
.file-uploader.square-image img {
  height: 100%;
}
.file-uploader[data-type=file]:after {
  content: "Drop file here or click to select";
}
.file-uploader[data-type=file].successful {
  background-color: var(--color-success);
}
.file-uploader[data-type=file].successful:after {
  content: '"' attr(data-filename) '" uploaded';
}
.file-uploader ~ .input-desc, .file-uploader ~ .form-error {
  margin-top: 0.625rem;
}
.file-uploader ~ .input-desc ~ .form-error {
  margin-top: calc(var(--layout-spacing) * -0.5);
}

.is-invalid .file-uploader {
  border-color: var(--color-error) !important;
}

.uploader-progress {
  display: none;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 4;
  height: 2em;
  border-radius: var(--layout-border-radius);
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  background-color: var(--color-light);
}
.uploader-progress:before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 100%;
  max-width: var(--progress-width, 0%);
  background-color: var(--color-primary);
}
.uploader-progress:after {
  line-height: 2em;
  margin-top: 0.1em;
  display: block;
  content: attr(data-label);
  font-size: 0.8em;
  position: absolute;
  text-align: center;
  top: 0;
  left: 0;
  right: 0;
  color: var(--color-black);
}

.uploader-reset {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 1.25rem;
  width: 2em;
  height: 2em;
  border: none;
  padding: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 4;
  display: none;
}
.uploader-reset i {
  font-size: 1.25em;
  color: var(--color-white);
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 41.75rem) {
  .file-uploader {
    --max-width: 9.375rem;
  }
}
/* =============================================================================
  Tooltips
========================================================================== */
.tooltip {
  margin: 0;
  opacity: 0.75;
  background: none;
  border: none;
  padding: 0;
  transition: opacity 200ms;
  display: inline-flex;
  line-height: inherit;
}
.tooltip i {
  font-size: 0.875em !important;
  width: 0.875em !important;
  height: 0.875em !important;
  vertical-align: middle;
  color: inherit !important;
  display: flex;
  align-items: center;
}
.tooltip i:first-child {
  margin-right: 0.5em;
}
.tooltip i:last-child {
  margin-left: 0.5em;
}

.tooltip:hover {
  opacity: 1;
}

/* =============================================================================
  Searchable Select Box
========================================================================== */
.select-box {
  position: relative;
  display: flex;
  width: 100%;
  flex-direction: column;
  margin: 0 0 var(--form-spacing, 30px);
  border: none !important;
}
.select-box .selected {
  margin: 0 0 var(--form-spacing, 30px);
  padding: var(--form-input-padding, 1rem);
  appearance: none;
  border: 1px solid var(--color-dark);
  border-radius: var(--form-input-radius, 0px);
  background-color: var(--color-white);
  font-family: inherit;
  font-size: 1rem;
  font-weight: var(--typography-body-weight);
  line-height: 1.2;
  color: #000;
  background-image: url("data:image/svg+xml,%3Csvg id='chevron-down' xmlns='http://www.w3.org/2000/svg' width='29.789' height='16' viewBox='0 0 29.789 16'%3E%3Cpath id='chevron-down-2' data-name='chevron-down' d='M37.279,170.819,24.1,183.445a1.913,1.913,0,0,1-1.207.524,1.752,1.752,0,0,1-1.144-.461L8.512,170.819a1.654,1.654,0,1,1,2.289-2.387L22.9,180.024,34.99,168.44a1.651,1.651,0,0,1,2.289,2.379Z' transform='translate(-8.001 -167.969)'/%3E%3C/svg%3E%0A");
  background-origin: content-box;
  background-position: right -1.875em center;
  background-repeat: no-repeat;
  background-size: 30px 16px;
  padding-right: 2.8125em;
  position: relative;
  order: 0;
  margin-bottom: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.select-box .option,
.select-box .selected {
  cursor: pointer;
}
.select-box [type=radio]:checked + .option {
  background: var(--color-light);
}
.select-box .option {
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  padding: var(--form-input-padding, 1rem);
}
.select-box .option:hover, .select-box .option.focussed {
  background: var(--color-light);
}
.select-box label {
  cursor: pointer;
}
.select-box .search-box {
  border-bottom: 1px solid var(--color-medium);
  width: 100%;
  transition: all 0.4s;
  margin-bottom: -1px;
}
.select-box [type=text] {
  padding: var(--form-input-padding, 1rem);
  border-radius: var(--form-input-radius, 0px) var(--form-input-radius, 0px) 0 0;
  z-index: 100;
  pointer-events: none;
  box-shadow: none !important;
  margin-bottom: 0;
}
.select-box [type=text]:focus {
  outline: none;
}
.select-box.is-active .select-box-inner {
  max-height: 31.25rem;
  opacity: 1;
  box-shadow: var(--focus-drop-shadow);
  z-index: 10;
}
.select-box.is-active .options-container + .selected:after {
  transform: rotateX(180deg);
  top: -6px;
}
.select-box.is-active .options-container ~ .search-box {
  opacity: 1;
}
.select-box.is-selected .select-box-reset {
  display: block;
}
.select-box[readonly] {
  pointer-events: none;
}
.select-box[readonly] .select-box-reset {
  display: none;
}
.select-box[readonly] .selected {
  background-color: var(--form-disabled-bg-color);
  cursor: not-allowed;
}
.select-box:has([aria-invalid=true]) {
  position: relative;
  margin-bottom: calc(var(--layout-spacing) * 0.5);
}
.select-box:has([aria-invalid=true]) .selected {
  border-color: var(--color-error) !important;
}
.select-box:has([aria-invalid=true]):after {
  color: var(--color-error);
  font-size: 0.875rem;
  position: relative;
  display: block;
  content: attr(data-pristine-required-message);
  margin-top: 0.3125rem;
}

.select-box-reset {
  position: absolute;
  display: block;
  top: 50%;
  right: var(--form-input-padding, 1rem);
  transform: translateY(-50%);
  width: 1.875em;
  height: 1.875em;
  display: none;
  cursor: pointer;
}
.select-box-reset:after {
  position: absolute;
  content: "";
  right: 0;
  top: 0;
  height: inherit;
  width: inherit;
  background: var(--color-white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cpath id='close-circle' d='M34.18,34.18a4.515,4.515,0,0,1,6.465,0l9.18,9.2,9.355-9.2a4.515,4.515,0,0,1,6.465,0,4.243,4.243,0,0,1,0,6.465l-9.023,9.18,9.023,9.355a4.571,4.571,0,0,1-6.465,6.465l-9.355-9.023-9.18,9.023a4.243,4.243,0,0,1-6.465,0,4.515,4.515,0,0,1,0-6.465l9.2-9.355-9.2-9.18a4.515,4.515,0,0,1,0-6.465ZM100,50A50,50,0,1,1,50,0,50,50,0,0,1,100,50ZM50,9.375A40.625,40.625,0,1,0,90.625,50,40.619,40.619,0,0,0,50,9.375Z'/%3E%3C/svg%3E%0A");
}

.select-box-inner {
  position: absolute;
  top: 100%;
  max-height: 0;
  opacity: 0;
  transition: all 0.4s;
  margin-top: 10px;
  width: 100%;
  overflow: hidden;
}

.options-container {
  background-color: var(--color-white);
  color: var(--color-dark);
  width: 100%;
  border-radius: 0 0 var(--form-input-radius, 0px) var(--form-input-radius, 0px);
  overflow: hidden;
  overflow-y: scroll;
  max-height: 18.75rem;
  order: 1;
}
.options-container [type=radio] {
  height: 0;
  width: 0;
  overflow: hidden;
  position: absolute;
  left: -9999px;
  pointer-events: none;
}
.options-container::-webkit-scrollbar {
  width: 5px;
  background: transparent;
  border-radius: 0.3125rem;
}
.options-container::-webkit-scrollbar-thumb {
  background: var(--color-medium);
  border-radius: 0.3125rem;
}
.options-container:empty:not(.is-loading):not(.is-error):not(.is-no-results):after {
  display: block;
  padding: var(--form-input-padding, 1rem);
  font-size: 0.75rem;
  content: "Options will appear after you begin typing";
}
.options-container.is-loading:after, .options-container.is-error:after, .options-container.is-no-results:after {
  display: block;
  padding: var(--form-input-padding, 1rem);
  font-size: 0.75rem;
  content: "Options loading.  Please wait...";
}
.options-container.is-error:after {
  color: var(--color-error);
  content: "There was an error getting options.  Please refresh and try again";
}
.options-container.is-no-results:after {
  color: var(--color-error);
  content: "There are no results for your search";
}

/* =============================================================================
   Repeatable Template
========================================================================== */
.template-item [data-group-remove], .template-item [data-clone-action], .template-item [data-clone] {
  font-size: 0.875rem;
  color: var(--color-dark);
  white-space: nowrap;
}
.template-item [data-group-remove]:before, .template-item [data-clone-action]:before, .template-item [data-clone]:before {
  position: relative;
  display: inline-block;
  content: "\e80a";
  margin-right: 0.5em;
  font-size: 1rem;
  font-family: "he-icons";
}
.template-item [data-group-remove]:hover:before, .template-item [data-clone-action]:hover:before, .template-item [data-clone]:hover:before {
  color: var(--color-primary);
}
.template-item [data-group-remove]:before {
  content: "\e84e";
}
.template-item [data-group-remove]:hover:before {
  color: var(--color-error);
}
.template-item:only-of-type .template-title-wrapper > [data-group-remove] {
  display: none;
}

.template-title-wrapper {
  border-bottom: 1px solid var(--color-medium);
  padding-bottom: 0.5em;
  margin-bottom: 0.5em;
}

.template-item-actions {
  float: right;
  font-size: 0.875rem;
  display: flex;
  flex-flow: row wrap;
  margin-left: -1rem;
}
.template-item-actions > * {
  width: auto;
  margin-left: 1rem;
  margin-bottom: 1rem;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 64rem) {
  .template-item [data-group-remove]:after, .template-item [data-clone-action]:after, .template-item [data-clone]:after {
    position: relative;
    display: inline-block;
    font-family: var(--typography-body-font);
    content: " CLONE";
  }
  .template-item [data-group-remove]:after {
    content: " REMOVE";
  }
}
/* =============================================================================
  CSS Overrides for Mailer Lite
========================================================================== */
.panel.signup .inner {
  width: 100%;
}

#content .ml-subscribe-form .subscribe-form {
  padding: 0 !important;
  width: 100% !important;
  background-color: transparent !important;
  border: none !important;
  display: flex;
  flex-flow: column;
  align-items: center;
}
#content .ml-subscribe-form .subscribe-form input, #content .ml-subscribe-form .subscribe-form select {
  margin-bottom: 0 !important;
  padding: var(--form-input-padding, 1rem) !important;
  border: 1px solid var(--form-input-border-color) !important;
  border-radius: var(--form-input-radius, 0px) !important;
  background-color: var(--color-white) !important;
  font-family: inherit;
  font-size: 1rem !important;
  font-weight: var(--typography-body-weight) !important;
}
#content .ml-subscribe-form .subscribe-form [type=submit] {
  background-color: var(--color-primary) !important;
  color: var(--color-white) !important;
  border-radius: var(--layout-border-radius) !important;
  padding-left: 1em !important;
  padding-right: 1em !important;
}
#content .form-section:has(h4) {
  display: none;
}
#content .form-section:has(.form-group) {
  display: grid;
  gap: var(--layout-grid-gap);
}
#content .ml-block-success .form-section {
  display: block;
  text-align: center;
}
#content .ml-block-success .form-section h4 {
  display: none;
}
#content .ml-block-success .form-section p {
  font-size: var(--typography-lead-size);
  line-height: 1.3;
  text-align: center;
}

@media (min-width: 41.75rem) {
  #content .form-section:has(.form-group) {
    grid-template-columns: 1fr 1fr;
  }
  #content .ml-subscribe-form .subscribe-form [type=submit] {
    width: auto !important;
  }
}
@media (min-width: 64rem) {
  #content .form-section:has(.form-group) {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}
form .ql-wrapper {
  margin-bottom: var(--form-spacing, 30px);
}
form .ql-wrapper:focus-within {
  border-color: transparent;
  outline: none;
  box-shadow: var(--form-focus-box-shadow);
}
form .ql-container {
  min-height: 200px;
  max-height: 300px;
  overflow-y: auto;
}
form .ql-editor {
  font-family: inherit;
  font-size: 1rem;
  font-weight: var(--typography-body-weight);
  line-height: 1.2;
}
form .ql-toolbar, form .quill {
  background-color: var(--color-white, #fff);
}
form .ql-counter {
  font-size: 0.875em;
  text-align: right;
  border: 1px solid #ccc;
  border-top: none;
  padding-right: 10px;
}
form .ql-counter.max {
  color: var(--color-error, #ff0000);
}

/* =============================================================================
  Visiblity
========================================================================== */
.hide {
  display: none !important;
}

.show-for-sr {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

@media screen and (min-width: 41.75rem) {
  .is-hide-sm {
    display: none !important;
  }
}
@media screen and (min-width: 64rem) {
  .is-hide-md {
    display: none !important;
  }
}
@media screen and (min-width: 75.625rem) {
  .is-hide-lg {
    display: none !important;
  }
}
@media screen and (min-width: 106.3125rem) {
  .is-hide-xl {
    display: none !important;
  }
}
@media screen and (max-width: 41.6875rem) {
  .is-hide-xs-only {
    display: none !important;
  }
  .is-show-sm, .is-show-md, .is-show-lg, .is-show-xl {
    display: none !important;
  }
}
@media screen and (min-width: 41.75rem) and (max-width: 63.9375rem) {
  .is-hide-sm-only {
    display: none !important;
  }
  .is-show-md, .is-show-lg, .is-show-xl {
    display: none !important;
  }
}
@media screen and (min-width: 64rem) and (max-width: 75.5625rem) {
  .is-hide-md-only {
    display: none !important;
  }
  .is-show-lg, .is-show-xl {
    display: none !important;
  }
}
@media screen and (min-width: 75.625rem) and (max-width: 106.25rem) {
  .is-hide-lg-only {
    display: none !important;
  }
  .is-show-xl {
    display: none !important;
  }
}
@media screen and (min-width: 106.3125rem) {
  .is-hide-xl-only {
    display: none !important;
  }
}
/* =============================================================================
  Device type
========================================================================== */
.is-show-touch, .is-show-mouse, .is-show-touch-mouse {
  display: none;
}

/* mobile device */
@media (pointer: coarse) {
  .is-show-touch {
    display: inherit;
  }
  .is-hide-touch {
    display: inherit !important;
  }
}
/* desktop */
@media (pointer: fine), (pointer: none) {
  .is-show-mouse {
    display: inherit;
  }
  .is-hide-mouse {
    display: none !important;
  }
}
/* touch desktop */
@media (pointer: fine) and (any-pointer: coarse) {
  .is-show-touch-mouse {
    display: inherit;
  }
  .is-hide-touch-mouse {
    display: none !important;
  }
}
@font-face {
  font-family: "he-icons";
  src: url("../font/he-icons.eot?10800767");
  src: url("../font/he-icons.eot?10800767#iefix") format("embedded-opentype"), url("../font/he-icons.woff2?10800767") format("woff2"), url("../font/he-icons.woff?10800767") format("woff"), url("../font/he-icons.ttf?10800767") format("truetype"), url("../font/he-icons.svg?10800767#he-icons") format("svg");
  font-weight: normal;
  font-style: normal;
}
/* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */
/* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */
/*
@media screen and (-webkit-min-device-pixel-ratio:0) {
  @font-face {
    font-family: 'he-icons';
    src: url('../font/he-icons.svg?10800767#he-icons') format('svg');
  }
}
*/
[class^=icon-]:before, [class*=" icon-"]:before {
  font-family: "he-icons";
  font-style: normal;
  font-weight: normal;
  speak: never;
  display: inline-block;
  text-decoration: inherit;
  width: 1em;
  margin-right: 0.2em;
  text-align: center;
  /* opacity: .8; */
  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;
  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;
  /* Animation center compensation - margins should be symmetric */
  /* remove if not needed */
  margin-left: 0.2em;
  /* you can be more comfortable with increased icons size */
  /* font-size: 120%; */
  /* Font smoothing. That was taken from TWBS */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
}

.icon-eye:before {
  transform: scale(0.8);
  transform-origin: left;
  margin-left: 0;
}

.icon-cart:before {
  content: "\e800";
} /* '' */
.icon-close-circle:before {
  content: "\e801";
} /* '' */
.icon-location-plus:before {
  content: "\e802";
} /* '' */
.icon-marker:before {
  content: "\e803";
} /* '' */
.icon-calendar:before {
  content: "\e804";
} /* '' */
.icon-search:before {
  content: "\e805";
} /* '' */
.icon-chevron-down:before {
  content: "\e806";
} /* '' */
.icon-user:before {
  content: "\e807";
} /* '' */
.icon-alert:before {
  content: "\e808";
} /* '' */
.icon-email:before {
  content: "\e809";
} /* '' */
.icon-copy:before {
  content: "\e80a";
} /* '' */
.icon-filter:before {
  content: "\e80b";
} /* '' */
.icon-phone:before {
  content: "\e80c";
} /* '' */
.icon-quote:before {
  content: "\e80d";
} /* '' */
.icon-external:before {
  content: "\e80e";
} /* '' */
.icon-home:before {
  content: "\e80f";
} /* '' */
.icon-exit:before {
  content: "\e810";
} /* '' */
.icon-manage:before {
  content: "\e811";
} /* '' */
.icon-help:before {
  content: "\e812";
} /* '' */
.icon-caret:before {
  content: "\e813";
} /* '' */
.icon-calendar-add:before {
  content: "\e814";
} /* '' */
.icon-cart-add:before {
  content: "\e815";
} /* '' */
.icon-file-add:before {
  content: "\e816";
} /* '' */
.icon-twitter:before {
  content: "\e817";
} /* '' */
.icon-vimeo:before {
  content: "\e818";
} /* '' */
.icon-youtube:before {
  content: "\e819";
} /* '' */
.icon-facebook:before {
  content: "\e81a";
} /* '' */
.icon-info:before {
  content: "\e81b";
} /* '' */
.icon-instagram:before {
  content: "\e81c";
} /* '' */
.icon-linkedin:before {
  content: "\e81d";
} /* '' */
.icon-pinterest:before {
  content: "\e81e";
} /* '' */
.icon-tiktok:before {
  content: "\e81f";
} /* '' */
.icon-download:before {
  content: "\e820";
} /* '' */
.icon-users:before {
  content: "\e824";
} /* '' */
.icon-tick:before {
  content: "\e825";
} /* '' */
.icon-share:before {
  content: "\e826";
} /* '' */
.icon-trash:before {
  content: "\e84e";
} /* '' */
.icon-edit:before {
  content: "\e84f";
} /* '' */
.icon-eye:before {
  content: "\e850";
} /* '' */
/* =============================================================================
  Layout
========================================================================== */
html {
  scroll-behavior: smooth;
}

@media (prefers-reduced-motion) {
  html {
    scroll-behavior: auto;
  }
}
body {
  margin: 0;
  overflow: auto;
  /*opacity: .75;
  transition: opacity 50ms linear;
  &.is-loaded {
    opacity: 1;
  }*/
}

.container {
  width: 100%;
  padding-right: var(--layout-container-padding);
  padding-left: var(--layout-container-padding);
  max-width: calc(var(--layout-container-max-width) + var(--layout-container-padding) + var(--layout-container-padding));
  margin-left: var(--layout-container-margin);
  margin-right: var(--layout-container-margin);
}

.container-inline {
  container-type: inline-size;
}

[id] {
  scroll-margin: var(--layout-anchor-offset, 2rem);
}

.img-overlay {
  position: relative;
}
.img-overlay:after {
  display: block;
  content: "";
  position: absolute;
  background-color: var(--color-black);
  opacity: 0.5;
  top: 0;
  width: 100%;
  bottom: 0;
  z-index: 2;
}

.bt {
  border-top: 1px solid var(--color-secondary);
}

.scrollh.scrollable {
  position: relative;
}
.scrollh.scrollable:after {
  position: absolute;
  display: block;
  top: 1.25rem;
  right: 0;
  height: calc(100% - 20px);
  content: "SCROLL HORIZONTALLY";
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: translateX(calc(100% + 5px));
  color: var(--color-medium);
  text-align: left;
  font-size: 0.875rem;
}
.scrollh.scrollable .inner {
  display: flex;
  flex-wrap: wrap;
  overflow-x: auto;
}

.scrollv.scrollable {
  position: relative;
}
.scrollv.scrollable:after {
  position: absolute;
  display: block;
  top: 50%;
  right: 0;
  content: "SCROLLABLE";
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: translate(calc(100% + 5px), -50%);
}
.scrollv.scrollable .inner {
  overflow-y: auto;
}

.item {
  display: inline-flex;
  justify-content: center;
  align-items: center;
}
.item.has-icon > [class^=icon-], .item.has-icon > [class*=icon-] {
  height: 1.25em;
  align-items: center;
  display: inline-flex;
  justify-content: center;
  font-size: 1.25em;
  color: var(--color-secondary);
}
.item.has-icon > [class^=icon-]:first-child:not(:last-child), .item.has-icon > [class*=icon-]:first-child:not(:last-child) {
  margin-right: 0.625rem;
}
.item.has-icon > [class^=icon-]:last-child:not(:first-child), .item.has-icon > [class*=icon-]:last-child:not(:first-child) {
  margin-left: 0.625rem;
}
.item:not(:last-child) {
  margin-right: 0.625rem;
}

.items.is-flex {
  flex-flow: row wrap;
  gap: 1rem;
}
.items.vertical > .item {
  display: flex;
  justify-content: flex-start;
}
.items.vertical > .item:not(:first-child) {
  margin-top: 6px;
}

.thumb-image-wrapper {
  border-radius: var(--layout-border-radius);
  overflow: hidden;
  background-color: var(--color-light);
}

/* =============================================================================
  Loader
========================================================================== */
#loader-wrapper {
  display: none;
  position: fixed;
  z-index: 9999;
  background-color: rgba(0, 0, 0, 0.4);
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  align-items: center;
  justify-content: center;
}

.inpage-loader.is-loading {
  min-height: 18.75rem;
  align-items: center;
  justify-content: center;
  display: flex !important;
}
.inpage-loader.is-loading > *:not(.loader) {
  display: none;
}
.inpage-loader.is-loading .loader {
  display: block;
  animation: loadingspin 1s linear infinite !important;
}

.loader {
  display: none;
  pointer-events: none;
  width: 6.25rem;
  height: 6.25rem;
  border: 0.6em solid transparent;
  border-color: var(--color-light);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  transform-origin: center;
}

body.is-loading #loader-wrapper {
  display: flex;
  flex-direction: column;
}
body.is-loading #loader-wrapper .loader {
  display: block;
  position: relative;
  animation: loadingspin 1s linear infinite !important;
}
body.is-loading #loader-wrapper:after {
  position: relative;
  bottom: 0;
  display: block;
  text-align: center;
  content: attr(data-label);
  font-size: 1.5rem;
  margin-top: 1rem;
  color: var(--color-white);
}

@keyframes loadingspin {
  0% {
    transform: rotate(0deg);
  }
  25% {
    transform: rotate(90deg) scale(1.025);
  }
  50% {
    transform: rotate(180deg) scale(1.05);
  }
  75% {
    transform: rotate(270deg) scale(1.025);
  }
  99% {
    transform: rotate(360deg);
  }
}
/* =============================================================================
  Ordering
========================================================================== */
@media (min-width: 64rem) {
  .md-order-1 {
    order: 1;
  }
  .md-order-2 {
    order: 2;
  }
}
@media (min-width: 75.625rem) {
  .lg-order-1 {
    order: 1;
  }
  .lg-order-2 {
    order: 2;
  }
}
/* =============================================================================
  Sticky
========================================================================== */
.is-sticky {
  position: sticky;
  z-index: 30;
}

/* =============================================================================
  Advert
========================================================================== */
.advert {
  display: block;
  position: relative;
}
.advert picture img {
  width: 100%;
}
.advert .hint {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  background-color: var(--color-dark);
  padding: 3px 5px;
  font-size: 0.625rem;
}
.advert .hint a:link, .advert .hint a:visited {
  color: var(--color-light) !important;
}

/* =============================================================================
  Schools List
========================================================================== */
.schools-list {
  container-type: inline-size;
}

.school-columns {
  display: grid;
  gap: var(--layout-grid-gap);
  row-gap: calc(var(--layout-grid-gap) / 2);
  grid-template-columns: 1fr;
}

.school {
  font-size: var(--typography-lead-size);
}

@container (min-width: 500px) {
  .school-columns {
    grid-template-columns: 1fr 1fr;
  }
}
@container (min-width: 1000px) {
  .school-columns {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@container (min-width: 1600px) {
  .school-columns {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}
/* =============================================================================
  Credits
========================================================================== */
.indigo-credits {
  display: block;
}
.indigo-credits img {
  display: inline-block;
}

/* =============================================================================
  Typography
========================================================================== */
/* =============================================================================
  Main
========================================================================== */
body {
  font-family: var(--typography-body-font);
  font-weight: var(--typography-body-weight);
  line-height: var(--typography-body-line-height);
  font-size: var(--typography-body-size);
  color: var(--typography-body-colour);
}

/* =============================================================================
  Headers
========================================================================== */
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
  font-family: var(--typography-header-font);
  font-weight: var(--typography-header-weight);
  line-height: var(--typography-header-line-height);
  font-size: var(--typography-h1-size);
  margin-bottom: var(--typography-header-margin-bottom);
}

h1, .h1, h2, .h2, h3, .h3 {
  text-transform: uppercase;
}

h1, .h1 {
  font-size: var(--typography-h1-size);
}

h2, .h2 {
  font-size: var(--typography-h2-size);
}

h3, .h3 {
  font-size: var(--typography-h3-size);
}

h4, .h4 {
  font-size: var(--typography-h4-size);
}

h5, .h5 {
  font-size: var(--typography-h5-size);
}

h6, .h6 {
  font-size: var(--typography-h6-size);
}

/* =============================================================================
  Body Copy
========================================================================== */
.lead {
  font-size: var(--typography-lead-size);
  line-height: 1.3;
}
.lead p {
  font-size: var(--typography-lead-size);
  line-height: 1.3;
}
.lead:not(:last-child) {
  margin-bottom: var(--typography-paragraph-margin);
}

.small {
  font-size: 0.875em;
}

.large {
  font-size: 1.5em !important;
}

.overline {
  font-size: 1.375rem;
  text-transform: uppercase;
  letter-spacing: 1.36;
  line-height: 1.36em;
}

.uc {
  text-transform: uppercase;
}

.sc {
  text-transform: none !important;
}

strong, .strong {
  font-weight: var(--typography-bold-weight);
}

.hr-text {
  display: flex;
  align-items: center;
  justify-content: left;
}
.hr-text:after {
  background: currentColor;
  height: 2px;
  flex: 1;
  margin-left: 1em;
  content: "";
}

.break-word {
  overflow-wrap: break-word;
  word-wrap: break-word;
  word-break: break-all;
  word-break: break-word;
  hyphens: auto;
}

blockquote {
  background-color: var(--color-light);
  padding: 1rem;
  font-size: 1.125rem;
  font-style: italic;
  margin-bottom: var(--layout-spacing);
}

/* =============================================================================
  Links
========================================================================== */
a, a:visited {
  transition: color 500ms ease;
  text-decoration: none;
}
a:link, a:visited:link {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.3);
}
a.has-icon [class^=icon-], a.has-icon [class*=icon-], a:visited.has-icon [class^=icon-], a:visited.has-icon [class*=icon-] {
  align-items: center;
  display: inline-flex;
  justify-content: center;
}
a.has-icon [class^=icon-]:first-child:not(:last-child), a.has-icon [class*=icon-]:first-child:not(:last-child), a:visited.has-icon [class^=icon-]:first-child:not(:last-child), a:visited.has-icon [class*=icon-]:first-child:not(:last-child) {
  margin-right: 0.5em;
}
a.has-icon [class^=icon-]:last-child:not(:first-child), a.has-icon [class*=icon-]:last-child:not(:first-child), a:visited.has-icon [class^=icon-]:last-child:not(:first-child), a:visited.has-icon [class*=icon-]:last-child:not(:first-child) {
  margin-left: 0.5em;
}

[data-href] {
  cursor: pointer;
}

[data-copy] {
  position: relative;
}
[data-copy]:after {
  display: block;
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 6px;
  font-size: 0.75rem;
  content: "Copied!";
  transform: scale(0);
  transform-origin: center;
  transition: transform 250ms ease-out;
}
[data-copy].is-copied:after {
  transform: scale(1);
}

/* =============================================================================
  Text Alignment
========================================================================== */
.text-right {
  text-align: right;
}

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

/* =============================================================================
Lists
========================================================================== */
ul.is-line {
  margin-left: 0;
  list-style-type: none;
}
ul.is-line li {
  margin-bottom: 1rem;
}
ul.is-line li:before {
  display: inline-block;
  content: "–";
  position: relative;
  font-size: 1em;
  color: var(--color-primary);
  margin-right: 0.75em;
  font-weight: var(--typography-bold-weight);
}
ul.is-line li a {
  padding: 0;
}

/* =============================================================================
  Content Styles
========================================================================== */
.content p:not(:last-child), .mce-content-body p:not(:last-child) {
  margin-bottom: var(--typography-paragraph-margin);
}
.content a:not(.button), .mce-content-body a:not(.button) {
  color: var(--color-black);
}
.content a:not(.button):visited, .mce-content-body a:not(.button):visited {
  color: var(--color-black);
}
.content a:not([class]), .mce-content-body a:not([class]) {
  position: relative;
  background-image: linear-gradient(to right, currentColor 75%, transparent 75%);
  background-position: 0 1.2em;
  background-repeat: repeat-x;
  transition: color 250ms ease, background-size 100ms linear;
  background-size: 12px 1px;
  line-height: 1.3em;
}
.content a:not([class]):hover, .mce-content-body a:not([class]):hover {
  background-size: 1px 1px;
}
.content sup, .content sub, .mce-content-body sup, .mce-content-body sub {
  font-size: 75%;
}
.content ul, .mce-content-body ul {
  list-style: disc outside;
  margin-left: 2em;
  margin-top: 1em;
}
.content ul:not(:last-child), .mce-content-body ul:not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}
.content ul li:not(:last-child), .mce-content-body ul li:not(:last-child) {
  margin-bottom: 0.5em;
}
.content ol:not([type]), .mce-content-body ol:not([type]) {
  list-style-position: outside;
  margin-left: 2em;
  margin-top: 1em;
}
.content ol:not([type]) li:not(:last-child), .mce-content-body ol:not([type]) li:not(:last-child) {
  margin-bottom: 0.5em;
}
.content ol:not([type]):not([type]), .mce-content-body ol:not([type]):not([type]) {
  list-style-type: decimal;
}
.content ol:not([type]):not(:last-child), .mce-content-body ol:not([type]):not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}
.content dl dd, .mce-content-body dl dd {
  margin-left: 2rem;
}
.content dl:not(:last-child), .mce-content-body dl:not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}
.content blockquote, .mce-content-body blockquote {
  background-color: var(--color-light);
  border-left: 5px solid var(--color-medium);
  padding: 1.25em 1.5em;
  font-size: 1.25em;
}
.content blockquote:not(:last-child), .mce-content-body blockquote:not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}
.content code, .content pre, .mce-content-body code, .mce-content-body pre {
  -moz-osx-font-smoothing: auto;
  -webkit-font-smoothing: auto;
  font-family: monospace;
  overflow-x: auto;
  padding: 1.25em 1.5em;
  white-space: pre;
  word-wrap: normal;
  background-color: var(--color-light);
  font-size: 1em;
}
.content code:not(:last-child), .content pre:not(:last-child), .mce-content-body code:not(:last-child), .mce-content-body pre:not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}
.content figure, .mce-content-body figure {
  text-align: center;
  background-color: var(--color-dark);
}
.content figure a, .mce-content-body figure a {
  display: block;
  line-height: 1 !important;
  background: transparent !important;
  margin-bottom: -2px;
}
.content figure img, .mce-content-body figure img {
  margin: 0;
  display: inline-block;
}
.content figure figcaption, .mce-content-body figure figcaption {
  padding: 0.375rem 0.375rem 0.625rem 0.375rem;
  color: var(--color-white);
  font-style: italic;
}
.content figure:not(:last-child), .mce-content-body figure:not(:last-child) {
  margin-bottom: var(--element-block-spacing);
}
.content img, .mce-content-body img {
  max-width: 100%;
  height: auto;
  margin: 1.5em 0;
}
.content p:first-child > img, .mce-content-body p:first-child > img {
  margin-top: 0;
}
.content .alignleft, .content img.alignleft, .mce-content-body .alignleft, .mce-content-body img.alignleft {
  margin-right: 1.5em;
  display: inline;
  float: left;
}
.content .alignleft:after, .content img.alignleft:after, .mce-content-body .alignleft:after, .mce-content-body img.alignleft:after {
  content: "";
  display: table;
  clear: both;
}
.content .alignright, .content img.alignright, .mce-content-body .alignright, .mce-content-body img.alignright {
  margin-left: 1.5em;
  display: inline;
  float: right;
}
.content .alignright:after, .content img.alignright:after, .mce-content-body .alignright:after, .mce-content-body img.alignright:after {
  content: "";
  display: table;
  clear: both;
}
.content .aligncenter, .content img.aligncenter, .mce-content-body .aligncenter, .mce-content-body img.aligncenter {
  margin-right: auto;
  margin-left: auto;
  display: block;
  clear: both;
}
.content video, .content object, .mce-content-body video, .mce-content-body object {
  max-width: 100%;
  height: auto;
}

@media (min-width: 75.625rem) {
  .alignleft, img.alignleft, .alignright, img.alignright {
    max-width: 50%;
  }
}
/* =============================================================================
Forms Related Stuff
========================================================================== */
form.disabled [type=color], form.disabled [type=date], form.disabled [type=datetime-local], form.disabled [type=datetime], form.disabled [type=email], form.disabled [type=month], form.disabled [type=number], form.disabled [type=password], form.disabled [type=search], form.disabled [type=tel], form.disabled [type=text], form.disabled [type=time], form.disabled [type=url], form.disabled [type=week], form.disabled [type=submit], form.disabled textarea, form.disabled select {
  pointer-events: none;
  opacity: 0.75;
  background-color: var(--form-disabled-bg-color);
  cursor: not-allowed;
}
form.processing button, form.processing [type=submit] {
  pointer-events: none;
  opacity: 0.5;
  cursor: not-allowed;
}

.response-success, .response-error {
  display: none;
}
.response-success > *, .response-error > * {
  margin-top: calc(var(--layout-spacing) * 0.5);
}
.response-success.is-active, .response-error.is-active {
  display: block !important;
}

label {
  display: block;
  margin: 0;
  font-size: 1rem;
  font-weight: var(--typography-body-weight);
  line-height: 1.8;
  color: var(--color-black);
}

.label-spacing {
  position: relative;
}
.label-spacing:before {
  position: relative;
  display: block;
  font-size: 1rem;
  font-weight: var(--typography-body-weight);
  line-height: 1.8;
  content: "spacer";
  opacity: 0;
}

[type=color], [type=date], [type=datetime-local], [type=datetime], [type=email], [type=month], [type=number], [type=password], [type=search], [type=tel], [type=text], [type=time], [type=url], [type=week], textarea, select {
  display: block;
  box-sizing: border-box;
  width: 100%;
  margin: 0 0 var(--form-spacing, 30px);
  padding: var(--form-input-padding, 1rem);
  border: 1px solid var(--form-input-border-color);
  border-radius: var(--form-input-radius, 0px);
  background-color: var(--color-white);
  font-family: inherit;
  font-size: 1rem;
  font-weight: var(--typography-body-weight);
  line-height: 1.2;
  color: #000;
  appearance: none;
}
[type=color][disabled], [type=color][readonly], [type=date][disabled], [type=date][readonly], [type=datetime-local][disabled], [type=datetime-local][readonly], [type=datetime][disabled], [type=datetime][readonly], [type=email][disabled], [type=email][readonly], [type=month][disabled], [type=month][readonly], [type=number][disabled], [type=number][readonly], [type=password][disabled], [type=password][readonly], [type=search][disabled], [type=search][readonly], [type=tel][disabled], [type=tel][readonly], [type=text][disabled], [type=text][readonly], [type=time][disabled], [type=time][readonly], [type=url][disabled], [type=url][readonly], [type=week][disabled], [type=week][readonly], textarea[disabled], textarea[readonly], select[disabled], select[readonly] {
  opacity: 0.75;
  background-color: var(--form-disabled-bg-color);
  cursor: not-allowed;
}

select[readonly] {
  pointer-events: none;
}

.js-disabled-option {
  display: none;
}

select {
  margin: 0 0 var(--form-spacing, 30px);
  padding: var(--form-input-padding, 1rem);
  appearance: none;
  border: 1px solid var(--color-dark);
  border-radius: var(--form-input-radius, 0px);
  background-color: var(--color-white);
  font-family: inherit;
  font-size: 1rem;
  font-weight: var(--typography-body-weight);
  line-height: 1.2;
  color: #000;
  background-image: url("data:image/svg+xml,%3Csvg id='chevron-down' xmlns='http://www.w3.org/2000/svg' width='29.789' height='16' viewBox='0 0 29.789 16'%3E%3Cpath id='chevron-down-2' data-name='chevron-down' d='M37.279,170.819,24.1,183.445a1.913,1.913,0,0,1-1.207.524,1.752,1.752,0,0,1-1.144-.461L8.512,170.819a1.654,1.654,0,1,1,2.289-2.387L22.9,180.024,34.99,168.44a1.651,1.651,0,0,1,2.289,2.379Z' transform='translate(-8.001 -167.969)'/%3E%3C/svg%3E%0A");
  background-origin: content-box;
  background-position: right -1.875em center;
  background-repeat: no-repeat;
  background-size: 30px 16px;
  padding-right: 2.8125em;
}

.form-spacing {
  margin-bottom: var(--form-spacing, 30px);
}

.input-desc {
  display: block;
  font-size: 0.75em;
  color: var(--color-dark);
  margin-top: calc(var(--layout-spacing) * -0.5);
  margin-bottom: calc(var(--layout-spacing) * 0.5);
}
.input-desc a:not(.button) {
  color: var(--color-accent);
}
.input-desc + .form-error {
  margin-top: 0;
}

/* =============================================================================
  Validation
========================================================================== */
.form-error {
  display: none;
  margin-top: calc(var(--layout-spacing) * -0.5);
  color: var(--color-error);
  font-size: 0.875rem;
}

[aria-invalid=true] {
  border-color: var(--color-error) !important;
}
[aria-invalid=true] ~ .form-error {
  display: block;
  margin-bottom: calc(var(--layout-spacing) * 0.5);
}
[aria-invalid=true] ~ .input-desc {
  margin-bottom: 0;
}

.is-invalid {
  border-color: var(--color-error) !important;
}
.is-invalid > .form-error {
  display: block;
  margin-bottom: calc(var(--layout-spacing) * 0.5);
}
.is-invalid > .input-group ~ .form-error {
  margin-top: calc(var(--form-spacing, 30px) * 0.5);
}

/* =============================================================================
  Other
========================================================================== */
.forgot-password-toggle {
  cursor: pointer;
}
.forgot-password-toggle:hover {
  opacity: 0.8;
}

.field-icon-wrapper {
  position: relative;
  display: block;
}
.field-icon-wrapper [class^=icon-], .field-icon-wrapper [class*=icon-] {
  position: absolute;
  top: calc(var(--form-input-padding, 1rem) / 2 + 0.067em);
  font-size: 1.875rem;
  align-items: center;
  display: inline-flex;
  justify-content: center;
  color: var(--color-secondary);
}
.field-icon-wrapper [class^=icon-]:first-child:not(:last-child), .field-icon-wrapper [class*=icon-]:first-child:not(:last-child) {
  left: var(--form-input-padding, 1rem);
}
.field-icon-wrapper [class^=icon-]:last-child:not(:first-child), .field-icon-wrapper [class*=icon-]:last-child:not(:first-child) {
  right: var(--form-input-padding, 1rem);
}
.field-icon-wrapper input:first-child:not(:last-child) {
  padding-right: 3.5em;
}
.field-icon-wrapper input:last-child:not(:first-child) {
  padding-left: 3.5em;
}

.search-submit {
  cursor: pointer;
  transform-origin: center;
}
.search-submit:hover {
  transform: scale(1.025);
}

/* =============================================================================
  Fieldset
========================================================================== */
fieldset {
  position: relative;
  padding: var(--form-spacing, 30px);
  border-radius: var(--form-input-radius, 0px);
  border: 1px solid var(--color-medium);
  box-shadow: var(--form-box-shadow);
}
fieldset:not(:last-child) {
  margin-bottom: calc(var(--form-spacing, 30px) + 16px);
}
fieldset:has(legend) {
  margin-top: 1.4375rem;
}
fieldset legend {
  position: absolute;
  top: 0;
  text-transform: uppercase;
  font-size: 1.125rem;
  background-color: var(--color-light);
  padding: 0.3125rem 0.625rem;
  border-radius: var(--form-input-radius, 0px);
  border-bottom-left-radius: 0;
  transform: translateY(-50%);
  color: var(--color-dark);
}

/* =============================================================================
  Radio
========================================================================== */
/* =============================================================================
Radio buttons
========================================================================== */
[type=radio].styled {
  height: 0;
  width: 0;
  overflow: hidden;
  position: absolute;
  left: -9999px;
}
[type=radio].styled + label {
  position: relative;
  display: inline-block;
  line-height: 2em;
  font-size: 1rem;
  margin: 0 1.25em 1em 0;
  padding-left: 2.75em;
}
[type=radio].styled + label:before {
  left: 0;
  top: 0;
  position: absolute;
  display: inline-block;
  float: left;
  content: "";
  background-color: var(--color-light);
  width: 2em;
  height: 2em;
  border-radius: 50%;
  border: 0.3em solid var(--color-light);
  transition: background-color 250ms ease;
}
[type=radio].styled + label span {
  line-height: 1;
  display: block;
  font-size: 0.75em;
  margin-top: -0.2em;
}
[type=radio].styled:focus + label:before {
  box-shadow: var(--form-focus-box-shadow);
}
[type=radio].styled:hover:not(:checked) + label:before {
  background-color: var(--color-medium);
}
[type=radio].styled:checked + label:before {
  background-color: var(--color-primary);
}
[type=radio].styled[disabled] + label {
  opacity: 0.6;
  cursor: not-allowed;
}
[type=radio].styled[disabled] + label span {
  color: var(--color-error);
}
[type=radio].white-radio + label:before {
  background-color: var(--color-white);
  border-color: var(--color-white);
}

/* =============================================================================
Checkbox
========================================================================== */
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch) {
  position: absolute;
  opacity: 0;
  z-index: -1;
  /*&[aria-invalid="true"] {
    + label {
      &:before {
        border:1px solid var(--color-error) !important;
      }
      .form-error {
        margin-top: rem-calc(5);
      }
    }
  }*/
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch) + label {
  margin-left: 0;
  position: relative;
  display: inline-block;
  padding: 0.65em 0 0 3.5em;
  min-height: 2.57em;
  line-height: 1.2;
  font-size: 1rem;
  margin-bottom: var(--form-spacing, 30px);
  cursor: pointer;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch) + label:before, input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch) + label:after {
  position: absolute;
  display: block;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch) + label:before {
  top: 0;
  left: 0;
  width: 2.57em;
  height: 2.57em;
  content: " ";
  border-radius: var(--form-input-radius, 0px);
  background-color: var(--color-light);
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch) + label:after {
  top: 0.35em;
  left: 0.875em;
  width: 0.75em;
  height: 1.5em;
  content: "";
  border: solid var(--color-secondary);
  border-width: 0 0.25em 0.25em 0;
  /*line-height: 1.5;
  text-align: center;*/
  opacity: 0;
  transform: rotate(45deg);
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch):checked + label:after {
  opacity: 1;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch):focus + label:before {
  box-shadow: var(--form-focus-box-shadow);
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch)[disabled] {
  opacity: 0.5;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch)[disabled] + label {
  text-decoration: line-through;
  opacity: 0.5;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch).label-left + label {
  margin-left: 0;
  padding: 0 2.5em 0 0;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch).label-left + label:before {
  left: auto;
  right: 0;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch).label-left + label:after {
  left: auto;
  right: 0.5em;
}
input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox):not(.switch).checkbox-white + label:before {
  background-color: var(--color-white);
}
input[type=checkbox].radio-style {
  display: none;
}
input[type=checkbox].radio-style + label {
  margin-left: 0;
}
input[type=checkbox].radio-style + label span {
  display: inline-block;
  border-radius: 50%;
  width: 1.0625rem;
  height: 1.0625rem;
  border: 3px solid var(--color-light);
  background-color: var(--color-light);
  margin-right: 0.5rem;
  float: left;
}
input[type=checkbox].radio-style:checked + label span {
  background-color: var(--color-medium);
}
input[type=checkbox].simple {
  border: 1px solid var(--form-input-border-color);
  border-radius: var(--form-input-radius, 0px);
  background: var(--color-light);
  color: var(--color-dark);
  clear: none;
  cursor: pointer;
  display: inline-block;
  line-height: 0;
  margin: -0.25rem 0.25rem 0 0;
  outline: 0;
  padding: 0 !important;
  text-align: center;
  vertical-align: middle;
  height: 2rem;
  width: 2rem;
  min-width: 2rem;
  -webkit-appearance: none;
  transition: 0.05s border-color ease-in-out;
}
input[type=checkbox].simple.small {
  height: 1.25rem;
  width: 1.25rem;
  min-width: 1.25rem;
}
input[type=checkbox].simple.border-dark {
  border-color: var(--color-dark);
}
input[type=checkbox].simple[disabled] {
  opacity: 0.5;
}
input[type=checkbox].simple:checked {
  display: inline-block;
  width: 1rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 46 46'%3E%3Crect id='Rectangle_31' data-name='Rectangle 31' width='46' height='46' rx='10' fill='%23e6e6e6' opacity='0'/%3E%3Cpath id='check' d='M49.889,80.145,35.4,94.639,30.07,89.313a.661.661,0,0,0-.935,0l-1.558,1.558a.661.661,0,0,0,0,.935l7.351,7.351a.661.661,0,0,0,.935,0L52.382,82.639a.661.661,0,0,0,0-.935l-1.558-1.558A.661.661,0,0,0,49.889,80.145Z' transform='translate(-17.383 -66.951)' fill='%231e1e1e'/%3E%3C/svg%3E%0A");
}
input[type=checkbox].simple + label {
  display: inline-block;
  margin-left: 0.3em;
}
input[type=checkbox].simple + label + .form-error {
  margin-top: 1rem;
}

.field-wrapper:not(.is-valid) input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox)[aria-invalid=true] + label:before {
  border: 1px solid var(--color-error) !important;
}
.field-wrapper:not(.is-valid) input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox)[aria-invalid=true] + label .form-error {
  margin-top: 0.3125rem;
}

/* =============================================================================
  Switch
========================================================================== */
input.switch {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}
input.switch + label {
  display: block;
  line-height: 1;
  cursor: pointer;
  text-indent: -9999px;
  width: calc(var(--form-switch-height) * 2);
  height: var(--form-switch-height);
  background: var(--form-switch-bg-color);
  border-radius: var(--form-switch-height);
  position: relative;
}
input.switch + label:after, input.switch + label:before {
  content: "";
  position: absolute;
  top: calc(var(--form-switch-height) * 0.1);
  left: calc(var(--form-switch-height) * 0.1);
  width: calc(var(--form-switch-height) * 0.8);
  height: calc(var(--form-switch-height) * 0.8);
  background: #fff;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 60%;
  border-radius: calc(var(--form-switch-height) * 0.8);
  transition: 0.3s;
}
input.switch + label:before {
  color: var(--form-switch-active-bg-color);
  opacity: 0;
  z-index: 2;
  transition: 0s;
  transition-delay: 0s;
  left: calc(100% - var(--form-switch-height) * 0.1);
  transform: translateX(-100%);
}
input.switch:checked + label {
  background: var(--form-switch-active-bg-color);
}
input.switch:checked + label:after, input.switch:checked + label:before {
  left: calc(100% - var(--form-switch-height) * 0.1);
  transform: translateX(-100%);
  opacity: 1;
}
input.switch:checked + label:before {
  transition: 0.15s;
  transition-delay: 0.3s;
}
input.switch:checked + label:active:after {
  width: calc(var(--form-switch-height) * 1.1);
}

.toggle {
  display: flex;
  align-items: center;
}
.toggle input + label {
  background: var(--form-switch-active-bg-color) !important;
}
.toggle .label-class {
  display: inline-flex;
  transition: opacity 0.25s ease;
}
.toggle .label-class:not(.active) {
  opacity: 0.5;
}

/* =============================================================================
  Input Groups
========================================================================== */
.input-group {
  display: flex;
  align-items: stretch;
  margin: 0 0 var(--form-spacing, 30px);
  font-size: 1rem;
}
.input-group input {
  margin: 0;
}
.input-group input:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group input:last-child {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.input-group-text {
  display: flex;
  align-items: center;
  padding: 0 8px;
  background: var(--color-light);
  border: 1px solid var(--color-dark);
  border-radius: var(--form-input-radius, 0px);
}
.input-group-text:first-child {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right-width: 0;
}
.input-group-text:last-child {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-left-width: 0;
}
.input-group-text:not(:first-child) {
  margin-left: -1px;
}

/* =============================================================================
  Grey Forms
========================================================================== */
.grey-form label {
  color: var(--color-black);
}
.grey-form [type=color], .grey-form [type=date], .grey-form [type=datetime-local], .grey-form [type=datetime], .grey-form [type=email], .grey-form [type=month], .grey-form [type=number], .grey-form [type=password], .grey-form [type=search], .grey-form [type=tel], .grey-form [type=text], .grey-form [type=time], .grey-form [type=url], .grey-form [type=week], .grey-form textarea, .grey-form select {
  border-color: var(--color-medium);
}
.grey-form .input-group-text {
  border-color: var(--color-medium);
  color: var(--color-black);
}
.grey-form input[type=checkbox]:not(.simple):not(.radio-style):not(.checkbox-dropdown):not(.expandable-item-checkbox) + label:before {
  background-color: var(--color-white);
}

/* =============================================================================
  White Form
========================================================================== */
.white-form [type=color], .white-form [type=date], .white-form [type=datetime-local], .white-form [type=datetime], .white-form [type=email], .white-form [type=month], .white-form [type=number], .white-form [type=password], .white-form [type=search], .white-form [type=tel], .white-form [type=text], .white-form [type=time], .white-form [type=url], .white-form [type=week], .white-form textarea, .white-form select {
  border: 1px solid var(--color-medium);
  box-shadow: var(--form-box-shadow);
}
.white-form [type=color]:focus-visible, .white-form [type=color].tinymce-focussed, .white-form [type=date]:focus-visible, .white-form [type=date].tinymce-focussed, .white-form [type=datetime-local]:focus-visible, .white-form [type=datetime-local].tinymce-focussed, .white-form [type=datetime]:focus-visible, .white-form [type=datetime].tinymce-focussed, .white-form [type=email]:focus-visible, .white-form [type=email].tinymce-focussed, .white-form [type=month]:focus-visible, .white-form [type=month].tinymce-focussed, .white-form [type=number]:focus-visible, .white-form [type=number].tinymce-focussed, .white-form [type=password]:focus-visible, .white-form [type=password].tinymce-focussed, .white-form [type=search]:focus-visible, .white-form [type=search].tinymce-focussed, .white-form [type=tel]:focus-visible, .white-form [type=tel].tinymce-focussed, .white-form [type=text]:focus-visible, .white-form [type=text].tinymce-focussed, .white-form [type=time]:focus-visible, .white-form [type=time].tinymce-focussed, .white-form [type=url]:focus-visible, .white-form [type=url].tinymce-focussed, .white-form [type=week]:focus-visible, .white-form [type=week].tinymce-focussed, .white-form textarea:focus-visible, .white-form textarea.tinymce-focussed, .white-form select:focus-visible, .white-form select.tinymce-focussed {
  border-color: transparent;
  outline: none;
  box-shadow: var(--form-focus-box-shadow);
}
.white-form [type=color]:focus-visible ~ .tox-tinymce, .white-form [type=color].tinymce-focussed ~ .tox-tinymce, .white-form [type=date]:focus-visible ~ .tox-tinymce, .white-form [type=date].tinymce-focussed ~ .tox-tinymce, .white-form [type=datetime-local]:focus-visible ~ .tox-tinymce, .white-form [type=datetime-local].tinymce-focussed ~ .tox-tinymce, .white-form [type=datetime]:focus-visible ~ .tox-tinymce, .white-form [type=datetime].tinymce-focussed ~ .tox-tinymce, .white-form [type=email]:focus-visible ~ .tox-tinymce, .white-form [type=email].tinymce-focussed ~ .tox-tinymce, .white-form [type=month]:focus-visible ~ .tox-tinymce, .white-form [type=month].tinymce-focussed ~ .tox-tinymce, .white-form [type=number]:focus-visible ~ .tox-tinymce, .white-form [type=number].tinymce-focussed ~ .tox-tinymce, .white-form [type=password]:focus-visible ~ .tox-tinymce, .white-form [type=password].tinymce-focussed ~ .tox-tinymce, .white-form [type=search]:focus-visible ~ .tox-tinymce, .white-form [type=search].tinymce-focussed ~ .tox-tinymce, .white-form [type=tel]:focus-visible ~ .tox-tinymce, .white-form [type=tel].tinymce-focussed ~ .tox-tinymce, .white-form [type=text]:focus-visible ~ .tox-tinymce, .white-form [type=text].tinymce-focussed ~ .tox-tinymce, .white-form [type=time]:focus-visible ~ .tox-tinymce, .white-form [type=time].tinymce-focussed ~ .tox-tinymce, .white-form [type=url]:focus-visible ~ .tox-tinymce, .white-form [type=url].tinymce-focussed ~ .tox-tinymce, .white-form [type=week]:focus-visible ~ .tox-tinymce, .white-form [type=week].tinymce-focussed ~ .tox-tinymce, .white-form textarea:focus-visible ~ .tox-tinymce, .white-form textarea.tinymce-focussed ~ .tox-tinymce, .white-form select:focus-visible ~ .tox-tinymce, .white-form select.tinymce-focussed ~ .tox-tinymce {
  border-color: transparent !important;
  outline: none;
  box-shadow: 0 0 0 4px var(--color-accent) !important;
}
.white-form [type=color][aria-invalid=true] ~ .tox-tinymce, .white-form [type=date][aria-invalid=true] ~ .tox-tinymce, .white-form [type=datetime-local][aria-invalid=true] ~ .tox-tinymce, .white-form [type=datetime][aria-invalid=true] ~ .tox-tinymce, .white-form [type=email][aria-invalid=true] ~ .tox-tinymce, .white-form [type=month][aria-invalid=true] ~ .tox-tinymce, .white-form [type=number][aria-invalid=true] ~ .tox-tinymce, .white-form [type=password][aria-invalid=true] ~ .tox-tinymce, .white-form [type=search][aria-invalid=true] ~ .tox-tinymce, .white-form [type=tel][aria-invalid=true] ~ .tox-tinymce, .white-form [type=text][aria-invalid=true] ~ .tox-tinymce, .white-form [type=time][aria-invalid=true] ~ .tox-tinymce, .white-form [type=url][aria-invalid=true] ~ .tox-tinymce, .white-form [type=week][aria-invalid=true] ~ .tox-tinymce, .white-form textarea[aria-invalid=true] ~ .tox-tinymce, .white-form select[aria-invalid=true] ~ .tox-tinymce {
  border-color: var(--color-error) !important;
}
.white-form .input-group-text {
  border-color: var(--color-medium);
  box-shadow: var(--form-box-shadow);
}

/* =============================================================================
  Form Section
========================================================================== */
.form-section {
  position: relative;
}

.form-section-help-toggle {
  font-size: 0.875em;
  color: var(--typography-body-colour);
  display: inline-block;
  margin: -0.625rem 0 0.625rem 0 !important;
  text-align: right;
}

/* =============================================================================
  TinyMCE
========================================================================== */
.tox-tinymce {
  border-radius: var(--form-input-radius, 0px) !important;
  border: 1px solid var(--color-medium) !important;
  box-shadow: var(--form-box-shadow) !important;
  margin-bottom: var(--form-spacing, 30px);
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 41.75rem) {
  .form-section-help-toggle {
    margin: 0 !important;
    position: absolute;
    top: 0.625rem;
    right: 1.25rem;
  }
}
#form-event-addon .out-of-stock-msg {
  display: none;
}
#form-event-addon.out-of-stock > * {
  display: none;
}
#form-event-addon.out-of-stock .out-of-stock-msg {
  display: block;
}

/* =============================================================================
  Panels
========================================================================== */
.panel {
  /* =============================================================================
  Quote Panel
  ========================================================================== */
  /* =============================================================================
    Titles
  ========================================================================== */
  /* =============================================================================
    Boxes
  ========================================================================== */
}
.panel.quote {
  overflow: hidden;
  align-items: center;
  display: flex;
  justify-content: center;
}
.panel.quote .container {
  position: relative;
}
.panel.quote .outer {
  position: relative;
}
.panel.quote .inner {
  aspect-ratio: 16/9;
  padding: calc(var(--layout-spacing) * 1.5);
  text-align: center;
  max-width: 50rem;
  margin: 0 auto;
}
.panel.quote figure {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  z-index: -1;
}
.panel.quote figure img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.panel .title-wrapper:has(.panel-subtitle) .panel-title {
  margin-bottom: 0.25rem;
}
.panel .title-wrapper:has(.panel-subtitle) .panel-subtitle {
  margin-bottom: var(--typography-header-margin-bottom);
}
.panel .panel-title em {
  font-style: normal;
  color: var(--panel-title-em-color);
}
/* =============================================================================
  Panel Colour Modifications
========================================================================== */
.panel-color .panel-title {
  color: var(--panel-title-color);
}
.panel-color .panel-subtitle {
  color: var(--panel-subtitle-color);
  font-size: var(--typography-lead-size);
}
.panel-color .panel-text p, .panel-color .panel-text ul, .panel-color .panel-text ol {
  color: var(--panel-text-color);
}
.panel-color.bg-primary {
  --panel-title-color: var(--color-white);
  --panel-subtitle-color: var(--color-secondary);
}
.panel-color.bg-primary .button {
  color: var(--color-dark);
}
.panel-color.bg-primary .button.is-secondary {
  color: var(--color-white);
}
.panel-color.bg-primary .button.is-secondary span {
  color: var(--color-dark);
}
.panel-color.bg-secondary, .panel-color.bg-dark {
  --panel-title-color: var(--color-primary);
  --panel-subtitle-color: var(--color-medium);
  --panel-text-color: var(--color-light);
}
.panel-color.bg-secondary .button.is-secondary, .panel-color.bg-dark .button.is-secondary {
  color: var(--color-accent);
}
.panel-color.bg-dark {
  --panel-title-color: var(--color-light);
}
.panel-color.bg-accent {
  --panel-title-color: var(--color-secondary);
  --panel-subtitle-color: var(--color-light);
  --panel-text-color: var(--color-white);
}
.panel-color.bg-seg {
  --panel-title-color: var(--color-white);
  --panel-title-em-color: var(--color-secondary);
  --panel-text-color: var(--color-black);
}

/* =============================================================================
  Media Wrapper
========================================================================== */
.panel-media-wrapper {
  overflow: hidden;
  border-radius: var(--layout-border-radius);
}

/* =============================================================================
  Home Hero
========================================================================== */
#hero-home, #event-search-wrapper {
  position: relative;
  z-index: 2;
}
#hero-home [type=text], #hero-home select, #event-search-wrapper [type=text], #event-search-wrapper select {
  border: none;
}
#hero-home [type=text]:focus-visible, #hero-home select:focus-visible, #event-search-wrapper [type=text]:focus-visible, #event-search-wrapper select:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--color-accent);
}
#hero-home button:focus, #event-search-wrapper button:focus {
  border-color: transparent;
}
#hero-home button:focus-visible, #event-search-wrapper button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--color-white);
}

#event-search-wrapper button:focus-visible {
  box-shadow: 0 0 0 4px var(--color-accent);
}
#event-search-wrapper label {
  color: var(--color-accent);
}
#event-search-wrapper .select-box .selected {
  border: none;
}
#event-search-wrapper .select-box.active, #event-search-wrapper .select-box:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px var(--color-accent);
}

/* =============================================================================
  FAQs
========================================================================== */
.faqs-wrapper {
  display: grid;
  gap: var(--layout-grid-gap);
  grid-template-columns: 1fr;
}
.faqs-wrapper details {
  margin-bottom: 0;
}
.faqs-wrapper details summary {
  font-size: 1.125rem;
  margin-bottom: 0;
  padding: var(--accordion-summary-pad);
  border-radius: var(--layout-border-radius);
}
.faqs-wrapper details[open] summary {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.faqs-wrapper details[open] .accordion-content {
  background-color: var(--color-white);
  margin-bottom: 0;
  padding: var(--accordion-summary-pad);
  border-bottom-left-radius: var(--layout-border-radius);
  border-bottom-right-radius: var(--layout-border-radius);
}

.faq-wrapper {
  max-width: 56.25rem;
  margin: 0 auto;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 75.625rem) {
  #hero-home {
    position: relative;
  }
  #hero-home:before, #hero-home:after {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    left: var(--layout-container-padding);
    width: 14%;
    transform: translateY(-50%);
    aspect-ratio: 1/1;
    background-image: url(../images/horse-dressage.svg);
    background-repeat: no-repeat;
    background-size: contain;
    opacity: 0.4;
  }
  #hero-home:after {
    left: auto;
    right: var(--layout-container-padding);
    background-image: url(../images/horse-jumping.svg);
  }
  /* =============================================================================
    FAQs
  ========================================================================== */
  .faqs-wrapper details summary {
    font-size: 1.375rem;
  }
  .faqs-wrapper details[open] .accordion-content {
    padding: var(--accordion-summary-pad);
  }
}
/* =============================================================================
  Venue stuff
========================================================================== */
.w3w-wrapper {
  font-size: 1.125rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  box-shadow: var(--form-box-shadow);
}
.w3w-wrapper a {
  padding: 0.5rem;
  background-color: var(--color-white);
  color: var(--color-dark) !important;
  display: inline-block;
  cursor: pointer;
}

.w3w-logo {
  color: #e11f26;
  float: left;
  margin-right: 2px;
}

.w3w-button {
  padding-right: 10px;
  border-top-left-radius: 6px;
  border-bottom-left-radius: 6px;
}
.w3w-button > * {
  transition: transform 100ms linear;
  display: inline-block;
}
.w3w-button:hover > * {
  transform: translateX(-2px);
}

.w3w-copy {
  border-left: 1px solid var(--color-medium);
  padding-left: 10px;
  border-top-right-radius: 6px;
  border-bottom-right-radius: 6px;
}
.w3w-copy i {
  display: block;
}
.w3w-copy:hover i {
  transform: scale(1.1);
  transform-origin: center;
  color: var(--color-primary);
}

.hero-additional .w3w-copy:after {
  color: var(--color-white);
}

/* =============================================================================
  Event stuff
========================================================================== */
/* =============================================================================
  Search
========================================================================== */
.search-form-inner {
  position: relative;
  z-index: 2;
}

.search-actions {
  position: relative;
  z-index: 1;
}

#advanced-search-wrapper {
  display: none;
}
#advanced-search-wrapper .is-animating {
  display: block;
}
#advanced-search-wrapper .inner {
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 500ms ease-in-out;
}
#advanced-search-wrapper.is-open {
  display: block;
}
#advanced-search-wrapper.is-open .inner {
  transform: scaleY(1);
}

#advanced-search-button, #form-submit-search-events {
  margin-top: var(--form-spacing, 30px);
}

#search-filters-wrapper {
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}
#search-filters-wrapper .buttons-wrapper {
  margin-left: -0.625rem;
  margin-bottom: -0.625rem;
}
#search-filters-wrapper .buttons-wrapper .button {
  margin-left: 0.3125rem;
  margin-right: 0.3125rem;
  margin-bottom: 0.625rem;
}

#search-results .advert {
  margin-bottom: 1.875rem;
}

.search-result {
  background-color: var(--color-light);
  border-radius: var(--form-input-radius);
  padding: 1.5rem;
  margin-bottom: 1.875rem;
  display: block;
}
.search-result .title-wrapper, .search-result .meta-wrapper {
  position: relative;
}
.search-result .title-wrapper:before, .search-result .meta-wrapper:before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  height: 100%;
  border-left: 1px solid var(--color-primary);
  margin-left: calc(var(--layout-grid-gap) * -0.5);
  display: none;
}
.search-result img {
  border-radius: var(--form-input-radius);
  overflow: hidden;
}
.search-result .result-date {
  color: var(--color-accent);
}
.search-result.featured {
  position: relative;
  background-color: var(--color-accent);
  overflow: hidden;
}
.search-result.featured .title-wrapper:before, .search-result.featured .meta-wrapper:before {
  border-color: var(--color-white);
}
.search-result.featured .result-title {
  color: var(--color-white);
}
.search-result.featured .result-pc_bc, .search-result.featured .result-date {
  color: var(--color-light);
}
.search-result.featured .search-item-meta .meta-item, .search-result.featured .search-item-meta .meta-label {
  color: var(--color-white);
}

.result-title {
  margin-bottom: 0.375rem;
}

.result-pc_bc {
  margin-top: -0.375rem;
  margin-bottom: 0.375rem;
}

.search-item-meta {
  font-size: 0.875rem;
}
.search-item-meta > *:not(:first-child) {
  margin-top: 0.375rem;
}
.search-item-meta .meta-label {
  color: var(--color-accent);
}

.small-button-wrapper {
  margin-top: 1rem;
}

.featured-ribbon {
  font-size: 0.75rem;
  width: 10em;
  height: 10em;
  border-top-right-radius: var(--form-input-radius);
  background: var(--color-secondary);
  position: absolute;
  top: 0;
  right: 0;
  text-align: center;
  letter-spacing: 1px;
  color: var(--color-white);
  text-transform: uppercase;
  transform: rotate(225deg) translate(0, 70%);
  z-index: 2;
}
.featured-ribbon span {
  display: block;
  transform: rotate(180deg);
  line-height: 2em;
}

/* at least one input mechanism of the device includes an accurate pointing device. - https://ferie.medium.com/detect-a-touch-device-with-only-css-9f8e30fa1134 */
@media (any-pointer: fine) {
  .search-result {
    transition: box-shadow 150ms ease-in-out;
  }
  .search-result:hover {
    box-shadow: var(--focus-drop-shadow);
  }
}
.event-venue-info a:not(.button) {
  color: var(--typography-body-colour);
}
.event-venue-info .w3w-wrapper {
  box-shadow: var(--focus-drop-shadow);
}

/* =============================================================================
  Sponsors
========================================================================== */
.event-sponsors {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 1.25rem;
}
.event-sponsors > * {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  padding: 1.25rem;
  border-radius: 1.25rem;
}

/* =============================================================================
  Booking
========================================================================== */
:root {
  --class-padding-v: 1.875rem;
  --class-padding-h: 2.5rem;
}

.event-distance-wrapper {
  align-items: center;
}

#classes-wrapper .class:nth-child(odd):not(.is-active) .summary {
  background-color: var(--color-light);
}
#classes-wrapper .class.is-full .spaces {
  font-weight: var(--typography-weight-bold);
  color: var(--color-error);
}
#classes-wrapper.has-active .class:not(.is-active) {
  opacity: 0.3;
}
#classes-wrapper a {
  transition: none;
}

.user-entry-editing #classes-wrapper.has-active .class:not(.is-active) {
  opacity: 0.75;
}
.user-entry-editing #classes-wrapper .class-close {
  display: none !important;
}
.user-entry-editing .entry-image {
  max-width: 15.625rem;
}

.class {
  overflow: hidden;
  border-radius: var(--layout-border-radius) !important;
}
.class .summary {
  padding: calc(var(--class-padding-v) * 0.5) calc(var(--class-padding-h) * 0.5);
}
.class .class-close {
  display: none;
}
.class.is-active .summary {
  background-color: var(--color-secondary);
  color: var(--color-white);
}
.class.is-active .summary a:not(.button) {
  color: var(--color-light);
}
.class.is-active .class-content {
  display: block;
}
.class.is-active .button.class-activator, .class.is-active .button.class-edit-canceller {
  display: none;
}
.class.is-active .class-close {
  font-size: 1.875rem;
  display: block;
}
.class.is-active:not(:last-child) {
  margin-bottom: var(--class-padding-v);
}
.class [data-readmore] {
  color: var(--color-dark);
  opacity: 0.75;
}
.class [data-readmore]:hover {
  opacity: 1;
}

.class-content {
  background-color: var(--color-light);
  padding: calc(var(--class-padding-v) * 0.5) calc(var(--class-padding-h) * 0.5);
  display: none;
}
.class-content#audience-content.is-active, .class-content#timed-content.is-active {
  display: block;
}

.entry-form section:not(:last-child) {
  margin-bottom: var(--class-padding-v);
}

.class-loader {
  min-height: 12.5rem;
}
.class-loader .loader {
  border: 0.4em solid transparent;
  border-color: var(--color-dark);
  border-top-color: var(--color-primary);
  width: 3.125rem;
  height: 3.125rem;
}

.price-wrapper {
  position: relative;
}

.class-ticket-number {
  max-width: 6.25rem;
}

.from {
  display: inline-block;
  font-size: 0.75rem;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-right: 0.3125rem;
}

.booking-fee {
  display: block;
  font-size: 0.75rem;
}

.rider-select-wrapper {
  padding-bottom: calc(var(--class-padding-v) * 0.75);
  margin-bottom: calc(var(--class-padding-v) * 0.75);
  border-bottom: 1px solid var(--color-medium);
}
.rider-select-wrapper:not(.is-complete) + .fields-wrapper {
  position: relative;
  max-height: 12.5rem;
  overflow: hidden;
}
.rider-select-wrapper:not(.is-complete) + .fields-wrapper:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
  background: var(--color-light);
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.75) 100%);
}
.rider-select-wrapper:not(.is-complete) + .fields-wrapper:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 90%;
  content: "Complete fields above to activate form";
  transform: translate(-50%, -50%);
  font-size: 1.25rem;
  color: var(--color-secondary);
  text-align: center;
  z-index: 4;
}
.rider-select-wrapper:not(.is-complete) + .fields-wrapper ~ div {
  display: none;
}

.pc-fields-wrapper {
  margin-bottom: calc(var(--class-padding-v) * 0.75);
  border-bottom: 1px solid var(--color-medium);
}
.pc-fields-wrapper .pc-valid-message {
  display: none;
}
.pc-fields-wrapper[data-pc-valid] .pc-default-validation-message, .pc-fields-wrapper[data-pc-valid] .js-entry-pc-validator {
  display: none;
}
.pc-fields-wrapper[data-pc-valid] .pc-valid-message {
  display: block;
  pointer-events: none;
}

.field-group-wrapper:not(:last-of-type) .field-wrapper:last-of-type {
  display: block;
  content: "";
  border-bottom: 1px solid var(--color-medium);
}
.field-group-wrapper:last-of-type .field-wrapper {
  margin-bottom: 0;
}

.class-actions-wrapper {
  background-color: var(--color-secondary);
  margin: calc(var(--class-padding-v) * -0.5) calc(var(--class-padding-h) * -0.5);
  padding: calc(var(--class-padding-v) * 0.5) calc(var(--class-padding-h) * 0.5);
  margin-top: 0;
}
.class-actions-wrapper > *:not(:last-child) {
  margin-bottom: 1.25rem;
}
.class-actions-wrapper .has-split {
  width: 100%;
}
.class-actions-wrapper .has-split .button:first-child {
  flex: 1;
}

/* =============================================================================
  Timed Event Booking;
========================================================================== */
.timed-class-title {
  margin-bottom: 1rem;
}

.timed-price label {
  text-transform: uppercase;
  font-size: var(--typography-size-small, 12px);
}

@container (min-width:64rem) {
  .timed-price {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    align-items: center;
  }
  .timed-price label {
    text-align: right;
  }
  .timed-price .timed-price {
    display: block;
  }
  .timed-price input {
    display: inline-block;
    max-width: 80px;
  }
}
@container (min-width:31rem) {
  .timed-prices-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
  }
  .timed-class-title {
    margin-bottom: 0;
  }
  .timed-price input {
    margin-bottom: 0;
  }
}
/* =============================================================================
  Cart
========================================================================== */
.cart-meta {
  line-height: 1.4;
}

/* =============================================================================
  Breakpoint
========================================================================== */
@media (min-width: 41.75rem) {
  #advanced-search-button, #form-submit-search-events {
    margin-top: 0;
  }
  .search-result .title-wrapper:before {
    display: block;
  }
  .result-action-wrapper {
    align-self: flex-end;
  }
  .class-actions-wrapper {
    display: flex;
  }
  .class-actions-wrapper > .button {
    margin-bottom: 0;
  }
  .class-actions-wrapper > *:last-child {
    margin-left: auto;
  }
  .class-actions-wrapper .has-split {
    width: auto;
  }
  .class-actions-wrapper .has-split > .button {
    width: auto;
  }
  .event-sponsors {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 64rem) {
  #search-filters-wrapper .filters-title {
    margin-right: 1rem;
  }
  #search-filters-wrapper .buttons-wrapper {
    margin-top: 0;
  }
  #search-filters-wrapper .flex-grid {
    align-items: center;
  }
  .search-result .title-wrapper:before, .search-result .meta-wrapper:before {
    display: block;
  }
  .search-item-meta {
    font-size: 1rem;
  }
  .class-activator-wrapper {
    text-align: right;
  }
  .class-ticket-number {
    margin-left: auto;
  }
  .featured-ribbon {
    font-size: 0.875rem;
  }
  .event-sponsors.has-3 {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 75.625rem) {
  .result-action-wrapper {
    align-self: center;
    text-align: right;
  }
  .class .summary {
    padding: var(--class-padding-v) var(--class-padding-h);
  }
  .class-content {
    padding: var(--class-padding-v) var(--class-padding-h);
  }
  .class-content .class-actions-wrapper {
    padding: var(--class-padding-v) var(--class-padding-h);
    margin: calc(var(--class-padding-v) * -1) calc(var(--class-padding-h) * -1);
    margin-top: 0;
  }
  .class-content .field-wrapper:last-of-type {
    margin-bottom: calc(var(--class-padding-v) * 1);
  }
  .field-group-wrapper:last-of-type .field-wrapper {
    margin-bottom: 0;
  }
  .from {
    position: absolute;
    display: block;
    transform: translateY(-100%);
  }
}
@media (min-width: 106.3125rem) {
  .search-result > .grid {
    --layout-grid-gap: 3.75rem;
  }
  .featured-ribbon {
    font-size: 1.125rem;
  }
}
/* =============================================================================
  Addons
========================================================================== */
#addons-list {
  display: grid;
  gap: var(--layout-grid-gap);
  grid-template-columns: 1fr;
}

[data-launch-addon] {
  cursor: pointer;
}

.addon-price {
  display: block;
  font-size: 1.5em;
  font-weight: var(--typography-bold-weight);
}

.addon-price-from {
  display: block;
  text-transform: uppercase;
  font-size: 0.75em;
}

#modal-addon-form .card-content:has(.addon-image-wrapper.hide) .md-7.cell {
  flex: 0 0 100%;
  max-width: 100%;
}
#modal-addon-form input[type=checkbox].simple {
  border-color: transparent;
  width: 2.5rem;
  height: 2.5rem;
}

/* =============================================================================
  Breakpoint
========================================================================== */
@media (min-width: 41.75rem) {
  #addons-list {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 64rem) {
  #addons-list {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media (min-width: 75.625rem) {
  #addons-list {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}
/* =============================================================================
  Results
========================================================================== */
#countdown {
  width: 100%;
  height: 0.5rem;
  position: sticky;
  margin-top: 0;
  top: 3.75rem;
  background-color: var(--color-light);
  z-index: 30;
}
#countdown span {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  background-color: var(--color-primary);
  width: 100%;
  max-width: 100%;
  transition: max-width 1000ms linear;
}

#cart-items-wrapper:empty {
  border-top: 3px solid var(--color-light);
}
#cart-items-wrapper:empty:before {
  position: relative;
  display: block;
  padding: 1.25rem;
  font-size: 1.2em;
  content: "You have no items in your cart";
}

.cart-entry {
  border-radius: var(--layout-border-radius);
  background-color: var(--color-light);
  align-items: center;
  padding: 0.75rem;
}
.cart-entry > * {
  flex: 0 1 auto; /* Default flex value */
}
.cart-entry:not(:last-child) {
  margin-bottom: 0.75rem;
}
.cart-entry.is-addon {
  position: relative;
  margin-left: 20px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.cart-entry.is-addon:before {
  border-top-right-radius: var(--layout-border-radius);
  border-bottom-right-radius: var(--layout-border-radius);
  background-color: var(--color-accent);
  position: absolute;
  left: -20px;
  top: 0;
  display: block;
  padding: 0.125rem 0;
  font-size: 0.75em;
  color: var(--color-white);
  height: 100%;
  width: 20px;
  line-height: 20px;
  content: "Addon";
  text-align: center;
  writing-mode: vertical-rl;
  text-transform: uppercase;
  transform: scale(-1);
}

.cart-title-wrapper a {
  font-weight: var(--typography-bold-weight);
  background: none !important;
  display: block;
}

.cart-meta a {
  font-weight: var(--typography-bold-normal);
}

.cart-price-wrapper {
  display: flex;
  align-items: center;
  flex: 1;
  margin-top: 1rem;
}
.cart-price-wrapper .price-wrapper {
  flex: 1;
}

.price-meta {
  display: block;
  font-size: 0.75rem;
}

.cart-action-wrapper {
  margin-left: 1rem;
}
.cart-action-wrapper button {
  margin: 0;
  border: none;
  font-size: 2em;
  color: var(--color-error);
  cursor: pointer;
  opacity: 0.75;
}
.cart-action-wrapper button:hover {
  opacity: 1;
}

.cart-image {
  max-width: 5rem;
  aspect-ratio: 1/1;
  margin: 0 1rem 0 0 !important;
  border-radius: var(--layout-border-radius);
  overflow: hidden;
}
.cart-image img, .cart-image video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cart-summary-prices {
  margin-top: 1rem;
  text-transform: uppercase;
}
.cart-summary-prices tr td {
  padding-left: 0;
  padding-right: 0;
}
.cart-summary-prices .total {
  margin-top: 0.625rem;
  padding-top: 0.625rem;
  border-top: 2px solid var(--color-medium);
  font-weight: var(--typography-bold-weight);
  font-size: 1.125rem;
}

#checkout-form-wrapper.disabled {
  pointer-events: none;
  opacity: 0.55;
}
#checkout-form-wrapper.disabled [type=color], #checkout-form-wrapper.disabled [type=date], #checkout-form-wrapper.disabled [type=datetime-local], #checkout-form-wrapper.disabled [type=datetime], #checkout-form-wrapper.disabled [type=email], #checkout-form-wrapper.disabled [type=month], #checkout-form-wrapper.disabled [type=number], #checkout-form-wrapper.disabled [type=password], #checkout-form-wrapper.disabled [type=search], #checkout-form-wrapper.disabled [type=tel], #checkout-form-wrapper.disabled [type=text], #checkout-form-wrapper.disabled [type=time], #checkout-form-wrapper.disabled [type=url], #checkout-form-wrapper.disabled [type=week], #checkout-form-wrapper.disabled [type=submit], #checkout-form-wrapper.disabled textarea, #checkout-form-wrapper.disabled select {
  pointer-events: none;
  opacity: 0.75;
  background-color: var(--form-disabled-bg-color);
  cursor: not-allowed;
}

#discount-codes-wrapper:has(#discount-codes-breakdown:empty) {
  display: none;
}

.payment-types {
  max-width: 83px !important;
}

#google-pay, #apple-pay {
  margin-bottom: 16px;
}

@supports (-webkit-appearance: -apple-pay-button) {
  .apple-pay-button {
    -webkit-appearance: -apple-pay-button;
    margin: 10px 10px 0 10px;
    -apple-pay-button-style: black;
    -apple-pay-button-type: plain;
    height: 40px;
    cursor: pointer;
  }
}
/* =============================================================================
  Cashflows
========================================================================== */
.cf-message {
  color: var(--color-error);
}

#pp-wrapper iframe, .pp-wrapper iframe {
  width: 100%;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 41.75rem) {
  .cart-entry {
    display: flex;
    flex-flow: row wrap;
  }
  .cart-title-wrapper, .cart-price-wrapper {
    display: flex;
    align-items: center;
    flex: 1;
  }
  .cart-price-wrapper {
    text-align: right;
    margin-top: 0;
  }
}
/* =============================================================================
  user related styles
========================================================================== */
/* =============================================================================
  General
========================================================================== */
#other-actions .overline {
  border-bottom: 1px solid var(--color-primary);
}

/* =============================================================================
  User Switching
========================================================================== */
#user_switching_switch_on {
  position: fixed;
  bottom: 30px;
  left: 30px;
  z-index: 300;
}
#user_switching_switch_on a {
  background-color: var(--color-error);
  font-size: 0;
  height: 60px;
  width: 60px;
  border-radius: 50%;
  display: block;
  opacity: 0.5;
}
#user_switching_switch_on a:before {
  content: "";
  width: 50%;
  height: 50%;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 640 512'%3E%3C!--!Font Awesome Free 6.5.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2024 Fonticons, Inc.--%3E%3Cpath d='M208 96a48 48 0 1 0 0-96 48 48 0 1 0 0 96zM123.7 200.5c1-.4 1.9-.8 2.9-1.2l-16.9 63.5c-5.6 21.1-.1 43.6 14.7 59.7l70.7 77.1 22 88.1c4.3 17.1 21.7 27.6 38.8 23.3s27.6-21.7 23.3-38.8l-23-92.1c-1.9-7.8-5.8-14.9-11.2-20.8l-49.5-54 19.3-65.5 9.6 23c4.4 10.6 12.5 19.3 22.8 24.5l26.7 13.3c15.8 7.9 35 1.5 42.9-14.3s1.5-35-14.3-42.9L281 232.7l-15.3-36.8C248.5 154.8 208.3 128 163.7 128c-22.8 0-45.3 4.8-66.1 14l-8 3.5c-32.9 14.6-58.1 42.4-69.4 76.5l-2.6 7.8c-5.6 16.8 3.5 34.9 20.2 40.5s34.9-3.5 40.5-20.2l2.6-7.8c5.7-17.1 18.3-30.9 34.7-38.2l8-3.5zm-30 135.1L68.7 398 9.4 457.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L116.3 441c4.6-4.6 8.2-10.1 10.6-16.1l14.5-36.2-40.7-44.4c-2.5-2.7-4.8-5.6-7-8.6zm347.7 119c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L461.3 384H480c88.4 0 160-71.6 160-160s-71.6-160-160-160L352 64c-17.7 0-32 14.3-32 32s14.3 32 32 32l128 0c53 0 96 43 96 96s-43 96-96 96H461.3l25.4-25.4c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0l-80 80c-12.5 12.5-12.5 32.8 0 45.3l80 80z' fill='%23fff'/%3E%3C/svg%3E") center center no-repeat;
  background-size: contain;
}
#user_switching_switch_on a:hover {
  transform: scale(1.02);
  opacity: 1;
}

/* =============================================================================
  Rider
========================================================================== */
#horses-wrapper.loader-active {
  display: flex;
  align-items: center;
  justify-content: center;
}
#horses-wrapper.loader-active .horses-loader {
  display: block;
  animation: loadingspin 1s linear infinite;
}
#horses-wrapper.loader-active #horses {
  display: none;
}
#horses-wrapper.loader-active [data-clone=horses] {
  display: none;
}

.horses-loader {
  display: none;
  width: 3.75rem;
  height: 3.75rem;
  border: 0.4em solid var(--color-white);
  border-top-color: var(--color-primary);
}

.horse-wrapper {
  background-color: var(--color-white);
  padding: 0.625rem 1rem;
  border-radius: 0.375rem;
  margin-bottom: calc(var(--layout-spacing) * 0.5);
}

.horse-title {
  margin-bottom: 1rem;
  padding-bottom: 0.625rem;
  border-bottom: 1px solid var(--color-primary);
}

.horse-commentary-wrapper {
  display: flex;
}
.horse-commentary-wrapper label {
  width: 100%;
  display: flex;
  flex-direction: column;
}
.horse-commentary-wrapper textarea {
  flex: 1;
}

.clone-horse {
  display: inline-block;
  float: right;
  font-size: 1rem;
  color: var(--color-secondary);
}

/* =============================================================================
  Breakpoint
========================================================================== */
@media (min-width: 64rem) {
  #other-actions {
    order: 2;
  }
  #table-wrapper {
    order: 3;
  }
}
/* =============================================================================
  Organiser
========================================================================== */
.event-manager-view {
  --header-bg-color: var(--color-dark);
  --header-burger-color: var(--color-white);
  --hero-bg-color: var(--color-accent);
  --hero-padding: var(--layout-spacing);
  --hero-overline-color: var(--color-secondary);
  --form-input-border-color: transparent;
  --table-striped-bg-color: #F7F7F8;
  --element-card-background: var(--color-white);
  background-color: var(--color-light);
}
.event-manager-view .modal {
  --form-input-border-color: var(--color-dark);
}
.event-manager-view #header {
  border: none !important;
}
.event-manager-view .navbar-menu {
  align-items: center;
}
.event-manager-view .navbar-menu > *:not(:first-child) {
  margin-left: 1rem;
}
.event-manager-view .faq-wrapper {
  background-color: var(--color-white);
  padding: calc(var(--element-box-padding) * 2);
  border-radius: var(--layout-border-radius);
}
.event-manager-view .box.has-bg {
  background-color: var(--color-white);
  border-radius: var(--layout-border-radius);
}
.event-manager-view .box .box-header {
  border-top-left-radius: var(--layout-border-radius);
  border-top-right-radius: var(--layout-border-radius);
}

/* =============================================================================
  Organiser Menu
========================================================================== */
#event-manager-menu {
  margin-left: 1.875rem;
}
#event-manager-menu > li > a {
  background-color: var(--color-dark);
  color: var(--color-white);
  text-transform: uppercase;
  padding: 1rem 1.25rem;
  transition: background-color 250ms ease, color 250ms ease;
}
#event-manager-menu > li > a:hover {
  background-color: var(--color-medium);
  color: var(--color-dark);
}
#event-manager-menu > li.is-current > a, #event-manager-menu > li.is-current-ancestor > a {
  background-color: var(--color-primary);
}
#event-manager-menu > li:not(:first-child) {
  border-left: 2px solid var(--color-white);
}

/* =============================================================================
  My Events
========================================================================== */
.events-table tr td {
  display: inline-block;
  width: 50%;
}
.events-table tr td:first-child {
  width: 100%;
}
.events-table .event-title a {
  color: var(--color-secondary);
  font-weight: var(--typography-bold-weight);
}

.em-table {
  border-radius: var(--layout-border-radius);
  overflow: hidden;
}
.em-table thead th {
  background-color: var(--color-accent) !important;
}
.em-table thead th.orderby-active {
  color: var(--color-black) !important;
}
.em-table .event-title {
  min-width: 12.5rem;
}
.em-table .event-title a {
  color: var(--color-secondary);
  font-weight: var(--typography-bold-weight);
}
.em-table .is-cancelled {
  opacity: 0.5;
}
.em-table .is-awaiting-payment td {
  background-color: color-mix(in srgb, var(--color-error) 25%, white) !important;
}
.em-table .is-awaiting-payment td.col-entry-title {
  position: relative;
}
.em-table .is-awaiting-payment td.col-entry-title:after {
  display: block;
  font-size: 0.875em;
  content: "Awaiting Payment";
  color: var(--color-error);
}

/* =============================================================================
  Event Status
========================================================================== */
.item-status {
  display: inline-flex;
  line-height: 2em;
  color: var(--color-white);
  background: var(--color-success);
  border-radius: 1.25em;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  cursor: inherit !important;
  white-space: nowrap;
  max-width: 100%;
  min-width: 5rem;
  justify-content: center;
  text-transform: uppercase;
}
.item-status > span {
  margin: 0 1em;
  overflow: hidden;
  text-overflow: ellipsis;
}
.item-status.awaiting-payment, .item-status.closed, .item-status.full {
  background: var(--color-error);
}
.item-status.awaiting-approval, .item-status.waitlist, .item-status.postponed {
  background: var(--color-alert);
}
.item-status.refunded {
  background: var(--color-dark);
}
.item-status.submitted {
  background: var(--color-accent);
}
.item-status.void, .item-status.draft {
  background: var(--color-light);
  color: var(--color-dark);
}
.item-status.cancelled {
  background: var(--color-error);
}
.item-status.is-small {
  font-size: 0.75rem;
}

/* =============================================================================
  Actions
========================================================================== */
.actions {
  display: flex;
  flex-flow: row wrap;
  gap: 10px;
  min-width: 5.625rem;
}

.action {
  position: relative;
  display: block;
  background-color: var(--color-secondary);
  color: var(--color-white) !important;
  border: 1px solid var(--color-secondary);
  border-radius: 6px;
  overflow: hidden;
  width: 2.5rem;
  height: 2.5rem;
}
.action:hover {
  opacity: 0.8;
}
.action i {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  font-size: 1.1em;
  line-height: 1;
}
.action.is-loading {
  cursor: not-allowed;
  position: relative;
}
.action.is-loading i {
  opacity: 0;
  position: relative;
  color: currentColor;
}
.action.is-loading:after {
  display: block;
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  height: 1.2em;
  width: 1.2em;
  transform: translate(-50%, -50%);
  background: transparent url("data:image/svg+xml,%3Csvg version='1.1' id='Layer_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 38 38' style='enable-background:new 0 0 38 38;' xml:space='preserve'%3E%3Cstyle type='text/css'%3E .st0%7Bfill:none;stroke:%23FFFFFF;stroke-width:6;stroke-opacity:0.5;%7D .st1%7Bfill:none;stroke:%23FFFFFF;stroke-width:6;%7D%0A%3C/style%3E%3Cg%3E%3Cg transform='translate(1 1)'%3E%3Ccircle class='st0' cx='18' cy='18' r='15.9'/%3E%3Cpath class='st1' d='M33.9,18c0-8.8-7.1-15.9-15.9-15.9 '%3E%3CanimateTransform accumulate='none' additive='replace' attributeName='transform' calcMode='linear' dur='1s' fill='remove' from='0 18 18' repeatCount='indefinite' restart='always' to='360 18 18' type='rotate'%3E%3C/animateTransform%3E%3C/path%3E%3C/g%3E%3C/g%3E%3C/svg%3E") center no-repeat;
  background-size: contain;
}
.action.is-accept {
  background-color: var(--color-success);
  border-color: var(--color-success);
}
.action.is-reject, .action.is-delete {
  background-color: var(--color-error);
  border-color: var(--color-error);
}
.action.is-disabled {
  opacity: var(--disabled-opacity, 0.5);
  cursor: not-allowed;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 64rem) {
  .em-table tr td {
    display: table-cell;
    width: auto;
  }
  .em-table tr td.event-title {
    max-width: 25rem;
  }
}
@media (min-width: 64rem) {
  /*.my-events-summary {
    td {
      &.buttons-cell {
        display: table-cell;
      }
    }
  }*/
}
/* =============================================================================
  Edit Event
========================================================================== */
#form-navigator {
  margin-top: 1.25rem;
}
#form-navigator .navigator-items {
  border-radius: var(--card-radius, 6px);
  background-color: var(--color-white);
  position: relative;
  box-shadow: var(--focus-drop-shadow);
  overflow: hidden;
  display: flex;
}
#form-navigator .navigator-items.no-active {
  background-color: var(--color-medium);
}
#form-navigator .navigator-items:not(.no-active) .is-active {
  background-size: 100% 100%;
  color: var(--color-white);
}
#form-navigator .navigator-items:not(.no-active) .is-active ~ .navigator-item:not(.is-active) {
  background-size: 0% 100%;
}
#form-navigator .navigator-item {
  padding: 0.75rem 1rem;
  background-image: linear-gradient(var(--color-primary), var(--color-primary));
  background-size: 0% 100%;
  background-position: 0 100%;
  background-repeat: no-repeat;
  transition: background-size 250ms ease, color 350ms ease;
  color: var(--color-dark);
  margin-right: 0;
  border-right: 1px solid var(--color-white);
  min-width: 6.25rem;
  text-align: center;
  text-transform: uppercase;
}

#default-image-wrapper {
  max-width: 9.375rem;
}

#em_location_map_wrapper {
  /*background-color: var(--color-light);
  min-height: 260px;
  position: relative;
  &:after {
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    transform: translate(-50%,-50%);
    text-transform: uppercase;
  }
  &.is-empty {
    &:after {
      content: "Please enter what3words value";
    }
  }
  &.is-loading {
    &:after {
      content: "Loading...";
    }
  }
  &.is-error {
    > div {
      display: none;
    }
    &:after {
      content:"ERROR.  Re-enter what3words";
      color: #ff0000;
    }
  }*/
}

/*#content_refund_visible {
  font-size: 1rem;
  line-height: var(--typography-body-line-height);
  border: 1px solid var(--color-medium);
  border-radius: var(--form-input-radius, 0px);
  box-shadow: var(--form-box-shadow);
  padding: 20px;
  min-height: rem-calc(300);
  max-height: rem-calc(300);
  overflow-y: auto;
  cursor: not-allowed;
  margin-bottom: var(--form-spacing, 30px);
}*/
.field-wrapper.is-invalid #content_refund_visible {
  border-color: var(--color-error) !important;
}

/* =============================================================================
  CLasses
========================================================================== */
.class-wrapper.no-remove [data-group-remove] {
  display: none;
  pointer-events: none;
}

.class-wrapper, .additional_content-wrapper {
  padding: 1rem;
  background-color: var(--color-light);
  border-radius: var(--layout-border-radius);
  margin-bottom: var(--form-spacing, 16px);
}

.class-fields-grid {
  /*display: flex;
  flex-flow: row wrap;
  gap: 10px;
  > * {
    width: calc(50% - 10px);
  }*/
}
.class-fields-grid:not(:last-child):has(.field-item:not(.hide)) {
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--color-dark);
}

.class-fields-separator {
  margin: 20px 0;
}

.class-fields-wrapper .rwmb-label hr {
  margin: 5px 0 10px;
}
.class-fields-wrapper.no-type {
  position: relative;
}
.class-fields-wrapper.no-type:after {
  display: block;
  content: "Choose form type first...";
  position: relative;
  margin: 0 auto;
  padding: 16px 0;
  color: red;
}
.class-fields-wrapper.no-type > *:not(.rwmb-label) {
  display: none;
}

.class-custom-fields {
  display: flex;
  flex-flow: row wrap;
  gap: 10px;
}
.class-custom-fields > li {
  padding: 4px 10px;
  background-color: var(--color-white);
}

/* =============================================================================
  Terms
========================================================================== */
.terms {
  border: 1px solid var(--color-dark);
  padding: 1rem;
  max-height: 12.5rem;
  overflow-y: auto;
}

/* =============================================================================
  Permissions
========================================================================== */
label:has(.user-email-check) {
  position: relative;
}
label:has(.user-email-check) input {
  z-index: 1;
}
label:has(.user-email-check):has(.valid):after {
  position: absolute;
  font-size: 24px;
  top: 34px;
  right: 10px;
  font-family: "he-icons";
  display: block;
  content: "\e825";
  z-index: 2;
  color: var(--color-success);
}
label:has(.user-email-check):has(.invalid):after {
  position: absolute;
  font-size: 24px;
  top: 34px;
  right: 10px;
  font-family: "he-icons";
  display: block;
  content: "\e801";
  z-index: 2;
  color: var(--color-error);
}

.user-email-check.checking {
  pointer-events: none;
  opacity: 0.5;
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 64rem) {
  /*.class-fields-grid {
    > * {
      width: calc(33.3333% - 10px);
    }
  }*/
}
@media (min-width: 75.625rem) {
  #form-navigator {
    position: sticky;
    top: 76px;
    z-index: 20;
  }
  #form-event [id] {
    scroll-margin-top: 10rem;
  }
  .form-section {
    justify-content: space-around;
    align-items: flex-start;
  }
  .help-col {
    position: sticky;
    top: 9.125rem;
  }
  /*.class-fields-grid {
    > * {
      width: calc(25% - 10px);
    }
  }*/
}
/* =============================================================================
  Edit Event
========================================================================== */
.em-entry-form section:not(:last-child), .em-entry-form .box:not(:last-child) {
  margin-bottom: var(--class-padding-v);
}
.em-entry-form .field-wrapper:last-of-type {
  margin-bottom: calc(var(--class-padding-v) * 1);
}

/* =============================================================================
  Breakpoints
========================================================================== */
@media (min-width: 64rem) {
  /*.class-fields-grid {
    > * {
      width: calc(33.3333% - 10px);
    }
  }*/
}