@charset "UTF-8";
/* Baseplate */
/* ==========================================================================
   Settings & Tools
   ========================================================================== */
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-thin.woff2") format("woff2");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-thin-italic.woff2") format("woff2");
  font-weight: 100;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-light-italic.woff2") format("woff2");
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-regular.woff2") format("woff2");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-medium-italic.woff2") format("woff2");
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-bold-italic.woff2") format("woff2");
  font-weight: 700;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-heavy.woff2") format("woff2");
  font-weight: 800;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-heavy-italic.woff2") format("woff2");
  font-weight: 800;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-black.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk";
  src: url("american-grotesk-black-italic.woff2") format("woff2");
  font-weight: 900;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-thin.woff2") format("woff2");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-thin-italic.woff2") format("woff2");
  font-weight: 100;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-light-italic.woff2") format("woff2");
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-medium-italic.woff2") format("woff2");
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-bold-italic.woff2") format("woff2");
  font-weight: 700;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-heavy.woff2") format("woff2");
  font-weight: 800;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-heavy-italic.woff2") format("woff2");
  font-weight: 800;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-black.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-compressed";
  src: url("american-grotesk-compressed-black-italic.woff2") format("woff2");
  font-weight: 900;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-thin.woff2") format("woff2");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-thin-italic.woff2") format("woff2");
  font-weight: 100;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-light-italic.woff2") format("woff2");
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-medium-italic.woff2") format("woff2");
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-bold-italic.woff2") format("woff2");
  font-weight: 700;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-heavy.woff2") format("woff2");
  font-weight: 800;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-heavy-italic.woff2") format("woff2");
  font-weight: 800;
  font-style: italic;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-black.woff2") format("woff2");
  font-weight: 900;
  font-style: normal;
}
@font-face {
  font-family: "american-grotesk-condensed";
  src: url("american-grotesk-condensed-black-italic.woff2") format("woff2");
  font-weight: 900;
  font-style: italic;
}
/*  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;
}

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

body {
  color: #231F20;
  background-color: #fff;
  overflow-x: hidden;
  /**
   * 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);
  transition: backdrop-filter 0.4s ease background-color 0.4s ease;
  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;
}

.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: 2;
}
@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: 1px solid #fff;
  background-color: #231F20;
  width: 100%;
  height: 100%;
  transition: background-color 0.4s ease;
}

:root {
  --link-color: #231F20;
  --focus-color: #3B004A;
  --theme-color: #3B004A;
  --theme-color-dark: #702157;
  --theme-color-light: #FF97D0;
  --text-color: #231F20;
  --text-color-light: #fff;
  --content-margin: 100px 0;
  --content-margin-big: 160px 0;
  --content-margin-small: 60px 0;
  --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: american-grotesk-compressed, sans-serif;
}

h1, h2 {
  font-weight: 800;
}

.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: american-grotesk, 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: american-grotesk, 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;
}

.nestedListItem {
  list-style: none;
}

.nestedListItem li {
  list-style: circle;
  margin-bottom: 10px;
}

/*  =========================================================================
    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:not([class]) {
  text-decoration: underline;
}
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: american-grotesk, 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: american-grotesk-compressed, sans-serif !important;
  font-size: var(--global-header-size-h1) !important;
}

h2.sg-section__title.sg-heading {
  font-family: american-grotesk-compressed, 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;
  border: none;
}
@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;
}

.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;
  --focus-color: #000;
}
@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-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 {
  background-color: #F0F0F0;
  padding: 30px;
}
#pattern-Modules-EventItem .event-item {
  max-width: 500px;
}

#pattern-Widgets-CalendarList .sg-pattern__content {
  background-color: #F0F0F0;
  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-7);
  --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-8);
    --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-9);
    --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;
}
.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: american-grotesk-compressed, sans-serif;
  font-weight: 900;
  text-transform: uppercase;
}
.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 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: 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;
  font-weight: 700;
}
@keyframes ButtonLine {
  0% {
    background-size: 100% 3px, 0 3px;
  }
  50% {
    background-size: 0 3px, 0 3px;
  }
  100% {
    background-size: 0 3px, 100% 3px;
  }
}
.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):visited:visited,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):hover:visited,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):active:visited {
  color: var(--link-color);
}
.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):focus,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):visited:hover,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):visited:focus,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):hover:hover,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):hover:focus,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):active:hover,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):active:focus {
  animation-name: ButtonLine;
  animation-duration: 0.75s;
}
.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):visited:hover,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):hover:hover,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):active:hover {
  font-weight: 700;
}
.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;
  }
}
@media (min-width: 23em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-7);
    --global-header-size-h2: var(--global-header-size-5);
    --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-1);
  }
}
@media (min-width: 30em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-8);
    --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-4);
    --global-header-size-h5: var(--global-header-size-3);
    --global-header-size-h6: var(--global-header-size-2);
  }
}
@media (min-width: 50em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-10);
    --global-header-size-h2: var(--global-header-size-8);
    --global-header-size-h3: var(--global-header-size-6);
    --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: 72em) {
  .s-prose {
    --global-header-size-h2: var(--global-header-size-9);
    --global-header-size-h3: var(--global-header-size-7);
    --global-header-size-h4: var(--global-header-size-6);
    --global-header-size-h5: var(--global-header-size-5);
    --global-header-size-h6: var(--global-header-size-4);
  }
}

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

.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-5);
  --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 25px;
  --global-button-padding-small: 10px 25px;
  --global-button-padding-big: 15px 60px;
}
@media (min-width: 50em) {
  :root {
    --global-button-size: var(--global-body-size-6);
    --global-button-size-small: var(--global-body-size-5);
    --global-button-size-big: var(--global-body-size-7);
    --global-button-padding: 15px 40px;
    --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: american-grotesk-condensed, sans-serif;
  font-size: var(--global-button-size);
  font-weight: 700;
  text-transform: uppercase;
  margin: 0;
  line-height: 1;
  padding: 15px 40px;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
  color: #fff;
  background-color: #3B004A;
  border: none;
  border-radius: 0;
  isolation: isolate;
  transition: color 0.4s ease, background-color 0.4s ease, border-color 0.4s ease, box-shadow 0.4s ease;
}
.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;
}
.btn:after, :where([data-component*=dialog] menu button):after,
.inline-button:after,
.btn-primary:after,
.step-button-next:after,
.step-button-prev:after,
.userform input[type=button]:after,
.userform input[type=submit]:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--theme-color-dark);
  z-index: -1;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s ease;
}
@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 {
    color: #fff;
    background-color: rgb(119.9932432432, 0, 150.5);
    text-decoration: none;
    outline: none;
  }
  .btn:hover:after, :hover:where([data-component*=dialog] menu button):after,
  .inline-button:hover:after,
  .btn-primary:hover:after,
  .step-button-next:hover:after,
  .step-button-prev:hover:after,
  .userform input[type=button]:hover:after,
  .userform input[type=submit]:hover:after {
    transform: scaleX(100%);
  }
}
.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: 4px double #000;
}

.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;
  opacity: 0.5;
}

.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--black {
  color: #fff;
  background-color: #000;
  box-shadow: inset 0 0 0 2px transparent;
}
.btn--black:after {
  background-color: var(--theme-color-dark);
}
@media (hover: hover) and (pointer: fine) {
  .btn--black:hover {
    color: #fff;
    background-color: #000;
    box-shadow: inset 0 0 0 2px var(--theme-color-dark);
  }
}

.btn--white {
  color: #231F20;
  background-color: #fff;
}
.btn--white:after {
  background-color: var(--theme-color-dark);
}
@media (hover: hover) and (pointer: fine) {
  .btn--white:hover {
    color: #fff;
    background-color: #fff;
  }
}

.btn--disabled {
  color: #231F20;
  background-color: #6A6A6A;
}
.btn--disabled:after {
  background-color: #6A6A6A;
}
@media (hover: hover) and (pointer: fine) {
  .btn--disabled:hover {
    color: #231F20;
    background-color: #6A6A6A;
  }
}
.btn--disabled .loader {
  border: 4px solid #8c8c8c;
  border-radius: 50%;
  border-top: 4px solid #ddd;
  width: 15px;
  height: 15px;
  display: inline-block;
  margin-left: 8px;
  -webkit-animation: spin 2s linear infinite;
  animation: spin 2s linear infinite;
}
@-webkit-keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
  }
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.btn--solid-white {
  color: #231F20;
  background-color: #fff;
}
.btn--solid-white:after {
  background-color: var(--theme-color-dark);
}
@media (hover: hover) and (pointer: fine) {
  .btn--solid-white:hover {
    color: #fff;
    background-color: #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;
  box-shadow: none;
  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: #231F20;
  background-color: transparent;
  box-shadow: inset 0 0 0 2px #231F20;
}
.btn--outline-black:after {
  background-color: #231F20;
}
@media (hover: hover) and (pointer: fine) {
  .btn--outline-black:hover {
    color: #fff;
    background-color: transparent;
  }
}

.btn--outline-white {
  background-color: transparent;
  box-shadow: inset 0 0 0 2px #fff;
}
.btn--outline-white:after {
  background-color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .btn--outline-white:hover {
    color: #231F20;
    background-color: transparent;
  }
}

.btn--loading {
  background-image: linear-gradient(-45deg, #3b004a, #3b004a 25%, rgba(59, 0, 74, 0.8) 25%, rgba(59, 0, 74, 0.8) 50%, #3b004a 50%, #3b004a 75%, rgba(59, 0, 74, 0.8) 75%, rgba(59, 0, 74, 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--themed {
  background-color: transparent;
  color: var(--button-color, #fff);
  transition: color 0.4s ease, border-color 0.4s ease, box-shadow 0.4s ease;
  z-index: 0;
}
.btn--themed:after {
  background-color: var(--highlight-color, #e91f00);
  content: "";
  filter: brightness(100%);
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  transition: filter 0.4s ease;
  width: 100%;
  z-index: -1;
}

.btn--theme-dark {
  background-color: var(--theme-color-dark);
  position: relative;
  isolation: isolate;
}
.btn--theme-dark:after {
  background-color: #000;
}
@media (hover: hover) and (pointer: fine) {
  .btn--theme-dark:hover {
    background-color: var(--theme-color-dark);
    color: #fff;
  }
}

.btn--theme-light {
  background-color: var(--theme-color-light);
}
@media (hover: hover) and (pointer: fine) {
  .btn--theme-light:hover {
    background-color: color-mix(in srgb, var(--theme-color-light) 85%, #fff);
    color: #fff;
  }
}

.btn--theme-dark-outline {
  color: var(--theme-color-dark);
  background-color: transparent;
  box-shadow: inset 0 0 0 2px var(--theme-color-dark);
}
@media (hover: hover) and (pointer: fine) {
  .btn--theme-dark-outline:hover {
    color: #fff;
    background-color: transparent;
  }
}

.btn--theme-light-outline {
  color: var(--theme-color-light);
  background-color: transparent;
  box-shadow: inset 0 0 0 2px var(--theme-color-light);
}
.btn--theme-light-outline:after {
  background-color: var(--theme-color-light);
}
@media (hover: hover) and (pointer: fine) {
  .btn--theme-light-outline:hover {
    color: #231F20;
    background-color: transparent;
  }
}

@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-dark);
  color: #fff;
  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;
}
@media (min-width: 50em) {
  .global-alert__message {
    padding: 0 70px 0 60px;
    text-align: center;
  }
}
.global-alert__message p {
  margin-bottom: 0;
}
.global-alert__message a {
  --focus-color: #fff;
  --link-color: #fff;
  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;
  font-weight: 700;
}
@keyframes ButtonLine {
  0% {
    background-size: 100% 3px, 0 3px;
  }
  50% {
    background-size: 0 3px, 0 3px;
  }
  100% {
    background-size: 0 3px, 100% 3px;
  }
}
.global-alert__message a:visited {
  color: var(--link-color);
}
.global-alert__message a:hover, .global-alert__message a:focus {
  animation-name: ButtonLine;
  animation-duration: 0.75s;
}

.global-alert__close {
  display: flex;
  align-items: center;
  font-family: inherit;
  appearance: none;
  border: 0;
  background: none;
  cursor: pointer;
  padding: 0;
  opacity: 0.8;
  line-height: 9px;
  color: #fff;
  transition: opacity 0.3s ease;
}
.global-alert__close:hover {
  opacity: 1;
}
@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 #fff;
}

/* ==========================================================================
	Global Footer
	========================================================================== */
.global-footer {
  background-color: #231F20;
  color: #fff;
  position: relative;
  padding: 25px 0;
  z-index: 4;
}

.global-footer__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}
@media (min-width: 50em) {
  .global-footer__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 50em) {
  .global-footer__inner {
    flex-direction: row;
    justify-content: space-between;
    gap: 40px;
  }
}

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

.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 #6A6A6A;
}
@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: 51px;
  height: 80px;
  margin-bottom: 15px;
}
@media (hover: hover) and (pointer: fine) {
  .global-footer__logo:hover .o-icon {
    background-color: var(--theme-color-dark);
  }
}
@media (min-width: 32em) {
  .global-footer__logo {
    margin-bottom: 25px;
  }
}
@media (min-width: 50em) {
  .global-footer__logo {
    width: 67px;
    height: 110px;
    margin-bottom: 0;
  }
}

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

.global-footer__social {
  display: flex;
  gap: 30px;
  justify-content: center;
  text-align: center;
  width: 100%;
}
@media (min-width: 50em) {
  .global-footer__social {
    text-align: left;
    width: auto;
  }
}
.global-footer__social:hover .o-icon {
  opacity: 0.4;
}

.social-link .o-icon {
  height: 32px;
  width: 32px;
  transition: opacity 0.4s ease;
}
.social-link:hover .o-icon {
  opacity: 1;
}

@media (max-width: 49.99em) {
  .global-footer__links {
    padding-bottom: 25px;
    margin-bottom: 25px;
    border-bottom: 1px solid #6A6A6A;
    width: 100%;
  }
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5px 15px;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 50em) {
  .footer-links {
    justify-content: flex-start;
  }
}

.footer-links__item {
  display: flex;
}

.footer-links__link {
  --focus-color: #fff;
  --link-color: #fff;
  color: var(--link-color);
  font-size: 14px;
  font-weight: 400;
  text-decoration: none;
  position: relative;
  transition: color 0.4s ease;
}
.footer-links__link:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background-color: var(--link-color, #fff);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  .footer-links__link:hover:before {
    transform: scaleX(100%);
  }
}

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

.footer-newsletter {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
  position: relative;
}
@media (min-width: 32em) {
  .footer-newsletter {
    flex-direction: row;
    gap: 20px;
  }
}
@media (min-width: 50em) {
  .footer-newsletter {
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (min-width: 62.5em) {
  .footer-newsletter {
    flex-direction: row;
    align-items: center;
  }
}

.footer-newsletter__body {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 15px;
  text-align: center;
  text-wrap: pretty;
}
@media (min-width: 32em) {
  .footer-newsletter__body {
    text-align: left;
  }
}
@media (min-width: 50em) {
  .footer-newsletter__body {
    align-items: flex-start;
    text-align: left;
  }
}

.footer-newsletter__title {
  align-items: center;
  display: flex;
  margin-bottom: 0;
}

.footer-newsletter__text {
  font-size: 16px;
  font-weight: 400;
  max-width: 430px;
}
.footer-newsletter__text p {
  margin-bottom: 0;
}

.footer-newsletter__button {
  flex-shrink: 0;
  width: 100%;
}
@media (min-width: 32em) {
  .footer-newsletter__button {
    width: auto;
  }
}

.global-footer__footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 0 25px;
  position: relative;
  width: 100%;
}
@media (min-width: 50em) {
  .global-footer__footer {
    flex-direction: row;
  }
}

.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;
  flex-shrink: 0;
}

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

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

.global-header__logo {
  border: none;
  z-index: 2;
  position: relative;
}
.user-is-tabbing .global-header__logo:focus {
  outline: 2px solid var(--theme-color-dark);
  outline-offset: 2px;
}

.global-header__logo--mobile .o-icon {
  width: 51px;
  height: 80px;
}

.global-header__logo--desktop {
  display: none;
  color: #fff;
  position: absolute;
  top: 0;
  left: 15px;
  transform: translate(-50%, -50%);
}
.global-header__logo--desktop .o-icon {
  width: 31px;
  height: 36px;
}

@media (min-width: 72em) {
  .global-header__logo--desktop {
    display: none;
  }
  .header-scroll .global-header__logo--desktop {
    display: block;
    position: absolute;
    color: #fff;
  }
  .global-header__logo--mobile {
    display: none;
  }
  .header-scroll .global-header__logo {
    display: block;
  }
}
/*  ==========================================================================
    Global Header - Toolbar
    ========================================================================== */
.global-header__toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  position: absolute;
  top: 0;
  right: 0;
  padding: 15px;
  width: 100%;
  z-index: -1;
}

.global-header__tools {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 3;
  transition: opacity 0.4s ease;
}
@media (max-width: 49.99em) {
  .global-header__tools {
    margin-right: 15px;
    border-right: 1px solid rgba(0, 0, 0, 0.4);
  }
  body:not(.nav-open) .global-header__tools {
    opacity: 0;
  }
}

.global-header__button {
  display: flex;
  align-items: center;
  margin-right: 15px;
  color: var(--link-color);
  background-color: transparent;
  padding: 0;
  border: none;
  transition: opacity 0.3s ease;
  cursor: pointer;
}
@media (min-width: 30em) {
  .global-header__button {
    margin-right: 20px;
  }
}
@media (min-width: 80em) {
  .global-header__button {
    margin-right: 25px;
  }
}
.global-header__button .o-icon {
  width: 25px;
  height: 25px;
  margin-right: 5px;
  flex-shrink: 0;
  transition: transform 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .global-header__button:hover .o-icon {
    transform: scale(1.1);
  }
}
body.nav-open .global-header__button {
  --link-color: #231F20;
}

.global-header__button-text {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  text-transform: uppercase;
  font-weight: 700;
  font-size: var(--global-body-size-2);
}

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

@media (min-width: 32em) {
  .global-header__account {
    width: 50px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
  }
}

.global-header__account-menu {
  position: relative;
  transition: opacity 0.3s ease;
  display: none;
}
@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__button--loading {
  cursor: wait;
  opacity: 0.5;
}

.global-header__button--login,
.global-header__button--logged-out {
  display: none;
}

body.user-logged-in .global-header__button--loading {
  display: none;
}
@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;
  }
  body.user-logged-in .global-header__account-menu .account-menu.is-toggled {
    opacity: 1;
    visibility: visible;
  }
  body.user-logged-in:has(.global-header__account-menu .account-menu.is-toggled) .calendar__sidebar {
    z-index: 1;
  }
}

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

@media (max-width: 31.99em) {
  .global-header__button--tickets {
    order: 2;
  }
}
.global-header__button--tickets .o-icon {
  width: 32px;
  height: 32px;
  margin-right: 0;
}

.global-header__button--search {
  background-color: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
}

/* ==========================================================================
    Global Header - Menu Button
    ========================================================================== */
.global-header__menu {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  border: 0;
  width: 32px;
  height: 32px;
  background: none;
  z-index: 3;
  cursor: pointer;
}
@media (min-width: 72em) {
  .global-header__menu {
    display: none;
  }
}
.user-is-tabbing .global-header__menu:focus {
  outline: 2px solid #000;
}

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

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

.global-header__menu.is-toggled .menu-icon__line {
  background-color: #231F20;
}
.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__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;
  }
}
.user-is-tabbing .desktop-navigation a:focus {
  outline: 2px solid var(--theme-color-dark);
  outline-offset: 2px;
}

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

.desktop-navigation__link {
  text-transform: uppercase;
  position: relative;
  font-size: 22px;
  font-weight: 500;
  font-family: american-grotesk-compressed, 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;
    background-color: #231F20;
  }
}

/* ==========================================================================
	   Global Header - Account Menu
	   ========================================================================== */
.account-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  right: -20px;
  top: 40px;
  width: 180px;
  opacity: 0;
  visibility: hidden;
  box-shadow: 2px 2px 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: 72em) {
  .account-menu {
    right: -10px;
  }
}
.account-menu:before {
  content: "";
  position: absolute;
  top: -6px;
  right: 51px;
  width: 12px;
  height: 12px;
  background: #fff;
  transform: rotate(45deg);
  box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.23);
  z-index: -1;
}
@media (min-width: 72em) {
  .account-menu:before {
    right: 36px;
  }
}
@media (min-width: 80em) {
  .account-menu:before {
    right: 46px;
  }
}

.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: #F0F0F0;
}

.account-menu__item--logout {
  padding: 10px 15px;
  background-color: var(--theme-color);
  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 Navigation
	========================================================================== */
.global-navigation {
  position: fixed;
  top: 0;
  right: 0;
  height: 100svh;
  width: 100%;
  z-index: 7;
  background-color: #fff;
  transform: translateX(100%);
  transition: transform 0.5s ease;
  overflow: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.global-navigation::-webkit-scrollbar-thumb, .global-navigation::-webkit-scrollbar, .global-navigation::-webkit-scrollbar-track {
  background-color: transparent;
  display: none;
}
.global-navigation.is-toggled {
  transform: translateX(0);
}
@media (min-width: 42.5em) {
  .global-navigation {
    max-width: 450px;
  }
}
@media (min-width: 72em) {
  .global-navigation {
    display: none;
  }
}

.global-navigation__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding-top: 100px;
}

.global-navigation__search {
  display: flex;
  align-items: center;
  padding: 15px 15px 30px;
}

.global-navigation__search-input {
  color: #231F20;
  background-color: transparent;
  border: 1px solid #231F20;
  border-width: 0 0 1px;
  padding: 10px 0;
  width: 100%;
  transition: border-bottom-color 0.3s ease;
}
.global-navigation__search-input:focus {
  outline: 2px solid var(--theme-color-dark);
  border-bottom-color: #3B004A;
}
.global-navigation__search-input::placeholder {
  color: rgba(35, 31, 32, 0.5);
}

.global-navigation__search-submit {
  color: #231F20;
  background-color: transparent;
  border: none;
  padding: 0;
  margin-top: -5px;
  margin-left: -20px;
}
.global-navigation__search-submit:focus {
  outline: 2px solid var(--theme-color-dark);
}

.global-navigation__footer {
  display: flex;
  gap: 15px;
  background-color: #fff;
  padding: 15px;
  padding-top: 0;
  box-shadow: 0px -7px 20px 20px rgba(255, 255, 255, 0.9);
  z-index: 2;
}
.global-navigation__footer > .btn, .global-navigation__footer > :where([data-component*=dialog] menu button) {
  flex-basis: 100%;
  justify-content: center;
}
.global-navigation__footer .footer__label--logged-in {
  display: none;
}
body.user-logged-in .global-navigation__footer .footer__label--logged-in {
  display: inline;
}
body.user-logged-in .global-navigation__footer .footer__label--logged-out {
  display: none;
}

/*  ==========================================================================
    Global Navigation - Global Nav
    ========================================================================== */
.global-navigation__items {
  flex: 1;
}

.global-nav {
  position: relative;
  height: 100%;
  width: 100%;
  overflow: hidden;
  overflow-y: auto;
}

.global-nav__inner {
  height: 100%;
  width: 100%;
  overflow: visible;
}

.global-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
  height: auto;
  max-height: fit-content;
  position: absolute;
  left: 100%;
  top: 0;
  padding: 5px 15px;
  background-color: #fff;
  transform: translate3d(0, 0, 0);
  transition: transform 0.3s ease;
  z-index: 1;
  -webkit-overflow-scrolling: touch;
}
.global-nav__list:not(.is-active) {
  overflow: initial;
  -webkit-overflow-scrolling: touch;
}
.global-nav__list > ul:first-child {
  height: auto;
  background-color: #fff;
}

.global-nav__account {
  border-top: 1px dashed rgba(255, 255, 255, 0.2);
  padding-top: 25px;
  margin-top: 40px;
}
.global-nav__account .global-nav__link {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.global-nav__account-arrow {
  margin-top: -5px;
}

.global-nav__description {
  font-size: 14px;
  margin-top: 10px;
  padding-right: 40px;
}

.global-nav__item.has-child > ul > .global-nav__item.has-child.global-nav__item--active > ul > li > ul {
  overflow-y: auto;
}

.global-nav__list.global-nav--level-0 {
  left: 0;
}

.global-nav__list.is-active {
  transform: translate3d(-100%, 0, 0);
}

.global-nav__item--active > .global-nav__child {
  z-index: 2;
}

.global-nav__item:not(.global-nav__item--active) ul {
  display: none;
}

.global-nav__item.global-nav__item--active > ul {
  display: block;
}

.global-nav__item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  min-height: 45px;
  border-bottom: 1px solid #231F20;
  padding-bottom: 15px;
  margin-bottom: 15px;
  word-break: break-word;
}

.global-nav__item-arrow {
  color: #231F20;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
@media (min-width: 62.5em) {
  .global-nav__item-arrow {
    width: 40px;
    height: 40px;
  }
}
.global-nav__item-arrow .o-icon {
  width: 24px;
  height: 24px;
}

.global-nav__item--back {
  margin-top: 20px;
  padding-top: 15px;
}

.global-nav__link {
  font-weight: 700;
  font-size: 28px;
  line-height: 1;
  color: #231F20;
  padding-right: 10px;
}
.global-nav__link:visited, .global-nav__link:active {
  color: #231F20;
}

.global-nav__back {
  display: flex;
  gap: 10px;
  align-items: center;
  border: none;
  margin: 0;
  padding: 0;
  background: transparent;
  font-weight: 700;
  font-size: 14px;
  appearance: none;
}
.global-nav__back::-moz-focus-inner {
  border: 0;
  padding: 0;
}
.global-nav__back .o-icon {
  width: 16px;
  height: 16px;
  transform: rotate(180deg);
}

.global-nav--level-1 .global-nav__item,
.global-nav--level-2 .global-nav__item,
.global-nav--level-3 .global-nav__item {
  padding-bottom: 10px;
  margin-bottom: 10px;
}
.global-nav--level-1 .global-nav__link,
.global-nav--level-2 .global-nav__link,
.global-nav--level-3 .global-nav__link {
  font-size: 18px;
}
@media (min-width: 62.5em) {
  .global-nav--level-1 .global-nav__link,
  .global-nav--level-2 .global-nav__link,
  .global-nav--level-3 .global-nav__link {
    font-size: 20px;
  }
}
@media screen and (max-height: 760px) {
  .global-nav--level-1 .global-nav__link,
  .global-nav--level-2 .global-nav__link,
  .global-nav--level-3 .global-nav__link {
    font-size: 18px;
  }
}
.global-nav--level-1 .global-nav__item--section .global-nav__link,
.global-nav--level-2 .global-nav__item--section .global-nav__link,
.global-nav--level-3 .global-nav__item--section .global-nav__link {
  font-size: 24px;
}
.global-nav--level-1 .global-nav__item--section .global-nav__link span,
.global-nav--level-2 .global-nav__item--section .global-nav__link span,
.global-nav--level-3 .global-nav__item--section .global-nav__link span {
  line-height: 1.2;
}
@media screen and (max-height: 760px) {
  .global-nav--level-1 .global-nav__item--section .global-nav__link,
  .global-nav--level-2 .global-nav__item--section .global-nav__link,
  .global-nav--level-3 .global-nav__item--section .global-nav__link {
    font-size: 22px;
  }
}
.global-nav--level-1 .global-nav__item-arrow .o-icon,
.global-nav--level-2 .global-nav__item-arrow .o-icon,
.global-nav--level-3 .global-nav__item-arrow .o-icon {
  width: 20px;
  height: 20px;
}

/*  ==========================================================================
	Global Navigation Overlay
	========================================================================== */
.global-navigation-overlay {
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
  transition: backdrop-filter 0.4s ease background-color 0.4s ease;
  position: fixed;
  opacity: 1;
  height: 100%;
  width: 100%;
  z-index: 6;
  visibility: visible;
  transition: opacity 0.5s ease;
  top: 0;
  left: 0;
}
body:not(.nav-open) .global-navigation-overlay {
  visibility: hidden;
  opacity: 0;
}

/*  ==========================================================================
	Global Navigation
	========================================================================== */
.global-search {
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
  transition: backdrop-filter 0.4s ease background-color 0.4s ease;
  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: american-grotesk, 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-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);
  transition: backdrop-filter 0.4s ease background-color 0.4s ease;
  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;
}

.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=');
  } */
}
@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 .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;
  position: relative;
  right: unset !important;
  top: 1px !important;
  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:after,
.glightbox-modern .gclose:after {
  content: "Close";
  display: flex;
  align-items: center;
  font-size: 16px;
  font-weight: 700;
  color: var(--theme-color-light);
  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);
  transition: backdrop-filter 0.4s ease background-color 0.4s ease;
}

:where(dialog) button[data-dialog-close] {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  gap: 5px;
  font-size: 16px;
  font-weight: 700;
  flex-shrink: 0;
  transition: color 0.4s ease;
  cursor: pointer;
}
:where(dialog) button[data-dialog-close] .o-icon {
  width: 23px;
  height: 23px;
  position: relative;
  top: 1px;
}
@media (min-width: 50em) {
  :where(dialog) button[data-dialog-close] {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  :where(dialog) button[data-dialog-close] {
    font-size: 22px;
  }
}

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

.form-container {
  position: relative;
  margin: var(--content-margin);
}

.form-container__inner {
  padding: 0 30px;
  margin: 0 auto;
}
@media (min-width: 58em) {
  .form-container__inner {
    width: 100%;
    max-width: 1000px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 58em) and (min-width: 50em) {
  .form-container__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.form-container__title {
  font-size: 26px;
  margin-bottom: 20px;
  grid-column: 1/-1;
  padding: 0 30px;
}
@media (min-width: 58em) {
  .form-container__title {
    font-size: 48px;
    margin-bottom: 40px;
    padding: 0;
  }
}

.userform {
  box-sizing: border-box;
}
.userform h1,
.userform h2,
.userform h3,
.userform h4,
.userform h5,
.userform h6 {
  margin: 30px 0;
}
.userform h1:first-child,
.userform h2:first-child,
.userform h3:first-child,
.userform h4:first-child,
.userform h5:first-child,
.userform h6:first-child {
  margin-top: 0;
}
.userform .right-title {
  font-size: 12px;
  margin-top: 10px;
  display: block;
  text-align: right;
  font-weight: 500;
}
.userform input[type=email],
.userform input[type=number],
.userform input[type=text],
.userform input[type=tel],
.userform input[type=url],
.userform input[type=date],
.userform input[type=search],
.userform textarea,
.userform select {
  width: 100%;
  height: 50px;
  padding: 0 15px;
  line-height: 50px;
  height: auto;
  position: relative;
  z-index: 2;
  appearance: none;
}
.userform input[type=email]:focus,
.userform input[type=number]:focus,
.userform input[type=text]:focus,
.userform input[type=tel]:focus,
.userform input[type=url]:focus,
.userform input[type=date]:focus,
.userform input[type=search]:focus,
.userform textarea:focus,
.userform select:focus {
  outline: none;
  border-color: #3B004A;
}
.userform input:-webkit-autofill,
.userform input:-webkit-autofill:hover,
.userform input:-webkit-autofill:focus,
.userform input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset !important;
}
.userform textarea {
  max-width: none;
  height: auto;
}
.userform select {
  background-image: url(images/chevron-down.svg);
  background-size: 20px;
  background-position: center right 20px;
  background-repeat: no-repeat;
  box-shadow: none;
  font-size: var(--global-body-text-small);
}
.userform select:focus {
  border-color: var(--theme-color, );
  outline: none;
  box-shadow: none;
}
.userform label,
.userform label.left {
  display: flex;
  margin: 0 0 5px;
  font-weight: bold;
  font-size: var(--global-body-text);
}
.userform legend,
.userform legend.left {
  display: flex;
  margin: 0 0 10px;
  font-weight: bold;
  font-size: var(--global-body-text);
}
.userform .userformsgroup > legend {
  padding: 0;
  font-size: var(--global-body-text);
  margin: 20px 0 15px;
}
.userform fieldset {
  margin: 0 0 10px;
  padding: 0;
  border: 0;
}
@media (min-width: 50em) {
  .userform fieldset {
    margin-bottom: 20px;
  }
}
.userform .requiredField.optionset legend:after,
.userform .requiredField.userformsoptionset legend:after {
  content: "Required";
  font-weight: normal;
  text-decoration: underline;
  font-size: 10px;
  margin-left: auto;
  padding-left: 5px;
}
.userform .requiredField.optionset label,
.userform .requiredField.userformsoptionset label {
  display: inline-block;
  font-weight: normal;
}
.userform .requiredField.text label:after {
  content: "Required";
  font-weight: normal;
  text-decoration: underline;
  font-size: 10px;
  margin-left: auto;
  padding-left: 5px;
}
@media (min-width: 32em) {
  .userform .requiredField.text label:after {
    margin-top: 5px;
  }
}
.userform .field.CompositeField .middleColumn p:last-child {
  margin-bottom: 0;
}
.userform .field.userformsoptionset label {
  position: relative;
  top: -4px;
  display: inline;
  margin: 0;
  cursor: pointer;
  font-size: var(--global-body-text-small);
  font-weight: normal;
}
.userform .field.userformsoptionset .middleColumn {
  display: flex;
  position: relative;
  width: 100%;
  flex-wrap: wrap;
}
.userform .field.userformsoptionset input[type=radio] {
  background-color: transparent;
  border: 2px solid #000;
  appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 100%;
  display: inline-block;
  margin: -4px 10px 0 0;
  flex-shrink: 0;
}
@media (min-width: 30em) {
  .userform .field.userformsoptionset input[type=radio] {
    margin-top: -3px;
  }
}
@media (min-width: 50em) {
  .userform .field.userformsoptionset input[type=radio] {
    margin-top: -2px;
  }
}
@media (min-width: 72em) {
  .userform .field.userformsoptionset input[type=radio] {
    margin-top: 2px;
  }
}
.userform .field.userformsoptionset input[type=radio]:before {
  background: #000;
  border-radius: 50%;
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate3d(-50%, -50%, 0) scale(0.01);
  transition: transform 0.2s ease-in-out;
  width: 12px;
  height: 12px;
}
.userform .field.userformsoptionset input[type=radio]:checked:before {
  transform: translate3d(-50%, -50%, 0) scale(1);
}
.userform .field.userformsoptionset .odd,
.userform .field.userformsoptionset .even {
  display: flex;
  position: relative;
  flex-basis: 100%;
  margin-bottom: 15px;
}
@media (min-width: 50em) {
  .userform .field.userformsoptionset .odd,
  .userform .field.userformsoptionset .even {
    flex-basis: 50%;
    padding-right: 4em;
  }
}
.userform .field.userformsoptionset input {
  margin: 5px 5px 5px 0;
  position: relative;
  top: -1px;
}
.userform .field.checkboxset {
  margin: 30px 0;
}
.userform .field.checkboxset .middleColumn {
  display: flex;
  position: relative;
  width: 100%;
  flex-wrap: wrap;
}
.userform .field.checkboxset .odd,
.userform .field.checkboxset .even {
  position: relative;
  flex-basis: 100%;
  margin-bottom: 15px;
}
@media (min-width: 50em) {
  .userform .field.checkboxset .odd,
  .userform .field.checkboxset .even {
    flex-basis: 50%;
    padding-right: 4em;
  }
}
.userform .field.checkboxset label {
  font-weight: normal;
  margin-bottom: 0;
  cursor: pointer;
  line-height: 1.5;
}
.userform .field.checkboxset input[type=checkbox] {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.userform .field.text,
.userform .field.dropdown,
.userform .field.textarea {
  position: relative;
}
.userform .error.message {
  display: block;
  font-weight: bold;
  margin: 0 0 10px;
  padding: 5px;
  background-color: var(--theme-color, );
  border: none;
  color: #000;
}
.userform input[type=file]::-webkit-file-upload-button {
  margin-right: 20px;
}
.userform .step-navigation .step-buttons {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: space-between;
  margin-top: 40px;
  padding-top: 20px;
  border-top: 1px solid #231F20;
}
.userform .step-navigation .step-buttons .step-button-next {
  margin-left: auto;
}
.userform .step-navigation .step-buttons .step-button-next,
.userform .step-navigation .step-buttons .step-button-prev {
  padding: var(--global-button-padding-big);
  font-size: var(--global-button-size-big);
}
.userform .step-navigation .step-buttons .Actions {
  margin-top: 0;
}
.userform .userform-progress {
  position: relative;
}
.userform .userform-progress > p {
  text-transform: uppercase;
  font-family: american-grotesk, sans-serif;
  letter-spacing: 2.5px;
  font-size: 10px;
  margin-bottom: 0;
}
@media (min-width: 58em) {
  .userform .userform-progress > p {
    font-size: 12px;
  }
}
.userform .userform-progress .progress {
  display: none;
}
.userform .userform-progress .step-buttons {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  position: absolute;
  top: 60px;
  width: 100%;
}
@media (min-width: 50em) {
  .userform .userform-progress .step-buttons {
    top: 80px;
  }
}
.userform .userform-progress .step-button-wrapper {
  width: 35px;
  height: 35px;
  margin-right: 10px;
  display: block;
}
.userform .userform-progress .step-button-wrapper .step-button-jump {
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0;
  margin: 0 !important;
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  color: #231F20;
  font-weight: bold;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  left: auto !important;
}
.userform .userform-progress .step-button-wrapper .step-button-jump[disabled] {
  opacity: 1;
  cursor: not-allowed;
  color: #231F20;
}
.userform .userform-progress .step-button-wrapper.viewed .step-button-jump {
  background-color: #000;
  border: 1px solid #000;
  color: #fff;
}
.userform .userform-progress .step-button-wrapper.current .step-button-jump {
  background-color: var(--theme-color, );
  border-color: var(--theme-color, );
  color: #231F20;
}
.userform .progress-title {
  font-family: american-grotesk, sans-serif;
  font-size: var(--global-header-size-h4);
  margin: 0 0 100px;
}
.userform .step-navigation .step-button-wrapper {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  display: inline-block;
  background-color: #fff;
  border: none;
  border-radius: var(--global-button-border-radius);
}
.userform .step-navigation .step-button-wrapper, .userform .step-navigation .step-button-wrapper:hover, .userform .step-navigation .step-button-wrapper:focus, .userform .step-navigation .step-button-wrapper:active {
  text-decoration: none;
}
.userform .step-navigation .step-button-wrapper:hover:before, .userform .step-navigation .step-button-wrapper:focus:before {
  width: 100%;
}
.user-is-tabbing .userform .step-navigation .step-button-wrapper:focus {
  outline: 2px solid #000;
}
.userform .step-navigation .step-button-wrapper.Actions input.action {
  padding: var(--global-button-padding-big);
  font-size: var(--global-button-size-big);
}

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: var(--global-input-size);
  font-family: american-grotesk, sans-serif;
}

.userformsstep {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.userformsstep .field {
  width: 100%;
  margin-bottom: 20px;
}
@media (min-width: 50em) {
  .userformsstep .field {
    margin-bottom: 30px;
  }
}
.userformsstep .field.full-width {
  width: 100%;
}
.userformsstep .field.half-width {
  width: 100%;
}
.userformsstep .field.half-width .middleColumn > * {
  flex-basis: 100%;
}
.userformsstep .field.quarter-width {
  width: 48%;
}
.userformsstep .field.quarter-width .middleColumn > * {
  flex-basis: 100%;
}
@media (min-width: 30em) {
  .userformsstep .field.textarea {
    width: 100%;
  }
}
@media (min-width: 50em) {
  .userformsstep .field.half-width {
    width: 48%;
  }
  .userformsstep .field.quarter-width {
    width: 22%;
  }
}

.FormHeading {
  width: 100%;
}

.userformsgroup {
  width: 100%;
  margin-top: 30px;
  margin-bottom: 0;
}
.userformsgroup > .middleColumn {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

h1 + .userformsgroup,
h2 + .userformsgroup,
h3 + .userformsgroup,
h4 + .userformsgroup,
h5 + .userformsgroup,
h6 + .userformsgroup {
  margin-top: 0;
}

/* ==========================================================================
   Animated Checkbox
   ========================================================================== */
@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;
  }
}
.checkbox,
.checkbox-wrapper {
  display: inline-block;
}
.checkbox label,
.checkbox-wrapper label {
  display: inline-block;
  position: relative;
  font-weight: normal;
  padding-left: 33px;
  cursor: pointer;
  font-size: 14px;
}
@media (min-width: 50em) {
  .checkbox label,
  .checkbox-wrapper label {
    font-size: 16px;
  }
}
.checkbox label:before,
.checkbox-wrapper label:before {
  content: "";
  width: 22px;
  height: 22px;
  position: absolute;
  background-color: transparent;
  border: 1px solid var(--theme-color-dark);
  border-radius: 3px;
  left: 0;
  top: 0;
}
@media (min-width: 30em) {
  .checkbox label:before,
  .checkbox-wrapper label:before {
    top: -1px;
  }
}
@media (min-width: 50em) {
  .checkbox label:before,
  .checkbox-wrapper label:before {
    top: 1px;
  }
}
.checkbox label:after,
.checkbox-wrapper 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: 15px;
  width: 7px;
  left: 3px;
  top: 12px;
  position: absolute;
  transition: border-color 0.4s;
}
@media (min-width: 30em) {
  .checkbox label:after,
  .checkbox-wrapper label:after {
    top: 11px;
  }
}
@media (min-width: 50em) {
  .checkbox label:after,
  .checkbox-wrapper label:after {
    top: 13px;
  }
}
.checkbox input,
.checkbox-wrapper input {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.checkbox input:checked + label:before,
.checkbox-wrapper input:checked + label:before {
  background-color: var(--theme-color-dark);
}
.checkbox input:checked + label:after,
.checkbox-wrapper input:checked + label:after {
  animation: checkBig 0.8s;
  border-color: #fff;
}

.field.checkbox label:after {
  top: 10px;
}

.field.checkboxset label:before {
  top: 2px;
}
.field.checkboxset label:after {
  top: 12px;
}

/*  ==========================================================================
	Accessibility Panel
	========================================================================== */
.accessibility-panel {
  position: relative;
  margin: var(--content-margin);
}

@media (min-width: 58em) {
  .accessibility-panel__inner {
    width: 100%;
    max-width: 1000px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (min-width: 58em) and (min-width: 50em) {
  .accessibility-panel__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 72em) {
  .accessibility-panel__inner {
    padding: 0;
  }
}

.accessibility-panel__wrapper {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (min-width: 58em) {
  .accessibility-panel__wrapper {
    flex-direction: row;
    justify-content: space-between;
    gap: 30px;
  }
}
@media (min-width: 62.5em) {
  .accessibility-panel__wrapper {
    gap: 60px;
  }
}
@media (min-width: 72em) {
  .accessibility-panel__wrapper {
    gap: 80px;
  }
}

.accessibility-panel__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 0 15px;
  width: 100%;
}
@media (min-width: 58em) {
  .accessibility-panel__content {
    align-self: center;
    padding: 0;
  }
  .accessibility-panel--has-items .accessibility-panel__content {
    max-width: 430px;
  }
}

.accessibility-panel__title {
  text-transform: uppercase;
  margin-bottom: 25px;
}

.accessibility-panel__info {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 16px;
  font-weight: 700;
  text-decoration: underline;
  margin-top: 20px;
  cursor: pointer;
}
.accessibility-panel__info .o-icon {
  width: 22px;
  height: 22px;
}
@media (min-width: 50em) {
  .accessibility-panel__info {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .accessibility-panel__info {
    font-size: 20px;
    margin-top: 30px;
  }
  .accessibility-panel__info .o-icon {
    width: 25px;
    height: 25px;
  }
}

.accessibility-panel__description {
  font-size: var(--global-body-text);
}
.accessibility-panel__description p:last-child {
  padding-bottom: 0;
}

.accessibility-panel__action {
  margin-top: 20px;
  padding: 0 15px;
}

.accessibility-panel__cta--desktop {
  display: none;
}
@media (min-width: 32em) {
  .accessibility-panel__cta--mobile {
    display: none;
  }
  .accessibility-panel__cta--desktop {
    display: flex;
    margin-top: 30px;
  }
}
@media (min-width: 58em) {
  .accessibility-panel__cta--desktop {
    width: 100%;
  }
}
@media (min-width: 62.5em) {
  .accessibility-panel__cta--desktop {
    margin-top: 40px;
  }
}

.accessibility-panel__heading {
  font-size: 24px;
  text-transform: uppercase;
  margin-bottom: 25px;
  padding-bottom: 5px;
  border-bottom: 1px solid #231F20;
}
@media (min-width: 50em) {
  .accessibility-panel__heading {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .accessibility-panel__heading {
    font-size: 30px;
  }
}

.accessibility-panel__performances {
  background-color: #6A6A6A;
  padding: 25px 15px;
  flex: 1;
}
@media (min-width: 58em) {
  .accessibility-panel__performances {
    padding: 30px;
  }
}
@media (min-width: 62.5em) {
  .accessibility-panel__performances {
    padding: 35px;
  }
}

.accessible-item {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
}
@media (min-width: 23em) {
  .accessible-item {
    flex-direction: row;
    justify-content: space-between;
  }
  .accessible-item .accessible-performances {
    text-align: right;
  }
}
.accessible-item:not(:last-child) {
  margin-bottom: 20px;
  padding-bottom: 20px;
}
.accessible-item:not(:last-child):after {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  background-image: url("icons/performance-info-line.svg");
  background-size: auto 1px;
  background-repeat: repeat-x;
  margin: 0;
  height: 1px;
  width: 100%;
}

.accessible-item__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.accessible-item__title {
  font-family: american-grotesk, sans-serif;
  font-size: 16px;
  font-weight: 700;
}
@media (min-width: 50em) {
  .accessible-item__title {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .accessible-item__title {
    font-size: 20px;
  }
}

.accessible-item__seats {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 15px;
  cursor: pointer;
}
.accessible-item__seats .o-icon {
  width: 21px;
  height: 21px;
}
@media (min-width: 62.5em) {
  .accessible-item__seats .o-icon {
    width: 25px;
    height: 25px;
  }
}

.accessible-item__seats-link {
  font-family: american-grotesk, sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-decoration: underline;
}
@media (min-width: 62.5em) {
  .accessible-item__seats-link {
    font-size: 18px;
  }
}

.accessible-item__seats-text {
  font-family: american-grotesk, sans-serif;
  font-size: 12px;
  font-weight: 700;
  margin-top: 5px;
}
@media (min-width: 62.5em) {
  .accessible-item__seats-text {
    font-size: 14px;
    margin-top: 10px;
  }
}

.accessible-performances {
  font-size: 14px;
  line-height: 1.6786;
}
@media (min-width: 50em) {
  .accessible-performances {
    font-size: 16px;
    line-height: 1.6563;
  }
}
@media (min-width: 62.5em) {
  .accessible-performances {
    font-size: 18px;
    line-height: 1.6389;
  }
}

/*  ==========================================================================
    Accessibility Panel - Info Popup
    ========================================================================== */
.accessibility-info__popup {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 15px;
  background-color: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(8px);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 20;
  transition: all 0.4s ease-in-out;
}
.accessibility-info__popup:not(.is-toggled) {
  opacity: 0;
  visibility: hidden;
}

.accessibility-info-popup {
  max-width: 700px;
}

.accessibility-info-popup__close {
  margin-left: auto;
}

.accessibility-info-popup__inner {
  display: flex;
  flex-direction: column;
  gap: 15px;
  padding: 20px;
  background-color: #fff;
  color: #231F20;
}
@media (min-width: 50em) {
  .accessibility-info-popup__inner {
    padding: 30px;
  }
}

.accessibility-info-popup__header {
  display: flex;
  align-items: center;
  gap: 10px;
}
@media (min-width: 62.5em) {
  .accessibility-info-popup__header {
    gap: 15px;
  }
}

.accessibility-info-popup__title {
  margin-bottom: 0;
  font-size: var(--global-header-size-h5);
}

.accessibility-info-popup__body {
  font-size: var(--global-body-text);
}

.accessibility-info-popup__icon {
  display: flex;
  align-items: center;
}
.accessibility-info-popup__icon .o-icon {
  width: 24px;
  height: 24px;
  color: var(--secondary-theme-color, #231F20);
}
@media (min-width: 50em) {
  .accessibility-info-popup__icon .o-icon {
    width: 27px;
    height: 27px;
  }
}
@media (min-width: 62.5em) {
  .accessibility-info-popup__icon .o-icon {
    width: 30px;
    height: 30px;
  }
}

/*  ==========================================================================
	Accordion Block
	========================================================================== */
.accordion-block {
  position: relative;
  margin: var(--content-margin);
}

.accordion-block__inner {
  width: 100%;
  max-width: 1000px;
  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__header {
  padding-bottom: 20px;
}

.accordion-block__title {
  margin-bottom: 0;
  padding-top: 10px;
  border-top: 1px solid #231F20;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .accordion-block__title {
    padding-top: 15px;
  }
}

.accordion-block__item {
  border-top: 1px solid #C0C0C0;
}
.accordion-block__item:last-child {
  border-bottom: 1px solid #C0C0C0;
}

.accordion-block__item__header {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  gap: 15px;
  cursor: pointer;
  padding: 20px 0;
  transition: transform 0.3s ease;
  list-style: none;
  box-sizing: border-box;
}
@media (min-width: 50em) {
  .accordion-block__item__header {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.accordion-block__item__header::-webkit-details-marker {
  display: none;
}
@media (min-width: 50em) {
  .accordion-block__item__header {
    padding: 25px 0;
  }
}
.accordion-block__item__header .o-icon {
  width: 21px;
  height: 21px;
  margin-left: auto;
  flex-shrink: 0;
  rotate: 90deg;
  color: var(--theme-color-dark);
  transition: rotate 0.4s ease, scale 0.4s ease;
}
@media (min-width: 50em) {
  .accordion-block__item__header .o-icon {
    width: 26px;
    height: 26px;
  }
}
@media (min-width: 62.5em) {
  .accordion-block__item__header .o-icon {
    width: 30px;
    height: 30px;
  }
}
.accordion__item--open .accordion-block__item__header .o-icon {
  rotate: 270deg;
}
.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: american-grotesk, 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: american-grotesk, 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: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 28px;
  text-transform: uppercase;
  text-wrap: pretty;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .accordion-block__name {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .accordion-block__name {
    font-size: 38px;
  }
}

.accordion-block__content {
  box-sizing: border-box;
  padding-bottom: 25px;
}
@media (min-width: 50em) {
  .accordion-block__content {
    padding-bottom: 30px;
  }
}
.accordion-block__content ul:first-child {
  margin-top: 0;
}
.accordion-block__content li:has(ul) {
  list-style: none;
}

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

/*  ==========================================================================
	Membership Levels Block
	========================================================================== */
.membership-levels .accordion-block__inner {
  width: 100%;
  max-width: 820px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .membership-levels .accordion-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.btn.membership-levels__button, .membership-levels__button:where([data-component*=dialog] menu button) {
  margin-bottom: 0;
}

.membership-levels__sticky {
  position: sticky;
  bottom: 0;
  z-index: 2;
  padding: 80px 0 20px;
  margin-bottom: 40px;
  text-align: center;
  background: linear-gradient(to top, #fff 0%, #fff 60%, rgba(255, 255, 255, 0) 100%);
  display: none;
}
.membership-levels__sticky.is-toggled {
  display: block;
}
@media (min-width: 50em) {
  .membership-levels__sticky {
    padding-bottom: 40px;
  }
}

.membership-levels__form {
  width: 100%;
  max-width: 820px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .membership-levels__form {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.membership-levels__field {
  display: inline-flex;
}
.membership-levels__field .currency {
  font-weight: 700;
  font-size: var(--global-body-size-6);
  align-self: center;
}

.membership-levels__value {
  color: #231F20;
  background-color: #fff;
  border: 1px solid #C0C0C0;
  border-right: 0;
  padding: 15px 0 15px 20px;
  margin-left: 10px;
  border-radius: 30px 0 0 30px;
  width: 100%;
  transition: border-color 0.3s ease;
  font-size: var(--global-body-size-5);
  max-width: 200px;
}
.membership-levels__value:focus {
  outline: none;
  border-color: var(--theme-color-dark);
}
.membership-levels__value::placeholder {
  color: #231F20;
  font-size: var(--global-body-size-5);
}
.membership-levels__value::-webkit-outer-spin-button, .membership-levels__value::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.membership-levels__value[type=number] {
  -moz-appearance: textfield;
}

.membership-levels__submit {
  border-radius: 0 30px 30px 0;
  padding-left: 25px;
  padding-right: 40px;
}

.membership-levels__selected-level {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 18px;
}

.membership-levels__next-level .next-level {
  text-decoration: underline;
  font-weight: 700;
  text-transform: capitalize;
}

/* Content Panel */
.content-panel {
  position: relative;
  margin: var(--content-margin);
}
.content-panel:first-child {
  margin-top: 40px;
}
@media (min-width: 58em) {
  .content-panel:first-child {
    margin-top: 60px;
  }
}
.content-panel:last-child:not(.element:last-child) {
  margin-bottom: 0;
  padding-bottom: 0;
}
.content-panel img {
  max-width: 100%;
  height: auto;
  display: block;
}

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

.content-panel__toggle {
  margin: 0;
  display: inline-block;
}
.content-panel__toggle .btn, .content-panel__toggle :where([data-component*=dialog] menu button) {
  text-decoration: none;
  margin-bottom: 0;
}
@keyframes LinkWave {
  50% {
    background-position: -600px 100%;
  }
}
.content-panel__toggle .btn:hover .btn__text:after, .content-panel__toggle :hover:where([data-component*=dialog] menu button) .btn__text:after, .content-panel__toggle .btn:focus .btn__text:after, .content-panel__toggle :focus:where([data-component*=dialog] menu button) .btn__text:after {
  animation: LinkWave 4s cubic-bezier(0, 0.25, 0.5, 1) infinite;
}
.content-panel__toggle .btn__text {
  position: relative;
  display: inline-block;
  overflow: hidden;
  padding: 0 0 6px;
}
.content-panel__toggle .btn__text:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 2000 60' xml:space='preserve'%3E%3Cpath d='M2000 59.5h-802c-31.8 0-61.4-2.4-92.7-4.9C1071.7 51.9 1037 49 997 49c-46.8 0-87.9 3.3-124.1 6.3-28 2.3-52.2 4.2-73.6 4.2H0v-6h799.3c21.2 0 45.2-2 73.1-4.2 36.4-3 77.5-6.3 124.6-6.3 40.3 0 75.1 2.8 108.8 5.6 31.2 2.5 60.6 4.9 92.2 4.9h802v6z' fill='%2316264d'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 600px 18px;
}
.content-panel__toggle .o-icon {
  margin: 0 0 2px 10px;
  width: 16px;
  height: 16px;
}
.content-panel__toggle.is-toggled {
  display: none;
}

.content-panel__more {
  margin-top: 30px;
  display: none;
}
.content-panel__more.is-toggled {
  display: block;
}

/*  ==========================================================================
	Donation Panel
	========================================================================== */
.donation-panel {
  display: flex;
  align-items: center;
  margin: var(--content-margin-small);
  width: 100%;
  max-width: 1360px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .donation-panel {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 58em) {
  .donation-panel {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
.user-is-tabbing .donation-panel label:focus {
  outline-color: #fff;
}

.donation-panel__content {
  display: flex;
  width: 100%;
}

.donation-panel__form {
  margin: 0 auto;
  max-width: 600px;
}

.donation-panel__inner {
  position: relative;
  text-align: center;
}

.donation-panel__title {
  color: #000;
  text-transform: uppercase;
  border-top: 1px solid #000;
  padding-top: 20px;
}

.donation-panel__description {
  font-size: 20px;
  margin: 0 0 20px;
}

.donation-panel__specific-amount {
  display: flex;
  justify-content: center;
}
@media (min-width: 58em) {
  .donation-panel__specific-amount {
    border-bottom: 1px solid #F0F0F0;
  }
}
.donation-panel__specific-amount .btn--text, .donation-panel__specific-amount :where([data-component*=dialog] [data-ref=cancel]) {
  color: #fff;
}

.donation-panel__specific-amount.hidden {
  display: none;
}

.donation-panel__amounts {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 20px;
  justify-content: center;
}

.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-light);
  text-decoration: none;
  color: var(--theme-color-dark);
  transform: scale(1.1);
}
@media (min-width: 50em) {
  .donation-panel__input:checked + .donation-panel__button,
  .donation-panel__button:hover,
  .donation-panel__button:focus {
    transform: scale(1.15);
  }
}

.donation-panel__button {
  align-items: center;
  background-color: #1b1b1b;
  border: 1px solid #fff;
  border-radius: 100%;
  color: #fff;
  cursor: pointer;
  display: flex;
  font-size: 14px;
  font-weight: 700;
  height: 58px;
  justify-content: center;
  margin: 5px;
  padding: 15px;
  transform: scale(1);
  transition: all 0.3s ease-in-out;
  width: 58px;
}
.donation-panel__button:focus-visible {
  outline: none;
  border: none;
}
@media (min-width: 32em) {
  .donation-panel__button {
    font-size: 14px;
    width: 70px;
    height: 70px;
  }
}
@media (min-width: 50em) {
  .donation-panel__button {
    margin: 5px 8px;
  }
}

.donation-amount {
  visibility: hidden;
}

.donation-panel__other-amount.hidden {
  display: none;
}

.donation-panel__other-amount {
  display: flex;
  justify-content: center;
  align-items: center;
}
.donation-panel__other-amount .form-control {
  color: #231F20;
  border: 1px solid;
  background-color: #fff;
  padding: 15px 0 15px 20px;
  margin-left: 10px;
  border-radius: 30px;
  width: 100%;
  transition: border-color 0.3s ease;
  font-size: 16px;
  max-width: 150px;
  font-weight: 700;
  letter-spacing: 1px;
}
.donation-panel__other-amount .form-control:focus {
  outline: 2px solid var(--theme-color-dark);
  outline-offset: 2px;
}
.donation-panel__other-amount .form-control::placeholder {
  color: #231F20;
  font-size: 16px;
}
.donation-panel__other-amount .currency {
  font-weight: bold;
  font-size: 18px;
}

.donation-panel__actions {
  margin-top: 30px;
}
.donation-panel__actions .btn, .donation-panel__actions :where([data-component*=dialog] menu button) {
  background-color: var(--theme-color-dark);
  width: 90%;
}
@media (min-width: 58em) {
  .donation-panel__actions .btn, .donation-panel__actions :where([data-component*=dialog] menu button) {
    width: auto;
  }
}
.user-is-tabbing .donation-panel__actions .btn:focus::after, .user-is-tabbing .donation-panel__actions :focus:where([data-component*=dialog] menu button)::after {
  transform: scaleX(1);
}
.donation-panel__actions .btn:focus ::after, .donation-panel__actions :focus:where([data-component*=dialog] menu button) ::after {
  background-color: black;
}
.donation-panel__actions .btn::after, .donation-panel__actions :where([data-component*=dialog] menu button)::after {
  background-color: #000;
}

.donation-panel__media {
  display: none;
  overflow: hidden;
}
@media (min-width: 58em) {
  .donation-panel__media {
    display: block;
  }
}
@media (min-width: 62.5em) {
  .donation-panel__media {
    margin-bottom: 0;
  }
}

.donation-panel__image {
  height: 100%;
  width: 100%;
  min-height: 500px;
  object-fit: cover;
  clip-path: polygon(5% 0, 100% 0, 100% 100%, 0% 100%);
}

/*  ==========================================================================
	Donation Panel - Image
	========================================================================== */
@media (min-width: 58em) {
  .donation-panel--image .donation-panel__inner {
    text-align: left;
  }
  .donation-panel--image .donation-panel__content {
    width: 55%;
  }
  .donation-panel--image .donation-panel__media {
    width: 45%;
  }
  .donation-panel--image .donation-panel__other-amount,
  .donation-panel--image .donation-panel__specific-amount {
    justify-content: flex-start;
  }
}

/*  ==========================================================================
	Downloads
	========================================================================== */
.downloads {
  position: relative;
  margin: var(--content-margin);
  color: #000;
}
@media (min-width: 50em) {
  .downloads {
    padding-bottom: 40px;
  }
}

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

.downloads__title {
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
  text-transform: uppercase;
  text-align: center;
}
.downloads__title:before, .downloads__title:after {
  position: absolute;
  content: "";
  top: 51%;
  overflow: hidden;
  width: 48%;
  height: 1px;
  background-image: linear-gradient(to right, black 0%, black 100%);
  background-size: auto 1px;
  background-repeat: repeat-x;
  margin-left: 3%;
}
.downloads__title:before {
  margin-left: -51%;
}

.downloads__list {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
}
@media (min-width: 50em) {
  .downloads__list {
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 40px;
  }
}

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

.downloads__link {
  display: flex;
  align-items: center;
  text-align: left;
  width: 100%;
  border: 2px solid #000;
  padding: 10px;
  transition: 0.2s ease box-shadoww;
}
@media (min-width: 50em) {
  .downloads__link {
    padding: 15px;
  }
}
.downloads__link:hover {
  border: 2px solid var(--theme-color-dark, #000);
  box-shadow: 1px 1px 1px var(--theme-color-dark, #000);
}

.downloads__icon {
  position: relative;
  margin-right: 10px;
}
.downloads__icon .o-icon {
  width: 24px;
  height: 24px;
}
@media (min-width: 50em) {
  .downloads__icon .o-icon {
    width: 30px;
    height: 30px;
  }
}

.downloads__details {
  display: inline;
  font-family: american-grotesk, sans-serif;
  font-weight: normal;
  margin-bottom: 0;
  vertical-align: bottom;
}

.downloads__name {
  font-size: 16px;
  display: inline;
  padding-bottom: 2px;
}
@media (min-width: 23em) {
  .downloads__name {
    font-size: 18px;
  }
}
@media (min-width: 50em) {
  .downloads__name {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .downloads__name {
    font-size: 24px;
  }
}

.downloads__meta {
  font-size: 12px;
  margin-left: auto;
}
@media (min-width: 32em) {
  .downloads__meta {
    font-size: 14px;
  }
}
@media (min-width: 58em) {
  .downloads__meta {
    font-size: 16px;
  }
}

/*  ==========================================================================
	Feature Item
	========================================================================== */
.feature-item {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
@media (min-width: 50em) {
  .feature-item {
    gap: 30px 0;
  }
}
@media (min-width: 62.5em) {
  .feature-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0 30px;
  }
}
@media (min-width: 50em) {
  .feature-item:hover .feature-item__details, .feature-item:focus .feature-item__details {
    border-top: 1px solid var(--theme-color-dark);
    color: var(--theme-color-dark);
  }
  .feature-item:hover .feature-item__cta, .feature-item:focus .feature-item__cta {
    color: var(--theme-color-dark);
  }
}

.feature-item__media {
  overflow: hidden;
  width: 100%;
}
@media (min-width: 62.5em) {
  .feature-item__media {
    width: 50%;
    margin-bottom: 0;
    flex-grow: 1;
  }
}

.feature-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 60%;
  height: 0;
  clip-path: polygon(0 0, 100% 1%, 100% 92%, 0% 100%);
}
@media (min-width: 62.5em) {
  .feature-item__intrinsic-ratio {
    clip-path: none;
    padding-bottom: 75%;
  }
}

.feature-item__image {
  height: auto;
  position: absolute;
  right: 0;
  transform: scale(1);
  transition: transform 0.4s ease;
  width: 100%;
  z-index: 2;
}
@media (min-width: 62.5em) {
  .feature-item__image {
    clip-path: polygon(0 0, 95% 0, 100% 100%, 0% 100%);
  }
}

.feature-item__details,
.feature-item__cta {
  transition: color 0.2s ease-in-out;
}

.feature-item__details {
  display: flex;
  flex-direction: column;
  gap: 15px;
  border-top: 1px solid #000;
  padding-top: 15px;
  margin: 0 auto;
}
@media (min-width: 50em) {
  .feature-item__details {
    padding-top: 30px;
  }
}
@media (min-width: 62.5em) {
  .feature-item__details {
    margin: 0;
    gap: 20px;
    width: 50%;
    max-width: 500px;
  }
}

.feature-item__prefix {
  display: block;
  font-size: 1rem;
  font-weight: 900;
  margin-bottom: 5px;
}
@media (min-width: 50em) {
  .feature-item__prefix {
    font-size: 22px;
  }
}

.feature-item__title {
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 23em) {
  .feature-item__title {
    font-size: 32px;
    font-weight: 900;
  }
}
@media (min-width: 50em) {
  .feature-item__title {
    font-size: 38px;
  }
}
@media (min-width: 62.5em) {
  .feature-item__title {
    font-size: 56px;
  }
}

.feature-item__description {
  margin-bottom: 0;
  font-size: 20px;
}
.feature-item__description p {
  margin-bottom: 0;
}

.feature-item__cta {
  cursor: pointer;
  background: none;
  display: flex;
  gap: 5px;
  justify-content: center;
  align-items: center;
  color: var(--theme-color-dark);
  border: none;
  font-size: 16px;
  font-weight: 700;
  padding: 10px 0;
  align-self: flex-start;
}
.feature-item__cta .o-icon {
  width: 27px;
  height: 27px;
}
@media (min-width: 50em) {
  .feature-item__cta .o-icon {
    width: 30px;
    height: 30px;
  }
}
@media (min-width: 50em) {
  .feature-item__cta {
    font-size: 22px;
    color: #000;
  }
}

/*  ==========================================================================
	Feature item
	========================================================================== */
.feature-group {
  position: relative;
  background-size: cover;
  margin: var(--content-margin);
}
.feature-group .feature-item {
  width: 100%;
  flex-direction: column;
}
@media (min-width: 50em) {
  .feature-group .feature-item {
    width: 50%;
    justify-content: unset;
    gap: 30px 0;
  }
  .feature-group .feature-item:hover .feature-item__details, .feature-group .feature-item:focus .feature-item__details {
    border-top: 1px solid var(--theme-color-dark);
    color: var(--theme-color-dark);
  }
  .feature-group .feature-item:hover .feature-item__cta, .feature-group .feature-item:focus .feature-item__cta {
    color: #000;
  }
}
@media (min-width: 50em) and (min-width: 62.5em) {
  .feature-group .feature-item:hover .feature-item__cta, .feature-group .feature-item:focus .feature-item__cta {
    color: var(--theme-color-dark);
  }
}
.feature-group .feature-item__media {
  width: 100%;
  flex-grow: 0;
}
.feature-group .feature-item__intrinsic-ratio {
  clip-path: polygon(0 0, 100% 1%, 100% 92%, 0% 100%);
}
.feature-group .feature-item__image {
  clip-path: none;
}
.feature-group .feature-item__details {
  width: 100%;
  max-width: unset;
}

.feature-group__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  position: relative;
  gap: 40px;
}
@media (min-width: 50em) {
  .feature-group__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 50em) {
  .feature-group__inner {
    flex-direction: row;
  }
}

/*  ==========================================================================
	Feature Panel
	========================================================================== */
.feature-panel {
  position: relative;
  margin: var(--content-margin-small);
}

.feature-panel__inner {
  position: relative;
  width: 100%;
  max-width: 1280px;
  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 - Right Aligned Image
	========================================================================== */
@media (min-width: 62.5em) {
  .feature-panel--right .feature-item__intrinsic-ratio:after {
    transform: rotate(-6deg);
  }
}
.feature-panel--right .feature-item__image {
  clip-path: none;
}
@media (min-width: 62.5em) {
  .feature-panel--right .feature-item__image {
    clip-path: polygon(8% 0, 100% 0, 100% 100%, 5% 100%);
  }
}

.content-block .feature-panel:first-child .feature-item {
  padding-top: 60px;
}
@media (min-width: 62.5em) {
  .content-block .feature-panel:first-child .feature-item {
    padding-top: 80px;
  }
}

/* Remove padding on feature panels that immediately follow a content-block */
.content-panel + .feature-panel .feature-item {
  padding: 0;
}

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

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

.image-gallery__header {
  position: relative;
  display: flex;
  justify-content: space-between;
  margin-bottom: 25px;
}

.image-gallery__title {
  margin-bottom: 0;
  padding-right: 150px;
  text-transform: uppercase;
  color: #fff;
  width: 100%;
}

.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;
  transition: background-color 0.4s ease;
  background-color: var(--theme-color-light);
}
@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: var(--theme-color-dark);
  transition: color 0.4s ease;
}
.image-gallery__button:not(.swiper-button-disabled):hover {
  background-color: color-mix(in srgb, var(--theme-color-light) 60%, #fff);
}

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

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

.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 {
  height: var(--image-height);
  width: auto;
  flex-shrink: 0;
  margin-right: 30px;
}
.image-gallery__slide.swiper-slide:last-child {
  margin-right: 0;
}

.image-gallery__zoom {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  position: absolute;
  top: 5px;
  right: 15px;
  z-index: 3;
}
@media (min-width: 50em) {
  .image-gallery__zoom {
    top: unset;
    bottom: 0;
  }
}

.image-gallery__info {
  margin-bottom: 0;
  padding-right: 20px;
  display: none;
  font-family: american-grotesk, sans-serif;
  font-weight: 700;
  font-size: var(--global-body-size-7);
}
@media (min-width: 32em) {
  .image-gallery__info {
    display: block;
  }
}

.image-gallery__fullscreen {
  font-size: 14px;
  font-weight: 700;
  background: none;
  padding: 0;
  margin: 0;
  border: 0;
  color: var(--theme-color-light);
  cursor: pointer;
  transition: color 0.4s ease;
}
.image-gallery__fullscreen .open,
.image-gallery__fullscreen .close {
  align-items: center;
  gap: 10px;
}
.image-gallery__fullscreen .open {
  display: flex;
  flex-direction: row-reverse;
}
.image-gallery__fullscreen .open .o-icon {
  transition: scale 0.4s ease;
}
.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;
    font-size: 22px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .image-gallery__fullscreen:hover {
    color: #fff;
  }
  .image-gallery__fullscreen:hover .open .o-icon {
    scale: 1.1;
  }
}

.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: american-grotesk, sans-serif;
  margin-bottom: 0;
}

.image-gallery__length {
  font-weight: 700;
}

.image-gallery__details {
  display: none;
}

.gallery-slide__caption {
  font-size: var(--global-caption);
}

.gallery-slide__credit {
  display: block;
  margin-top: 15px;
  font-size: 16px;
}

@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 {
  position: relative;
  box-sizing: border-box;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .gallery-slide__inner {
    height: var(--image-height);
  }
}

.gallery-slide__media {
  position: relative;
  aspect-ratio: 16/9;
}
.gallery-slide__media.gallery-slide__media--portrait {
  aspect-ratio: 11/7;
}

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

.gallery-slide__content {
  display: none;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.75);
  color: #fff;
  padding: 20px;
  width: 100%;
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .gallery-slide__content {
    display: block;
    opacity: 0;
    transition: opacity 0.5s ease;
  }
  .image-gallery__slide:hover .gallery-slide__content {
    opacity: 1;
  }
}

.image-gallery--fullscreen .image-gallery__fullscreen {
  opacity: 1;
}
@media (min-width: 58em) {
  .image-gallery--fullscreen .image-gallery__fullscreen {
    margin: 15px;
    right: 0;
  }
}
.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 {
  display: none;
  position: absolute;
  margin-bottom: 0;
}
@media (min-width: 62.5em) {
  .image-gallery--fullscreen .image-gallery__header {
    display: block;
  }
}
.image-gallery--fullscreen .image-gallery__container {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 9999;
  background-color: #231F20;
  width: 100%;
  max-width: none;
  padding: 0;
}
@media (min-width: 58em) {
  .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: #231F20;
}
@media (min-width: 58em) {
  .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;
}
@media (min-width: 50em) {
  .image-gallery--fullscreen .image-gallery__slide .gallery-slide__inner {
    height: unset;
  }
}
.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;
}
@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: #231F20;
  color: #fff;
  font-size: var(--global-body-size-5);
  margin-top: 0;
  padding: 15px;
}
@media (min-width: 58em) {
  .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: 58em) {
  .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;
}
@media (min-width: 42.5em) {
  .image-gallery--fullscreen .image-gallery__slides.swiper-wrapper {
    max-height: 80svh;
  }
}
@media (min-width: 58em) {
  .image-gallery--fullscreen .image-gallery__slides.swiper-wrapper {
    max-height: unset;
  }
}
.image-gallery--fullscreen .image-gallery__slide.swiper-slide {
  height: auto;
  width: 100%;
}
.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: 53svh;
}
@media (min-width: 24.375em) {
  .image-gallery--fullscreen .gallery-slide__media--portrait .gallery-slide__image {
    max-height: 60svh;
  }
}
@media (min-width: 58em) {
  .image-gallery--fullscreen .gallery-slide__media--portrait .gallery-slide__image {
    width: auto;
    height: calc(100svh - 30px);
    max-height: none;
  }
}

@media (max-width: 49.99em) {
  .image-gallery__body.image-gallery__body--show .image-gallery__slide.swiper-slide {
    height: auto;
    flex-shrink: 1;
  }
}
@media (max-width: 49.99em) {
  .image-gallery__body.image-gallery__body--show .gallery-slide__content {
    position: relative;
    padding: 20px 0;
    display: block;
    background-color: transparent;
  }
}
@media (max-width: 49.99em) {
  .image-gallery--fullscreen .image-gallery__body.image-gallery__body--show .image-gallery__slide.swiper-slide {
    flex-shrink: 0;
  }
}
@media (max-width: 49.99em) {
  .image-gallery--fullscreen .image-gallery__body.image-gallery__body--show .gallery-slide__content {
    display: none;
  }
}

/*  ==========================================================================
	People Panel
	========================================================================== */
.people-panel {
  display: flex;
  flex-direction: column;
  gap: 40px;
  position: relative;
  margin: var(--content-margin);
  padding: 40px 0;
}
.people-panel:first-child {
  margin-top: 40px;
  padding-top: 0;
}
@media (min-width: 50em) {
  .people-panel:first-child {
    margin-top: 80px;
  }
}
@media (min-width: 50em) {
  .people-panel {
    padding: 60px 0;
    gap: 60px;
  }
}

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

.people-panel__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 0;
}
@media (min-width: 50em) {
  .people-panel__inner {
    gap: 40px;
  }
}
@media (min-width: 72em) {
  .people-panel__inner {
    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) {
  .people-panel__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.people-panel__header {
  padding: 0 15px;
}
@media (min-width: 72em) {
  .people-panel__header {
    padding: 0;
  }
}

.people-panel__title {
  margin-bottom: 0;
  padding-top: 10px;
  border-top: 1px solid #231F20;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .people-panel__title {
    padding-top: 15px;
  }
}

.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 (max-width: 29.99em) {
  .people-panel__primary .people-panel__list {
    display: flex;
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
  }
  .people-panel__primary .people-panel__list .person {
    width: calc(50% - 30px);
  }
}
@media (min-width: 42.5em) {
  .people-panel__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 62.5em) {
  .people-panel__list {
    grid-template-columns: repeat(4, 1fr);
    gap: 60px 40px;
  }
}
@media (min-width: 72em) {
  .people-panel__list {
    padding: 0;
  }
}

.person {
  margin: 0;
  border: 0;
  padding: 0;
  flex-shrink: 0;
  background: none;
  width: 100%;
}

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

.person__media {
  position: relative;
  padding-bottom: 125%;
  height: 0;
  width: 100%;
  overflow: hidden;
  margin-bottom: 20px;
}

.person__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: filter 0.4s ease, clip-path 0.4s ease;
  z-index: 1;
}
.person:not(.person--bio) .person__image {
  filter: grayscale(1);
  clip-path: polygon(5% 0%, 100% 0%, 95% 100%, 0% 100%);
}
@media (hover: hover) and (pointer: fine) {
  .person__image {
    filter: grayscale(1);
    clip-path: polygon(5% 0%, 100% 0%, 95% 100%, 0% 100%);
  }
  .person--bio:hover .person__image {
    filter: grayscale(0);
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  }
}

.person__media .o-icon {
  color: #231F20;
  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;
}
.person--bio .person__details {
  color: var(--theme-color-dark);
}

@media (hover: hover) and (pointer: fine) {
  .person--bio .person__details {
    color: #231F20;
  }
  .person--bio:hover .person__details {
    color: var(--theme-color-dark);
  }
}
.person__name {
  display: inline;
  font-family: american-grotesk, sans-serif;
  line-height: 1.2;
  font-size: 18px;
}
@media (min-width: 50em) {
  .person__name {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .person__name {
    font-size: 24px;
  }
}

.person__role {
  margin-top: 7px;
  font-size: 16px;
}
@media (min-width: 50em) {
  .person__role {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .person__role {
    font-size: 20px;
  }
}

/* ==========================================================================
	People Panel - 1 & 2 People
	========================================================================== */
@media (min-width: 50em) {
  .people-panel--1:not(.people-panel--left).people-panel__primary .people-panel__inner,
  .people-panel--2:not(.people-panel--left).people-panel__primary .people-panel__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 20px;
  }
  .people-panel--1:not(.people-panel--left).people-panel__primary .people-panel__list,
  .people-panel--2:not(.people-panel--left).people-panel__primary .people-panel__list {
    display: flex;
  }
  .people-panel--1:not(.people-panel--left).people-panel__primary .person,
  .people-panel--2:not(.people-panel--left).people-panel__primary .person {
    max-width: 280px;
    flex-shrink: 1;
  }
}
@media (min-width: 72em) {
  .people-panel--1:not(.people-panel--left).people-panel__primary .people-panel__inner,
  .people-panel--2:not(.people-panel--left).people-panel__primary .people-panel__inner {
    gap: 0 60px;
  }
}

/*  ==========================================================================
	People Panel - Secondary
	========================================================================== */
.people-panel__secondary .people-panel__list {
  gap: 25px 20px;
}
.people-panel__secondary .person__details {
  padding-top: 10px;
  border-top: 2px solid #F0F0F0;
  color: #231F20;
  transition: color 0.4s ease, border-color 0.4s ease;
}
.people-panel__secondary .person--bio .person__details {
  border-color: var(--theme-color-dark);
}
@media (min-width: 42.5em) {
  .people-panel__secondary .people-panel__list {
    gap: 40px;
  }
  .people-panel__secondary .person__details {
    padding-top: 15px;
    border-top: 1px solid;
  }
}
@media (hover: hover) and (pointer: fine) {
  .people-panel__secondary .person--bio .person__details {
    border-color: #231F20;
  }
  .people-panel__secondary .person--bio:hover .person__details {
    border-color: var(--theme-color-dark);
  }
}

/* ==========================================================================
	People Panel - People Popup
	========================================================================== */
.people-popup {
  --link-color: #fff;
  --focus-color: #fff;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: 100svh;
  height: 100svh;
  background-color: #231F20;
  color: #fff;
  overflow-y: auto;
  z-index: 20;
  text-align: left;
  border: none;
  margin: 0;
  padding: 0;
}

.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;
  }
}
@media (min-width: 50em) {
  .people-popup__inner {
    padding-top: 120px;
  }
}

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

.people-popup__close {
  position: fixed;
  top: 15px;
  right: 10px;
  padding: 5px;
  margin: 0;
  border: 0;
  color: #fff;
  background-color: #231F20;
  border-radius: 5px;
  z-index: 3;
}
@media (min-width: 50em) {
  .people-popup__close {
    color: var(--theme-color-light);
    position: static;
  }
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .people-popup__close:hover {
    color: #fff;
  }
}

@media (min-width: 50em) {
  .people-popup__body {
    display: flex;
    justify-content: space-between;
    gap: 100px;
  }
}

.people-popup__details {
  margin-bottom: 30px;
  text-align: left;
}
@media (min-width: 50em) {
  .people-popup__details {
    width: 30%;
    text-align: center;
  }
}

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

.people-popup__name {
  font-family: american-grotesk, sans-serif;
  font-weight: 700;
  font-size: 32px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .people-popup__name {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .people-popup__name {
    font-size: 48px;
  }
}

.people-popup__role {
  font-family: american-grotesk, sans-serif;
  font-weight: 700;
  font-size: 24px;
  color: #C0C0C0;
}
@media (min-width: 50em) {
  .people-popup__role {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .people-popup__role {
    font-size: 32px;
  }
}

.people-popup__previously {
  padding-top: 30px;
  padding-bottom: 40px;
  margin-top: 30px;
  margin-bottom: 0;
  border-top: 1px solid #6A6A6A;
  font-size: var(--global-body-text);
}
.people-popup__previously a {
  color: var(--theme-color-light);
  text-decoration: underline;
  font-style: italic;
}

.people-popup__sticky.people-popup__sticky--image .people-popup__meta {
  margin-left: 20px;
}
@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%;
  margin-bottom: 40px;
}
.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: 125%;
  height: 0;
  overflow: hidden;
}

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

@media (min-width: 50em) {
  .people-popup__information {
    width: 60%;
  }
}

.people-popup__meta {
  margin-bottom: 30px;
}

.people-popup__button {
  position: sticky;
  bottom: 0;
  padding: 20px 0;
}
@media (min-width: 50em) {
  .people-popup__button {
    margin-top: 30px;
    text-align: right;
  }
}

.people-popup__link {
  width: 100%;
  background-color: var(--secondary-theme-color);
  color: var(--secondary-text-color);
}
@media (hover: hover) and (pointer: fine) {
  .people-popup__link:hover {
    background-color: color-mix(in srgb, var(--secondary-theme-color) 85%, #fff);
    color: var(--secondary-text-color);
  }
}
@media (min-width: 32em) {
  .people-popup__link {
    width: auto;
  }
}

/*  ==========================================================================
	Pull Quote    N.B add a class of center if you need centered text!
	========================================================================== */
.pull-quote {
  position: relative;
  margin: var(--content-margin);
  padding-left: 15px;
  padding-right: 15px;
  color: #000;
  width: 100%;
  max-width: 1120px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .pull-quote {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 72em) {
  .pull-quote {
    padding-left: 0;
    padding-right: 0;
  }
}

.pull-quote__inner {
  border-bottom: 1px solid #000;
  border-top: 1px solid #000;
  padding-bottom: 40px;
  padding-top: 30px;
}
@media (min-width: 50em) {
  .pull-quote__inner {
    padding-top: 40px;
  }
}

.quote {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.quote__description {
  margin-inline-start: 40px;
  margin-inline-end: 40px;
  width: 100%;
}

.quote__text {
  position: relative;
  font-size: 28px;
  font-family: american-grotesk, sans-serif;
  font-weight: bold;
  line-height: 1.4;
  margin: 0 auto;
  text-align: center;
  padding-bottom: 0;
}
.quote__text p {
  margin-bottom: 15px;
}
.quote__text p:first-child:before {
  content: "“";
}
@media (min-width: 50em) {
  .quote__text p:first-child:before {
    margin-left: -0.95rem;
  }
}
.quote__text p:last-child:after {
  content: "”";
}
@media (min-width: 30em) {
  .quote__text {
    font-size: 26px;
  }
}
@media (min-width: 50em) {
  .quote__text {
    font-size: 28px;
  }
}
@media (min-width: 72em) {
  .quote__text {
    font-size: 38px;
  }
}

.quote__meta {
  color: var(--theme-color-dark);
  margin-inline-start: 40px;
  margin-inline-end: 40px;
  width: 100%;
  max-width: 720px;
  font-size: var(--global-body-size-3);
  text-align: center;
  line-height: 2;
  margin-bottom: 20px;
}
@media (min-width: 50em) {
  .quote__meta {
    font-size: var(--global-body-size-5);
    margin-bottom: 30px;
  }
}

.quote__link {
  display: block;
  color: var(--theme-color-dark);
  font-family: american-grotesk, sans-serif;
  font-size: 20px;
  font-weight: 400;
  text-decoration: none;
  text-align: center;
}
@media (min-width: 50em) {
  .quote__link {
    font-size: 24px;
  }
}
.quote__link:hover, .quote__link:focus {
  color: #000;
}

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

/*  ==========================================================================
	Review
	========================================================================== */
.review-block {
  position: relative;
  margin: var(--content-margin);
  overflow: hidden;
  width: 100%;
  max-width: 1120px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .review-block {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.review-block__inner {
  border-top: 1px solid #000;
}

.review-block__list {
  position: relative;
  height: auto;
  width: 100%;
  display: flex;
  transition-property: transform;
}

.review {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 30px;
  padding: 30px 0;
  position: relative;
  z-index: 2;
  min-height: 250px;
  flex-shrink: 0;
  background-color: #fff;
  width: 100%;
}
@media (min-width: 50em) {
  .review {
    padding: 30px 20px;
  }
}

.review__rating {
  display: inline-flex;
  color: var(--theme-color-dark);
  text-align: center;
  --icon-size: 48px;
}
.review__rating .o-icon {
  width: var(--icon-size);
  height: var(--icon-size);
  display: inline-block;
}
@media (min-width: 50em) {
  .review__rating .o-icon {
    width: 64px;
    height: 64px;
  }
}

.review-block.review-block--rating .review__rating .o-icon {
  width: 100%;
}

.review__description {
  max-width: 860px;
  width: 100%;
}

.review__quote {
  color: #000;
  font-family: american-grotesk, sans-serif;
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
  margin: 0 auto;
  padding-bottom: 0;
  position: relative;
  text-align: center;
}
@media (min-width: 50em) {
  .review__quote {
    font-size: 38px;
  }
}
.review__quote p {
  margin-bottom: 0;
}
.review__quote p:first-child:before {
  content: "“";
}
@media (min-width: 50em) {
  .review__quote p:first-child:before {
    margin-left: -0.95rem;
  }
}
.review__quote p:last-child:after {
  content: "”";
}
@media (min-width: 30em) {
  .review__quote {
    font-size: var(--global-header-size-6);
  }
}
@media (min-width: 50em) {
  .review__quote {
    font-size: var(--global-header-size-7);
  }
}
@media (min-width: 72em) {
  .review__quote {
    font-size: var(--global-header-size-9);
  }
}

.review__meta {
  border-top: 1px solid #fff;
  font-size: 0.875rem;
  line-height: 1.2;
  max-width: 860px;
  padding-top: 10px;
  text-align: center;
  width: 100%;
}
@media (min-width: 50em) {
  .review__meta {
    font-size: var(--global-body-size-5);
  }
}

.review__link {
  display: block;
}
.review__link:hover, .review__link:focus {
  color: var(--theme-color);
}

.review__cite {
  font-style: normal;
}

.review__publisher {
  font-style: italic;
}

.review__cite,
.review__publisher {
  color: var(--theme-color-dark);
  display: inline-block;
  font-family: american-grotesk, sans-serif;
  text-decoration: none;
  font-size: 20px;
}
@media (min-width: 50em) {
  .review__cite,
  .review__publisher {
    font-size: 24px;
  }
}

.review.center .review__text,
.review.center .review__meta {
  text-align: center;
}

.review__stop-autoplay {
  cursor: pointer;
  display: flex;
  justify-self: flex-end;
  background: none;
  border: none;
  padding: 0;
}
.review__stop-autoplay .o-icon {
  color: var(--theme-color-dark);
}
.review__stop-autoplay .o-icon:hover {
  color: #000;
}

.review__play-title {
  display: none;
}

.review-block .swiper-pagination-bullets {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
}
.review-block .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  border-radius: 100%;
  background-color: var(--theme-color-dark);
  opacity: 0.2;
  cursor: pointer;
  border: none;
  margin: 0;
}
.review-block .swiper-pagination-bullet-active {
  opacity: 1;
}

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}
.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}
.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

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

/*  ==========================================================================
	Sponsors
	========================================================================== */
.company-block {
  position: relative;
  margin: var(--content-margin);
}

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

.company-block__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 50em) {
  .company-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 58em) {
  .company-block__inner {
    gap: 60px;
  }
}

.company-block__group {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
}
@media (min-width: 58em) {
  .company-block__group {
    grid-template-columns: 1fr auto;
  }
}

.company-block__header {
  border-top: 1px solid #000;
}

.company-block__heading {
  font-size: 28px;
  margin-bottom: 0;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .company-block__heading {
    font-size: 38px;
  }
}
@media (min-width: 62.5em) {
  .company-block__heading {
    font-size: 48px;
  }
}

.company-block__list {
  display: grid;
  gap: 30px;
  grid-template-columns: repeat(2, 1fr);
}

.company-block__header {
  padding: 15px 0 0 0;
}
@media (min-width: 50em) {
  .company-block__header {
    padding: 20px 0;
  }
}

@media (min-width: 32em) {
  .company-block__group--single {
    grid-template-columns: 1fr auto;
  }
}
.company-block__group--single .company-block__list {
  grid-template-columns: 1fr;
}

.company-block__group--extended {
  grid-template-columns: 1fr;
}
@media (min-width: 58em) {
  .company-block__group--extended .company-block__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
.company-block__group--extended .company-item {
  width: 100%;
}

@media (min-width: 58em) {
  .company-block__group--4-up .company-block__list {
    grid-template-columns: repeat(4, 1fr);
  }
}

/*  ==========================================================================
	Sponsors - Item
	========================================================================== */
.company-item {
  display: flex;
  flex-direction: column;
  gap: 20px;
  text-align: center;
}
@media (min-width: 62.5em) {
  .company-item {
    width: 250px;
  }
}
@media (min-width: 72em) {
  .company-item {
    width: 300px;
  }
}

.company-item__image-container,
.company-item__description:only-child {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #F0F0F0;
  padding: 30px;
  overflow: hidden;
}
@media (min-width: 62.5em) {
  .company-item__image-container,
  .company-item__description:only-child {
    height: 160px;
  }
}

img.company-item__image {
  display: block;
  margin: 0 auto;
  width: auto;
  height: auto;
  max-height: 40px;
  transition: transform 0.3s ease-in-out;
}
@media (min-width: 62.5em) {
  img.company-item__image {
    max-height: 60px;
    max-width: 160px;
  }
}
@media (hover: hover) and (pointer: fine) {
  a.company-item:hover img.company-item__image {
    transform: scale(1.05);
  }
}

.company-item__description {
  text-align: center;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.3;
  text-wrap: balance;
  transition: color 0.4s ease;
}
.company-item__description:only-child {
  height: 100%;
}
@media (min-width: 58em) {
  .company-item__description {
    font-size: 18px;
  }
  .company-item__description:only-child {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .company-item__description:only-child {
    height: 100%;
    min-height: 160px;
  }
}
@media (hover: hover) and (pointer: fine) {
  a.company-item:hover .company-item__description {
    color: var(--theme-color-dark);
  }
}

/*  ==========================================================================
	Sponsors - Left alignment
	========================================================================== */
.company-block--left.company-block__group {
  grid-template-columns: 1fr;
}
.company-block--left .company-block__list {
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 42.5em) {
  .company-block--left .company-block__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 62.5em) {
  .company-block--left .company-block__list {
    grid-template-columns: repeat(4, 1fr);
  }
}

/*  ==========================================================================
	Venue Panel
	========================================================================== */
.venue-panel {
  margin: var(--content-margin);
}

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

.venue-panel__content {
  display: flex;
  flex-direction: column;
  width: 100%;
}
@media (min-width: 50em) {
  .venue-panel__content {
    gap: 20px;
  }
}

.venue-panel__header {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (min-width: 50em) {
  .venue-panel__header {
    display: grid;
    align-items: flex-end;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: 1fr;
    gap: 30px;
    grid-template-areas: "title title address";
  }
}
@media (min-width: 62.5em) {
  .venue-panel__header {
    gap: 40px;
  }
}

.venue-panel__title {
  margin-bottom: 0;
  font-weight: 800;
  text-transform: uppercase;
  text-wrap: balance;
  grid-area: title;
}

.venue-panel__address {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-bottom: 0;
  grid-area: address;
}

a.venue-panel__address,
.venue-footer-item {
  transition: color 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  a.venue-panel__address:hover,
  .venue-footer-item:hover {
    color: var(--theme-color-dark);
  }
}

.venue-panel__address-line-1 {
  font-size: 22px;
  font-weight: 700;
}
@media (min-width: 50em) {
  .venue-panel__address-line-1 {
    font-size: 26px;
  }
}
@media (min-width: 62.5em) {
  .venue-panel__address-line-1 {
    font-size: 28px;
  }
}

.venue-panel__address-line-2 {
  font-size: 18px;
}
@media (min-width: 50em) {
  .venue-panel__address-line-2 {
    font-size: 20px;
  }
}

.venue-panel__intrinsic-ratio {
  position: relative;
  padding-bottom: 50%;
  height: 0;
}

.venue-panel__image {
  height: 100%;
  position: absolute;
  right: 0;
  width: 100%;
  z-index: 2;
}

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

.venue-footer-item {
  display: block;
  padding-top: 15px;
  margin-top: 30px;
  border-top: 1px solid #231F20;
}

.venue-footer-item__title {
  font-family: american-grotesk, sans-serif;
  font-size: 22px;
}
@media (min-width: 50em) {
  .venue-footer-item__title {
    font-size: 26px;
  }
}
@media (min-width: 62.5em) {
  .venue-footer-item__title {
    font-size: 28px;
  }
}

.venue-footer-item__info {
  font-size: 18px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .venue-footer-item__info {
    font-size: 20px;
  }
}

/*  ==========================================================================
	Video Gallery
	========================================================================== */
.video-gallery {
  position: relative;
  padding: 40px 0;
  overflow: hidden;
  background-color: #231F20;
  color: #fff;
}
@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: 1280px;
    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;
  border-top: 1px solid #fff;
  margin: 0 15px 30px;
  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 {
    margin: 0 0 30px;
  }
}

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

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

.video-gallery__previous,
.video-gallery__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) {
  .video-gallery__previous,
  .video-gallery__next {
    display: inline-block;
  }
}
.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 {
  width: 16px;
  height: 20px;
  transition: color 0.4s ease;
}
.video-gallery__previous:not(.swiper-button-disabled):hover,
.video-gallery__next:not(.swiper-button-disabled):hover {
  background-color: var(--theme-color-light);
}
.video-gallery__previous:not(.swiper-button-disabled):hover .o-icon,
.video-gallery__next:not(.swiper-button-disabled):hover .o-icon {
  color: var(--theme-color-light);
}

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

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

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

.video-gallery__list {
  display: flex;
  -webkit-overflow-scrolling: touch;
}

.video-gallery__item {
  display: flex;
  width: 320px;
  padding-right: 15px;
  flex-shrink: 0;
  box-sizing: content-box;
  position: relative;
}
@media (min-width: 62.5em) {
  .video-gallery__item {
    width: calc(33.3% - 26px);
    padding-right: 40px;
  }
  .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%;
  border-bottom: 1px solid #E5E5E5;
}
.user-is-tabbing .video-gallery .video-item a:focus {
  outline-color: #fff;
}
.video-gallery .video-item .video-item__details {
  flex: 1;
}
.video-gallery .video-item .video-item__media {
  position: relative;
  overflow: hidden;
}
.video-gallery .video-item .video-item__image {
  position: relative;
  width: 100%;
  height: auto;
  transition: transform 0.3s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
  .video-gallery .video-item:hover .video-item__image {
    transform: scale(1.05);
  }
}
.video-gallery .video-item .video-item__title {
  display: none;
}
.video-gallery .video-item .video-item__description {
  font-family: american-grotesk, sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: normal;
  transition: color 0.4s ease;
}
@media (min-width: 62.5em) {
  .video-gallery .video-item .video-item__description {
    font-size: 24px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .post-item:hover .video-gallery .video-item .video-item__description {
    color: var(--theme-color-dark);
  }
}
.video-gallery .video-item .video-item__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  inset: 0;
  margin: auto;
  padding: 1px;
  background-color: #fff;
  color: var(--theme-color-dark);
  width: 47px;
  height: 47px;
  border-radius: 50%;
  z-index: 2;
  transition: background-color 0.4s ease;
}
.video-gallery .video-item .video-item__icon .o-icon {
  width: 100%;
  height: 100%;
}
@media (min-width: 62.5em) {
  .video-gallery .video-item .video-item__icon {
    width: 69px;
    height: 69px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .video-gallery .video-item .video-item__icon {
    background-color: var(--theme-color-light);
  }
  .video-gallery .video-item:hover .video-item__icon {
    background-color: #fff;
  }
}

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

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

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

.well {
  background-color: #F0F0F0;
  padding: 30px;
}
@media (min-width: 62.5em) {
  .well {
    padding: 40px;
  }
}
.well + .well {
  margin-top: 0;
}
.well.grey {
  background-color: #F0F0F0;
}
.well.dark-violet {
  background-color: #3B004A;
  color: #fff;
}
.well.dark-violet a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button), .well.dark-violet .s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button):visited, .well.dark-violet .s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button):hover, .well.dark-violet .s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button):active {
  color: #fff;
}
.well.sanguine-red {
  background-color: #9F0000;
  color: #fff;
}
.well.sanguine-red a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button), .well.sanguine-red .s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button):visited, .well.sanguine-red .s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button):hover, .well.sanguine-red .s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):not([data-component*=dialog] menu button):active {
  color: #fff;
}

/*  ==========================================================================
	Event Header
	========================================================================== */
.event-header {
  position: relative;
  margin-top: 15px;
}

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

.event-header__content {
  display: flex;
  gap: 15px 30px;
  margin-top: -110px;
  margin-left: 78px;
  padding-right: 60px;
}
@media (min-width: 50em) {
  .event-header__content {
    padding-right: 215px;
  }
}
@media (min-width: 72em) {
  .event-header__content {
    margin: 0;
    padding: 0;
  }
}

.event-header__details {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 100%;
}
@media (min-width: 72em) {
  .event-header__details {
    flex-direction: row;
    align-items: flex-end;
    gap: 30px;
  }
}

.event-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.8;
}

.event-header__title--1,
.event-header__title--3 {
  font-size: 22px;
}
@media (min-width: 50em) {
  .event-header__title--1,
  .event-header__title--3 {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .event-header__title--1,
  .event-header__title--3 {
    font-size: 48px;
  }
}

@media (min-width: 62.5em) {
  .event-header__title--1 {
    margin-bottom: 3px;
  }
}

.event-header__title--3 {
  margin-top: 3px;
}
@media (min-width: 62.5em) {
  .event-header__title--3 {
    margin-top: 4px;
  }
}

.event-header__date {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-header__date {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .event-header__date {
    font-size: 24px;
  }
}

@media (max-width: 71.99em) {
  .event-header__logo {
    display: none;
  }
}
.event-header__logo .o-icon {
  border: 0;
  width: 105px;
  height: 171px;
}

.event-header__media {
  margin-top: 10px;
  margin-bottom: 0;
}
@media (min-width: 72em) {
  .event-header__media {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 40px;
  }
}
@media (min-width: 72em) and (min-width: 50em) {
  .event-header__media {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.event-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
}
@media (min-width: 62.5em) {
  .event-header__intrinsic-ratio {
    padding-bottom: 56.25%;
  }
}

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

.event-header__footer {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-shrink: 0;
  width: 400px;
  max-width: 100%;
}
@media (min-width: 72em) {
  .event-header__footer {
    align-items: flex-end;
  }
}

.event-btns {
  display: flex;
  gap: 15px;
}
@media (max-width: 71.99em) {
  .event-btns {
    position: fixed;
    bottom: 0;
    left: 0;
    padding: 15px;
    background-color: #fff;
    width: 100%;
    z-index: 5;
    box-shadow: 0px 0px 20px 6px rgba(0, 0, 0, 0.2588235294);
  }
}

@media (max-width: 71.99em) {
  .event-btns__btn {
    padding-left: 0;
    padding-right: 0;
    flex-basis: 100%;
  }
}

#event-popup-btn {
  visibility: hidden;
  display: none;
}

/*  ==========================================================================
	Page Header
	========================================================================== */
.page-header {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background-color: #231F20;
}
@media (max-width: 71.99em) {
  .page-header {
    margin-top: calc(var(--global-header-height) * -1);
  }
}

.page-header__inner {
  position: relative;
  width: 100%;
  margin: 0 auto;
}

.page-header__media {
  position: relative;
  margin-bottom: 0;
  z-index: -1;
}
.page-header__media:before {
  position: absolute;
  content: "";
  background: linear-gradient(to top, black, transparent);
  height: 100%;
  width: 100%;
  z-index: 3;
}

.page-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 61.5384615385%;
  height: 0;
}
@media (min-width: 62.5em) {
  .page-header__intrinsic-ratio {
    padding-bottom: 30%;
  }
}

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

.page-header__content {
  width: 100%;
  max-width: 820px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding-top: 140px;
  padding-bottom: 20px;
  color: #fff;
}
@media (min-width: 50em) {
  .page-header__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 50em) {
  .page-header__content {
    padding-bottom: 30px;
  }
}
@media (min-width: 62.5em) {
  .page-header__content {
    padding-bottom: 40px;
  }
}
@media (min-width: 72em) {
  .page-header__content {
    padding-top: 0;
  }
}

.page-header__logo {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  top: 30px;
  left: 15px;
  right: 0;
}
@media (min-width: 50em) {
  .page-header__logo {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (max-width: 71.99em) {
  .page-header__logo {
    display: none;
  }
}
.page-header__logo .o-icon {
  width: 105px;
  height: 171px;
}

.page-header__breadcrumb {
  position: relative;
  z-index: 1;
}

.page-header__title {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 32px;
  text-transform: uppercase;
  margin-bottom: 0;
  line-height: 0.9;
}
@media (min-width: 24.375em) {
  .page-header__title {
    font-size: 48px;
  }
}
@media (min-width: 50em) {
  .page-header__title {
    font-size: 60px;
  }
}
@media (min-width: 62.5em) {
  .page-header__title {
    font-size: 90px;
  }
}

/*  ==========================================================================
    Page Header - Image
    ========================================================================== */
.page-header--image {
  background-color: transparent;
}
.page-header--image .page-header__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding-top: 0;
}
.page-header--image .page-header__logo {
  position: absolute;
}

/*  ==========================================================================
	Calendar
	========================================================================== */
.calendar {
  position: relative;
  padding: 30px 0;
}
@media (min-width: 62.5em) {
  .calendar {
    padding: 40px 0;
  }
}

.calendar__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-wrap: wrap;
}
@media (min-width: 50em) {
  .calendar__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 62.5em) {
  .calendar__inner {
    flex-wrap: nowrap;
  }
}

.calendar__list {
  order: 2;
  width: 100%;
}
@media (min-width: 62.5em) {
  .calendar__list {
    order: 1;
    flex-grow: 1;
    flex-shrink: 1;
    width: auto;
  }
}

.calendar__sidebar {
  order: 1;
  width: 100%;
  position: sticky;
  top: 0;
  padding: 20px 0;
  margin-top: -20px;
  z-index: 6;
  background-color: #F0F0F0;
}
@media (min-width: 62.5em) {
  .calendar__sidebar {
    order: 2;
    width: 300px;
    flex-shrink: 0;
    margin-left: 40px;
    margin-top: 0;
    margin-bottom: 60px;
    position: static;
    top: auto;
    background-color: transparent;
  }
}
@media (min-width: 62.5em) {
  .calendar__sidebar {
    margin-top: 20px;
  }
}
@media (min-width: 80em) {
  .calendar__sidebar {
    width: 350px;
    margin-left: 100px;
  }
}

.calendar__sticky {
  position: sticky;
  top: 20px;
  width: 100%;
}
@media (min-width: 72em) {
  .calendar__sticky {
    top: calc(var(--global-header-height) + 20px);
  }
}

.calendar-actions {
  display: flex;
  justify-content: space-between;
  width: 100%;
}

.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: 16px;
  font-weight: 700;
  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: 24px;
  height: 24px;
}
@media (min-width: 50em) {
  .calendar-actions__date,
  .calendar-actions__toggle,
  .date-selector__close,
  .calendar-filters__close {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .calendar-actions__date,
  .calendar-actions__toggle,
  .date-selector__close,
  .calendar-filters__close {
    font-size: 22px;
  }
}

@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: #231F20;
  z-index: 3;
  transition: color 0.4s ease;
}
@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 {
    display: none;
  }
}

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

.calendar__desktop-date-picker {
  margin-top: 30px;
}

/*  ==========================================================================
	Whats On
	========================================================================== */
.page-whatson .page-content,
.page-curated .page-content,
.page-calendar .page-content {
  background-color: #F0F0F0;
}

/*  ==========================================================================
	Whats On - Header
	========================================================================== */
.whatson-header {
  position: relative;
  padding-top: 15px;
  padding-bottom: 10px;
  background-color: #fff;
}
@media (min-width: 72em) {
  .whatson-header {
    padding-bottom: 30px;
  }
}

.whatson-header__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-top: -111px;
}
@media (min-width: 50em) {
  .whatson-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 72em) {
  .whatson-header__inner {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    margin-top: 0;
    gap: 40px;
  }
}

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

.whatson-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.8;
  font-size: 42px;
}
@media (min-width: 50em) {
  .whatson-header__title {
    font-size: 72px;
  }
}
@media (min-width: 72em) {
  .whatson-header__title {
    font-size: 90px;
  }
}

@media (max-width: 71.99em) {
  .whatson-header__logo {
    width: 51px;
    height: 80px;
    visibility: hidden;
  }
}
.whatson-header__logo .o-icon {
  border: 0;
  width: 51px;
  height: 80px;
}
@media (min-width: 72em) {
  .whatson-header__logo .o-icon {
    width: 105px;
    height: 171px;
  }
}
.user-is-tabbing .whatson-header__logo:focus {
  outline: 2px solid var(--theme-color-dark);
  outline-offset: 2px;
}

.whatson-header__tabs {
  display: flex;
  flex-direction: row;
  gap: 20px;
}
@media (min-width: 50em) {
  .whatson-header__tabs {
    gap: 30px;
  }
}

.whatson-header__tab {
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 22px;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1;
  position: relative;
}
.whatson-header__tab:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -10px;
  width: 100%;
  height: 5px;
  background-color: var(--theme-color-dark);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
@media (min-width: 50em) {
  .whatson-header__tab {
    font-size: 24px;
  }
}
@media (min-width: 72em) {
  .whatson-header__tab:before {
    bottom: -6px;
    height: 4px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .whatson-header__tab:hover:before {
    transform: scaleX(100%);
  }
}

.whatson-header__tab--active:before {
  transform: scaleX(100%);
}

/*  ==========================================================================
	Performance Popup
	========================================================================== */
.performance-popup {
  align-items: center;
  justify-content: center;
  position: fixed;
  background-color: transparent;
  margin: auto;
  padding: 0;
  border: 0;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
}
@media (min-width: 50em) {
  .performance-popup {
    width: calc(100% - 40px);
    height: calc(100% - 40px);
  }
}
.performance-popup[open] {
  display: flex;
}
.performance-popup::backdrop {
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
  transition: backdrop-filter 0.4s ease background-color 0.4s ease;
}

.performance-popup__inner {
  display: flex;
  flex-direction: column;
  background-color: var(--theme-color-dark);
  color: #fff;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
@media (min-width: 50em) {
  .performance-popup__inner {
    max-width: 760px;
    max-height: 720px;
  }
}

.performance-popup__header {
  display: flex;
  justify-content: space-between;
  gap: 25px;
  position: sticky;
  top: 0;
  padding: 15px;
  background-color: var(--theme-color-dark);
  z-index: 5;
}
@media (min-width: 50em) {
  .performance-popup__header {
    padding: 25px 40px;
  }
}

.performance-popup__close {
  display: flex;
  align-items: center;
  gap: 5px;
  border: 0;
  padding: 0;
  margin: 0;
  background: none;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
}
@media (min-width: 50em) {
  .performance-popup__close {
    position: fixed;
    top: 0;
    right: 0;
    margin: 20px 15px;
    font-size: 22px;
    color: var(--theme-color-light);
  }
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .performance-popup__close:hover {
    color: #fff;
  }
}
.performance-popup__close .o-icon {
  position: relative;
  top: 1px;
  width: 23px;
  height: 23px;
}

.performance-popup__name {
  text-transform: uppercase;
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .performance-popup__name {
    font-size: 42px;
  }
}

.performance-popup__group {
  overflow-y: auto;
  padding: 0 15px;
}
@media (min-width: 50em) {
  .performance-popup__group {
    padding: 0 40px;
  }
}

.performance-popup__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-bottom: 20px;
}
@media (min-width: 50em) {
  .performance-popup__list {
    padding-bottom: 40px;
  }
}

/*  ==========================================================================
	Performance Popup - Item
	========================================================================== */
.performance-popup-item {
  background-color: #fff;
  color: #000;
  padding: 15px;
  transition: background-color 0.4s ease;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.performance-popup-item .o-icon {
  transition: 0.2s ease-in-out;
  color: var(--theme-color-dark);
}
@media (min-width: 50em) {
  .performance-popup-item {
    min-width: 650px;
    padding: 20px;
    background-color: #F0F0F0;
  }
  .performance-popup-item .o-icon {
    transform: translateX(-10px);
  }
}
@media (hover: hover) and (pointer: fine) {
  .performance-popup-item:hover {
    background-color: #fff;
  }
  .performance-popup-item:hover .o-icon {
    transform: translateX(0);
  }
}

.performance-popup-item__title {
  font-size: var(--global-body-size-5);
  margin-bottom: 0;
  width: calc(100% - 24px);
}
@media (min-width: 50em) {
  .performance-popup-item__title {
    font-size: var(--global-body-size-7);
  }
}

.performance-popup-item__date {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}

.performance-popup-item__info {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  padding-top: 15px;
  margin-top: 15px;
  border-top: 1px solid #F0F0F0;
}
@media (min-width: 50em) {
  .performance-popup-item__info {
    flex-direction: row;
    border-color: #E5E5E5;
  }
}

.performance-popup-item__tag {
  background-color: var(--theme-color-dark);
  color: #fff;
  font-weight: 700;
  padding: 6px 10px;
  box-sizing: border-box;
  display: inline-block;
  font-size: 12px;
  text-transform: uppercase;
}

.performance-popup-item__footer {
  margin-top: 10px;
  border-top: 1px solid #E5E5E5;
  padding-top: 10px;
  width: 100%;
}

.performance-popup-item__tags {
  display: flex;
  gap: 15px;
}

.performance-popup-item__availability {
  display: inline-block;
  font-size: 12px;
  text-transform: uppercase;
  font-weight: 700;
}

.performance-popup-item__availability {
  display: flex;
  align-items: center;
  gap: 15px;
}
.performance-popup-item__availability.limited .performance-popup-item__availability-line:after {
  width: 20%;
  background: #9F0000;
}
.performance-popup-item__availability.good .performance-popup-item__availability-line:after {
  width: 80%;
  background: #197C00;
}

.performance-popup-item__availability-line {
  width: 120px;
  height: 8px;
  background: #C0C0C0;
  border-radius: 10px;
  position: relative;
  overflow: hidden;
}

.performance-popup-item__availability-line:after {
  content: "";
  width: 0;
  height: 8px;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 0;
}

/*  ==========================================================================
	Event Details
	========================================================================== */
.event-details {
  padding: 30px 0;
}
@media (min-width: 72em) {
  .event-details {
    padding: 40px 0;
  }
}
@media (max-width: 71.99em) {
  .event-details .event-btns {
    display: none;
  }
}

.event-details__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 50em) {
  .event-details__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 62.5em) {
  .event-details__inner {
    flex-direction: row;
    gap: 40px;
  }
  .event-details__inner > * {
    flex-basis: 100%;
  }
}

.event-details__meta {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (min-width: 50em) {
  .event-details__meta {
    gap: 25px;
  }
}

.event-details__title {
  font-size: 34px;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-details__title {
    font-size: 40px;
  }
}
@media (min-width: 62.5em) {
  .event-details__title {
    font-size: 56px;
  }
}

.event-cast {
  list-style: none;
  padding: 0;
  margin: 0;
}

.event-cast__person {
  font-size: 18px;
}
@media (min-width: 50em) {
  .event-cast__person {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .event-cast__person {
    font-size: 28px;
  }
}

.event-details__running-time {
  font-size: 18px;
  margin-bottom: 0;
  text-wrap: pretty;
}
@media (min-width: 50em) {
  .event-details__running-time {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .event-details__running-time {
    font-size: 24px;
  }
}

.event-details__links {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 15px;
}
@media (min-width: 62.5em) {
  .event-details__links {
    gap: 5px 25px;
  }
}

.event-details__link,
.event-details__synopsis-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--theme-color-dark);
  cursor: pointer;
  transition: color 0.4s ease;
}
@media (min-width: 50em) {
  .event-details__link,
  .event-details__synopsis-btn {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .event-details__link,
  .event-details__synopsis-btn {
    font-size: 22px;
  }
}
.event-details__link .o-icon,
.event-details__synopsis-btn .o-icon {
  width: 23px;
  height: 23px;
}
.event-details__link:hover,
.event-details__synopsis-btn:hover {
  color: #231F20;
}

.event-details__content {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

/*  ==========================================================================
	Event Sticky Bar
	========================================================================== */
.event-sticky-bar {
  display: none;
  position: sticky;
  top: 0;
  background-color: var(--theme-color-dark);
  color: #fff;
  margin-bottom: -5px;
  padding: 8px 0 15px;
  z-index: 3;
  width: 100%;
  transition: transform 0.4s ease;
}
@media (min-width: 72em) {
  .event-sticky-bar {
    position: fixed;
    top: var(--global-header-height);
    padding: 10px 0 15px;
    transform: translateY(-100%);
    z-index: 5;
  }
  .event-sticky-bar.show {
    transform: translateY(0%);
  }
}
.event-sticky-bar .event-btns__btn {
  padding: 10px 40px;
}
.event-sticky-bar .event-btns button {
  color: var(--theme-color-dark);
}
.event-sticky-bar .event-btns button::after {
  background-color: #fff;
  color: #000;
}

.event-sticky-bar__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 60px;
}
@media (min-width: 50em) {
  .event-sticky-bar__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.event-sticky-bar__nav {
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  margin-bottom: -5px;
  padding-bottom: 5px;
}
.event-sticky-bar__nav::-webkit-scrollbar {
  display: none;
}

.event-sticky-bar__list {
  display: flex;
  gap: 10px;
  padding: 0 5px;
  margin: 0;
  list-style: none;
}

.event-sticky-bar__item {
  display: flex;
  padding-top: 5px;
}

.event-sticky-bar__link {
  white-space: nowrap;
  font-size: 16px;
  font-weight: 700;
  border: 1px solid var(--link-color);
  border-radius: 50px;
  padding: 3px 15px 5px;
  transition: color 0.4s ease, background-color 0.4s ease;
}
.user-is-tabbing .event-sticky-bar__link:focus {
  outline: 2px solid var(--link-color);
  outline-offset: 2px;
}
.event-sticky-bar__link:before {
  content: none !important;
}
.event-sticky-bar__link:hover, .event-sticky-bar__link:active {
  background-color: var(--link-color);
  color: var(--theme-color-dark);
}

@media (max-width: 71.99em) {
  .event-sticky-bar__actions {
    display: none;
  }
}

.event-sticky-bar__btns {
  display: flex;
  gap: 10px;
}

.event-sticky-bar__link {
  --link-color: #fff;
}

/*  ==========================================================================
	Review Scroller
	========================================================================== */
.review-scroller {
  position: relative;
  background: var(--theme-color-dark);
  padding: 40px 0;
  overflow: hidden;
}
@media (min-width: 50em) {
  .review-scroller {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .review-scroller {
    padding: 60px 0 80px;
  }
}
.review-scroller:last-child {
  margin-bottom: 0;
}

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

.review-scroller__header {
  position: relative;
  margin-bottom: 30px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .review-scroller__header {
    align-items: center;
  }
}

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

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

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

.review-scroller__previous {
  margin-right: 0;
}
.review-scroller__previous .o-icon {
  transform: rotate(90deg);
}
.review-scroller__previous:active .o-icon {
  transform: scale(0.9) rotate(90deg);
}

.review-scroller__next {
  margin-right: 15px;
}
@media (min-width: 62.5em) {
  .review-scroller__next {
    margin-right: 0;
  }
}
.review-scroller__next .o-icon {
  transform: rotate(-90deg);
}
.review-scroller__next:active .o-icon {
  transform: scale(0.9) rotate(-90deg);
}

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

.review-scroller__list {
  display: flex;
}

/*  ==========================================================================
    Review Scroller - Items
    ========================================================================== */
.review-scroller-item {
  background-color: #fff;
  padding: 20px;
  display: flex;
  flex-shrink: 0;
  width: 256px;
  margin-right: 20px;
}
@media (min-width: 32em) {
  .review-scroller-item {
    width: 300px;
  }
}
@media (min-width: 50em) {
  .review-scroller-item {
    width: 400px;
    padding: 30px;
  }
}
@media (min-width: 62.5em) {
  .review-scroller-item:last-child {
    margin-right: 0;
  }
}
@media (min-width: 80em) {
  .review-scroller-item {
    width: calc(33.3% - 13px);
  }
}

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

.review-scroller-item__quote {
  font-family: american-grotesk, sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
}
.review-scroller-item__quote p:last-child {
  margin-bottom: 0;
}
.review-scroller-item__quote p:first-child:before {
  content: "“";
}
.review-scroller-item__quote p:last-child:after {
  content: "”";
}
@media (min-width: 32em) {
  .review-scroller-item__quote {
    font-size: 24px;
  }
}
@media (min-width: 50em) {
  .review-scroller-item__quote {
    font-size: 28px;
    line-height: 1.1;
  }
}

.review-scroller-item__meta {
  width: 100%;
  max-width: 720px;
  text-align: left;
  line-height: 1;
  padding-left: 40px;
  position: relative;
  font-size: 14px;
  color: var(--theme-color-dark);
}
.review-scroller-item__meta:before {
  content: "";
  position: absolute;
  height: 1px;
  width: 29px;
  background-color: var(--theme-color-dark);
  top: 9px;
  left: 0;
}
@media (min-width: 50em) {
  .review-scroller-item__meta:before {
    width: 48px;
    top: 10px;
  }
}
@media (min-width: 32em) {
  .review-scroller-item__meta {
    font-size: 16px;
  }
}
@media (min-width: 50em) {
  .review-scroller-item__meta {
    padding-left: 60px;
    font-size: 18px;
  }
}

.review-scroller-item__cite {
  font-style: normal;
}

/* ==========================================================================
   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: 58em) {
  .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: 58em) {
  .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%;
}

/*  ==========================================================================
	Synopsis Popup
	========================================================================== */
.synopsis-popup {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  background-color: var(--theme-color-dark);
  color: #fff;
  padding: 0;
}

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

.synopsis-popup__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: sticky;
  gap: 5px;
  top: 0;
  padding: 15px 0;
  background-color: var(--theme-color-dark);
}
@media (min-width: 50em) {
  .synopsis-popup__header {
    gap: 15px;
    padding: 40px 0 20px;
  }
}

@media (min-width: 50em) {
  .synopsis-popup__titles {
    display: flex;
    flex-direction: column-reverse;
    max-width: 800px;
  }
}
@media (min-width: 72em) {
  .synopsis-popup__titles {
    max-width: 1000px;
  }
}

.synopsis-popup__prefix {
  display: block;
  line-height: 1;
  padding-bottom: 5px;
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 26px;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .synopsis-popup__prefix {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .synopsis-popup__prefix {
    font-size: 38px;
  }
}

.synopsis-popup__title {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 0;
  text-wrap: balance;
}

.synopsis-popup__close {
  color: #fff;
}
@media (min-width: 62.5em) {
  .synopsis-popup__close {
    position: fixed;
    top: 40px;
    right: 60px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .synopsis-popup__close:hover {
    color: var(--theme-color-light);
  }
}

.synopsis-popup__body {
  padding: 15px 0;
  font-size: 18px;
}
@media (min-width: 50em) {
  .synopsis-popup__body {
    font-size: 20px;
  }
}
.synopsis-popup__body h3 {
  font-size: 24px;
}
@media (min-width: 50em) {
  .synopsis-popup__body h3 {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .synopsis-popup__body h3 {
    font-size: 32px;
  }
}
.synopsis-popup__body p {
  margin-bottom: 1.3em;
}
.synopsis-popup__body p:last-child {
  margin-bottom: 0;
}

/*  ==========================================================================
	Embed Video
	========================================================================== */
.embed-video {
  position: relative;
  padding: 30px 0;
  background-color: #231F20;
  color: #fff;
}
@media (min-width: 50em) {
  .embed-video {
    padding: 40px 0;
  }
}
@media (min-width: 62.5em) {
  .embed-video {
    padding: 60px 0;
  }
}
.user-is-tabbing .embed-video a:focus {
  outline-color: #fff;
}

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

/*  ==========================================================================
	Embed Video - Video Item
	========================================================================== */
.embed-video .video-item {
  display: flex;
  flex-direction: column;
  gap: 25px;
}
@media (min-width: 50em) {
  .embed-video .video-item {
    display: grid;
    grid-template-columns: 280px 1fr;
    align-items: center;
  }
}
.embed-video .video-item .video-item__details {
  grid-column: 1;
  grid-row: 1;
}
.embed-video .video-item .video-item__title {
  color: var(--theme-color-light);
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 22px;
  margin-bottom: 5px;
}
@media (min-width: 50em) {
  .embed-video .video-item .video-item__title {
    font-size: 24px;
    color: #fff;
  }
}
@media (min-width: 62.5em) {
  .embed-video .video-item .video-item__title {
    font-size: 26px;
  }
}
.embed-video .video-item .video-item__description {
  color: #C0C0C0;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .embed-video .video-item .video-item__description {
    font-size: 32px;
  }
}
.embed-video .video-item .video-item__cta {
  display: flex;
  align-items: center;
  gap: 5px;
  margin-top: 15px;
  font-weight: 700;
  font-size: 16px;
  color: var(--theme-color-light);
}
@media (min-width: 50em) {
  .embed-video .video-item .video-item__cta {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .embed-video .video-item .video-item__cta {
    font-size: 22px;
  }
}
.embed-video .video-item .video-item__media {
  display: block;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  width: 100%;
  grid-column: 2;
  grid-row: 1;
}
.embed-video .video-item .video-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
}
.embed-video .video-item .video-item__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  inset: 0;
  margin: auto;
  padding: 1px;
  background-color: #fff;
  color: var(--theme-color-dark);
  width: 47px;
  height: 47px;
  border-radius: 50%;
  z-index: 2;
  transition: background-color 0.4s ease;
}
.embed-video .video-item .video-item__icon .o-icon {
  width: 100%;
  height: 100%;
}
@media (min-width: 32em) {
  .embed-video .video-item .video-item__icon {
    width: 69px;
    height: 69px;
  }
}
@media (min-width: 50em) {
  .embed-video .video-item .video-item__icon {
    background-color: var(--theme-color-light);
  }
}
@media (min-width: 62.5em) {
  .embed-video .video-item .video-item__icon {
    width: 91px;
    height: 91px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .embed-video .video-item .video-item__cta:hover {
    color: #fff;
  }
  .embed-video .video-item .video-item__media:hover .video-item__icon {
    background-color: #fff;
  }
}

/*  ==========================================================================
	Grouped Info
	========================================================================== */
.grouped-info {
  display: flex;
  flex-direction: column;
  gap: 30px;
  position: relative;
  background-color: #fff;
  color: #000;
  margin: 40px 0;
}
@media (min-width: 58em) {
  .grouped-info {
    margin: 60px 0;
  }
}

.grouped-info__title {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  font-size: 32px;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .grouped-info__title {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 50em) {
  .grouped-info__title {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .grouped-info__title {
    font-size: 60px;
  }
}

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

.preformance-info__border {
  border-top: 1px solid #F0F0F0;
  padding-top: 22px;
}

.grouped-info__group {
  height: auto;
}

.grouped-info__group:last-child:nth-child(odd) {
  flex: 1;
}
@media (min-width: 42.5em) {
  .grouped-info__group:last-child:nth-child(odd) .grouped-info__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 50em) {
  .grouped-info__group:last-child:nth-child(odd) .grouped-info__list {
    grid-template-columns: repeat(3, 1fr);
  }
}

.grouped-info__header {
  border-top: 1px solid #000;
  display: flex;
  justify-content: space-between;
}

.grouped-info__heading {
  font-size: 32px;
  margin-bottom: 15px;
  text-transform: uppercase;
  width: auto;
}
@media (min-width: 50em) {
  .grouped-info__heading {
    font-size: 42px;
    width: 50%;
  }
}
@media (min-width: 62.5em) {
  .grouped-info__heading {
    font-size: 56px;
  }
}

.grouped-info:has(.grouped-info__title) .grouped-info__heading {
  font-size: 26px;
}
@media (min-width: 50em) {
  .grouped-info:has(.grouped-info__title) .grouped-info__heading {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .grouped-info:has(.grouped-info__title) .grouped-info__heading {
    font-size: 42px;
  }
}

.grouped-info__cta {
  display: none;
  align-items: center;
  gap: 5px;
  color: var(--theme-color-dark);
  font-weight: 700;
  height: fit-content;
  font-size: 16px;
}
@media (min-width: 50em) {
  .grouped-info__cta {
    display: flex;
    font-size: 22px;
  }
}

.grouped-info__btn {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 5px;
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--theme-color-dark);
  cursor: pointer;
  transition: color 0.4s ease;
  width: 100%;
}
@media (min-width: 50em) {
  .grouped-info__btn {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .grouped-info__btn {
    font-size: 22px;
    justify-content: flex-end;
  }
}
.grouped-info__btn .o-icon {
  width: 23px;
  height: 23px;
}
.grouped-info__btn:hover {
  color: #231F20;
}

.grouped-info__cta.mobile {
  display: flex;
}
@media (min-width: 50em) {
  .grouped-info__cta.mobile {
    display: none;
  }
}

.grouped-info__list {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 30px;
  align-items: flex-start;
}

.grouped-info__header {
  padding: 15px 0 0 0;
}
@media (min-width: 50em) {
  .grouped-info__header {
    padding: 20px 0;
  }
}

.grouped-info__item {
  width: auto;
  display: flex;
  justify-content: center;
  flex-direction: column;
}

.grouped-info__item-title {
  font-family: american-grotesk, sans-serif;
  font-size: 20px;
  font-weight: 700;
}
@media (min-width: 58em) {
  .grouped-info__item-title {
    font-size: 28px;
  }
}

.grouped-info__description {
  margin-bottom: 0;
  font-size: 18px;
  font-weight: 400;
}
@media (min-width: 58em) {
  .grouped-info__description {
    font-size: 20px;
  }
}

/*  ==========================================================================
	Grouped Info - Inline
	========================================================================== */
.grouped-info--inline .grouped-info__inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.grouped-info--inline .grouped-info__group {
  width: 100%;
  margin-bottom: 40px;
}
.grouped-info--inline .grouped-info__group:last-child {
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .grouped-info--inline .grouped-info__group {
    height: auto;
  }
}
@media (min-width: 62.5em) {
  .grouped-info--inline .grouped-info__group {
    width: 48%;
  }
}
@media (min-width: 50em) {
  .grouped-info--inline .grouped-info__heading {
    width: 100%;
  }
}
.grouped-info--inline .grouped-info__item {
  width: 100%;
}
@media (min-width: 50em) {
  .grouped-info--inline .grouped-info__cta.mobile {
    display: flex;
  }
}

/*  ==========================================================================
	grouped-info-4up
	========================================================================== */
.grouped-info--4up .grouped-info__group {
  border-bottom: 1px solid #F0F0F0;
  display: flex;
  flex-direction: column;
  width: 100%;
}
@media (min-width: 32em) {
  .grouped-info--4up .grouped-info__group {
    border-bottom: none;
    width: 45%;
  }
}
@media (min-width: 62.5em) {
  .grouped-info--4up .grouped-info__group {
    width: 24%;
  }
}
.grouped-info--4up .grouped-info__header {
  align-items: center;
  border-top: none;
}
@media (min-width: 62.5em) {
  .grouped-info--4up .grouped-info__header {
    flex: 1;
  }
}
.grouped-info--4up .grouped-info__heading {
  font-size: 20px;
  text-transform: capitalize;
  margin-bottom: 0;
  height: fit-content;
  width: 100%;
}
@media (min-width: 50em) {
  .grouped-info--4up .grouped-info__heading {
    font-size: 24px;
  }
}
@media (min-width: 58em) {
  .grouped-info--4up .grouped-info__heading {
    font-size: 26px;
  }
}
.grouped-info--4up .grouped-info__list {
  gap: 0;
  padding: 0 0 20px;
}
.grouped-info--4up .preformance-info__border {
  border: none;
}

/*  ==========================================================================
	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-month {
  display: flex;
  flex-direction: column;
}

.calendar-list-month__title {
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: 20px;
  padding-bottom: 10px;
  position: sticky;
  top: 60px;
  background-color: #F0F0F0;
  z-index: 5;
  font-size: 28px;
}
@media (min-width: 50em) {
  .calendar-list-month__title {
    font-size: 48px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-month__title {
    margin-top: 0;
    margin-bottom: 30px;
    padding-top: 15px;
    top: 0;
  }
}
@media (min-width: 72em) {
  .calendar-list-month__title {
    top: var(--global-header-height);
  }
}

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

.calendar-list-day {
  display: grid;
  grid-template-columns: 80px 1fr;
  align-items: flex-start;
  gap: 15px;
}
@media (min-width: 50em) {
  .calendar-list-day {
    grid-template-columns: 105px 1fr;
    gap: 40px;
  }
}

.calendar-list-day__title {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: sticky;
  top: 115px;
  font-family: american-grotesk, sans-serif;
  font-weight: 700;
  margin-bottom: 0;
  padding: 10px 0;
  border-top: 1px solid #C0C0C0;
}
@media (min-width: 50em) {
  .calendar-list-day__title {
    top: 130px;
    padding: 20px 0;
    border-color: #6A6A6A;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-day__title {
    top: 90px;
  }
}
@media (min-width: 72em) {
  .calendar-list-day__title {
    top: calc(var(--global-header-height) + 90px);
  }
}

.calendar-list-day__day {
  font-size: 14px;
}
@media (min-width: 50em) {
  .calendar-list-day__day {
    font-size: 16px;
  }
}

.calendar-list-day__date {
  font-size: 18px;
}
@media (min-width: 50em) {
  .calendar-list-day__date {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-day__date {
    font-size: 24px;
  }
}

.calendar-list-event {
  display: flex;
  flex-direction: column;
  gap: 20px;
  background: none;
  padding: 10px 0 25px;
  border-width: 1px 0 0 0;
  border-color: #C0C0C0;
  text-align: left;
  width: 100%;
  cursor: pointer;
}
@media (min-width: 50em) {
  .calendar-list-event {
    padding: 20px 0 25px;
    border-color: #6A6A6A;
  }
}

.calendar-list-event__title {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 26px;
  text-transform: uppercase;
  margin-bottom: 0;
  transition: color 0.4s ease;
  color: #000;
}
@media (min-width: 50em) {
  .calendar-list-event__title {
    font-size: 30px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-event__title {
    font-size: 34px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .calendar-list-event:hover .calendar-list-event__title {
    color: var(--theme-color-dark);
  }
}

.calendar-list-event__prefix,
.calendar-list-event__suffix {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 16px;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .calendar-list-event__prefix,
  .calendar-list-event__suffix {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-event__prefix,
  .calendar-list-event__suffix {
    font-size: 20px;
  }
}

.calendar-list-event__time {
  font-size: 16px;
  margin-top: 10px;
  margin-bottom: 0;
  color: #000;
}
@media (min-width: 50em) {
  .calendar-list-event__time {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-event__time {
    font-size: 20px;
  }
}

.calendar-list-event__footer {
  width: 100%;
}

/*  ==========================================================================
    Calendar - Footer
    ========================================================================== */
.calendar-info {
  display: grid;
  grid-template-columns: 100%;
  justify-content: space-between;
  width: 100%;
}
@media (min-width: 50em) {
  .calendar-info {
    flex-direction: row;
  }
}
.calendar-info.calendar-info--has-availability {
  grid-template-columns: 50% 50%;
}

.calendar-categories {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 10px 15px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.calendar-category {
  background-color: var(--theme-color-dark);
  color: #fff;
  padding: 7px 10px;
  font-family: american-grotesk-condensed, sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1;
  flex-shrink: 0;
}

.calendar-availability {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 15px;
  flex-shrink: 0;
  height: 20px;
  grid-column-start: 2;
}
@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: american-grotesk-condensed, 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 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 #C0C0C0;
  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-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 34px;
  text-transform: uppercase;
  margin-bottom: 0;
}
.date-selector__month-title strong {
  margin-right: 8px;
}

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

.date-selector__button {
  padding: 0;
  background-color: var(--theme-color-dark);
  border: 2px solid var(--theme-color-dark);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px;
  margin-right: 7px;
  width: 31px;
  height: 31px;
  cursor: pointer;
  transition: background-color 0.4s ease, color 0.4s ease, border-color 0.4s ease;
}
.date-selector__button .o-icon {
  height: 15px;
  width: 15px;
}
.date-selector__button:last-child {
  margin-right: 0;
}
@media (hover: hover) and (pointer: fine) {
  .date-selector__button:hover {
    border-color: #231F20;
    background-color: #231F20;
    color: #fff;
  }
}
.date-selector__button:active .o-icon {
  scale: 0.9;
}

.date-selector__button--disabled {
  opacity: 0.25;
  cursor: not-allowed;
}

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

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

.date-selector__day-name {
  width: 14.285%;
  text-transform: uppercase;
  font-weight: 700;
  font-family: american-grotesk, 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: 5px;
  margin: 5px 0;
  border: none;
  background: transparent;
  color: #444;
  font-family: american-grotesk, sans-serif;
}

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

.date-selector__day--today {
  opacity: 1;
  position: relative;
  color: #fff;
}
.date-selector__day--today:after {
  content: "";
  width: 34px;
  height: 34px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--theme-color-dark);
  z-index: -1;
  border-radius: 100%;
}

.date-selector__day:not(.date-selector__day--today):active, .date-selector__day:not(.date-selector__day--today):hover {
  opacity: 0.3;
}

/*  ==========================================================================
    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: 32px;
  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 {
  max-width: unset;
  max-height: unset;
  padding: unset;
  margin: unset;
  margin-left: auto;
  width: 316px;
  box-shadow: 0 0 25px 5px rgba(0, 0, 0, 0.1);
  z-index: 20;
  /*  stylelint-disable */
  /*  2. EXIT STATE  */
  translate: 100% 0;
  display: none;
  transition: translate 0.4s ease, display 0.4s ease;
  transition-behavior: allow-discrete;
  /*  stylelint-enable */
}
@media (min-width: 30em) {
  .calendar-filters {
    width: 400px;
  }
}
@media (min-width: 50em) {
  .calendar-filters {
    width: 500px;
  }
}
.calendar-filters[open] {
  /*  0. BEFORE-OPEN STATE  */
  /*  1. IS-OPEN STATE  */
  display: flex;
  translate: 0 0;
}
@starting-style {
  .calendar-filters[open] {
    translate: 100% 0;
  }
}

.calendar-filters__action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  position: sticky;
  bottom: 0;
  margin-top: 20px;
  padding-bottom: 15px;
  background-color: #fff;
  box-shadow: 0 -6px 20px 10px #fff;
}
.calendar-filters__action .calendar-filters__btn {
  width: 100%;
  justify-content: center;
  outline-offset: 2px;
}
@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;
  height: 100svh;
  width: 100%;
  max-width: 316px;
  overflow-y: auto;
  z-index: 20;
}
@media (min-width: 30em) {
  .calendar-filters__body {
    max-width: 400px;
  }
}
@media (min-width: 50em) {
  .calendar-filters__body {
    max-width: 500px;
    padding: 40px 40px 0;
  }
}
.calendar-filters__body .calendar-filters__toggle {
  top: 0;
  right: 0;
}
.user-is-tabbing .calendar-filters__body .calendar-filters__toggle:focus {
  outline: 2px solid #231F20;
  outline-offset: 5px;
  overflow: hidden;
}
.calendar-filters__body .calendar-filters__reset {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 16px;
  font-weight: 500;
  color: #231F20;
}

.calendar-filter__header {
  position: relative;
}

.calendar-filters__title {
  font-size: 20px;
  font-weight: 700;
  font-family: american-grotesk, sans-serif;
  margin-bottom: 40px;
}
@media (min-width: 50em) {
  .calendar-filters__title {
    font-size: 24px;
  }
}
@media (min-width: 62.5em) {
  .calendar-filters__title {
    font-size: 26px;
  }
}

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

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

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

.calendar-filters__group__name {
  font-size: 18px;
  font-weight: 700;
  font-family: american-grotesk, sans-serif;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .calendar-filters__group__name {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .calendar-filters__group__name {
    font-size: 22px;
  }
}

.calendar-filters__group__toggle {
  position: relative;
  width: 23px;
  height: 23px;
  flex-shrink: 0;
  margin-left: auto;
  background-color: var(--theme-color-dark);
  border: 1.5px solid #fff;
  border-radius: 100%;
}
.calendar-filters__group__toggle:before {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  left: calc(50% - 1px);
  width: 10px;
  height: 2px;
  transform: rotate(90deg) translate(-50%, -50%);
  transform-origin: left;
  background-color: #fff;
  transition: background-color 0.3s ease;
}
.calendar-filters__group__header.is-toggled .calendar-filters__group__toggle:before {
  content: none;
}
.calendar-filters__group__toggle:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 10px;
  height: 2px;
  transform: translate(-50%, -50%);
  background-color: #fff;
  transition: background-color 0.3s ease;
}

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

.calendar-filters__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 15px 20px;
  padding-top: 20px;
}

.calendar-filters__item {
  display: flex;
  align-items: flex-start;
}
.calendar-filters__item--disabled {
  opacity: 0.5;
}
.user-is-tabbing .calendar-filters__item:has(input:focus) {
  outline: 2px solid #231F20;
  outline-offset: 2px;
}

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

/*  ==========================================================================
	Event Scroller
	========================================================================== */
.event-scroller {
  position: relative;
  background: var(--theme-color-dark);
  color: #fff;
  padding: 40px 0;
  overflow: hidden;
}
.event-scroller--dark {
  background: #231F20;
}
@media (min-width: 50em) {
  .event-scroller {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .event-scroller {
    padding: 60px 0 80px;
  }
}
.event-scroller:last-child {
  margin-bottom: 0;
}
.user-is-tabbing .event-scroller a:focus {
  outline-color: #fff;
}

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

.event-scroller__header {
  position: relative;
  margin-bottom: 30px;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 50em) {
  .event-scroller__header {
    align-items: center;
  }
}

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

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

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

.event-scroller__previous {
  margin-right: 0;
}
.event-scroller__previous .o-icon {
  transform: rotate(180deg);
}
.event-scroller__previous:active .o-icon {
  transform: scale(0.9) rotate(180deg);
}

.event-scroller__next {
  margin-right: 15px;
}
@media (min-width: 62.5em) {
  .event-scroller__next {
    margin-right: 0;
  }
}
.event-scroller__next:active .o-icon {
  transform: scale(0.9);
}

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

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

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

.event-scroller__item:has(+ .event-scroller__previous-title) {
  padding-right: 20px;
}
@media (min-width: 62.5em) {
  .event-scroller__item:has(+ .event-scroller__previous-title) {
    padding-right: 30px;
  }
}

.event-scroller__previous-title {
  font-size: 38px;
  margin-right: 5px;
  writing-mode: vertical-rl;
  text-transform: uppercase;
}

/*  ==========================================================================
	Event Scroller - Production Archive
	========================================================================== */
.page-production-archive .event-scroller {
  background: #fff;
  color: #231F20;
}
.page-production-archive .event-scroller .event-item__details {
  padding: 0;
}
.page-production-archive .event-scroller .event-scroller__previous,
.page-production-archive .event-scroller .event-scroller__next {
  background-color: #231F20;
  color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .page-production-archive .event-scroller .event-scroller__previous:not(.swiper-button-disabled):hover,
  .page-production-archive .event-scroller .event-scroller__next:not(.swiper-button-disabled):hover {
    background-color: var(--theme-color-dark);
  }
}

/*  ==========================================================================
	Event Item
	========================================================================== */
.event-item {
  background-color: #fff;
  color: #231F20;
  width: 100%;
}

.event-item__media {
  position: relative;
  height: 0;
  padding-bottom: 60%;
  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 15px 15px;
}

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

.event-item__title--1,
.event-item__title--3 {
  display: block;
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 18px;
  font-weight: 800;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .event-item__title--1,
  .event-item__title--3 {
    font-size: 24px;
  }
}

.event-item__title--2 {
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 32px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-item__title--2 {
    font-size: 42px;
  }
}

.event-item__description {
  font-size: 14px;
  margin-top: 15px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-item__description {
    font-size: 16px;
  }
}

.event-item__credits {
  margin: 15px 0 20px;
  font-size: 14px;
  flex-grow: 1;
}
@media (min-width: 50em) {
  .event-item__credits {
    font-size: 16px;
  }
}

.event-item__cite {
  margin: 0;
}

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

.event-item__info {
  position: relative;
  display: flex;
  flex-direction: row;
  gap: 20px;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
}
.event-item__info:before {
  content: "";
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 100%;
  height: 1px;
  background-color: #F0F0F0;
  transition: background-color 0.3s ease-in-out, height 0.3s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
  .event-item:hover .event-item__info {
    color: var(--theme-color-dark);
  }
  .event-item:hover .event-item__info:before {
    height: 2px;
    background-color: var(--theme-color-dark);
  }
}
.event-item__titles:has(+ .event-item__info) {
  padding-bottom: 40px;
}

.event-item__date {
  position: relative;
  font-weight: 700;
  margin: auto 0 0;
  font-size: 14px;
  transition: color 0.3s ease-in-out;
  margin-top: 0;
}
@media (min-width: 50em) {
  .event-item__date {
    font-size: 16px;
  }
}

.event-item__tag {
  min-width: fit-content;
  padding: 3px 8px;
  height: fit-content;
  border-radius: 3px;
  background: var(--theme-color-dark);
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 0;
  border: 1px solid var(--theme-color-dark);
}
.event-item__tag.event-item__tag--next {
  background: #fff;
  color: var(--theme-color-dark);
  border-color: var(--theme-color-dark);
}

/*  ==========================================================================
	Event List
	========================================================================== */
.event-list {
  position: relative;
  padding: 30px 0;
  background-color: var(--theme-color-dark);
  color: #fff;
}
@media (min-width: 50em) {
  .event-list {
    padding: 40px 0;
  }
}
@media (min-width: 62.5em) {
  .event-list {
    padding: 60px 0;
  }
}

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

.event-list__title {
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: 20px;
}

.event-list__events {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (min-width: 50em) {
  .event-list__events {
    gap: 30px;
  }
}
@media (min-width: 62.5em) {
  .event-list__events {
    gap: 40px;
  }
}

.event-list-item {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px;
  padding: 15px;
  background-color: #fff;
  color: #231F20;
}
@media (min-width: 50em) {
  .event-list-item {
    flex-direction: row;
    align-items: initial;
    gap: 0;
    padding: 30px;
  }
}

.event-list-item__body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 15px;
}

.event-list-item__titles {
  display: flex;
  flex-direction: column;
  text-transform: uppercase;
  font-weight: 800;
  font-family: american-grotesk-compressed, sans-serif;
  line-height: 1;
}

.event-list-item__title {
  margin-bottom: 0;
}
@media (min-width: 62.5em) {
  .event-list-item__title {
    font-size: 48px;
  }
}

.event-list-item__prefix,
.event-list-item__suffix {
  font-size: 22px;
}
@media (min-width: 50em) {
  .event-list-item__prefix,
  .event-list-item__suffix {
    font-size: 26px;
  }
}
@media (min-width: 62.5em) {
  .event-list-item__prefix,
  .event-list-item__suffix {
    font-size: 32px;
  }
}

.event-list-item__description {
  margin-bottom: 0;
}
@media (max-width: 31.99em) {
  .event-list-item__description {
    display: none;
  }
}
@media (min-width: 50em) {
  .event-list-item__description {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .event-list-item__description {
    font-size: 20px;
  }
}

.event-list-item__date,
.event-list-item__price {
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-list-item__date,
  .event-list-item__price {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .event-list-item__date,
  .event-list-item__price {
    font-size: 24px;
  }
}

.event-list-item__date {
  line-height: 1.3;
}

.event-list-item__action {
  display: flex;
  flex-direction: column;
  height: auto;
  width: 100%;
}
@media (min-width: 50em) {
  .event-list-item__action {
    align-items: flex-start;
    justify-content: center;
    flex-shrink: 0;
    padding-left: 40px;
    margin-left: 40px;
    border-left: 1px solid #E5E5E5;
    width: 360px;
    max-width: 100%;
  }
}

.event-list-item__cta {
  margin-top: 15px;
}
@media (max-width: 49.99em) {
  .event-list-item__cta {
    width: 100%;
  }
}

/*  ==========================================================================
	Post Scroller
	========================================================================== */
.post-scroller {
  position: relative;
  padding: 40px 0;
  overflow: hidden;
}
@media (min-width: 50em) {
  .post-scroller {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .post-scroller {
    padding: 60px 0 80px;
  }
}
.post-scroller:last-child {
  margin-bottom: 0;
}

@media (min-width: 62.5em) {
  .post-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) {
  .post-scroller__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

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

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

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

.post-scroller__previous,
.post-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) {
  .post-scroller__previous,
  .post-scroller__next {
    display: inline-block;
  }
}
.post-scroller__previous.swiper-button-disabled,
.post-scroller__next.swiper-button-disabled {
  cursor: not-allowed;
}
.post-scroller__previous .o-icon,
.post-scroller__next .o-icon {
  width: 16px;
  height: 20px;
  transition: color 0.4s ease;
}
.post-scroller__previous:not(.swiper-button-disabled):hover,
.post-scroller__next:not(.swiper-button-disabled):hover {
  background-color: #231F20;
}
.post-scroller__previous:not(.swiper-button-disabled):hover .o-icon,
.post-scroller__next:not(.swiper-button-disabled):hover .o-icon {
  color: #fff;
}

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

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

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

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

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

/*  ==========================================================================
    Post Scroller - Items
    ========================================================================== */
.post-item {
  display: flex;
  width: 100%;
  border-bottom: 1px solid #E5E5E5;
  transition: border-bottom 0.3s ease-in-out;
}
.post-item:hover {
  border-bottom: 2px solid var(--theme-color-dark);
}

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

.post-item__intrinsic-ratio {
  position: relative;
  height: 0;
  padding-bottom: 57.1428571429%;
  overflow: hidden;
}

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

.post-item__info {
  padding: 0 0 20px;
}

.post-item__content {
  display: flex;
  flex-direction: column;
}
@media (hover: hover) and (pointer: fine) {
  .post-item:hover .post-item__content {
    color: var(--theme-color-dark);
  }
}

.post-item__post-type {
  font-family: american-grotesk-compressed, 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__title {
  font-family: american-grotesk, sans-serif;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 0;
  line-height: normal;
  transition: color 0.4s ease;
}
@media (min-width: 62.5em) {
  .post-item__title {
    font-size: 24px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .post-item:hover .post-item__title {
    color: var(--theme-color-dark);
  }
}

/*  ==========================================================================
	Breadcrumb
	========================================================================== */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 5px;
  font-weight: 700;
  font-size: 14px;
}
.breadcrumb .o-icon {
  width: 15px;
  height: 15px;
  rotate: 180deg;
  transition: transform 0.4s ease;
}
@media (min-width: 50em) {
  .breadcrumb {
    font-size: 18px;
  }
  .breadcrumb .o-icon {
    width: 18px;
    height: 18px;
  }
}
@media (min-width: 62.5em) {
  .breadcrumb {
    font-size: 20px;
  }
}
.breadcrumb:hover .o-icon {
  transform: translateX(5px);
}

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

.article-list__inner {
  width: 100%;
  max-width: 1280px;
  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__grid {
  display: grid;
  gap: 30px;
}
@media (min-width: 32em) {
  .article-list__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px 15px;
  }
}
@media (min-width: 50em) {
  .article-list__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 62.5em) {
  .article-list__grid {
    gap: 30px;
  }
}
@media (min-width: 72em) {
  .article-list__grid {
    gap: 40px;
  }
}

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

/*  ==========================================================================
	Article List Header
	========================================================================== */
.article-list-header {
  position: relative;
  padding-top: 15px;
  padding-bottom: 10px;
  background-color: #fff;
}
@media (min-width: 72em) {
  .article-list-header {
    padding-bottom: 30px;
  }
}

.article-list-header__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-top: -111px;
}
@media (min-width: 50em) {
  .article-list-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 72em) {
  .article-list-header__inner {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    margin-top: 0;
    gap: 40px;
  }
}

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

.article-list-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.8;
  font-size: 42px;
}
@media (min-width: 50em) {
  .article-list-header__title {
    font-size: 72px;
  }
}
@media (min-width: 72em) {
  .article-list-header__title {
    font-size: 90px;
  }
}

@media (max-width: 71.99em) {
  .article-list-header__logo {
    visibility: hidden;
    width: 51px;
    height: 80px;
  }
}
.article-list-header__logo .o-icon {
  border: 0;
  width: 105px;
  height: 171px;
}

/*  ==========================================================================
    Article List Header - Category Switcher
    ========================================================================== */
.category-switcher {
  flex-shrink: 0;
  text-align: right;
  cursor: pointer;
}
body.category-switcher-open .category-switcher {
  color: #fff;
}
body:not(.nav-open) .category-switcher {
  z-index: 8;
}
@media (min-width: 32em) {
  .category-switcher {
    margin-top: -50px;
  }
}
@media (min-width: 72em) {
  .category-switcher {
    margin-top: 0;
    top: 12px;
    position: relative;
  }
}

.category-switcher__backdrop {
  position: fixed;
  content: "";
  background: rgba(0, 0, 0, 0.85);
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s;
}
body.category-switcher-open .category-switcher__backdrop {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
  z-index: 6;
}

.category-switcher__nav {
  position: relative;
}
body.category-switcher-open .category-switcher__nav {
  z-index: 7;
}

.category-switcher__title,
.category-switcher__link {
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 22px;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1;
  position: relative;
  margin-bottom: 0;
}

.category-switcher__title {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding-bottom: 10px;
  position: relative;
}
.category-switcher__title .o-icon {
  rotate: 90deg;
  width: 16px;
  height: 16px;
  transition: rotate 0.4s ease;
}
.category-switcher__title:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: #fff;
  right: 0;
  bottom: 0;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.5s ease;
}
body.category-switcher-open .category-switcher__title:before {
  transform: scaleX(100%);
}
body.category-switcher-open .category-switcher__title .o-icon {
  rotate: 270deg;
}

.category-switcher__list {
  display: none;
  flex-direction: column;
  gap: 10px;
  position: absolute;
  top: 100%;
  left: auto;
  right: 0;
  width: max-content;
  list-style: none;
  padding-top: 10px;
  padding-left: 0;
  z-index: 6;
}
body.category-switcher-open .category-switcher__list {
  display: flex;
}
@media (hover: hover) and (pointer: fine) {
  .category-switcher__list:hover .category-switcher__link {
    color: #999;
  }
}

.category-switcher__link {
  display: block;
  word-wrap: normal;
  transition: color 0.3s ease;
  width: auto;
  text-align: right;
  padding: 0;
  font-size: 24px;
}
@media (hover: hover) and (pointer: fine) {
  .category-switcher__link:hover {
    color: #fff !important;
  }
}

/*  ==========================================================================
	Article Header
	========================================================================== */
.article-header {
  position: relative;
  margin-top: 15px;
}

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

.article-header__content {
  display: flex;
  gap: 15px 30px;
  margin: 0 15px;
}
@media (min-width: 72em) {
  .article-header__content {
    margin: 0;
    padding: 0;
  }
}

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

.article-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: american-grotesk, sans-serif;
  font-weight: 700;
  width: 100%;
  font-size: 32px;
}
@media (min-width: 32em) {
  .article-header__title {
    font-size: 42px;
  }
}
@media (min-width: 50em) {
  .article-header__title {
    font-size: 56px;
  }
}
@media (min-width: 62.5em) {
  .article-header__title {
    font-size: 60px;
  }
}
@media (min-width: 72em) {
  .article-header__title {
    font-size: 72px;
  }
}

.article-header__category {
  font-family: american-grotesk-condensed, sans-serif;
  font-weight: 700;
  font-size: 18px;
  text-transform: uppercase;
  line-height: 1;
}
@media (min-width: 32em) {
  .article-header__category {
    font-size: 20px;
  }
}
@media (min-width: 50em) {
  .article-header__category {
    font-size: 24px;
  }
}
@media (min-width: 62.5em) {
  .article-header__category {
    font-size: 28px;
  }
}
@media (min-width: 72em) {
  .article-header__category {
    font-size: 32px;
  }
}

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

@media (max-width: 71.99em) {
  .article-header__logo {
    display: none;
  }
}
.article-header__logo .o-icon {
  border: 0;
  width: 105px;
  height: 171px;
}

.article-header__footer {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  flex-shrink: 0;
  gap: 5px 15px;
  width: 100%;
  margin-top: 20px;
  padding-top: 10px;
  border-top: 1px solid #231F20;
}
@media (min-width: 50em) {
  .article-header__footer {
    margin-top: 30px;
    padding-top: 5px;
  }
}

/*  ==========================================================================
	Article Header - Media
	========================================================================== */
.article-header__media {
  margin-top: 20px;
  position: relative;
}
@media (min-width: 72em) {
  .article-header__media {
    margin-top: 40px;
  }
}

.article-header__media--image,
.article-header__media--video {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-header__media--image,
  .article-header__media--video {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.article-header__media--audio {
  display: flex;
  background-color: #F0F0F0;
  padding: 20px 0;
}
@media (min-width: 50em) {
  .article-header__media--audio {
    padding: 40px 0;
  }
}

.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__figcaption {
  display: flex;
  flex-direction: column;
  align-self: flex-end;
  text-align: right;
  margin-top: 15px;
  font-size: 14px;
  max-width: 800px;
}
@media (min-width: 50em) {
  .article-header__figcaption {
    font-size: 16px;
  }
}

.article-header__video {
  aspect-ratio: 16/9;
}

.article-header__play {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 47px;
  height: 47px;
  inset: 0;
  margin: auto;
  padding: 14px;
  background-color: var(--theme-color-light);
  overflow: hidden;
  border-radius: 100%;
  cursor: pointer;
}
.article-header__play .o-icon {
  width: 100%;
  height: 100%;
  color: var(--theme-color-dark);
  position: relative;
  left: 2px;
}
@media (min-width: 32em) {
  .article-header__play {
    width: 69px;
    height: 69px;
    padding: 20px;
  }
}
@media (min-width: 62.5em) {
  .article-header__play {
    width: 100px;
    height: 100px;
    padding: 30px;
  }
  .article-header__play .o-icon {
    left: 4px;
  }
}

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

/*  ==========================================================================
	Event Inline
	========================================================================== */
.event-inline {
  background-color: #231F20;
  width: 100%;
}
.user-is-tabbing .event-inline a:focus {
  outline-color: #fff;
}

.event-inline__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 20px 15px;
  background-color: #231F20;
}
@media (min-width: 50em) {
  .event-inline__inner {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    display: grid;
    grid-template-columns: 170px 1fr auto;
    align-items: center;
  }
}
@media (min-width: 50em) and (min-width: 50em) {
  .event-inline__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 62.5em) {
  .event-inline__inner {
    gap: 30px;
    padding: 20px 30px;
  }
}
@media (min-width: 72em) {
  .event-inline__inner {
    gap: 40px;
  }
}

.event-inline__intrinsic-ratio {
  position: relative;
  padding-bottom: 55.5555555556%;
  height: 0;
  overflow: hidden;
}

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

.event-inline__content {
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: #fff;
}

.event-inline__title {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 32px;
  text-transform: uppercase;
  line-height: 0.9;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-inline__title {
    font-size: 36px;
  }
}
@media (min-width: 62.5em) {
  .event-inline__title {
    font-size: 38px;
  }
}
@media (min-width: 72em) {
  .event-inline__title {
    font-size: 42px;
  }
}

.event-inline__date {
  font-family: american-grotesk, sans-serif;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 0;
}

.event-inline__actions {
  display: flex;
  flex-direction: column;
  gap: 10px 15px;
}
@media (min-width: 42.5em) {
  .event-inline__actions {
    flex-direction: row;
  }
}
@media (min-width: 50em) {
  .event-inline__actions {
    flex-direction: column;
  }
}
@media (min-width: 62.5em) {
  .event-inline__actions {
    flex-direction: row;
  }
}

.event-inline__btn {
  width: 100%;
}

.event-inline__btn.btn--theme-light {
  color: var(--theme-color-dark);
}
@media (hover: hover) and (pointer: fine) {
  .event-inline__btn.btn--theme-light:hover {
    color: #fff;
  }
}

/*  ==========================================================================
	Event Inline - Sticky
	========================================================================== */
.event-inline--sticky {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 5;
  transform: translateY(-100%);
  transition: transform 0.4s ease;
}
@media (min-width: 62.5em) {
  .event-inline--sticky {
    display: block;
  }
  .event-inline--sticky.show {
    transform: translateY(0%);
  }
}
@media (min-width: 72em) {
  .event-inline--sticky.show {
    transform: translateY(calc(0% + var(--global-header-height)));
  }
}
.user-is-tabbing .event-inline--sticky a:focus {
  outline-color: #fff;
}

/*  ==========================================================================
	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: #231F20;
}
.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__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: 30em) {
  .page-grid__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px 25px;
  }
}
@media (min-width: 50em) {
  .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: 70%;
  height: 0;
  overflow: hidden;
}
@media (min-width: 62.5em) {
  .page-item__intrinsic-ratio {
    padding-bottom: 71.4285714286%;
  }
}

.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: american-grotesk-compressed, sans-serif;
  font-size: 28px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
  transition: color 0.4s ease;
}
@media (min-width: 50em) {
  .page-item__title {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .page-item__title {
    font-size: 36px;
  }
}
.page-item:hover .page-item__title {
  color: var(--theme-color-dark);
}

.page-item__description {
  margin-top: 10px;
  margin-bottom: 0;
  font-size: 16px;
}
@media (min-width: 50em) {
  .page-item__description {
    font-size: 18px;
  }
}

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

.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;
  position: relative;
}
@media (min-width: 50em) {
  .site-search__header-inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.site-search__title {
  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 #231F20;
  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: 10px;
}
@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-size: 16px;
  font-weight: 500;
  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: 4px;
  width: 100%;
  left: 0;
  bottom: -11px;
  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: -10px;
  }
}
.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-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__results {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}
@media (min-width: 50em) {
  .site-search__results {
    padding-left: 15px;
    padding-right: 15px;
  }
}

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

.search-result {
  display: block;
  padding-bottom: 20px;
  border-bottom: 1px solid #231F20;
  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;
}
.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 {
  display: none;
}
@media (min-width: 42.5em) {
  .search-result .search-result__content {
    display: block;
    margin-top: 0;
  }
}
.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;
  letter-spacing: 1.5px;
  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__content {
  margin: 15px 0 0;
  font-size: var(--global-body-text-small);
}
.search-result__content em {
  background-color: var(--theme-color);
  color: var(--theme-text-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;
}

.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: american-grotesk, 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;
}

.search-result__previous .pagination__link .o-icon {
  transform: rotate(180deg);
}

.pagination__item {
  padding: 0;
  background-color: var(--theme-color-dark);
  border: 2px solid var(--theme-color-dark);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px;
  margin-right: 7px;
  width: 31px;
  height: 31px;
  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 {
    border-color: #231F20;
    background-color: #231F20;
    color: #fff;
  }
}
.pagination__item:active .o-icon {
  scale: 0.9;
}

.pagination__item--disabled {
  opacity: 0.25;
  cursor: not-allowed;
}

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

/*  ==========================================================================
	Subscription Panel
	========================================================================== */
.subscription-panel {
  position: relative;
  margin: var(--content-margin);
}

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

.subscription-panel__subscriptions {
  display: flex;
  flex-direction: column;
  gap: 25px;
}
@media (min-width: 50em) {
  .subscription-panel__subscriptions {
    gap: 40px;
  }
}

.subscription {
  border-top: 1px solid #C0C0C0;
  padding-top: 20px;
}
@media (min-width: 50em) {
  .subscription {
    padding-top: 30px;
  }
}

.subscription__header {
  margin-bottom: 20px;
}
@media (min-width: 50em) {
  .subscription__header {
    margin-bottom: 30px;
  }
}

.subscription__prefix,
.subscription__suffix,
.subscription__prices {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 18px;
  text-transform: uppercase;
  line-height: 0.7;
}
@media (min-width: 50em) {
  .subscription__prefix,
  .subscription__suffix,
  .subscription__prices {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .subscription__prefix,
  .subscription__suffix,
  .subscription__prices {
    font-size: 24px;
  }
}

.subscription__title {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 28px;
  text-transform: uppercase;
  text-wrap: pretty;
}
@media (min-width: 50em) {
  .subscription__title {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .subscription__title {
    font-size: 38px;
  }
}

.subscription__prices {
  display: flex;
  flex-wrap: wrap;
  gap: 7px 0;
}
.subscription__prices > span:last-child {
  padding-left: 5px;
}

.subscription__price {
  color: var(--theme-color-dark);
}

.subscription__content.s-prose {
  line-height: 1.6;
}

.subscription__content.s-prose ul:only-child {
  margin: 20px 0;
}
@media (min-width: 50em) {
  .subscription__content.s-prose ul:only-child {
    margin: 30px 0;
  }
}

.subscription__content.s-prose li {
  margin-bottom: 5px;
}

/*  ==========================================================================
    Image
    ========================================================================== */
.image-block {
  margin: var(--content-margin);
}

.image-block__inner {
  width: 100%;
  max-width: 1280px;
  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;
  }
}

.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;
  margin-top: 15px;
  font-size: 14px;
  max-width: 800px;
}
@media (min-width: 50em) {
  .image-block__figcaption {
    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%;
  }
}

/*  ==========================================================================
	Feature Card Scroller
	========================================================================== */
.featured-card-scroller {
  background-color: var(--theme-color-dark);
  color: #fff;
  position: relative;
  padding: 40px 0;
  overflow: hidden;
}
@media (min-width: 50em) {
  .featured-card-scroller {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .featured-card-scroller {
    padding: 60px 0 80px;
  }
}
.featured-card-scroller:last-child {
  margin-bottom: 0;
}
.user-is-tabbing .featured-card-scroller a:focus {
  outline-color: #fff;
}

@media (min-width: 62.5em) {
  .featured-card-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) {
  .featured-card-scroller__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

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

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

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

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

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

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

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

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

/*  ==========================================================================
    Feature Card Scroller - Items
    ========================================================================== */
.feature-card-item {
  background-color: #fff;
  color: #000;
}
.user-is-tabbing .feature-card-item a:focus {
  outline-color: #fff;
}

.feature-card-item__actions {
  margin-top: auto;
}

.feature-card-item__btn {
  color: var(--theme-color-dark);
  background-color: transparent;
  box-shadow: inset 0 0 0 2px var(--theme-color-dark);
  padding-left: 0;
  padding-right: 0;
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .feature-card-item:hover .feature-card-item__btn {
    color: white;
  }
  .feature-card-item__btn:hover {
    color: #fff;
    background-color: transparent;
  }
}

.feature-card-item {
  display: flex;
  width: 100%;
  border-bottom: 1px solid #E5E5E5;
}

.feature-card-item__inner {
  display: flex;
  flex-direction: column;
  gap: 15px;
  height: 100%;
  width: 100%;
}

.feature-card-item__container {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding: 0 15px 15px;
}

.feature-card-item__media {
  overflow: hidden;
  position: relative;
  padding-bottom: 60%;
  height: 0;
}

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

.feature-card-item__content {
  display: flex;
  flex-direction: column;
  min-height: 220px;
  word-break: break-word;
}

.feature-card-item__description {
  margin-bottom: 30px;
  font-size: 18px;
}
.feature-card-item__description p {
  margin-bottom: 0;
}

.feature-card-item__prefix {
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 62.5em) {
  .feature-card-item__prefix {
    font-size: 18px;
  }
}

.feature-card-item__title {
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 24px;
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 15px;
  line-height: normal;
  transition: color 0.4s ease;
}
@media (min-width: 62.5em) {
  .feature-card-item__title {
    font-size: 32px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .feature-card-item:hover .feature-card-item__title {
    color: var(--theme-color-dark);
  }
}

@media (hover: hover) and (pointer: fine) {
  .feature-card-item:hover .feature-card-item__btn:after {
    background-color: #000;
    transform: scaleX(100%);
  }
}

/*  ==========================================================================
	Featured Posts Content Block
	========================================================================== */
.featured-posts {
  position: relative;
  margin: var(--content-margin);
  padding-bottom: 40px;
}

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

.featured-posts__title {
  margin-bottom: 30px;
  text-transform: uppercase;
}

@media (min-width: 72em) {
  .featured-posts__content {
    display: flex;
    align-items: flex-start;
  }
}

/*  ==========================================================================
	Featured Post (Headline Post)
	========================================================================== */
@media (min-width: 72em) {
  .featured-post {
    width: 50%;
    position: sticky;
    top: calc(30px + var(--global-header-height));
  }
}

.featured-post-item {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #E5E5E5;
}
@media (min-width: 58em) {
  .featured-post-item {
    flex-direction: row;
  }
}
@media (min-width: 62.5em) {
  .featured-post-item {
    flex-direction: column;
  }
}

.featured-post-item__media {
  overflow: hidden;
  width: 100%;
}
@media (min-width: 58em) {
  .featured-post-item__media {
    width: 50%;
  }
}
@media (min-width: 62.5em) {
  .featured-post-item__media {
    width: 100%;
  }
}

.featured-post-item__intrinsic-ratio {
  position: relative;
  height: 0;
  padding-bottom: 60%;
  overflow: hidden;
}

.featured-post-item__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
  .featured-post:hover .featured-post-item__image {
    transform: scale(1.05);
  }
}

.featured-post-item__content {
  width: 100%;
}
@media (min-width: 58em) {
  .featured-post-item__content {
    width: 45%;
  }
}
@media (min-width: 62.5em) {
  .featured-post-item__content {
    width: 100%;
  }
}

.featured-post-item__title {
  font-family: american-grotesk, sans-serif;
  font-size: 28px;
  font-weight: 700;
}
@media (min-width: 42.5em) {
  .featured-post-item__title {
    font-size: 38px;
  }
}
@media (min-width: 50em) {
  .featured-post-item__title {
    font-size: 48px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .featured-post:hover .featured-post-item__title {
    color: var(--theme-color-dark);
  }
}

.featured-post-item__post-type {
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 62.5em) {
  .featured-post-item__post-type {
    font-size: 18px;
  }
}

/*  ==========================================================================
	Featured Post List
	========================================================================== */
.featured-posts__list {
  display: flex;
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch;
  margin-left: -15px;
  margin-right: -15px;
  padding-left: 15px;
}
.featured-posts__list::-webkit-scrollbar {
  display: none;
}
@media (min-width: 72em) {
  .featured-posts__list {
    display: block;
    width: 680px;
    flex-shrink: 0;
    padding-left: 40px;
    margin: 0;
  }
}

/*  ==========================================================================
	Featured Posts Items
	========================================================================== */
.featured-posts__item {
  width: 300px;
  flex-shrink: 0;
  padding-right: 15px;
}
.featured-posts__item .posts-item {
  padding-bottom: 0;
  background: none;
}
@media (min-width: 50em) {
  .featured-posts__item {
    width: 400px;
  }
}
@media (min-width: 72em) {
  .featured-posts__item {
    width: 100%;
  }
}
.featured-posts__item .post-item {
  height: 100%;
  margin-bottom: 20px;
}
@media (min-width: 72em) {
  .featured-posts__item .post-item {
    padding-bottom: 20px;
  }
}
.featured-posts__item .post-item__media {
  width: 100%;
}
@media (min-width: 72em) {
  .featured-posts__item .post-item__media {
    width: 40%;
    flex-shrink: 0;
  }
}
.featured-posts__item .post-item__inner {
  flex-direction: column;
}
@media (min-width: 72em) {
  .featured-posts__item .post-item__inner {
    flex-direction: row;
    align-items: center;
  }
}
.featured-posts__item .post-item__info {
  width: 90%;
}
@media (min-width: 72em) {
  .featured-posts__item .post-item__info {
    width: 60%;
  }
}

/*  ==========================================================================
	Podcast Embed
	========================================================================== */
.podcast-embed {
  margin: var(--content-margin);
}

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

.podcast-embed__title {
  margin-bottom: 0;
  padding-top: 10px;
  border-top: 1px solid #231F20;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .podcast-embed__title {
    padding-top: 15px;
  }
}

.podcast-embed__media {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  background-color: #F0F0F0;
  margin-top: 20px;
  padding: 20px;
}
@media (min-width: 50em) {
  .podcast-embed__media {
    padding: 40px;
  }
}
@media (min-width: 72em) {
  .podcast-embed__media {
    margin-top: 40px;
  }
}

@media (max-width: 49.99em) {
  .podcast-embed__audio {
    height: 100px;
  }
}

/*  ==========================================================================
	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;
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 50em) {
  .season-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@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: american-grotesk-compressed, 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: american-grotesk-compressed, 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;
  display: flex;
  flex-direction: column;
}
@media (min-width: 50em) {
  .season-info__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@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);
  }
}

/*  ==========================================================================
	Event Grid
	========================================================================== */
.event-grid {
  position: relative;
  padding: 20px 0;
  overflow: hidden;
  background-color: var(--theme-color-dark);
}
.event-grid:last-child {
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-grid {
    padding: 60px 0;
  }
}
.user-is-tabbing .event-grid a:focus {
  outline-color: #fff;
}

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

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

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

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

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

/*  ==========================================================================
    Home Hero
    ========================================================================== */
.home-hero {
  background-color: var(--theme-color-dark);
  position: relative;
  overflow: hidden;
}

@media (max-width: 71.99em) {
  .page:has(.home-hero) .global-group {
    position: fixed;
  }
  .page:has(.home-hero).nav-open .global-group {
    z-index: 8;
  }
}
.page:has(.home-hero) .content-blocks {
  position: relative;
  background-color: #fff;
  z-index: 2;
}

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

.home-hero__logo {
  position: fixed;
  z-index: 2;
  top: calc(var(--global-header-height) + 40px);
  left: 0;
  width: 100%;
}
@media (max-width: 71.99em) {
  .home-hero__logo {
    display: none;
  }
}
.home-hero__logo .o-icon {
  width: 105px;
  height: 171px;
}

.home-hero--primary,
.home-hero--secondary {
  position: sticky;
  top: 0;
  max-height: 95svh;
}
@media (min-width: 62.5em) {
  .home-hero--primary,
  .home-hero--secondary {
    max-height: 85svh;
  }
}
@media (min-width: 72em) {
  .home-hero--primary,
  .home-hero--secondary {
    top: var(--global-header-height);
    max-height: 85svh;
  }
}

.home-hero__media {
  position: relative;
  z-index: 0;
}

.home-hero__intrinsic-ratio {
  position: relative;
  padding-bottom: 180%;
  height: 0;
}
@media (min-width: 62.5em) {
  .home-hero__intrinsic-ratio {
    padding-bottom: 50%;
  }
}

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

.home-hero__body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: absolute;
  bottom: 0;
  padding-bottom: 15px;
  width: 100%;
  height: 100%;
  z-index: 2;
}
@media (min-width: 72em) {
  .home-hero__body {
    padding: 40px 0;
  }
}

.home-hero__content {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  width: 100%;
  color: #fff;
}
@media (min-width: 50em) {
  .home-hero__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (max-width: 71.99em) {
  .home-hero__content {
    justify-content: flex-end;
  }
}

.home-hero__info-container {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
}
@media (min-width: 50em) {
  .home-hero__info-container {
    flex-direction: row;
    align-items: flex-end;
    gap: 30px;
  }
}
.home-hero__info-container::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 75%;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(255, 255, 255, 0.01));
  pointer-events: none;
}

.home-hero__tag {
  width: fit-content;
  padding: 6px 10px;
  margin-bottom: 0;
  border-radius: 3px;
  background: var(--theme-color-dark);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  border: 1px solid rgba(255, 255, 255, 0.5);
}
@media (min-width: 50em) {
  .home-hero__tag {
    font-size: 16px;
    padding: 6px 12px 8px 12px;
  }
}
.home-hero__tag.home-hero__tag--next {
  background: #fff;
  color: var(--theme-color-dark);
  border: 1px solid var(--theme-color-dark);
}

.home-hero__info {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-bottom: 15px;
  width: 100%;
}
@media (min-width: 50em) {
  .home-hero__info {
    padding-bottom: 0;
    width: 50%;
  }
}

.home-hero__titles {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.home-hero__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.85;
}
@media (min-width: 62.5em) {
  .home-hero__title {
    line-height: 0.8;
  }
}

.home-hero__title--1,
.home-hero__title--3 {
  font-size: 22px;
}
@media (min-width: 50em) {
  .home-hero__title--1,
  .home-hero__title--3 {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .home-hero__title--1,
  .home-hero__title--3 {
    font-size: 48px;
  }
}

@media (min-width: 62.5em) {
  .home-hero__title--1 {
    margin-bottom: 3px;
  }
}

.home-hero__title--3 {
  margin-top: 3px;
}
@media (min-width: 62.5em) {
  .home-hero__title--3 {
    margin-top: 4px;
  }
}

.home-hero__prefix,
.home-hero__suffix {
  font-weight: 700;
  font-size: 18px;
}
@media (min-width: 50em) {
  .home-hero__prefix,
  .home-hero__suffix {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .home-hero__prefix,
  .home-hero__suffix {
    font-size: 22px;
  }
}

.home-hero__links {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 15px;
}
@media (min-width: 62.5em) {
  .home-hero__links {
    gap: 5px 25px;
  }
}

.home-hero__link {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--theme-color-light);
  cursor: pointer;
  transition: color 0.4s ease;
}
@media (min-width: 50em) {
  .home-hero__link {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .home-hero__link {
    font-size: 22px;
  }
}
.home-hero__link .o-icon {
  width: 23px;
  height: 23px;
}
.home-hero__link:hover {
  color: #fff;
}
.user-is-tabbing .home-hero__link:focus {
  outline: 2px solid #fff;
}

.home-hero__event-details {
  position: relative;
  border-top: 1px solid #F0F0F0;
  padding-top: 15px;
}
@media (min-width: 50em) {
  .home-hero__event-details {
    border-top: none;
    padding-top: 0;
    flex-grow: 1;
    text-align: right;
  }
}
.home-hero__event-details .event-btns {
  position: unset;
  background-color: unset;
  box-shadow: unset;
  padding: 0;
}
@media (min-width: 50em) {
  .home-hero__event-details .event-btns {
    justify-content: flex-end;
  }
}
.home-hero__event-details .event-btns .event-btns__btn:first-child {
  background-color: var(--theme-color-light);
  color: var(--theme-color-dark);
  box-shadow: unset;
}
.home-hero__event-details .event-btns .event-btns__btn:first-child:hover {
  color: #181822;
}
.home-hero__event-details .event-btns .event-btns__btn:first-child:after {
  background-color: #fff;
}
.home-hero__event-details .event-btns .event-btns__btn {
  box-shadow: inset 0 0 0 2px white;
  color: #fff;
}
.user-is-tabbing .home-hero__event-details .event-btns .event-btns__btn:focus {
  outline: 2px solid #fff;
}

.home-hero__dates {
  font-family: american-grotesk, sans-serif;
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 15px;
}
@media (min-width: 30em) {
  .home-hero__dates {
    font-size: 18px;
  }
}
@media (min-width: 50em) {
  .home-hero__dates {
    margin-bottom: 10px;
  }
}
@media (min-width: 42.5em) {
  .home-hero__dates {
    font-size: 24px;
  }
}

/*  ========================================================================== */
/*  Header Video
/*  ========================================================================== */
.header__video {
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  width: 2000px;
  height: 100%;
  opacity: 0;
  transition: opacity 1s ease 1s;
  z-index: 2;
}
@media (min-width: 42.5em) {
  .header__video {
    width: 3000px;
  }
}
@media (min-width: 62.5em) {
  .header__video {
    width: 110%;
    height: 150%;
  }
}
.header__video iframe {
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  width: 100%;
  height: 100%;
}

.header__video--loaded .header__video,
.header__video--loaded .header__video-overlay,
.header__video--loaded .header__video-btn {
  opacity: 1;
}

.header__video-overlay {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}

.header__video-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 5px;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 38px;
  height: 38px;
  margin: 15px;
  color: #fff;
  background-color: #000;
  border: 1px solid #707070;
  border-radius: 15px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 1s ease;
  z-index: 3;
  text-decoration: none;
}
.header__video-btn:focus, .header__video-btn:hover {
  text-decoration: none;
  background-color: #000;
}
.header__video-btn .o-icon {
  width: 12px;
  height: 12px;
}
@media (max-width: 31.99em) {
  .header__video-btn {
    z-index: 8;
  }
  .nav-open .header__video-btn {
    z-index: 3;
  }
}
@media (min-width: 50em) {
  .header__video-btn {
    width: 43px;
    height: 43px;
  }
  .header__video-btn .o-icon {
    width: 15px;
    height: 15px;
  }
}
@media (min-width: 62.5em) {
  .header__video-btn {
    width: 48px;
    height: 48px;
    margin: 20px;
  }
}
.header__video-btn .header__video-btn--play,
.header__video-btn .header__video-btn--pause {
  display: none;
}
.header__video-btn.paused .header__video-btn--play {
  display: block;
}
.header__video-btn.paused .header__video-btn--pause {
  display: none;
}
.header__video-btn:not(.paused) .header__video-btn--play {
  display: none;
}
.header__video-btn:not(.paused) .header__video-btn--pause {
  display: block;
}

/*  ==========================================================================
	Venue Header
	========================================================================== */
.venue-header {
  position: relative;
  margin-top: 15px;
}

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

.venue-header__content {
  display: flex;
  gap: 15px 30px;
  margin-top: -110px;
  margin-left: 78px;
  padding-right: 60px;
}
@media (min-width: 72em) {
  .venue-header__content {
    margin: 0;
    padding: 0;
  }
}

.venue-header__details {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 100%;
  align-self: flex-end;
}

.venue-header__titles {
  display: flex;
  flex-direction: column;
}

.venue-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.8;
}

.venue-header__prefix,
.venue-header__suffix {
  font-family: american-grotesk-compressed, sans-serif;
  font-weight: 800;
  font-size: 22px;
  text-transform: uppercase;
  line-height: 0.8;
}
@media (min-width: 50em) {
  .venue-header__prefix,
  .venue-header__suffix {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .venue-header__prefix,
  .venue-header__suffix {
    font-size: 48px;
  }
}

@media (min-width: 62.5em) {
  .venue-header__prefix {
    margin-bottom: 3px;
  }
}

.venue-header__suffix {
  margin-top: 3px;
}
@media (min-width: 62.5em) {
  .venue-header__suffix {
    margin-top: 4px;
  }
}

@media (max-width: 71.99em) {
  .venue-header__logo {
    display: none;
  }
}
.venue-header__logo .o-icon {
  border: 0;
  width: 105px;
  height: 171px;
}

.venue-header__media {
  display: flex;
  flex-direction: column;
  margin-top: 15px;
  margin-bottom: 0;
}
@media (min-width: 30em) {
  .venue-header__media {
    margin-top: 10px;
  }
}
@media (min-width: 50em) {
  .venue-header__media {
    margin-top: 20px;
  }
}
@media (min-width: 72em) {
  .venue-header__media {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 40px;
  }
}
@media (min-width: 72em) and (min-width: 50em) {
  .venue-header__media {
    padding-left: 15px;
    padding-right: 15px;
  }
}

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

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

.venue-header__figcaption {
  display: flex;
  flex-direction: column;
  align-self: flex-end;
  text-align: right;
  margin-top: 15px;
  padding: 0 15px;
  font-size: 14px;
  max-width: 800px;
}
@media (min-width: 50em) {
  .venue-header__figcaption {
    font-size: 16px;
  }
}
@media (min-width: 72em) {
  .venue-header__figcaption {
    padding: 0;
  }
}

/*  ==========================================================================
	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: #231F20;
}
.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: 70%;
  height: 0;
  overflow: hidden;
}
@media (min-width: 62.5em) {
  .venue-item__intrinsic-ratio {
    padding-bottom: 71.4285714286%;
  }
}

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

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

.venue-item__title {
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 28px;
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
  transition: color 0.4s ease;
}
@media (min-width: 50em) {
  .venue-item__title {
    font-size: 32px;
  }
}
@media (min-width: 62.5em) {
  .venue-item__title {
    font-size: 36px;
  }
}
.venue-item:hover .venue-item__title {
  color: var(--theme-color-dark);
}

.venue-item__prefix,
.venue-item__suffix {
  display: block;
  font-family: american-grotesk-compressed, sans-serif;
  font-size: 18px;
  font-weight: 800;
  line-height: 0.8;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .venue-item__prefix,
  .venue-item__suffix {
    font-size: 24px;
  }
}

.venue-item__description {
  margin-top: 10px;
  margin-bottom: 0;
  font-size: 16px;
}
@media (min-width: 50em) {
  .venue-item__description {
    font-size: 18px;
  }
}

/*  ==========================================================================
	Event Header Alt
	========================================================================== */
.event-header--alt .event-header__content {
  flex-direction: column;
}
.event-header--alt .event-header__archived-message {
  font-size: 16px;
  margin-bottom: 10px;
}
.event-header--alt .event-header__archived-link {
  --link-color: var(--theme-color-dark);
  --focus-color: var(--theme-color-dark);
  font-weight: 700;
  color: var(--theme-color-dark);
  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;
  }
}
.event-header--alt .event-header__archived-link:visited {
  color: var(--link-color);
}
.event-header--alt .event-header__archived-link:hover, .event-header--alt .event-header__archived-link:focus {
  animation-name: ButtonLine;
  animation-duration: 0.75s;
}
.event-header--alt .event-header__media {
  padding: 0;
  max-width: none;
}
.event-header--alt .event-header__intrinsic-ratio {
  padding-bottom: 80%;
}
@media (min-width: 50em) {
  .event-header--alt {
    width: 100%;
    max-width: 1280px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    gap: 40px;
    margin-bottom: 40px;
  }
}
@media (min-width: 50em) and (min-width: 50em) {
  .event-header--alt {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 50em) {
  .event-header--alt > * {
    width: 50%;
  }
  .event-header--alt .event-header__header {
    display: flex;
    gap: 30px;
  }
  .event-header--alt .event-header__inner {
    padding: 0;
  }
  .event-header--alt .event-header__content {
    gap: 40px;
    padding-right: 0;
    margin-top: 0;
    margin-left: 0;
  }
  .event-header--alt .event-header__media {
    margin-top: 0;
  }
  .event-header--alt .event-header__footer {
    width: 100%;
    align-items: flex-start;
  }
  .event-header--alt .event-header__archived-message {
    font-size: 20px;
  }
}
@media (min-width: 72em) {
  .event-header--alt > * {
    width: 50%;
  }
  .event-header--alt .event-header__archived-message {
    font-size: 22px;
  }
}

/* ==========================================================================
   Widgets
   ========================================================================== */
/*  ==========================================================================
	Calendar List
	========================================================================== */
.calendar__list {
  order: 2;
  width: 100%;
}
@media (min-width: 62.5em) {
  .calendar__list {
    order: 1;
    flex-grow: 1;
    flex-shrink: 1;
    width: auto;
  }
}

.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: #231F20;
  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: american-grotesk, 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 #231F20;
  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;
  margin: auto;
  padding: 0;
  width: 100%;
  background-color: transparent;
}
@media (min-width: 50em) {
  .calendar-popup {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (max-width: 49.99em) {
  .calendar-popup {
    height: 100%;
    max-width: 100%;
    max-height: 100%;
  }
}

.calendar-popup__inner {
  background-color: #fff;
}
@media (max-width: 49.99em) {
  .calendar-popup__inner {
    padding: 0;
    overflow-y: auto;
    height: 100%;
  }
}

.calendar-popup__close {
  position: fixed;
  top: 15px;
  right: 10px;
  padding: 5px;
  margin: 0;
  border: 0;
  color: #231F20;
  background-color: #fff;
  border-radius: 5px;
  z-index: 3;
}
@media (min-width: 50em) {
  .calendar-popup__close {
    color: var(--theme-color-light);
    background-color: transparent;
    top: 40px;
    right: 40px;
  }
}
@media (min-width: 50em) and (hover: hover) and (pointer: fine) {
  .calendar-popup__close:hover {
    color: #fff;
  }
}

.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: american-grotesk-compressed, 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 #E5E5E5;
  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: 0 -15px;
  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;
}

/* ==========================================================================
   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;
  padding: 20px;
  border: none;
  border-radius: 15px;
}
@media (min-width: 50em) {
  :where([data-component*=dialog]) {
    padding-left: 15px;
    padding-right: 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, .accessibility-panel__info, .accessible-item__seats {
  padding: 0;
  border: 0;
  outline: none;
  background: transparent;
}

/* ==========================================================================
   Utilities: Tones
   ========================================================================== */
.u-tone-primary {
  color: #3B004A;
}

.u-tone-bg-tint {
  color: contrasting(#F0F0F0, , #231F20);
  background-color: #F0F0F0;
  border-color: currentColor;
}

.u-tone-bg-primary {
  color: contrasting(#3B004A, , #231F20);
  background-color: #3B004A;
  border-color: currentColor;
  color: #fff;
}

.u-tone-bg-dark {
  color: contrasting(#231F20, , #231F20);
  background-color: #231F20;
  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 */
