@charset "UTF-8";
/* Baseplate */
/* ==========================================================================
   Settings & Tools
   ========================================================================== */
@font-face {
  font-family: "Faktum";
  src: url("Faktum-Bold.woff2") format("woff2"), url("Faktum-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum Con";
  src: url("Faktum-ConRegular.woff2") format("woff2"), url("Faktum-ConRegular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum";
  src: url("Faktum-Regular.woff2") format("woff2"), url("Faktum-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum";
  src: url("Faktum-ExtraBold.woff2") format("woff2"), url("Faktum-ExtraBold.woff") format("woff");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum";
  src: url("Faktum-RegularItalic.woff2") format("woff2"), url("Faktum-RegularItalic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Faktum";
  src: url("Faktum-SemiBold.woff2") format("woff2"), url("Faktum-SemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum";
  src: url("Faktum-Medium.woff2") format("woff2"), url("Faktum-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum";
  src: url("Faktum-Light.woff2") format("woff2"), url("Faktum-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum Wide";
  src: url("Faktum-WideMedium.woff2") format("woff2"), url("Faktum-WideMedium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum Wide";
  src: url("Faktum-WideSemiBold.woff2") format("woff2"), url("Faktum-WideSemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Faktum Wide";
  src: url("Faktum-WideExtraBold.woff2") format("woff2"), url("Faktum-WideExtraBold.woff") format("woff");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
/*  stylelint-disable */
/**
 * Get color from palette w/default tone
 */
/**
 * Add percentage of white to a color
 */
/**
 * Add percentage of black to a color
 */
/* ==========================================================================
   Base
   ========================================================================== */
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: 700;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/* ==========================================================================
   Base
   ========================================================================== */
html {
  box-sizing: border-box;
  height: 100%;
  font-size: 100%;
  line-height: 1.5;
  text-rendering: geometricPrecision;
  scroll-padding-top: 200px;
  /* Smooth scrolling for anchor navigation */
  scroll-behavior: smooth;
}

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

body {
  color: #000;
  background-color: #fff;
  /**
   * Sticky footer
   * https://philipwalton.github.io/solved-by-flexbox/demos/sticky-footer/
   */
  display: flex;
  min-height: 100vh;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
}
body:before {
  content: "";
  display: block;
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
  position: fixed;
  z-index: 20;
  width: 100%;
  height: 100svh;
  top: 0;
  left: 0;
  opacity: 0;
  visibility: hidden;
}
body.nav-open {
  overflow: hidden;
}
body.nav-open .calendar__sidebar {
  z-index: 5;
}
body.filters-open, body.dates-open {
  position: fixed;
  width: 100%;
}
body.filters-open:before, body.dates-open:before {
  opacity: 1;
  visibility: visible;
}
body.filters-open .calendar__sidebar,
body.filters-open .whatson-grid__sidebar, body.dates-open .calendar__sidebar,
body.dates-open .whatson-grid__sidebar {
  z-index: 20;
  background-color: transparent;
}
body.filters-open .calendar-actions, body.dates-open .calendar-actions {
  filter: blur(6px);
  pointer-events: none;
}
body:has(.people-popup[open]) {
  overflow: hidden;
}

.global-container {
  display: flex;
  flex-direction: column;
  flex: 1;
  background-color: #fff;
}

.page-content {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.global-group {
  width: 100%;
  position: relative;
  z-index: 8;
}
@media (max-width: 71.99em) {
  .global-container:has(.global-navigation.is-toggled) .global-group {
    z-index: 8;
  }
}
@media (min-width: 72em) {
  .global-group {
    position: sticky;
    top: 0;
    z-index: 8;
  }
  .glightbox-open .global-group {
    position: fixed;
  }
}

svg.o-icon--logo {
  border: none;
  background-color: transparent;
  width: 100%;
  height: 50px;
  transition: background-color 0.4s ease;
  width: 80px;
}

:root {
  --link-color: #000;
  --focus-color: #262687;
  --theme-color: #262687;
  --theme-color-dark: ;
  --theme-color-light: ;
  --text-color: #000;
  --text-color-light: #fff;
  --theme-highlight-color: #FFC8E0;
  --theme-highlight-text-color: #000;
  --theme-body-text-color: #fff;
  --event-sticky-height: 0px;
  --content-margin: 100px 0;
  --content-margin-big: 160px 0;
  --content-margin-small: 60px 0;
  --global-header-size-0: 14px;
  --global-header-size-1: 16px;
  --global-header-size-2: 18px;
  --global-header-size-3: 20px;
  --global-header-size-4: 22px;
  --global-header-size-5: 24px;
  --global-header-size-6: 26px;
  --global-header-size-7: 28px;
  --global-header-size-8: 32px;
  --global-header-size-9: 38px;
  --global-header-size-10: 42px;
  --global-header-size-11: 48px;
  --global-header-size-12: 56px;
  --global-header-size-13: 60px;
  --global-header-size-14: 72px;
  --global-header-size-15: 90px;
  --global-header-size-16: 96px;
  --global-header-size-h1: var(--global-header-size-11);
  --global-header-size-h2: var(--global-header-size-8);
  --global-header-size-h3: var(--global-header-size-8);
  --global-header-size-h4: var(--global-header-size-1);
  --global-header-size-h5: var(--global-header-size-1);
  --global-header-size-h6: var(--global-header-size-1);
}
@media (min-width: 23em) {
  :root {
    --global-header-size-h1: var(--global-header-size-12);
    --global-header-size-h2: var(--global-header-size-9);
    --global-header-size-h3: var(--global-header-size-8);
    --global-header-size-h4: var(--global-header-size-2);
    --global-header-size-h5: var(--global-header-size-1);
    --global-header-size-h6: var(--global-header-size-1);
  }
}
@media (min-width: 30em) {
  :root {
    --global-header-size-h1: var(--global-header-size-13);
    --global-header-size-h2: var(--global-header-size-10);
    --global-header-size-h3: var(--global-header-size-9);
    --global-header-size-h4: var(--global-header-size-4);
    --global-header-size-h5: var(--global-header-size-3);
    --global-header-size-h6: var(--global-header-size-2);
  }
}
@media (min-width: 50em) {
  :root {
    --global-header-size-h1: var(--global-header-size-15);
    --global-header-size-h2: var(--global-header-size-11);
    --global-header-size-h3: var(--global-header-size-10);
    --global-header-size-h4: var(--global-header-size-5);
    --global-header-size-h5: var(--global-header-size-4);
    --global-header-size-h6: var(--global-header-size-3);
  }
}
@media (min-width: 62.5em) {
  :root {
    --global-header-size-h2: var(--global-header-size-12);
  }
}

.spacer {
  height: 40vh;
}

/* ==========================================================================
   Typography
   ========================================================================== */
h1, h2, h3, h4, h5, h6, .h6, .ff-display {
  font-weight: bold;
  font-family: Faktum, sans-serif;
}

.ff-display {
  font-weight: normal;
}

h4.ff-display {
  font-weight: bold;
}

/**
 * ff-* classes chained to avoid fonts-loaded specificity
 */
html, body, button, input, select, textarea, .ff-body.ff-body {
  font-family: Faktum, sans-serif;
}

.ff-caption.ff-caption {
  font-family: sans-serif;
}

pre, code, kbd, samp, .ff-monospace.ff-monospace {
  font-family: "Hack", "Droid Mono", monospace;
}

/* ==========================================================================
   Base - Headings
   ========================================================================== */
h1 {
  font-size: var(--global-header-size-h1);
}

h2 {
  font-size: var(--global-header-size-h2);
}

h3 {
  font-size: var(--global-header-size-h3);
}

h4 {
  font-size: var(--global-header-size-h4);
}

h5 {
  font-size: var(--global-header-size-h5);
}

h6 {
  font-size: var(--global-header-size-h6);
}

h1, h2, h3, h4, h5, h6 {
  line-height: 1;
  margin: 0 0 0.5rem;
  color: inherit;
}

h4, h5, h6 {
  font-weight: normal;
  font-family: Faktum, sans-serif;
}

/*  =========================================================================
    Grouping content
    http://developers.whatwg.org/grouping-content.html
    ========================================================================= */
p, pre, blockquote, ul, ol, dl, figure, table, fieldset {
  margin: 0;
  margin-bottom: 0.75em;
}

ol, ul {
  padding-left: 1.5em;
  list-style-position: outside;
}

li > ul, li > ol {
  margin-bottom: 0;
}

ul {
  list-style-type: disc;
}

blockquote {
  margin: 0;
}

figure, figcaption {
  /*  Correct `block` display for `figure` and `figcaption` elements in IE 8/9 */
  display: block;
}

/*  =========================================================================
    Text-level semantics
    http://developers.whatwg.org/text-level-semantics.html
    ========================================================================= */
small {
  /*  Address inconsistent and variable font size in all browsers */
  font-size: 90%;
  display: inline-block;
  letter-spacing: 0;
  font-weight: normal;
  font-family: inherit;
}

dfn {
  /*  Address styling not present in Safari 5 and Chrome */
  font-style: italic;
}

abbr[title], dfn[title] {
  cursor: help;
  border-bottom: 1px dotted;
}

sub, sup {
  /*  Position subscript and superscript content without affecting line-height */
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

::-moz-selection {
  background: #b3d4fc;
  /*  Remove text-shadow in selection highlight */
  text-shadow: none;
}

::selection {
  background: #b3d4fc;
  /*  Remove text-shadow in selection highlight */
  text-shadow: none;
}

/*  =========================================================================
    Links
    http://developers.whatwg.org/links.html
    ========================================================================= */
a {
  color: inherit;
  font-weight: normal;
  line-height: inherit;
  word-wrap: break-word;
  text-decoration: none;
  /* Remove gray background color from active links in IE 10 */
  background-color: transparent;
}
a:active, a:hover {
  /* Improve readability when focused and mouse hovered in all browsers */
  outline: 0;
  cursor: pointer;
}
a:focus {
  outline: none;
}
.user-is-tabbing a:focus {
  outline: 2px solid #000;
}

.skip-link {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  background-color: rgba(255, 255, 255, 0.92);
  color: #181822;
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  font-size: 20px;
  text-decoration: underline;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  margin: auto;
  z-index: 2;
  opacity: 1;
  outline: 0 !important;
  border: 2px solid #181822;
  backdrop-filter: blur(1px);
  transition: opacity 0.4s ease;
}
.skip-link:not(:focus) {
  opacity: 0;
  pointer-events: none;
}

/* ==========================================================================
   Page: Skip to content
   ========================================================================== */
.skip-to-content {
  background: var(--theme-color);
  color: #fff;
  font-weight: 500;
  left: 50%;
  padding: 10px;
  position: absolute;
  transform: translate(-50%, -110%);
  transition: transform 0.3s;
  z-index: 13;
}

.skip-to-content:focus {
  outline: none;
  transform: translate(-50%);
}

/*  =========================================================================
    Embedded content
    http://developers.whatwg.org/embedded-content-1
    ========================================================================= */
img, picture, embed, object, video {
  /* Remove border when inside `a` element in IE 8/9 */
  display: block;
  border: 0;
  max-width: 100%;
}

img[width], img[height] {
  /* Non-fluid images if you specify `width` and/or `height` attributes. */
  max-width: none;
}

svg:not(:root) {
  /* Correct overflow displayed oddly in IE9 */
  overflow: hidden;
}

iframe {
  border: none;
}

/*  =========================================================================
    Pattern Styling
    ========================================================================= */
h1.sg-section__title.sg-heading {
  font-family: Faktum, sans-serif !important;
  font-size: var(--global-header-size-h1) !important;
}

h2.sg-section__title.sg-heading {
  font-family: Faktum, sans-serif !important;
  font-size: var(--global-header-size-h2) !important;
}

h2#styleguide,
h2#pagespages,
h2#patternspatterns {
  font-size: 28px;
  margin-bottom: 10px;
}
h2#styleguide a,
h2#pagespages a,
h2#patternspatterns a {
  text-decoration: none;
  color: var(--link-color);
  background: linear-gradient(to bottom, var(--focus-color) 0%, var(--focus-color) 100%), linear-gradient(to bottom, var(--focus-color) 0%, var(--focus-color) 100%);
  background-position: 0 100%, 100% 100%;
  background-repeat: no-repeat, no-repeat;
  background-size: 100% 3px, 0 3px;
  text-decoration: none;
  transition: background-size 0.2s ease-in-out;
  border-bottom: 0;
  padding-bottom: 3px;
}
@keyframes ButtonLine {
  0% {
    background-size: 100% 3px, 0 3px;
  }
  50% {
    background-size: 0 3px, 0 3px;
  }
  100% {
    background-size: 0 3px, 100% 3px;
  }
}
h2#styleguide a:visited,
h2#pagespages a:visited,
h2#patternspatterns a:visited {
  color: var(--link-color);
}
h2#styleguide a:hover, h2#styleguide a:focus,
h2#pagespages a:hover,
h2#pagespages a:focus,
h2#patternspatterns a:hover,
h2#patternspatterns a:focus {
  animation-name: ButtonLine;
  animation-duration: 0.75s;
}
h2#styleguide a,
h2#pagespages a,
h2#patternspatterns a {
  border: none;
}

.sg-section-pages-list .sg-list {
  margin-top: 30px;
  list-style: decimal;
}
.sg-section-pages-list .sg-list__item {
  margin-bottom: 5px;
  font-size: 20px;
}
.sg-section-pages-list .sg-list__item a {
  text-decoration: none;
  color: var(--link-color);
  background: linear-gradient(to bottom, var(--focus-color) 0%, var(--focus-color) 100%), linear-gradient(to bottom, var(--focus-color) 0%, var(--focus-color) 100%);
  background-position: 0 100%, 100% 100%;
  background-repeat: no-repeat, no-repeat;
  background-size: 100% 3px, 0 3px;
  text-decoration: none;
  transition: background-size 0.2s ease-in-out;
  border-bottom: 0;
  padding-bottom: 3px;
}
@keyframes ButtonLine {
  0% {
    background-size: 100% 3px, 0 3px;
  }
  50% {
    background-size: 0 3px, 0 3px;
  }
  100% {
    background-size: 0 3px, 100% 3px;
  }
}
.sg-section-pages-list .sg-list__item a:visited {
  color: var(--link-color);
}
.sg-section-pages-list .sg-list__item a:hover, .sg-section-pages-list .sg-list__item a:focus {
  animation-name: ButtonLine;
  animation-duration: 0.75s;
}
.sg-section-pages-list .sg-list__item a {
  --focus-color: #000;
}

.sg-container {
  max-width: 1440px !important;
}

#pattern-Modules-NewsItem .news-item {
  max-width: 500px;
}

#pattern-Modules-PageItem .page-item {
  max-width: 500px;
}

#pattern-Modules-EventItem .sg-pattern__content {
  padding: 30px;
}
#pattern-Modules-EventItem .event-item {
  max-width: 500px;
}

#pattern-Widgets-CalendarList .sg-pattern__content {
  margin: 0 -5px;
  padding: 10px 5px;
}
@media (min-width: 50em) {
  #pattern-Widgets-CalendarList .sg-pattern__content {
    padding: 30px;
    margin: 0;
  }
}

#pattern-Modules-PeoplePopup .people-popup {
  position: relative;
  top: auto;
  left: auto;
  opacity: 1;
  height: auto;
}

/* ==========================================================================
   Scoped Contexts
   ========================================================================== */
/*  =========================================================================
    Scopes: Prose
    ========================================================================= */
:root {
  --global-body-size-1: 8px;
  --global-body-size-2: 10px;
  --global-body-size-3: 12px;
  --global-body-size-4: 14px;
  --global-body-size-5: 16px;
  --global-body-size-6: 18px;
  --global-body-size-7: 20px;
  --global-body-size-8: 22px;
  --global-body-size-9: 24px;
  --global-body-size-10: 26px;
  --global-body-size-11: 28px;
  --global-body-size-12: 32px;
  --global-body-text: var(--global-body-size-5);
  --global-body-text-small: var(--global-body-size-6);
  --global-body-text-big: var(--global-body-size-8);
  --global-caption: var(--global-body-size-5);
}
@media (min-width: 50em) {
  :root {
    --global-body-text: var(--global-body-size-7);
    --global-body-text-small: var(--global-body-size-7);
    --global-body-text-big: var(--global-body-size-9);
    --global-caption: var(--global-body-size-6);
  }
}
@media (min-width: 62.5em) {
  :root {
    --global-body-text: var(--global-body-size-7);
    --global-body-text-big: var(--global-body-size-10);
  }
}

.s-prose h1,
.s-prose h2,
.s-prose h3,
.s-prose h4,
.s-prose h5,
.s-prose h6 {
  margin: 0 0 15px;
  line-height: 1.2;
  text-wrap: pretty;
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
}
.s-prose h1.text-center,
.s-prose h2.text-center,
.s-prose h3.text-center,
.s-prose h4.text-center,
.s-prose h5.text-center,
.s-prose h6.text-center {
  text-align: center;
}
.s-prose h1 + ul,
.s-prose h2 + ul,
.s-prose h3 + ul,
.s-prose h4 + ul,
.s-prose h5 + ul,
.s-prose h6 + ul {
  margin-top: 20px;
}
.s-prose h2,
.s-prose h3,
.s-prose h4,
.s-prose h5,
.s-prose h6 {
  margin-top: 60px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
}
.s-prose h2:first-child,
.s-prose h3:first-child,
.s-prose h4:first-child,
.s-prose h5:first-child,
.s-prose h6:first-child {
  margin-top: 0;
}
.s-prose h2:last-child,
.s-prose h3:last-child,
.s-prose h4:last-child,
.s-prose h5:last-child,
.s-prose h6:last-child {
  margin-bottom: 0;
}
.s-prose h2 {
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}
.s-prose h3, .s-prose h5 {
  font-family: Faktum Wide, sans-serif;
}
.s-prose p:last-of-type {
  margin-bottom: 0;
}
.s-prose p {
  margin: var(--global-body-text) 0 0;
  text-wrap: pretty;
}
.s-prose p:first-child {
  margin-top: 0;
}
.s-prose p.text-center {
  text-align: center;
}
.s-prose p:empty {
  display: none;
}
.s-prose p:not(.quote__text):not(.cta):not(.caption),
.s-prose ul,
.s-prose ol,
.s-prose dl {
  font-size: var(--global-body-text);
  line-height: 1.4;
}
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button),
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):visited,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):hover,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):active {
  text-decoration: underline;
}
.s-prose .btn, .s-prose :where([data-component*=dialog] menu button) {
  margin-top: 30px;
  margin-bottom: 30px;
}
.s-prose .inline-button {
  margin: 5px 10px 5px 0;
}
.s-prose .fluid-width-video-wrapper {
  margin-bottom: 1em;
}
.s-prose hr {
  max-width: 15em;
  margin: 2em auto;
  border: none;
  border-top: 1px solid #6A6A6A;
}
.s-prose .inline-video {
  margin: 20px -20px;
}
.s-prose small {
  font-size: var(--global-body-text-small);
}
.s-prose .lead {
  font-weight: 700;
}
.s-prose pre {
  margin: 30px 0;
  padding: 30px;
  background-color: #000;
  color: #5aff75;
  white-space: pre-wrap;
}
@media (min-width: 30em) {
  .s-prose ul,
  .s-prose ol {
    margin: 30px 0;
  }
  .s-prose ul:only-child,
  .s-prose ol:only-child {
    margin: 0;
  }
}
@media (min-width: 50em) {
  .s-prose .inline-video {
    margin: 40px -40px;
  }
}
.s-prose {
  --global-header-size-h2: var(--global-header-size-5);
  --global-header-size-h1: var(--global-header-size-7);
  --global-header-size-h3: var(--global-header-size-3);
  --global-header-size-h4: var(--global-header-size-2);
  --global-header-size-h5: var(--global-header-size-1);
  --global-header-size-h6: var(--global-header-size-0);
}
@media (min-width: 30em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-9);
    --global-header-size-h2: var(--global-header-size-7);
    --global-header-size-h3: var(--global-header-size-5);
    --global-header-size-h4: var(--global-header-size-3);
    --global-header-size-h5: var(--global-header-size-2);
    --global-header-size-h6: var(--global-header-size-1);
  }
}
@media (min-width: 50em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-11);
    --global-header-size-h2: var(--global-header-size-8);
    --global-header-size-h3: var(--global-header-size-7);
    --global-header-size-h4: var(--global-header-size-5);
    --global-header-size-h5: var(--global-header-size-4);
    --global-header-size-h6: var(--global-header-size-2);
  }
}
@media (min-width: 72em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-13);
    --global-header-size-h2: var(--global-header-size-10);
    --global-header-size-h3: var(--global-header-size-9);
    --global-header-size-h4: var(--global-header-size-7);
    --global-header-size-h5: var(--global-header-size-5);
    --global-header-size-h6: var(--global-header-size-3);
  }
}

/* ==========================================================================
   Objects
   ========================================================================== */
/* ==========================================================================
   Grid
   ========================================================================== */
.o-grid:before, .o-grid:after {
  content: " ";
  display: table;
}
.o-grid:after {
  clear: both;
}
.o-grid {
  padding-left: 0;
}

.o-grid, .o-grid__item {
  list-style: none;
  margin: 0;
}

.o-grid__item {
  border-color: transparent;
  margin-bottom: 2.5%;
}

/**
 * Drop bottom margins if we know we only
 * have a single row of grid items.
 */
@media (min-width: 62.5em) {
  .o-grid--single-row .o-grid__item {
    margin-bottom: 0 !important;
  }
}

/**
 * Even numbers
 */
@media (min-width: 30em) {
  .o-grid--2up, .o-grid--4up {
    width: 102.5%;
    margin-left: -2.5%;
  }
}
@media (min-width: 30em) {
  .o-grid--2up .o-grid__item, .o-grid--4up .o-grid__item {
    float: left;
    margin-left: 1.25%;
    padding-left: 1.25%;
    margin-bottom: 2.5%;
    width: 48.75%;
  }
}
@media (min-width: 50em) {
  .o-grid--2up .o-grid__item, .o-grid--4up .o-grid__item {
    border-style: solid;
    border-width: 0 0 0 1px;
  }
}

@media (min-width: 50em) {
  .o-grid--2up .o-grid__item:nth-of-type(2n + 1) {
    clear: left;
    border-left: none;
  }
}

@media (min-width: 50em) {
  .o-grid--4up .o-grid__item {
    width: 23.75%;
  }
  .o-grid--4up .o-grid__item:nth-of-type(2n + 1) {
    clear: none;
  }
  .o-grid--4up .o-grid__item:nth-of-type(4n + 1) {
    clear: left;
    border-left: none;
  }
}

/**
 * Odd numbers
 */
@media (min-width: 50em) {
  .o-grid--3up {
    width: 102.5%;
    margin-left: -2.5%;
  }
  .o-grid--3up .o-grid__item {
    float: left;
    margin-left: 1.25%;
    padding-left: 1.25%;
    margin-bottom: 2.5%;
    width: 32.05%;
  }
  .o-grid--3up .o-grid__item:nth-of-type(2n + 1) {
    clear: none;
  }
  .o-grid--3up .o-grid__item:nth-of-type(3n + 1) {
    clear: left;
    border-left: none;
  }
}
/* ==========================================================================
   Objects: Icons
   ========================================================================== */
.o-icon {
  display: inline-block;
  vertical-align: middle;
  fill: currentColor;
  width: 24px;
  height: 24px;
}

.o-icon--small {
  width: 13px;
  height: 13px;
}

.o-icon--medium {
  width: 26px;
  height: 26px;
}

.o-icon--large {
  width: 32px;
  height: 32px;
}

.o-icon--xlarge {
  width: 40px;
  height: 40px;
}

.o-icon--scale {
  width: 0.75em;
  height: 0.75em;
  vertical-align: middle;
  position: relative;
  top: -2px;
}

.o-icon--top {
  vertical-align: top;
}

.o-icon--bottom {
  vertical-align: bottom;
}

.o-icon--offset {
  margin-right: 5px;
}

/* ==========================================================================
   Objects: Lists
   ========================================================================== */
.o-block-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.o-block-list__item, .o-block-list__link {
  display: block;
}

.o-block-list__item {
  margin-bottom: 5px;
}

.o-inline-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.o-inline-list__item {
  display: inline-block;
  margin-right: 10px;
}
.o-inline-list__item:last-child {
  margin-right: 0;
}

.o-inline-list__link {
  display: block;
}

/* ==========================================================================
   Object: Buttons
   ========================================================================== */
:root {
  --global-button-size: var(--global-body-size-4);
  --global-button-size-small: var(--global-body-size-4);
  --global-button-size-big: var(--global-body-size-6);
  --global-button-border-radius: 50px;
  --global-button-padding: 15px 40px;
  --global-button-padding-small: 10px 25px;
  --global-button-padding-big: 15px 60px;
}
@media (min-width: 50em) {
  :root {
    --global-button-size: var(--global-body-size-5);
    --global-button-size-small: var(--global-body-size-5);
    --global-button-size-big: var(--global-body-size-7);
    --global-button-padding: 15px 60px;
    --global-button-padding-small: 9px 18px;
    --global-button-padding-big: 20px 40px;
  }
}

.btn, :where([data-component*=dialog] menu button),
.inline-button,
.btn-primary,
.step-button-next,
.step-button-prev,
.userform input[type=button],
.userform input[type=submit] {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  display: inline-block;
  user-select: none;
  -webkit-appearance: none;
  font: inherit;
  font-family: Faktum Wide, sans-serif;
  font-size: var(--global-button-size);
  font-weight: 700;
  margin: 0;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
  color: var(--theme-highlight-text-color, #fff);
  background-color: var(--theme-highlight-color, #262687);
  border: 1.5px solid var(--theme-highlight-color, #262687);
  padding: var(--global-button-padding);
  width: auto;
  border-radius: 40px;
  line-height: 1.2;
  isolation: isolate;
  transition: 0.4s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.btn, :where([data-component*=dialog] menu button), .btn:hover, .btn:focus, .btn:active,
.inline-button,
.inline-button:hover,
.inline-button:focus,
.inline-button:active,
.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.step-button-next,
.step-button-next:hover,
.step-button-next:focus,
.step-button-next:active,
.step-button-prev,
.step-button-prev:hover,
.step-button-prev:focus,
.step-button-prev:active,
.userform input[type=button],
.userform input[type=button]:hover,
.userform input[type=button]:focus,
.userform input[type=button]:active,
.userform input[type=submit],
.userform input[type=submit]:hover,
.userform input[type=submit]:focus,
.userform input[type=submit]:active {
  text-decoration: none;
}
@media (hover: hover) and (pointer: fine) {
  .btn:hover, :hover:where([data-component*=dialog] menu button),
  .inline-button:hover,
  .btn-primary:hover,
  .step-button-next:hover,
  .step-button-prev:hover,
  .userform input[type=button]:hover,
  .userform input[type=submit]:hover {
    background-color: transparent;
    color: var(--theme-highlight-color, #fff);
    border-color: var(--theme-highlight-color, #262687);
    text-decoration: none;
    outline: none;
  }
}
.user-is-tabbing .btn:focus, .user-is-tabbing :focus:where([data-component*=dialog] menu button),
.user-is-tabbing .inline-button:focus,
.user-is-tabbing .btn-primary:focus,
.user-is-tabbing .step-button-next:focus,
.user-is-tabbing .step-button-prev:focus,
.user-is-tabbing .userform input[type=button]:focus,
.user-is-tabbing .userform input[type=submit]:focus {
  outline: none;
  font-weight: 700;
  border: 1px solid #262687;
  border-style: double;
  border-width: 3px;
}

.btn--inverted, .error-page a,
.error-page .btn,
.error-page :where([data-component*=dialog] menu button) {
  color: var(--theme-highlight-color, #fff);
  background-color: var(--theme-color, #262687);
  border: 1.5px solid var(--theme-color, #262687);
}
@media (hover: hover) and (pointer: fine) {
  .btn--inverted:hover, .error-page a:hover,
  .error-page .btn:hover,
  .error-page :hover:where([data-component*=dialog] menu button) {
    background-color: transparent;
    color: var(--theme-color, #000);
    border-color: var(--theme-color, #262687);
    text-decoration: none;
    outline: none;
  }
}

.btn--primary {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--primary:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--primary:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn--indigo {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--indigo:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--indigo:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn--dark-purple {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--dark-purple:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--dark-purple:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn--maroon {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--maroon:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--maroon:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn--pink {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--pink:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--pink:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn--light-blue {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--light-blue:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--light-blue:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn--peach {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--peach:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--peach:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn--light {
  color: var(--theme-body-text-color);
  background-color: var(--theme-color);
  border-color: var(--theme-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--light:hover {
    color: var(--theme-color);
    background-color: transparent;
    border-color: var(--theme-color);
  }
}
.user-is-tabbing .btn--light:focus {
  color: var(--theme-body-text-color-inverse);
  border-color: var(--theme-body-text-color-inverse);
}

.btn-primary[disabled],
.btn-primary[disabled]:hover {
  background-color: var(--theme-color);
}

.btn[disabled], [disabled]:where([data-component*=dialog] menu button),
.btn[disabled]:hover,
.btn.is-disabled,
.is-disabled:where([data-component*=dialog] menu button),
.btn.is-disabled:hover {
  cursor: default;
  cursor: not-allowed;
  background-color: #757575;
  color: #fff;
  border-color: #757575;
}

.btn--small {
  font-size: var(--global-button-size-small);
  padding: var(--global-button-padding-small);
  line-height: 1.1;
}

.btn--big {
  padding: var(--global-button-padding-big);
  font-size: var(--global-button-size-big);
}

.btn--primary {
  color: #fff;
  background-color: #262687;
  border-color: #262687;
}
@media (hover: hover) and (pointer: fine) {
  .btn--primary:hover {
    color: #000;
    background-color: #FFC8E0;
    border-color: #FFC8E0;
  }
}
.user-is-tabbing .btn--primary:focus {
  color: #000;
  border-color: #000;
}

.btn--red {
  color: #262687;
  background-color: #DB1E1E;
  border-color: #DB1E1E;
}
@media (hover: hover) and (pointer: fine) {
  .btn--red:hover {
    color: #fff;
    background-color: rgb(196.5722891566, 26.9277108434, 26.9277108434);
  }
}
.user-is-tabbing .btn--red:focus {
  color: #fff;
  border-color: #000;
}

.btn--white {
  color: #000;
  background-color: #fff;
  border-color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .btn--white:hover {
    color: #000;
    background-color: rgb(216.75, 216.75, 216.75);
  }
}
.user-is-tabbing .btn--white:focus {
  color: #fff;
  border-color: #000;
}

.btn--outline {
  color: var(--theme-body-text-color);
  background-color: transparent;
  border-color: var(--theme-body-text-color);
}
@media (hover: hover) and (pointer: fine) {
  .btn--outline:hover {
    color: var(--theme-body-text-color-inverse);
    background-color: var(--theme-body-text-color);
    border-color: var(--theme-body-text-color);
  }
}
.user-is-tabbing .btn--outline:focus {
  border-color: #000;
}

.btn--white-outline {
  color: #fff;
  background-color: transparent;
  border-color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .btn--white-outline:hover {
    color: #000;
    background-color: #fff;
  }
}
.user-is-tabbing .btn--white-outline:focus {
  border-color: #000;
}

.btn--black-outline {
  color: #000;
  background-color: transparent;
  border-color: #000;
}
@media (hover: hover) and (pointer: fine) {
  .btn--black-outline:hover {
    color: #fff;
    background-color: #000;
  }
}
.user-is-tabbing .btn--black-outline:focus {
  border-color: #000;
}

.btn--transparent {
  backdrop-filter: blur(10px);
  color: #fff;
  background-color: transparent;
  border: 1px solid transparent;
}
@media (hover: hover) and (pointer: fine) {
  .btn--transparent:hover {
    color: #fff;
    border-color: #fff;
  }
}
.user-is-tabbing .btn--transparent:focus {
  background-color: rgba(0, 0, 0, 0.2);
  color: #fff;
  border-color: #757575;
}

.btn--double-outline {
  color: #fff;
  background-color: rgba(0, 0, 0, 0.6);
  border: 1px solid #fff;
  border-radius: 2px;
  outline: 1px solid #fff;
  outline-offset: 5px;
}
@media (hover: hover) and (pointer: fine) {
  .btn--double-outline:hover {
    color: #000;
    background-color: #fff;
    border: 1px solid #fff;
    outline: 1px solid #fff;
  }
}

.btn--text, :where([data-component*=dialog] [data-ref=cancel]) {
  color: var(--theme-color);
  background-color: transparent;
  margin: 0;
  text-decoration: none;
  border: none;
  border-radius: 0;
  padding: 0;
}
@media (hover: hover) and (pointer: fine) {
  .btn--text:hover, :hover:where([data-component*=dialog] [data-ref=cancel]) {
    color: var(--theme-color);
    background-color: transparent;
    text-decoration: underline;
  }
}

.btn:has(.o-icon), :has(.o-icon):where([data-component*=dialog] menu button) {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.btn:has(.o-icon) .o-icon, :has(.o-icon):where([data-component*=dialog] menu button) .o-icon {
  flex-shrink: 0;
}

.btn--outline-black {
  color: #000;
  background-color: transparent;
  border-color: #000;
}
@media (hover: hover) and (pointer: fine) {
  .btn--outline-black:hover {
    color: #fff;
    border-color: #000;
    background-color: #000;
  }
}
.user-is-tabbing .btn--outline-black:focus {
  color: #fff;
  border-color: #000;
  background-color: #000;
}

.btn--outline-white {
  color: #fff;
  background-color: transparent;
  border-color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .btn--outline-white:hover {
    color: #000;
    background-color: #fff;
    border-color: #fff;
  }
}
.user-is-tabbing .btn--outline-white:focus {
  color: #000;
  border-color: #fff;
}

.btn--outline-primary {
  background-color: transparent;
  color: #fff;
  border-color: #262687;
}
@media (hover: hover) and (pointer: fine) {
  .btn--outline-primary:hover {
    color: #000;
    background-color: #fff;
  }
}
.user-is-tabbing .btn--outline-primary:focus {
  color: #000;
  border-color: #000;
  background-color: #fff;
}

.btn--loading {
  background-image: linear-gradient(-45deg, #262687, #262687 25%, rgba(38, 38, 135, 0.8) 25%, rgba(38, 38, 135, 0.8) 50%, #262687 50%, #262687 75%, rgba(38, 38, 135, 0.8) 75%, rgba(38, 38, 135, 0.8));
  background-color: #000;
  animation: loadingButton 1s linear infinite;
  background-size: 4em 4em;
  color: white;
  cursor: progress;
}
@media (hover: hover) and (pointer: fine) {
  .btn--loading:hover {
    background-color: #000;
    cursor: progress;
  }
}

.btn--auto {
  color: var(--gradient-text-color-inverse, var(--theme-highlight-color-inverse, #fff));
  background-color: var(--gradient-text-color, var(--theme-highlight-color, #000));
  border-color: var(--gradient-text-color, var(--theme-highlight-color, #000));
}
@media (hover: hover) and (pointer: fine) {
  .btn--auto:hover, .btn--auto:focus {
    color: var(--gradient-text-color, var(--theme-highlight-color, #fff));
    background-color: transparent;
    border-color: var(--gradient-text-color, var(--theme-highlight-color, #000));
  }
}

.btn--pause > div, .btn--pause-mobile {
  display: flex;
}
.btn--pause-desktop {
  display: none;
}
@media (min-width: 50em) {
  .btn--pause-desktop {
    display: flex;
  }
  .btn--pause-mobile {
    display: none;
  }
}

.btn--pause-desktop {
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  gap: 10px;
  margin: 0;
  padding: 10px 15px;
  border: 0;
  border-radius: 30px;
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  background: transparent;
  cursor: pointer;
  z-index: 3;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.btn--pause-desktop .o-icon {
  color: #fff;
  height: 30px;
  width: 30px;
  transition: color 0.3s ease;
}
.btn--pause-desktop:hover {
  background-color: var(--theme-color);
  color: var(--theme-body-text-color);
}
.btn--pause-desktop:hover .o-icon {
  color: var(--theme-body-text-color);
}

.btn--pause-mobile {
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  background-color: transparent;
  color: #fff;
  z-index: 3;
  margin: 0 0 0 auto;
}
.btn--pause-mobile .o-icon {
  color: #fff;
  height: 35px;
  width: 35px;
  margin-right: 5px;
}

@keyframes loadingButton {
  to {
    background-position: 4em 0;
  }
}
/* ==========================================================================
   Objects: Blocks
   ========================================================================== */
.o-slats {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-bottom: 0;
}

.o-slats__item {
  display: block;
  font-weight: normal;
  padding: 0.5em 0;
  border-bottom: 1px solid #6A6A6A;
}
.o-slats__item:last-of-type {
  border-bottom: none;
}

/* ==========================================================================
   Object: Figures
   ========================================================================== */
.o-figure {
  position: relative;
  margin: 0;
}

.o-figure__media {
  width: 100%;
}

.o-figure__caption {
  font-size: 80%;
  margin: 0;
  position: absolute;
  bottom: 8px;
  left: 8px;
  padding: 0.3em 0.5em;
  background-color: rgba(0, 0, 0, 0.4);
  color: white;
}

/* ==========================================================================
   Object: Embeds
   ========================================================================== */
.o-embed {
  height: 0;
  position: relative;
  /*  Default 3:2 aspect-ratio */
  padding-bottom: 0.6666666667;
}

.o-embed--video {
  /*  16:9 aspect-ratio for video */
  padding-bottom: 0.5625;
}

.o-embed__iframe {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ==========================================================================
   Globals
   ========================================================================== */
/* ==========================================================================
Global Alert
========================================================================== */
.global-alerts__alert {
  background-color: var(--theme-color);
  color: var(--theme-body-text-color);
  display: none;
}

.global-alerts__alert.visible {
  display: flex;
}
.nav-open .global-alerts__alert.visible, .global-container:has(.event-sticky-nav.show) .global-alerts__alert.visible {
  display: none;
}

.global-alerts__alert + .global-alerts__alert {
  border-top: 1px solid #fff;
}

.global-alert__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px;
  position: relative;
  width: 100%;
  font-size: 12px;
}
@media (min-width: 50em) {
  .global-alert__inner {
    font-size: 14px;
  }
}

.global-alert__message {
  text-align: left;
  text-transform: none;
  width: calc(100% - 35px);
  margin: 0;
  font-weight: 500;
}
@media (min-width: 50em) {
  .global-alert__message {
    padding: 0 70px 0 60px;
    text-align: center;
  }
}
.global-alert__message p:last-child {
  margin-bottom: 0;
}
.global-alert__message a {
  text-decoration: underline;
  font-weight: 700;
}

.global-alert__close {
  display: flex;
  align-items: center;
  font-family: inherit;
  appearance: none;
  border: 0;
  background: none;
  cursor: pointer;
  padding: 0;
  line-height: 9px;
  color: #fff;
}
@media (min-width: 50em) {
  .global-alert__close {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
  }
}
.global-alert__close .o-icon {
  width: 16px;
  height: 16px;
}
.user-is-tabbing .global-alert__close:focus {
  outline: 2px solid #000;
}

/* ==========================================================================
    Global Footer
    ========================================================================== */
.global-footer {
  background-color: #fff;
  color: #000;
  position: relative;
  padding: 25px 0 0;
  z-index: 4;
  width: 100%;
  border-top: 1px solid #000;
}

.global-footer__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .global-footer__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.global-footer__inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
}
@media (max-width: 49.99em) {
  .global-footer__inner .global-footer__logo-wrapper,
  .global-footer__inner .global-footer__top {
    order: 1;
  }
  .global-footer__inner .global-footer__newsletter {
    order: 2;
  }
  .global-footer__inner .global-footer__info {
    order: 4;
  }
  .global-footer__inner .global-footer__nav {
    order: 3;
  }
  .global-footer__inner .global-footer__sponsors {
    order: 5;
  }
  .global-footer__inner .global-footer__copy {
    order: 6s;
  }
  .global-footer__inner .global-footer__footer {
    order: 7;
  }
}

.global-footer__logo-wrapper {
  width: 100%;
  padding: 40px 0 30px;
  display: flex;
  align-items: center;
  gap: 30px;
  flex-wrap: wrap;
}
@media (min-width: 50em) {
  .global-footer__logo-wrapper {
    gap: 40px;
  }
}

.global-footer__info {
  width: 100%;
  position: relative;
  border-top: 1px solid #E7E7E7;
  padding: 30px 0;
}
@media (max-width: 49.99em) {
  .global-footer__info {
    border-top: none;
    padding: 0 0 30px;
  }
}

.global-footer__info-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}

.global-footer__info-title {
  font-weight: 600;
}

.global-footer__info-copy a {
  text-decoration: underline;
}
.global-footer__info-copy p {
  margin-bottom: 0;
}

.global-footer__nav {
  width: 100%;
  border-top: 1px solid #E7E7E7;
  padding: 30px 0;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
@media (min-width: 50em) {
  .global-footer__nav {
    align-items: center;
    flex-direction: row;
  }
}

.global-footer__nav-list {
  width: 100%;
}
@media (min-width: 62.5em) {
  .global-footer__nav-list {
    display: flex;
    justify-content: flex-start;
    gap: 30px;
  }
}

.global-footer__content {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.global-footer__copy {
  border-top: 1px solid #E7E7E7;
  padding: 30px 0 0;
  width: 100%;
  font-size: 14px;
}
@media (min-width: 62.5em) {
  .global-footer__copy {
    font-size: 16px;
    padding: 30px 0 20px;
  }
}

.global-footer__copy-inner {
  max-width: 900px;
  font-weight: 500;
  font-family: Faktum Wide, sans-serif;
}
@media (min-width: 62.5em) {
  .global-footer__copy-inner {
    font-size: 16px;
  }
}

.footer-sponsor {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 30px;
  text-align: center;
  width: fit-content;
  min-height: 75px;
  padding: 0;
}
@media (min-width: 62.5em) {
  .footer-sponsor {
    width: auto;
  }
}

.footer-sponsor__item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  flex: 1;
  gap: 10px;
  padding: 20px 0;
}
@media (min-width: 50em) {
  .footer-sponsor__item {
    align-items: center;
    gap: 25px;
    padding: 0;
  }
}

img.footer-sponsor__image {
  display: block;
  width: auto;
  height: auto;
  max-height: 70px;
  max-width: 100px;
}
@media (min-width: 80em) {
  img.footer-sponsor__image {
    max-width: 130px;
    max-height: 90px;
  }
}

.global-footer h3 {
  font-size: 18px;
  margin-bottom: 10px;
  font-family: Faktum Wide, sans-serif;
}

.global-footer__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 25px;
  text-align: center;
  width: 100%;
  padding-bottom: 25px;
  margin-bottom: 25px;
  border-bottom: 1px solid;
}
@media (min-width: 50em) {
  .global-footer__header {
    flex-direction: row;
    justify-content: space-between;
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
}
@media (min-width: 62.5em) {
  .global-footer__header {
    gap: 100px;
  }
}

.global-footer__logo {
  width: 170px;
  height: 50px;
  margin-bottom: 15px;
  display: block;
}
@media (min-width: 50em) {
  .global-footer__logo {
    margin-bottom: 0;
  }
}
@media (min-width: 72em) {
  .global-footer__logo {
    width: 200px;
    height: 70px;
  }
}
.global-footer__logo svg {
  width: 100%;
  height: 100%;
}

.user-is-tabbing .global-footer a:focus {
  outline-color: #fff;
}

.global-footer__social {
  display: flex;
  gap: 20px;
  justify-content: flex-start;
  text-align: center;
  width: 100%;
}
@media (min-width: 50em) {
  .global-footer__social {
    text-align: left;
    width: auto;
    justify-content: center;
  }
}
@media (max-width: 49.99em) {
  .global-footer__social {
    border-top: 1px solid #E7E7E7;
    padding-top: 30px;
  }
}
.global-footer__social:hover .o-icon {
  opacity: 0.4;
}

.social-link {
  background-color: var(--theme-color, #262687);
  padding: 10px;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.social-link .o-icon {
  height: 20px;
  width: 20px;
  transition: opacity 0.4s ease;
  fill: #fff;
}
.social-link:hover .o-icon {
  opacity: 1;
}

.global-footer__links {
  width: 100%;
  margin-bottom: 0;
}
@media (max-width: 49.99em) {
  .global-footer__links {
    margin-bottom: 40px;
  }
}

.global-footer__links-header {
  border-bottom: 1px solid #000;
  padding-bottom: 10px;
}

.footer-links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (min-width: 50em) {
  .footer-links {
    flex-direction: row;
  }
}

.footer-links__item {
  display: flex;
}

.footer-links__link {
  --focus-color: #000;
  --link-color: #000;
  color: var(--link-color);
  font-size: 14px;
  font-weight: 600;
  text-decoration: underline;
}
@media (hover: hover) and (pointer: fine) {
  .footer-links__link:hover {
    text-decoration: none;
  }
}

.global-footer__newsletter {
  display: flex;
  justify-content: center;
  width: 100%;
}
@media (min-width: 50em) {
  .global-footer__newsletter {
    justify-content: flex-start;
  }
}

.global-footer__footer {
  width: 100%;
}

.global-footer__footer-inner {
  color: #000;
  width: 100%;
  padding: 0 0 30px;
}
@media (min-width: 50em) {
  .global-footer__footer-inner {
    display: flex;
    justify-content: space-between;
    padding: 30px 0;
    border-top: 1px solid #E7E7E7;
  }
}

.global-footer__meta {
  align-items: center;
  display: flex;
  gap: 0 30px;
  width: 100%;
}
@media (min-width: 62.5em) {
  .global-footer__meta {
    width: auto;
  }
}
@media (min-width: 72em) {
  .global-footer__meta {
    gap: 0 40px;
  }
}

.global-footer__copyright {
  font-size: 14px;
  margin-bottom: 0;
}

.global-footer__logos {
  display: flex;
  padding-bottom: 40px;
  flex-wrap: wrap;
  gap: 20px 40px;
}
.global-footer__logos .o-icon--sponsor-cuyahoga {
  width: 70px;
  height: 70px;
}
.global-footer__logos .o-icon--sponsor-ohio-arts {
  width: 150px;
  height: 70px;
}
@media (min-width: 50em) {
  .global-footer__logos {
    gap: 20px 80px;
  }
}
@media (min-width: 62.5em) {
  .global-footer__logos {
    padding-bottom: 60px;
  }
}

@media (max-width: 49.99em) {
  .global-footer__made {
    margin-top: 10px;
    display: inline-block;
  }
}
.global-footer__made .o-icon {
  width: 50px;
  height: 20px;
}

.footer-newsletter {
  padding: 0 0 30px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 50em) {
  .footer-newsletter {
    flex-direction: row;
    padding: 30px 0;
  }
}
.footer-newsletter .footer-newsletter__body {
  width: 100%;
  max-width: 600px;
}
@media (min-width: 50em) {
  .footer-newsletter .footer-newsletter__body {
    width: 50%;
  }
}
.footer-newsletter .footer-newsletter__body-title {
  font-weight: 700;
}
@media (min-width: 50em) {
  .footer-newsletter .footer-newsletter__body-title {
    font-size: 26px;
  }
}
.footer-newsletter .footer-newsletter__body-text {
  font-weight: 500;
}
.footer-newsletter .footer-newsletter__form {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  gap: 20px;
  font-size: 14px;
  width: 100%;
}
@media (max-width: 49.99em) {
  .footer-newsletter .footer-newsletter__form {
    flex-wrap: wrap;
  }
}
@media (min-width: 50em) {
  .footer-newsletter .footer-newsletter__form {
    width: 50%;
  }
}
.footer-newsletter .footer-newsletter__form .footer-newsletter__label {
  font-weight: 500;
  width: calc(50% - 10px);
}
.footer-newsletter .footer-newsletter__form .footer-newsletter__input {
  padding: 10px 5px;
  border: 2px solid #E7E7E7;
  border-radius: 3px;
  font-size: 14px;
  width: 100%;
  margin-top: 5px;
}
.footer-newsletter .footer-newsletter__form .footer-newsletter__button {
  background-color: var(--theme-color, #262687);
  border-radius: 30px;
  border: none;
  width: 170px;
  height: 42px;
  font-weight: 700;
  color: #fff;
  font-size: 14px;
  font-family: Faktum Wide, sans-serif;
  padding: 10px 5px;
}
@media (max-width: 49.99em) {
  .footer-newsletter .footer-newsletter__form .footer-newsletter__button {
    width: 100%;
  }
}

/* ==========================================================================
    Global Footer - Theme overwrites
    ========================================================================== */
body.theme-pink .footer-newsletter .footer-newsletter__form .footer-newsletter__button, body.theme-pink .social-link {
  background-color: var(--theme-highlight-color);
}

body.theme-peach .footer-newsletter .footer-newsletter__form .footer-newsletter__button, body.theme-peach .social-link {
  background-color: var(--theme-highlight-color);
}

body.theme-light-blue .footer-newsletter .footer-newsletter__form .footer-newsletter__button, body.theme-light-blue .social-link {
  background-color: var(--theme-highlight-color);
}

/* ==========================================================================
    Global Footer - Pre-Launch Newsletter Fix
    ========================================================================== */
@media (min-width: 59em) {
  .global-footer__top {
    display: flex;
    align-items: flex-end;
  }
  .global-footer__top .global-footer__logo-wrapper {
    width: 40%;
  }
  .global-footer__top .global-footer__newsletter {
    width: 60%;
  }
  .global-footer__top .footer-newsletter {
    align-items: center;
    gap: 20px;
  }
  .global-footer__top .footer-newsletter__body-title {
    font-size: 22px;
  }
}
.global-footer__top .footer-newsletter {
  gap: 10px;
}
.global-footer__top .footer-newsletter__body {
  width: unset;
  max-width: unset;
}
.global-footer__top .footer-newsletter__body-text {
  margin-bottom: 0;
}
.global-footer__top .footer-newsletter__button {
  cursor: pointer;
}

/*  ==========================================================================
    Global Header
    ========================================================================== */
.global-header {
  --link-color: #000;
  box-sizing: border-box;
  position: relative;
  z-index: 8;
  background-color: #fff;
}
@media (min-width: 72em) {
  .global-header {
    width: 100%;
    transition: background-color 0.4s ease;
  }
}

.global-header__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .global-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.global-header__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 15px;
  padding-bottom: 15px;
  z-index: 2;
  gap: 20px;
}

.global-header__wrapper {
  flex-grow: 1;
}

.global-header__logo {
  border: none;
  z-index: 2;
  position: relative;
}
.user-is-tabbing .global-header__logo:focus {
  outline: 2px solid #fff;
  outline-offset: 2px;
}
.global-header__logo .o-icon {
  height: 45px;
  width: 148px;
  fill: var(--link-color);
}
@media (min-width: 72em) {
  .global-header__logo .o-icon {
    height: 50px;
    width: 165px;
  }
}

.global-header__tag {
  display: flex;
  align-items: flex-end;
  gap: 30px;
}
@media (min-width: 80em) {
  .global-header__tag {
    gap: 60px;
  }
}

.header-tag {
  display: none;
}
@media (min-width: 59em) {
  .header-tag {
    display: block;
  }
}
.header-tag .header-tag__title {
  font-size: 16px;
  line-height: 1;
  margin: 0 0 8px;
  font-weight: 600;
  font-family: Faktum Wide, sans-serif;
}
@media (min-width: 72em) {
  .header-tag .header-tag__title {
    font-size: 20px;
  }
}
.header-tag .header-tag__subtitle {
  margin: 0;
  line-height: 1;
  font-size: 12px;
}
@media (min-width: 72em) {
  .header-tag .header-tag__subtitle {
    font-size: 16px;
  }
}

/*  ==========================================================================
    Global Header - Search
    ========================================================================== */
.global-header__search {
  display: none;
  padding: 7px 30px;
  background-color: rgba(255, 255, 255, 0.2);
  position: relative;
  border-radius: 3px;
}
@media (min-width: 50em) {
  .global-header__search {
    display: flex;
    align-items: center;
    min-width: 300px;
  }
}
@media (min-width: 72em) {
  .global-header__search {
    min-width: 400px;
  }
}

.global-header__search-input {
  color: #fff;
  background-color: transparent;
  border: 1px solid transparent;
  border-width: 0 0 1px;
  padding: 5px 10px 5px 20px;
  width: 100%;
  transition: border-bottom-color 0.3s ease;
  font-size: 14px !important;
}
.global-header__search-input:focus {
  outline: none;
  border-bottom-color: rgba(38, 38, 135, 0.2);
}
.global-header__search-input::placeholder {
  color: #fff;
}

.global-header__search-submit {
  color: #fff;
  background-color: transparent;
  border: none;
  padding: 0;
  margin-top: -2px;
  position: absolute;
  left: 20px;
}
.global-header__search-submit:focus {
  outline: 1px solid var(--theme-color-dark);
}
.global-header__search-submit .o-icon {
  width: 15px;
  height: 15px;
}

/*  ==========================================================================
    Global Header - Toolbar
    ========================================================================== */
.global-header__toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  z-index: -1;
}
@media (min-width: 50em) {
  .global-header__toolbar {
    margin-bottom: 20px;
  }
}

.global-header__tools {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 3;
  gap: 15px;
  transition: opacity 0.4s ease;
}
@media (min-width: 30em) {
  .global-header__tools {
    gap: 20px;
  }
}
@media (min-width: 80em) {
  .global-header__tools {
    gap: 25px;
  }
}

.global-header__button {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--link-color);
  background-color: transparent;
  padding: 0;
  border: none;
  transition: opacity 0.3s ease;
  cursor: pointer;
}
.global-header__button .o-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  transition: transform 0.3s ease;
}
@media (min-width: 50em) {
  .global-header__button .o-icon {
    width: 16px;
    height: 16px;
  }
}
.user-is-tabbing .global-header__button:focus {
  outline: 2px solid var(--link-color);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  .global-header__button:hover .o-icon {
    transform: scale(1.1);
  }
}

.global-header__button-text {
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
}
@media (max-width: 49.99em) {
  .global-header__button-text {
    display: none;
  }
}

body.user-logged-in .global-header__login {
  display: none;
}

.global-header__account {
  border: 0;
  padding: 0;
  background: none;
  cursor: pointer;
  display: none;
}
@media (min-width: 50em) {
  .global-header__account {
    display: flex;
  }
}

.global-header__button--account.is-toggled .o-icon--chevron {
  transition: transform 0.3s ease;
}

.global-header__account-menu {
  position: relative;
  display: none;
  transition: opacity 0.3s ease;
}
@media (max-width: 31.99em) {
  .global-header__account-menu {
    display: flex;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    width: 0;
    height: 0;
  }
  .nav-open .global-header__account-menu {
    position: fixed;
    left: 15px;
    top: 22px;
    overflow: visible;
  }
  .nav-open .global-header__account-menu .global-header__button-text {
    height: auto;
    position: relative;
    width: auto;
    clip: revert;
    margin: 0 0 0 2px;
  }
}
.global-header__account-menu .o-icon--chevron-down {
  width: 7px;
  height: 10px;
  transition: none;
}
.global-header__account-menu .is-toggled .o-icon--chevron-down {
  transform: rotate(180deg);
}

@media (max-width: 31.99em) {
  body.user-logged-in.nav-open .global-header__account-menu {
    opacity: 1;
    visibility: visible;
    width: auto;
    height: auto;
  }
}
@media (min-width: 32em) {
  body.user-logged-in .global-header__account-menu {
    display: flex;
  }
}

@media (max-width: 31.99em) {
  body.user-logged-out.nav-open .global-header__login {
    opacity: 1;
    visibility: visible;
    width: auto;
    height: auto;
  }
}
@media (min-width: 32em) {
  body.user-logged-out .global-header__login {
    display: flex;
  }
}

.global-header__button--ticket {
  display: flex;
}
.items-in-cart .global-header__button--ticket {
  display: none;
}

.global-header__button--cart svg {
  fill: transparent;
}
.global-header__button--cart {
  position: relative;
  display: none;
}
.items-in-cart .global-header__button--cart {
  display: flex;
}
.global-header__button--cart .cart-number {
  background: var(--theme-color);
  color: var(--theme-body-text-color);
  height: 20px;
  line-height: 19px;
  width: 20px;
  text-align: center;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 600;
  display: none;
}
.items-in-cart .global-header__button--cart .cart-number {
  display: inline-block;
}

.global-header__button--cart .o-icon {
  width: 24px;
  height: 24px;
  margin-right: 0;
  fill: var(--link-color);
}
@media (min-width: 50em) {
  .global-header__button--cart .o-icon {
    width: 16px;
    height: 16px;
  }
}

.global-header__button--search {
  display: none;
}
@media (min-width: 50em) {
  .global-header__button--search {
    display: flex;
  }
}

.global-header__scroll-top {
  align-items: center;
  position: fixed;
  bottom: 15px;
  right: 15px;
  width: 40px;
  height: 40px;
  margin: 0;
  padding: 14px;
  border: 0;
  border-radius: 100%;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
  background-color: #757575;
  z-index: 20;
  cursor: pointer;
}
.global-header__scroll-top:hover {
  background-color: #424242;
}
.global-header__scroll-top .o-icon {
  color: #fff;
}
.global-header__scroll-top {
  /*  stylelint-disable */
}
.global-header__scroll-top.is-toggled {
  /*  0. BEFORE-OPEN STATE  */
}
@starting-style {
  .global-header__scroll-top.is-toggled {
    opacity: 0;
  }
}
.global-header__scroll-top.is-toggled {
  /*  1. IS-OPEN STATE  */
  display: flex;
  opacity: 1;
}
.global-header__scroll-top {
  /*  2. EXIT STATE  */
  opacity: 0;
  display: none;
  transition: background-color 0.4s ease, opacity 0.4s ease, display 0.4s ease;
  transition-behavior: allow-discrete;
  /*  stylelint-enable */
}

/* ==========================================================================
    Global Header - Menu Button
    ========================================================================== */
.global-header__menu {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  border: 0;
  width: 28px;
  height: 32px;
  background: none;
  z-index: 3;
  cursor: pointer;
}
.user-is-tabbing .global-header__menu:focus {
  outline: 2px solid #fff;
  outline-offset: 5px;
}
.global-header__menu span {
  visibility: hidden;
  display: none;
}
@media (min-width: 50em) {
  .global-header__menu span {
    visibility: visible;
    display: inline-block;
    margin-left: 15px;
    color: #fff;
  }
}
@media (min-width: 50em) {
  .global-header__menu {
    display: none;
  }
}

.menu-icon {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: transparent;
  border: hidden;
  width: 100%;
  transition: all 250ms ease-in-out;
}

.menu-icon__line {
  position: absolute;
  width: 100%;
  height: 2.5px;
  background-color: var(--link-color);
  transition: all 0.3s ease-out;
}

.menu-icon__line--1 {
  transform: translateY(-7px);
}

.menu-icon__line--2 {
  transform: translateY(7px);
}

.global-header__menu.is-toggled .menu-icon__line--1 {
  transform: translateY(0) rotate(45deg) scaleX(1.05);
}
.global-header__menu.is-toggled .menu-icon__line--2 {
  transform: translateY(0) rotate(-45deg) scaleX(1.05);
}
.global-header__menu.is-toggled .menu-icon__line--3 {
  opacity: 0;
}

.global-header__dropdown-menu {
  position: absolute;
  background-color: #fff;
  left: 0;
  top: 0px;
  width: 100vw;
  height: 100svh;
  z-index: 0;
  opacity: 0;
  transition: opacity 0.3s ease;
}
body.nav-open .global-header__dropdown-menu {
  opacity: 1;
}
@media (min-width: 72em) {
  .global-header__dropdown-menu {
    display: none;
  }
}
.global-header__dropdown-menu .header__navigation {
  display: block;
}
.global-header__dropdown-menu .header__navigation .desktop-navigation {
  margin-top: 150px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.global-header__dropdown-menu .header__navigation .desktop-navigation .desktop-navigation__item {
  display: block;
  margin: 25px 0;
}
.global-header__dropdown-menu .header__navigation .desktop-navigation .desktop-navigation__item .desktop-navigation__link:before {
  display: block;
  margin-right: 0;
  width: 0px;
  height: 0px;
}

/*  ==========================================================================
    Global Header - Navigation
    ========================================================================== */
.global-header__navigation {
  margin: 0 auto;
  display: none;
}
@media (min-width: 72em) {
  .global-header__navigation {
    display: block;
  }
}

.desktop-navigation {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0 30px;
}
@media (min-width: 72em) {
  .desktop-navigation {
    flex-direction: row;
  }
}

.desktop-navigation__item {
  display: inline-block;
}

.desktop-navigation__link {
  text-transform: uppercase;
  position: relative;
  font-size: 22px;
  font-weight: 500;
  font-family: Faktum, sans-serif;
  color: var(--link-color);
  transition: color 0.4s ease;
  position: relative;
  transition: color 0.4s ease;
}
.desktop-navigation__link:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -5px;
  width: 100%;
  height: 3px;
  background-color: var(--link-color, #fff);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  .desktop-navigation__link:hover:before {
    transform: scaleX(100%);
  }
}
.desktop-navigation__link:hover {
  color: var(--link-color);
  text-decoration: none;
}

.desktop-navigation__item--active .desktop-navigation__link:before {
  transform: scaleX(100%);
}

/* ==========================================================================
    Global Header - Transparent
    ========================================================================== */
.global-header.global-header--transparent {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.89), rgba(0, 0, 0, 0.3) 35%, rgba(5, 242, 108, 0) 50%);
  --link-color: #fff;
}
.global-container:has(.global-navigation.is-toggled) .global-header.global-header--transparent {
  background: transparent;
}
@media (min-width: 62.5em) {
  .global-header.global-header--transparent {
    --link-color: #fff;
  }
}
@media (min-width: 72em) {
  .global-header.global-header--transparent {
    background: transparent;
    --link-color: #000;
  }
  .global-header.global-header--transparent.header-scroll {
    --link-color: #fff;
  }
}

/* ==========================================================================
    Global Header - Account Menu
    ========================================================================== */
.account-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  right: -10px;
  top: 40px;
  width: 280px;
  opacity: 0;
  visibility: hidden;
  box-shadow: 7px 10px 9px rgba(0, 0, 0, 0.1490196078);
  border-radius: 10px;
  transition: opacity 0.5s ease;
}
.account-menu.is-toggled {
  opacity: 1;
  visibility: visible;
}
@media (min-width: 50em) {
  .account-menu {
    top: 40px;
    right: -100%;
  }
}
.account-menu:before {
  content: "";
  position: absolute;
  top: -6px;
  right: 14px;
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid #fff;
}
@media (min-width: 50em) {
  .account-menu:before {
    right: 19px;
  }
}

.account-menu__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px;
  background-color: #fff;
  position: relative;
  cursor: default;
}
.account-menu__header:after {
  content: "";
  width: calc(100% - 30px);
  position: absolute;
  bottom: 0;
  left: 15px;
  border-top: 1px solid #000;
}

.account-menu__greeting {
  font-size: 16px;
  margin: 0;
}

.account-menu__logout.js-append-returnurl {
  text-decoration: underline;
  font-size: 14px;
}

.account-menu__item:first-child .account-menu__link {
  border-radius: 5px 10px 0 0;
}
@media (min-width: 32em) {
  .account-menu__item:first-child .account-menu__link {
    border-radius: 10px 10px 0 0;
  }
}

.account-menu__link {
  display: block;
  font-weight: bold;
  padding: 15px;
  background-color: #fff;
  transition: background-color 0.3s ease;
  outline-offset: -4px;
}
.account-menu__link:hover, .account-menu__link:focus {
  background-color: #E7E7E7;
}

.account-menu__item--logout {
  padding: 10px 15px;
  background-color: #000;
  border-radius: 0 0 10px 10px;
  text-align: right;
}
.account-menu__item--logout .account-menu__link {
  background-color: transparent;
  padding: 0 0 3px;
  border-bottom: 2px solid transparent;
  color: #fff;
}
.account-menu__item--logout .account-menu__link, .account-menu__item--logout .account-menu__link:focus {
  outline: none;
}
.account-menu__item--logout:has(.account-menu__link:focus-visible) {
  outline: 2px solid #fff;
  outline-offset: -5px;
}

/*  ==========================================================================
    Global Header - Nav Open
    ========================================================================== */
body.nav-open .global-header {
  --link-color: #fff;
  background-color: transparent;
}

/*  ==========================================================================
    Global Navs
    ========================================================================== */
.global-navs {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  overflow-y: auto;
  z-index: 7;
}
.global-navs .global-nav-desktop,
.global-navs .global-nav-desktop__overlay {
  display: none;
}
@media (min-width: 72em) {
  .global-navs .global-nav-mobile {
    display: none;
  }
  .global-navs .global-nav-desktop,
  .global-navs .global-nav-desktop__overlay {
    display: block;
  }
}
.global-navs {
  /*  stylelint-disable */
}
.global-navs.is-toggled {
  /*  0. BEFORE-OPEN STATE  */
}
@starting-style {
  .global-navs.is-toggled {
    transform: translateX(-100%);
  }
}
.global-navs.is-toggled {
  /*  1. IS-OPEN STATE  */
  display: block;
  transform: translateX(0%);
}
.global-navs {
  /*  2. EXIT STATE  */
  transform: translateX(-100%);
  display: none;
  transition: transform 0.7s ease, display 0.7s ease;
  transition-behavior: allow-discrete;
  /*  stylelint-enable */
}

/*  ==========================================================================
    Global Navigation - Mobile
    ========================================================================== */
.global-nav-mobile {
  position: fixed;
  top: 0;
  left: 0;
  height: 100svh;
  width: 100%;
  background-color: #000;
  transform: translateX(-100%);
  transition: transform 0.5s ease;
  overflow: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.global-nav-mobile::-webkit-scrollbar-thumb, .global-nav-mobile::-webkit-scrollbar, .global-nav-mobile::-webkit-scrollbar-track {
  background-color: transparent;
  display: none;
}
.global-navs.is-toggled .global-nav-mobile {
  transform: translateX(0);
}

.global-nav-mobile__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.global-nav-mobile__search {
  display: flex;
  align-items: center;
  padding: 15px 15px 20px;
}

.global-nav-mobile__search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}
.global-nav-mobile__search-wrapper .o-icon {
  position: absolute;
  right: 0;
  width: 20px;
  height: 20px;
  color: #fff;
}
.global-nav-mobile__search-wrapper:after {
  position: absolute;
  content: "";
  background-color: #fff;
  height: 1px;
  width: 100%;
  right: 0;
  bottom: 0;
}

.global-nav-mobile__search-input {
  color: #fff;
  background-color: transparent;
  border: 0;
  outline: 0;
  padding: 10px 40px 10px 0;
  width: 100%;
  transition: border-bottom-color 0.3s ease;
}
.user-is-tabbing .global-nav-mobile__search-input:focus {
  outline: 2px solid #fff;
}
.global-nav-mobile__search-input::placeholder {
  color: rgba(255, 255, 255, 0.8);
}

.global-nav-mobile__search-submit {
  color: #000;
  background-color: transparent;
  border: none;
  padding: 0;
  margin-left: 15px;
}
.global-nav-mobile__search-submit:focus {
  outline: 2px solid var(--theme-color-dark);
}

.global-nav-mobile__buttons {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
  z-index: 2;
}
.global-nav-mobile__buttons .o-icon {
  width: 20px;
  height: 20px;
  color: #3d3d3d;
}

.global-nav-mobile__buttons-inner {
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  margin-top: 20px;
  padding-top: 30px;
  width: 100%;
}

.global-nav-mobile__footer {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
  color: #fff;
  justify-content: space-around;
}
.global-nav-mobile__footer .o-icon {
  width: 20px;
  height: 20px;
  color: #fff;
}

.global-nav-mobile__link {
  padding: 10px;
  text-align: center;
  font-weight: 700;
  display: flex;
  align-content: center;
  gap: 10px;
}

.global-nav-mobile__button {
  width: 100%;
}

/*  ==========================================================================
     Global Navigation - Mobile Nav
    ========================================================================== */
.global-nav-mobile {
  padding-top: var(--global-header-height);
}
.global-nav-mobile .global-nav-mobile__items {
  flex: 1;
}
.global-nav-mobile .global-nav {
  position: relative;
  height: 100%;
  width: 100%;
  overflow: hidden;
  overflow-y: auto;
}
.global-nav-mobile .global-nav__inner {
  height: 100%;
  width: 100%;
  overflow: visible;
}
.global-nav-mobile .global-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 100%;
  top: 0;
  padding: 5px 15px 0 15px;
  transform: translate3d(0, 0, 0);
  transition: transform 0.3s ease;
  z-index: 1;
  -webkit-overflow-scrolling: touch;
}
.global-nav-mobile .global-nav__list:not(.is-active) {
  overflow: initial;
  -webkit-overflow-scrolling: touch;
}
.global-nav-mobile .global-nav__list > ul:first-child {
  height: auto;
  background-color: #fff;
}
.global-nav-mobile .global-nav__account {
  border-top: 1px dashed rgba(255, 255, 255, 0.2);
  padding-top: 25px;
  margin-top: 40px;
}
.global-nav-mobile .global-nav__account .global-nav__link {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.global-nav-mobile .global-nav__account-arrow {
  margin-top: -5px;
}
.global-nav-mobile .global-nav__description {
  font-size: 14px;
  margin-top: 10px;
  padding-right: 40px;
}
.global-nav-mobile .global-nav__item.has-child > ul > .global-nav__item.has-child.global-nav__item--active > ul > li > ul {
  overflow-y: auto;
}
.global-nav-mobile .global-nav__list.global-nav--level-0 {
  left: 0;
}
.global-nav-mobile .global-nav__list.is-active {
  transform: translate3d(-100%, 0, 0);
}
.global-nav-mobile .global-nav__item--active > .global-nav__child {
  z-index: 2;
}
.global-nav-mobile .global-nav__item:not(.global-nav__item--active) ul {
  display: none;
}
.global-nav-mobile .global-nav__item.global-nav__item--active > ul {
  display: block;
}
.global-nav-mobile .global-nav__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  word-break: break-word;
}
.global-nav-mobile .global-nav__item-arrow {
  color: #fff;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
@media (min-width: 62.5em) {
  .global-nav-mobile .global-nav__item-arrow {
    width: 40px;
    height: 40px;
  }
}
.global-nav-mobile .global-nav__item-arrow .o-icon {
  width: 24px;
  height: 24px;
}
.global-nav-mobile .global-nav__item--back {
  margin-top: 20px;
  padding-bottom: 15px;
  border-bottom: 1px solid #fff;
}
.global-nav-mobile .global-nav__link {
  font-weight: 400;
  font-size: 20px;
  line-height: 1;
  color: #fff;
  padding: 15px 0;
  font-family: Faktum Wide, sans-serif;
}
.global-nav-mobile .global-nav__link:visited, .global-nav-mobile .global-nav__link:active {
  color: #fff;
}
.global-nav-mobile .global-nav__back {
  display: flex;
  gap: 10px;
  align-items: center;
  border: none;
  margin: 0;
  padding: 0;
  background: transparent;
  font-weight: 400;
  font-size: 14px;
  text-transform: uppercase;
  color: #fff;
  font-family: Faktum Wide, sans-serif;
  appearance: none;
}
.global-nav-mobile .global-nav__back::-moz-focus-inner {
  border: 0;
  padding: 0;
}
.global-nav-mobile .global-nav__back .o-icon {
  width: 16px;
  height: 16px;
}
.global-nav-mobile .global-nav--level-0 > .global-nav__item > .global-nav__link {
  font-family: Faktum Wide, sans-serif;
}
.global-nav-mobile .global-nav--level-1 .global-nav__item-arrow .o-icon,
.global-nav-mobile .global-nav--level-2 .global-nav__item-arrow .o-icon,
.global-nav-mobile .global-nav--level-3 .global-nav__item-arrow .o-icon {
  color: #fff;
  width: 20px;
  height: 20px;
}
.global-nav-mobile .global-nav--level-2 .global-nav__item.has-child {
  flex-direction: column;
  align-items: flex-start;
}
.global-nav-mobile .global-nav--level-3 {
  margin-top: 20px;
}
.global-nav-mobile .global-nav--level-3.global-nav__child {
  display: block !important;
  position: static;
  transform: none;
  max-height: none;
  border-left: 1px solid #bfbebd;
  padding-top: 0;
  padding-left: 15px;
  margin: 10px 0;
  margin-left: 15px;
}
.global-nav-mobile .global-nav--level-3 .global-nav__link {
  padding: 10px 0;
  font-size: 16px;
}
.global-nav-mobile .global-nav-footer__item {
  position: relative;
}
.global-nav-mobile .global-nav-footer__item .global-nav-footer__link {
  display: block;
  padding-top: 15px;
  color: #fff;
  font-size: 20px;
  font-weight: 300;
}
.global-nav-mobile .global-nav-footer__item:nth-child(1 of .global-nav-footer__item) {
  margin-top: 20px;
}
.global-nav-mobile .global-nav-footer__item:nth-child(1 of .global-nav-footer__item):after {
  position: absolute;
  content: "";
  background-color: #bfbebd;
  height: 1px;
  width: 120px;
  top: 0;
  left: 0;
}

/*  ==========================================================================
    Global Navigation - Desktop
    ========================================================================== */
.global-nav-desktop__inner {
  display: flex;
  height: 100%;
}

.global-nav-desktop__search {
  display: flex;
  align-items: center;
  padding: 15px 15px 20px;
}

.global-nav-desktop__search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}
.global-nav-desktop__search-wrapper .o-icon {
  position: absolute;
  left: 0;
  width: 20px;
  height: 20px;
  color: #000;
  opacity: 0.5;
}

.global-nav-desktop__search-input {
  color: #000;
  background-color: transparent;
  border: 1px solid #000;
  border-width: 0 0 1px;
  padding: 10px 0 10px 60px;
  width: 100%;
  transition: border-bottom-color 0.3s ease;
}
.user-is-tabbing .global-nav-desktop__search-input:focus {
  outline: 2px solid #000;
  border-bottom-color: #262687;
}
.global-nav-desktop__search-input::placeholder {
  color: rgba(0, 0, 0, 0.5);
}

.global-nav-desktop__search-submit {
  color: #000;
  background-color: transparent;
  border: none;
  padding: 0;
  margin-left: 15px;
}
.user-is-tabbing .global-nav-desktop__search-submit:focus {
  outline: 2px solid #000;
}

.global-nav-desktop__buttons {
  display: flex;
  align-items: center;
  gap: 15px;
  background-color: #262687;
  padding: 15px;
  text-transform: uppercase;
  z-index: 2;
}
.global-nav-desktop__buttons .o-icon {
  width: 20px;
  height: 20px;
}

/*  ==========================================================================
     Global Navigation - Desktop Nav
    ========================================================================== */
.global-nav-desktop {
  display: none;
}
@media (min-width: 50em) {
  .global-nav-desktop {
    display: block;
  }
}
.global-nav-desktop .global-nav {
  position: relative;
}
.global-nav-desktop .global-nav__list {
  display: flex;
  justify-content: flex-end;
  gap: 20px;
}
@media (min-width: 72em) {
  .global-nav-desktop .global-nav__list {
    gap: 40px;
  }
}
@media (min-width: 80em) {
  .global-nav-desktop .global-nav__list {
    gap: 60px;
  }
}
.global-nav-desktop .global-nav__item.has-child > ul > .global-nav__item.has-child.global-nav__item--active > ul > li > ul {
  overflow-y: auto;
}
.global-nav-desktop .global-nav__list.global-nav--level-0 {
  position: static;
}
.global-nav-desktop .global-nav__list.global-nav--level-0 > .child-nav-desktop__item > .child-nav-desktop__link {
  font-family: Faktum, sans-serif;
  color: #000;
  font-weight: 600;
}
.global-nav-desktop .global-nav__list.global-nav--level-0 > .child-nav-desktop__item > .child-nav-desktop__item-arrow .o-icon {
  color: #000;
}
.global-nav-desktop .global-nav__list.global-nav--level-0 > .child-nav-desktop__item > .child-nav-desktop__item-arrow:hover {
  transform: translateX(10px);
}
.user-is-tabbing .global-nav-desktop .global-nav__list.global-nav--level-0 > .child-nav-desktop__item-arrow:focus {
  outline: 2px solid #000;
  outline-offset: 2px;
}
.global-nav-desktop .child-nav-desktop__item > ul:not(.child-nav-desktop__nested) {
  display: block;
  position: absolute;
  top: 0;
  left: 100%;
  height: 100%;
  width: 100%;
  max-width: 30vw;
  padding: 30px 40px 40px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateX(-100%);
  transition: all 0.4s ease;
}
.global-nav-desktop .child-nav-desktop__item > ul:not(.child-nav-desktop__nested)[aria-hidden=true] {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.global-nav-desktop .child-nav-desktop__item > ul:not(.child-nav-desktop__nested)[aria-hidden=false] {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.global-nav-desktop .child-nav-desktop__item.nav-desktop__item--active > ul {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
  transform: translateX(0%);
}
.global-nav-desktop .child-nav-desktop__item.nav-desktop__item--active .child-nav-desktop__nested {
  display: block;
  position: static;
  top: auto;
  left: auto;
  height: auto;
  width: auto;
  max-width: none;
  margin: 5px 0;
}
.global-nav-desktop .child-nav-desktop__item.nav-desktop__item--active .child-nav-desktop__nested[aria-hidden=true] {
  display: none;
}
.global-nav-desktop .child-nav-desktop__item.nav-desktop__item--active .child-nav-desktop__nested[aria-hidden=false] {
  display: block;
}
.global-nav-desktop .child-nav-desktop__item.nav-desktop__item--active > .child-nav-desktop__item-arrow {
  transform: translateX(10px);
}
.global-nav-desktop .child-nav-desktop__item {
  display: block;
}
.global-nav-desktop .child-nav-desktop__item-arrow {
  color: #fff;
  background-color: transparent;
  padding: 0;
  margin: 0;
  border: none;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transform: translateX(0);
  transition: transform 0.4s ease;
}
@media (min-width: 62.5em) {
  .global-nav-desktop .child-nav-desktop__item-arrow {
    width: 40px;
    height: 40px;
  }
}
.global-nav-desktop .child-nav-desktop__item-arrow .o-icon {
  width: 24px;
  height: 24px;
}
.user-is-tabbing .global-nav-desktop .child-nav-desktop__item-arrow:focus {
  outline: 2px solid #fff;
  outline-offset: 2px;
}
.global-nav-desktop .child-nav-desktop__item--back {
  margin-top: 20px;
  padding-bottom: 15px;
  border-bottom: 2px solid #bfbebd;
}
.global-nav-desktop .child-nav-desktop__link {
  font-weight: 600;
  font-size: 14px;
  line-height: 1;
  color: #fff;
  padding: 15px 0;
  transition: color 0.4s ease;
}
@media (min-width: 62.5em) {
  .global-nav-desktop .child-nav-desktop__link {
    font-size: 16px;
  }
}
.global-nav-desktop .child-nav-desktop__link:visited, .global-nav-desktop .child-nav-desktop__link:active {
  color: #fff;
}
.user-is-tabbing .global-nav-desktop .child-nav-desktop__link:focus {
  outline: 2px solid #fff;
  outline-offset: 2px;
}
.global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__link,
.global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__link,
.global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__link {
  font-size: 20px;
  color: #000;
}
@media (min-width: 90em) {
  .global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__link,
  .global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__link,
  .global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__link {
    font-size: 22px;
  }
}
.user-is-tabbing .global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__link:focus,
.user-is-tabbing .global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__link:focus,
.user-is-tabbing .global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__link:focus {
  outline: 2px solid #000;
  outline-offset: 2px;
}
.global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__item-arrow,
.global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__item-arrow,
.global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__item-arrow {
  transform: translateX(0);
}
.global-nav-desktop .child-nav-desktop--level-1 .nav-desktop__item--active .child-nav-desktop__item-arrow,
.global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__item-arrow:hover,
.global-nav-desktop .child-nav-desktop--level-2 .nav-desktop__item--active .child-nav-desktop__item-arrow,
.global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__item-arrow:hover,
.global-nav-desktop .child-nav-desktop--level-3 .nav-desktop__item--active .child-nav-desktop__item-arrow,
.global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__item-arrow:hover {
  transform: translateX(10px);
}
.user-is-tabbing .global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__item-arrow:focus,
.user-is-tabbing .global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__item-arrow:focus,
.user-is-tabbing .global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__item-arrow:focus {
  outline: 2px solid #000;
  outline-offset: 2px;
}
.global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__item-arrow .o-icon,
.global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__item-arrow .o-icon,
.global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__item-arrow .o-icon {
  width: 20px;
  height: 20px;
  color: #000;
}
@media (min-width: 90em) {
  .global-nav-desktop .child-nav-desktop--level-1 .child-nav-desktop__item-arrow .o-icon,
  .global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__item-arrow .o-icon,
  .global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__item-arrow .o-icon {
    width: 22px;
    height: 22px;
  }
}
.global-nav-desktop .child-nav-desktop--level-1 {
  z-index: -1;
}
.global-nav-desktop .child-nav-desktop--level-1:before {
  position: absolute;
  content: "";
  background-color: #262687;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: -1;
}
.global-nav-desktop .child-nav-desktop--level-2 {
  z-index: -2;
}
.global-nav-desktop .child-nav-desktop--level-2:before {
  position: absolute;
  content: "";
  background-color: #fff;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  z-index: -1;
}
.global-nav-desktop .child-nav-desktop--level-2 .child-nav-desktop__item {
  flex-direction: column;
  align-items: flex-start;
}
.global-nav-desktop .child-nav-desktop--level-3 {
  margin-top: 20px;
}
.global-nav-desktop .child-nav-desktop--level-3.child-nav-desktop__child {
  display: block !important;
  position: static;
  transform: none;
  max-height: none;
  border-left: 1px solid #bfbebd;
  padding-top: 0;
  padding-left: 15px;
  margin: 10px 0;
  margin-left: 15px;
}
.global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__link {
  padding: 10px 0;
  font-size: 16px;
}
.user-is-tabbing .global-nav-desktop .child-nav-desktop--level-3 .child-nav-desktop__link:focus {
  outline: 2px solid #000;
  outline-offset: 2px;
}
.global-nav-desktop .child-nav-desktop__nested {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-top: 10px;
}
.global-nav-desktop .child-nav-desktop__nested.child-nav-desktop__nested--level-1 {
  border-left: 2px solid #bfbebd;
  padding-left: 15px;
}
.global-nav-desktop .child-nav-desktop__nested.child-nav-desktop__nested--level-2 {
  border-left: 1px solid #d0d0d0;
  padding-left: 20px;
}
.global-nav-desktop .child-nav-desktop__nested.child-nav-desktop__nested--level-3 {
  border-left: 1px solid #e0e0e0;
  padding-left: 25px;
}
.global-nav-desktop .child-nav-desktop__nested-item {
  margin-bottom: 5px;
}
.global-nav-desktop .child-nav-desktop__nested-link {
  display: block;
  margin: 5px 0;
  padding: 5px 0;
  font-size: 18px;
  color: #000;
  text-decoration: none;
}
.global-nav-desktop .child-nav-desktop__nested-link:visited, .global-nav-desktop .child-nav-desktop__nested-link:active {
  color: #000;
}
.user-is-tabbing .global-nav-desktop .child-nav-desktop__nested-link:focus {
  outline: 2px solid #000;
  outline-offset: 2px;
}
.global-nav-desktop .child-nav-desktop__nested-link + ul .child-nav-desktop__nested-link {
  font-size: 16px;
}
.global-nav-desktop .global-nav-footer__item {
  position: relative;
}
.global-nav-desktop .global-nav-footer__item .global-nav-footer__link {
  display: block;
  margin-top: 15px;
  color: #fff;
  font-size: 20px;
  font-weight: 300;
}
.user-is-tabbing .global-nav-desktop .global-nav-footer__item .global-nav-footer__link:focus {
  outline: 2px solid #fff;
  outline-offset: 2px;
}
.global-nav-desktop .global-nav-footer__item:nth-child(1 of .global-nav-footer__item) {
  margin-top: 30px;
  padding-top: 10px;
}
.global-nav-desktop .global-nav-footer__item:nth-child(1 of .global-nav-footer__item):after {
  position: absolute;
  content: "";
  background-color: #bfbebd;
  height: 1px;
  width: 120px;
  top: 0;
  left: 0;
}

/*  ==========================================================================
    Global Navigation - Desktop Overlay
    ========================================================================== */
.global-nav-desktop__overlay {
  position: fixed;
  height: 100svh;
  width: 100%;
  z-index: 6;
  visibility: visible;
  top: 0;
  left: 0;
  z-index: 0;
}
body:not(.nav-open) .global-nav-desktop__overlay {
  visibility: hidden;
}

/*  ==========================================================================
	Global Navigation
	========================================================================== */
.global-search {
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100svh;
  z-index: 11;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
}
.global-search.is-toggled {
  opacity: 1;
  visibility: visible;
}

.global-search__close {
  position: absolute;
  top: 20px;
  right: 20px;
  background-color: transparent;
  border: none;
  padding: 0;
  color: #fff;
  cursor: pointer;
}

.global-search__form {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  padding: 0 15px;
  width: 100%;
  max-width: 500px;
}
@media (min-width: 50em) {
  .global-search__form {
    margin-top: -80px;
  }
}

.global-search__field {
  width: 100%;
  position: relative;
}

.global-search__label {
  width: 100%;
  color: #fff;
  font-size: var(--global-header-size-h4);
  font-weight: bold;
  margin-bottom: 10px;
  text-align: center;
  justify-content: center;
}

.global-search__input {
  width: 100%;
  height: 50px;
  line-height: 50px;
  padding: 0 70px 0 20px;
  border-radius: 30px;
  border: none;
  height: auto;
  border: 1px solid #fff;
  font-family: Faktum, sans-serif;
  appearance: none;
}
.global-search__input:focus {
  outline: none;
  border-color: var(--theme-color);
}

.global-search__submit {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 20px;
  background-color: transparent;
  border: none;
  z-index: 2;
  padding: 0;
}
.global-search__submit .o-icon {
  width: 25px;
  height: 25px;
}

/* ==========================================================================
   Modules
   ========================================================================== */
@custom-media --small-viewport (width >=576px);
@custom-media --medium-small-viewport (width > 768px);
@custom-media --medium-viewport (width >=992px);
@custom-media --large-viewport (width >=1200px);
.glightbox-container {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999999 !important;
  overflow: hidden;
  touch-action: none;
  -webkit-text-size-adjust: 100%;
  -webkit-backface-visibility: hidden;
  outline: none;
  overflow: hidden;
}
.glightbox-container.inactive {
  display: none;
}
.glightbox-container .gcontainer {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 9999;
  overflow: hidden;
}
.glightbox-container .gslider {
  transition: transform 0.4s ease;
  height: 100%;
  left: 0;
  top: 0;
  width: 100%;
  position: relative;
  overflow: hidden;
  display: flex !important;
  justify-content: center;
  align-items: center;
  transform: translate3d(0, 0, 0);
}
.glightbox-container .gslide {
  width: 100%;
  position: absolute;
  opacity: 1;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  /* top: 0;
  left: 0;
  right: 0;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); */
}
.glightbox-container .gslide.current {
  opacity: 1;
  z-index: 99999;
  position: relative;
}
.glightbox-container .gslide.prev {
  opacity: 1;
  z-index: 9999;
}
.glightbox-container .gslide-inner-content {
  width: 100%;
}
.glightbox-container .ginner-container {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  flex-direction: column;
  max-width: 100%;
  margin: auto;
  height: 100vh;
}
.glightbox-container .ginner-container.gvideo-container {
  width: 100%;
}
@media (--medium-small-viewport) {
  .glightbox-container .ginner-container {
    width: auto;
    height: auto;
    flex-direction: row;
  }
}
.glightbox-container .ginner-container.desc-bottom, .glightbox-container .ginner-container.desc-top {
  flex-direction: column;
}
.glightbox-container .ginner-container.desc-left, .glightbox-container .ginner-container.desc-right {
  max-width: 100% !important;
}
@media (--medium-small-viewport) {
  .glightbox-container .ginner-container.desc-top .gslide-description {
    order: 0;
  }
  .glightbox-container .ginner-container.desc-top .gslide-image,
  .glightbox-container .ginner-container.desc-top .gslide-image img {
    order: 1;
  }
}
@media (--medium-small-viewport) {
  .glightbox-container .ginner-container.desc-left .gslide-description {
    order: 0;
  }
  .glightbox-container .ginner-container.desc-left .gslide-image {
    order: 1;
  }
}

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

.gslide-image {
  align-items: center;
}
.gslide-image img {
  max-height: 100vh;
  display: block;
  max-width: 100%;
  margin: 0;
  padding: 0;
  float: none;
  outline: none;
  border: none;
  user-select: none;
  max-width: 100vw;
  width: auto;
  height: auto;
  object-fit: cover;
  touch-action: none;
  margin: auto;
  min-width: 200px;
}
@media (--medium-small-viewport) {
  .gslide-image img {
    max-height: 97vh;
    max-width: calc(100% - 20px);
    max-width: 100%;
  }
}
.desc-top .gslide-image img, .desc-bottom .gslide-image img {
  width: auto;
}
.desc-left .gslide-image img, .desc-right .gslide-image img {
  width: auto;
  max-width: 100%;
}
.gslide-image img.zoomable {
  position: relative;
}
@media (--medium-small-viewport) {
  .gslide-image img.zoomable {
    cursor: zoom-in;
  }
  .zoomed .gslide-image img.zoomable {
    cursor: grab;
  }
}
.gslide-image img.dragging {
  cursor: grabbing !important;
  transition: none;
}

.gslide-video {
  width: 100%;
  max-width: 100%;
  position: relative;
  width: 100vh;
  max-width: 100vh;
  width: 100% !important;
  margin: auto;
}
.gslide-video .gvideo-wrapper {
  width: 100%;
  /* max-width: 160vmin; */
  margin: auto;
}
.gslide-video:before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(255, 0, 0, 0.34);
  display: none;
}
.gslide-video.playing:before {
  display: none;
}
.gslide-video.fullscreen {
  max-width: 100% !important;
  min-width: 100%;
}
.gslide-video.fullscreen video {
  max-width: 100% !important;
  width: 100% !important;
}

.plyr--video .plyr__control:hover {
  opacity: 0.5;
  background-color: transparent;
}
.plyr--video .plyr__control:focus {
  background-color: transparent;
}

.plyr--video .plyr__control.plyr__control--overlaid, .plyr--video .plyr__control.plyr__control--overlaid:hover, .plyr--video .plyr__control.plyr__control--overlaid.plyr__tab-focus {
  opacity: 1;
  overflow: hidden;
  width: 84px;
  height: 84px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border: 2px solid #fff;
  transition: color 0.4s ease;
  box-shadow: none;
  background-color: transparent;
}

.plyr--full-ui input[type=range] {
  color: var(--theme-color);
}

.gslide-inline {
  background: #fff;
  padding: 20px;
  text-align: left;
  max-height: calc(100vh - 40px);
  height: auto;
  overflow: auto;
  width: 90%;
  max-width: 600px;
  margin: auto;
}
.gslide-inline.gslide-media {
  width: 90%;
}
@media (--medium-small-viewport) {
  .gslide-inline {
    max-height: 95vh;
  }
}

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

.gslide-external {
  display: flex;
  width: 100%;
  min-width: 100%;
  background: #fff;
  padding: 0;
  overflow: auto;
  max-height: 62vh;
}
@media (--medium-small-viewport) {
  .gslide-external {
    max-height: 95vh;
  }
}

.gslide-media {
  display: block;
  display: inline-flex;
  display: flex;
  width: auto;
}
.zoomed .gslide-media {
  box-shadow: none !important;
}
.desc-top .gslide-media, .desc-bottom .gslide-media {
  margin: 0 auto;
  flex-direction: column;
}
.gslide-media {
  /* Make the external brightcove video - full height */
}
.gslide-media.gslide-external {
  height: 100%;
}

.gslide-description {
  position: relative;
  display: none;
}
.gslide-description.description-left, .gslide-description.description-right {
  max-width: 100%;
}
@media (--medium-small-viewport) {
  .gslide-description.description-left, .gslide-description.description-right {
    max-width: 275px;
  }
}
.gslide-description.description-bottom, .gslide-description.description-top {
  margin: 0 auto;
  width: 100%;
}
.gslide-description p {
  margin-bottom: 12px;
}
.gslide-description p:last-child {
  margin-bottom: 0;
}
.zoomed .gslide-description {
  display: none;
}

/*
 * Description for mobiles
 * something like facebook does the description
 * for the photos
*/
.glightbox-mobile .glightbox-container .gslide-description {
  height: auto !important;
  width: 100%;
  background: transparent;
  position: absolute;
  bottom: 15px;
  padding: 19px 11px;
  max-width: 100vw !important;
  order: 2 !important;
  max-height: 78vh;
  overflow: auto !important;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.75) 100%);
  transition: opacity 0.3s linear;
  padding-bottom: 50px;
}
.glightbox-mobile .glightbox-container .gslide-title {
  color: #fff;
  font-size: 1em;
}
.glightbox-mobile .glightbox-container .gslide-desc {
  color: #a1a1a1;
}
.glightbox-mobile .glightbox-container .gslide-desc a {
  color: #fff;
  font-weight: bold;
}
.glightbox-mobile .glightbox-container .gslide-desc * {
  color: inherit;
}
.glightbox-mobile .glightbox-container .gslide-desc .desc-more {
  color: #fff;
  opacity: 0.4;
}

.gdesc-open .gslide-media {
  transition: opacity 0.5s ease;
  opacity: 0.4;
}
.gdesc-open .gdesc-inner {
  padding-bottom: 30px;
}

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

.greset {
  transition: all 0.3s ease;
}

.gabsolute {
  position: absolute;
}

.grelative {
  position: relative;
}

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

.glightbox-open {
  overflow: hidden;
}
@media (--medium-small-viewport) {
  .glightbox-open {
    height: auto;
  }
}

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

.goverlay {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
  will-change: opacity;
}
.gprev,
.gnext,
.gclose {
  background-repeat: no-repeat;
  z-index: 99999;
  cursor: pointer;
  width: 26px;
  height: 44px;
  display: block;
  background-position: 0 0;
  border: none;
}
.gprev svg,
.gnext svg,
.gclose svg {
  display: block;
  width: 100%;
  height: auto;
}
.gprev.disabled,
.gnext.disabled,
.gclose.disabled {
  opacity: 0.1;
}
.gprev .garrow,
.gnext .garrow,
.gclose .garrow {
  stroke: #fff;
}

iframe.wait-autoplay {
  opacity: 0;
}

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

@media (--medium-small-viewport) {
  .glightbox-clean .gslide-media,
  .glightbox-modern .gslide-media {
    box-shadow: 1px 2px 9px rgba(0, 0, 0, 0.65);
  }
}
.glightbox-clean .gslide-description,
.glightbox-modern .gslide-description {
  background: #fff;
}
.glightbox-clean .gdesc-inner,
.glightbox-modern .gdesc-inner {
  padding: 22px 20px;
}
.glightbox-clean .gslide-title,
.glightbox-modern .gslide-title {
  font-size: 1em;
  font-weight: normal;
  font-family: arial, sans-serif;
  color: #000;
  margin-bottom: 19px;
  line-height: 1.4em;
}
.glightbox-clean .gslide-desc,
.glightbox-modern .gslide-desc {
  font-size: 0.86em;
  margin-bottom: 0;
  font-family: arial, sans-serif;
  line-height: 1.4em;
}
.glightbox-clean .gslide-video,
.glightbox-modern .gslide-video {
  background: #000;
}
.glightbox-clean,
.glightbox-modern {
  /* .gprev,
  .gnext,
  .gclose{
      border: none;
      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGMAAAA2CAYAAADTeCfRAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyFpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNS1jMDE0IDc5LjE1MTQ4MSwgMjAxMy8wMy8xMy0xMjowOToxNSAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIE1hY2ludG9zaCIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDo5NThDMEMwNzg3NjgxMUU1QUM2MUYwRDYwNTNEN0UxMSIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo5NThDMEMwODg3NjgxMUU1QUM2MUYwRDYwNTNEN0UxMSI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOjk1OEMwQzA1ODc2ODExRTVBQzYxRjBENjA1M0Q3RTExIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjk1OEMwQzA2ODc2ODExRTVBQzYxRjBENjA1M0Q3RTExIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+htE8KwAAA9BJREFUeNrsm1tIFGEYhndDI4OSLgqkMrKjBXYwCjt40QkpL4pMyoqMgigIgm6iiy66KSwpj2vrucKgpINRRhYRooQkWYEWUkaWERokhVQXbu/QOyDhpjPzz3H/Dx7W1f2+753/3X9mnPnHHwqFfDKcEWPkEEgzZEgzpBkybDbjHLhvIP8GKLNhPILgksEaFaDKKWacAMdAn4Ean8F+kGOxGXFgDyjSmZ8L9oFpurKVU1uBnAr9jZMCah1hrQLBGkciyL7FGvNymXdZb2+RG3GGYo4LrHmINS9abEiZRkMu8PNXjPQVJV4Vc9SEgclm7WqLDSkd5RdBiBGizCihmMMmDkwWe1yz2JBy9g2E+ft5o7smkWZUUMwBCwYmg71u2nQMCZhphFEzaihmt4UDk86e9TYZUsj3OaKNMGJGHcVkWjwoChvZ+7HFfQvZt42vpaJ76Em6SzHbbDBCZR01NFvct519u8yorzXhEcWk2WiESiq1tFrUT901veZrnp1mNFHEWgcYoZJMTe0m98ljn3K+z+f7oB1mtLD5agcZoZJEbZ3Ab0J9deCrwpzSB6004xWbLnegESqJ1NgNok04aFeF+XtA5MF8pA90stkiBxuhkkCtvSBGQL2iEYz415Bys8yIAu/ZZKELjFCJp+Z+EGugTgHrVGq8ClEm2oxZ4CUYAHNcZIRKHOjj6ed8A8eISo15xUaPIcP9spFFk11ohMp0bkOHxrxa5lXo7Ksack9Pvn+YpTqLwS0QDZbxRo+bYgJoBZPAZtCiIVe5QzceZBroXwP8YKfWRH+YdVOx4AOYCOJBt0uMUAz4BGLAVNDjhXvg/bwF2UdTElywLVOoN5o/97hsRv/3HvgAv10fwVuQ6ODtUO45f6HmyaDXi6tDfoMZNKMdJDlwG2ZyN/qVs/mbl5fqDILZoAO8AMkO0j8XvONJhjKLf0TKuqkF4Dl4BlY6QLty1vcGdHE39SvSFrEtBc2gCWywUfcKfjE6eHIxGKkrCleBRvAApNmgOQU8BW2crRG/vDMV1JN0C/WmcmYqZizxeSyMLO/cBG6DOyDDAq3rwRPOyhSfB8PoWtst4DrJMlGnYnwDeMjZ4c0QdGGumhfIsk246LeVtetcfOFyVEQJ8nQv+AkqwThQIqjuDnAV1ILtPo9HlMBaB/kfewCMBfkG6ylL85VnJZSroLt8kRAmTLezOpfUD+W0WQvFnIzfpEePlaeO5oE1OvOVp56+R8KuaWiYZYYMG05tZUgzpBkypBnSDBnSDGmGDGmGDGmGNEOGNEOaIUOa4YH4I8AAM9m8BFEzyDIAAAAASUVORK5CYII=');
  } */
}
.glightbox-clean .gprev,
.glightbox-clean .gnext,
.glightbox-clean .gclose,
.glightbox-modern .gprev,
.glightbox-modern .gnext,
.glightbox-modern .gclose {
  background-color: rgba(0, 0, 0, 0.12);
}
.glightbox-clean .gprev path,
.glightbox-clean .gnext path,
.glightbox-clean .gclose path,
.glightbox-modern .gprev path,
.glightbox-modern .gnext path,
.glightbox-modern .gclose path {
  fill: #fff;
}
.glightbox-clean button:focus:not(.focused):not(.disabled),
.glightbox-modern button:focus:not(.focused):not(.disabled) {
  outline: none;
}
.glightbox-clean .gprev,
.glightbox-modern .gprev {
  position: absolute;
  top: -100%;
  left: 30px;
  width: 40px;
  height: 56px;
}
@media (--medium-small-viewport) {
  .glightbox-clean .gprev,
  .glightbox-modern .gprev {
    top: 45%;
  }
}
.glightbox-clean .gnext,
.glightbox-modern .gnext {
  position: absolute;
  top: -100%;
  right: 30px;
  width: 40px;
  height: 56px;
}
@media (--medium-small-viewport) {
  .glightbox-clean .gnext,
  .glightbox-modern .gnext {
    top: 45%;
  }
}
.glightbox-clean .gclose,
.glightbox-modern .gclose {
  display: flex;
  align-items: center;
  position: fixed;
  top: 5px;
  right: 10px;
  width: auto;
  gap: 5px;
  background-color: transparent;
}
@media (min-width: 50em) {
  .glightbox-clean .gclose,
  .glightbox-modern .gclose {
    top: 20px;
    right: 20px;
  }
}
.glightbox-clean .gclose:before,
.glightbox-modern .gclose:before {
  content: "";
  z-index: 20;
  position: absolute;
  top: 5px;
  right: 10px;
  border: none;
  cursor: pointer;
  padding: 0;
  mask-image: url("/assets/close-circle.svg");
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: 100%;
  width: 23px;
  height: 23px;
  border-radius: 50%;
  background-color: var(--theme-color-light);
  transition: background-color 0.4s ease;
}
@media (min-width: 50em) {
  .glightbox-clean .gclose:before,
  .glightbox-modern .gclose:before {
    top: 20px;
    right: 20px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .glightbox-clean .gclose:before:hover,
  .glightbox-modern .gclose:before:hover {
    background-color: #fff;
  }
}
.glightbox-clean .gclose:before,
.glightbox-modern .gclose:before {
  position: relative;
  right: unset !important;
  top: 1px !important;
  transition: background-color 0.4s ease;
}
.glightbox-clean .gclose:after,
.glightbox-modern .gclose:after {
  content: "Close";
  display: flex;
  align-items: center;
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  transition: color 0.4s ease;
}
@media (min-width: 50em) {
  .glightbox-clean .gclose:after,
  .glightbox-modern .gclose:after {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .glightbox-clean .gclose:after,
  .glightbox-modern .gclose:after {
    font-size: 22px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .glightbox-clean .gclose:hover:before,
  .glightbox-modern .gclose:hover:before {
    background-color: #fff;
  }
  .glightbox-clean .gclose:hover:after,
  .glightbox-modern .gclose:hover:after {
    color: #fff;
  }
}
.glightbox-clean .gclose svg,
.glightbox-modern .gclose svg {
  display: none;
}

.gfadeIn {
  animation: gfadeIn 0.5s ease;
}

.gfadeOut {
  animation: gfadeOut 0.5s ease;
}

.gslideOutLeft {
  animation: gslideOutLeft 0.3s ease;
}

.gslideInLeft {
  animation: gslideInLeft 0.3s ease;
}

.gslideOutRight {
  animation: gslideOutRight 0.3s ease;
}

.gslideInRight {
  animation: gslideInRight 0.3s ease;
}

.gzoomIn {
  animation: gzoomIn 0.5s ease;
}

.gzoomOut {
  animation: gzoomOut 0.5s ease;
}

@keyframes lightboxLoader {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes gfadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes gfadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes gslideInLeft {
  0% {
    opacity: 0;
    transform: translate3d(-60%, 0, 0);
  }
  100% {
    visibility: visible;
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes gslideOutLeft {
  0% {
    opacity: 1;
    visibility: visible;
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-60%, 0, 0);
    opacity: 0;
    visibility: hidden;
  }
}
@keyframes gslideInRight {
  0% {
    opacity: 0;
    visibility: visible;
    transform: translate3d(60%, 0, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes gslideOutRight {
  0% {
    opacity: 1;
    visibility: visible;
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(60%, 0, 0);
    opacity: 0;
  }
}
@keyframes gzoomIn {
  0% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  100% {
    opacity: 1;
  }
}
@keyframes gzoomOut {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  100% {
    opacity: 0;
  }
}
/*  ==========================================================================
    Dialog
    ========================================================================== */
:where(dialog) {
  border: 0;
}
:where(dialog)::backdrop {
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
}

:where(dialog) button[data-dialog-close] {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  gap: 5px;
  font-size: var(--global-button-size);
  font-weight: 400;
  flex-shrink: 0;
  transition: color 0.4s ease, background-color 0.4s ease;
  cursor: pointer;
}
:where(dialog) button[data-dialog-close] .o-icon {
  width: 23px;
  height: 23px;
  position: relative;
}

/* ==========================================================================
   Forms
   ========================================================================== */
:root {
  --global-input-size: 16px;
}
@media (min-width: 50em) {
  :root {
    --global-input-size: 18px;
  }
}

input[type=email],
input[type=number],
input[type=text],
input[type=tel],
input[type=url],
input[type=date],
input[type=search],
textarea,
select {
  font-size: 14px;
  font-family: Faktum, sans-serif;
}

.form-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  padding: 15px;
  max-width: 920px;
  display: flex;
  align-self: center;
  margin: 20px 0;
}
@media (min-width: 50em) {
  .form-wrapper {
    margin: var(--content-margin-small);
    margin-left: auto;
    margin-right: auto;
  }
}

.form-group {
  box-sizing: border-box;
  width: calc(var(--field-width) * 1% - 8px);
}
.form-group[style*="--field-width: 100"] {
  width: 100%;
}
@media (max-width: 42.49em) {
  .form-group {
    width: 100%;
  }
}

.form-label {
  display: block;
  font-weight: 500;
  text-transform: capitalize;
}

.checkbox-group {
  margin-top: 15px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 15px;
}
@media (min-width: 30em) {
  .checkbox-group {
    grid-template-columns: repeat(2, 1fr);
  }
}

.form-input {
  width: 100%;
  margin-top: 5px;
  box-sizing: border-box;
}
.form-input:focus {
  outline: none;
}
.form-input:focus-visible {
  outline: -webkit-focus-ring-color auto 1px;
}

.form-input--checkbox,
.form-input--radio {
  width: auto;
  margin: 0;
}

.radio-group {
  margin-top: 15px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 15px;
}
@media (min-width: 30em) {
  .radio-group {
    grid-template-columns: repeat(2, 1fr);
  }
}

.form-select {
  width: 100%;
  margin-top: 5px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20fill%3D%22black%22%20viewBox%3D%220%200%2018%2012%22%3E%3Cpath%20d%3D%22M8.995%2011.286a.927.927%200%200%200%20.694-.305l8.021-8.341a.945.945%200%200%200%20.28-.672C18%201.42%2017.596%201%2017.057%201c-.26%200-.497.105-.674.273L8.446%209.508h1.108L1.617%201.273A.94.94%200%200%200%20.943%201C.404%201%200%201.42%200%201.968c0%20.264.093.497.28.683l8.02%208.33c.208.208.497.305.705.305Z%22/%3E%3C/svg%3E");
  background-position: right 12px center;
  background-repeat: no-repeat;
  background-size: 16px;
  padding-right: 40px;
  cursor: pointer;
  padding-left: 5px;
}
.form-select::-ms-expand {
  display: none;
}
.form-select:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 #000;
}

.form-select,
.form-input,
.form-textarea {
  padding: 10px;
  border: 2px solid #E7E7E7;
  border-radius: 3px;
  font-size: 14px;
  font-family: Faktum, sans-serif;
  background-color: #fff;
  height: 46px;
  box-sizing: border-box;
}
.form-select:focus,
.form-input:focus,
.form-textarea:focus {
  outline: none;
}
.form-select:focus-visible,
.form-input:focus-visible,
.form-textarea:focus-visible {
  outline: -webkit-focus-ring-color auto 1px;
}
.form-select[placeholder],
.form-input[placeholder],
.form-textarea[placeholder] {
  text-transform: capitalize;
}

.form-textarea {
  width: 100%;
  min-height: 120px;
  resize: vertical;
}

.form-message {
  padding: 15px;
  background-color: #F4F4F4;
  border-radius: 3px;
  color: #181822;
}
.form-message p {
  margin: 0;
}

.form-submit__button {
  margin: 1rem 0 0 auto;
}

/* ==========================================================================
   Animated Checkbox Styles
   ========================================================================== */
@keyframes check {
  0% {
    height: 0;
    width: 0;
  }
  25% {
    height: 0;
    width: 6px;
  }
  50% {
    height: 12px;
    width: 6px;
  }
}
@keyframes checkBig {
  0% {
    height: 0;
    width: 0;
  }
  25% {
    height: 0;
    width: 7px;
  }
  50% {
    height: 15px;
    width: 7px;
  }
}
.form-label--checkbox {
  position: relative;
  padding-left: 33px;
  cursor: pointer;
  display: inline-block;
  margin-bottom: 5px;
}
.form-label--checkbox .form-input--checkbox {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.form-label--checkbox:before {
  content: "";
  width: 22px;
  height: 22px;
  position: absolute;
  background-color: transparent;
  border: 2px solid #E7E7E7;
  border-radius: 3px;
  left: 0;
  top: 0;
  transition: all 0.3s ease;
}
.form-label--checkbox:after {
  border-right: 2px solid transparent;
  border-top: 2px solid transparent;
  transform: scaleX(-1) rotate(135deg);
  transform-origin: left top;
  content: "";
  display: block;
  height: 15px;
  width: 7px;
  left: 3px;
  top: 12px;
  position: absolute;
  transition: border-color 0.4s;
}
.form-label--checkbox:has(.form-input--checkbox:checked):before {
  background-color: #262687;
  border-color: #262687;
}
.form-label--checkbox:has(.form-input--checkbox:checked):after {
  animation: checkBig 0.8s;
  border-color: #fff;
}

/* ==========================================================================
   Animated Radio Styles
   ========================================================================== */
.form-label--radio {
  position: relative;
  padding-left: 33px;
  cursor: pointer;
  display: inline-block;
  margin-bottom: 5px;
}
.form-label--radio .form-input--radio {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.form-label--radio:before {
  content: "";
  width: 22px;
  height: 22px;
  position: absolute;
  background-color: transparent;
  border: 2px solid #E7E7E7;
  border-radius: 50%;
  left: 0;
  top: 0;
  transition: all 0.3s ease;
}
.form-label--radio:after {
  content: "";
  width: 12px;
  height: 12px;
  position: absolute;
  background-color: transparent;
  border-radius: 50%;
  left: 5px;
  top: 5px;
  transition: all 0.3s ease;
  transform: scale(0);
}
.form-label--radio:has(.form-input--radio:checked):before {
  background-color: #262687;
  border-color: #262687;
}
.form-label--radio:has(.form-input--radio:checked):after {
  background-color: #fff;
  transform: scale(1);
}
.form-label--radio:has(.form-input--radio:focus):before {
  outline: none;
}
.form-label--radio:has(.form-input--radio:focus-visible):before {
  outline: -webkit-focus-ring-color auto 1px;
}

/*  ==========================================================================
    Themes and Gradients
    ========================================================================== */
.theme-primary {
  --theme-color: #262687;
  --theme-body-text-color: #fff;
  --theme-body-text-color-inverse: #000;
}

.theme-indigo {
  --theme-color: #262687;
  --theme-body-text-color: #fff;
  --theme-body-text-color-inverse: #000;
}

.theme-dark-purple {
  --theme-color: #780F5D;
  --theme-body-text-color: #fff;
  --theme-body-text-color-inverse: #000;
}

.theme-maroon {
  --theme-color: #6E0505;
  --theme-body-text-color: #fff;
  --theme-body-text-color-inverse: #000;
}

.theme-pink {
  --theme-color: #FFC8E0;
  --theme-body-text-color: #000;
  --theme-body-text-color-inverse: #fff;
}

.theme-light-blue {
  --theme-color: #D2E6FF;
  --theme-body-text-color: #000;
  --theme-body-text-color-inverse: #fff;
}

.theme-peach {
  --theme-color: #F7D5A1;
  --theme-body-text-color: #000;
  --theme-body-text-color-inverse: #fff;
}

.theme-light {
  --theme-color: #FFFAF8;
  --theme-body-text-color: #000;
  --theme-body-text-color-inverse: #fff;
}

/*  ==========================================================================
    Theme Feature Colours
    ========================================================================== */
.theme-pink, .theme-peach {
  --theme-highlight-color: #DB1E1E;
  --theme-highlight-text-color: #fff;
}

.theme-indigo {
  --theme-highlight-color: #FFC8E0;
  --theme-highlight-text-color: #fff;
}

.theme-dark-purple {
  --theme-highlight-color: #D2E6FF;
  --theme-highlight-text-color: #000;
}

.theme-maroon {
  --theme-highlight-color: #F7D5A1;
  --theme-highlight-text-color: #000;
}

.theme-light-blue {
  --theme-highlight-color: #5F08C9;
  --theme-highlight-text-color: #fff;
}

.theme-dark-purple .pull-quote,
.theme-maroon .pull-quote,
.theme-indigo .pull-quote {
  color: var(--theme-color);
}

.theme-peach .concert-list-block__previous,
.theme-peach .concert-list-block__next,
.theme-peach .page-list__previous,
.theme-peach .page-list__next,
.theme-peach .venue-scroller__previous,
.theme-peach .venue-scroller__next,
.theme-peach .series-pack-list__previous,
.theme-peach .series-pack-list__next,
.theme-peach .date-selector__button,
.theme-light-blue .concert-list-block__previous,
.theme-light-blue .concert-list-block__next,
.theme-light-blue .page-list__previous,
.theme-light-blue .page-list__next,
.theme-light-blue .venue-scroller__previous,
.theme-light-blue .venue-scroller__next,
.theme-light-blue .series-pack-list__previous,
.theme-light-blue .series-pack-list__next,
.theme-light-blue .date-selector__button,
.theme-pink .concert-list-block__previous,
.theme-pink .concert-list-block__next,
.theme-pink .page-list__previous,
.theme-pink .page-list__next,
.theme-pink .venue-scroller__previous,
.theme-pink .venue-scroller__next,
.theme-pink .series-pack-list__previous,
.theme-pink .series-pack-list__next,
.theme-pink .date-selector__button {
  background-color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .theme-peach .calendar-header__tab--active,
  .theme-light-blue .calendar-header__tab--active,
  .theme-pink .calendar-header__tab--active {
    background-color: var(--theme-highlight-color);
    color: #fff;
  }
}
.theme-peach .concert-list-block .concert-item .concert-item-category,
.theme-light-blue .concert-list-block .concert-item .concert-item-category,
.theme-pink .concert-list-block .concert-item .concert-item-category {
  color: var(--theme-highlight-color);
}
.theme-peach .artist__role,
.theme-peach .person__role,
.theme-light-blue .artist__role,
.theme-light-blue .person__role,
.theme-pink .artist__role,
.theme-pink .person__role {
  color: var(--theme-highlight-color);
}
.theme-peach .series-pack-list__tag,
.theme-light-blue .series-pack-list__tag,
.theme-pink .series-pack-list__tag {
  color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .theme-peach .bio-header__name,
  .theme-light-blue .bio-header__name,
  .theme-pink .bio-header__name {
    color: var(--theme-highlight-color);
  }
}
@media (min-width: 50em) {
  .theme-peach .bio-header__intrinsic-ratio:after,
  .theme-light-blue .bio-header__intrinsic-ratio:after,
  .theme-pink .bio-header__intrinsic-ratio:after {
    background-color: var(--theme-color);
  }
}

/*  ==========================================================================
	Accordion Block
	========================================================================== */
.accordion-block {
  position: relative;
  margin: 30px 0;
}
@media (min-width: 50em) {
  .accordion-block {
    margin: var(--content-margin-small);
  }
}

.accordion-block__inner {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .accordion-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.accordion-block__title {
  margin-bottom: 0;
  padding-top: 10px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  padding-bottom: 15px;
  font-size: 22px;
  border-bottom: 1px solid #dAdAdA;
}
@media (min-width: 50em) {
  .accordion-block__title {
    padding-top: 15px;
    font-size: 26px;
  }
}

.accordion-block__item__header {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .accordion-block__item__header {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.accordion-block__item__header {
  display: flex;
  align-items: center;
  gap: 15px;
  cursor: pointer;
  padding: 15px 0;
  transition: transform 0.3s ease;
  list-style: none;
  box-sizing: border-box;
}
.accordion-block__item__header::-webkit-details-marker {
  display: none;
}
@media (min-width: 50em) {
  .accordion-block__item__header {
    padding: 15px 0;
  }
}
.accordion-block__item__header .o-icon {
  width: 18px;
  height: 18px;
  margin-left: auto;
  flex-shrink: 0;
  rotate: 90deg;
  color: #000;
  transition: rotate 0.4s ease, scale 0.4s ease;
}
.accordion__item--open .accordion-block__item__header .o-icon {
  rotate: -90deg;
}
.accordion-block__item__header:hover .o-icon, .accordion-block__item__header:focus .o-icon {
  scale: 1.1;
}

.accordion-block__item__title {
  font-size: var(--global-body-size-6);
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  margin-bottom: 0;
  line-height: 1.3;
}
@media (min-width: 50em) {
  .accordion-block__item__title {
    font-size: var(--global-body-size-10);
  }
}

.accordion-block__item__subtitle {
  font-size: var(--global-body-size-4);
  font-family: Faktum Wide, sans-serif;
  margin-top: 5px;
}
@media (min-width: 50em) {
  .accordion-block__item__subtitle {
    font-size: var(--global-body-size-7);
  }
}

.accordion-block__name {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 16px;
  text-wrap: pretty;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .accordion-block__name {
    font-size: 22px;
  }
}

.accordion-block__content {
  box-sizing: border-box;
  padding-bottom: 15px;
}
@media (min-width: 50em) {
  .accordion-block__content {
    padding-bottom: 20px;
  }
}
.accordion-block__content ul:first-child {
  margin-top: 0;
}

.accordion-block__prose {
  padding: 0 0 30px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease-in-out;
}
.accordion__item--open .accordion-block__prose {
  opacity: 1;
  visibility: visible;
}
@media (min-width: 50em) {
  .accordion-block__prose {
    padding: 0 0 40px;
  }
}

/*  ==========================================================================
    Rich Text
    ========================================================================== */
.rich-text {
  margin: 30px 0;
}
@media (min-width: 50em) {
  .rich-text {
    margin: 60px 0;
  }
}

.rich-text__inner {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .rich-text__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.error-page {
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 45px 0;
  position: relative;
  overflow: hidden;
}
.error-page .content-panel__body {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}
@media (max-width: 49.99em) {
  .error-page .content-panel__body {
    padding: 0 15px;
  }
}
.error-page:last-child:not(.element:last-child) {
  margin-bottom: 45px;
}
.error-page h1 {
  font-size: 40px;
  font-family: Faktum Wide, sans-serif;
  margin: 0;
}
@media (min-width: 50em) {
  .error-page h1 {
    font-size: 60px;
  }
}
@media (min-width: 72em) {
  .error-page h1 {
    font-size: 80px;
  }
}
.error-page h2 {
  margin-top: 0;
  padding-bottom: 0;
  font-family: Faktum Wide, sans-serif;
  font-size: 26px;
  font-weight: 600;
  border-bottom: none;
}
@media (min-width: 50em) {
  .error-page h2 {
    font-size: 30px;
  }
}
.error-page .s-prose p:not(.quote__text):not(.cta):not(.caption) {
  margin-top: 0;
  font-size: 14px;
}
@media (min-width: 50em) {
  .error-page .s-prose p:not(.quote__text):not(.cta):not(.caption) {
    font-size: 18px;
  }
}
.error-page .rich-text__body {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}
.error-page:before, .error-page:after {
  content: "";
  position: absolute;
  width: 80px;
  height: 53px;
  opacity: 0.6;
  pointer-events: none;
  z-index: 1;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 5px;
}
@media (min-width: 50em) {
  .error-page:before, .error-page:after {
    width: 120px;
    height: 80px;
  }
}
.error-page:before {
  background-image: url("https://images.baskercdn.com/sydneysymphony/media/become-a-member.jpg");
  left: 5%;
  bottom: 30px;
  transform: rotate(-15deg);
  animation: float-left 4.5s ease-in-out infinite;
}
@media (min-width: 50em) {
  .error-page:before {
    left: calc(50% - 300px - 120px - 60px);
    bottom: auto;
    top: 50%;
  }
}
.error-page:after {
  background-image: url("https://images.baskercdn.com/sydneysymphony/media/Dvorak-And-Strauss.jpg");
  right: 5%;
  top: 30px;
  transform: rotate(15deg);
  animation: float-right 3.5s ease-in-out infinite;
  animation-delay: 0.2s;
}
@media (min-width: 50em) {
  .error-page:after {
    width: 135px;
    height: 90px;
    right: calc(50% - 300px - 135px - 60px);
    top: 15%;
  }
}
@keyframes float-left {
  0%, 100% {
    transform: translateY(0) rotate(-15deg);
  }
  50% {
    transform: translateY(-20px) rotate(-15deg);
  }
}
@keyframes float-right {
  0%, 100% {
    transform: translateY(0) rotate(15deg);
  }
  50% {
    transform: translateY(-20px) rotate(15deg);
  }
}

/*  ==========================================================================
    Donation Panel
    ========================================================================== */
.donation-panel {
  position: relative;
}

.donation-panel__inner {
  width: 100%;
}
@media (min-width: 50em) {
  .donation-panel__inner {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

.donation-panel__media {
  overflow: hidden;
  width: 100%;
}

.donation-panel__intrinsic-ratio {
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
}
@media (min-width: 62.5em) {
  .donation-panel__intrinsic-ratio {
    padding-bottom: 50%;
  }
}
@media (min-width: 80em) {
  .donation-panel__intrinsic-ratio {
    padding-bottom: 33.3333333333%;
  }
}

.donation-panel__image {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}

.donation-panel__details {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding: 20px 20px 30px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  background: var(--theme-highlight-color, #262687);
  color: var(--theme-body-text-color-inverse, #000);
}
@media (min-width: 50em) {
  .donation-panel__details {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 40px 20px;
    width: 666px;
    z-index: 2;
  }
}
@media (min-width: 62.5em) {
  .donation-panel__details {
    padding: 40px 60px;
  }
}

.donation-panel__title {
  margin-bottom: 0;
  font-size: 20px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
}
@media (min-width: 50em) {
  .donation-panel__title {
    font-size: 38px;
  }
}

.donation-panel__description {
  font-size: 16px;
  font-weight: 400;
}
@media (min-width: 50em) {
  .donation-panel__description {
    font-size: 20px;
  }
}
.donation-panel__description p {
  margin-bottom: 0;
}

.donation-panel__amounts {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
}
@media (min-width: 62.5em) {
  .donation-panel__amounts {
    gap: 15px;
  }
}

.donation-panel__amount:first-child .donation-panel__button {
  margin-left: 0;
}

.donation-panel__input {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.donation-panel__input:checked + .donation-panel__button,
.donation-panel__button:hover,
.donation-panel__button:focus {
  background-color: var(--theme-color, #262687);
  color: var(--theme-highlight-color, #fff);
  text-decoration: none;
  transform: scale(1.1);
}

.donation-panel__button {
  align-items: center;
  cursor: pointer;
  display: flex;
  font-size: 16px;
  font-weight: 400;
  justify-content: center;
  margin: 0;
  padding: 10px;
  transform: scale(1);
  transition: all 0.3s ease-in-out;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  background: transparent;
  border: 1px solid;
}
.donation-panel__button:focus-visible {
  outline: none;
  border: none;
}

@media (max-width: 49.99em) {
  .donation-panel__actions, .donation-panel__actions .btn, .donation-panel__actions :where([data-component*=dialog] menu button) {
    width: 100%;
  }
}

.donation-amount {
  visibility: hidden;
}

/*  ==========================================================================
	Downloads
	========================================================================== */
.downloads {
  position: relative;
  padding: 30px 0;
}
@media (min-width: 50em) {
  .downloads {
    padding: 60px 0;
  }
}

.downloads__inner {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .downloads__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.downloads__inner {
  display: flex;
  flex-direction: column;
  padding: 15px;
  background-color: var(--theme-color);
}
@media (min-width: 62.5em) {
  .downloads__inner {
    flex-direction: row;
    justify-content: space-between;
    padding: 30px 60px;
  }
  .downloads__inner:has(.downloads__list:only-child) {
    justify-content: flex-end;
  }
}

.downloads__header {
  position: relative;
  flex: 0 0 auto;
  width: 100%;
  margin-bottom: 15px;
}
@media (min-width: 62.5em) {
  .downloads__header {
    flex: 0 0 50%;
    text-align: left;
    width: auto;
    margin-right: 40px;
    margin-bottom: 0;
  }
}

.downloads__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 0;
  color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .downloads__title {
    font-size: 26px;
  }
}

.downloads__description {
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 0;
  margin-top: 5px;
  color: var(--theme-body-text-color);
}
@media (min-width: 50em) {
  .downloads__description {
    font-size: 16px;
  }
}

.downloads__items {
  position: relative;
  color: #000;
  flex: 1 1 auto;
  width: 100%;
  margin-right: 30px;
}

.downloads__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
@media (min-width: 50em) {
  .downloads__list {
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
  }
  .downloads__list:only-child {
    width: 100%;
    align-items: flex-end;
  }
}
@media (min-width: 62.5em) {
  .downloads__list {
    width: 50%;
    align-items: center;
  }
}

.downloads__item {
  max-width: 450px;
  width: 100%;
}

.downloads__link {
  display: flex;
  align-items: center;
  text-align: left;
  width: 100%;
  border-top: 2px solid transparent;
  padding: 8px 0;
  position: relative;
  overflow: hidden;
  transition: 0.2s ease box-shadow;
}
@media (min-width: 50em) {
  .downloads__link {
    padding: 12px 0;
  }
}
.downloads__link:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--theme-highlight-color);
  transform: scaleX(1);
  transform-origin: left;
  transition: transform 0.4s ease-in-out;
  z-index: 1;
}
.downloads__link:hover:before {
  animation: top-border-animate 0.8s ease-in-out forwards;
}

@keyframes top-border-animate {
  0% {
    transform: scaleX(1);
    transform-origin: left;
  }
  50% {
    transform: scaleX(0);
    transform-origin: right;
  }
  51% {
    transform: scaleX(0);
    transform-origin: left;
  }
  100% {
    transform: scaleX(1);
    transform-origin: left;
  }
}
.downloads__icon {
  position: relative;
  margin-right: 10px;
}
.downloads__icon .o-icon {
  width: 24px;
  height: 24px;
  color: var(--theme-highlight-color);
  padding: 0 4px;
}
@media (min-width: 50em) {
  .downloads__icon .o-icon {
    width: 28px;
    height: 28px;
  }
}

.downloads__details {
  display: inline;
  font-family: Faktum, sans-serif;
  font-weight: normal;
  margin-bottom: 0;
  vertical-align: bottom;
  color: var(--theme-body-text-color);
}

.downloads__name {
  font-size: 16px;
  display: inline;
  padding-bottom: 0;
}

.downloads__meta {
  font-size: 13px;
  margin-left: auto;
  color: var(--theme-body-text-color);
  min-width: fit-content;
}
@media (min-width: 59em) {
  .downloads__meta {
    font-size: 16px;
  }
}

.downloads__type {
  text-transform: uppercase;
}

/*  ==========================================================================
    Feature Item
    ========================================================================== */
.feature-item {
  display: grid;
  grid-template-columns: 40% 1fr;
  grid-template-rows: repeat(2, auto);
  grid-template-areas: "image header" "footer footer";
}
@media (min-width: 42.5em) {
  .feature-item {
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "image header" "image footer";
  }
}
@media (min-width: 62.5em) {
  .feature-item {
    padding-right: var(--event-nav-width);
    grid-template-areas: "image header" "footer footer";
  }
}
@media (min-width: 90em) {
  .feature-item {
    grid-template-areas: "image header" "image footer";
  }
}

.feature-item__header {
  grid-area: header;
  align-self: center;
  padding: 10px 15px 0;
}
@media (min-width: 42.5em) {
  .feature-item__header {
    align-self: flex-end;
    text-align: center;
  }
}
@media (min-width: 62.5em) {
  .feature-item__header {
    align-self: center;
    text-align: left;
  }
}
@media (min-width: 90em) {
  .feature-item__header {
    align-self: flex-end;
    text-align: center;
  }
}

.feature-item__footer {
  grid-area: footer;
}

.feature-item__media {
  grid-area: image;
  overflow: hidden;
  width: 100%;
}

.feature-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
}

.feature-item__image {
  height: auto;
  position: absolute;
  right: 0;
  transform: scale(1);
  transition: transform 0.4s ease;
  width: 100%;
  z-index: 2;
}

.feature-item__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 400;
  font-size: 24px;
  text-wrap: balance;
  line-height: 1.2;
  margin-bottom: 0;
}

.feature-item__suffix {
  margin-bottom: 0;
  border-top: 1px solid black;
  margin-top: 10px;
  padding-top: 15px;
  font-size: 14px;
  text-wrap: balance;
  line-height: 1.3;
}
@media (min-width: 42.5em) {
  .feature-item__suffix {
    border-top: 0;
    padding-top: 0;
    font-size: 16px;
  }
}
@media (min-width: 62.5em) {
  .feature-item__suffix {
    border-top: 1px solid black;
    padding-top: 15px;
    font-size: 14px;
  }
}
@media (min-width: 90em) {
  .feature-item__suffix {
    border-top: 0;
    padding-top: 0;
  }
}
@media (min-width: 106em) {
  .feature-item__suffix {
    font-size: 16px;
  }
}

.feature-item__description {
  margin-bottom: 0;
  padding: 15px 15px 0;
  font-size: 14px;
  text-wrap: pretty;
}
.feature-item__description p {
  margin-bottom: 0;
}
@media (min-width: 42.5em) {
  .feature-item__description {
    text-align: center;
    font-size: 16px;
  }
}
@media (min-width: 62.5em) {
  .feature-item__description {
    text-align: left;
    font-size: 14px;
  }
}
@media (min-width: 90em) {
  .feature-item__description {
    text-align: center;
  }
}
@media (min-width: 106em) {
  .feature-item__description {
    font-size: 16px;
  }
}

.feature-item__cta {
  padding: 15px;
}
@media (min-width: 42.5em) {
  .feature-item__cta {
    padding-top: 25px;
    padding-bottom: 0;
    text-align: center;
  }
}
@media (min-width: 62.5em) {
  .feature-item__cta {
    padding-top: 15px;
    padding-bottom: 15px;
    text-align: left;
  }
}
@media (min-width: 90em) {
  .feature-item__cta {
    padding-top: 25px;
    padding-bottom: 0;
    text-align: center;
  }
}

.feature-item__btn {
  width: 100%;
}
@media (min-width: 42.5em) {
  .feature-item__btn {
    width: auto;
  }
}
@media (min-width: 62.5em) {
  .feature-item__btn {
    width: 100%;
  }
}
@media (min-width: 90em) {
  .feature-item__btn {
    width: auto;
  }
}
@media (hover: hover) and (pointer: fine) {
  .feature-item:has(.feature-item__btn:hover) .feature-item__image {
    transform: scale(1.05);
  }
}

/*  ==========================================================================
    Image Gallery
    ========================================================================== */
.image-gallery {
  --image-height: 280px;
  position: relative;
  padding: 15px 0;
  background-color: #252525;
  color: #fff;
  overflow: hidden;
}
@media (min-width: 50em) {
  .image-gallery {
    --image-height: 500px;
    padding: 45px 0;
  }
}
@media (min-width: 62.5em) {
  .image-gallery {
    --image-height: 500px;
  }
}

.image-gallery__container {
  width: 100%;
  max-width: 1360px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .image-gallery__container {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.image-gallery__container {
  position: relative;
}

.image-gallery__header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 15px;
  justify-content: space-between;
  position: relative;
  margin-bottom: 25px;
}
@media (min-width: 50em) {
  .image-gallery__header {
    flex-direction: row;
    align-items: center;
  }
}

.image-gallery__actions {
  display: flex;
  width: 100%;
  align-items: center;
  gap: 15px;
}

.image-gallery__buttons {
  display: none;
  width: 100%;
  justify-content: flex-end;
  align-items: center;
  gap: 0 8px;
}
@media (min-width: 50em) {
  .image-gallery__buttons {
    display: flex;
  }
}

.image-gallery__button {
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #fff;
}
@media (min-width: 62.5em) {
  .image-gallery__button {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.image-gallery__button.swiper-button-disabled {
  cursor: not-allowed;
}
.image-gallery__button .o-icon {
  color: #000;
  width: 16px;
  height: 16px;
  scale: 1;
  transition: scale 0.4s ease;
}
.image-gallery__button:not(.swiper-button-disabled):hover .o-icon {
  scale: 1.1;
}

.image-gallery__button--previous {
  margin-left: 0;
}
.image-gallery__button--previous .o-icon {
  rotate: -180deg;
  position: relative;
  left: -1px;
}

.image-gallery__button--next {
  margin-left: 15px;
}
@media (min-width: 62.5em) {
  .image-gallery__button--next {
    margin-left: 0;
  }
}
.image-gallery__button--next .o-icon {
  position: relative;
  left: 1px;
}

.image-gallery__body {
  display: flex;
  position: relative;
  align-self: center;
}

.image-gallery__content.swiper-container {
  position: relative;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  list-style: none;
  height: 100%;
  width: 100%;
  padding: 0;
  z-index: 2;
}

.image-gallery__slides.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.image-gallery__slide.swiper-slide {
  width: auto;
  flex-shrink: 0;
  margin-right: 30px;
  max-width: min-content;
  overflow: hidden;
}
.image-gallery__slide.swiper-slide:last-child {
  margin-right: 0;
}

.image-gallery__meta {
  position: relative;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
  font-size: 16px;
  margin-top: 20px;
  max-width: 600px;
}
@media (min-width: 50em) {
  .image-gallery__meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
    font-size: 18px;
  }
}

.image-gallery__description {
  font-family: Faktum Wide, sans-serif;
  margin-bottom: 0;
}

.image-gallery__length,
.image-gallery__zoom {
  border-left: 1px solid;
  padding-left: 15px;
  flex-shrink: 0;
  height: 28px;
}

.image-gallery__length,
.image-gallery__fullscreen {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  font-size: 14px;
  transition: color 0.4s ease;
  color: #fff;
}
@media (min-width: 50em) {
  .image-gallery__length,
  .image-gallery__fullscreen {
    font-size: 16px;
  }
}
.image-gallery__length .o-icon,
.image-gallery__fullscreen .o-icon {
  width: 20px;
  height: 20px;
}

.image-gallery__length {
  margin-bottom: 0;
  padding-left: 0;
  border-left: 0;
}

.image-gallery__zoom {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  z-index: 3;
}

.image-gallery__fullscreen {
  background: none;
  padding: 0;
  margin: 0;
  border: 0;
  cursor: pointer;
}
.image-gallery__fullscreen .open,
.image-gallery__fullscreen .close {
  align-items: center;
  gap: 10px;
}
.image-gallery__fullscreen .open .o-icon,
.image-gallery__fullscreen .close .o-icon {
  transition: scale 0.4s ease;
}
.image-gallery__fullscreen .open {
  display: flex;
  flex-direction: row-reverse;
}
.image-gallery__fullscreen .close {
  display: none;
}
.image-gallery__fullscreen .close .o-icon {
  position: relative;
  top: 1px;
}
@media (min-width: 50em) {
  .image-gallery__fullscreen {
    flex-direction: row-reverse;
  }
}
@media (hover: hover) and (pointer: fine) {
  .image-gallery__fullscreen:hover .o-icon {
    scale: 1.1;
  }
}

.image-gallery__details {
  display: none;
}

.gallery-slide__caption {
  font-size: var(--global-caption);
  font-size: 14px;
  font-weight: 400;
}

.gallery-slide__credit {
  display: block;
  font-size: 14px;
  font-weight: 400;
}

@media (hover: hover) and (pointer: fine) {
  .image-gallery__body:hover .image-gallery__button {
    opacity: 1;
  }
  .image-gallery__body:hover .image-gallery__button.swiper-button-disabled {
    opacity: 0;
  }
  .image-gallery__body:hover .image-gallery__fullscreen {
    opacity: 1;
  }
}
.gallery-slide__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
  box-sizing: border-box;
  margin-bottom: 0;
}

.gallery-slide__media {
  position: relative;
}

.gallery-slide__image {
  height: var(--image-height);
  width: auto;
}

.gallery-slide__content {
  width: 100%;
}

.image-gallery--fullscreen .image-gallery__fullscreen {
  position: fixed;
  right: 15px;
  opacity: 1;
}
@media (min-width: 59em) {
  .image-gallery--fullscreen .image-gallery__fullscreen {
    margin: 15px;
  }
}
.image-gallery--fullscreen .image-gallery__fullscreen .open {
  display: none;
}
.image-gallery--fullscreen .image-gallery__fullscreen .close {
  display: flex;
}
.image-gallery--fullscreen .image-gallery__button {
  opacity: 1;
  box-shadow: none;
  width: 50px;
  height: 50px;
}
.image-gallery--fullscreen .image-gallery__button.swiper-button-disabled {
  opacity: 0.3;
}
.image-gallery--fullscreen .image-gallery__header {
  position: absolute;
  margin-bottom: 0;
}
.image-gallery--fullscreen .image-gallery__container {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9999;
  background-color: #000;
  width: 100%;
  max-width: none;
  padding: 0;
}
@media (min-width: 59em) {
  .image-gallery--fullscreen .image-gallery__container {
    display: flex;
  }
}
.image-gallery--fullscreen .image-gallery__title {
  display: none;
}
.image-gallery--fullscreen .image-gallery__body {
  position: static;
  background-color: #252525;
}
@media (min-width: 59em) {
  .image-gallery--fullscreen .image-gallery__body {
    width: calc(100% - 300px);
  }
}
.image-gallery--fullscreen .image-gallery__body:after {
  content: none;
}
.image-gallery--fullscreen .image-gallery__buttons {
  position: fixed;
  bottom: 30px;
  right: 30px;
  z-index: 2;
}
.image-gallery--fullscreen .image-gallery__button--previous {
  top: auto;
  bottom: 20px;
  right: 90px;
  left: auto;
  transform: none;
}
.image-gallery--fullscreen .image-gallery__button--next {
  top: auto;
  bottom: 20px;
  right: 20px;
  left: auto;
  transform: none;
}
.image-gallery--fullscreen .image-gallery__body:hover .image-gallery__button.swiper-button-disabled {
  opacity: 0.3;
}
.image-gallery--fullscreen .image-gallery__zoom {
  max-width: unset;
  position: absolute;
  top: 20px;
  bottom: unset;
  border-left: 0;
}
@media (min-width: 50em) {
  .image-gallery--fullscreen .image-gallery__zoom {
    padding-top: 0;
  }
}
.image-gallery--fullscreen .image-gallery__info {
  display: none;
}
.image-gallery--fullscreen .image-gallery__meta {
  display: flex;
  background-color: #000;
  color: #fff;
  font-size: var(--global-body-size-5);
  margin-top: 0;
  padding: 15px;
}
@media (min-width: 59em) {
  .image-gallery--fullscreen .image-gallery__meta {
    width: 300px;
    margin-top: 0;
    padding: 100px 15px 0;
  }
}
.image-gallery--fullscreen .image-gallery__details {
  display: block;
  width: auto;
  padding-right: 60px;
}
@media (min-width: 59em) {
  .image-gallery--fullscreen .image-gallery__details {
    padding-right: 0;
  }
}
.image-gallery--fullscreen .image-gallery__description,
.image-gallery--fullscreen .image-gallery__length,
.image-gallery--fullscreen .gallery-slide__content {
  display: none;
}
.image-gallery--fullscreen .image-gallery__content.swiper-container {
  height: auto;
  max-width: 100%;
  overflow: hidden;
}
.image-gallery--fullscreen .image-gallery__slides.swiper-wrapper {
  align-items: center;
  padding-left: 0;
}
.image-gallery--fullscreen .image-gallery__slide.swiper-slide {
  height: auto;
  width: 100%;
  max-width: unset;
  overflow: unset;
}
.image-gallery--fullscreen .image-gallery__position {
  margin: 0 0 40px;
}
.image-gallery--fullscreen .gallery-slide__caption {
  display: block;
}
.image-gallery--fullscreen .gallery-slide__credit {
  display: block;
  margin-top: 20px;
}
.image-gallery--fullscreen .gallery-slide {
  padding: 15px;
}
.image-gallery--fullscreen .gallery-slide__media {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 0;
  height: auto;
}
.image-gallery--fullscreen .gallery-slide__media .gallery-slide__image {
  position: relative;
  width: 100%;
  max-width: 100%;
  height: auto;
}
.image-gallery--fullscreen .gallery-slide__media--portrait .gallery-slide__image {
  width: auto;
  height: auto;
  max-height: 60vh;
}
@media (min-width: 59em) {
  .image-gallery--fullscreen .gallery-slide__media--portrait .gallery-slide__image {
    width: auto;
    height: calc(100vh - 30px);
    max-height: none;
  }
}

.newsletter {
  background-color: #F4F4F4;
  color: #DB1E1E;
  position: relative;
  padding: 30px 15px;
  margin-top: 40px;
}
.newsletter:before {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 0;
  width: 100%;
  height: 40px;
  overflow: hidden;
  background-color: #F4F4F4;
  z-index: 1;
  clip-path: polygon(100% 0, 0px 100%, 100% 100%);
}
@media (min-width: 50em) {
  .newsletter {
    padding: 60px 15px;
  }
}

.newsletter__inner {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .newsletter__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.newsletter__inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  gap: 10px;
  flex-direction: column;
}
@media (min-width: 50em) {
  .newsletter__inner {
    gap: 40px;
    flex-direction: row;
  }
}
@media (min-width: 62.5em) {
  .newsletter__inner {
    gap: 60px;
  }
}

.newsletter__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  line-height: 1.2;
  font-size: 20px;
  margin-bottom: 10px;
}
@media (min-width: 50em) {
  .newsletter__title {
    font-size: 26px;
  }
}

.newsletter__form {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px;
  color: #000;
}
@media (min-width: 50em) {
  .newsletter__form {
    gap: 30px 15px;
  }
}
.newsletter__form label {
  font-weight: 500;
  margin-bottom: 5px;
}
.newsletter__form input {
  border: 1px solid transparent;
  background-color: #fff;
  color: #000;
  padding: 10px 10px;
  width: 100%;
}
.newsletter__form button {
  background-color: #DB1E1E;
  border: 2px solid #DB1E1E;
  color: #fff;
  border-radius: 30px;
  font-weight: 700;
  width: auto;
  padding: 10px 30px;
  font-size: 14px;
  font-family: Faktum Wide, sans-serif;
  transition: 0.2s ease-in-out;
  cursor: pointer;
}
.newsletter__form button:hover {
  background-color: transparent;
  color: #DB1E1E;
}
@media (max-width: 49.99em) {
  .newsletter__form button {
    width: 100%;
  }
}
.newsletter__form p {
  width: 100%;
}
.newsletter__form p a {
  text-decoration: underline;
}
.newsletter__form .newsletter__field {
  width: calc(50% - 7.5px);
  display: flex;
  flex-direction: column;
}

.newsletter__footer {
  font-size: 14px;
}

/*  ==========================================================================
    People Panel
    ========================================================================== */
.people-panel {
  display: flex;
  flex-direction: column;
  position: relative;
  margin: var(--content-margin);
}

.people-panel:last-child {
  margin-bottom: 0;
}

.people-panel__header {
  padding: 15px 0;
}

.people-panel__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 24px;
  margin-bottom: 0;
  text-align: center;
}
@media (min-width: 50em) {
  .people-panel__title {
    font-size: 26px;
  }
}

.people-panel__group {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: 40px;
}
@media (min-width: 50em) {
  .people-panel__group {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    gap: 40px;
  }
}
@media (min-width: 50em) and (min-width: 50em) {
  .people-panel__group {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.people-panel__subtitle {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 22px;
  margin-bottom: 0;
  text-align: center;
}

.people-panel__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 20px;
  align-items: flex-start;
  padding: 0 15px;
}
.people-panel__list::-webkit-scrollbar {
  display: none;
}
@media (min-width: 42.5em) {
  .people-panel__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 72em) {
  .people-panel__list {
    grid-template-columns: repeat(4, 1fr);
    gap: 60px;
    padding: 0;
  }
}

/*  ==========================================================================
    People Panel - Person
    ========================================================================== */
.person {
  position: relative;
  margin: 0;
  border: 0;
  padding: 0;
  flex-shrink: 0;
  background: none;
  width: 100%;
  display: flex;
  align-items: center;
}

@media (hover: hover) and (pointer: fine) {
  .person--bio {
    cursor: pointer;
  }
}

.person__media {
  width: 100%;
}

.person__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
  width: 100%;
  overflow: hidden;
}

.person__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  transition: transform 0.3s ease-in-out, filter 0.2s ease-in-out;
}

.person__media .o-icon {
  color: #757575;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  height: 80%;
  z-index: 1;
  transform: translate(-50%, -50%);
}

.person__media--image {
  background-color: transparent;
}

.person__details {
  text-align: left;
  transition: color 0.4s ease;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  word-break: break-word;
}
.person--bio .person__details {
  color: #000;
}

.person__details--full {
  width: 100%;
}

.person__name {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 0;
  font-size: 18px;
}
@media (min-width: 80em) {
  .person__name {
    font-size: 20px;
  }
}

.person__role {
  color: var(--theme-color);
  margin: 5px 0 0;
  font-family: Faktum Wide, sans-serif;
  font-weight: 500;
  font-size: 12px;
}
@media (min-width: 80em) {
  .person__role {
    font-size: 14px;
  }
}

.person__icon {
  position: absolute;
  bottom: 15px;
  right: 0;
  opacity: 0.4;
  transition: opacity 0.3s ease-in-out;
}
.person__icon .o-icon {
  width: 24px;
  height: 24px;
}

.person--bio:hover .person__image, .person--bio:focus .person__image {
  transform: scale(1.05);
  filter: brightness(1.1) contrast(1.05) saturate(1.1);
}
.person--bio:hover .person__icon, .person--bio:focus .person__icon {
  opacity: 1;
}

/*  ==========================================================================
    People Panel - Image
    ========================================================================== */
.people-panel__list--image .person {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.people-panel__list--image .person__details {
  padding: 15px 0;
  flex-grow: 1;
  width: 100%;
}
.people-panel__list--image .person__details.person__details--full {
  justify-content: flex-end;
  border-top: 1px solid #000;
}
.people-panel__list--image .person__role {
  padding-right: 25px;
}

/*  ==========================================================================
    People Panel - No Image
    ========================================================================== */
@media (min-width: 72em) {
  .people-panel__list--no-image {
    gap: 60px;
  }
}
.people-panel__list--no-image .person {
  display: block;
}
.people-panel__list--no-image .person__details {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  min-height: unset;
}
.people-panel__list--no-image .person__name {
  border-top: 1px solid #000;
  padding-top: 5px;
}
@media (min-width: 59em) {
  .people-panel__list--no-image .person__name {
    padding-top: 10px;
  }
}
.people-panel__list--no-image .person__icon {
  top: 10px;
  bottom: unset;
}

/* ==========================================================================
    People Panel - People Popup
    ========================================================================== */
.person-popup {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.people-popup {
  --link-color: #000;
  --focus-color: #000;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: 100svh;
  height: 100svh;
  background-color: #fff;
  color: #000;
  overflow-y: auto;
  z-index: 20;
  text-align: left;
  border: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 50em) {
  .people-popup[open] {
    height: fit-content;
    max-height: 90svh;
    width: calc(100% - 40px);
    max-width: 1120px;
    display: flex;
    justify-self: center;
    align-self: center;
  }
}

.people-popup__inner {
  padding: 15px;
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .people-popup__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.people-popup__inner {
  padding-right: 30px;
}
@media (min-width: 50em) {
  .people-popup__inner {
    padding: 30px;
  }
}

@media (min-width: 50em) {
  .people-popup__header {
    display: flex;
    justify-content: flex-end;
    position: relative;
    top: -80px;
    position: relative;
    top: 0;
    right: 0;
  }
}

.people-popup__close {
  position: fixed;
  top: 15px;
  right: 20px;
  margin: 0;
  border: 0;
  color: #000;
  background-color: #fff;
  z-index: 3;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid #D5D5D5;
  padding: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (hover: hover) and (pointer: fine) {
  .people-popup__close:hover {
    background-color: var(--theme-color);
    color: #fff;
    border-color: var(--theme-color);
  }
}
@media (min-width: 50em) {
  .people-popup__close {
    position: static;
    width: 44px;
    height: 44px;
    top: 15px;
    right: 10px;
    padding: 12px;
  }
}

.people-popup__body {
  display: flex;
  flex-direction: column-reverse;
  gap: 30px;
}
@media (min-width: 50em) {
  .people-popup__body {
    flex-direction: row-reverse;
    justify-content: space-between;
    gap: 60px;
    position: relative;
    margin-top: -40px;
  }
}
@media (max-width: 49.99em) {
  .people-popup__body:not(:has(.people-popup__image)) .people-popup__sticky {
    display: none;
  }
  .people-popup__body:not(:has(.people-popup__image)) .people-popup__meta {
    padding-right: 140px;
    padding-left: 0;
  }
}
@media (min-width: 50em) {
  .people-popup__body:not(:has(.people-popup__image)) .people-popup__details {
    display: none;
  }
  .people-popup__body:not(:has(.people-popup__image)) .people-popup__information {
    width: 100%;
  }
}

.people-popup__details {
  text-align: left;
  display: flex;
  flex-direction: row;
}
@media (min-width: 50em) {
  .people-popup__details {
    width: 40%;
    text-align: center;
    display: unset;
  }
}

.people-popup__sticky {
  display: block;
  min-width: 125px;
}
@media (min-width: 50em) {
  .people-popup__sticky {
    position: sticky;
    top: 30px;
    min-width: unset;
  }
}

.people-popup__name {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 24px;
  margin-bottom: 0;
  padding-right: 25px;
  word-break: break-word;
}
@media (min-width: 50em) {
  .people-popup__name {
    font-size: 38px;
    padding-right: 44px;
  }
}

.people-popup__role {
  margin-top: 10px;
  margin-bottom: 0;
  font-size: 16px;
  color: var(--theme-color);
}
@media (min-width: 50em) {
  .people-popup__role {
    font-size: 24px;
    margin-top: 0;
    font-weight: 500;
  }
}

.people-popup__sticky.people-popup__sticky--image .people-popup__meta {
  margin-left: 15px;
}
@media (min-width: 50em) {
  .people-popup__sticky.people-popup__sticky--image .people-popup__meta {
    margin-left: 0;
  }
}
.people-popup__sticky.people-popup__sticky--image .people-popup__name {
  font-size: 22px;
}
.people-popup__sticky.people-popup__sticky--image .people-popup__role {
  font-size: 18px;
}

.people-popup__media {
  width: 100%;
}
.people-popup__media .o-icon {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  height: 80%;
  z-index: 1;
  transform: translate(-50%, -50%);
}

.people-popup__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
  overflow: hidden;
}

.people-popup__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.people-popup__intrinsic-ratio {
  position: relative;
  overflow: hidden;
}

.people-popup__information {
  padding-bottom: 40px;
}
@media (min-width: 50em) {
  .people-popup__information {
    width: 60%;
    padding-top: 20px;
  }
}

.people-popup__meta {
  margin-bottom: 30px;
}
@media (max-width: 49.99em) {
  .people-popup__meta.people-popup__meta--desktop {
    display: none;
  }
}
.people-popup__meta.people-popup__meta--mobile {
  padding-left: 20px;
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (min-width: 50em) {
  .people-popup__meta.people-popup__meta--mobile {
    display: none;
  }
}

/*  ==========================================================================
    Pull Quote
    ========================================================================== */
.pull-quote {
  position: relative;
  margin: var(--content-margin);
  color: var(--theme-highlight-color);
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .pull-quote {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.quote {
  position: relative;
}
@media (max-width: 62.49em) {
  .quote {
    padding-left: 20px;
  }
}
.quote:before {
  content: "";
  border-left: 1px solid;
  position: absolute;
  right: 100%;
  top: 0;
  bottom: 0;
}
@media (min-width: 62.5em) {
  .quote:before {
    right: calc(100% + 40px);
  }
}
@media (min-width: 72em) {
  .quote:before {
    right: calc(100% + 60px);
  }
}

.quote__text {
  position: relative;
  font-size: 18px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  line-height: 1.2;
  margin: 0 auto;
  padding-bottom: 0;
}
.quote__text p {
  margin-bottom: 15px;
  text-wrap: pretty;
}
.quote__text p:first-child:before {
  content: "“";
  display: inline-block;
}
.quote__text p:last-child:after {
  content: "”";
  display: inline-block;
}
@media (min-width: 50em) {
  .quote__text {
    font-size: 22px;
  }
  .quote__text p {
    margin-bottom: 15px;
  }
}
@media (min-width: 72em) {
  .quote__text {
    font-size: 26px;
  }
}

.quote__meta {
  width: 100%;
}

.quote__link {
  display: block;
  font-family: Faktum, sans-serif;
  font-size: 14px;
  font-weight: 400;
  text-decoration: none;
  line-height: 1;
}
@media (min-width: 50em) {
  .quote__link {
    font-size: 20px;
  }
}
@media (min-width: 72em) {
  .quote__link {
    font-size: 24px;
  }
}
.quote__link:hover, .quote__link:focus {
  text-decoration: underline;
}

.quote__cite {
  display: inline-block;
  font-style: normal;
}

/*  ==========================================================================
    Sponsors
    ========================================================================== */
.company-block {
  position: relative;
  margin: 15px 0 30px;
}
@media (min-width: 59em) {
  .company-block {
    margin: var(--content-margin-small);
  }
}

.company-block__inner {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .company-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.company-block__groups {
  display: flex;
  flex-direction: column;
}
@media (min-width: 50em) {
  .company-block__groups {
    gap: 10px;
  }
}

.company-block__heading {
  font-family: Faktum Wide, sans-serif;
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 0;
  padding-top: 10px;
  text-align: center;
  word-wrap: break-word;
}
@media (min-width: 59em) {
  .company-block__heading {
    font-size: 20px;
    text-align: left;
    border-top: 1px solid #C4C4C4;
  }
}
@media (min-width: 62.5em) {
  .company-block__heading {
    font-size: 26px;
  }
}

/*  ==========================================================================
    Sponsors - Groups Layout
    ========================================================================== */
.company-block__group {
  display: grid;
  grid-template-columns: 1fr;
  gap: 25px;
  margin: 10px 0;
}
.company-block__group:only-child {
  margin: 0;
}
.company-block__group .company-item__image-container {
  min-height: 125px;
}

.company-block__list {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
@media (min-width: 32em) {
  .company-block__list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    justify-content: center;
  }
}
@media (max-width: 58.99em) {
  .company-block__list {
    grid-template-columns: repeat(auto-fit, minmax(220px, max-content));
  }
}
@media (min-width: 62.5em) {
  .company-block__list {
    gap: 20px;
  }
}

@media (min-width: 59em) {
  .company-block__group--single,
  .company-block__group--two {
    grid-template-columns: 1fr auto;
    align-items: center;
    margin: 30px 0;
  }
}
@media (min-width: 59em) {
  .company-block__group--single .company-item__image-container,
  .company-block__group--two .company-item__image-container {
    min-height: 191px;
  }
}
@media (min-width: 59em) {
  .company-block__group--single .company-item,
  .company-block__group--two .company-item {
    max-width: 302px;
    margin: 0;
  }
}

@media (min-width: 59em) {
  .company-block__group--single {
    grid-template-columns: 1fr 302px;
    gap: 60px;
  }
}
@media (min-width: 59em) {
  .company-block__group--single .company-block__list {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 31.99em) {
  .company-block__group--single .company-item {
    width: 100%;
  }
}

@media (min-width: 59em) {
  .company-block__group--two {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 60px;
    overflow: hidden;
  }
}
@media (min-width: 59em) {
  .company-block__group--two .company-block__list {
    grid-template-columns: repeat(2, 302px);
    gap: 30px;
  }
}

@media (min-width: 59em) {
  .company-block__group--three-plus .company-block__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
  }
}
@media (min-width: 59em) {
  .company-block__group--three-plus .company-item__image-container {
    min-height: 167px;
  }
}
.company-block__group--three-plus .company-item {
  justify-self: center;
}
@media (min-width: 59em) {
  .company-block__group--three-plus .company-item {
    max-width: 320px;
    margin: 0;
  }
}

@media (max-width: 31.99em) {
  .company-block__group--two .company-item,
  .company-block__group--three-plus .company-item {
    width: calc(50% - 7.5px);
  }
}

/*  ==========================================================================
    Sponsors - Item
    ========================================================================== */
.company-item {
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-align: center;
}
@media (max-width: 58.99em) {
  .company-item {
    width: 220px;
  }
}
@media (min-width: 59em) {
  .company-item {
    width: 100%;
    margin: 0 auto;
  }
}

.company-item__image-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  gap: 10px;
  padding: 20px;
}
@media (min-width: 50em) {
  .company-item__image-container {
    gap: 25px;
    padding: 15px;
  }
}
.company-item__image-container:has(p.company-item__description:only-child) {
  padding: 0 20px;
}

img.company-item__image {
  display: block;
  margin-top: auto;
  width: auto;
  height: auto;
  max-height: 100px;
}
@media (min-width: 62.5em) {
  img.company-item__image {
    max-height: 120px;
    max-width: 200px;
  }
}
img.company-item__image:only-child {
  margin: 0;
}

.company-item__description {
  display: flex;
  align-items: center;
  text-align: center;
  margin-top: auto;
  margin-bottom: 0;
  font-size: 14px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 400;
  text-wrap: balance;
  transition: color 0.4s ease;
  word-break: break-word;
}
.company-item__description:only-child {
  height: 100%;
}
a.company-item .company-item__description {
  color: #000;
  text-decoration: underline;
}
@media (min-width: 59em) {
  .company-item__description {
    font-size: 16px;
  }
  .company-item__description:only-child {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .company-item__description:only-child {
    height: 100%;
    min-height: 100px;
  }
}

/*  ==========================================================================
	Series Pack Header
	========================================================================== */
.series-pack-header {
  position: relative;
  background-color: var(--theme-color);
  color: var(--theme-highlight-color);
}

@media (min-width: 50em) {
  .series-pack-header__inner {
    max-width: 1440px;
    margin: auto;
    display: flex;
  }
}

.series-pack-header__media {
  width: 100%;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .series-pack-header__media {
    width: 45%;
  }
}
@media (min-width: 90em) {
  .series-pack-header__media {
    transform: translateX(calc(((100vw - 1440px) / 2) * -1));
  }
}

.series-pack-header__media-inner {
  position: relative;
  height: 100%;
}
@media (min-width: 90em) {
  .series-pack-header__media-inner {
    width: calc(100% + ((100vw - 1440px) / 2));
  }
}

@media (max-width: 49.99em) {
  .series-pack-header__intrinsic-ratio {
    position: relative;
    padding-bottom: 75%;
    height: 0;
    overflow: hidden;
  }
}
@media (min-width: 50em) {
  .series-pack-header__intrinsic-ratio {
    height: 100%;
  }
}

.series-pack-header__image {
  position: absolute;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: 2;
}
@media (min-width: 50em) {
  .series-pack-header__image {
    position: unset;
  }
}

.series-pack-header__content {
  padding: 20px 0 10px;
}
@media (min-width: 50em) {
  .series-pack-header__content {
    max-width: 55%;
    align-self: center;
    padding: 40px 30px 40px 30px;
  }
}
@media (max-width: 49.99em) {
  .series-pack-header__content {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 49.99em) and (min-width: 50em) {
  .series-pack-header__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 80em) {
  .series-pack-header__content {
    padding: 40px 60px 40px 120px;
  }
}

.series-pack-header__titles {
  border-bottom: 1px solid;
  padding-bottom: 10px;
}

.series-pack-header__title {
  display: flex;
  flex-direction: column;
  font-family: Faktum Wide, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 32px;
  text-wrap: balance;
  width: 100%;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .series-pack-header__title {
    font-size: 38px;
  }
}
@media (min-width: 72em) {
  .series-pack-header__title {
    font-size: 48px;
  }
}

.series-pack-header__suffix {
  font-weight: 400;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  margin-top: 20px;
  text-wrap: pretty;
}
@media (min-width: 50em) {
  .series-pack-header__suffix {
    font-size: 22px;
  }
}
@media (min-width: 80em) {
  .series-pack-header__suffix {
    font-size: 26px;
  }
}

.series-pack-header__details {
  margin: 10px 0 15px;
}

.series-pack-header__venue {
  text-decoration: none;
  color: var(--theme-body-text-color);
  font-size: 16px;
  margin-bottom: 5px;
  display: inline-block;
  font-weight: 500;
}

.series-pack-header__dates {
  color: var(--theme-body-text-color);
  display: flex;
  flex-wrap: wrap;
  gap: 0 15px;
  font-size: 14px;
  font-weight: 500;
}

.series-pack-header__date {
  margin: 0 0 5px;
}

.series-pack-header__description {
  margin-bottom: 15px;
  font-size: 16px;
  font-weight: 600;
  color: var(--theme-body-text-color);
}
@media (max-width: 49.99em) {
  .series-pack-header__description {
    display: none;
  }
}

.series-pack-header__mobile-sticky {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: var(--theme-color);
  padding: 10px 20px;
  z-index: 5;
  color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .series-pack-header__mobile-sticky {
    display: none;
  }
}

.series-pack-header__mobile-sticky--light {
  background-color: #fff;
  color: #000;
  border-top: 1px solid #F4F4F4;
}
.series-pack-header__mobile-sticky--light .series-pack-header__copy {
  color: #000;
}
.series-pack-header__mobile-sticky--light .series-pack-header__text-button {
  color: var(--theme-highlight-color);
}
.series-pack-header__mobile-sticky--light .series-pack-header__text-button:hover {
  background-color: transparent;
}

.series-pack-header__mobile-buttons {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin: 10px 0 5px;
}

.series-pack-header__mobile-content-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.series-pack-header__buttons {
  display: flex;
  gap: 15px;
  margin: 15px 0 10px;
}
@media (max-width: 49.99em) {
  .series-pack-header__buttons {
    display: none;
  }
}
@media (min-width: 50em) {
  .series-pack-header__buttons {
    margin: 30px 0 20px;
    gap: 20px;
    flex-wrap: wrap;
  }
}

.series-pack-header__button {
  font-weight: 700 !important;
  justify-content: center;
}
@media (min-width: 62.5em) {
  .series-pack-header__button {
    width: calc(50% - 10px);
  }
}

.series-pack-header__content-footer {
  display: flex;
  align-items: center;
  gap: 10px;
}
@media (max-width: 49.99em) {
  .series-pack-header__content-footer {
    display: none;
  }
}

.series-pack-header__copy {
  font-weight: 600;
  color: var(--theme-body-text-color);
  margin: 0;
  font-size: 14px;
}
@media (min-width: 50em) {
  .series-pack-header__copy {
    font-size: 18px;
  }
}

.series-pack-header__divider {
  font-size: 22px;
}

.series-pack-header__text-button {
  background-color: transparent;
  border: none;
  outline: none;
  color: var(--theme-highlight-color);
  padding: 0;
  font-weight: 600;
  font-size: 14px;
  text-decoration: underline;
  cursor: pointer;
}
@media (min-width: 50em) {
  .series-pack-header__text-button {
    font-size: 18px;
  }
}

/*  ==========================================================================
	Series Pack List
	========================================================================== */
.series-list {
  padding: 40px 0;
}
@media (min-width: 50em) {
  .series-list {
    padding: 60px 0;
  }
}

.series-list__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .series-list__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.series-list__header {
  margin-bottom: 30px;
}

.series-list__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 5px;
}
@media (min-width: 50em) {
  .series-list__title {
    font-size: 24px;
  }
}
@media (min-width: 72em) {
  .series-list__title {
    font-size: 26px;
  }
}

.series-list__suffix {
  text-decoration: none;
  font-size: 14px;
  margin-bottom: 5px;
  display: inline-block;
  font-weight: 500;
  display: none;
}
@media (min-width: 50em) {
  .series-list__suffix {
    font-size: 16px;
  }
}
.series-list__suffix.show {
  display: block;
}

.series-list__list {
  display: grid;
  gap: 15px;
  grid-template-columns: repeat(1, minmax(220px, 1fr));
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.series-list__list::-webkit-scrollbar {
  display: none;
}
.series-list__list:has(> :only-child) {
  grid-template-columns: 1fr;
  overflow: hidden;
}
@media (min-width: 42.5em) {
  .series-list__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    overflow: visible;
  }
  .series-list__list:has(> :only-child) {
    max-width: 660px;
    margin: 0 auto;
  }
}
@media (min-width: 50em) {
  .series-list__list {
    overflow-x: auto;
  }
}
@media (min-width: 62.5em) {
  .series-list__list {
    grid-template-columns: repeat(3, 1fr);
  }
}

/*  ==========================================================================
    Series Pack Items
    ========================================================================== */
.series-item {
  display: flex;
  flex-direction: column;
  gap: 15px;
  height: 100%;
  width: 100%;
}
.series-item .series-item__content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.series-item .series-item__details {
  flex: 1;
  margin-top: 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 120px;
}
@media (min-width: 50em) {
  .series-item .series-item__details {
    min-height: 150px;
  }
}
.series-item .series-item__media {
  position: relative;
  overflow: hidden;
}
.series-item .series-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
  object-fit: cover;
  object-position: center;
}
.series-item .series-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
.series-item .series-item__favorite {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2;
  display: none;
}
@media (min-width: 50em) {
  .series-item .series-item__favorite {
    bottom: 20px;
    right: 20px;
  }
}
.series-item .series-item__favorite-btn {
  background-color: rgba(255, 255, 255, 0.75);
  border: none;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  padding: 0;
}
.series-item .series-item__favorite-btn:hover {
  background: var(--theme-highlight-color);
}
.series-item .series-item__favorite-btn svg {
  width: 18px;
  height: 18px;
}
@media (min-width: 50em) {
  .series-item .series-item__favorite-btn {
    width: 46px;
    height: 46px;
  }
  .series-item .series-item__favorite-btn svg {
    width: 23px;
    height: 23px;
  }
}
.series-item .series-item__favorite-btn .filled {
  display: none;
}
.series-item .series-item__favorite-btn.is-favorite {
  background-color: #fff;
}
.series-item .series-item__favorite-btn.is-favorite .outline {
  display: none;
}
.series-item .series-item__favorite-btn.is-favorite .filled {
  display: block;
}
.series-item .series-item__title {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .series-item .series-item__title {
    font-size: 22px;
    line-height: 1.4;
    min-height: 62px;
  }
}
.series-item .series-item__dates {
  margin-top: 15px;
}
.series-item .series-item__date-item {
  display: flex;
  border-top: 1px solid #dAdAdA;
  padding: 5px 0 7px;
  gap: 40px;
}
.series-item .series-item__date {
  font-size: 14px;
  margin: 0;
}
.series-item .series-item__time {
  font-size: 14px;
  margin: 0 0 0 auto;
}
.series-item .series-item__venue {
  font-size: 14px;
  font-weight: 500;
  margin: 0;
}
.series-item .series-item__categories {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 5px;
  list-style: none;
  padding: 0;
  margin: 0;
  padding-top: 15px;
  border-top: 1px solid #dAdAdA;
}
.series-item .series-item-category {
  color: var(--theme-color);
  border: 1px solid;
  border-radius: 20px;
  padding: 6px 10px;
  font-family: Faktum, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1;
  flex-shrink: 0;
}
@media (min-width: 50em) {
  .series-item .series-item-category {
    padding: 8px 15px;
  }
}

/*  ==========================================================================
	Series Pack List
	========================================================================== */
.series-pack-list {
  position: relative;
  padding: 15px 0 30px;
  overflow: hidden;
  background-color: #fff;
  color: #000;
}
@media (min-width: 50em) {
  .series-pack-list {
    padding: 30px 0;
  }
}
.series-pack-list:last-child {
  margin-bottom: 0;
}

@media (min-width: 62.5em) {
  .series-pack-list__inner {
    width: 100%;
    max-width: 1390px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 62.5em) and (min-width: 50em) {
  .series-pack-list__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.series-pack-list__header {
  position: relative;
  margin: 0 15px 15px;
  padding-top: 15px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .series-pack-list__header {
    align-items: center;
  }
}
@media (min-width: 62.5em) {
  .series-pack-list__header {
    align-items: flex-start;
    margin: 0 0 15px;
    gap: 40px;
  }
}

.series-pack-list__header-content {
  width: 100%;
}

.series-pack-list__title-container {
  display: flex;
  align-items: center;
  gap: 20px;
}
@media (max-width: 49.99em) {
  .series-pack-list__title-container {
    justify-content: space-between;
  }
}

.series-pack-list__tag {
  color: var(--theme-color);
  font-size: 13px;
  border: 1px solid;
  padding: 3px 15px;
  border-radius: 20px;
  font-weight: 500;
}

.series-pack-list__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .series-pack-list__title {
    font-size: 28px;
  }
}

.series-pack-list__description {
  margin-top: 5px;
  font-size: 15px;
  font-weight: 400;
}
@media (min-width: 50em) {
  .series-pack-list__description {
    font-size: 20px;
  }
}

.series-pack-list__actions {
  display: flex;
  gap: 0 8px;
  margin-left: auto;
  flex-shrink: 0;
}
@media (min-width: 62.5em) {
  .series-pack-list__actions {
    margin-right: 40px;
  }
}

.series-pack-list__previous,
.series-pack-list__next {
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  transition: background-color 0.4s ease;
  background-color: var(--theme-color);
}
.series-pack-list__previous.series-pack-list--grey,
.series-pack-list__next.series-pack-list--grey {
  background-color: #F4F4F4;
}
@media (min-width: 62.5em) {
  .series-pack-list__previous,
  .series-pack-list__next {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.series-pack-list__previous.swiper-button-disabled,
.series-pack-list__next.swiper-button-disabled {
  cursor: not-allowed;
}
.series-pack-list__previous .o-icon,
.series-pack-list__next .o-icon {
  color: var(--text-color-light);
  scale: 1;
  transition: scale 0.4s ease;
  width: 16px;
  height: 16px;
}
.series-pack-list__previous:not(.swiper-button-disabled):hover .o-icon,
.series-pack-list__next:not(.swiper-button-disabled):hover .o-icon {
  scale: 1.1;
}

.series-pack-list__previous {
  margin-left: 0;
}
.series-pack-list__previous .o-icon {
  rotate: -180deg;
}

.series-pack-list__next {
  margin-left: 15px;
}
@media (min-width: 62.5em) {
  .series-pack-list__next {
    margin-left: 0;
  }
}

.series-pack-list__content.series-pack-list__content--grid .series-pack-list__grid::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .series-pack-list__content.series-pack-list__content--grid .series-pack-list__grid {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}
.series-pack-list__content.series-pack-list__content--grid .series-pack-list__list {
  display: grid;
  gap: 15px;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.series-pack-list__content.series-pack-list__content--grid .series-pack-list__list::-webkit-scrollbar {
  display: none;
}
.series-pack-list__content.series-pack-list__content--grid .series-pack-list__list:has(> :only-child) {
  grid-template-columns: 1fr;
  overflow: hidden;
}
@media (min-width: 42.5em) {
  .series-pack-list__content.series-pack-list__content--grid .series-pack-list__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    overflow: visible;
  }
  .series-pack-list__content.series-pack-list__content--grid .series-pack-list__list:has(> :only-child) {
    max-width: 660px;
    margin: 0 auto;
  }
}
@media (min-width: 50em) {
  .series-pack-list__content.series-pack-list__content--grid .series-pack-list__list {
    overflow-x: auto;
  }
}
@media (max-width: 49.99em) {
  .series-pack-list__content.series-pack-list__content--grid .series-pack-list__list {
    display: flex;
    -webkit-overflow-scrolling: touch;
  }
  .series-pack-list__content.series-pack-list__content--grid .series-pack-list__list .series-pack-list__item {
    display: flex;
    width: 320px;
    padding-right: 15px;
    flex-shrink: 0;
    box-sizing: content-box;
    position: relative;
  }
}
.series-pack-list__content.series-pack-list__content--grid .series-pack-list__item {
  width: 100%;
  display: flex;
}
.series-pack-list__content.series-pack-list__content--grid .series-pack-list__item:only-child {
  width: 100%;
}
@media (min-width: medium-minor) {
  .series-pack-list__content.series-pack-list__content--grid .series-pack-list__item:only-child {
    grid-column: 1/-1;
  }
}
.series-pack-list__content.series-pack-list__content--slider .series-pack-list__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .series-pack-list__content.series-pack-list__content--slider .series-pack-list__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}
.series-pack-list__content.series-pack-list__content--slider .series-pack-list__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}
.series-pack-list__content.series-pack-list__content--slider .series-pack-list__item {
  display: flex;
  width: 320px;
  padding-right: 15px;
  flex-shrink: 0;
  box-sizing: content-box;
  position: relative;
}
@media (min-width: 62.5em) {
  .series-pack-list__content.series-pack-list__content--slider .series-pack-list__item {
    width: calc(33.33% - 23px);
    padding-right: 30px;
  }
  .series-pack-list__content.series-pack-list__content--slider .series-pack-list__item:last-child {
    padding-right: 0;
  }
}
@media (min-width: 62.5em) {
  .series-pack-list__content.series-pack-list__content--slider-more {
    width: calc(100% - 30px);
  }
}

/*  ==========================================================================
    Concert List - Items
    ========================================================================== */
.series-pack-list .series-item .series-item__details {
  gap: 3px;
}
.series-pack-list .series-item .series-item__title {
  line-height: 1.2;
  margin-bottom: 5px;
}
@media (min-width: 50em) {
  .series-pack-list .series-item .series-item__title {
    min-height: auto;
  }
}
.series-pack-list .series-item .series-item__packages {
  font-size: 16px;
  margin: 5px 0 0;
}
.series-pack-list .series-item .series-item__venue, .series-pack-list .series-item .series-item__date {
  font-size: 16px;
  font-weight: 400;
  margin: 5px 0 0;
}
@media (min-width: 50em) {
  .series-pack-list .series-item .series-item__venue, .series-pack-list .series-item .series-item__date {
    margin: 0;
    font-weight: 600;
  }
}

/*  ==========================================================================
    Venue Panel
	========================================================================== */
.venue-panel {
  position: relative;
  padding: 30px 0;
  background-color: var(--theme-color);
}
@media (min-width: 50em) {
  .venue-panel {
    padding: 40px 0;
  }
}
@media (min-width: 62.5em) {
  .venue-panel {
    padding: 60px 0;
  }
}
.user-is-tabbing .venue-panel a:focus {
  outline-color: #000;
}

.venue-panel__inner {
  padding: 0 20px;
}
@media (min-width: 62.5em) {
  .venue-panel__inner {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 62.5em) and (min-width: 50em) {
  .venue-panel__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.venue-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  margin-bottom: 10px;
}
@media (min-width: 62.5em) {
  .venue-panel__header {
    padding: 0;
  }
}

.venue-panel__nav {
  display: none;
  align-items: center;
  gap: 15px;
}
@media (min-width: 50em) {
  .venue-panel__nav {
    display: flex;
  }
}

.venue-panel__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 24px;
  color: var(--theme-body-text-color);
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .venue-panel__title {
    font-size: 26px;
  }
}
@media (min-width: 62.5em) {
  .venue-panel__title {
    font-size: 38px;
  }
}

.venue-panel__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}

.venue-panel__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .venue-panel__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 20px;
  }
}

.venue-panel__previous,
.venue-panel__next {
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  transition: background-color 0.4s ease;
  background-color: var(--theme-highlight-color);
}
@media (min-width: 62.5em) {
  .venue-panel__previous,
  .venue-panel__next {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.venue-panel__previous.swiper-button-disabled,
.venue-panel__next.swiper-button-disabled {
  cursor: not-allowed;
}
.venue-panel__previous .o-icon,
.venue-panel__next .o-icon {
  color: var(--theme-color);
  scale: 1;
  transition: scale 0.4s ease;
  width: 16px;
  height: 16px;
}
.venue-panel__previous:not(.swiper-button-disabled):hover .o-icon,
.venue-panel__next:not(.swiper-button-disabled):hover .o-icon {
  scale: 1.1;
}

.venue-panel__previous {
  margin-left: 0;
}
.venue-panel__previous .o-icon {
  rotate: -180deg;
}

.venue-panel__next {
  margin-left: 15px;
}
@media (min-width: 62.5em) {
  .venue-panel__next {
    margin-left: 0;
  }
}

/*  ==========================================================================
	Venue Panel - Venue Item
	========================================================================== */
.venue-panel-item {
  color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .venue-panel-item {
    display: flex;
    align-items: center;
    gap: 60px;
  }
}
.venue-panel-item:hover .venue-panel-item__image {
  opacity: 1;
}
.venue-panel-item:hover .venue-panel-item__arrow {
  transform: translateX(5px);
}

.venue-panel-item__floating-arrow {
  color: var(--theme-highlight-color);
  position: absolute;
  top: 0;
  right: 0;
  width: 18px;
  height: 18px;
}
@media (min-width: 50em) {
  .venue-panel-item__floating-arrow {
    display: none;
  }
}

.venue-panel-item__pretitle {
  color: var(--theme-body-text-color);
  font-family: Faktum Wide, sans-serif;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 5px;
}
@media (min-width: 50em) {
  .venue-panel-item__pretitle {
    font-size: 20px;
  }
}

.venue-panel-item__title {
  color: var(--theme-highlight-color);
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 26px;
  margin-bottom: 10px;
  max-width: 340px;
  line-height: 1.2;
}
@media (min-width: 50em) {
  .venue-panel-item__title {
    max-width: 450px;
    font-size: 32px;
    margin-bottom: 15px;
  }
}
@media (min-width: 62.5em) {
  .venue-panel-item__title {
    font-size: 38px;
  }
}

.venue-panel-item__details {
  width: 100%;
  position: relative;
}
@media (min-width: 62.5em) {
  .venue-panel-item__details {
    width: calc(50% - 60px / 2);
  }
}

.venue-panel-item__description {
  font-size: 16px;
  color: var(--theme-body-text-color);
  line-height: 1.1;
  margin-bottom: 30px;
}
@media (max-width: 49.99em) {
  .venue-panel-item__description {
    margin-bottom: 0;
  }
}
@media (min-width: 50em) {
  .venue-panel-item__description {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .venue-panel-item__description {
    font-size: 20px;
  }
}

.venue-panel-item__pin {
  display: none;
}
@media (min-width: 50em) {
  .venue-panel-item__pin {
    display: inline-block;
    vertical-align: bottom;
    fill: var(--theme-body-text-color);
    width: 24px;
    height: 24px;
    margin-right: 5px;
  }
}

.venue-panel-item__media {
  width: 100%;
}
@media (max-width: 49.99em) {
  .venue-panel-item__media {
    margin-bottom: 20px;
  }
}
@media (min-width: 62.5em) {
  .venue-panel-item__media {
    width: calc(50% - 30px);
  }
}

.venue-panel-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 57.1428571429%;
  height: 0;
  width: 100%;
  overflow: hidden;
}

.venue-panel-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: opacity 0.4s ease;
  object-fit: cover;
  object-position: center;
  opacity: 0.8;
}

.venue-panel-item__cta {
  color: var(--theme-body-text-color);
  font-size: 15px;
  border-top: 1px solid var(--theme-highlight-color);
  padding-top: 30px;
  font-weight: 500;
  font-family: Faktum Wide, sans-serif;
}
@media (max-width: 49.99em) {
  .venue-panel-item__cta {
    display: none;
  }
}

.venue-panel-item__arrow {
  width: 22px;
  height: 22px;
  margin-left: 5px;
  transition: transform 0.4s ease;
  display: inline-block;
}

/*  ==========================================================================
    Venue Panel - Two Venues
	========================================================================== */
.venue-panel--two .venue-panel__inner {
  padding: 0;
}
@media (min-width: 32em) {
  .venue-panel--two .venue-panel__scroll {
    padding-right: 20px;
  }
}
@media (min-width: 62.5em) {
  .venue-panel--two .venue-panel__scroll {
    padding-right: 0;
  }
}
@media (min-width: 32em) {
  .venue-panel--two .venue-panel__list {
    gap: 20px;
  }
}
@media (min-width: 80em) {
  .venue-panel--two .venue-panel__list {
    gap: 60px;
  }
}
.venue-panel--two .venue-panel__item {
  min-width: 320px;
  width: 320px;
  padding-right: 20px;
  flex-shrink: 0;
}
@media (min-width: 32em) {
  .venue-panel--two .venue-panel__item {
    width: calc(50% - 10px);
    padding-right: 0;
  }
}
@media (min-width: 80em) {
  .venue-panel--two .venue-panel__item {
    width: calc(50% - 30px);
  }
}
.venue-panel--two .venue-panel-item {
  flex-direction: column;
  gap: 20px;
}
.venue-panel--two .venue-panel-item__media,
.venue-panel--two .venue-panel-item__details {
  width: 100%;
}
.venue-panel--two .venue-panel-item__pretitle {
  display: none;
}
.venue-panel--two .venue-panel-item__title {
  font-size: 20px;
  padding-right: 20px;
}
@media (min-width: 50em) {
  .venue-panel--two .venue-panel-item__title {
    font-size: 26px;
    padding-right: 0;
  }
}
@media (min-width: 72em) {
  .venue-panel--two .venue-panel-item__title {
    font-size: 38px;
  }
}
@media (min-width: 62.5em) {
  .venue-panel--two .venue-panel-item__description {
    font-size: 18px;
  }
}

/*  ==========================================================================
	Venue Panel - Scroller (3 or More)
	========================================================================== */
.venue-panel--scroller .venue-panel__scroll {
  padding-right: 0;
}
.venue-panel--scroller .venue-panel__list {
  gap: 0;
}
@media (min-width: 32em) {
  .venue-panel--scroller .venue-panel__item {
    width: calc(40% - 10px);
    padding-right: 20px;
  }
}
@media (min-width: 50em) {
  .venue-panel--scroller .venue-panel__item {
    width: calc(40% - 15px);
    padding-right: 30px;
  }
}
.venue-panel--scroller .venue-panel-item__title {
  font-size: 20px;
  padding-right: 20px;
}
@media (min-width: 50em) {
  .venue-panel--scroller .venue-panel-item__title {
    font-size: 26px;
    padding-right: 0;
  }
}
@media (min-width: 72em) {
  .venue-panel--scroller .venue-panel-item__title {
    font-size: 32px;
  }
}

/*  ==========================================================================
    Venue List Block
    ========================================================================== */
.venue-list {
  position: relative;
  margin: 30px 0;
  overflow: hidden;
}
@media (min-width: 50em) {
  .venue-list {
    margin: var(--content-margin-small);
  }
}

.venue-list__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .venue-list__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.venue-list__list {
  display: grid;
  gap: 40px;
  grid-template-columns: 1fr;
}
@media (min-width: 32em) {
  .venue-list__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px 25px;
  }
}
@media (min-width: 50em) {
  .venue-list__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 62.5em) {
  .venue-list__list {
    gap: 40px 40px;
  }
}

.venue-list__item {
  display: flex;
  width: 100%;
  box-sizing: content-box;
}

/*  ==========================================================================
    Video Gallery
    ========================================================================== */
.video-gallery {
  position: relative;
  padding: 15px 0 30px;
  overflow: hidden;
  background-color: #fff;
  color: #000;
}
@media (min-width: 50em) {
  .video-gallery {
    padding: 60px 0;
  }
}
.video-gallery:last-child {
  margin-bottom: 0;
}

@media (min-width: 62.5em) {
  .video-gallery__inner {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 62.5em) and (min-width: 50em) {
  .video-gallery__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.video-gallery__header {
  position: relative;
  margin: 0 15px 15px;
  padding-top: 15px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .video-gallery__header {
    align-items: center;
  }
}
@media (min-width: 62.5em) {
  .video-gallery__header {
    align-items: flex-start;
    margin: 0 0 30px;
    gap: 40px;
  }
}

.video-gallery__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .video-gallery__title {
    font-size: 28px;
  }
}

.video-gallery__description {
  margin-top: 5px;
  font-size: 15px;
  font-weight: 400;
}
@media (min-width: 50em) {
  .video-gallery__description {
    font-size: 20px;
  }
}

.video-gallery__actions {
  display: flex;
  gap: 0 8px;
  margin-left: auto;
  flex-shrink: 0;
}

.video-gallery__previous,
.video-gallery__next {
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  transition: background-color 0.4s ease;
  background-color: var(--theme-color);
}
.video-gallery__previous.video-gallery--grey,
.video-gallery__next.video-gallery--grey {
  background-color: #F4F4F4;
}
@media (min-width: 62.5em) {
  .video-gallery__previous,
  .video-gallery__next {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.video-gallery__previous.swiper-button-disabled,
.video-gallery__next.swiper-button-disabled {
  cursor: not-allowed;
}
.video-gallery__previous .o-icon,
.video-gallery__next .o-icon {
  color: var(--text-color-light);
  scale: 1;
  transition: scale 0.4s ease;
  width: 16px;
  height: 16px;
}
.video-gallery__previous:not(.swiper-button-disabled):hover .o-icon,
.video-gallery__next:not(.swiper-button-disabled):hover .o-icon {
  scale: 1.1;
}

.video-gallery__previous {
  margin-left: 0;
}
.video-gallery__previous .o-icon {
  rotate: -180deg;
}

.video-gallery__next {
  margin-left: 15px;
}
@media (min-width: 62.5em) {
  .video-gallery__next {
    margin-left: 0;
  }
}

.video-gallery__content.video-gallery__content--grid .video-gallery__list {
  display: grid;
  gap: 15px;
  margin: 0 15px;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
@media only screen and (max-width: 520px) {
  .video-gallery__content.video-gallery__content--grid .video-gallery__list {
    grid-template-columns: repeat(2, minmax(150px, 1fr));
  }
}
.video-gallery__content.video-gallery__content--grid .video-gallery__list::-webkit-scrollbar {
  display: none;
}
.video-gallery__content.video-gallery__content--grid .video-gallery__list:has(> :only-child) {
  grid-template-columns: 1fr;
  overflow: hidden;
}
@media (min-width: 42.5em) {
  .video-gallery__content.video-gallery__content--grid .video-gallery__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    overflow: visible;
  }
  .video-gallery__content.video-gallery__content--grid .video-gallery__list:has(> :only-child) {
    max-width: 660px;
    margin: 0 auto;
  }
}
@media (min-width: 62.5em) {
  .video-gallery__content.video-gallery__content--grid .video-gallery__list {
    margin: 0;
  }
}
.video-gallery__content.video-gallery__content--grid .video-gallery__item {
  width: 100%;
  display: flex;
}
.video-gallery__content.video-gallery__content--grid .video-gallery__item:only-child {
  width: 100%;
}
@media (min-width: medium-minor) {
  .video-gallery__content.video-gallery__content--grid .video-gallery__item:only-child {
    grid-column: 1/-1;
  }
}
.video-gallery__content.video-gallery__content--slider .video-gallery__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .video-gallery__content.video-gallery__content--slider .video-gallery__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}
.video-gallery__content.video-gallery__content--slider .video-gallery__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}
.video-gallery__content.video-gallery__content--slider .video-gallery__item {
  display: flex;
  width: 220px;
  padding-right: 15px;
  flex-shrink: 0;
  box-sizing: content-box;
  position: relative;
}
@media (min-width: 62.5em) {
  .video-gallery__content.video-gallery__content--slider .video-gallery__item {
    width: calc(23% - 23px);
    padding-right: 30px;
  }
  .video-gallery__content.video-gallery__content--slider .video-gallery__item:last-child {
    padding-right: 0;
  }
}

/*  ==========================================================================
    Video Gallery - Items
    ========================================================================== */
.video-gallery .video-item {
  display: flex;
  flex-direction: column;
  gap: 15px;
  height: 100%;
  width: 100%;
}
.video-gallery .video-item .video-item__content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.video-gallery .video-item .video-item__details {
  flex: 1;
  margin-top: 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 120px;
}
@media (min-width: 50em) {
  .video-gallery .video-item .video-item__details {
    min-height: 150px;
  }
}
.video-gallery .video-item .video-item__media {
  position: relative;
  overflow: hidden;
}
.video-gallery .video-item .video-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
  object-fit: cover;
  object-position: center;
}
.video-gallery .video-item .video-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
@media (min-width: 80em) {
  .video-gallery .video-item .video-item__intrinsic-ratio {
    padding-bottom: 66.6666666667%;
  }
}
.video-gallery .video-item .video-item__media:hover .video-item__image,
.video-gallery .video-item .video-item__media:focus .video-item__image {
  transform: scale(1.05);
}
.video-gallery .video-item .video-item__media:hover .video-item__icon,
.video-gallery .video-item .video-item__media:focus .video-item__icon {
  transform: scale(0.95);
}
.video-gallery .video-item .video-item__pretitle {
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 0;
}
.video-gallery .video-item .video-item__title {
  display: block;
  font-family: Faktum, sans-serif;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.6;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .video-gallery .video-item .video-item__title {
    font-size: 20px;
    line-height: 1.4;
  }
}
.video-gallery .video-item .video-item__description {
  font-size: 14px;
  margin-top: 10px;
  margin-bottom: 15px;
  text-wrap: pretty;
  list-style: 1.2;
}
@media (min-width: 50em) {
  .video-gallery .video-item .video-item__description {
    font-size: 16px;
  }
}
.video-gallery .video-item .video-item__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: 10px;
  bottom: 10px;
  padding: 1px;
  background-color: rgba(255, 255, 255, 0.6);
  color: var(--theme-color);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  z-index: 2;
  transition: transform 0.4s ease;
}
.video-gallery .video-item .video-item__icon .o-icon {
  width: 100%;
  height: 100%;
  max-width: 16px;
  margin-left: 5px;
}
@media (hover: hover) and (pointer: fine) {
  .video-gallery .video-item:hover .video-item__icon {
    background-color: #262687;
    color: var(--theme-highlight-color);
  }
}
.video-gallery .video-item .video-item__duration {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-top: auto;
  padding-top: 15px;
  border-top: 1px solid #C4C4C4;
  font-size: 15px;
  font-weight: 300;
}
.video-gallery .video-item .video-item__duration .o-icon {
  width: 20px;
  height: 20px;
}

/*  ==========================================================================
    Video Gallery - color schemes
    ========================================================================== */
.video-gallery.video-gallery--grey {
  background-color: #F4F4F4;
  color: #000;
}

/* ==========================================================================
   Well Block
   ========================================================================== */
.well-block {
  position: relative;
  padding: 0 15px;
  margin: var(--content-margin);
}

.well-block__inner {
  background-color: var(--theme-color);
}
@media (min-width: 59em) {
  .well-block__inner {
    width: 100%;
    max-width: 1000px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 59em) and (min-width: 50em) {
  .well-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

@media (min-width: 50em) {
  .well-block--centered h2 {
    text-align: center;
  }
}

.well {
  padding: 30px;
}
@media (min-width: 62.5em) {
  .well {
    padding: 40px;
  }
}
.well + .well {
  margin-top: 0;
}

.well-block__body.s-prose .well__title {
  color: var(--theme-highlight-color);
  border-bottom: none;
  padding-bottom: 0;
}

.well-block__body.s-prose h1,
.well-block__body.s-prose h2,
.well-block__body.s-prose h3,
.well-block__body.s-prose h4,
.well-block__body.s-prose h5,
.well-block__body.s-prose h6,
.well-block__body.s-prose p,
.well-block__body.s-prose ul,
.well-block__body.s-prose ol,
.well-block__body.s-prose li {
  color: var(--theme-body-text-color);
  border-color: color-mix(in srgb, var(--theme-body-text-color) 25%, transparent);
}

/*  ==========================================================================
    Event Header
    ========================================================================== */
.event-header {
  position: relative;
  background-color: var(--theme-color);
  color: var(--theme-body-text-color);
}

@media (min-width: 50em) {
  .event-header__inner {
    max-width: 1440px;
    margin: auto;
    display: flex;
  }
}

.event-header__media {
  width: 100%;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-header__media {
    width: 45%;
  }
}
@media (min-width: 90em) {
  .event-header__media {
    transform: translateX(calc(((100vw - 1440px) / 2) * -1));
  }
}

.event-header__media-inner {
  position: relative;
  height: 100%;
}
@media (min-width: 90em) {
  .event-header__media-inner {
    width: calc(100% + ((100vw - 1440px) / 2));
  }
}

@media (max-width: 49.99em) {
  .event-header__intrinsic-ratio {
    position: relative;
    padding-bottom: 75%;
    height: 0;
    overflow: hidden;
  }
}
@media (min-width: 50em) {
  .event-header__intrinsic-ratio {
    height: 100%;
  }
}

.event-header__image {
  position: absolute;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: 2;
}
@media (min-width: 50em) {
  .event-header__image {
    position: unset;
  }
}

.event-header__favorite {
  position: absolute;
  bottom: 20px;
  right: 20px;
  z-index: 2;
  display: none;
}

.event-header__favorite-btn {
  background-color: rgba(255, 255, 255, 0.75);
  border: none;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
}
.event-header__favorite-btn:hover {
  background: var(--theme-highlight-color);
}
.event-header__favorite-btn svg {
  width: 20px;
  height: 20px;
}
@media (min-width: 50em) {
  .event-header__favorite-btn {
    width: 60px;
    height: 60px;
  }
  .event-header__favorite-btn svg {
    width: 30px;
    height: 30px;
  }
}
.event-header__favorite-btn .filled {
  display: none;
}
.event-header__favorite-btn.is-favorite {
  background-color: #fff;
}
.event-header__favorite-btn.is-favorite .outline {
  display: none;
}
.event-header__favorite-btn.is-favorite .filled {
  display: block;
}

.event-header__content {
  padding: 20px 0 10px;
}
@media (min-width: 50em) {
  .event-header__content {
    max-width: 55%;
    align-self: center;
    padding: 40px 30px 40px 30px;
  }
}
@media (max-width: 49.99em) {
  .event-header__content {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 49.99em) and (min-width: 50em) {
  .event-header__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 80em) {
  .event-header__content {
    padding: 40px 60px 40px 120px;
  }
}

.event-header__titles {
  border-bottom: 1px solid;
  padding-bottom: 10px;
  color: var(--theme-highlight-color);
}

.event-header__title {
  display: flex;
  flex-direction: column;
  font-family: Faktum Wide, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 32px;
  text-wrap: balance;
  width: 100%;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-header__title {
    font-size: 38px;
  }
}
@media (min-width: 72em) {
  .event-header__title {
    font-size: 48px;
  }
}

@media (min-width: 50em) {
  .event-header__title--long {
    font-size: 28px;
  }
}
@media (min-width: 72em) {
  .event-header__title--long {
    font-size: 38px;
  }
}
@media (min-width: 106em) {
  .event-header__title--long {
    font-size: 42px;
  }
}

.event-header__suffix {
  font-weight: 400;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  margin-top: 20px;
  text-wrap: pretty;
}
@media (min-width: 50em) {
  .event-header__suffix {
    font-size: 22px;
  }
}
@media (min-width: 80em) {
  .event-header__suffix {
    font-size: 26px;
  }
}

.event-header__details {
  margin: 10px 0 15px;
}

.event-header__venue-dates:not(:first-child) {
  border-top: 1px solid var(--theme-highlight-color);
  padding-top: 10px;
  margin-top: 10px;
}

.event-header__venue {
  text-decoration: none;
  color: var(--theme-body-text-color);
  font-size: 16px;
  margin-bottom: 5px;
  display: block;
  font-weight: 500;
}

.event-header__dates {
  color: var(--theme-body-text-color);
  display: flex;
  flex-wrap: wrap;
  gap: 0 15px;
  font-size: 14px;
  font-weight: 500;
}

.event-header__date {
  margin: 0 0 5px;
}

.event-header__description {
  margin-bottom: 15px;
  font-size: 16px;
  font-weight: 600;
  color: var(--theme-body-text-color);
}
@media (max-width: 49.99em) {
  .event-header__description {
    display: none;
  }
}

.event-header__sticky,
.event-header__mobile-sticky {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  background-color: var(--theme-color);
  color: var(--theme-highlight-color);
  margin: auto;
  padding: 10px 20px;
  z-index: 5;
}
@media (min-width: 50em) {
  .event-header__sticky,
  .event-header__mobile-sticky {
    display: none;
  }
}

.event-header__mobile-sticky--light {
  background-color: #fff;
  color: #000;
  border-top: 1px solid #F4F4F4;
}
.event-header__mobile-sticky--light .event-header__copy {
  color: #000;
}
.event-header__mobile-sticky--light .event-header__text-button {
  color: #262687;
}

.event-header__mobile-buttons {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin: 10px 0 5px;
}

.event-header__tag {
  padding: 10px 20px;
  border-radius: 10px;
  color: var(--theme-body-text-color);
  background-color: transparent;
  border: 1px solid var(--theme-body-text-color);
}

.event-header__mobile-content-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.event-header__buttons {
  display: flex;
  gap: 15px;
  margin: 15px 0 10px;
}
@media (max-width: 49.99em) {
  .event-header__buttons {
    display: none;
  }
}
@media (min-width: 50em) {
  .event-header__buttons {
    margin: 30px 0 20px;
    gap: 20px;
    flex-wrap: wrap;
  }
}

.event-header__button {
  justify-content: center;
  font-weight: 700 !important;
}
@media (max-width: 49.99em) {
  .event-header__mobile-buttons .event-header__button:only-child {
    width: 100%;
  }
}
@media (max-width: 49.99em) {
  .event-header__mobile-buttons .event-header__button:not(only-child) {
    width: calc(50% - 7.5px);
  }
}
@media (min-width: 62.5em) {
  .event-header__button {
    width: calc(50% - 10px);
  }
}

.event-header__content-footer {
  display: flex;
  align-items: center;
  gap: 10px;
}
@media (max-width: 49.99em) {
  .event-header__content-footer {
    display: none;
  }
}

.event-header__copy {
  font-weight: 600;
  color: var(--theme-body-text-color);
  margin: 0;
  font-size: 14px;
  text-wrap: balance;
  line-height: 1.1;
}
@media (min-width: 50em) {
  .event-header__copy {
    font-size: 18px;
  }
}

.event-header__divider {
  font-size: 22px;
}

.event-header__text-button {
  background-color: transparent;
  border: none;
  outline: none;
  color: var(--theme-highlight-color);
  padding: 0;
  font-weight: 600;
  font-size: 14px;
  text-decoration: underline;
  cursor: pointer;
}
@media (min-width: 50em) {
  .event-header__text-button {
    font-size: 18px;
  }
}

/*  ==========================================================================
    Event Header Sticky - Desktop
    ========================================================================== */
@media (min-width: 50em) {
  .event-header__sticky {
    display: none;
    padding: 10px 30px;
    bottom: 15px;
    max-width: 520px;
    background: rgba(255, 255, 255, 0.45);
    border-radius: 50px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    transform: translateY(100%);
    transition: transform 0.7s ease, display 0.7s ease allow-discrete;
  }
  .event-header__sticky.show {
    display: block;
    transform: translateY(0%);
  }
  @starting-style {
    .event-header__sticky.show {
      transform: translateY(100%);
    }
  }
  .event-header__sticky,
  .event-header__sticky .event-header__copy,
  .event-header__sticky .event-header__text-button {
    color: #000;
  }
  .event-header__sticky .event-header__mobile-content-footer {
    margin: 15px 0 10px;
  }
  .event-header__sticky .event-header__mobile-buttons {
    margin-top: 15px;
  }
  .event-header__sticky .book-btn {
    background-color: var(--theme-color);
    border-color: var(--theme-color);
    color: var(--theme-body-text-color);
  }
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .event-header__sticky .book-btn:hover {
    color: #fff;
    border-color: #000;
    background-color: #000;
  }
}
@media (min-width: 50em) {
  .user-is-tabbing .event-header__sticky .book-btn:focus {
    color: #fff;
    border-color: #000;
    background-color: #000;
  }
  .event-header__sticky .subscribe-btn {
    border-color: #000;
    color: #000;
  }
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .event-header__sticky .subscribe-btn:hover {
    color: #fff;
    border-color: #000;
    background-color: #000;
  }
}
@media (min-width: 50em) {
  .user-is-tabbing .event-header__sticky .subscribe-btn:focus {
    color: #fff;
    border-color: #000;
    background-color: #000;
  }
  .event-header__sticky .event-header__tag {
    border-color: #000;
    color: #000;
  }
}

/*  ==========================================================================
    Event Header - Falback Image
    ========================================================================== */
.event-header__media--fallback .event-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 87.5%;
}
.event-header__media--fallback .event-header__image {
  position: absolute;
}

/*  ==========================================================================
    Event Header - Lapsed - Hidden Sticky Bar
    ========================================================================== */
/*  ==========================================================================
    Page Header
    ========================================================================== */
.page-header {
  position: relative;
}

.page-header__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .page-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.page-header__inner {
  position: relative;
}
@media (min-width: 50em) {
  .page-header__inner {
    display: flex;
  }
}

.page-header__content {
  width: 100%;
  padding: 40px 0;
  max-width: 800px;
}
@media (min-width: 50em) {
  .page-header__content {
    padding: 60px 0;
  }
}

.page-header__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  font-size: 28px;
  text-transform: uppercase;
  margin-bottom: 0;
  line-height: 1;
  text-wrap: balance;
}
@media (min-width: 50em) {
  .page-header__title {
    font-size: 42px;
  }
}
@media (min-width: 72em) {
  .page-header__title {
    font-size: 48px;
  }
}

.page-header__subtitle {
  font-family: Faktum, sans-serif;
  font-weight: 600;
  font-size: 20px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .page-header__subtitle {
    font-size: 28px;
  }
}
@media (min-width: 72em) {
  .page-header__subtitle {
    font-size: 38px;
  }
}

.page-header__description {
  font-size: 16px;
  line-height: 1.4;
  margin-top: 5px;
  margin-bottom: 0;
  text-wrap: pretty;
}
.page-header__subtitle + .page-header__description {
  margin-top: 0;
}
@media (min-width: 50em) {
  .page-header__description {
    font-size: 20px;
  }
}

/*  ==========================================================================
    Page Header - With Image
    ========================================================================== */
.page-header__media {
  overflow: hidden;
  width: 100%;
  position: relative;
  margin: 0 0 0 auto;
}
@media (max-width: 49.99em) {
  .page-header__media {
    margin-bottom: 40px;
  }
}
@media (min-width: 50em) {
  .page-header__media {
    width: 50%;
    margin-bottom: 0;
  }
  .page-header__media:before {
    content: "";
    position: absolute;
    top: -1px;
    left: 0;
    height: calc(100% + 2px);
    width: 160px;
    z-index: 1;
    background-color: #fff;
    transform: skewX(5deg);
    transform-origin: top;
    left: -120px;
  }
}

.page-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 60%;
  height: 0;
}

.page-header__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
}

@media (min-width: 50em) {
  .page-header--image .page-header__inner {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
.page-header--image .page-header__content {
  width: 100%;
  padding: 40px 0 20px;
}
@media (min-width: 50em) {
  .page-header--image .page-header__content {
    width: 50%;
    padding: 60px 0;
    max-width: 660px;
  }
}

/*  ==========================================================================
	Whats On - Header
	========================================================================== */
.calendar-header {
  position: relative;
  padding-top: 40px;
  padding-bottom: 10px;
}
@media (min-width: 72em) {
  .calendar-header {
    padding-bottom: 5px;
    padding-top: 60px;
  }
}

.calendar-header__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .calendar-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.calendar-header__container {
  display: flex;
  justify-content: space-between;
  gap: 30px;
  align-items: flex-end;
  border-bottom: 1px solid #dAdAdA;
  padding-bottom: 20px;
}
@media (min-width: 50em) {
  .calendar-header__container {
    align-items: center;
  }
}

.calendar-header__content {
  display: flex;
  align-items: flex-end;
  gap: 15px;
  padding-right: 60px;
}
@media (min-width: 72em) {
  .calendar-header__content {
    margin: 0;
    padding: 0;
    gap: 40px;
  }
}

.calendar-header__title {
  margin-bottom: 0;
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 28px;
}
@media (min-width: 50em) {
  .calendar-header__title {
    font-size: 42px;
  }
}
@media (min-width: 72em) {
  .calendar-header__title {
    font-size: 48px;
  }
}

.calendar-header__tabs {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 15px;
}
@media (min-width: 50em) {
  .calendar-header__tabs {
    gap: 1px;
  }
}

.calendar-header__tab {
  font-family: Faktum, sans-serif;
  font-size: 14px;
}
@media (max-width: 49.99em) {
  .calendar-header__tab {
    line-height: 1.2;
    text-wrap: nowrap;
    position: relative;
    text-transform: uppercase;
    font-weight: 500;
  }
  .calendar-header__tab:after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 2px;
    background-color: #000;
    opacity: 0;
  }
}
@media (min-width: 50em) {
  .calendar-header__tab {
    line-height: 1;
    background-color: #dAdAdA;
    transition: 0.4s ease;
    font-weight: 600;
    padding: 12px 15px;
  }
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .calendar-header__tab:hover {
    opacity: 0.8;
  }
}
@media (min-width: 50em) {
  .calendar-header__tab:first-child {
    border-radius: 20px 0 0 20px;
    padding-left: 20px;
  }
  .calendar-header__tab:last-child {
    border-radius: 0 20px 20px 0;
    padding-right: 20px;
  }
}

.calendar-header__tab--active {
  background-color: transparent;
  color: #000;
}
@media (max-width: 49.99em) {
  .calendar-header__tab--active {
    font-weight: 600;
  }
  .calendar-header__tab--active:after {
    opacity: 1;
  }
}
@media (min-width: 50em) {
  .calendar-header__tab--active {
    background-color: var(--theme-color);
    color: var(--theme-body-text-color);
  }
}

/*  ==========================================================================
	Calendar
	========================================================================== */
.calendar {
  position: relative;
  padding: 30px 0;
}

.calendar__inner {
  width: 100%;
  position: relative;
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .calendar__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 62.5em) {
  .calendar__inner {
    display: flex;
    align-items: flex-start;
  }
}

.calendar__list {
  order: 2;
  width: 100%;
}
@media (min-width: 62.5em) {
  .calendar__list {
    max-width: calc(100% - 450px);
  }
}
@media (min-width: 62.5em) {
  .calendar__list {
    order: 1;
    width: 100%;
  }
}

.calendar__sidebar {
  order: 1;
  width: 100%;
  position: sticky;
  top: 0;
  padding: 15px 0;
  z-index: 3;
}
@media (max-width: 62.49em) {
  .calendar__sidebar {
    margin: 0;
    margin-bottom: -15px;
    height: 0;
    padding: 0;
    top: 15px;
  }
}
@media (min-width: 62.5em) {
  .calendar__sidebar {
    margin-bottom: 30px;
    position: sticky;
    background-color: #fff;
    top: calc(var(--global-header-height) - 5px);
    right: 0;
    background-color: transparent;
    height: auto;
    display: flex;
    justify-content: flex-end;
    width: 450px;
    margin: 0;
    padding: 0;
    order: 2;
  }
}

@media (min-width: 50em) {
  .calendar__sidebar-inner {
    max-height: calc(100vh - var(--global-header-height));
    overflow: hidden auto;
  }
}

.calendar__sidebar__inner {
  display: flex;
  flex-direction: column;
}

.calendar__sticky {
  width: 100%;
  padding: 0 15px;
}
@media (min-width: 62.5em) {
  .calendar__sticky {
    width: 450px;
    padding: 0;
  }
}

.calendar-actions {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  overflow: hidden;
}
@media (min-width: 62.5em) {
  .calendar-actions {
    padding-right: 80px;
  }
}

.calendar-actions__date,
.calendar-actions__toggle,
.date-selector__close,
.calendar-filters__close {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  font-size: 14px;
  color: var(--theme-color-dark);
  cursor: pointer;
}
.calendar-actions__date .o-icon,
.calendar-actions__toggle .o-icon,
.date-selector__close .o-icon,
.calendar-filters__close .o-icon {
  width: 16px;
  height: 16px;
  margin-right: 8px;
}
@media (min-width: 50em) {
  .calendar-actions__date,
  .calendar-actions__toggle,
  .date-selector__close,
  .calendar-filters__close {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .calendar-actions__date,
  .calendar-actions__toggle,
  .date-selector__close,
  .calendar-filters__close {
    font-size: 20px;
  }
}

.calendar-actions__date, .calendar-actions__toggle {
  font-size: 14px;
}
@media (min-width: 50em) {
  .calendar-actions__date, .calendar-actions__toggle {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .calendar-actions__date, .calendar-actions__toggle {
    font-size: 20px;
  }
}
@media (max-width: 62.49em) {
  .calendar-actions__date .o-icon, .calendar-actions__toggle .o-icon {
    width: 20px;
    height: 20px;
    margin-right: 0px;
    margin-top: -2px;
  }
}

@media (min-width: 62.5em) {
  .date-selector__close {
    display: none;
  }
}

.date-selector__close,
.calendar-filters__close {
  flex-direction: row-reverse;
  position: absolute;
  top: 25px;
  right: 20px;
  color: #000;
  z-index: 3;
  transition: color 0.4s ease;
  text-decoration: none;
}
.date-selector__close .o-icon,
.calendar-filters__close .o-icon {
  width: 14px;
  height: 14px;
  margin-right: 8px;
  margin-top: -1px;
}
@media (hover: hover) and (pointer: fine) {
  .date-selector__close:hover,
  .calendar-filters__close:hover {
    color: var(--theme-color-dark);
  }
}

@media (min-width: 62.5em) {
  .calendar-actions__date, .calendar-actions__toggle {
    display: none;
  }
}

.calendar-actions__toggle {
  margin-left: 15px;
  transition: color 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  .calendar-actions__toggle:hover {
    color: #000;
  }
}

.calendar__desktop-date-picker {
  background: #fff;
  padding: 20px;
}

/* ==========================================================================
   Swiper
   ========================================================================== */
.swiper-container-vertical > .swiper-wrapper {
  flex-direction: column;
}

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

/* ==========================================================================
   Pagination
   ========================================================================== */
.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination.swiper-pagination-bullets {
  text-align: center;
  transform: translate3d(0, 0, 0);
  z-index: 10;
  width: 100%;
  cursor: pointer;
  display: flex;
  align-items: center;
}

.swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  margin: 0 calc(10px / 2);
  display: inline-block;
  border-radius: 100%;
  background: transparent;
  border: 1px solid #000;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background-color: #000;
}

/* ==========================================================================
   Slider nav
   ========================================================================== */
.swiper-button {
  position: absolute;
  top: 0%;
  z-index: 2;
  background: transparent;
  border: 0;
  border-radius: 0;
  text-indent: -999999px;
  overflow: hidden;
  width: 50px;
  height: 50px;
  opacity: 0.6;
  transition: opacity 0.2s ease;
  margin: 0;
  padding: 0;
}
@media (min-width: 50em) {
  .swiper-button {
    top: 30%;
    transform: translateY(-50%);
  }
}
@media (min-width: 59em) {
  .swiper-button {
    top: 50%;
    transform: translateY(-50%);
  }
}

.swiper-button-disabled {
  opacity: 0.2;
  cursor: not-allowed;
}

.swiper-button__prev {
  background: rgba(255, 255, 255, 0.4) url("images/navigate-before.svg") no-repeat center center;
  background-size: 100%;
  left: 15px;
}

.swiper-button__next {
  background: rgba(255, 255, 255, 0.4) url("images/navigate-next.svg") no-repeat center center;
  background-size: 100%;
  right: 15px;
}

@media (min-width: 50em) {
  .swiper-button__prev {
    left: 0;
    background: url("images/navigate-before.svg") no-repeat;
    background-size: 100%;
  }
  .swiper-button__next {
    right: 0;
    background: url("images/navigate-next.svg") no-repeat;
    background-size: 100%;
  }
}
@media (min-width: 72em) {
  .swiper-button__prev {
    left: 40px;
  }
  .swiper-button__next {
    right: 40px;
  }
}
.swiper-scrollbar {
  z-index: 50;
  height: 5px;
  margin: 20px 0 0;
  position: sticky;
  left: 0;
  display: none;
}
@media (min-width: 62.5em) {
  .swiper-scrollbar {
    display: block;
  }
}

.swiper-scrollbar-drag {
  height: 5px;
  position: relative;
  background: var(--theme-highlight-color);
  left: 0;
  top: 0;
}

/* ==========================================================================
   Scroller nav
   ========================================================================== */
.scroller__buttons {
  position: absolute;
  right: 0;
  bottom: 0;
}

.scroller__button[disabled] {
  opacity: 0.25;
  cursor: not-allowed;
}

.scroller__button {
  display: block;
  text-indent: -999999px;
  overflow: hidden;
  display: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  width: 40px;
  height: 40px;
  margin: 0;
  padding: 0;
}
@media (min-width: 59em) {
  .scroller__button {
    display: inline-block;
  }
}

.scroller__button--previous {
  background: url("images/navigate-before.svg") no-repeat center center;
  background-size: 100%;
}

.scroller__button--next {
  background: url("images/navigate-next.svg") no-repeat center center;
  background-size: 100%;
}

/*  ==========================================================================
    Video Block
	========================================================================== */
.video-block {
  position: relative;
  padding: 70px 0 30px;
  background-color: transparent;
  color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .video-block {
    padding: 80px 0 40px;
  }
}
@media (min-width: 72em) {
  .video-block {
    padding: 60px 0 40px;
  }
}
.user-is-tabbing .video-block a:focus {
  outline-color: #000;
}
.video-block:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--theme-color);
  z-index: 0;
  clip-path: polygon(0 40px, 100% 0, 100% 100%, 0 100%);
}

.video-block.video-block--black {
  background-color: transparent;
  color: #fff;
}
.user-is-tabbing .video-block.video-block--black a:focus {
  outline-color: #fff;
}
.video-block.video-block--black:before {
  background-color: #000;
}
.video-block.video-block--black .video-item .video-item__title,
.video-block.video-block--black .video-item .video-item__description,
.video-block.video-block--black .video-item .video-item__duration {
  color: #fff;
}

.video-block.video-block--grey {
  background-color: transparent;
  color: #000;
}
.user-is-tabbing .video-block.video-block--grey a:focus {
  outline-color: #000;
}
.video-block.video-block--grey:before {
  background-color: #F4F4F4;
}
.video-block.video-block--grey .video-item .video-item__title,
.video-block.video-block--grey .video-item .video-item__description,
.video-block.video-block--grey .video-item .video-item__duration {
  color: #000;
}

.video-block__inner {
  width: 100%;
  max-width: 1390px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .video-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.video-block__inner {
  position: relative;
}

/*  ==========================================================================
	Video Block - Video Item
	========================================================================== */
@media (min-width: 50em) {
  .video-block .video-item {
    display: flex;
    align-items: center;
    gap: 60px;
  }
}
.video-block .video-item .video-item__title {
  color: var(--theme-highlight-color);
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 26px;
  margin-bottom: 10px;
}
@media (min-width: 50em) {
  .video-block .video-item .video-item__title {
    font-size: 32px;
    margin-bottom: 15px;
  }
}
@media (min-width: 72em) {
  .video-block .video-item .video-item__title {
    font-size: 38px;
  }
}
.video-block .video-item .video-item__details {
  width: 100%;
}
@media (min-width: 50em) {
  .video-block .video-item .video-item__details {
    width: 40%;
  }
}
@media (min-width: 62.5em) {
  .video-block .video-item .video-item__details {
    width: 50%;
  }
}
.video-block .video-item .video-item__description {
  font-size: 16px;
  color: var(--theme-body-text-color);
  line-height: 1.1;
  margin-bottom: 30px;
}
@media (min-width: 50em) {
  .video-block .video-item .video-item__description {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .video-block .video-item .video-item__description {
    font-size: 20px;
  }
}
.video-block .video-item .video-item__content {
  display: flex;
  flex-direction: column;
  width: 100%;
}
@media (min-width: 50em) {
  .video-block .video-item .video-item__content {
    flex-direction: row;
    gap: 50px;
    align-items: center;
  }
}
@media (min-width: 62.5em) {
  .video-block .video-item .video-item__content {
    gap: 130px;
  }
}
.video-block .video-item .video-item__media {
  display: flex;
  order: 1;
}
@media (min-width: 50em) {
  .video-block .video-item .video-item__media {
    flex-direction: row-reverse;
    width: 60%;
  }
}
@media (min-width: 62.5em) {
  .video-block .video-item .video-item__media {
    width: 50%;
  }
}
.video-block .video-item .video-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
@media (min-width: 80em) {
  .video-block .video-item .video-item__intrinsic-ratio {
    padding-bottom: 66.6666666667%;
  }
}
.video-block .video-item .video-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
  object-fit: cover;
  object-position: center;
}
.video-block .video-item .video-item__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  inset: 0;
  margin: auto;
  padding: 1px;
  background-color: #fff;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  z-index: 2;
  transition: transform 0.4s ease;
  padding: 10px;
}
.video-block .video-item .video-item__icon .o-icon {
  width: 100%;
  height: 100%;
  color: #000;
  margin-left: 15%;
}
@media (min-width: 62.5em) {
  .video-block .video-item .video-item__icon {
    width: 75px;
    height: 75px;
    padding: 22px;
  }
}
.video-block .video-item .video-item__media:hover .video-item__image,
.video-block .video-item .video-item__media:focus .video-item__image {
  transform: scale(1.05);
}
.video-block .video-item .video-item__media:hover .video-item__icon,
.video-block .video-item .video-item__media:focus .video-item__icon {
  transform: scale(0.95);
}

/*  ==========================================================================
	Calendar List
	========================================================================== */
.calendar-list {
  position: relative;
}

.calendar-list__months {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (min-width: 50em) {
  .calendar-list__months {
    gap: 30px;
  }
}
.calendar-list__months .feature-banner {
  margin-top: 60px;
}

.calendar-list-month {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .calendar-list-month {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.calendar-list-month {
  display: flex;
  flex-direction: column;
  margin-bottom: 30px;
}
@media (max-width: 62.49em) {
  .calendar-list-month {
    padding-left: 0;
    padding-right: 0;
  }
}

.calendar-list-month__title {
  text-transform: capitalize;
  font-weight: 400;
  font-family: Faktum, sans-serif;
  margin-bottom: 20px;
  padding-bottom: 15px;
  top: 0;
  background-color: #fff;
  z-index: 2;
  font-size: 18px;
  position: sticky;
}
@media (max-width: 62.49em) {
  .calendar-list-month__title {
    padding-top: 15px;
  }
}
@media (min-width: 50em) {
  .calendar-list-month__title {
    font-size: 24px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-month__title {
    margin-top: 0;
    margin-bottom: 20px;
    padding-top: 15px;
    top: 0;
  }
}
@media (min-width: 72em) {
  .calendar-list-month__title {
    top: var(--global-header-height);
  }
}
.calendar-list-month__title strong {
  font-weight: 600;
}

.calendar-list-month__days {
  display: flex;
  flex-direction: column;
  gap: 25px;
}
@media (min-width: 50em) {
  .calendar-list-month__days {
    gap: 30px;
  }
}

.calendar-list-day {
  display: flex;
  align-items: flex-start;
}
@media (min-width: 50em) {
  .calendar-list-day {
    gap: 15px;
  }
}

.calendar-list-day__events div:last-child .calendar-list-event {
  padding-bottom: 0;
}

.calendar-list-day__title {
  display: flex;
  flex-direction: column;
  gap: 2px;
  position: sticky;
  top: 55px;
  font-family: Faktum, sans-serif;
  font-weight: 600;
  margin-bottom: 0;
  padding: 5px 0 0;
  border-top: 0;
  align-items: center;
  height: 100%;
  width: 80px;
}
@media (max-width: 49.99em) {
  .calendar-list-day__title {
    width: 75px;
  }
}
@media (min-width: 50em) {
  .calendar-list-day__title {
    top: 35px;
    padding: 35px 0;
    width: 105px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-day__title {
    top: 25px;
  }
}
@media (min-width: 72em) {
  .calendar-list-day__title {
    top: calc(var(--global-header-height) + 35px);
  }
}

.calendar-list-day__day {
  font-size: 14px;
  font-weight: 400;
  font-family: Faktum, sans-serif;
  display: block;
}
@media (min-width: 50em) {
  .calendar-list-day__day {
    display: none;
  }
}

.calendar-list-day__day--desktop {
  font-size: 14px;
  font-weight: 400;
  font-family: Faktum, sans-serif;
  display: none;
}
@media (min-width: 50em) {
  .calendar-list-day__day--desktop {
    display: block;
  }
}

.calendar-list-day__date {
  font-size: 28px;
}
@media (min-width: 50em) {
  .calendar-list-day__date {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-day__date {
    font-size: 48px;
  }
}

.calendar-list-day__events {
  border-left: 1px solid #dAdAdA;
  width: calc(100% - 80px);
}
@media (min-width: 50em) {
  .calendar-list-day__events {
    width: calc(100% - 105px);
  }
}

/*  ==========================================================================
	Calendar List Event
	========================================================================== */
.calendar-list-event {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  background: none;
  padding: 0 15px 25px;
  border-width: 0;
  text-align: left;
  width: 100%;
  cursor: pointer;
}
@media (min-width: 50em) {
  .calendar-list-event {
    padding: 20px 20px 25px;
  }
}
@media (min-width: 72em) {
  .calendar-list-event {
    gap: 40px;
  }
}
.calendar-list-event:hover .calendar-list-event__header::before {
  width: 5px;
}

.calendar-list-event__header {
  position: relative;
}
@media (min-width: 72em) {
  .calendar-list-event__header {
    width: calc(100% - 220px);
  }
}
.calendar-list-event__header:before {
  content: "";
  position: absolute;
  top: 0;
  left: -25px;
  width: 0;
  height: 100%;
  transition: width 0.1s ease-in-out;
}

.calendar-list-event__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.2;
  margin-bottom: 0;
  transition: color 0.4s ease;
  color: #000;
}
@media (min-width: 50em) {
  .calendar-list-event__title {
    font-size: 28px;
  }
}
@media (min-width: 80em) {
  .calendar-list-event__title {
    font-size: 32px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .calendar-list-event:hover .calendar-list-event__title {
    color: var(--theme-color-dark);
  }
}

.calendar-list-event__time {
  font-size: 14px;
  margin-bottom: 5px;
  font-weight: 500;
  color: #000;
  display: block;
}
@media (min-width: 50em) {
  .calendar-list-event__time {
    font-size: 16px;
    font-weight: 400;
  }
}

.calendar-list-event__venue {
  font-size: 14px;
  font-weight: 300;
  color: #000;
  margin-top: 10px;
}
@media (min-width: 50em) {
  .calendar-list-event__venue {
    font-size: 16px;
  }
}

.calendar-list-event__media {
  display: none;
}
@media (min-width: 72em) {
  .calendar-list-event__media {
    display: block;
    overflow: hidden;
    width: 180px;
    margin-top: 0;
  }
}

.calendar-list-event__intrinsic-ratio {
  position: relative;
  padding-bottom: 83.3333333333%;
  height: 0;
  min-height: 100%;
}

.calendar-list-event__image {
  height: auto;
  position: absolute;
  right: 0;
  transition: transform 0.4s ease;
  width: 100%;
  min-height: 100%;
  object-fit: cover;
}

/*  ==========================================================================
    Calendar - Footer
    ========================================================================== */
.calendar-info {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
}
@media (min-width: 50em) {
  .calendar-info {
    flex-direction: row;
    gap: 30px;
  }
}

.calendar-categories {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0;
  margin-top: 10px;
}
@media (min-width: 50em) {
  .calendar-categories {
    gap: 10px 15px;
  }
}

.calendar-category {
  color: var(--theme-color);
  border: 1px solid;
  border-radius: 20px;
  padding: 6px 10px;
  font-family: Faktum, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1;
  flex-shrink: 0;
}
@media (min-width: 50em) {
  .calendar-category {
    padding: 8px 15px;
  }
}

.calendar-availability {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 15px;
  flex-shrink: 0;
}
@media (min-width: 50em) {
  .calendar-availability {
    margin-left: auto;
  }
}

.calendar-availability--line {
  width: 130px;
  height: 7px;
  border-radius: 10px;
  background: linear-gradient(#000 0 0) 0/0% no-repeat #ddd;
}
@media (min-width: 50em) {
  .calendar-availability--line {
    width: 100px;
  }
}

.calendar-availability--text {
  font-family: Faktum, sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.calendar-availability--good .calendar-availability--line {
  background: linear-gradient(#289500 0 0) 0/0 no-repeat #ddd;
  animation: goodProgress 1s linear forwards;
  animation-iteration-count: 1;
}

.calendar-availability--low .calendar-availability--line {
  background: linear-gradient(#F5C600 0 0) 0/0 no-repeat #ddd;
  animation: lowProgress 1s linear forwards;
  animation-iteration-count: 1;
}

.calendar-availability--limited-seating .calendar-availability--line {
  background: linear-gradient(#BE0000 0 0) 0/0 no-repeat #ddd;
  animation: limitedProgress 1s linear forwards;
  animation-iteration-count: 1;
}

@keyframes goodProgress {
  100% {
    background-size: 100%;
  }
}
@keyframes lowProgress {
  100% {
    background-size: 55%;
  }
}
@keyframes limitedProgress {
  100% {
    background-size: 25%;
  }
}
.calendar-filters__label:before {
  width: 20px;
  height: 20px;
  top: 0px;
}
@media (min-width: 50em) {
  .calendar-filters__label:before {
    top: 1px;
  }
}
@media (min-width: 72em) {
  .calendar-filters__label:before {
    top: 2px;
  }
}

/*  ==========================================================================
	Calendar Date Selector
	========================================================================== */
.date-selector {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  height: 100svh;
  background-color: #fff;
  z-index: 13;
  padding: 0 20px;
  width: 100%;
  max-width: 470px;
  transform: translateX(-100%);
  transition: transform 0.4s ease;
}
.dates-open .date-selector {
  transform: translateX(0);
}
@media (min-width: 62.5em) {
  .date-selector {
    display: block;
    position: unset;
    top: unset;
    right: unset;
    height: unset;
    padding: 0;
    background-color: transparent;
    transform: translateX(0);
    opacity: 1;
    transition: opacity 0.4s ease;
  }
  .filters-open .date-selector, .nav-open .date-selector {
    opacity: 0;
    pointer-events: none;
  }
}

@media (max-width: 62.49em) {
  .calendar__desktop-date-picker {
    display: none;
  }
}

.date-selector__inner {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 30px;
  height: 100vh;
  max-width: 550px;
  margin: 0 auto;
}
@media (min-width: 62.5em) {
  .date-selector__inner {
    height: unset;
    max-width: none;
    margin: 0;
  }
}
.date-selector__inner::-webkit-scrollbar {
  display: none;
}
@-moz-document url-prefix() {
  .date-selector__inner {
    scrollbar-width: none;
  }
}

.date-selector__month {
  margin-bottom: 15px;
}
@media (min-width: 32em) {
  .date-selector__month {
    margin-bottom: 0;
  }
}

.date-selector__header {
  position: sticky;
  top: 0;
  z-index: 2;
  border-bottom: 1px solid #dAdAdA;
  background-color: #fff;
  padding: 20px 0 0;
  margin-bottom: 15px;
}
@media (min-width: 62.5em) {
  .date-selector__header {
    background-color: transparent;
    padding: 0;
    margin-bottom: 0;
  }
}

.date-selector__month-header {
  display: flex;
  align-items: center;
  margin-bottom: 30px;
}

.date-selector__month-title {
  font-size: 22px;
  margin-bottom: 0;
  text-transform: capitalize;
  font-family: Faktum, sans-serif;
  font-weight: 400;
}
.date-selector__month-title strong {
  font-weight: 600;
}

.date-selector__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-left: auto;
  flex-shrink: 0;
}

.date-selector__button {
  padding: 0;
  background: var(--theme-color);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px;
  margin-right: 7px;
  width: 31px;
  height: 31px;
  cursor: pointer;
  transition: opacity 0.4s ease, color 0.4s ease, border-color 0.4s ease;
}
.date-selector__button .o-icon {
  height: 15px;
  width: 15px;
  fill: var(--theme-body-text-color);
}
.date-selector__button:last-child {
  margin-right: 0;
}
@media (hover: hover) and (pointer: fine) {
  .date-selector__button:hover {
    opacity: 0.8;
  }
}
.date-selector__button:active .o-icon {
  scale: 0.9;
}

.date-selector__button--disabled {
  opacity: 0.25;
  cursor: not-allowed;
}
@media (hover: hover) and (pointer: fine) {
  .date-selector__button--disabled:hover {
    opacity: 0.25;
  }
}

.date-selector__button--previous .o-icon {
  rotate: 180deg;
}

.date-selector__days-header {
  display: flex;
  align-items: center;
  padding-bottom: 10px;
}

.date-selector__day-name {
  width: 14.285%;
  text-transform: uppercase;
  font-weight: 700;
  font-family: Faktum, sans-serif;
  font-size: 14px;
  text-align: center;
}

.date-selector__days {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.date-selector__day {
  width: 14.285%;
  opacity: 0.3;
  text-align: center;
  padding: 10px 10px;
  margin: 5px 0;
  border: none;
  background: transparent;
  color: #444;
  font-family: Faktum, sans-serif;
}

.date-selector__day--events {
  font-weight: 700;
  opacity: 1;
  cursor: pointer;
}

.date-selector__day--today {
  opacity: 1;
  position: relative;
  background-color: var(--theme-color);
  color: var(--theme-body-text-color);
  font-weight: 700;
  border-radius: 20px;
}

/*  ==========================================================================
	Calendar Date Selector - Mobile (Vertical Scrolling)
	========================================================================== */
.calendar__mobile-date-picker .date-selector__month {
  margin-bottom: 15px;
}
.calendar__mobile-date-picker .date-selector__month-title {
  font-size: 18px;
  margin-bottom: 30px;
}
.calendar__mobile-date-picker .date-selector__month-header {
  display: block;
  position: sticky;
  top: 0;
  z-index: 2;
  background-color: #fff;
  margin-bottom: 15px;
}
@media (min-width: 62.5em) {
  .calendar__mobile-date-picker {
    display: none;
  }
}

/*  ==========================================================================
	Calendar Filters
	========================================================================== */
.calendar-filters__action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: 20px;
  padding-bottom: 15px;
  box-shadow: 0 -6px 20px 10px #fff;
}
.calendar-filters__action .calendar-filters__btn {
  width: 100%;
  border-radius: 20px;
}
@media (min-width: 50em) {
  .calendar-filters__action {
    padding-bottom: 40px;
  }
}

.calendar-filters__body {
  display: flex;
  flex-direction: column;
  background-color: #fff;
  padding: 20px 15px 0;
  width: 100%;
}
@media (max-width: 62.49em) {
  .calendar-filters__body {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    height: 100svh;
    background-color: #fff;
    z-index: 13;
    padding: 0 20px;
    width: 100%;
    max-width: 470px;
    transform: translateX(100%);
    transition: transform 0.4s ease;
    padding-top: 30px;
    overflow-y: auto;
  }
}
@media (min-width: 50em) {
  .calendar-filters__body {
    padding: 30px 20px 0;
    max-width: 410px;
  }
}
@media (min-width: 62.5em) {
  .calendar-filters__body {
    padding: 0 20px;
  }
}
.calendar-filters__body .calendar-filters__toggle {
  top: 0;
  right: 0;
}
@media (min-width: 62.5em) {
  .calendar-filters__body .calendar-filters__toggle {
    display: none;
  }
}
.user-is-tabbing .calendar-filters__body .calendar-filters__toggle:focus {
  outline: 2px solid #000;
  outline-offset: 5px;
  overflow: hidden;
}
.calendar-filters__body .calendar-filters__reset {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 16px;
  font-weight: 500;
  color: #000;
}
.filters-open .calendar-filters__body {
  transform: translateX(0);
  box-shadow: 0 0 25px 5px rgba(0, 0, 0, 0.1);
}

.calendar-filter__header {
  position: relative;
}

.calendar-filters__title {
  font-size: 18px;
  font-weight: 600;
  font-family: Faktum, sans-serif;
  margin-bottom: 30px;
}

.calendar-filters__groups {
  margin-bottom: auto;
}

.calendar-filters__group + .calendar-filters__group {
  margin-top: 10px;
}

.calendar-filters__group__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 0 0 10px;
  border: 1px solid #dAdAdA;
  border-width: 0 0 1px 0;
  background-color: transparent;
  width: 100%;
}
.user-is-tabbing .calendar-filters__group__header:focus {
  outline: 2px solid #000;
  outline-offset: 5px;
  overflow: hidden;
}

.calendar-filters__group__name {
  font-size: 16px;
  font-weight: 600;
  font-family: Faktum, sans-serif;
  margin-bottom: 0;
}

.calendar-filters__group__toggle {
  position: relative;
  width: 23px;
  height: 23px;
  flex-shrink: 0;
  margin-left: auto;
  border-radius: 100%;
}
.calendar-filters__group__toggle:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 2px;
  transform: translate(-50%, -50%);
  background-color: #000;
  transition: background-color 0.3s ease;
}

.calendar-filters__options {
  display: none;
}
.calendar-filters__options.is-toggled {
  display: block;
}

.calendar-filters__list {
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
  padding: 20px 0;
}

.calendar-filters__item {
  display: flex;
  align-items: center;
  flex: 1 1 auto;
  min-width: calc(50% - 10px);
  gap: 10px;
}
.calendar-filters__item--disabled {
  opacity: 0.5;
}
.calendar-filters__item input[type=checkbox] {
  display: none;
}
.calendar-filters__item input[type=checkbox] + label {
  position: relative;
  display: flex;
  align-items: flex-start;
  margin: 0;
  width: auto;
  padding-top: 0;
}
.calendar-filters__item input[type=checkbox] + label strong, .calendar-filters__item input[type=checkbox] + label em, .calendar-filters__item input[type=checkbox] + label b {
  margin: 0 4px;
}
.calendar-filters__item input[type=checkbox] + label:before {
  content: "";
  width: 18px;
  height: 18px;
  margin: 3px 10px -6px 0;
  display: inline-block;
  flex-shrink: 0;
  box-sizing: border-box;
  border: 1.5px solid var(--theme-color);
}
.calendar-filters__item input[type=checkbox] + label:after {
  --border: 2px solid transparent;
  border-right: var(--border);
  border-top: var(--border);
  transform: scaleX(-1) rotate(135deg);
  transform-origin: left top;
  content: "";
  display: block;
  height: 12px;
  width: 6px;
  top: 13px;
  left: 3px;
  position: absolute;
  transition: border-color 0.4s;
  box-sizing: border-box;
}
.calendar-filters__item input[type=checkbox]:checked + label:before {
  background-color: var(--theme-color);
}
.calendar-filters__item input[type=checkbox]:checked + label:after {
  animation: check 0.8s;
  border-color: var(--theme-body-text-color);
}
@keyframes check {
  0% {
    height: 0;
    width: 0;
  }
  25% {
    height: 0;
    width: 6px;
  }
  50% {
    height: 12px;
    width: 6px;
  }
}

.calendar-filters__more {
  margin: 0 0 20px;
}

.calendar-filters__group--long .calendar-filters__list div:nth-of-type(1n+7) {
  display: none;
}
.calendar-filters__group--long.is-toggled .calendar-filters__list div {
  display: block;
}
.calendar-filters__group--long.is-toggled .calendar-filters__more {
  display: none;
}

/*  ==========================================================================
    Concert List
    ========================================================================== */
.concert-list-block {
  position: relative;
  padding: 15px 0 30px;
  overflow: hidden;
  background-color: #fff;
  color: #000;
}
@media (min-width: 50em) {
  .concert-list-block {
    padding: 30px 0;
  }
}
.concert-list-block:last-child {
  margin-bottom: 0;
}

@media (min-width: 62.5em) {
  .concert-list-block__inner {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 62.5em) and (min-width: 50em) {
  .concert-list-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.concert-list-block__header {
  position: relative;
  margin: 0 15px 15px;
  padding-top: 15px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .concert-list-block__header {
    align-items: center;
  }
}
@media (min-width: 62.5em) {
  .concert-list-block__header {
    align-items: flex-start;
    margin: 0 0 15px;
    gap: 40px;
  }
}

.concert-list-block__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .concert-list-block__title {
    font-size: 28px;
  }
}

.concert-list-block__description {
  margin-top: 5px;
  font-size: 15px;
  font-weight: 400;
}
@media (min-width: 50em) {
  .concert-list-block__description {
    font-size: 20px;
  }
}

.concert-list-block__actions {
  display: flex;
  gap: 0 8px;
  margin-left: auto;
  flex-shrink: 0;
}
@media (min-width: 62.5em) {
  .concert-list-block__actions {
    margin-right: 40px;
  }
}

.concert-list-block__previous,
.concert-list-block__next {
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  transition: background-color 0.4s ease;
  background-color: var(--theme-color);
}
.concert-list-block__previous.concert-list-block--grey,
.concert-list-block__next.concert-list-block--grey {
  background-color: #F4F4F4;
}
@media (min-width: 62.5em) {
  .concert-list-block__previous,
  .concert-list-block__next {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.concert-list-block__previous.swiper-button-disabled,
.concert-list-block__next.swiper-button-disabled {
  cursor: not-allowed;
}
.concert-list-block__previous .o-icon,
.concert-list-block__next .o-icon {
  color: var(--text-color-light);
  scale: 1;
  transition: scale 0.4s ease;
  width: 16px;
  height: 16px;
}
.concert-list-block__previous:not(.swiper-button-disabled):hover .o-icon,
.concert-list-block__next:not(.swiper-button-disabled):hover .o-icon {
  scale: 1.1;
}

.concert-list-block__previous {
  margin-left: 0;
}
.concert-list-block__previous .o-icon {
  rotate: -180deg;
}

.concert-list-block__next {
  margin-left: 15px;
}
@media (min-width: 62.5em) {
  .concert-list-block__next {
    margin-left: 0;
  }
}

.concert-list-block__content.concert-list-block__content--grid .concert-list-block__grid::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__grid {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.concert-list-block__content.concert-list-block__content--grid .concert-list-block__list {
  display: grid;
  gap: 15px;
  grid-template-columns: 1fr;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.concert-list-block__content.concert-list-block__content--grid .concert-list-block__list::-webkit-scrollbar {
  display: none;
}
.concert-list-block__content.concert-list-block__content--grid .concert-list-block__list:has(> :only-child) {
  grid-template-columns: 1fr;
  overflow: hidden;
}
@media (min-width: 42.5em) {
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    overflow: visible;
  }
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__list:has(> :only-child) {
    max-width: 660px;
    margin: 0 auto;
  }
}
@media (min-width: 50em) {
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__list {
    overflow-x: auto;
  }
}
@media (max-width: 49.99em) {
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__list {
    grid-template-columns: 1fr;
  }
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__list .concert-list-block__item {
    display: flex;
    width: 100%;
    padding-right: 15px;
    flex-shrink: 0;
    box-sizing: content-box;
    position: relative;
  }
}
@media (min-width: 59em) {
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
.concert-list-block__content.concert-list-block__content--grid .concert-list-block__item {
  width: 100%;
  display: flex;
}
.concert-list-block__content.concert-list-block__content--grid .concert-list-block__item:only-child {
  width: 100%;
}
@media (min-width: medium-minor) {
  .concert-list-block__content.concert-list-block__content--grid .concert-list-block__item:only-child {
    grid-column: 1/-1;
  }
}
.concert-list-block__content.concert-list-block__content--slider .concert-list-block__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .concert-list-block__content.concert-list-block__content--slider .concert-list-block__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}
.concert-list-block__content.concert-list-block__content--slider .concert-list-block__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}
.concert-list-block__content.concert-list-block__content--slider .concert-list-block__item {
  display: flex;
  width: 320px;
  padding-right: 15px;
  flex-shrink: 0;
  box-sizing: content-box;
  position: relative;
}
@media (min-width: 62.5em) {
  .concert-list-block__content.concert-list-block__content--slider .concert-list-block__item {
    width: calc(33.33% - 23px);
    padding-right: 30px;
  }
  .concert-list-block__content.concert-list-block__content--slider .concert-list-block__item:last-child {
    padding-right: 0;
  }
}
@media (min-width: 62.5em) {
  .concert-list-block__content.concert-list-block__content--slider-more {
    width: calc(100% - 30px);
  }
}

.concert-list-block:has(.concert-list-block__grid) .concert-list-block__actions {
  display: none;
}

/*  ==========================================================================
    Concert List - Items
    ========================================================================== */
.concert-list-block .concert-item {
  display: flex;
  flex-direction: column;
  gap: 15px;
  height: 100%;
  width: 100%;
}
.concert-list-block .concert-item .concert-item__content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.concert-list-block .concert-item .concert-item__details {
  flex: 1;
  margin-top: 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 120px;
}
@media (min-width: 50em) {
  .concert-list-block .concert-item .concert-item__details {
    min-height: 150px;
  }
}
.concert-list-block .concert-item .concert-item__media {
  position: relative;
  overflow: hidden;
}
.concert-list-block .concert-item .concert-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
  object-fit: cover;
  object-position: center;
}
.concert-list-block .concert-item .concert-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
.concert-list-block .concert-item .concert-item__favorite {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2;
  display: none;
}
@media (min-width: 50em) {
  .concert-list-block .concert-item .concert-item__favorite {
    bottom: 20px;
    right: 20px;
  }
}
.concert-list-block .concert-item .concert-item__favorite-btn {
  background-color: rgba(255, 255, 255, 0.75);
  border: none;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  padding: 0;
}
.concert-list-block .concert-item .concert-item__favorite-btn:hover {
  background: var(--theme-highlight-color);
}
.concert-list-block .concert-item .concert-item__favorite-btn svg {
  width: 18px;
  height: 18px;
}
@media (min-width: 50em) {
  .concert-list-block .concert-item .concert-item__favorite-btn {
    width: 46px;
    height: 46px;
  }
  .concert-list-block .concert-item .concert-item__favorite-btn svg {
    width: 23px;
    height: 23px;
  }
}
.concert-list-block .concert-item .concert-item__favorite-btn .filled {
  display: none;
}
.concert-list-block .concert-item .concert-item__favorite-btn.is-favorite {
  background-color: #fff;
}
.concert-list-block .concert-item .concert-item__favorite-btn.is-favorite .outline {
  display: none;
}
.concert-list-block .concert-item .concert-item__favorite-btn.is-favorite .filled {
  display: block;
}
.concert-list-block .concert-item .concert-item__title {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .concert-list-block .concert-item .concert-item__title {
    font-size: 22px;
    line-height: 1.4;
    min-height: 62px;
  }
}
.concert-list-block .concert-item .concert-item__dates {
  margin-top: 15px;
}
.concert-list-block .concert-item .concert-item__date-item {
  display: flex;
  border-top: 1px solid #dAdAdA;
  padding: 5px 0 7px;
  gap: 40px;
}
.concert-list-block .concert-item .concert-item__date {
  font-size: 14px;
  margin: 0;
}
.concert-list-block .concert-item .concert-item__venue {
  font-size: 14px;
  font-weight: 500;
  margin: 0;
}
.concert-list-block .concert-item .concert-item__categories {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 5px;
  list-style: none;
  padding: 0;
  margin: 0;
  padding-top: 15px;
  border-top: 1px solid #dAdAdA;
}
.concert-list-block .concert-item .concert-item-category {
  color: var(--theme-color);
  border: 1px solid;
  border-radius: 20px;
  padding: 6px 10px;
  font-family: Faktum, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1;
  flex-shrink: 0;
}
@media (min-width: 50em) {
  .concert-list-block .concert-item .concert-item-category {
    padding: 8px 15px;
  }
}

/*  ==========================================================================
	Event Item
	========================================================================== */
.event-item {
  color: #000;
  width: 100%;
}

.event-item__media {
  position: relative;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
}

.event-item__image {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
  .event-item:hover .event-item__image {
    transform: scale(1.05);
  }
}

.event-item__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 15px;
  height: 100%;
}

.event-item__details {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 0 0 15px;
}

.event-item__prefix {
  font-weight: 300;
  font-size: 12px;
}
@media (min-width: 50em) {
  .event-item__prefix {
    font-size: 14px;
  }
}
@media (min-width: 90em) {
  .event-item__prefix {
    font-size: 16px;
  }
}

.event-item__titles {
  line-height: 0.9;
  transition: color 0.3s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
  .event-item:hover .event-item__titles {
    color: var(--theme-color-dark);
  }
}

.event-item__title {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-size: 18px;
  font-weight: 700;
  margin: 10px 0 8px;
}
@media (min-width: 50em) {
  .event-item__title {
    font-size: 24px;
  }
}
@media (min-width: 72em) {
  .event-item__title {
    font-size: 28px;
  }
}

.event-item__cite {
  margin: 0;
}

.event-item__name {
  font-weight: 700;
}

.event-item__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid;
  padding-bottom: 5px;
  margin: auto 0 0;
}

.event-item__date {
  position: relative;
  font-weight: 300;
  margin: 0;
  font-size: 12px;
  transition: color 0.3s ease-in-out;
  text-wrap: nowrap;
}
@media (min-width: 50em) {
  .event-item__date {
    font-size: 14px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .event-item:hover .event-item__date {
    color: var(--theme-color-dark);
  }
  .event-item:hover .event-item__date:before {
    height: 2px;
    background-color: var(--theme-color-dark);
  }
}

.event-item__location {
  position: relative;
  font-weight: 300;
  margin: 0;
  font-size: 12px;
  transition: color 0.3s ease-in-out;
  display: flex;
  align-items: center;
  text-wrap: balance;
}
@media (min-width: 50em) {
  .event-item__location {
    font-size: 14px;
  }
}
.event-item__location .event-pin {
  height: 24px;
  width: 24px;
  margin-top: -1px;
  margin-right: 5px;
}

.event-item__heart {
  position: absolute;
  top: 10px;
  right: 10px;
  border: none;
  background: none;
  width: 35px;
  height: 35px;
}
.event-item__heart .o-icon {
  fill: #fff;
  width: 100%;
  height: 100%;
}

/*  ==========================================================================
    Breadcrumb
    ========================================================================== */
.breadcrumbs {
  display: flex;
  margin-top: 20px;
  margin-bottom: 20px;
  overflow-x: auto;
}
@media (min-width: 50em) {
  .breadcrumbs {
    margin-top: 40px;
    margin-bottom: 20px;
  }
}

.breadcrumbs__list {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 15px;
  align-items: center;
}

.breadcrumb {
  transition: color 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 5px;
  font-size: 14px;
  font-weight: 600;
}
@media (min-width: 50em) {
  .breadcrumb {
    font-weight: 700;
    font-size: 18px;
  }
}
.breadcrumb .o-icon--chevron-left {
  width: 10px;
  height: 10px;
}
@media (min-width: 50em) {
  .breadcrumb .o-icon--chevron-left {
    width: 16px;
    height: 16px;
  }
}

/*  ==========================================================================
    Article List
    ========================================================================== */
@media (min-width: 59em) {
  .article-list {
    padding: 40px 0 60px;
  }
}

.article-list__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-list__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.article-list__title {
  width: 100%;
  grid-column: 1/-1;
  font-family: Faktum Wide, sans-serif;
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .article-list__title {
    font-size: 28px;
  }
}

.article-list__feature-grid {
  display: grid;
  gap: 30px;
  margin-bottom: 80px;
}
@media (min-width: 32em) {
  .article-list__feature-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px 15px;
    margin-bottom: 120px;
  }
}
@media (min-width: 62.5em) {
  .article-list__feature-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px 60px;
  }
}

.article-list__grid {
  display: grid;
  gap: 30px;
  margin-bottom: 80px;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 50em) {
  .article-list__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px 15px;
  }
}
@media (min-width: 62.5em) {
  .article-list__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
  }
}

.article-list__item .post-item {
  height: 100%;
}

.article-list__item--featured .post-item__inner {
  gap: 20px;
}
@media (min-width: 62.5em) {
  .article-list__item--featured .post-item__inner {
    gap: 25px;
  }
}
.article-list__item--featured .post-item__title {
  font-size: 20px;
  font-weight: 600;
}
@media (min-width: 50em) {
  .article-list__item--featured .post-item__title {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .article-list__item--featured .post-item__title {
    font-size: 24px;
    line-height: 1.2;
  }
}
@media (min-width: 72em) {
  .article-list__item--featured .post-item__title {
    font-size: 28px;
  }
}

/*  ==========================================================================
    Article List Header
    ========================================================================== */
.article-list-header {
  margin: 40px 0;
}

.article-list-header__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-list-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.article-list-header__inner {
  display: flex;
  justify-content: space-between;
}

.article-list-header__titles {
  width: 50%;
}

.article-list-header__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 28px;
  margin-bottom: 0;
  line-height: 1.2;
  text-transform: uppercase;
}
@media (min-width: 32em) {
  .article-list-header__title {
    font-size: 38px;
  }
}
@media (min-width: 50em) {
  .article-list-header__title {
    font-size: 42px;
  }
}
@media (min-width: 72em) {
  .article-list-header__title {
    font-size: 48px;
  }
}

/*  ==========================================================================
	Article Header
	========================================================================== */
.article-header {
  position: relative;
  margin-top: 15px;
  color: var(--theme-highlight-color);
}
.article-header:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 75%;
  z-index: 1;
  background-color: var(--theme-color);
}

.article-header__inner {
  width: 100%;
  max-width: 1120px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.article-header__inner {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (min-width: 72em) {
  .article-header__inner {
    gap: 40px;
  }
}

.article-header__content {
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding: 20px 0 10px;
  z-index: 2;
}
@media (min-width: 50em) {
  .article-header__content {
    padding-bottom: 30px;
    gap: 40px;
  }
}

.article-header__details {
  display: flex;
  flex-direction: column;
  width: 100%;
}
@media (min-width: 72em) {
  .article-header__details {
    margin-top: 20px;
  }
}

.article-header__titles {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (min-width: 50em) {
  .article-header__titles {
    gap: 20px;
  }
}

.article-header__category {
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  font-size: 18px;
}
@media (min-width: 50em) {
  .article-header__category {
    font-size: 22px;
  }
}

.article-header__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 800;
  font-size: 28px;
  text-transform: uppercase;
  margin-bottom: 0;
  line-height: 1.1;
}
@media (min-width: 50em) {
  .article-header__title {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .article-header__title {
    font-size: 48px;
  }
}

.article-header__subtitle {
  font-family: Faktum Wide, sans-serif;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.2;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .article-header__subtitle {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .article-header__subtitle {
    font-size: 38px;
  }
}

.article-header__date,
.article-header__author {
  font-size: 14px;
  font-weight: 300;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .article-header__date,
  .article-header__author {
    font-size: 16px;
  }
}
@media (min-width: 62.5em) {
  .article-header__date,
  .article-header__author {
    font-size: 18px;
  }
}

.article-header__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  flex-shrink: 0;
  gap: 5px 10px;
  width: 100%;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid;
}
@media (min-width: 50em) {
  .article-header__footer {
    gap: 5px 20px;
    margin-top: 30px;
    padding-top: 25px;
  }
}
.article-header__footer .o-icon {
  width: 12px;
  height: 12px;
}

/*  ==========================================================================
	Article Header - Media
	========================================================================== */
.article-header__media {
  position: relative;
  z-index: 2;
}
@media (max-width: 49.99em) {
  .article-header__media {
    margin: 0 -15px;
  }
}
.article-header__media .video-item__icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--theme-highlight-color);
  border: 2px solid var(--theme-highlight-color);
  width: 68px;
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  z-index: 2;
  transition: background-color 0.2s ease-in-out;
}
.article-header__media .video-item__icon .o-icon {
  width: 25px;
  height: 25px;
  margin-right: -4px;
  color: #000;
  transition: color 0.2s ease-in-out;
}
@media (min-width: 50em) {
  .article-header__media .video-item__icon {
    width: 80px;
    height: 80px;
  }
  .article-header__media .video-item__icon .o-icon {
    width: 35px;
    height: 35px;
    margin-right: -7px;
  }
}
.article-header__media.article-header--video:hover .video-item__icon {
  background-color: transparent;
}
.article-header__media.article-header--video:hover .video-item__icon .o-icon {
  color: var(--theme-highlight-color);
}

.article-header__figure {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
}

.article-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
}

.article-header__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  z-index: 2;
}

/*  ==========================================================================
	Article Header - Nav
	========================================================================== */
.article-header__nav {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-header__nav {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.article-header__nav-link {
  color: black;
  font-weight: 600;
}
.article-header__nav-link span {
  font-weight: 300;
}

/*  ==========================================================================
	Page Scroller
	========================================================================== */
.page-scroller {
  position: relative;
  margin: var(--content-margin);
  overflow: hidden;
}

@media (min-width: 62.5em) {
  .page-scroller__inner {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 62.5em) and (min-width: 50em) {
  .page-scroller__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.page-scroller__header {
  position: relative;
  border-top: 1px solid #000;
  margin: 0 15px 30px;
  padding-top: 15px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .page-scroller__header {
    align-items: center;
  }
}
@media (min-width: 62.5em) {
  .page-scroller__header {
    margin: 0 0 30px;
  }
}

.page-scroller__title {
  font-size: 32px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .page-scroller__title {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .page-scroller__title {
    font-size: 60px;
  }
}

.page-scroller__actions {
  display: flex;
  gap: 0 8px;
  margin-left: auto;
  flex-shrink: 0;
}

.page-scroller__previous,
.page-scroller__next {
  background-color: var(--theme-color-dark);
  color: #fff;
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  transition: background-color 0.4s ease;
}
@media (min-width: 62.5em) {
  .page-scroller__previous,
  .page-scroller__next {
    display: inline-block;
  }
}
.page-scroller__previous.swiper-button-disabled,
.page-scroller__next.swiper-button-disabled {
  cursor: not-allowed;
}
.page-scroller__previous .o-icon,
.page-scroller__next .o-icon {
  width: 16px;
  height: 20px;
  transition: color 0.4s ease;
}
.page-scroller__previous:not(.swiper-button-disabled):hover,
.page-scroller__next:not(.swiper-button-disabled):hover {
  background-color: #000;
}
.page-scroller__previous:not(.swiper-button-disabled):hover .o-icon,
.page-scroller__next:not(.swiper-button-disabled):hover .o-icon {
  color: #fff;
}

.page-scroller__previous {
  margin-right: 0;
}
.page-scroller__previous .o-icon {
  transform: rotate(180deg);
}

.page-scroller__next {
  margin-right: 15px;
}
@media (min-width: 62.5em) {
  .page-scroller__next {
    margin-right: 0;
  }
}

.page-scroller__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .page-scroller__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}

.page-scroller__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}

.page-scroller__item {
  display: flex;
  width: 300px;
  padding-right: 25px;
  flex-shrink: 0;
  box-sizing: content-box;
}
@media (min-width: 62.5em) {
  .page-scroller__item {
    width: calc(33.3% - 26px);
    padding-right: 40px;
  }
  .page-scroller__item:last-child {
    padding-right: 0;
  }
}

/*  ==========================================================================
	Page Grid
	========================================================================== */
.page-grid {
  position: relative;
  margin: var(--content-margin);
  overflow: hidden;
}
.page-grid:last-child {
  margin-bottom: 0;
}

.page-grid__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .page-grid__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.page-grid__header {
  position: relative;
  border-top: 1px solid #000;
  margin-bottom: 30px;
  padding-top: 15px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .page-grid__header {
    align-items: center;
  }
}

.page-grid__title {
  font-size: 32px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .page-grid__title {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .page-grid__title {
    font-size: 60px;
  }
}

.page-grid__list {
  display: grid;
  gap: 40px;
}
@media (min-width: 32em) {
  .page-grid__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px 25px;
  }
}
@media (min-width: 59em) {
  .page-grid__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 62.5em) {
  .page-grid__list {
    gap: 80px 40px;
  }
}

.page-grid__item {
  display: flex;
  width: 100%;
  box-sizing: content-box;
}

/*  ==========================================================================
    Page Item
    ========================================================================== */
.page-item {
  display: flex;
  width: 100%;
}

.page-item__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  height: 100%;
  width: 100%;
}

.page-item__media {
  margin-bottom: 0;
}

.page-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 60%;
  height: 0;
  overflow: hidden;
}
@media (min-width: 62.5em) {
  .page-item__intrinsic-ratio {
    padding-bottom: 62.5%;
  }
}

.page-item__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.3s ease-in-out;
}
.page-item:hover .page-item__image {
  transform: scale(1.05);
}

.page-item__content {
  display: flex;
  flex-direction: column;
}

.page-item__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 10px;
  transition: color 0.4s ease;
  position: relative;
}
@media (min-width: 50em) {
  .page-item__title {
    font-size: 22px;
    margin-bottom: 5px;
  }
}

.page-item__description {
  margin: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
}

/*  ==========================================================================
	Search Page
	========================================================================== */
.search-page {
  background-color: #E7E7E7;
}

.site-search {
  position: relative;
  z-index: 2;
}

.search-form__wrapper {
  padding-bottom: 20px;
}

.site-search__header {
  background-color: #fff;
  padding-top: 20px;
  text-align: center;
}
@media (min-width: 32em) {
  .site-search__header {
    padding-top: 40px;
  }
}

.site-search__header-inner {
  width: 100%;
  max-width: 1360px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .site-search__header-inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.site-search__header-inner {
  position: relative;
}

.site-search__title {
  font-weight: 600;
  margin-bottom: 20px;
}

.search-form {
  display: inline-block;
  position: relative;
  width: 100%;
  max-width: 450px;
  padding: 0 15px;
}

.search-form__input {
  width: 100%;
  height: 50px;
  line-height: 50px;
  padding: 0 70px 0 20px;
  border-radius: 30px;
  border: none;
  height: auto;
  font-size: 16px;
  border: 1px solid rgba(0, 0, 0, 0.25);
  appearance: none;
  background-color: #fff;
}

.search-form__button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 30px;
  background-color: transparent;
  border: none;
  z-index: 2;
  padding: 0;
}
.search-form__button .o-icon {
  width: 25px;
  height: 25px;
}

.site-search__nav {
  padding-bottom: 5px;
}
@media (min-width: 42.5em) {
  .site-search__nav {
    gap: 0 40px;
    justify-content: center;
  }
}

.search-nav {
  display: flex;
  justify-content: space-evenly;
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (min-width: 42.5em) {
  .search-nav {
    gap: 0 40px;
    justify-content: center;
  }
}

.search-nav__link {
  display: flex;
  flex-direction: column;
  position: relative;
  font-family: Faktum Wide, sans-serif;
  font-size: 16px;
  font-weight: 600;
  opacity: 0.8;
  text-decoration: none;
  transition: opacity 0.4s ease;
}
@media (min-width: 50em) {
  .search-nav__link {
    font-size: 18px;
  }
}
.search-nav__link:after {
  position: absolute;
  content: "";
  height: 3px;
  width: 100%;
  left: 0;
  bottom: -3px;
  background-color: #4d4d4d;
  opacity: 0;
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform 0.4s ease, opacity 1s ease;
}
@media (min-width: 42.5em) {
  .search-nav__link:after {
    bottom: -5px;
  }
}
.search-nav__link.search-nav__link--current, .search-nav__link:hover {
  opacity: 1;
}
.search-nav__link.search-nav__link--current:after, .search-nav__link:hover:after {
  opacity: 1;
  transform: scaleY(1);
}

.search-nav__link--current {
  cursor: default;
}

.search-nav__link--disabled {
  pointer-events: none;
  cursor: default;
}

.search-nav__link-results {
  color: #000;
  font-size: 12px;
}

.site-search__message {
  text-align: center;
  padding: 60px 15px;
}

.site-search__loading {
  padding: 40px 0;
  min-height: 300px;
  display: flex;
  align-items: center;
  position: relative;
  z-index: 2;
}

.site-search__list .event-scroller {
  margin-bottom: 60px;
}
@media (min-width: 72em) {
  .site-search__list .event-scroller {
    margin-bottom: 80px;
  }
}

.site-search__totals {
  font-family: Faktum, sans-serif;
  font-weight: 600;
  margin: 25px 0 15px 0;
}

.site-search__totals,
.site-search__results {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .site-search__totals,
  .site-search__results {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.site-search__totals,
.site-search__results {
  position: relative;
}

.site-search__pagination {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .site-search__pagination {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.site-search__pagination {
  margin-top: 40px;
  margin-bottom: 60px;
  border-top: 1px solid #000;
  padding-top: 15px;
}
@media (min-width: 59em) {
  .site-search__pagination {
    margin-bottom: 100px;
  }
}

.search-result {
  display: block;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  margin: 20px 0;
  transform: scale(1);
  transition: transform 0.3s ease;
}
.search-result:last-child {
  border-bottom: none;
}
@media (min-width: 50em) {
  .search-result {
    margin: 40px 0;
    padding-bottom: 40px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .search-result:hover, .search-result:focus {
    transform: scale(1.01);
  }
}
.search-result .search-result__title {
  margin-bottom: 0;
  line-height: 1.1;
  font-family: Faktum Wide, sans-serif;
  font-weight: 800;
  font-size: 20px;
}
@media (min-width: 42.5em) {
  .search-result .search-result__title {
    font-size: 22px;
  }
}
.search-result .search-result__container {
  width: 100%;
}
@media (min-width: 42.5em) {
  .search-result .search-result__container {
    display: flex;
    align-items: flex-start;
  }
}
.search-result .search-result__body {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.search-result .search-result__media {
  position: relative;
  margin-bottom: 10px;
  flex-shrink: 0;
  overflow: hidden;
}
@media (min-width: 42.5em) {
  .search-result .search-result__media {
    margin-right: 20px;
    margin-bottom: 0;
  }
}
.search-result .search-result__image {
  width: 100%;
  height: 53vw;
  object-fit: cover;
  transform: scale(1);
  transition: transform 0.3s ease;
}
@media (min-width: 42.5em) {
  .search-result .search-result__image {
    width: 250px;
    height: 170px;
  }
}
.search-result .search-result__content {
  margin-top: 10px;
}
@media (min-width: 42.5em) {
  .search-result .search-result__content {
    margin-top: 15px;
  }
}
.search-result .search-result__meta {
  display: flex;
  justify-content: space-between;
  margin-top: auto;
  padding: 10px 0;
  flex-direction: row;
}
@media (min-width: 42.5em) {
  .search-result .search-result__meta {
    flex-direction: column;
    gap: 5px;
  }
}
.search-result .search-result__running-time {
  display: flex;
  align-items: center;
}
.search-result .search-result__running-time .o-icon {
  width: 12px;
  height: 12px;
  margin-right: 5px;
}
.search-result .search-result__icon {
  position: absolute;
  z-index: 2;
  bottom: 12px;
  left: 12px;
  background-color: transparent;
  padding: 0;
  border: none;
  color: #fff;
}
.search-result .search-result__icon .o-icon {
  width: 28px;
  height: 28px;
}
@media (hover: hover) and (pointer: fine) {
  .search-result:hover .search-result__image, .search-result:focus .search-result__image {
    transform: scale(1.05);
  }
}

.search-result__type,
.search-result__prefix {
  display: block;
  text-transform: uppercase;
  font-weight: 700;
  font-size: var(--global-body-size-2);
}
@media (min-width: 50em) {
  .search-result__type,
  .search-result__prefix {
    font-size: var(--global-body-size-3);
  }
}

.search-result__title {
  font-weight: 600;
}

.search-result__content {
  margin: 15px 0 0;
  font-size: var(--global-body-text-small);
  font-size: 14px;
}
@media (min-width: 42.5em) {
  .search-result__content {
    font-size: 16px;
  }
}
.search-result__content em {
  background-color: var(--theme-color);
  color: var(--theme-highlight-color);
  padding: 4px;
  font-style: normal;
}

.search-result__meta {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: var(--global-body-size-4);
  color: #535353;
}
@media (min-width: 50em) {
  .search-result__meta {
    font-size: var(--global-body-size-5);
  }
}

.search-result__link {
  display: inline-block;
  font-style: italic;
  margin-bottom: 10px;
  display: none;
}

.search-result--page .search-result__type {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.search-result--page .search-result__title {
  font-family: Faktum, sans-serif;
  font-size: var(--global-header-size-h4);
}

.search-result--news {
  padding: 20px;
  border-bottom: none;
}

/* ==========================================================================
   Navigation: Search Results pagination
   ========================================================================== */
.search-result__pagination-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 0;
  margin: 0 0 40px;
}
@media (min-width: 50em) {
  .search-result__pagination-inner {
    margin: 0 0 60px;
  }
}

.search-result__previous .pagination__link .o-icon {
  transform: rotate(180deg);
}

.pagination__item {
  padding: 0;
  background-color: #fff;
  border: 1px solid #757575;
  border-radius: 5px;
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 7px;
  width: 32px;
  height: 32px;
  cursor: pointer;
  transition: background-color 0.4s ease, color 0.4s ease, border-color 0.4s ease;
}
.pagination__item .o-icon {
  height: 15px;
  width: 15px;
}
.pagination__item:last-child {
  margin-right: 0;
}
@media (hover: hover) and (pointer: fine) {
  .pagination__item:hover {
    background-color: var(--theme-color);
    border: 1px solid var(--theme-color);
    color: var(--theme-body-text-color);
    font-weight: 700;
  }
}
.pagination__item:active .o-icon {
  scale: 0.9;
}
.pagination__item.pagination__item--current {
  background-color: var(--theme-color);
  border: 1px solid var(--theme-color);
  color: var(--theme-body-text-color);
  font-weight: 700;
}
.pagination__item.pagination__item--next, .pagination__item.pagination__item--prev {
  background-color: var(--theme-color);
  border: 1px solid var(--theme-color);
  color: var(--theme-body-text-color);
  border-radius: 50%;
  transition: scale 0.4s ease-in-out;
}
.pagination__item.pagination__item--next .o-icon, .pagination__item.pagination__item--prev .o-icon {
  scale: 1;
  transition: scale 0.4s ease;
}
.pagination__item.pagination__item--next:not(.pagination__item--disabled):hover .o-icon, .pagination__item.pagination__item--prev:not(.pagination__item--disabled):hover .o-icon {
  scale: 1.1;
}

.pagination__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: inherit;
  text-decoration: none;
  border-radius: 3px;
  font-weight: 700;
}
.pagination__link--disabled {
  cursor: not-allowed;
}

.pagination__current {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.pagination__ellipsis {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.pagination__item--disabled {
  opacity: 0.25;
  cursor: not-allowed;
}

/* ==========================================================================
  Search Results - tab
  ========================================================================== */
.page-search-results:has(.search-nav__link--current.search-nav__link--Concerts) .concert-list-block, .page-search-results:has(.search-nav__link--current.search-nav__link--News) .concert-list-block {
  display: none;
}
.page-search-results:has(.search-nav__link--current.search-nav__link--All) .concert-list-block + .site-search__totals {
  margin-top: -15px;
}

/*  ==========================================================================
    Search Results - Concert Items
    ========================================================================== */
.search-result__container .concert-item {
  display: flex;
  flex-direction: column;
  gap: 15px;
  height: 100%;
  width: 100%;
}
.search-result__container .concert-item .concert-item__content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
@media (min-width: 50em) {
  .search-result__container .concert-item .concert-item__content {
    flex-direction: row;
    gap: 40px;
  }
}
.search-result__container .concert-item .concert-item__details {
  flex: 1;
  margin-top: 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
@media (min-width: 50em) {
  .search-result__container .concert-item .concert-item__details {
    min-height: 150px;
  }
}
.search-result__container .concert-item .concert-item__media {
  position: relative;
  overflow: hidden;
}
@media (min-width: 50em) {
  .search-result__container .concert-item .concert-item__media {
    width: 42%;
    margin-bottom: 0;
  }
}
.search-result__container .concert-item .concert-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
  object-fit: cover;
  object-position: center;
}
.search-result__container .concert-item .concert-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
.search-result__container .concert-item .concert-item__favorite {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2;
  display: none;
}
@media (min-width: 50em) {
  .search-result__container .concert-item .concert-item__favorite {
    bottom: 20px;
    right: 20px;
  }
}
.search-result__container .concert-item .concert-item__favorite-btn {
  background-color: rgba(255, 255, 255, 0.75);
  border: none;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  padding: 0;
}
.search-result__container .concert-item .concert-item__favorite-btn:hover {
  background: var(--theme-highlight-color);
}
.search-result__container .concert-item .concert-item__favorite-btn svg {
  width: 18px;
  height: 18px;
}
@media (min-width: 50em) {
  .search-result__container .concert-item .concert-item__favorite-btn {
    width: 46px;
    height: 46px;
  }
  .search-result__container .concert-item .concert-item__favorite-btn svg {
    width: 23px;
    height: 23px;
  }
}
.search-result__container .concert-item .concert-item__favorite-btn .filled {
  display: none;
}
.search-result__container .concert-item .concert-item__favorite-btn.is-favorite {
  background-color: #fff;
}
.search-result__container .concert-item .concert-item__favorite-btn.is-favorite .outline {
  display: none;
}
.search-result__container .concert-item .concert-item__favorite-btn.is-favorite .filled {
  display: block;
}
.search-result__container .concert-item .concert-item__title {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  margin-bottom: 0;
  text-transform: capitalize;
}
@media (min-width: 50em) {
  .search-result__container .concert-item .concert-item__title {
    font-size: 22px;
    line-height: 1.4;
    min-height: 40px;
  }
}
.search-result__container .concert-item .concert-item__dates {
  margin-top: 15px;
}
.search-result__container .concert-item .concert-item__date-item {
  display: flex;
  border-top: 1px solid #dAdAdA;
  padding: 5px 0 7px;
  gap: 40px;
}
.search-result__container .concert-item .concert-item__date {
  font-size: 14px;
  margin: 0;
}
.search-result__container .concert-item .concert-item__venue {
  font-size: 14px;
  font-weight: 500;
  margin: 0;
}
.search-result__container .concert-item .concert-item__categories {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 5px;
  list-style: none;
  padding: 0;
  margin: 0;
  padding-top: 15px;
  border-top: 1px solid #dAdAdA;
}
.search-result__container .concert-item .concert-item-category {
  color: var(--theme-color);
  border: 1px solid;
  border-radius: 20px;
  padding: 6px 10px;
  font-family: Faktum, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1;
  flex-shrink: 0;
}
@media (min-width: 50em) {
  .search-result__container .concert-item .concert-item-category {
    padding: 8px 15px;
  }
}

/*  ==========================================================================
    Image
    ========================================================================== */
.image-block {
  margin: var(--content-margin);
}

.image-block__inner {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .image-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (max-width: 49.99em) {
  .image-block__inner {
    padding: 0;
  }
}

.image-block__media {
  position: relative;
}

.image-block__figure {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
}

.image-block__intrinsic-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
}

.image-block__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  z-index: 2;
}

.image-block__figcaption {
  display: flex;
  flex-direction: column;
  align-self: flex-end;
  text-align: right;
  text-wrap: balance;
  margin-top: 15px;
  font-size: 14px;
  max-width: 800px;
  gap: 3px;
}
@media (min-width: 50em) {
  .image-block__figcaption {
    font-size: 16px;
  }
}

.image-block__meta {
  display: flex;
  justify-content: space-between;
  margin-top: 15px;
  flex-wrap: wrap;
  gap: 10px;
}
@media (max-width: 49.99em) {
  .image-block__meta {
    padding: 0 15px;
  }
}

.image-block__caption, .image-block__credit {
  font-weight: 400;
  color: #444;
  margin: 0;
  font-size: 14px;
}
@media (min-width: 50em) {
  .image-block__caption, .image-block__credit {
    font-size: 16px;
  }
}

/*  ==========================================================================
    Image - Full Width
    ========================================================================== */
@media (min-width: 72em) {
  .image-block--full .image-block__inner {
    padding: 0;
    max-width: none;
  }
  .image-block--full .image-block__figcaption {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 72em) and (min-width: 50em) {
  .image-block--full .image-block__figcaption {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.image-block--full .image-block__full-image {
  height: 0;
  background-size: cover;
  background-position: center;
  padding-bottom: 56.25%;
}
@media (min-width: 72em) {
  .image-block--full .image-block__full-image {
    padding-bottom: 33.3333333333%;
    background-attachment: fixed;
  }
}
@media (min-width: 106em) {
  .image-block--full .image-block__full-image {
    padding-bottom: 50%;
  }
}

/*  ==========================================================================
	Embed Iframe
	========================================================================== */
.embed-iframe__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 20px;
}
@media (min-width: 50em) {
  .embed-iframe__title {
    font-size: 26px;
  }
}

.embed-iframe {
  padding: 20px 0 35px;
  background-color: #F4F4F4;
}
@media (min-width: 50em) {
  .embed-iframe {
    padding: var(--content-margin-small);
  }
}

.embed-iframe__inner {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .embed-iframe__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.embed-iframe__media {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

@media (max-width: 49.99em) {
  .embed-iframe__audio {
    height: 100px;
  }
}

.embed-iframe__media.embed-iframe__media--brightcove iframe {
  height: 100%;
  min-height: 250px;
}
@media (min-width: 50em) {
  .embed-iframe__media.embed-iframe__media--brightcove iframe {
    min-height: 450px;
  }
}

.embed-iframe__brightcove-container {
  width: 100%;
}

/*  ==========================================================================
	Season Header
	========================================================================== */
.season-header {
  position: relative;
  margin-top: -111px;
  padding-top: 15px;
  padding-bottom: 15px;
  background-color: var(--theme-color-dark);
  color: #fff;
}
@media (min-width: 50em) {
  .season-header {
    padding-top: 38px;
    padding-bottom: 40px;
  }
}
@media (min-width: 72em) {
  .season-header {
    margin-top: 0;
    padding-top: 30px;
  }
}

.season-header__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .season-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.season-header__inner {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 72em) {
  .season-header__inner {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    gap: 40px;
  }
}

.season-header__content {
  display: flex;
  align-items: flex-end;
  gap: 15px;
  padding-right: 60px;
}
@media (min-width: 72em) {
  .season-header__content {
    margin: 0;
    padding: 0;
    gap: 40px;
  }
}

.season-header__titles {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
@media (min-width: 50em) {
  .season-header__titles {
    max-width: calc(100% - 220px);
  }
}
@media (min-width: 72em) {
  .season-header__titles {
    max-width: 100%;
  }
}

.season-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: Faktum, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.8;
  font-size: 42px;
}
@media (min-width: 50em) {
  .season-header__title {
    font-size: 72px;
  }
}
@media (min-width: 72em) {
  .season-header__title {
    font-size: 90px;
  }
}
@media (min-width: 80em) {
  .season-header__title {
    font-size: 96px;
  }
}

.season-header__prefix,
.season-header__suffix {
  font-family: Faktum, sans-serif;
  font-weight: 800;
  font-size: 22px;
  text-transform: uppercase;
  line-height: 0.8;
}
@media (min-width: 50em) {
  .season-header__prefix,
  .season-header__suffix {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .season-header__prefix,
  .season-header__suffix {
    font-size: 38px;
  }
}
@media (min-width: 72em) {
  .season-header__prefix,
  .season-header__suffix {
    font-size: 48px;
  }
}

@media (max-width: 71.99em) {
  .season-header__logo {
    visibility: hidden;
    width: 51px;
    height: 80px;
  }
}
.season-header__logo .o-icon {
  width: 105px;
  height: 171px;
}

/*  ==========================================================================
	Season Info
	========================================================================== */
.season-info {
  margin: 30px 0;
}
@media (min-width: 50em) {
  .season-info {
    margin: 40px 0;
  }
}
@media (min-width: 62.5em) {
  .season-info {
    margin: 80px 0;
  }
}

.season-info__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .season-info__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.season-info__inner {
  display: flex;
  flex-direction: column;
}
@media (min-width: 50em) {
  .season-info__inner {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 40px;
  }
}
@media (min-width: 62.5em) {
  .season-info__inner {
    gap: 80px;
  }
}

.season-info__body {
  width: 100%;
  max-width: 820px;
}
.season-info__body:only-child {
  margin: 0 auto;
}

.season-info__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: fixed;
  bottom: 0;
  right: 0;
  padding: 15px;
  width: 100%;
  background-color: #fff;
  box-shadow: 0px 0px 20px 6px rgba(0, 0, 0, 0.2588235294);
  z-index: 5;
}
@media (min-width: 30em) {
  .season-info__actions {
    flex-direction: row;
  }
  .season-info__actions > * {
    flex-basis: 100%;
  }
}
@media (min-width: 50em) {
  .season-info__actions {
    flex-direction: column;
    position: sticky;
    gap: 15px;
    top: 15px;
    bottom: unset;
    padding: 0;
    box-shadow: none;
    max-width: 300px;
  }
}
@media (min-width: 72em) {
  .season-info__actions {
    top: calc(var(--global-header-height) + 15px);
  }
}

/*  ==========================================================================
    Home Hero
    ========================================================================== */
.page-hero {
  display: flex;
  flex-direction: column-reverse;
  background-color: #000;
  color: #fff;
  position: relative;
  overflow: hidden;
}
@media (min-width: 50em) {
  .page-hero {
    flex-direction: column;
    max-height: 85svh;
  }
  .page-hero:after {
    content: "";
    position: absolute;
    background: linear-gradient(to top, #000, transparent);
    width: 100%;
    height: 60%;
    left: 0;
    bottom: 0;
  }
}

.page-hero__inner {
  display: flex;
  justify-content: center;
}

.page-hero__body {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .page-hero__body {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.page-hero__body {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px 20px 40px;
  width: 100%;
  z-index: 2;
  position: relative;
}
.page-hero__body:before {
  position: absolute;
  content: "";
  background: linear-gradient(to top, black, transparent);
  height: 100px;
  width: 100%;
  top: 0;
  left: 0;
}
@media (max-width: 49.99em) {
  .page-hero__body {
    margin-top: -60px;
  }
}
@media (min-width: 50em) {
  .page-hero__body {
    position: absolute;
    padding: 20px;
    top: 50%;
    transform: translateY(-50%);
  }
  .page-hero__body:before {
    display: none;
  }
}

.page-hero__title {
  display: flex;
  flex-direction: column;
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  font-size: 28px;
  text-wrap: balance;
  text-shadow: 5px 5px 7px rgba(0, 0, 0, 0.25);
  width: 100%;
  max-width: 666px;
  text-transform: uppercase;
  margin-bottom: 15px;
  position: relative;
}
@media (min-width: 30em) {
  .page-hero__title {
    font-size: 38px;
  }
}
@media (min-width: 50em) {
  .page-hero__title {
    font-size: 48px;
  }
}

.page-hero__details {
  display: flex;
  flex-direction: column;
  gap: 30px;
  max-width: 666px;
  position: relative;
}

.page-hero__suffix {
  font-size: 18px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 500;
  margin: 0;
  line-height: 1.2;
}
@media (min-width: 50em) {
  .page-hero__suffix {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .page-hero__suffix {
    font-size: 26px;
  }
}

.page-hero__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 2px 7px;
  font-size: 14px;
}
@media (min-width: 50em) {
  .page-hero__meta {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .page-hero__meta {
    font-size: 20px;
  }
}
.page-hero__meta .o-icon {
  color: #fff;
  width: 10px;
  height: 10px;
}

.page-hero__date,
.page-hero__venue {
  margin-bottom: 0;
}

.page-hero__btns {
  display: flex;
  gap: 20px;
}

.page-hero__btn .o-icon {
  width: 23px;
  height: 23px;
}

.page-hero__media {
  position: relative;
  z-index: 0;
}

.page-hero__intrinsic-ratio {
  position: relative;
  padding-bottom: 75%;
  height: 0;
}
@media (min-width: 62.5em) {
  .page-hero__intrinsic-ratio {
    padding-bottom: 50%;
  }
}

.page-hero__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  z-index: 2;
}

/*  ==========================================================================
    Home Hero - Video
    ========================================================================== */
.page-hero--video {
  margin-bottom: 0;
}
.page-hero--video button.video-controls {
  top: 15px;
  right: 15px;
  bottom: auto;
}
@media (min-width: 50em) {
  .page-hero--video button.video-controls {
    top: auto;
    bottom: 20px;
    right: 20px;
  }
}
@media (min-width: 72em) {
  .page-hero--video button.video-controls {
    bottom: 40px;
    right: 40px;
  }
}
@media (min-width: 96.875em) {
  .page-hero--video button.video-controls {
    bottom: 40px;
    right: 90px;
  }
}
.page-hero--video .page-hero__body::before {
  top: -40px;
}

.page-hero__media--video {
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: 0;
  left: 0;
  pointer-events: none;
  overflow: hidden;
}
@media (min-width: 50em) {
  .page-hero__media--video {
    height: 150%;
  }
}
@media (min-width: 62.5em) {
  .page-hero__media--video {
    height: 100%;
  }
}

@media (min-width: 50em) {
  .page-hero__media--video .video-container {
    min-height: 500px;
  }
}
@media (min-width: 59em) {
  .page-hero__media--video .video-container {
    min-height: 800px;
  }
}
@media (min-width: 90em) {
  .page-hero__media--video .video-container {
    min-height: 2000px;
  }
}

.page-hero__pause.btn--pause-mobile {
  top: 15px;
}

.page-hero__footer-btn {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .page-hero__footer-btn {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.page-hero__footer-btn {
  position: absolute;
  bottom: 60px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  justify-content: flex-end;
}

/*  ========================================================================== */
/*  Header Video
/*  ========================================================================== */
.header-video {
  margin-bottom: 40px;
}
@media (min-width: 59em) {
  .header-video {
    margin-bottom: 0;
  }
}

.video-container,
.video-container iframe {
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  width: 2000px;
  height: 100%;
  z-index: 2;
  transition: opacity 1s ease;
}

.header__video--loaded .header__video,
.header__video--loaded .header__video-overlay,
.header__video--loaded .header__video-btn {
  opacity: 1;
}

.video-container-overlay {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  z-index: 3;
}

button.video-controls {
  display: flex;
  align-items: center;
  gap: 0 8px;
  position: absolute;
  bottom: -40px;
  right: 15px;
  padding: 10px 20px;
  color: #fff;
  background-color: #383839;
  border-radius: 20px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 1s ease;
  z-index: 3;
}
.header-video:has(.video-container--loaded) button.video-controls, .header-video.video-container--loaded button.video-controls {
  opacity: 1;
}
button.video-controls.playing .video-control--pause {
  display: block;
}
button.video-controls.playing .video-control--play {
  display: none;
}
button.video-controls.paused .video-control--play {
  display: block;
}
button.video-controls.paused .video-control--pause {
  display: none;
}
@media (min-width: 50em) {
  button.video-controls {
    bottom: 10px;
    right: 10px;
  }
}
@media (min-width: 62.5em) {
  button.video-controls {
    bottom: 15px;
    right: 15px;
  }
}

.video-control {
  height: 20px;
  width: 11px;
}
.video-control .o-icon {
  width: 100%;
  height: 100%;
}

.video-control--text {
  font-size: 14px;
  font-weight: 600;
}

/*  ==========================================================================
	Venue Header
	========================================================================== */
.venue-header {
  position: relative;
  background-color: var(--theme-color);
}

.venue-header__inner {
  display: flex;
  flex-direction: column-reverse;
}
@media (min-width: 50em) {
  .venue-header__inner {
    flex-direction: row;
    align-items: stretch;
    gap: 30px;
  }
}
@media (min-width: 72em) {
  .venue-header__inner {
    gap: 60px;
    max-width: 1440px;
    margin: auto;
  }
}

.venue-header__media {
  margin-bottom: 0;
  order: 1;
}
@media (min-width: 50em) {
  .venue-header__media {
    width: 45%;
  }
}
@media (min-width: 90em) {
  .venue-header__media {
    transform: translateX(calc(((100vw - 1440px) / 2)));
  }
}

.venue-header__media-inner {
  position: relative;
  height: 100%;
  margin-bottom: 0;
}
@media (min-width: 90em) {
  .venue-header__media-inner {
    width: calc(100% + ((100vw - 1440px) / 2));
    transform: translateX(calc(((100vw - 1440px) / 2) * -1));
  }
}

.venue-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
}
@media (min-width: 50em) {
  .venue-header__intrinsic-ratio {
    position: relative;
    padding-bottom: 71.4285714286%;
  }
}

.venue-header__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
@media (min-width: 50em) {
  .venue-header__image {
    object-fit: cover;
    object-position: center;
  }
}

.venue-header__content {
  display: flex;
  flex-direction: column;
  padding: 15px;
}
@media (min-width: 50em) {
  .venue-header__content {
    width: 55%;
    justify-content: center;
    align-items: flex-start;
  }
}
@media (min-width: 72em) {
  .venue-header__content {
    padding: 30px 0 30px 15px;
  }
}

.venue-header__titles {
  color: var(--theme-highlight-color);
  margin-bottom: 15px;
}
@media (min-width: 50em) {
  .venue-header__titles {
    margin-bottom: 20px;
  }
}

.venue-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.9;
  font-size: 28px;
  text-wrap: balance;
}
@media (min-width: 50em) {
  .venue-header__title {
    font-size: 38px;
  }
}
@media (min-width: 72em) {
  .venue-header__title {
    font-size: 48px;
  }
}

.venue-header__prefix,
.venue-header__suffix {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-weight: 400;
  font-size: 20px;
  line-height: 0.8;
}
@media (min-width: 50em) {
  .venue-header__prefix,
  .venue-header__suffix {
    font-size: 22px;
  }
}
@media (min-width: 72em) {
  .venue-header__prefix,
  .venue-header__suffix {
    font-size: 26px;
  }
}

.venue-header__prefix {
  margin-bottom: 10px;
}
@media (min-width: 62.5em) {
  .venue-header__prefix {
    margin-bottom: 10px;
  }
}

.venue-header__suffix {
  margin-top: 10px;
}
@media (min-width: 62.5em) {
  .venue-header__suffix {
    margin-top: 12px;
  }
}

.venue-header__address {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 5px;
  padding-top: 15px;
  border-top: 1px solid var(--theme-highlight-color);
  font-size: 12px;
  color: var(--theme-highlight-color);
}
.venue-header__address .o-icon {
  width: 16px;
  height: 16px;
}
@media (min-width: 72em) {
  .venue-header__address .o-icon {
    width: 22px;
    height: 22px;
  }
}
@media (min-width: 50em) {
  .venue-header__address {
    border-top: none;
    padding-top: 0;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--theme-highlight-color);
    font-size: 16px;
  }
}
@media (min-width: 72em) {
  .venue-header__address {
    font-size: 20px;
    padding-bottom: 30px;
  }
}

.venue-header__breadcrumbs + .content-blocks .rich-text {
  margin-top: 30px;
}

.venue-header__breadcrumbs-inner {
  margin-top: 15px;
  padding: 0 15px;
}
@media (min-width: 50em) {
  .venue-header__breadcrumbs-inner {
    margin-top: 20px;
  }
}
@media (min-width: 72em) {
  .venue-header__breadcrumbs-inner {
    width: 100%;
    max-width: 920px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    padding: 0;
    margin-top: 60px;
  }
}
@media (min-width: 72em) and (min-width: 50em) {
  .venue-header__breadcrumbs-inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

/*  ==========================================================================
	Venue Scroller
	========================================================================== */
.venue-scroller {
  position: relative;
  margin: var(--content-margin);
  overflow: hidden;
  padding: 5px;
}

@media (min-width: 62.5em) {
  .venue-scroller__inner {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 62.5em) and (min-width: 50em) {
  .venue-scroller__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.venue-scroller__header {
  position: relative;
  border-top: 1px solid #000;
  margin: 0 15px 30px;
  padding-top: 15px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .venue-scroller__header {
    align-items: center;
  }
}
@media (min-width: 62.5em) {
  .venue-scroller__header {
    margin: 0 0 30px;
  }
}

.venue-scroller__title {
  font-size: 32px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .venue-scroller__title {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .venue-scroller__title {
    font-size: 60px;
  }
}

.venue-scroller__actions {
  display: flex;
  gap: 0 8px;
  margin-left: auto;
  flex-shrink: 0;
}

.venue-scroller__previous,
.venue-scroller__next {
  background-color: var(--theme-color-dark);
  color: #fff;
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  transition: background-color 0.4s ease;
}
@media (min-width: 62.5em) {
  .venue-scroller__previous,
  .venue-scroller__next {
    display: inline-block;
  }
}
.venue-scroller__previous.swiper-button-disabled,
.venue-scroller__next.swiper-button-disabled {
  cursor: not-allowed;
}
.venue-scroller__previous .o-icon,
.venue-scroller__next .o-icon {
  width: 16px;
  height: 20px;
  transition: color 0.4s ease;
}
.venue-scroller__previous:not(.swiper-button-disabled):hover,
.venue-scroller__next:not(.swiper-button-disabled):hover {
  background-color: #000;
}
.venue-scroller__previous:not(.swiper-button-disabled):hover .o-icon,
.venue-scroller__next:not(.swiper-button-disabled):hover .o-icon {
  color: #fff;
}

.venue-scroller__previous {
  margin-right: 0;
}
.venue-scroller__previous .o-icon {
  transform: rotate(180deg);
}

.venue-scroller__next {
  margin-right: 15px;
}
@media (min-width: 62.5em) {
  .venue-scroller__next {
    margin-right: 0;
  }
}

.venue-scroller__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .venue-scroller__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}

.venue-scroller__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}

.venue-scroller__item {
  display: flex;
  width: 300px;
  padding-right: 25px;
  flex-shrink: 0;
  box-sizing: content-box;
}
@media (min-width: 62.5em) {
  .venue-scroller__item {
    width: calc(33.3% - 26px);
    padding-right: 40px;
  }
  .venue-scroller__item:last-child {
    padding-right: 0;
  }
}

/*  ==========================================================================
    Venue Item
    ========================================================================== */
.venue-item {
  display: flex;
  width: 100%;
}

.venue-item__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  height: 100%;
  width: 100%;
}

.venue-item__media {
  margin-bottom: 0;
}

.venue-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.venue-item__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.3s ease-in-out;
}

.venue-item__info {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.venue-item__info .venue-item__arrow {
  min-width: 28px;
}

.venue-item__content {
  display: flex;
  flex-direction: column;
}

.venue-item__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 22px;
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 0;
  transition: color 0.4s ease;
}
@media (min-width: 32em) {
  .venue-item__title {
    font-size: 16px;
  }
}
@media (min-width: 62.5em) {
  .venue-item__title {
    font-size: 22px;
  }
}

.venue-item__prefix,
.venue-item__suffix {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 0.8;
  text-transform: uppercase;
}
@media (min-width: 32em) {
  .venue-item__prefix,
  .venue-item__suffix {
    font-size: 10px;
  }
}
@media (min-width: 62.5em) {
  .venue-item__prefix,
  .venue-item__suffix {
    font-size: 14px;
  }
}

.venue-item__prefix {
  margin-bottom: 5px;
}

.venue-item__suffix {
  margin-top: 5px;
}

.venue-item__address {
  margin-top: 10px;
  margin-bottom: 0;
  font-size: 13px;
}

/*  ==========================================================================
    Venue Item - custom venue-item__arrow animation
    ========================================================================== */
.venue-item__arrow {
  cursor: pointer;
  height: 28px;
  position: relative;
  transition: all 0.3s ease;
  width: 28px;
  display: inline-block;
}
.venue-item__arrow:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-color: var(--theme-color);
  transform: translate(-50%, -50%) scale(0);
  transition: transform 0.3s ease;
  opacity: 0;
}

.venue-item__arrow--top,
.venue-item__arrow--bottom {
  background-color: #000;
  height: 2px;
  position: absolute;
  width: 12px;
  left: 50%;
  border-radius: 4px;
  z-index: 1;
  transition: background-color 0.3s ease;
  transform-origin: right center;
}
.venue-item__arrow--top:after,
.venue-item__arrow--bottom:after {
  background-color: var(--theme-highlight-color-light);
  content: "";
  height: 100%;
  position: absolute;
  top: 0;
  transition: all 0.15s;
  border-radius: 4px;
}

.venue-item__arrow--top {
  top: 13px;
  transform: translateX(-7px) rotate(45deg);
}
.venue-item__arrow--top:after {
  left: 100%;
  right: 0;
  transition-delay: 0s;
}

.venue-item__arrow--bottom {
  bottom: 13px;
  transform: translateX(-7px) rotate(-45deg);
}
.venue-item__arrow--bottom:after {
  left: 0;
  right: 100%;
  transition-delay: 0.15s;
}

/*  ==========================================================================
    Venue Item - Hover
    ========================================================================== */
.venue-item:hover .venue-item__title {
  color: var(--theme-color-dark);
}
.venue-item:hover .venue-item__image {
  transform: scale(1.05);
}
.venue-item:hover .venue-item__arrow {
  transform: translateX(3px);
}
.venue-item:hover .venue-item__arrow:before {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}
.venue-item:hover .venue-item__arrow--top,
.venue-item:hover .venue-item__arrow--bottom {
  background-color: #fff;
}
.venue-item:hover .venue-item__arrow--top:after {
  left: 0;
  transition-delay: 0.15s;
}
.venue-item:hover .venue-item__arrow--bottom:after {
  right: 0;
  transition-delay: 0s;
}

.venue-item:active .venue-item__arrow {
  transform: translateX(5px) scale(0.9);
}

/*  ==========================================================================
    Date Picker
    ========================================================================== */
@media (min-width: 62.5em) {
  .event-header__date-picker--mobile {
    display: none;
  }
}

.event-header__date-picker--desktop {
  display: none;
}
@media (min-width: 62.5em) {
  .event-header__date-picker--desktop {
    display: block;
  }
}

.date-picker__list {
  display: flex;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 15px;
  overflow-x: auto;
}
@media (min-width: 50em) {
  .date-picker__list {
    flex-wrap: wrap;
    overflow: hidden;
    padding: 0;
  }
}

.date-picker__item {
  flex-shrink: 0;
}

.date-picker__radio {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.date-picker__inner {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 14px;
  text-transform: uppercase;
  border: 1px solid #000;
  background-color: transparent;
  padding: 10px;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
.date-picker__radio:checked + .date-picker__inner {
  background-color: #DB1E1E;
  border-color: #DB1E1E;
  color: #fff;
}
@media (min-width: 50em) {
  .date-picker__inner {
    flex-direction: column;
    gap: 5px;
    padding: 10px;
    border-radius: 3px;
    text-transform: uppercase;
    position: relative;
    transition: border-color 0.3s ease;
  }
  .date-picker__inner:after {
    opacity: 0;
    position: absolute;
    content: "Buy Tickets";
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #DB1E1E;
    color: #fff;
    width: 100%;
    height: 100%;
    width: 100%;
    font-size: 20px;
    text-align: center;
    line-height: 1;
    transition: opacity 0.3s ease;
  }
  .date-picker__inner:hover {
    border-color: #DB1E1E;
  }
  .date-picker__inner:hover:after {
    opacity: 1;
  }
}

.date-picker__header {
  display: flex;
  align-items: center;
  gap: 5px;
  line-height: 1;
}
.date-picker__header .o-icon {
  width: 8px;
  height: 8px;
}
@media (min-width: 50em) {
  .date-picker__header {
    font-size: 10px;
  }
  .date-picker__header .o-icon:nth-child(2 of .o-icon) {
    display: none;
  }
}

.date-picker__day {
  letter-spacing: 1px;
}

.date-picker__date {
  margin-bottom: 0;
  line-height: 1;
  text-align: center;
}
@media (min-width: 50em) {
  .date-picker__date {
    font-size: 26px;
  }
}

.date-picker__availability {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  color: #DB1E1E;
  font-size: 12px;
  text-align: center;
  margin-top: 5px;
  margin-bottom: 0;
}
.date-picker__availability .o-icon {
  width: 12px;
  height: 12px;
}
@media (min-width: 50em) {
  .date-picker__availability {
    font-size: 10px;
  }
}

.date-picker__btn {
  width: 100%;
  margin: 0;
  padding: 20px;
  background-color: #DB1E1E;
  color: #fff;
  border: 0;
  text-transform: uppercase;
  font-weight: 700;
}
@media (min-width: 50em) {
  .date-picker__btn {
    display: none;
  }
}

/*  ==========================================================================
    Bio Header
    ========================================================================== */
.bio-header {
  margin: var(--content-margin-small);
  margin-bottom: 0;
}
@media (max-width: 49.99em) {
  .bio-header {
    margin-top: 0;
  }
}
.page-content .bio-header:only-child {
  margin-bottom: 60px;
}
@media (min-width: 50em) {
  .page-content .bio-header:only-child {
    margin-bottom: 100px;
  }
}

.bio-header__inner {
  display: flex;
  flex-direction: column;
}
@media (min-width: 50em) {
  .bio-header__inner {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 50em) and (min-width: 50em) {
  .bio-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.bio-header__wrapper {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (min-width: 50em) {
  .bio-header__wrapper {
    flex-direction: row;
    align-items: flex-start;
    gap: 30px;
  }
  .bio-header__wrapper .bio-header__sticky {
    max-width: 300px;
    position: sticky;
    top: 20px;
  }
}
@media (min-width: 62.5em) {
  .bio-header__wrapper {
    gap: 60px;
  }
  .bio-header__wrapper .bio-header__sticky {
    max-width: 400px;
  }
}
@media (min-width: 72em) {
  .bio-header__wrapper .bio-header__sticky {
    top: calc(var(--global-header-height) + 30px);
  }
}

@media (max-width: 49.99em) {
  .bio-header__breadcrumbs {
    padding-left: 15px;
    padding-right: 15px;
    margin-bottom: 0;
  }
}
.bio-header__breadcrumbs .breadcrumbs {
  margin-top: 0;
}

.bio-header__sticky {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column-reverse;
}
@media (min-width: 50em) {
  .bio-header__sticky {
    flex-direction: column;
  }
}

.bio-header__meta {
  background-color: var(--theme-color);
  color: var(--theme-highlight-color);
  padding: 20px;
}
@media (min-width: 50em) {
  .bio-header__meta {
    background-color: transparent;
    padding: 0;
    color: #000;
  }
}

.bio-header__name {
  font-family: Faktum Wide, sans-serif;
  font-weight: 700;
  font-size: 28px;
  margin-bottom: 0;
  line-height: 0.8;
  text-transform: uppercase;
  text-wrap: balance;
}
@media (min-width: 50em) {
  .bio-header__name {
    font-size: 42px;
    color: var(--theme-color);
  }
}
@media (min-width: 62.5em) {
  .bio-header__name {
    font-size: 60px;
  }
}

.bio-header__role {
  margin-top: 15px;
  margin-bottom: 0;
  font-size: 18px;
  line-height: 1;
  font-weight: 500;
}
@media (min-width: 50em) {
  .bio-header__role {
    font-size: 22px;
    margin-top: 20px;
  }
}
@media (min-width: 62.5em) {
  .bio-header__role {
    font-size: 28px;
  }
}

.bio-header__position {
  padding-top: 5px;
  margin-bottom: 0;
  font-weight: 300;
  font-size: 16px;
  line-height: 1;
}
@media (min-width: 50em) {
  .bio-header__position {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .bio-header__position {
    font-size: 22px;
  }
}

.bio-header__media {
  width: 100%;
}
@media (min-width: 50em) {
  .bio-header__media {
    margin-top: 30px;
  }
}

.bio-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
}
@media (min-width: 50em) {
  .bio-header__intrinsic-ratio:after {
    content: "";
    position: absolute;
    left: -25px;
    bottom: -25px;
    background-color: var(--theme-highlight-color);
    clip-path: polygon(3% 0, 100% 0, 100% 97%, 0% 100%);
    width: 103%;
    height: 103%;
  }
}

.bio-header__image {
  position: absolute;
  right: 0;
  height: auto;
  width: 100%;
  z-index: 2;
}

.bio-header__content {
  width: 100%;
  padding-left: 15px;
  padding-right: 15px;
}
@media (min-width: 50em) {
  .bio-header__content {
    padding-left: 20px;
    padding-right: 0;
  }
}

.bio-header__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 800;
  font-size: 24px;
  text-transform: capitalize;
  margin-bottom: 10px;
}
@media (min-width: 50em) {
  .bio-header__title {
    font-size: 42px;
  }
}

.bio-header__breadcrumbs--desktop {
  display: none;
}
@media (min-width: 50em) {
  .bio-header__breadcrumbs--desktop {
    display: block;
  }
}

.bio-header__breadcrumbs--mobile {
  display: block;
}
@media (min-width: 50em) {
  .bio-header__breadcrumbs--mobile {
    display: none;
  }
}

/*  ==========================================================================
   Orchestra Roster
    ========================================================================== */
.orchestra-roster {
  background-color: #fff;
}
.orchestra-roster:has(.orchestra-roster__section--names.active) .orchestra-sticky-bar {
  display: none;
}

.orchestra-roster__inner,
.orchestra-roster__navigation--inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .orchestra-roster__inner,
  .orchestra-roster__navigation--inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.orchestra-roster__navigation--inner {
  padding-bottom: 15px;
}
@media (min-width: 72em) {
  .orchestra-roster__navigation--inner {
    padding-bottom: 30px;
  }
}
@media (min-width: 50em) {
  #page-content:has(> .page-header.page-header--image) .content-blocks .orchestra-roster__navigation--inner {
    margin-top: 60px;
  }
}

.orchestra-roster__inner {
  position: relative;
  z-index: 0;
}

.orchestra-roster__title {
  font-size: 20px;
  font-family: Faktum Wide, sans-serif;
  text-transform: capitalize;
  border-bottom: 1px solid #000;
  padding-bottom: 20px;
  margin-bottom: 10px;
}
@media (min-width: 50em) {
  .orchestra-roster__title {
    font-size: 38px;
    padding-bottom: 30px;
    margin-bottom: 30px;
  }
}

.orchestra-roster__description {
  margin-bottom: 10px;
}

.orchestra-roster__navigation {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  height: 50px;
  font-family: Faktum, sans-serif;
  letter-spacing: normal;
}
.orchestra-roster__navigation .btn:hover :after, .orchestra-roster__navigation :hover:where([data-component*=dialog] menu button) :after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 12px;
  background-color: #000;
  transform: translateY(8px);
}

.orchestra-roster__switch {
  color: #000;
  padding-bottom: 5px;
  font-size: 20px;
  letter-spacing: normal;
  text-decoration: none;
  text-transform: capitalize;
}
@media (min-width: 50em) {
  .orchestra-roster__switch {
    font-size: 24px;
    padding-bottom: 10px;
  }
}
.orchestra-roster__switch:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background-color: #000;
  transform: translateY(8px);
  transition: height ease-in-out 0.25s;
}

.orchestra-roster__switch:hover {
  color: #000;
  text-decoration: none;
}
.orchestra-roster__switch:hover:after {
  height: 11px;
  background-color: #000;
}

.orchestra-roster__switch--active:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 11px;
  background-color: #000;
  transform: translateY(8px);
}

.orchestra-roster__instrument {
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

.orchestra-roster__instrument-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background-color: transparent;
  border: none;
  cursor: pointer;
  padding: 20px 0;
  color: #000;
}
.orchestra-roster__instrument-header .o-icon {
  width: 18px;
  height: 18px;
  margin-left: auto;
  flex-shrink: 0;
  rotate: 90deg;
  color: #000;
  transition: rotate 0.3s ease;
}

.orchestra-roster__instrument-name {
  margin-bottom: 0;
  font-family: Faktum Wide, sans-serif;
  font-size: 18px;
  font-weight: 700;
  text-transform: capitalize;
}
@media (min-width: 50em) {
  .orchestra-roster__instrument-name {
    font-size: 28px;
  }
}

.orchestra-roster__group {
  padding: 20px 0;
}
@media (min-width: 50em) {
  .orchestra-roster__group {
    padding: 40px 0;
  }
}

.orchestra-roster__grid {
  margin-bottom: 40px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 20px;
  align-items: stretch;
  padding: 0 15px;
  margin-top: 15px;
}
.orchestra-roster__grid::-webkit-scrollbar {
  display: none;
}
@media (min-width: 42.5em) {
  .orchestra-roster__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 72em) {
  .orchestra-roster__grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 60px 20px;
    padding: 0;
    margin-top: 30px;
  }
}

.orchestra-roster__instrument-list {
  overflow: hidden;
  max-height: 0;
  padding: 0;
  margin: 0;
  transition: max-height 0.3s ease, padding 0.3s ease;
}

.orchestra-roster__instrument--open .orchestra-roster__instrument-header .o-icon {
  rotate: -90deg;
}
.orchestra-roster__instrument--open .orchestra-roster__instrument-list {
  padding: 30px 0;
  max-height: none;
}

.orchestra-roster__section--instrument {
  display: none;
}
@media (min-width: 72em) {
  .orchestra-roster__section--instrument .orchestra-roster__grid {
    gap: 60px;
  }
}
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item {
  flex-direction: column;
  gap: 0;
}
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item__image {
  object-fit: cover;
}
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item__media,
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item__details {
  width: 100%;
}
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item__details {
  padding: 15px;
  background-color: #F4F4F4;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item__name,
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item__role {
  text-align: center;
}
.orchestra-roster__section--instrument .orchestra-roster__grid .orchestra-item__role {
  width: 100%;
}

.orchestra-roster__section.active {
  display: block;
}

.orchestra-roster__section--names {
  display: none;
}
.orchestra-roster__section--names .orchestra-roster__grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
}
@media (min-width: 50em) {
  .orchestra-roster__section--names .orchestra-roster__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 106em) {
  .orchestra-roster__section--names .orchestra-roster__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.orchestra-roster__section--names .orchestra-roster__grid .orchestra-item {
  flex-direction: row;
  gap: 0;
  align-items: stretch;
}
.orchestra-roster__section--names .orchestra-roster__grid .orchestra-item__media {
  width: 125px;
}
@media (min-width: 30em) {
  .orchestra-roster__section--names .orchestra-roster__grid .orchestra-item__media {
    width: 150px;
  }
}
.orchestra-roster__section--names .orchestra-roster__grid .orchestra-item__image {
  object-fit: cover;
}
.orchestra-roster__section--names .orchestra-roster__grid .orchestra-item__details {
  padding: 15px;
  background-color: #F4F4F4;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  flex: 1;
}
.orchestra-roster__section--names .orchestra-item__details {
  width: 100%;
}

.orchestra-roster__letter-heading {
  text-transform: uppercase;
  border-bottom: 1px solid #000;
  margin-bottom: 30px;
}

.orchestra-ensemble__alphabet {
  position: sticky;
  top: 0;
  margin: 10px 0;
  padding: 15px 0;
  background-color: #fff;
  z-index: 5;
}
@media (min-width: 72em) {
  .orchestra-ensemble__alphabet {
    top: var(--global-header-height);
  }
}
.orchestra-ensemble__alphabet:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 30px;
  background: linear-gradient(to right, rgba(251, 249, 245, 0) 0, #fff 75%);
  z-index: 2;
}

.orchestra-ensemble__letters {
  background-color: transparent;
  display: flex;
  overflow-x: scroll;
  scrollbar-width: none;
  text-transform: uppercase;
}

.orchestra-ensemble__letter {
  position: relative;
  background-color: var(--theme-color);
  color: var(--theme-body-text-color);
  z-index: 2;
  height: 40px;
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  font-size: 20px;
  flex-shrink: 0;
}
.orchestra-ensemble__letter:hover {
  color: var(--theme-highlight-text-color);
}
.orchestra-ensemble__letter:hover:after {
  height: 100%;
}
.orchestra-ensemble__letter:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--theme-highlight-color);
  transition: height ease-in-out 0.25s, background-color ease-in-out 0.25s;
  z-index: -1;
}
.orchestra-ensemble__letter.disabled {
  cursor: not-allowed;
  background-color: transparent;
  margin-right: 0;
  margin-left: -10px;
  color: #000;
}
.orchestra-ensemble__letter.disabled:after {
  content: none;
}
.orchestra-ensemble__letter.disabled:hover {
  color: initial;
}

/*  ==========================================================================
   Orchestra Roster - Featured Group
    ========================================================================== */
.orchestra-roster__featured-section {
  clip-path: inset(0 -100vmax);
  grid-column: 1/-1;
  box-shadow: 0 0 0 100vmax #F4F4F4;
}

.orchestra-roster__featured-group {
  display: block;
  text-decoration: none;
  color: inherit;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-group {
    margin-bottom: 40px;
  }
}
.orchestra-roster__featured-group:hover {
  text-decoration: none;
  color: inherit;
}

.orchestra-roster__featured-card {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  text-align: center;
  background: #F4F4F4;
  padding: 30px 0;
  margin-bottom: 30px;
  min-height: 300px;
  transition: all 0.3s ease;
  cursor: pointer;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-card {
    flex-direction: row-reverse;
    text-align: left;
    padding: 0;
    min-height: 400px;
    align-items: stretch;
  }
}

.orchestra-roster__featured-content {
  flex: 1;
  padding-right: 0;
  margin-bottom: 30px;
  max-width: calc(100% - 150px);
  text-align: left;
  padding-right: 25px;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-content {
    max-width: 50%;
    padding: 40px;
    margin-bottom: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}

.orchestra-roster__featured-title {
  font-size: 22px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-weight: 700;
  color: #000;
  margin: 0 0 20px 0;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-title {
    font-size: 38px;
  }
}

.orchestra-roster__featured-description,
.orchestra-roster__featured-subtitle {
  font-size: 16px;
  color: #252525;
  line-height: 1.3;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-description,
  .orchestra-roster__featured-subtitle {
    font-size: 20px;
  }
}

.orchestra-roster__featured-description {
  margin: 0 0 15px 0;
}

.orchestra-roster__featured-subtitle {
  margin: 0;
}

.orchestra-roster__featured-media {
  position: relative;
  width: 40%;
  text-align: center;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-media {
    width: 50%;
  }
}

.orchestra-roster__featured-inner {
  position: relative;
  height: 100%;
  margin-bottom: 0;
  width: 100%;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-inner {
    flex-direction: row;
    align-items: stretch;
    gap: 30px;
  }
}
@media (min-width: 72em) {
  .orchestra-roster__featured-inner {
    gap: 60px;
    max-width: 1440px;
    margin: auto;
  }
}

.orchestra-roster__featured-intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
}
@media (min-width: 80em) {
  .orchestra-roster__featured-intrinsic-ratio {
    position: relative;
    padding-bottom: 60%;
  }
}

.orchestra-roster__featured-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.orchestra-roster__featured-name {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 24px;
  color: #000;
  margin: 15px 0 0 0;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-name {
    font-size: 28px;
  }
}
.orchestra-roster__featured-name.orchestra-roster__featured-name--mobile {
  display: block;
  font-size: 16px;
  font-family: Faktum, sans-serif;
  font-weight: 700;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-name.orchestra-roster__featured-name--mobile {
    display: none;
  }
}
.orchestra-roster__featured-name.orchestra-roster__featured-name--desktop {
  display: none;
}
@media (min-width: 50em) {
  .orchestra-roster__featured-name.orchestra-roster__featured-name--desktop {
    display: block;
    margin-bottom: 25px;
  }
}

/*  ==========================================================================
    Orchestra Item
    ========================================================================== */
.orchestra-item {
  margin: 0;
  border: 0;
  padding: 0;
  flex-shrink: 0;
  background: none;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 30px;
}

.orchestra-item__media {
  width: 150px;
}

.orchestra-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
  width: 100%;
  overflow: hidden;
}

.orchestra-item__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.orchestra-item__media .o-icon {
  color: #757575;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  height: 80%;
  z-index: 1;
  transform: translate(-50%, -50%);
}

.orchestra-item__media--image {
  background-color: transparent;
}

.orchestra-item__details {
  text-align: left;
  transition: color 0.4s ease;
  width: calc(100% - 190px);
}

.orchestra-item__details--full {
  width: 100%;
}

.orchestra-item__name {
  display: inline;
  font-family: Faktum Wide, sans-serif;
  line-height: 1.2;
  font-size: 16px;
  font-weight: 500;
}
@media (min-width: 50em) {
  .orchestra-item__name {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 0;
  }
}

.orchestra-item__role {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  padding-top: 10px;
  margin-top: 10px;
  margin-bottom: 0;
  font-weight: 300;
  font-size: 14px;
}

.orchestra-item__position {
  margin-top: 5px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: 400;
}
@media (min-width: 50em) {
  .orchestra-item__position {
    font-size: 16px;
    font-weight: 500;
  }
}

.people-panel__primary {
  padding: 25px 0 40px;
}
@media (min-width: 62.5em) {
  .people-panel__primary {
    padding: 40px 0 60px;
  }
}

/*  ==========================================================================
	Orchestra Sticky Bar
	========================================================================== */
.orchestra-sticky-bar {
  position: sticky;
  top: 0;
  background: var(--theme-color);
  border-bottom: transparent;
  z-index: 1;
  transition: all 0.3s ease;
}
@media (min-width: 72em) {
  .orchestra-sticky-bar {
    top: var(--global-header-height);
  }
}

.orchestra-sticky-bar__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .orchestra-sticky-bar__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.orchestra-sticky-bar__inner {
  margin: 0 auto;
  padding: 0 0 0 15px;
}
@media (min-width: 50em) {
  .orchestra-sticky-bar__inner {
    padding: 0 20px;
  }
}

.orchestra-sticky-bar__nav {
  display: flex;
  align-items: stretch;
  min-height: 50px;
}
@media (min-width: 50em) {
  .orchestra-sticky-bar__nav {
    min-height: 60px;
  }
}
.orchestra-sticky-bar__nav:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 30px;
  background: linear-gradient(to right, color-mix(in srgb, var(--theme-color) 0%, transparent) 0, var(--theme-color) 95%);
  z-index: 2;
}

.orchestra-sticky-bar__list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 15px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.orchestra-sticky-bar__list::-webkit-scrollbar {
  display: none;
}
@media (min-width: 50em) {
  .orchestra-sticky-bar__list {
    gap: 30px;
  }
}

.orchestra-sticky-bar__item {
  flex-shrink: 0;
}
@media (max-width: 49.99em) {
  .orchestra-sticky-bar__item:last-child {
    margin-right: 15px;
  }
}

.orchestra-sticky-bar__link {
  height: 100%;
  display: flex;
  align-items: center;
  padding: 10px 0;
  text-decoration: none;
  color: var(--theme-body-text-color);
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 16px;
  text-transform: capitalize;
  letter-spacing: 0.5px;
  border-bottom: 2px solid transparent;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.orchestra-sticky-bar__link:hover, .orchestra-sticky-bar__link.active {
  color: var(--theme-highlight-color);
  border-bottom-color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .orchestra-sticky-bar__link {
    padding: 15px 0;
  }
}

/*  ==========================================================================
	Program Panel
	========================================================================== */
.program-panel {
  position: relative;
  padding: 30px 0;
}
@media (min-width: 50em) {
  .program-panel {
    padding: 60px 0;
  }
}

.program-panel__inner {
  width: 100%;
  max-width: 920px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .program-panel__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.program-panel__inner {
  display: flex;
  flex-direction: column;
  padding: 15px;
  background-color: #F4F4F4;
}
@media (min-width: 62.5em) {
  .program-panel__inner {
    flex-direction: row;
    padding: 30px;
  }
}

.program-panel__header {
  position: relative;
  flex: 0 0 auto;
  width: 100%;
  margin-bottom: 15px;
  color: #000;
}
@media (min-width: 50em) {
  .program-panel__header {
    flex: 0 0 45%;
    text-align: left;
    width: auto;
    margin-right: 40px;
    margin-bottom: 30px;
  }
}

.program-panel__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 22px;
  font-weight: 600;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .program-panel__title {
    font-size: 26px;
  }
}

.program-panel__items {
  position: relative;
  color: #000;
  flex: 1 1 auto;
  width: 100%;
  margin-right: 30px;
}

.program-item__content {
  padding: 12px 0;
  border-top: 1px solid #000;
}

.program-item__title {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 0;
}

.program-item__subtitle {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 0;
}

.program-panel__additional-info {
  border-top: 1px solid #000;
  padding-top: 10px;
}
.program-panel__additional-info.s-prose p:not(.quote__text):not(.cta):not(.caption),
.program-panel__additional-info.s-prose ul,
.program-panel__additional-info.s-prose ol,
.program-panel__additional-info.s-prose dl {
  font-size: 14px;
  font-family: Faktum, sans-serif;
  font-weight: 400;
}

/*  ==========================================================================
	Performance Info
	========================================================================== */
.performance-info {
  background-color: var(--theme-color);
  color: var(--theme-highlight-color);
}

.performance-info__inner {
  padding-bottom: 15px;
}
@media (min-width: 59em) {
  .performance-info__inner {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
@media (min-width: 59em) and (min-width: 50em) {
  .performance-info__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.performance-info__container {
  display: flex;
  overflow-x: auto;
  gap: 15px;
  padding: 0 15px;
}
@media (min-width: 59em) {
  .performance-info__container {
    gap: 20px;
    overflow: unset;
    padding: 0;
  }
}

.performance-info__item {
  padding: 20px;
  position: relative;
  flex: 0 0 280px;
}
@media (min-width: 59em) {
  .performance-info__item {
    flex: 1 1 calc(33% - 15px);
    padding: 30px;
  }
}

.performance-info__item::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--theme-highlight-color) 100%);
}

.performance-info__item-title {
  font-size: 22px;
  font-weight: 600;
  font-family: Faktum Wide, sans-serif;
}

.performance-info__item-copy {
  font-size: 16px;
  color: var(--theme-body-text-color);
}
.performance-info__item-copy p {
  margin: 0;
}
.performance-info__item-copy strong {
  font-weight: 600;
}

/*  ==========================================================================
	Performance Info - 4
	========================================================================== */
@media (min-width: 59em) {
  .performance-info__container--4 {
    flex-wrap: wrap;
  }
  .performance-info__container--4 .performance-info__item {
    flex-basis: calc(50% - 15px);
  }
}
@media (min-width: 72em) {
  .performance-info__container--4 {
    flex-wrap: nowrap;
  }
  .performance-info__container--4 .performance-info__item {
    flex-basis: calc(33% - 15px);
  }
}

/*  ==========================================================================
	Performance Info - More than 4
	========================================================================== */
@media (min-width: 59em) {
  .performance-info__container--3-up {
    flex-wrap: wrap;
  }
  .performance-info__container--3-up .performance-info__item {
    flex-grow: 0;
    flex-basis: calc(50% - 15px);
  }
}
@media (min-width: 72em) {
  .performance-info__container--3-up .performance-info__item {
    flex-basis: calc(33% - 15px);
  }
}

/*  ==========================================================================
    Child Grid
    ========================================================================== */
.child-grid {
  position: relative;
  margin: 30px 0;
  overflow: hidden;
}
@media (min-width: 50em) {
  .child-grid {
    margin: var(--content-margin-small);
  }
}
.child-grid .page-item .page-item__intrinsic-ratio:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 15px;
  background-color: #fff;
  transition: width 0.4s ease;
  z-index: 10;
  display: block;
}
@media (min-width: 50em) {
  .child-grid .page-item .page-item__intrinsic-ratio:before {
    height: 30px;
  }
}
.child-grid .page-item .page-item__intrinsic-ratio:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 15px;
  height: 0;
  background-color: #fff;
  transition: height 0.4s ease;
  z-index: 10;
  display: block;
}
.child-grid .page-item .page-item__intrinsic-ratio:hover:before {
  width: 50px;
}
@media (min-width: 50em) {
  .child-grid .page-item .page-item__intrinsic-ratio:hover:before {
    width: 100px;
  }
}
.child-grid .page-item .page-item__intrinsic-ratio:hover:after {
  height: 50px;
}
@media (min-width: 50em) {
  .child-grid .page-item .page-item__intrinsic-ratio:hover:after {
    height: 100px;
  }
}

.child-grid__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .child-grid__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.child-grid__title {
  font-size: 22px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  margin-bottom: 30px;
}
@media (min-width: 50em) {
  .child-grid__title {
    font-size: 26px;
    margin-bottom: 20px;
  }
}

.child-grid__list {
  display: grid;
  gap: 30px;
  grid-template-columns: 1fr;
}
@media (min-width: 30em) {
  .child-grid__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px 25px;
  }
}
@media (min-width: 50em) {
  .child-grid__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 62.5em) {
  .child-grid__list {
    gap: 40px 40px;
  }
}

.child-grid__item {
  display: flex;
  width: 100%;
  box-sizing: content-box;
}

/*  ==========================================================================
    Artsits Panel
    ========================================================================== */
.artists-panel {
  display: flex;
  flex-direction: column;
  position: relative;
  margin: var(--content-margin);
}

.artists-panel:last-child {
  margin-bottom: 0;
}

.artists-panel__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 0;
}
@media (min-width: 59em) {
  .artists-panel__inner {
    gap: 40px;
    width: 100%;
    max-width: 920px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 59em) and (min-width: 50em) {
  .artists-panel__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.artists-panel__header {
  padding: 0 15px;
}
@media (min-width: 72em) {
  .artists-panel__header {
    padding: 0;
  }
}

.artists-panel__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  font-size: 24px;
  padding-bottom: 20px;
  text-align: center;
}
@media (min-width: 50em) {
  .artists-panel__title {
    font-size: 26px;
  }
}

.artists-panel__list {
  display: flex;
}
@media (max-width: 58.99em) {
  .artists-panel__list {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}
.artists-panel__list::-webkit-scrollbar {
  display: none;
}
@media (min-width: 59em) {
  .artists-panel__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    padding: 0 15px;
  }
}
@media (min-width: 72em) {
  .artists-panel__list {
    gap: 60px;
    padding: 0;
  }
}

/*  ==========================================================================
    Artsits Panel - Artist
    ========================================================================== */
.artist {
  position: relative;
  background: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0;
  border: 0;
  padding: 0;
  flex-shrink: 0;
  width: 280px;
  margin-right: 20px;
}
@media (min-width: 32em) {
  .artist {
    width: 320px;
  }
}
@media (min-width: 59em) {
  .artist {
    width: 100%;
    height: 100%;
    flex-direction: row;
    background-color: #F4F4F4;
    align-items: flex-start;
  }
}

@media (hover: hover) and (pointer: fine) {
  .artist--bio {
    cursor: pointer;
  }
}

.artist__media {
  width: 100%;
}
@media (min-width: 59em) {
  .artist__media {
    width: 150px;
  }
}

.artist__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
  width: 100%;
  overflow: hidden;
}

.artist__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  transition: transform 0.3s ease-in-out, filter 0.2s ease-in-out;
}

.artist__media .o-icon {
  color: #757575;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  height: 80%;
  z-index: 1;
  transform: translate(-50%, -50%);
}

.artist__media--image {
  background-color: transparent;
}

.artist__details {
  display: flex;
  flex-direction: column;
  padding: 15px;
  background-color: #F4F4F4;
  text-align: left;
  flex-grow: 1;
  width: 100%;
}
@media (min-width: 59em) {
  .artist__details {
    width: calc(100% - 150px);
    height: 100%;
    padding: 15px 15px 15px 30px;
    background-color: transparent;
    justify-content: center;
    align-items: flex-start;
  }
}
.artist--bio .artist__details {
  color: #000;
}

.artist__name {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 0;
  font-size: 18px;
}
@media (min-width: 32em) {
  .artist__name {
    font-size: 20px;
  }
}
@media (min-width: 59em) {
  .artist__name {
    font-size: 18px;
  }
}
@media (min-width: 72em) {
  .artist__name {
    font-size: 22px;
  }
}

.artist__role {
  color: var(--theme-color);
  margin: 5px 0 0;
  font-family: Faktum Wide, sans-serif;
  font-weight: 500;
  font-size: 12px;
}
@media (min-width: 32em) {
  .artist__role {
    font-size: 14px;
  }
}
@media (min-width: 59em) {
  .artist__role {
    font-size: 12px;
  }
}
@media (min-width: 72em) {
  .artist__role {
    font-size: 16px;
  }
}

.artist__icon {
  position: absolute;
  bottom: 15px;
  right: 15px;
  opacity: 0.4;
  transition: right 0.3s ease-in-out;
}
.artist__icon .o-icon {
  width: 28px;
  height: 28px;
}

.artist--bio:hover .artist__image, .artist--bio:focus .artist__image {
  transform: scale(1.05);
  filter: brightness(1.1) contrast(1.05) saturate(1.1);
}
.artist--bio:hover .artist__icon, .artist--bio:focus .artist__icon {
  right: 10px;
}

/*  ==========================================================================
	Posts
	========================================================================== */
.post-item {
  display: flex;
  width: 100%;
  transition: border-bottom 0.3s ease-in-out;
}

.post-item__inner {
  display: flex;
  flex-direction: column;
  gap: 10px;
  height: 100%;
  width: 100%;
}
@media (min-width: 62.5em) {
  .post-item__inner {
    gap: 20px;
  }
}
@media (min-width: 62.5em) {
  .post-item__inner {
    gap: 25px;
  }
}

.post-item__media {
  overflow: hidden;
}

.post-item__intrinsic-ratio {
  position: relative;
  height: 0;
  padding-bottom: 73.3333333333%;
  overflow: hidden;
}

.post-item__image {
  position: absolute;
  width: 100%;
  height: auto;
}

.post-item__content {
  display: flex;
  flex-direction: column;
}

.post-item__post-type {
  font-family: Faktum, sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 62.5em) {
  .post-item__post-type {
    font-size: 18px;
  }
}

.post-item__prefix {
  display: inline-block;
  font-weight: 700;
  font-size: 14px;
}
@media (min-width: 50em) {
  .post-item__prefix {
    font-size: 16px;
  }
}

.post-item__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 10px;
}
@media (min-width: 50em) {
  .post-item__title {
    font-size: 22px;
    font-weight: 600;
  }
}
@media (min-width: 62.5em) {
  .post-item__title {
    font-size: 24px;
    line-height: 1.2;
  }
}
@media (min-width: 72em) {
  .post-item__title {
    font-size: 28px;
  }
}

.post-item__date {
  padding-top: 10px;
  display: block;
  font-size: 14px;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  margin: auto 0 0 0;
}

.post-item__details,
.post-item__cta {
  font-size: 16px;
}

.post-item__cta {
  text-decoration: underline;
}

/*  ==========================================================================
    Concert List
    ========================================================================== */
.page-list {
  position: relative;
  padding: 15px 0 30px;
  overflow: hidden;
  background-color: #fff;
  color: #000;
}
@media (min-width: 50em) {
  .page-list {
    padding: 30px 0;
  }
}
.page-list:last-child {
  margin-bottom: 0;
}

@media (min-width: 62.5em) {
  .page-list__inner {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 62.5em) and (min-width: 50em) {
  .page-list__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.page-list__header {
  position: relative;
  margin: 0 15px 15px;
  padding-top: 15px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .page-list__header {
    align-items: center;
  }
}
@media (min-width: 62.5em) {
  .page-list__header {
    align-items: flex-start;
    margin: 0 0 15px;
    gap: 40px;
  }
}

.page-list__title {
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .page-list__title {
    font-size: 28px;
  }
}

.page-list__description {
  margin-top: 5px;
  font-size: 15px;
  font-weight: 400;
}
@media (min-width: 50em) {
  .page-list__description {
    font-size: 20px;
  }
}

.page-list__actions {
  display: flex;
  gap: 0 8px;
  margin-left: auto;
  flex-shrink: 0;
}
@media (min-width: 62.5em) {
  .page-list__actions {
    margin-right: 40px;
  }
}

.page-list__previous,
.page-list__next {
  border: none;
  padding: 0;
  cursor: pointer;
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  transition: background-color 0.4s ease;
  background-color: var(--theme-color);
}
.page-list__previous.page-list--grey,
.page-list__next.page-list--grey {
  background-color: #F4F4F4;
}
@media (min-width: 62.5em) {
  .page-list__previous,
  .page-list__next {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.page-list__previous.swiper-button-disabled,
.page-list__next.swiper-button-disabled {
  cursor: not-allowed;
}
.page-list__previous .o-icon,
.page-list__next .o-icon {
  color: var(--text-color-light);
  scale: 1;
  transition: scale 0.4s ease;
  width: 16px;
  height: 16px;
}
.page-list__previous:not(.swiper-button-disabled):hover .o-icon,
.page-list__next:not(.swiper-button-disabled):hover .o-icon {
  scale: 1.1;
}

.page-list__previous {
  margin-left: 0;
}
.page-list__previous .o-icon {
  rotate: -180deg;
}

.page-list__next {
  margin-left: 15px;
}
@media (min-width: 62.5em) {
  .page-list__next {
    margin-left: 0;
  }
}

.page-list__content.page-list__content--grid .page-list__grid::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .page-list__content.page-list__content--grid .page-list__grid {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.page-list__content.page-list__content--grid .page-list__list {
  display: grid;
  gap: 15px;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.page-list__content.page-list__content--grid .page-list__list::-webkit-scrollbar {
  display: none;
}
.page-list__content.page-list__content--grid .page-list__list:has(> :only-child) {
  grid-template-columns: 1fr;
  overflow: hidden;
}
@media (min-width: 42.5em) {
  .page-list__content.page-list__content--grid .page-list__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    overflow: visible;
  }
  .page-list__content.page-list__content--grid .page-list__list:has(> :only-child) {
    max-width: 660px;
    margin: 0 auto;
  }
}
@media (min-width: 50em) {
  .page-list__content.page-list__content--grid .page-list__list {
    overflow-x: auto;
  }
}
@media (max-width: 49.99em) {
  .page-list__content.page-list__content--grid .page-list__list {
    display: flex;
    -webkit-overflow-scrolling: touch;
  }
  .page-list__content.page-list__content--grid .page-list__list .page-list__item {
    display: flex;
    width: 320px;
    padding-right: 15px;
    flex-shrink: 0;
    box-sizing: content-box;
    position: relative;
  }
}
.page-list__content.page-list__content--grid .page-list__item {
  width: 100%;
  display: flex;
}
.page-list__content.page-list__content--grid .page-list__item:only-child {
  width: 100%;
}
@media (min-width: medium-minor) {
  .page-list__content.page-list__content--grid .page-list__item:only-child {
    grid-column: 1/-1;
  }
}
.page-list__content.page-list__content--slider .page-list__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .page-list__content.page-list__content--slider .page-list__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-left: 15px;
  }
}
.page-list__content.page-list__content--slider .page-list__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}
.page-list__content.page-list__content--slider .page-list__item {
  display: flex;
  width: 320px;
  padding-right: 15px;
  flex-shrink: 0;
  box-sizing: content-box;
  position: relative;
}
@media (min-width: 62.5em) {
  .page-list__content.page-list__content--slider .page-list__item {
    width: calc(33.33% - 23px);
    padding-right: 30px;
  }
  .page-list__content.page-list__content--slider .page-list__item:last-child {
    padding-right: 0;
  }
}
@media (min-width: 62.5em) {
  .page-list__content.page-list__content--slider-more {
    width: calc(100% - 30px);
  }
}

.page-list:has(.page-list__grid) .page-list__actions {
  display: none;
}

/*  ==========================================================================
    Concert List - Items
    ========================================================================== */
.page-list .concert-item {
  display: flex;
  flex-direction: column;
  gap: 15px;
  height: 100%;
  width: 100%;
}
.page-list .concert-item .concert-item__content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.page-list .concert-item .concert-item__details {
  flex: 1;
  margin-top: 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 120px;
}
@media (min-width: 50em) {
  .page-list .concert-item .concert-item__details {
    min-height: 150px;
  }
}
.page-list .concert-item .concert-item__media {
  position: relative;
  overflow: hidden;
}
.page-list .concert-item .concert-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
  object-fit: cover;
  object-position: center;
}
.page-list .concert-item .concert-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
.page-list .concert-item .concert-item__favorite {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2;
  display: none;
}
@media (min-width: 50em) {
  .page-list .concert-item .concert-item__favorite {
    bottom: 20px;
    right: 20px;
  }
}
.page-list .concert-item .concert-item__favorite-btn {
  background-color: rgba(255, 255, 255, 0.75);
  border: none;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  padding: 0;
}
.page-list .concert-item .concert-item__favorite-btn:hover {
  background: var(--theme-highlight-color);
}
.page-list .concert-item .concert-item__favorite-btn svg {
  width: 18px;
  height: 18px;
}
@media (min-width: 50em) {
  .page-list .concert-item .concert-item__favorite-btn {
    width: 46px;
    height: 46px;
  }
  .page-list .concert-item .concert-item__favorite-btn svg {
    width: 23px;
    height: 23px;
  }
}
.page-list .concert-item .concert-item__favorite-btn .filled {
  display: none;
}
.page-list .concert-item .concert-item__favorite-btn.is-favorite {
  background-color: #fff;
}
.page-list .concert-item .concert-item__favorite-btn.is-favorite .outline {
  display: none;
}
.page-list .concert-item .concert-item__favorite-btn.is-favorite .filled {
  display: block;
}
.page-list .concert-item .concert-item__title {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .page-list .concert-item .concert-item__title {
    font-size: 22px;
    line-height: 1.4;
    min-height: 62px;
  }
}
.page-list .concert-item .concert-item__dates {
  margin-top: 15px;
}
.page-list .concert-item .concert-item__date-item {
  display: flex;
  border-top: 1px solid #dAdAdA;
  padding: 5px 0 7px;
  gap: 40px;
}
.page-list .concert-item .concert-item__date {
  font-size: 14px;
  margin: 0;
}
.page-list .concert-item .concert-item__venue {
  font-size: 14px;
  font-weight: 500;
  margin: 0;
}
.page-list .concert-item .concert-item__categories {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 5px;
  list-style: none;
  padding: 0;
  margin: 0;
  padding-top: 15px;
  border-top: 1px solid #dAdAdA;
}
.page-list .concert-item .concert-item-category {
  color: var(--theme-color);
  border: 1px solid;
  border-radius: 20px;
  padding: 6px 10px;
  font-family: Faktum, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1;
  flex-shrink: 0;
}
@media (min-width: 50em) {
  .page-list .concert-item .concert-item-category {
    padding: 8px 15px;
  }
}

/*  ==========================================================================
    Concert List
    ========================================================================== */
.season-grid {
  position: relative;
  padding: 15px 0 30px;
  overflow: hidden;
  background-color: #fff;
  color: #000;
}
@media (min-width: 50em) {
  .season-grid {
    padding: 30px 0;
  }
}
.season-grid:last-child {
  margin-bottom: 0;
}

.season-grid__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .season-grid__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.season-grid__container {
  margin-bottom: 40px;
}
@media (min-width: 50em) {
  .season-grid__container {
    margin-bottom: 60px;
  }
}

.season-grid__list-title {
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 30px;
}
@media (min-width: 50em) {
  .season-grid__list-title {
    font-size: 28px;
  }
}

.season-grid__list {
  display: grid;
  gap: 15px;
  grid-template-columns: repeat(1, 1fr);
}
@media (min-width: 42.5em) {
  .season-grid__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 62.5em) {
  .season-grid__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
  }
}
@media (max-width: 49.99em) {
  .season-grid__list .season-grid__item {
    display: flex;
    width: 100%;
    flex-shrink: 0;
    box-sizing: content-box;
    position: relative;
  }
}

.season-grid__toggle-btn {
  display: block;
  width: 100%;
}
@media (min-width: 42.5em) {
  .season-grid__toggle-btn {
    display: none;
  }
}

.season-grid__list--extended {
  margin-top: 15px;
}
@media (max-width: 42.49em) {
  .season-grid__list--extended {
    display: none;
  }
}
@media (min-width: 62.5em) {
  .season-grid__list--extended {
    margin-top: 30px;
  }
}
@media (max-width: 42.49em) {
  .season-grid__list--extended.active {
    display: grid;
  }
}

/*  ==========================================================================
    Concert List - Items
    ========================================================================== */
.season-grid .concert-item {
  display: flex;
  flex-direction: column;
  gap: 15px;
  height: 100%;
  width: 100%;
}
.season-grid .concert-item .concert-item__content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.season-grid .concert-item .concert-item__details {
  flex: 1;
  margin-top: 5px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 120px;
}
@media (min-width: 50em) {
  .season-grid .concert-item .concert-item__details {
    min-height: 150px;
  }
}
.season-grid .concert-item .concert-item__media {
  position: relative;
  overflow: hidden;
}
.season-grid .concert-item .concert-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
  object-fit: cover;
  object-position: center;
}
.season-grid .concert-item .concert-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
.season-grid .concert-item .concert-item__favorite {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 2;
  display: none;
}
@media (min-width: 50em) {
  .season-grid .concert-item .concert-item__favorite {
    bottom: 20px;
    right: 20px;
  }
}
.season-grid .concert-item .concert-item__favorite-btn {
  background-color: rgba(255, 255, 255, 0.75);
  border: none;
  border-radius: 50%;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s ease;
  padding: 0;
}
.season-grid .concert-item .concert-item__favorite-btn:hover {
  background: var(--theme-highlight-color);
}
.season-grid .concert-item .concert-item__favorite-btn svg {
  width: 18px;
  height: 18px;
}
@media (min-width: 50em) {
  .season-grid .concert-item .concert-item__favorite-btn {
    width: 46px;
    height: 46px;
  }
  .season-grid .concert-item .concert-item__favorite-btn svg {
    width: 23px;
    height: 23px;
  }
}
.season-grid .concert-item .concert-item__favorite-btn .filled {
  display: none;
}
.season-grid .concert-item .concert-item__favorite-btn.is-favorite {
  background-color: #fff;
}
.season-grid .concert-item .concert-item__favorite-btn.is-favorite .outline {
  display: none;
}
.season-grid .concert-item .concert-item__favorite-btn.is-favorite .filled {
  display: block;
}
.season-grid .concert-item .concert-item__title {
  display: block;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.6;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .season-grid .concert-item .concert-item__title {
    font-size: 22px;
    line-height: 1.4;
    min-height: 62px;
  }
}
.season-grid .concert-item .concert-item__dates {
  margin-top: 15px;
}
.season-grid .concert-item .concert-item__date-item {
  display: flex;
  border-top: 1px solid #dAdAdA;
  padding: 5px 0 7px;
  gap: 40px;
}
.season-grid .concert-item .concert-item__date {
  font-size: 14px;
  margin: 0;
}
.season-grid .concert-item .concert-item__venue {
  font-size: 14px;
  font-weight: 500;
  margin: 0;
}
.season-grid .concert-item .concert-item__categories {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 5px;
  list-style: none;
  padding: 0;
  margin: 0;
  padding-top: 15px;
  border-top: 1px solid #dAdAdA;
}
.season-grid .concert-item .concert-item-category {
  color: var(--theme-color);
  border: 1px solid;
  border-radius: 20px;
  padding: 6px 10px;
  font-family: Faktum, sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1;
  flex-shrink: 0;
}
@media (min-width: 50em) {
  .season-grid .concert-item .concert-item-category {
    padding: 8px 15px;
  }
}

.feature-panel {
  color: var(--theme-body-text-color);
  padding: 30px 0;
}
.feature-panel.text-black {
  color: #000;
}
.feature-panel.text-white {
  color: #fff;
}
@media (min-width: 50em) {
  .feature-panel {
    background-color: var(--theme-color);
  }
}

.feature-panel__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .feature-panel__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.feature-panel__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.feature-panel__inner:has(.feature-panel__link):hover .feature-panel__link-icon, .feature-panel__inner:has(.feature-panel__link):focus .feature-panel__link-icon {
  transform: translateX(10px);
}
.feature-panel__inner:has(.feature-panel__link):hover .feature-panel__image, .feature-panel__inner:has(.feature-panel__link):focus .feature-panel__image {
  transform: scale(1.05);
}

.feature-panel__media {
  overflow: hidden;
  width: 100%;
  position: relative;
}
@media (max-width: 49.99em) {
  .feature-panel__media {
    order: 1;
  }
}
@media (min-width: 50em) {
  .feature-panel__media {
    width: 50%;
    margin-bottom: 0;
  }
  .feature-panel__media:before {
    content: "";
    position: absolute;
    top: -1px;
    left: 0;
    height: calc(100% + 2px);
    width: 80px;
    z-index: 2;
    background-color: var(--theme-color);
    transform: skewX(5deg);
    transform-origin: top;
    left: -40px;
  }
}

.feature-panel__intrinsic-ratio {
  position: relative;
  padding-bottom: 60%;
  height: 0;
}

.feature-panel__image {
  height: 100%;
  position: absolute;
  right: 0;
  transform: scale(1);
  transition: transform 0.4s ease;
  width: 100%;
  min-height: 100%;
  object-fit: cover;
}

.feature-panel__details {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 15px;
  padding: 30px 20px;
  margin: 0 auto;
  position: relative;
}
@media (max-width: 49.99em) {
  .feature-panel__details {
    order: 2;
    background-color: var(--theme-color);
  }
}
@media (min-width: 50em) {
  .feature-panel__details {
    padding: 40px 20px;
    width: 50%;
  }
}
@media (min-width: 62.5em) {
  .feature-panel__details {
    margin: 0;
    gap: 20px;
    padding: 100px 20px;
  }
}

.feature-panel__title {
  margin-bottom: 0;
  font-size: 20px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  color: var(--theme-highlight-color);
  max-width: 420px;
  line-height: 1.2;
}
@media (min-width: 50em) {
  .feature-panel__title {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .feature-panel__title {
    font-size: 38px;
  }
}

.feature-panel__description {
  margin-bottom: 0;
  font-size: 16px;
}
.feature-panel__description p {
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .feature-panel__description {
    font-size: 20px;
  }
}

.feature-panel__link {
  font-size: 16px;
  font-weight: 600;
  display: inline-flex;
  gap: 10px;
  align-items: center;
}
@media (min-width: 50em) {
  .feature-panel__link {
    font-size: 20px;
  }
}

.feature-panel__link-icon {
  transition: transform 0.3s ease;
}
.feature-panel__link-icon .o-icon {
  width: 16px;
  height: 16px;
}

@media (min-width: 50em) {
  .feature-panel--right .feature-panel__inner {
    justify-content: flex-end;
  }
  .feature-panel--right .feature-panel__media {
    order: 2;
  }
  .feature-panel--right .feature-panel__media:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: auto;
    width: 20vw;
    max-width: 50%;
    z-index: 2;
  }
  .feature-panel--right .feature-panel__details {
    order: 1;
  }
}

/*  ==========================================================================
    Featured News
    ========================================================================== */
.featured-news {
  padding: 40px 0;
  background-color: var(--theme-color);
  color: var(--theme-highlight-color);
}
.featured-news .post-item {
  height: 100%;
}
@media (max-width: 62.49em) {
  .featured-news .post-item {
    width: 300px;
  }
}
@media (max-width: 49.99em) {
  .featured-news .post-item {
    width: 266px;
  }
}
.featured-news .post-item__title {
  font-size: 20px;
}
@media (min-width: 62.5em) {
  .featured-news .post-item__title {
    font-size: 22px;
  }
}
.featured-news .post-item__date {
  border-color: var(--theme-highlight-color);
}
@media (min-width: 50em) {
  .featured-news {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .featured-news {
    padding: 80px 0;
  }
}

.featured-news__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .featured-news__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.featured-news__scroll::-webkit-scrollbar {
  display: none;
}
@media (max-width: 62.49em) {
  .featured-news__scroll {
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
  }
}

.featured-news__list {
  padding: 20px 0;
  gap: 30px;
  display: flex;
  -webkit-overflow-scrolling: touch;
}
@media (min-width: 50em) {
  .featured-news__list {
    gap: 30px;
    padding: 20px 0 40px;
  }
}
@media (min-width: 62.5em) {
  .featured-news__list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (min-width: 80em) {
  .featured-news__list {
    gap: 30px 60px;
  }
}

.featured-news__title {
  padding-bottom: 0;
  margin-bottom: 0;
  font-family: Faktum Wide, sans-serif;
  font-size: 20px;
}
@media (min-width: 50em) {
  .featured-news__title {
    font-size: 26px;
  }
}

.theme-, .theme-white {
  background-color: #fff;
  color: #000;
}
.theme- .post-item__date, .theme-white .post-item__date {
  border-color: #C4C4C4;
}

/* ==========================================================================
   Widgets
   ========================================================================== */
/*  ==========================================================================
	Calendar List
	========================================================================== */
.calendar__list {
  order: 2;
  width: 100%;
}
@media (min-width: 62.5em) {
  .calendar__list {
    order: 1;
    width: 100%;
  }
}

.calendar-list {
  position: relative;
}
.calendar-list__group {
  margin-bottom: 40px;
}
.calendar-list__group--year:first-child .calendar-list__year, .calendar-list__group--year:first-child div:first-of-type .calendar-list__month {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.calendar-list__year {
  display: inline-block;
  position: relative;
  line-height: 1.2;
  background: linear-gradient(180deg, var(--theme-color) 0, var(--theme-color));
  background-position: 0 100%;
  background-size: 100% 50%;
  background-repeat: no-repeat;
  text-decoration: none;
  padding: 0 5px 5px;
  font-weight: 700;
  font-size: var(--global-header-size-2);
  font-family: museo-sans, sans-serif;
  margin: 0 auto 5px;
}
.calendar-list__month {
  font-weight: 700;
  margin-bottom: 15px;
}
@media (min-width: 62.5em) {
  .calendar-list__groups {
    padding-top: 30px;
  }
  .calendar-list__group {
    margin-bottom: 60px;
  }
}

/*  ==========================================================================
	Calendar List - Performance
	========================================================================== */
.calendar-performance {
  display: flex;
  background-color: #fff;
  margin-bottom: 2px;
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow 0.3s ease, transform 0.3s ease, background-color 0.5s ease;
}
.calendar-performance--focused {
  background-color: #aaa;
  transform: scale(1.1);
  transition: background-color 0s, transform 0s;
}
@media (min-width: 50em) {
  .calendar-performance {
    border-radius: 8px;
    margin-bottom: 10px;
  }
  .calendar-performance:hover, .calendar-performance:focus {
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
    transform: scale(1.01);
    z-index: 2;
  }
}
@media (min-width: 62.5em) {
  .calendar-performance {
    border-radius: 15px;
  }
}

.calendar-performance__date-holder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-color: #757575;
  color: #fff;
  width: 50px;
  flex-shrink: 0;
  padding: 10px 0;
}
@media (min-width: 50em) {
  .calendar-performance__date-holder {
    width: 70px;
  }
}
@media (min-width: 62.5em) {
  .calendar-performance__date-holder {
    width: 100px;
  }
}

.calendar-performance__day,
.calendar-performance__month {
  display: block;
  text-transform: uppercase;
  font-size: var(--global-body-size-2);
}
@media (min-width: 62.5em) {
  .calendar-performance__day,
  .calendar-performance__month {
    font-size: var(--global-body-size-4);
  }
}

.calendar-performance__date {
  display: block;
  font-weight: bold;
  line-height: 1;
  font-size: var(--global-header-size-5);
}
@media (min-width: 62.5em) {
  .calendar-performance__date {
    font-size: var(--global-header-size-8);
  }
}

.calendar-performance__details {
  padding: 20px 15px;
  align-self: center;
  margin-right: auto;
  flex-grow: 1;
}
@media (min-width: 62.5em) {
  .calendar-performance__details {
    padding: 15px 30px;
  }
}

.calendar-performance__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: bold;
  margin-bottom: 0;
  line-height: 1.2;
}

.calendar-performance__prefix,
.calendar-performance__suffix {
  display: block;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: var(--global-body-size-1);
}
@media (min-width: 50em) {
  .calendar-performance__prefix,
  .calendar-performance__suffix {
    font-size: var(--global-body-size-2);
  }
}

.calendar-performance__prefix {
  margin-bottom: 2px;
}

.calendar-performance__suffix {
  margin-top: 2px;
  margin-bottom: 10px;
}

.calendar-performance__meta {
  display: block;
  font-size: var(--global-body-size-2);
}
@media (min-width: 62.5em) {
  .calendar-performance__meta {
    margin-top: 10px;
  }
}
@media (min-width: 72em) {
  .calendar-performance__meta {
    font-size: var(--global-body-size-4);
  }
}

.calendar-performance__time {
  font-weight: bold;
}

.calendar-performance__tags {
  display: flex;
  flex-wrap: wrap;
  margin-top: 10px;
}
@media (min-width: 32em) {
  .calendar-performance__tags {
    margin-top: 15px;
  }
}

.calendar-performance__tag {
  border: 1px solid rgba(0, 0, 0, 0.25);
  font-weight: bold;
  padding: 3px 8px;
  font-size: var(--global-body-size-1);
}
@media (min-width: 62.5em) {
  .calendar-performance__tag {
    font-size: var(--global-body-size-2);
  }
}

.calendar-performance__media {
  display: none;
  flex-shrink: 0;
}
@media (min-width: 32em) {
  .calendar-performance__media {
    display: block;
    width: 150px;
  }
}
@media (min-width: 72em) {
  .calendar-performance__media {
    width: 200px;
  }
}

.calendar-performance__intrinsic-ratio {
  position: relative;
  padding-bottom: 83.3333333333%;
  height: 0;
  overflow: hidden;
}

.calendar-performance__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
   Calendar Popup
   ========================================================================== */
.calendar-popup {
  width: 100%;
  max-width: 1120px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .calendar-popup {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.calendar-popup {
  margin: auto;
  padding: 0;
  width: 100%;
  background-color: transparent;
}
@media (max-width: 49.99em) {
  .calendar-popup {
    height: 100%;
    max-width: 100%;
    max-height: 100%;
  }
}

.calendar-popup__inner {
  background-color: #fff;
  height: 100%;
}
@media (max-width: 49.99em) {
  .calendar-popup__inner {
    padding: 0;
    overflow-y: auto;
  }
}

.calendar-popup__close {
  position: fixed;
  top: 15px;
  right: 10px;
  padding: 5px;
  margin: 0;
  border: 0;
  color: #000;
  background-color: #fff;
  border-radius: 5px;
  z-index: 3;
}
@media (min-width: 50em) {
  .calendar-popup__close {
    color: #fff;
    background-color: transparent;
    top: 40px;
    right: 40px;
  }
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .calendar-popup__close:hover {
    color: #727171;
  }
}

.calendar-popup-item {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 15px;
}
@media (min-width: 50em) {
  .calendar-popup-item {
    flex-direction: row;
  }
  .calendar-popup-item > * {
    width: 50%;
  }
}
@media (min-width: 62.5em) {
  .calendar-popup-item {
    padding: 40px;
    gap: 40px;
  }
}

.calendar-popup-item__body {
  display: flex;
  flex-direction: column;
}

.calendar-popup-item__title {
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__title {
    font-size: 42px;
  }
}

.calendar-popup-item__prefix,
.calendar-popup-item__suffix {
  font-family: Faktum, sans-serif;
  font-weight: 800;
  font-size: 18px;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .calendar-popup-item__prefix,
  .calendar-popup-item__suffix {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .calendar-popup-item__prefix,
  .calendar-popup-item__suffix {
    font-size: 22px;
  }
}

.calendar-popup-item__prefix {
  margin-bottom: -5px;
}

.calendar-popup-item__suffix {
  margin-top: -3px;
}

.calendar-popup-item__date {
  margin-top: 5px;
  margin-bottom: 0;
  font-size: 16px;
}
@media (min-width: 50em) {
  .calendar-popup-item__date {
    font-size: 18px;
  }
}

.calendar-popup-item__venue {
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__venue {
    font-size: 18px;
  }
}

.calendar-popup-item__footer {
  border-top: 1px solid;
  padding-top: 20px;
  margin-top: 20px;
}
.calendar-popup-item__footer .calendar-info {
  flex-wrap: wrap;
}
@media (min-width: 50em) {
  .calendar-popup-item__footer {
    order: 1;
    margin-bottom: 30px;
  }
}

.calendar-popup-item__description {
  margin-top: 20px;
  padding-bottom: 60px;
  font-size: 16px;
}
.calendar-popup-item__description p:last-child {
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__description {
    font-size: 18px;
    padding-bottom: 0;
    max-height: 250px;
    overflow-y: auto;
  }
}

.calendar-popup-item__media {
  margin-bottom: 0;
}

.calendar-popup-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__intrinsic-ratio {
    padding-bottom: 70%;
  }
}

.calendar-popup-item__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  z-index: 2;
}

.calendar-popup-item__actions {
  display: flex;
  justify-content: end;
  gap: 15px;
  position: sticky;
  bottom: 0;
  width: 100%;
  order: 2;
  margin: -15px 0;
  padding: 15px;
  padding-right: 0;
  background-color: #fff;
}
@media (max-width: 49.99em) {
  .calendar-popup-item__actions {
    position: fixed;
    right: 0;
    margin: 0;
    padding: 15px;
  }
  .calendar-popup-item__actions > .btn, .calendar-popup-item__actions > :where([data-component*=dialog] menu button) {
    flex-basis: 100%;
    padding-left: 0;
    padding-right: 0;
  }
}

.calendar-scroller__list {
  display: flex;
}

.calendar-event {
  min-width: 350px;
  padding: 20px 15px;
}

.series-package-popup {
  position: relative;
  max-width: 90%;
  width: 900px;
  padding: 0;
}
@media (max-width: 49.99em) {
  .series-package-popup {
    margin: auto 0 var(--event-sticky-height) 0;
    position: fixed;
    max-width: 100%;
    max-height: calc(95% - var(--event-sticky-height));
  }
}

.series-package-popup__header {
  padding: 20px 30px 15px;
  border-bottom: 1px solid #D5D5D5;
}
@media (min-width: 50em) {
  .series-package-popup__header {
    padding: 30px;
  }
}

@media (max-width: 49.99em) {
  .series-package-popup__close {
    display: none !important;
  }
}
@media (min-width: 50em) {
  .series-package-popup__close {
    position: absolute;
    top: 10px;
    right: 30px;
    background: none;
    border: none;
    cursor: pointer;
    background-color: transparent;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #D5D5D5;
    border-radius: 50%;
    padding: 8px;
  }
  .series-package-popup__close:hover {
    background-color: #F4F4F4;
  }
}
@media (min-width: 62.5em) {
  .series-package-popup__close {
    width: 44px;
    height: 44px;
    padding: 12px;
  }
}

.series-package-popup__title {
  font-size: 14px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
}
@media (min-width: 50em) {
  .series-package-popup__title {
    font-size: 18px;
  }
}

.series-package-popup__list {
  border: none;
  padding: 0;
  margin: 0;
}

@media (min-width: 50em) {
  .series-package-popup__list.series-package-popup__list--long {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(var(--grid-rows, 4), auto);
    grid-auto-flow: column;
  }
}

.series-package-item {
  border-bottom: 1px solid #D5D5D5;
  padding: 20px 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}
@media (max-width: 49.99em) {
  .series-package-item {
    gap: 10px;
  }
}
.series-package-item.active .series-package-item__checkbox-item:before {
  background: var(--theme-highlight-color);
}

.series-package-item__title {
  font-size: 17px;
  font-weight: 600;
  display: flex;
  gap: 0 40px;
}
@media (max-width: 49.99em) {
  .series-package-item__title {
    font-size: 16px;
    justify-content: space-between;
  }
}

.series-package-item__description {
  font-size: 16px;
  margin: 0;
}
@media (max-width: 49.99em) {
  .series-package-item__description {
    font-size: 14px;
  }
}

.series-package-item__checkbox {
  visibility: hidden;
  height: 0;
  width: 0;
}

.series-package-item__checkbox-item {
  width: 30px;
  height: 30px;
  border: 1px solid;
  border-radius: 50%;
  position: relative;
}
.series-package-item__checkbox-item:before {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
}

.book-tickets-popup {
  position: relative;
  max-width: 90%;
  width: 900px;
  padding: 0;
}
@media (max-width: 49.99em) {
  .book-tickets-popup {
    margin: auto 0 var(--event-sticky-height) 0;
    position: fixed;
    max-width: 100%;
    max-height: calc(95% - var(--event-sticky-height));
  }
}

@media (max-width: 49.99em) {
  .book-tickets-popup__inner {
    padding-bottom: var(--event-mobile-sticky-height);
  }
}

.book-tickets-popup__header {
  padding: 20px 30px 15px;
  border-bottom: 1px solid #D5D5D5;
}

@media (max-width: 49.99em) {
  .book-tickets-popup__close {
    display: none !important;
  }
}
@media (min-width: 50em) {
  .book-tickets-popup__close {
    position: absolute;
    top: 10px;
    right: 30px;
    background: none;
    border: none;
    cursor: pointer;
    background-color: transparent;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #D5D5D5;
    border-radius: 50%;
    padding: 8px;
  }
  .book-tickets-popup__close:hover {
    background-color: #F4F4F4;
  }
}
@media (min-width: 62.5em) {
  .book-tickets-popup__close {
    width: 44px;
    height: 44px;
    padding: 12px;
  }
}

.book-tickets-popup__title {
  font-size: 14px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
}
@media (min-width: 50em) {
  .book-tickets-popup__title {
    font-size: 18px;
  }
}

.book-tickets-item {
  border-bottom: 1px solid #D5D5D5;
  padding: 20px 30px;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 49.99em) {
  .book-tickets-item {
    gap: 10px;
  }
}

.book-tickets-item__date {
  font-size: 17px;
  font-weight: 600;
  display: flex;
  gap: 0 40px;
}
@media (max-width: 49.99em) {
  .book-tickets-item__date {
    font-size: 16px;
    justify-content: space-between;
  }
}

.book-tickets-item__venue {
  font-size: 16px;
}
@media (max-width: 49.99em) {
  .book-tickets-item__venue {
    font-size: 14px;
  }
}

.book-tickets-item__categories {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.book-tickets-item__category {
  color: #780F5D;
  border: 1px solid;
  padding: 3px 20px;
  border-radius: 20px;
  font-size: 13px;
}
@media (max-width: 49.99em) {
  .book-tickets-item__category {
    font-size: 12px;
    padding: 3px 10px;
    color: #262687;
  }
}

.book-tickets-item__cta .btn, .book-tickets-item__cta :where([data-component*=dialog] menu button) {
  padding: 15px 30px;
}
@media (max-width: 49.99em) {
  .book-tickets-item__cta .btn, .book-tickets-item__cta :where([data-component*=dialog] menu button) {
    font-size: 14px;
    padding: 10px 15px;
  }
}

.subscribe-popup {
  position: relative;
  padding: 30px;
  max-width: 90%;
  width: 900px;
}
@media (max-width: 49.99em) {
  .subscribe-popup {
    margin: auto 0 var(--event-sticky-height) 0;
    position: fixed;
    max-width: 100%;
    max-height: calc(95% - var(--event-sticky-height));
    padding: 0;
  }
}

@media (max-width: 49.99em) {
  .subscribe-popup__inner {
    padding-bottom: var(--event-mobile-sticky-height);
  }
}

.subscribe-popup__header {
  padding: 15px 0;
}
@media (max-width: 49.99em) {
  .subscribe-popup__header {
    padding: 20px;
    border-bottom: 1px solid #F4F4F4;
  }
}

@media (max-width: 49.99em) {
  .subscribe-popup__close {
    display: none !important;
  }
}
@media (min-width: 50em) {
  .subscribe-popup__close {
    position: absolute;
    top: 30px;
    right: 30px;
    background: none;
    border: none;
    cursor: pointer;
    background-color: transparent;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #D5D5D5;
    border-radius: 50%;
    padding: 8px;
  }
  .subscribe-popup__close:hover {
    background-color: #F4F4F4;
  }
}
@media (min-width: 62.5em) {
  .subscribe-popup__close {
    width: 44px;
    height: 44px;
    padding: 12px;
  }
}

.subscribe-popup__title {
  font-size: 14px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  margin: 0;
}
@media (min-width: 50em) {
  .subscribe-popup__title {
    font-size: 18px;
  }
}

.subscribe-item {
  display: flex;
  gap: 30px;
  align-items: center;
}
@media (min-width: 50em) {
  .subscribe-item {
    padding: 20px 30px 20px 15px;
  }
}
@media (max-width: 49.99em) {
  .subscribe-item {
    padding: 20px;
    border-bottom: 1px solid #F4F4F4;
  }
}

.subscribe-item__image {
  width: 160px;
}
@media (max-width: 49.99em) {
  .subscribe-item__image {
    display: none;
  }
}

.subscribe-item__title {
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 3px;
  font-size: 16px;
}
@media (min-width: 50em) {
  .subscribe-item__title {
    font-size: 18px;
  }
}

.subscribe-item__copy {
  font-size: 14px;
  margin: 0;
}
@media (min-width: 50em) {
  .subscribe-item__copy {
    font-size: 20px;
  }
}

.subscribe-item__arrow {
  margin: 0 0 0 auto;
}
.subscribe-item__arrow .o-icon {
  width: 19px;
  height: 19px;
}
@media (min-width: 50em) {
  .subscribe-item__arrow .o-icon {
    width: 36px;
    height: 36px;
  }
}

.price-popup {
  position: relative;
  max-width: 90%;
  width: 900px;
  padding: 20px 30px 30px;
  background-color: #D5D5D5;
}
@media (max-width: 49.99em) {
  .price-popup {
    margin: auto 0 var(--event-sticky-height) 0;
    position: fixed;
    max-width: 100%;
    max-height: calc(100% - var(--event-sticky-height));
    padding: 0;
  }
}

.price-popup__header {
  padding: 15px 0;
}
.price-table + .price-popup__header {
  margin-top: 15px;
}

.price-popup__close {
  position: absolute;
  top: 10px;
  right: 30px;
  background: none;
  border: none;
  cursor: pointer;
  background-color: #F4F4F4;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #D5D5D5;
  border-radius: 50%;
  padding: 8px;
}
.price-popup__close:hover {
  background-color: transparent;
}
@media (max-width: 49.99em) {
  .price-popup__close {
    background-color: transparent;
    width: 20px;
    height: 20px;
    padding: 0;
    top: 15px;
    right: 10px;
  }
  .price-popup__close .o-icon {
    width: 8px !important;
    height: 8px !important;
  }
}
@media (min-width: 62.5em) {
  .price-popup__close {
    width: 44px;
    height: 44px;
    padding: 12px;
  }
}

.price-popup__title {
  font-size: 18px;
  font-family: Faktum Wide, sans-serif;
  font-weight: 600;
  margin-bottom: 0;
}
@media (max-width: 49.99em) {
  .price-popup__title {
    padding-left: 10px;
    padding-right: 10px;
  }
}

.price-table {
  width: 100%;
  border-collapse: collapse;
  display: table;
}

.price-table__header {
  display: table-header-group;
  background-color: #E8E8E8;
}
.price-table__header > *:first-child {
  width: 25%;
}
.price-table__header > * {
  display: table-cell;
  padding: 10px;
  font-weight: 600;
  width: 15%;
}

.price-table__row {
  display: table-row;
  background-color: #DFDFDF;
  border-bottom: 1px solid #D5D5D5;
}
.price-table__row > *:first-child {
  font-weight: 600;
  width: 25%;
}
.price-table__row > * {
  display: table-cell;
  padding: 10px;
  width: 15%;
}

/* ==========================================================================
   Utilities
   ========================================================================== */
/* ==========================================================================
   Utilities: Visibility
   ========================================================================== */
/**
 * JS helpers
 */
.no-js .u-visible-js, .supports-js .u-hidden-js {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.supports-js .u-hidden-js {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

/**
 * Hide from browsers, but not screenreaders
 */
.visually-hidden, .u-visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

/**
 * Hide from both screenreaders and browsers: h5bp.com/u
 */
[hidden], .u-hidden {
  display: none !important;
  visibility: hidden;
}

/**
 * Hide visually and from screenreaders, but maintain layout
 */
.u-invisible {
  visibility: hidden;
}

/**
 * Image Replacement
 */
.u-ir {
  display: block;
  text-indent: -999999px;
  overflow: hidden;
}

/*  ==========================================================================
	Dialog
	========================================================================== */
[data-component*=dialog] * {
  box-sizing: border-box;
  outline-color: var(--theme-color);
}

:where([data-component*=dialog]) {
  width: 100%;
  max-width: 650px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  :where([data-component*=dialog]) {
    padding-left: 15px;
    padding-right: 15px;
  }
}
:where([data-component*=dialog]) {
  padding: 20px;
  border: none;
  border-radius: 15px;
}
@media (min-width: 50em) {
  :where([data-component*=dialog]) {
    padding: 30px;
  }
}
:where([data-component*=dialog])::backdrop {
  background-color: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(30px) brightness(50%) contrast(120%);
}

:where([data-component=no-dialog]:not([hidden])) {
  display: block;
  inset-block-start: 30px;
  inset-inline-start: 50%;
  position: fixed;
  z-index: 999;
  transform: translateX(-50%);
  box-shadow: 0 0 1000px 1000px rgba(0, 0, 0, 0.5);
}

:where([data-component*=dialog] menu) {
  display: flex !important;
  gap: 15px;
  justify-content: flex-end;
  margin: 0;
  padding: 0;
}

:where([data-component*=dialog] [data-ref=fieldset]) {
  border: none;
  margin: unset !important;
  padding: unset !important;
}

:where([data-component*=dialog] [data-ref=message]) {
  font-size: var(--global-body-text-big);
  line-height: 1.5;
  margin-block-end: 20px;
}

:where([data-component*=dialog] [data-ref=template]:not(:empty)) {
  margin-block-end: 20px;
  width: 100%;
}

/* hack for Firefox */
@-moz-document url-prefix() {
  [data-component=no-dialog]:not([hidden]) {
    inset-inline-start: 0;
    transform: none;
  }
}
/* added to `body` when browser do not support `<dialog>` */
.dialog-open {
  background-color: rgba(0, 0, 0, 0.2);
  overflow: hidden;
}

/* ==========================================================================
   Utilities: Layout
   ========================================================================== */
.u-constrained {
  width: 100%;
  max-width: 1640px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .u-constrained {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.u-fullwidth {
  display: block;
  width: 100%;
}

.u-inset {
  padding-top: 16px;
  padding-bottom: 16px;
}

.u-padded {
  padding: 16px;
}

.u-ratio {
  position: relative;
  height: 0;
  /*  Maintain layout, based on 4:3 aspect-ratio */
  padding-bottom: 75%;
}

.u-ratio--5-3 {
  /*  Maintain layout, based on 5:3 aspect-ratio */
  padding-bottom: 60%;
}

.u-ratio--16-9 {
  /*  Maintain layout, based on 5:3 aspect-ratio */
  padding-bottom: 56.25%;
}

.u-ratio--square {
  /*  Maintain layout, based on square aspect-ratio */
  padding-bottom: 100%;
}

.u-button-reset {
  padding: 0;
  border: 0;
  outline: none;
  background: transparent;
}

/* ==========================================================================
   Utilities: Tones
   ========================================================================== */
.u-tone-primary {
  color: #262687;
}

.u-tone-bg-tint {
  color: contrasting(#E7E7E7, , #000);
  background-color: #E7E7E7;
  border-color: currentColor;
}

.u-tone-bg-primary {
  color: contrasting(#262687, , #000);
  background-color: #262687;
  border-color: currentColor;
  color: #fff;
}

.u-tone-bg-dark {
  color: contrasting(#757575, , #000);
  background-color: #757575;
  border-color: currentColor;
  color: #fff;
}

/* ==========================================================================
   Utilities: Text
   ========================================================================== */
.u-font-scale-display-1 {
  font-size: 16px;
}

.u-font-scale-display-2 {
  font-size: 18px;
}

.u-font-scale-display-3 {
  font-size: 20px;
}

.u-font-scale-display-4 {
  font-size: 22px;
}

.u-font-scale-display-5 {
  font-size: 24px;
}

.u-font-scale-display-6 {
  font-size: 26px;
}

.u-font-scale-display-7 {
  font-size: 28px;
}

.u-font-scale-display-8 {
  font-size: 32px;
}

.u-font-scale-display-9 {
  font-size: 38px;
}

.u-font-scale-display-10 {
  font-size: 42px;
}

.u-font-scale-display-11 {
  font-size: 48px;
}

.u-font-scale-display-12 {
  font-size: 56px;
}

.u-font-scale-display-13 {
  font-size: 60px;
}

.u-font-scale-display-14 {
  font-size: 72px;
}

.u-font-scale-display-15 {
  font-size: 90px;
}

.u-font-scale-display-16 {
  font-size: 96px;
}

.u-font-scale-body-1 {
  font-size: 8px;
}

.u-font-scale-body-2 {
  font-size: 10px;
}

.u-font-scale-body-3 {
  font-size: 12px;
}

.u-font-scale-body-4 {
  font-size: 14px;
}

.u-font-scale-body-5 {
  font-size: 16px;
}

.u-font-scale-body-6 {
  font-size: 18px;
}

.u-font-scale-body-7 {
  font-size: 20px;
}

.u-font-scale-body-8 {
  font-size: 22px;
}

.u-font-scale-body-9 {
  font-size: 24px;
}

.u-font-scale-body-10 {
  font-size: 26px;
}

.u-font-scale-body-11 {
  font-size: 28px;
}

.u-font-scale-body-12 {
  font-size: 32px;
}

.u-font-scale-caption-1 {
  font-size: 11px;
}

.u-font-scale-caption-2 {
  font-size: 12px;
}

.u-font-scale-caption-3 {
  font-size: 14px;
}

.u-font-scale-caption-4 {
  font-size: 16px;
}

.u-font-scale-monospace-1 {
  font-size: 14px;
}

.u-font-scale-monospace-2 {
  font-size: 16px;
}

.u-block-link {
  display: block;
  height: 100%;
}

.u-list-unstyled {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* ==========================================================================
   Print (inlined for performance)
   ========================================================================== */
/* ==========================================================================
   Print
   ========================================================================== */
@media print {
  * {
    background: transparent !important;
    color: #000 !important; /* Black prints faster: h5bp.com/s */
    box-shadow: none !important;
    text-shadow: none !important;
  }
  a, a:visited {
    text-decoration: underline;
  }
  a[href]:after {
    content: " (" attr(href) ")";
  }
  abbr[title]:after {
    content: " (" attr(title) ")";
  }
  /*
   * Don't show links for images, or javascript/internal links
   */
  a[href^="javascript:"]:after, a[href^="#"]:after {
    content: "";
  }
  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }
  thead {
    display: table-header-group; /* h5bp.com/t */
  }
  tr, img {
    page-break-inside: avoid;
  }
  img {
    max-width: 100% !important;
  }
  p, h2, h3 {
    orphans: 3;
    widows: 3;
  }
  h2, h3 {
    page-break-after: avoid;
  }
}
/* ------------------------------------*\
    #ANNOTATIONS
\*------------------------------------ */
/**
 * Annotated elements styles
 * 1) Annotation styles that appear inside the iframe
 * 2) For elements in the DOM that have an annotation, we want to
 * provide styles that help the user understand that annotations are available.
 * We do this with some cursor helpers and a
 */
.pl-has-annotation {
  cursor: help !important;
  outline: 1px dotted #808080;
  outline-offset: -4px;
  transition: box-shadow 0.2s ease;
}
.pl-has-annotation a,
.pl-has-annotation input {
  cursor: help !important;
}
.pl-has-annotation:hover {
  box-shadow: 0 0 3px #808080;
}
.pl-has-annotation.active {
  box-shadow: inset 0 0 6px #4d4d4d;
  outline: 1px dotted #808080;
  outline-offset: -1px;
}

/*# sourceMappingURL=style.css.map */
