@charset "UTF-8";
/* Baseplate */
/* ==========================================================================
   Settings & Tools
   ========================================================================== */
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Thin.woff2") format("woff2"), url("GT-Ultra-Fine-Thin.woff") format("woff");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Thin-Italic.woff2") format("woff2"), url("GT-Ultra-Fine-Thin-Italic.woff") format("woff");
  font-weight: 100;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Light.woff2") format("woff2"), url("GT-Ultra-Fine-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Light-Italic.woff2") format("woff2"), url("GT-Ultra-Fine-Light-Italic.woff") format("woff");
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Regular.woff2") format("woff2"), url("GT-Ultra-Fine-Regular.woff") format("woff");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Regular-Italic.woff2") format("woff2"), url("GT-Ultra-Fine-Regular-Italic.woff") format("woff");
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Bold.woff2") format("woff2"), url("GT-Ultra-Fine-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Bold-Italic.woff2") format("woff2"), url("GT-Ultra-Fine-Bold-Italic.woff") format("woff");
  font-weight: 700;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Black.woff2") format("woff2"), url("GT-Ultra-Fine-Black.woff") format("woff");
  font-weight: 800;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-fine";
  src: url("GT-Ultra-Fine-Black-Italic.woff2") format("woff2"), url("GT-Ultra-Fine-Black-Italic.woff") format("woff");
  font-weight: 800;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Thin.woff2") format("woff2"), url("GT-Ultra-Standard-Thin.woff") format("woff");
  font-weight: 100;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Thin-Italic.woff2") format("woff2"), url("GT-Ultra-Standard-Thin-Italic.woff") format("woff");
  font-weight: 100;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Light.woff2") format("woff2"), url("GT-Ultra-Standard-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Light-Italic.woff2") format("woff2"), url("GT-Ultra-Standard-Light-Italic.woff") format("woff");
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Regular.woff2") format("woff2"), url("GT-Ultra-Standard-Regular.woff") format("woff");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Regular-Italic.woff2") format("woff2"), url("GT-Ultra-Standard-Regular-Italic.woff") format("woff");
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Bold.woff2") format("woff2"), url("GT-Ultra-Standard-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Bold-Italic.woff2") format("woff2"), url("GT-Ultra-Standard-Bold-Italic.woff") format("woff");
  font-weight: 700;
  font-style: italic;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Black.woff2") format("woff2"), url("GT-Ultra-Standard-Black.woff") format("woff");
  font-weight: 800;
  font-style: normal;
}
@font-face {
  font-family: "gt-ultra-standard";
  src: url("GT-Ultra-Standard-Black-Italic.woff2") format("woff2"), url("GT-Ultra-Standard-Black-Italic.woff") format("woff");
  font-weight: 800;
  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: #000;
  background-color: #fff;
  /**
   * Sticky footer
   * https://philipwalton.github.io/solved-by-flexbox/demos/sticky-footer/
   */
  display: flex;
  min-height: 100vh;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
}
body:before {
  content: "";
  display: block;
  backdrop-filter: blur(4px);
  background-color: rgba(0, 0, 0, 0.8);
  position: fixed;
  z-index: 20;
  width: 100%;
  height: 100svh;
  top: 0;
  left: 0;
  opacity: 0;
  visibility: hidden;
}
body.nav-open {
  overflow: hidden;
}
body.nav-open .calendar__sidebar {
  z-index: 5;
}
body.nav-open .global-header {
  background-color: #000;
}
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: sticky;
  top: 0;
  z-index: 8;
}
@media (min-width: 72em) {
  .glightbox-open .global-group {
    position: fixed;
  }
}

.body-text {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 300;
  font-size: var(--global-body-text);
  text-wrap: pretty;
  line-height: 1.4;
}

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

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

.sub-header {
  margin: 0 0 15px;
  line-height: 1.2;
  text-wrap: pretty;
  font-weight: 400;
  font-family: gt-ultra-standard, sans-serif;
  --global-header-size-h1: var(--global-header-size-4);
  --global-header-size-h2: var(--global-header-size-3);
  --global-header-size-h3: var(--global-header-size-2);
  --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-0);
}
@media (min-width: 23em) {
  .sub-header {
    --global-header-size-h1: var(--global-header-size-6);
    --global-header-size-h2: var(--global-header-size-4);
    --global-header-size-h3: var(--global-header-size-3);
    --global-header-size-h4: var(--global-header-size-2);
    --global-header-size-h5: var(--global-header-size-1);
    --global-header-size-h6: var(--global-header-size-0);
  }
}
@media (min-width: 30em) {
  .sub-header {
    --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-4);
    --global-header-size-h4: var(--global-header-size-2);
    --global-header-size-h5: var(--global-header-size-1);
    --global-header-size-h6: var(--global-header-size-0);
  }
}
@media (min-width: 50em) {
  .sub-header {
    --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-3);
    --global-header-size-h5: var(--global-header-size-2);
    --global-header-size-h6: var(--global-header-size-1);
  }
}
@media (min-width: 62.5em) {
  .sub-header {
    --global-header-size-h1: var(--global-header-size-9);
    --global-header-size-h2: var(--global-header-size-8);
    --global-header-size-h3: var(--global-header-size-5);
    --global-header-size-h4: var(--global-header-size-3);
    --global-header-size-h5: var(--global-header-size-2);
    --global-header-size-h6: var(--global-header-size-1);
  }
}

.spacer {
  height: 40vh;
}

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

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

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

/**
 * ff-* classes chained to avoid fonts-loaded specificity
 */
html, body, button, input, select, textarea, .ff-body.ff-body {
  font-family: gt-ultra-standard, 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, .h1 {
  font-size: var(--global-header-size-h1);
}

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

h3, .h3, .event-components .event-scroller__title {
  font-size: var(--global-header-size-h3);
}

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

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

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

h1, .h1, h2, .h2, h3, .h3, .event-components .event-scroller__title, h4, .h4, h5, .h5, h6, .h6 {
  line-height: 1;
  margin: 0 0 0.5rem;
  color: inherit;
  font-family: gt-ultra-fine, 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;
}

ul.lines {
  display: flex;
  flex-direction: column;
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 300;
  list-style: none;
  margin: 30px 0;
  padding: 0;
}
ul.lines li {
  margin-bottom: 10px;
  margin-left: 5px;
  padding: 0 15px 10px;
  padding-left: 1.2em;
  border: solid #757575;
  border-width: 0 0 1px 0;
}
ul.lines li:last-child {
  padding-bottom: 0;
  margin-bottom: 0;
  border-bottom: 0;
}

blockquote {
  margin: 0;
}

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

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

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

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

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

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

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

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

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

.skip-link {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  background-color: rgba(255, 255, 255, 0.92);
  color: #181822;
  font-family: gt-ultra-fine, 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: gt-ultra-standard, sans-serif !important;
  font-size: var(--global-header-size-h1) !important;
}

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

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

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

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

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

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

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

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

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

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

.s-prose h1,
.s-prose h2,
.s-prose h3,
.s-prose h4,
.s-prose h5,
.s-prose h6 {
  margin: 0 0 15px;
  line-height: 1.2;
  text-wrap: pretty;
  font-weight: 400;
  font-family: gt-ultra-standard, sans-serif;
}
.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;
}
.s-prose h2:first-child,
.s-prose h3:first-child,
.s-prose h4:first-child,
.s-prose h5:first-child,
.s-prose h6:first-child {
  margin-top: 0;
}
.s-prose h2:last-child,
.s-prose h3:last-child,
.s-prose h4:last-child,
.s-prose h5:last-child,
.s-prose h6:last-child {
  margin-bottom: 0;
}
.s-prose h2 {
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}
.s-prose p:last-of-type {
  margin-bottom: 0;
}
.s-prose p {
  margin: var(--global-body-text) 0 0;
  text-wrap: pretty;
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 300;
}
.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):not(.lead),
.s-prose ul,
.s-prose ol,
.s-prose dl {
  font-size: var(--global-body-text);
  line-height: 1.4;
}
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button),
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):visited,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):hover,
.s-prose a:not(.inline-button):not(.btn):not([data-component*=dialog] menu button):active {
  text-decoration: underline;
}
.s-prose .btn, .s-prose :where([data-component*=dialog] menu button) {
  margin-top: 30px;
  margin-bottom: 30px;
}
.s-prose .inline-button {
  margin: 5px 10px 5px 0;
}
.s-prose .fluid-width-video-wrapper {
  margin-bottom: 1em;
}
.s-prose hr {
  max-width: 15em;
  margin: 2em auto;
  border: none;
  border-top: 1px solid #6A6A6A;
}
.s-prose .inline-video {
  margin: 20px -20px;
}
.s-prose small {
  font-size: var(--global-body-text-small);
}
.s-prose .lead {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 300;
  font-size: var(--global-body-text-big);
  line-height: 1.3;
}
.s-prose pre {
  margin: 30px 0;
  padding: 30px;
  background-color: #000;
  color: #5aff75;
  white-space: pre-wrap;
}
.s-prose ul,
.s-prose ol {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 300;
  margin: 30px 0;
}
.s-prose ul li,
.s-prose ol li {
  margin-bottom: 15px;
}
.s-prose ul {
  list-style: none;
  padding: 0;
}
.s-prose ul:not(.lines) li {
  position: relative;
  padding-left: 1.2em;
  margin-left: 5px;
}
.s-prose ul:not(.lines) li::before {
  position: absolute;
  content: "";
  top: 4px;
  left: 0;
  width: 0.8em;
  height: 0.8em;
  background-image: url('data:image/svg+xml,<svg viewBox="0 0 363 367" xmlns="http://www.w3.org/2000/svg"><path d="M363 183.5C291.747 217.983 221.247 287.087 181.5 367C141.753 287.087 71.2637 217.983 0 183.5C71.2534 149.017 141.753 79.9129 181.5 0C221.247 79.9129 291.736 149.017 363 183.5Z"/></svg>');
  background-size: 100%;
  background-position: center;
}
@media (min-width: 30em) {
  .s-prose ul:only-child,
  .s-prose ol:only-child {
    margin: 0;
  }
}
@media (min-width: 50em) {
  .s-prose .inline-video {
    margin: 40px -40px;
  }
}
.s-prose {
  --global-header-size-h1: var(--global-header-size-4);
  --global-header-size-h2: var(--global-header-size-3);
  --global-header-size-h3: var(--global-header-size-2);
  --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-0);
}
@media (min-width: 23em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-6);
    --global-header-size-h2: var(--global-header-size-4);
    --global-header-size-h3: var(--global-header-size-3);
    --global-header-size-h4: var(--global-header-size-2);
    --global-header-size-h5: var(--global-header-size-1);
    --global-header-size-h6: var(--global-header-size-0);
  }
}
@media (min-width: 30em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-7);
    --global-header-size-h2: var(--global-header-size-5);
    --global-header-size-h3: var(--global-header-size-4);
    --global-header-size-h4: var(--global-header-size-2);
    --global-header-size-h5: var(--global-header-size-1);
    --global-header-size-h6: var(--global-header-size-0);
  }
}
@media (min-width: 50em) {
  .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-3);
    --global-header-size-h5: var(--global-header-size-2);
    --global-header-size-h6: var(--global-header-size-1);
  }
}
@media (min-width: 62.5em) {
  .s-prose {
    --global-header-size-h1: var(--global-header-size-9);
    --global-header-size-h2: var(--global-header-size-8);
    --global-header-size-h3: var(--global-header-size-5);
    --global-header-size-h4: var(--global-header-size-3);
    --global-header-size-h5: var(--global-header-size-2);
    --global-header-size-h6: var(--global-header-size-1);
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* ==========================================================================
   Object: Buttons
   ========================================================================== */
:root {
  --global-button-size: var(--global-body-size-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: 10px 30px;
  --global-button-padding-small: 10px 25px;
  --global-button-padding-big: 15px 60px;
}
@media (min-width: 50em) {
  :root {
    --global-button-size-small: var(--global-body-size-5);
    --global-button-size-big: var(--global-body-size-7);
    --global-button-padding: 10px 30px;
    --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: gt-ultra-standard, sans-serif;
  font-size: var(--global-button-size);
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
  color: #E6D6CF;
  background-color: #000;
  border: 1px solid #000;
  color: #fff;
  padding: var(--global-button-padding);
  width: auto;
  border-radius: 4px;
  line-height: 1.2;
  isolation: isolate;
  transition: 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;
}
@media (hover: hover) and (pointer: fine) {
  .btn:hover, :hover:where([data-component*=dialog] menu button),
  .inline-button:hover,
  .btn-primary:hover,
  .step-button-next:hover,
  .step-button-prev:hover,
  .userform input[type=button]:hover,
  .userform input[type=submit]:hover {
    background-color: #575757;
    color: #fff;
    border-color: #575757;
    text-decoration: none;
    outline: none;
  }
}
.user-is-tabbing .btn:focus, .user-is-tabbing :focus:where([data-component*=dialog] menu button),
.user-is-tabbing .inline-button:focus,
.user-is-tabbing .btn-primary:focus,
.user-is-tabbing .step-button-next:focus,
.user-is-tabbing .step-button-prev:focus,
.user-is-tabbing .userform input[type=button]:focus,
.user-is-tabbing .userform input[type=submit]:focus {
  outline: none;
  font-weight: 700;
  border: 1px solid #E6D6CF;
  border-style: double;
  border-width: 3px;
}

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

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

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

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

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

.btn--red {
  color: #E6D6CF;
  background-color: #D73E23;
  border-color: #D73E23;
}
@media (hover: hover) and (pointer: fine) {
  .btn--red:hover {
    color: #fff;
    background-color: rgb(193.07, 55.676, 31.43);
  }
}
.user-is-tabbing .btn--red:focus {
  color: #fff;
  border-color: #000;
}

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

.btn--white, .page-header--full-height .page-header__link.page-header__link--primary {
  color: #000;
  background-color: #fff;
  border-color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .btn--white:hover, .page-header--full-height .page-header__link.page-header__link--primary:hover {
    color: #fff;
    background-color: transparent;
    border-color: #fff;
  }
}
.user-is-tabbing .btn--white:focus, .user-is-tabbing .page-header--full-height .page-header__link.page-header__link--primary:focus, .page-header--full-height .user-is-tabbing .page-header__link.page-header__link--primary:focus {
  color: #fff;
  background-color: transparent;
  border-color: #fff;
}

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

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

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

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

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

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

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

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

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

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

.btn--pause-desktop {
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  gap: 10px;
  margin: 0;
  padding: 20px 25px;
  border: 0;
  border-radius: 20px;
  font-size: 14px;
  font-weight: 500;
  color: #d0befa;
  background-color: #2b2930;
  cursor: pointer;
  z-index: 3;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.btn--pause-desktop .o-icon {
  color: #d0befa;
  height: 14px;
  width: 14px;
  transition: color 0.3s ease;
}
.btn--pause-desktop:hover {
  background-color: #d0befa;
  color: #2b2930;
}
.btn--pause-desktop:hover .o-icon {
  color: #2b2930;
}

.btn--pause-mobile {
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 100%;
  background-color: #2b2930;
  position: absolute;
  top: calc(var(--global-header-height) + 15px);
  right: 15px;
  z-index: 3;
}
.btn--pause-mobile .o-icon {
  color: #d0befa;
  height: 14px;
  width: 14px;
}

@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: #87085D;
  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:last-child {
  margin-bottom: 0;
}
.global-alert__message a {
  text-decoration: underline;
  font-weight: 700;
}

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

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

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

.global-footer__logo-social {
  width: 100%;
  padding-top: 40px;
}
@media (min-width: 50em) {
  .global-footer__logo-social {
    width: calc(33% - 40px);
  }
}
@media (min-width: 62.5em) {
  .global-footer__logo-social {
    width: 25%;
  }
}
@media (max-width: 49.99em) {
  .global-footer__logo-social {
    max-width: 400px;
    margin: 0 auto 20px;
  }
}

.global-footer__info {
  width: 100%;
  background: #E6D6CF;
  padding: 40px 20px 20px;
  text-align: center;
  position: relative;
}
@media (min-width: 50em) {
  .global-footer__info {
    width: calc(33% - 40px);
  }
}
@media (min-width: 62.5em) {
  .global-footer__info {
    width: 25%;
  }
}
@media (max-width: 49.99em) {
  .global-footer__info {
    max-width: 400px;
    margin: 0 auto 20px;
  }
}
.global-footer__info:before {
  content: "";
  width: 60px;
  height: 28px;
  transform: skew(30deg);
  background: #E6D6CF;
  display: inline-block;
  position: absolute;
  top: 0;
  left: -8px;
}
.global-footer__info:after {
  content: "";
  width: 60px;
  height: 28px;
  transform: skew(-30deg);
  background: #E6D6CF;
  display: inline-block;
  position: absolute;
  top: 0;
  right: -8px;
}

@media (max-width: 49.99em) {
  .global-footer__info-inner:before {
    content: "";
    width: 60px;
    height: 20px;
    transform: skew(-20deg);
    background: #E6D6CF;
    display: inline-block;
    position: absolute;
    bottom: 0;
    left: -3px;
  }
  .global-footer__info-inner:after {
    content: "";
    width: 60px;
    height: 20px;
    transform: skew(20deg);
    background: #E6D6CF;
    display: inline-block;
    position: absolute;
    bottom: 0;
    right: -3px;
  }
}
.global-footer__info-copy {
  margin-bottom: 30px;
  font-weight: 300;
}
.global-footer__info-copy a {
  font-weight: 300;
  text-decoration: underline;
}

.global-footer__nav {
  width: 100%;
  padding-top: 20px;
}
@media (min-width: 50em) {
  .global-footer__nav {
    width: calc(33% - 40px);
    padding-top: 40px;
  }
}
@media (min-width: 62.5em) {
  .global-footer__nav {
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
}

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

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

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

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

.global-footer__logo {
  width: 100%;
  height: 105px;
  max-width: 350px;
  margin-bottom: 15px;
  display: block;
}
@media (hover: hover) and (pointer: fine) {
  .global-footer__logo:hover .o-icon {
    background-color: var(--theme-color-dark);
  }
}
.global-footer__logo svg {
  width: 100%;
  height: 100%;
}
@media (max-width: 49.99em) {
  .global-footer__logo {
    margin-left: auto;
    margin-right: auto;
  }
}

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

.global-footer__social {
  display: flex;
  gap: 5px;
  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 {
  background: #E6D6CF;
  padding: 10px;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.social-link .o-icon {
  height: 20px;
  width: 20px;
  transition: opacity 0.4s ease;
}
.social-link:hover .o-icon {
  opacity: 1;
}

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

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

.footer-links {
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-links__item {
  display: flex;
}

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

.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 {
  background-color: #000;
  width: 100%;
}

.global-footer__footer-inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .global-footer__footer-inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.global-footer__footer-inner {
  display: flex;
  color: #fff;
  justify-content: center;
  text-align: center;
  width: 100%;
  padding: 40px 15px;
}

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

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

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

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

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

.global-header__nav {
  width: calc(50% + 25px);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (min-width: 50em) {
  .global-header__nav {
    width: 30%;
    max-width: 300px;
  }
}

.global-header__logo {
  border: none;
  z-index: 2;
  position: relative;
}
.user-is-tabbing .global-header__logo:focus {
  outline: 2px solid #fff;
  outline-offset: 2px;
}
.global-header__logo .o-icon {
  height: 30px;
  width: 50px;
  color: #fff;
}
@media (min-width: 50em) {
  .global-header__logo .o-icon {
    height: 40px;
    width: 70px;
  }
}

/*  ==========================================================================
    Global Header - Home Page
    ========================================================================== */
.page-homepage .global-header {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.89), rgba(0, 0, 0, 0.3) 35%, rgba(5, 242, 108, 0) 50%);
  position: fixed;
  top: var(--global-alert-height);
  width: 100%;
}
.page-homepage .global-header.header-scroll {
  background: #000;
}

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

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

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

/*  ==========================================================================
    Global Header - Toolbar
    ========================================================================== */
.global-header__toolbar {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: calc(50% - 45px);
  z-index: -1;
}
@media (min-width: 50em) {
  .global-header__toolbar {
    width: 30%;
    max-width: 300px;
  }
}

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

.global-header__button {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  color: var(--link-color);
  background-color: transparent;
  padding: 0;
  border: none;
  transition: opacity 0.3s ease;
  cursor: pointer;
}
.global-header__button .o-icon {
  width: 20px;
  height: 25px;
  flex-shrink: 0;
  transition: transform 0.3s ease;
}
.user-is-tabbing .global-header__button:focus {
  outline: 2px solid var(--link-color);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  .global-header__button:hover .o-icon {
    transform: scale(1.1);
  }
  .global-header__button:hover .o-icon--chevron {
    transform: rotate(90deg);
  }
  .global-header__button:hover.global-header__button--account.is-toggled .o-icon--chevron {
    transform: rotate(-90deg);
  }
}

.global-header__button-text {
  text-transform: uppercase;
  font-weight: 700;
  font-size: var(--global-body-size-2);
  line-height: 1;
}
@media (max-width: 49.99em) {
  .global-header__button-text {
    display: none;
  }
}

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

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

.global-header__account {
  border: 0;
  padding: 0;
  background: none;
  cursor: pointer;
}
.global-header__account .o-icon {
  width: 18px;
}
@media (max-width: 49.99em) {
  .global-header__account {
    display: none;
  }
}

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

@media (min-width: 32em) {
  body.user-logged-in .global-header__account-menu {
    display: flex;
  }
}

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

.global-header__button--cart svg {
  fill: transparent;
}
.global-header__button--cart {
  position: relative;
}
.global-header__button--cart .cart-number {
  position: absolute;
  top: -8px;
  right: -10px;
  background: #fff;
  color: #000;
  height: 20px;
  line-height: 17px;
  width: 20px;
  text-align: center;
  border-radius: 50%;
  font-size: 12px;
  border: 2px solid #000;
  display: none;
}
.items-in-cart .global-header__button--cart .cart-number {
  display: inline-block;
}

.global-header__button--cart .o-icon,
.global-header__button--donate .o-icon {
  width: 20px;
  height: 25px;
  margin-right: 0;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.global-newsletter {
  background-color: #000;
  color: #fff;
  position: relative;
  padding: 40px 15px 60px;
  z-index: 4;
}

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

.global-newsletter__icon svg {
  width: 35px;
  height: 35px;
  margin-bottom: 20px;
}

.global-newsletter__title {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 32px;
  margin-bottom: 10px;
}
@media (min-width: 50em) {
  .global-newsletter__title {
    font-size: 42px;
  }
}

.global-newsletter__copy {
  font-size: 18px;
  margin-bottom: 10px;
}
@media (min-width: 50em) {
  .global-newsletter__copy {
    font-size: 22px;
  }
}

.global-newsletter__form {
  display: flex;
  gap: 15px;
}
.global-newsletter__form input {
  border: 1px solid #fff;
  background-color: transparent;
  color: #fff;
  border-radius: 4px;
  padding: 10px 15px;
  max-width: 200px;
}
.global-newsletter__form input::placeholder {
  color: #fff;
}
.global-newsletter__form button {
  background-color: #fff;
  border: 1px solid #fff;
  color: #000;
  border-radius: 4px;
  padding: 10px 15px;
  text-transform: uppercase;
}

.global-newsletter__embed {
  margin-top: 10px;
  max-width: 1000px;
  width: 100%;
}

.global-newsletter__cta {
  margin-top: 10px;
}

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

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

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

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

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

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

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

.global-nav-mobile__buttons {
  display: flex;
  align-items: center;
  gap: 15px;
  background-color: #E6D6CF;
  padding: 15px;
  text-transform: uppercase;
  z-index: 2;
}
.global-nav-mobile__buttons .o-icon {
  width: 20px;
  height: 20px;
  color: #3d3d3d;
}
.global-nav-mobile__buttons.logged-in {
  display: none;
}

body.user-logged-in .global-nav-mobile__buttons.logged-out {
  display: none;
}
body.user-logged-in .global-nav-mobile__buttons.logged-in {
  display: flex;
}

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

/*  ==========================================================================
    Global Navigation - Desktop
    ========================================================================== */
.global-nav-desktop {
  position: fixed;
  top: 0;
  left: 0;
  height: 100svh;
  width: 100%;
  background-color: #fff;
  transition: transform 0.5s ease;
}
@media (min-width: 42.5em) {
  .global-nav-desktop {
    max-width: 450px;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

.global-search__input {
  width: 100%;
  height: 50px;
  line-height: 50px;
  padding: 0 70px 0 20px;
  border-radius: 30px;
  border: none;
  height: auto;
  border: 1px solid #fff;
  font-family: gt-ultra-standard, 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);
  will-change: opacity;
}
.gprev,
.gnext,
.gclose {
  background-repeat: no-repeat;
  z-index: 99999;
  cursor: pointer;
  width: 26px;
  height: 44px;
  display: block;
  background-position: 0 0;
  border: none;
}
.gprev svg,
.gnext svg,
.gclose svg {
  display: block;
  width: 100%;
  height: auto;
}
.gprev.disabled,
.gnext.disabled,
.gclose.disabled {
  opacity: 0.1;
}
.gprev .garrow,
.gnext .garrow,
.gclose .garrow {
  stroke: #fff;
}

iframe.wait-autoplay {
  opacity: 0;
}

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

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

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

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

.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: #E6D6CF;
}
.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, #D73E23);
  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, #D73E23);
  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 rgba(0, 0, 0, 0.25);
}
.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: gt-ultra-standard, 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: #000;
  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: #000;
}
.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, #D73E23);
  border-color: var(--theme-color, #D73E23);
  color: #000;
}
.userform .progress-title {
  font-family: gt-ultra-standard, 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: gt-ultra-standard, 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;
}

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

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

.theme-red {
  --theme-color: #D73E23;
  --theme-text-color: #fff;
  --theme-text-color-inverse: #000;
}

.theme-blue {
  --theme-color: #396EEA;
  --theme-text-color: #fff;
  --theme-text-color-inverse: #000;
}

.theme-teal {
  --theme-color: #62D5C6;
  --theme-text-color: #000;
  --theme-text-color-inverse: #fff;
}

.theme-berry {
  --theme-color: #87085D;
  --theme-text-color: #fff;
  --theme-text-color-inverse: #000;
}

.theme-green {
  --theme-color: #2F8609;
  --theme-text-color: #fff;
  --theme-text-color-inverse: #000;
}

.theme-orange {
  --theme-color: #F2900F;
  --theme-text-color: #000;
  --theme-text-color-inverse: #fff;
}

.theme-yellow {
  --theme-color: #F7E94D;
  --theme-text-color: #000;
  --theme-text-color-inverse: #fff;
}

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

.theme-purple {
  --theme-color: #7D0BDA;
  --theme-text-color: #fff;
  --theme-text-color-inverse: #000;
}

.theme-mauve {
  --theme-color: #A36272;
  --theme-text-color: #fff;
  --theme-text-color-inverse: #000;
}

.gradient-primary {
  --gradient-color: linear-gradient(136deg, #D73E23 20%, #87085d 40%, #000 80%);
  --gradient-text-color: #fff;
  --gradient-text-color-inverse: #000;
}

.gradient-blackberry {
  --gradient-color: linear-gradient(136deg, #000, #87085D);
  --gradient-text-color: #fff;
  --gradient-text-color-inverse: #000;
}

.gradient-blueberry {
  --gradient-color: linear-gradient(136deg, #02ECFF 20%, #1754DD 40%, #870D5D 80%);
  --gradient-text-color: #fff;
  --gradient-text-color-inverse: #000;
}

.gradient-dusk {
  --gradient-color: linear-gradient(136deg, #F7E94D 20%, #F2900F 40%, #D73E23 80%);
  --gradient-text-color: #fff;
  --gradient-text-color-inverse: #000;
}

.gradient-matcha {
  --gradient-color: linear-gradient(136deg, #62D5C6 60%, #F7E94D);
  --gradient-text-color: #000;
  --gradient-text-color-inverse: #fff;
}

.gradient-blossom {
  --gradient-color: linear-gradient(136deg, #62D5C6 40%, #46B2C7 60%, #FFFAF8);
  --gradient-text-color: #000;
  --gradient-text-color-inverse: #fff;
}

.gradient-dawn {
  --gradient-color: linear-gradient(136deg, #BCCFFA 40%, #FFF0FA 80%, #FFFAF8);
  --gradient-text-color: #000;
  --gradient-text-color-inverse: #fff;
}

/*  ==========================================================================
	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;
}
@media (min-width: 50em) {
  .accordion-block__title {
    padding-top: 15px;
  }
}

.accordion-block__item__header {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .accordion-block__item__header {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.accordion-block__item__header {
  display: flex;
  align-items: center;
  gap: 15px;
  cursor: pointer;
  padding: 20px 0;
  transition: transform 0.3s ease;
  list-style: none;
  box-sizing: border-box;
}
.accordion-block__item__header::-webkit-details-marker {
  display: none;
}
@media (min-width: 50em) {
  .accordion-block__item__header {
    padding: 25px 0;
  }
}
.accordion-block__item__header .o-icon {
  display: none;
}
.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: gt-ultra-fine, 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: gt-ultra-fine, sans-serif;
  margin-top: 5px;
}
@media (min-width: 50em) {
  .accordion-block__item__subtitle {
    font-size: var(--global-body-size-7);
  }
}

.accordion-block__name {
  margin-bottom: 0;
}

.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__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;
}
@media (min-width: 50em) {
  .membership-levels__form {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.membership-levels__form {
  text-align: center;
  margin-bottom: 0;
}

.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: #000;
  background-color: #fff;
  border: 1px solid;
  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: #000;
  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: gt-ultra-standard, 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 {
  padding-top: 0;
}
.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.content-panel--white {
  background-color: #fff;
}
.content-panel.content-panel--primary {
  background-color: #E6D6CF;
  margin: 0;
  padding: var(--content-margin);
}

.content-panel__inner {
  width: 100%;
  max-width: 1000px;
  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;
  }
}

.error-page {
  min-height: 70vh;
  display: flex;
  align-items: center;
  margin: 45px 0;
}
.error-page:last-child:not(.element:last-child) {
  margin-bottom: 45px;
}
.error-page h1 {
  font-size: 60px;
  font-family: gt-ultra-fine, sans-serif;
  margin: 0;
}
@media (min-width: 50em) {
  .error-page h1 {
    font-size: 80px;
  }
}
@media (min-width: 72em) {
  .error-page h1 {
    font-size: 100px;
  }
}
.error-page h2 {
  margin-top: 0;
  padding-bottom: 0;
  font-size: 26px;
  font-weight: 500;
  border-bottom: none;
}
@media (min-width: 50em) {
  .error-page h2 {
    font-size: 28px;
  }
}
.error-page .s-prose p:not(.quote__text):not(.cta):not(.caption) {
  margin-top: 0;
  font-size: 14px;
}
@media (min-width: 50em) {
  .error-page .s-prose p:not(.quote__text):not(.cta):not(.caption) {
    font-size: 18px;
  }
}
.error-page .content-panel__body {
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

/*  ==========================================================================
    Donation Panel
    ========================================================================== */
.donation-panel {
  margin: var(--content-margin);
  background: var(--theme-color, #E6D6CF);
  color: var(--theme-text-color, #000);
}
.donation-panel .donation-panel__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, var(--theme-color, #E6D6CF) 100%);
}
@media (min-width: 50em) {
  .donation-panel .donation-panel__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, var(--theme-color, #E6D6CF) 79%, var(--theme-color, #E6D6CF) 100%);
  }
}
@media (min-width: 50em) {
  .donation-panel.donation-panel--right .donation-panel__media:before {
    background: linear-gradient(80deg, var(--theme-color, #E6D6CF) 0%, var(--theme-color, #E6D6CF) 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

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

.donation-panel__media {
  overflow: hidden;
  width: 100%;
  position: relative;
}
@media (max-width: 49.99em) {
  .donation-panel__media:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    height: 10vh;
    z-index: 2;
    max-height: 50%;
  }
}
@media (min-width: 50em) {
  .donation-panel__media {
    width: 54%;
    margin-bottom: 0;
  }
  .donation-panel__media:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    width: 20vw;
    max-width: 50%;
    z-index: 2;
  }
}

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

.donation-panel__image {
  height: auto;
  position: absolute;
  right: 0;
  transform: scale(1);
  transition: transform 0.4s ease;
  width: 100%;
  min-height: 100%;
  object-fit: cover;
}

.donation-panel__details {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding: 20px 20px 30px;
  margin: 0 auto;
  text-align: center;
  position: relative;
}
@media (min-width: 50em) {
  .donation-panel__details {
    padding: 40px 20px;
    width: 50%;
    max-width: 500px;
  }
}
@media (min-width: 62.5em) {
  .donation-panel__details {
    margin: 0;
    gap: 20px;
    padding: 60px 20px;
  }
}

.donation-panel__title {
  margin-bottom: 0;
}

.donation-panel__description {
  margin-bottom: 10px;
  text-wrap: balance;
}
.donation-panel__description p {
  margin-bottom: 0;
}

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

.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: #000;
  text-decoration: none;
  color: #fff;
  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: #fff;
  border-radius: 4px;
  color: #000;
  cursor: pointer;
  display: flex;
  font-size: 14px;
  font-weight: 700;
  justify-content: center;
  margin: 0;
  padding: 10px 25px;
  transform: scale(1);
  transition: all 0.3s ease-in-out;
}
.donation-panel__button:focus-visible {
  outline: none;
  border: none;
}
@media (min-width: 50em) {
  .donation-panel__button {
    font-size: 16px;
  }
}

.donation-amount {
  visibility: hidden;
}

.donation-panel__actions {
  margin-top: 10px;
}

@media (min-width: 50em) {
  .donation-panel--right .donation-panel__inner {
    justify-content: flex-end;
  }
  .donation-panel--right .donation-panel__media {
    order: 2;
  }
  .donation-panel--right .donation-panel__media:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: auto;
    width: 20vw;
    max-width: 50%;
    z-index: 2;
  }
  .donation-panel--right .donation-panel__details {
    order: 1;
  }
}

/*  ==========================================================================
	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;
}
@media (min-width: 50em) {
  .downloads__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.downloads__inner {
  text-align: center;
}

.downloads__title {
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
  text-align: center;
  font-family: gt-ultra-fine, sans-serif;
}
.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: gt-ultra-standard, 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;
  }
}

/*  ==========================================================================
	Download Cards
	========================================================================== */
.download-cards {
  margin: var(--content-margin);
}

.download-cards--center .download-cards__title {
  text-align: center;
}
.download-cards--center .download-cards__items {
  justify-content: center;
}

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

.download-cards__title {
  margin-bottom: 20px;
  font-family: gt-ultra-fine, sans-serif;
}

.download-cards__items {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.download-card {
  width: calc(50% - 20px);
}
@media (min-width: 50em) {
  .download-card {
    width: calc(33.3% - 20px);
  }
  .download-card:hover .download-card__icon {
    color: #62D5C6;
    background-color: #000;
  }
}
@media (min-width: 72em) {
  .download-card {
    width: calc(20% - 20px);
  }
}
.download-card:focus .download-card__icon {
  color: #62D5C6;
  background-color: #000;
}

.download-card__media {
  position: relative;
  margin-bottom: 15px;
}

.download-card__intrinsic-ratio.media.media-image {
  position: relative;
  height: 0;
  padding-bottom: 133.3333333333%;
}

.download-card__image {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.download-card__icon {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.7);
  color: #fff;
  transition: background-color 0.3s ease;
}

.download-card__icon .o-icon {
  width: 22px;
  height: 22px;
  transition: color 0.3s ease;
}

.download-card__prefix {
  font-weight: 300;
  text-transform: uppercase;
  font-size: 12px;
}
@media (min-width: 50em) {
  .download-card__prefix {
    font-size: 14px;
  }
}

.download-card__title {
  font-size: 18px;
}
@media (min-width: 50em) {
  .download-card__title {
    font-size: 22px;
  }
}

.feature-banner .btn, .feature-banner :where([data-component*=dialog] menu button) {
  width: 100%;
  max-width: 300px;
  margin-top: 20px;
}

.text-black {
  color: #000;
}

.text-white {
  color: #fff;
}

.feature-banner__inner {
  width: 100%;
}
@media (min-width: 50em) {
  .feature-banner__inner {
    display: flex;
  }
}

.feature-banner__media {
  overflow: hidden;
  width: 100%;
  position: relative;
}
@media (max-width: 49.99em) {
  .feature-banner__media:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    height: 10vh;
    z-index: 2;
    max-height: 50%;
  }
}
@media (min-width: 50em) {
  .feature-banner__media {
    width: 54%;
    margin-bottom: 0;
  }
  .feature-banner__media:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    width: 20vw;
    max-width: 50%;
    z-index: 2;
  }
}

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

.feature-banner__image {
  height: 100%;
  position: absolute;
  right: 0;
  transform: scale(1);
  transition: transform 0.4s ease;
  width: 100%;
  min-height: 100%;
  object-fit: cover;
}

.feature-banner__details {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding: 20px;
  margin: 0 auto;
  text-align: center;
  position: relative;
}
@media (min-width: 50em) {
  .feature-banner__details {
    padding: 40px 20px;
    width: 50%;
    max-width: 500px;
  }
}
@media (min-width: 62.5em) {
  .feature-banner__details {
    margin: 0;
    gap: 20px;
    padding: 100px 20px;
  }
}

.feature-banner__prefix {
  margin-bottom: -10px;
}

.feature-banner__title {
  margin-bottom: 0;
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
}

.feature-banner__description {
  margin-bottom: 0;
}
.feature-banner__description p {
  margin-bottom: 0;
}

.feature-banner__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-banner__cta .o-icon {
  width: 27px;
  height: 27px;
}
@media (min-width: 50em) {
  .feature-banner__cta .o-icon {
    width: 30px;
    height: 30px;
  }
}
@media (min-width: 50em) {
  .feature-banner__cta {
    font-size: 22px;
    color: #000;
  }
}

@media (min-width: 50em) {
  .feature-banner--right .feature-banner__inner {
    justify-content: flex-end;
  }
  .feature-banner--right .feature-banner__media {
    order: 2;
  }
  .feature-banner--right .feature-banner__media:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: auto;
    width: 20vw;
    max-width: 50%;
    z-index: 2;
  }
  .feature-banner--right .feature-banner__details {
    order: 1;
  }
}

.feature-banner--primary {
  background-color: #E6D6CF;
}
.feature-banner--primary .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #E6D6CF 100%);
}
@media (min-width: 50em) {
  .feature-banner--primary .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #E6D6CF 79%, #E6D6CF 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--primary.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #E6D6CF 0%, #E6D6CF 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--light {
  background-color: #FFFAF8;
}
.feature-banner--light .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #FFFAF8 100%);
}
@media (min-width: 50em) {
  .feature-banner--light .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #FFFAF8 79%, #FFFAF8 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--light.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #FFFAF8 0%, #FFFAF8 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--red {
  background-color: #D73E23;
}
.feature-banner--red .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #D73E23 100%);
}
@media (min-width: 50em) {
  .feature-banner--red .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #D73E23 79%, #D73E23 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--red.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #D73E23 0%, #D73E23 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--blue {
  background-color: #396EEA;
}
.feature-banner--blue .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #396EEA 100%);
}
@media (min-width: 50em) {
  .feature-banner--blue .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #396EEA 79%, #396EEA 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--blue.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #396EEA 0%, #396EEA 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--teal {
  background-color: #62D5C6;
}
.feature-banner--teal .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #62D5C6 100%);
}
@media (min-width: 50em) {
  .feature-banner--teal .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #62D5C6 79%, #62D5C6 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--teal.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #62D5C6 0%, #62D5C6 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--berry {
  background-color: #87085D;
}
.feature-banner--berry .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #87085D 100%);
}
@media (min-width: 50em) {
  .feature-banner--berry .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #87085D 79%, #87085D 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--berry.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #87085D 0%, #87085D 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--green {
  background-color: #2F8609;
}
.feature-banner--green .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #2F8609 100%);
}
@media (min-width: 50em) {
  .feature-banner--green .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #2F8609 79%, #2F8609 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--green.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #2F8609 0%, #2F8609 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--orange {
  background-color: #F2900F;
}
.feature-banner--orange .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #F2900F 100%);
}
@media (min-width: 50em) {
  .feature-banner--orange .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #F2900F 79%, #F2900F 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--orange.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #F2900F 0%, #F2900F 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--yellow {
  background-color: #F7E94D;
}
.feature-banner--yellow .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #F7E94D 100%);
}
@media (min-width: 50em) {
  .feature-banner--yellow .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #F7E94D 79%, #F7E94D 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--yellow.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #F7E94D 0%, #F7E94D 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--pink {
  background-color: #DF0C98;
}
.feature-banner--pink .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #DF0C98 100%);
}
@media (min-width: 50em) {
  .feature-banner--pink .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #DF0C98 79%, #DF0C98 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--pink.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #DF0C98 0%, #DF0C98 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--purple {
  background-color: #7D0BDA;
}
.feature-banner--purple .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #7D0BDA 100%);
}
@media (min-width: 50em) {
  .feature-banner--purple .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #7D0BDA 79%, #7D0BDA 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--purple.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #7D0BDA 0%, #7D0BDA 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--mauve {
  background-color: #A36272;
}
.feature-banner--mauve .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #A36272 100%);
}
@media (min-width: 50em) {
  .feature-banner--mauve .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #A36272 79%, #A36272 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--mauve.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #A36272 0%, #A36272 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

.feature-banner--black {
  background-color: #000;
}
.feature-banner--black .feature-banner__media:before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #000 100%);
}
@media (min-width: 50em) {
  .feature-banner--black .feature-banner__media:before {
    background: linear-gradient(100deg, rgba(0, 0, 0, 0) 0%, rgba(20, 43, 40, 0) 40%, #000 79%, #000 100%);
  }
}
@media (min-width: 50em) {
  .feature-banner--black.feature-banner--right .feature-banner__media:before {
    background: linear-gradient(80deg, #000 0%, #000 40%, rgba(0, 0, 0, 0) 79%, rgba(20, 43, 40, 0) 40%);
  }
}

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

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

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

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

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

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

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

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

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

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

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

/*  ==========================================================================
	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%;
  }
  .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%;
}
.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;
}
@media (min-width: 50em) {
  .feature-group__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.feature-group__inner {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  position: relative;
}
@media (min-width: 50em) {
  .feature-group__inner {
    flex-direction: row;
    gap: 40px;
  }
}

/*  ==========================================================================
Feature Panel - Text
========================================================================== */
.feature-panel-text {
  position: relative;
  padding: 40px 0;
}
@media (min-width: 50em) {
  .feature-panel-text {
    padding: 60px 0;
  }
}

.feature-panel-text--white {
  background-color: #fff;
}

.feature-panel-text--primary {
  background-color: #FFFAF8;
}

.feature-panel-text--secondary {
  background-color: #E6D6CF;
}

.feature-panel-text--black {
  background-color: #000;
  color: #fff;
}

.feature-panel-text--blue {
  background-color: #396EEA;
  color: #fff;
}

.feature-panel-text--teal {
  background-color: #62D5C6;
}

.feature-panel-text--berry {
  background-color: #87085D;
  color: #fff;
}

.feature-panel-text__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-text__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.feature-panel-text__inner {
  max-width: 1000px;
  text-align: center;
}

.feature-panel-text__title {
  margin-bottom: 25px;
  padding-bottom: 20px;
  border-bottom: 1px solid;
}

.feature-panel-text__description {
  font-weight: 300;
}
.feature-panel-text__description p {
  margin-bottom: 20px;
}

.feature-panel-text__cta {
  margin-top: 10px;
}

/*  ==========================================================================
	Image Gallery
	========================================================================== */
.image-gallery {
  position: relative;
  padding: 30px 0 0;
  background-color: #E6D6CF;
  overflow: hidden;
}
@media (min-width: 58em) {
  .image-gallery {
    padding: 80px 0;
  }
}
@media (min-width: 80em) {
  .image-gallery {
    padding: 120px 0;
  }
}

.image-gallery__container {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .image-gallery__container {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.image-gallery__container {
  position: relative;
}
@media (min-width: 58em) {
  .image-gallery__container {
    display: flex;
    gap: 20px;
    justify-content: space-between;
  }
}

.image-gallery__title {
  border-bottom: 1px solid;
  margin-bottom: 25px;
  padding-bottom: 25px;
}
@media (min-width: 42.5em) {
  .image-gallery__title {
    margin-bottom: 30px;
    padding-bottom: 30px;
  }
}

.image-gallery__subtitle {
  font-family: gt-ultra-fine, sans-serif;
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 25px;
}
@media (min-width: 42.5em) {
  .image-gallery__subtitle {
    font-size: 24px;
  }
}

.image-gallery__button {
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 31px;
  height: 31px;
  transition: opacity 0.4s ease;
  position: absolute;
  top: 50%;
  z-index: 3;
  transform: translateY(-50%);
  background: #000;
  border-radius: 50%;
  color: #fff;
}
@media (min-width: 50em) {
  .image-gallery__button {
    width: 35px;
    height: 35px;
  }
}
.image-gallery__button.image-gallery__button--previous {
  left: 20px;
}
.image-gallery__button.image-gallery__button--next {
  right: 20px;
}
.image-gallery__button.swiper-button-disabled {
  cursor: not-allowed;
}
.image-gallery__button .o-icon {
  color: var(--theme-color-dark);
  transition: color 0.4s ease;
  width: 15px;
  height: 15px;
}
@media (min-width: 50em) {
  .image-gallery__button .o-icon {
    width: 18px;
    height: 18px;
  }
}
.image-gallery__button:not(.swiper-button-disabled):hover {
  opacity: 0.6;
}

.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;
  overflow: hidden;
  margin: 40px -15px 0;
}
@media (min-width: 58em) {
  .image-gallery__body {
    width: calc(100% - 420px);
    margin: 0;
  }
}
@media (min-width: 80em) {
  .image-gallery__body {
    width: calc(100% - 550px);
  }
}

.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: auto;
  width: 100%;
  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;
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: var(--global-body-size-7);
  display: block;
  width: 100%;
}
@media (min-width: 58em) {
  .image-gallery__info {
    max-width: 420px;
    padding-top: 20px;
    padding-right: 20px;
  }
}
@media (max-width: 57.99em) {
  .image-gallery__info .btn, .image-gallery__info :where([data-component*=dialog] menu button) {
    width: 100%;
  }
}

.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: 58em) {
  .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 {
  margin-bottom: 30px;
  line-height: 1.2;
}

.gallery-slide__inner {
  position: relative;
  box-sizing: border-box;
  margin-bottom: 0;
}

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

.gallery-slide__image {
  width: 100%;
  height: 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;
  position: absolute;
  top: 0;
}
.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;
  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: #757575;
}
@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;
}
.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;
  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;
  width: 100%;
  overflow: hidden;
}
.image-gallery--fullscreen .image-gallery__slides.swiper-wrapper {
  align-items: center;
  padding-left: 0;
}
.image-gallery--fullscreen .image-gallery__slide.swiper-slide {
  height: auto;
  width: 100%;
}
.image-gallery--fullscreen .image-gallery__position {
  margin: 0 0 40px;
}
.image-gallery--fullscreen .gallery-slide__caption {
  display: block;
}
.image-gallery--fullscreen .gallery-slide__credit {
  display: block;
  margin-top: 20px;
}
.image-gallery--fullscreen .gallery-slide {
  padding: 15px;
}
.image-gallery--fullscreen .gallery-slide__media {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 0;
  height: auto;
}
.image-gallery--fullscreen .gallery-slide__media .gallery-slide__image {
  position: relative;
  width: 100%;
  max-width: 100%;
  height: auto;
}
.image-gallery--fullscreen .gallery-slide__media--portrait .gallery-slide__image {
  width: auto;
  height: auto;
  max-height: 60vh;
}
@media (min-width: 58em) {
  .image-gallery--fullscreen .gallery-slide__media--portrait .gallery-slide__image {
    width: auto;
    height: calc(100vh - 30px);
    max-height: none;
  }
}

/*  ==========================================================================
    People Panel
    ========================================================================== */
.people-panel {
  display: flex;
  flex-direction: column;
  position: relative;
  margin: var(--content-margin);
  padding: 40px 0;
  background-color: #E6D6CF;
}
@media (min-width: 50em) {
  .people-panel {
    padding: 60px 0;
  }
}

.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: 1440px;
    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__header-title {
  border-bottom: 1px solid #000;
  padding-bottom: 20px;
}
@media (min-width: 50em) {
  .people-panel__header-title {
    padding-bottom: 30px;
  }
}

.people-panel__title {
  margin-bottom: 0;
  padding-top: 10px;
}
@media (min-width: 50em) {
  .people-panel__title {
    padding-top: 15px;
  }
}

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

.person {
  margin: 0;
  border: 0;
  padding: 0;
  flex-shrink: 0;
  background: none;
  width: 100%;
  display: flex;
  align-items: center;
  gap: 30px;
}

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

.person__media {
  width: 150px;
}

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

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

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

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

.person__details {
  text-align: left;
  transition: color 0.4s ease;
  width: calc(100% - 190px);
}
.person--bio .person__details {
  color: #000;
}

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

@media (hover: hover) and (pointer: fine) {
  .person--bio .person__details {
    color: #000;
  }
  .person--bio:hover .person__details {
    color: #000;
  }
}
.person__name {
  display: inline;
  font-family: gt-ultra-fine, 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: 26px;
  }
}

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

.person__position {
  border-top: 1px solid;
  padding-top: 10px;
  margin-top: 10px;
  margin-bottom: 0;
  font-weight: 300;
  font-size: 14px;
}

.people-panel__primary {
  padding: 25px 0 40px;
}
@media (min-width: 62.5em) {
  .people-panel__primary {
    padding: 40px 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;
  color: #000;
  transition: color 0.4s ease, border-color 0.4s ease;
}
.people-panel__secondary .person--bio .person__details {
  border-color: #000;
}
@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: #000;
  }
  .people-panel__secondary .person--bio:hover .person__details {
    border-color: #000;
  }
}

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

.works-popup .people-popup__inner {
  padding-top: 80px;
}
@media (min-width: 50em) {
  .works-popup .people-popup__inner {
    padding-top: 120px;
  }
}

.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: var(--global-button-padding);
  margin: 0;
  border: 0;
  color: #fff;
  background-color: #000;
  border-radius: 4px;
  z-index: 3;
}
@media (hover: hover) and (pointer: fine) {
  .people-popup__close:hover {
    background-color: #575757;
    color: #fff;
  }
}
@media (min-width: 50em) {
  .people-popup__close {
    position: static;
  }
}

.people-popup__body {
  display: flex;
  flex-direction: column-reverse;
  gap: 40px;
}
@media (min-width: 50em) {
  .people-popup__body {
    flex-direction: row-reverse;
    justify-content: space-between;
    gap: 60px;
  }
}
@media (min-width: 62.5em) {
  .people-popup__body {
    gap: 100px;
  }
}

.people-popup__body--centered {
  justify-content: center;
}

.people-popup__details {
  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: gt-ultra-fine, 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 {
  margin-top: 15px;
  margin-bottom: 0;
  font-size: 16px;
}
@media (min-width: 50em) {
  .people-popup__role {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .people-popup__role {
    font-size: 20px;
  }
}

.people-popup__position {
  border-top: 1px solid;
  padding-top: 10px;
  margin-top: 10px;
  margin-bottom: 0;
  font-weight: 300;
  font-size: 16px;
}
@media (min-width: 50em) {
  .people-popup__position {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .people-popup__position {
    font-size: 20px;
  }
}

.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%;
}
.people-popup__media .o-icon {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 80%;
  height: 80%;
  z-index: 1;
  transform: translate(-50%, -50%);
}

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

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

.people-popup__information {
  padding-bottom: 40px;
}
@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;
  }
}

/*  ==========================================================================
    Pull Quote
    ========================================================================== */
.pull-quote {
  position: relative;
  margin: var(--content-margin);
  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;
  }
}

.quote {
  display: flex;
  flex-direction: column;
  align-items: center;
  border-left: 25px solid #000;
  background-color: #E6D6CF;
  padding: 30px;
}
@media (min-width: 50em) {
  .quote {
    padding: 40px;
  }
}
@media (min-width: 62.5em) {
  .quote {
    padding: 60px;
  }
}

.quote__text {
  position: relative;
  font-size: 20px;
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-style: italic;
  line-height: 1.4;
  margin: 0 auto;
  text-align: center;
  padding-bottom: 0;
  max-width: 670px;
}
.quote__text p {
  margin-bottom: 15px;
  text-wrap: pretty;
}
.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: 50em) {
  .quote__text {
    font-size: 22px;
  }
  .quote__text p {
    margin-bottom: 20px;
  }
}
@media (min-width: 72em) {
  .quote__text {
    font-size: 24px;
  }
}

.quote__meta {
  width: 100%;
  max-width: 720px;
  font-size: var(--global-body-size-3);
  text-align: center;
  line-height: 2;
}
@media (min-width: 50em) {
  .quote__meta {
    font-size: var(--global-body-size-5);
  }
}

.quote__link {
  display: block;
  color: #000;
  font-family: gt-ultra-standard, sans-serif;
  font-size: 20px;
  font-weight: 300;
  text-decoration: none;
  font-style: italic;
  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: italic;
}

/*  ==========================================================================
	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__description {
  max-width: 860px;
  width: 100%;
}

.review__quote {
  color: #000;
  font-family: gt-ultra-fine, 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,
.review__publisher {
  color: var(--theme-color-dark);
  display: inline-block;
  font-family: gt-ultra-fine, 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__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .company-block__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.company-block__title {
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

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

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

.company-block__heading {
  margin-bottom: 0;
  padding-top: 30px;
}

.company-block__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 15px;
}
@media (min-width: 62.5em) {
  .company-block__list {
    gap: 20px;
  }
}

@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: 10px;
  text-align: center;
}
@media (min-width: 62.5em) {
  .company-item {
    width: 250px;
  }
}
@media (min-width: 72em) {
  .company-item {
    width: 300px;
  }
}

.company-item__image-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  gap: 20px;
  padding: 20px;
  border: 1px solid rgba(0, 0, 0, 0.08);
}
@media (min-width: 50em) {
  .company-item__image-container {
    gap: 25px;
    padding: 30px;
  }
}

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

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

/*  ==========================================================================
    Venue Block
    ========================================================================== */
.venue-block {
  margin: var(--content-margin-small);
}

.venue-block__inner {
  padding: 0 15px;
}
@media (min-width: 62.5em) {
  .venue-block__inner {
    padding: 0 40px;
  }
}
@media (min-width: 80em) {
  .venue-block__inner {
    padding: 0 60px;
  }
}

.venue-block__title {
  margin-bottom: 20px;
}

.venue-block__heading {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 400;
  font-size: 20px;
  margin-top: 25px;
  margin-bottom: 20px;
}

.venue-block__description {
  margin-top: 20px;
}
.venue-block__description p:last-child {
  margin-bottom: 0;
}

.venue-block__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
  margin-top: 20px;
  width: 100%;
}
.venue-block__btns > * {
  flex-grow: 1;
}

.parking-panel {
  margin-top: 40px;
}

/*  ==========================================================================
    Venue Panel
    ========================================================================== */
.venue-panel__figure {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
}

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

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

.venue-panel__address {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 14px;
}
@media (min-width: 50em) {
  .venue-panel__address {
    font-size: 16px;
  }
}
.venue-panel__address .o-icon {
  width: 20px;
  height: 20px;
}

.venue-panel__address-text {
  text-decoration: underline;
}

/*  ==========================================================================
    Parking Panel
    ========================================================================== */
.parking-panel__figure {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  position: relative;
}

.parking-panel__image-wrapper {
  max-height: 55vw;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
@media (min-width: 62.5em) {
  .parking-panel__image-wrapper {
    max-height: 20vw;
  }
}
.parking-panel__figure.is-toggled .parking-panel__image-wrapper {
  max-height: 100svh;
}
.parking-panel__figure.is-toggled .parking-panel__image-wrapper .parking-panel__image {
  transform: translateY(0%);
}

.parking-panel__intrinsic-ratio {
  position: relative;
  padding-bottom: 133.3333333333%;
  height: 0;
}

.parking-panel__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  transform: translateY(-35vw);
  transition: transform 0.3s ease;
  z-index: 2;
}
@media (min-width: 62.5em) {
  .parking-panel__image {
    transform: translateY(-13vw);
  }
}

.parking-panel__figcaption {
  background-color: #E6D6CF;
  padding: 20px 5px;
  font-size: 14px;
}
.parking-panel__figcaption > *:last-child {
  margin-bottom: 0;
}
@media (min-width: 62.5em) {
  .parking-panel__figcaption {
    padding: 20px;
  }
}
@media (min-width: 90em) {
  .parking-panel__figcaption {
    padding: 20px 40px;
  }
}

.parking-panel__toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  right: 0;
  border: none;
  border-radius: 100%;
  margin: 15px;
  padding: 10px;
  background-color: #E6D6CF;
  width: 40px;
  height: 40px;
  cursor: pointer;
  z-index: 3;
}
.parking-panel__toggle .parking-panel__zoom-in,
.parking-panel__toggle .parking-panel__zoom-out {
  position: absolute;
  width: 20px;
  height: 20px;
  transition: opacity 0.3s ease;
}
.parking-panel__toggle .parking-panel__zoom-out {
  opacity: 0;
}
.parking-panel__figure.is-toggled .parking-panel__toggle .parking-panel__zoom-in {
  opacity: 0;
}
.parking-panel__figure.is-toggled .parking-panel__toggle .parking-panel__zoom-out {
  opacity: 1;
}
.parking-panel__toggle .o-icon {
  width: 100%;
  height: 100%;
}

/*  ==========================================================================
	Video Gallery
	========================================================================== */
.video-gallery {
  position: relative;
  padding: 40px 0;
  overflow: hidden;
  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;
}
.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__description {
  font-family: gt-ultra-fine, 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;
  margin: var(--content-margin);
}

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

.well-block__title {
  margin-bottom: 15px;
}
@media (min-width: 62.5em) {
  .well-block__title {
    margin-bottom: 20px;
  }
}

.well {
  color: #000;
  padding: 30px;
}
@media (min-width: 50em) {
  .well {
    padding: 40px;
  }
}
@media (min-width: 62.5em) {
  .well {
    padding: 60px;
  }
}

.well--white {
  background-color: #fff;
}

.well--primary {
  background-color: #FFFAF8;
}

.well--secondary {
  background-color: #E6D6CF;
}

.well--black {
  background-color: #000;
  color: #fff;
}

.well--blue {
  background-color: #396EEA;
  color: #fff;
}

.well--teal {
  background-color: #62D5C6;
}

.well--berry {
  background-color: #87085D;
  color: #fff;
}

/*  ==========================================================================
    Event Header
    ========================================================================== */
.event-header {
  position: relative;
  padding: 15px;
}
@media (min-width: 62.5em) {
  .event-header {
    padding: 40px 0 0 40px;
  }
}
@media (min-width: 80em) {
  .event-header {
    padding: 80px 0 0 60px;
  }
}

.event-header__inner {
  display: flex;
  flex-direction: column;
}

.event-header__media {
  width: 100%;
  margin-bottom: 0;
}

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

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

.event-sticky__sponsor {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  justify-content: center;
  margin-bottom: 0;
  padding: 15px;
  color: #fff;
  line-height: 1;
  text-transform: uppercase;
  background-color: #000;
  position: sticky;
  bottom: 0;
  z-index: 2;
}
@media (min-width: 50em) {
  .event-sticky__sponsor {
    padding: 20px;
  }
}

.event-sticky__sponsor-image {
  width: 100px;
}

.event-header__prefix {
  font-size: 14px;
}
@media (min-width: 50em) {
  .event-header__prefix {
    font-size: 16px;
  }
}

.event-header__title {
  display: flex;
  flex-direction: column;
  text-wrap: balance;
  width: 100%;
  margin-bottom: 0;
}

.event-header__suffix {
  margin-top: 5px;
}

.event-header__meta {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2px 10px;
  border-top: 1px solid #000;
  padding: 5px 0;
  font-size: 14px;
}
@media (min-width: 50em) {
  .event-header__meta {
    font-size: 16px;
  }
}

.event-header__venue {
  text-decoration: underline;
}

.event-header__points {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 0;
  padding-right: 30px;
}
.event-header__points .o-icon {
  width: 14px;
  height: 14px;
}

.event-header__dates {
  position: fixed;
  bottom: 0;
  left: 0;
  background-color: #fff;
  z-index: 5;
  box-shadow: 0 -4px 4px rgba(0, 0, 0, 0.1);
  width: 100%;
}
@media (min-width: 50em) {
  .event-header__dates {
    position: initial;
    margin-top: 30px;
    margin-bottom: 40px;
    background: none;
    box-shadow: none;
    z-index: 0;
  }
}

.event-header__student {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 5px;
  font-size: 14px;
  text-wrap: pretty;
  margin-top: 30px;
}
.event-header__student .o-icon {
  width: 20px;
  height: 20px;
}
@media (min-width: 50em) {
  .event-header__student {
    font-size: 16px;
    margin-top: 0;
  }
}

.event-header__student-link {
  text-decoration: underline;
}

.event-addons {
  border-top: 1px solid #000;
  padding-top: 20px;
}
@media (min-width: 50em) {
  .event-addons {
    padding-top: 10px;
  }
}

.event-addons__list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.event-addons__description {
  margin-bottom: 15px;
  font-size: 14px;
}
.event-addons__description .o-icon {
  width: 16px;
  height: 16px;
}
@media (min-width: 50em) {
  .event-addons__description {
    font-size: 16px;
  }
}

.event-addon {
  display: flex;
  align-items: center;
  gap: 20px;
}

.event-addon__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}

.event-addon__title {
  font-size: 14px;
  text-transform: uppercase;
  font-weight: 400;
  font-family: gt-ultra-standard, sans-serif;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-addon__title {
    font-size: 16px;
  }
}

.event-addon__icons {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  width: 85px;
}
@media (min-width: 50em) {
  .event-addon__icons {
    width: 120px;
  }
}

.event-addon__icon {
  display: flex;
  gap: 5px;
}
.event-addon__icon .o-icon {
  width: 15px;
}
@media (min-width: 62.5em) {
  .event-addon__icon .o-icon {
    width: 24px;
  }
}

.event-addon__description {
  font-size: 12px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .event-addon__description {
    font-size: 14px;
  }
}

/*  ==========================================================================
    Page Header
    ========================================================================== */
.page-header {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  max-height: 100svh;
}
.page-header.page-header--white {
  background-color: #fff;
}
.page-header.page-header--primary {
  background-color: #E6D6CF;
}

.page-header__inner {
  display: flex;
  flex-direction: column-reverse;
  position: relative;
  width: 100%;
  margin: 0 auto;
  max-height: 100svh;
}

.page-header__media {
  position: relative;
  isolation: isolate;
}

.page-header__figure {
  position: relative;
  margin-bottom: 0;
  z-index: -1;
}

.page-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 57.1428571429%;
  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: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .page-header__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.page-header__content {
  display: flex;
  flex-direction: column;
  gap: 30px;
  padding-top: 60px;
  padding-bottom: 0;
  color: #000;
  z-index: 2;
}
@media (min-width: 50em) {
  .page-header__content {
    gap: 40px;
  }
}
@media (min-width: 62.5em) {
  .page-header__content {
    padding-top: 100px;
  }
}

.page-header--full-height .page-header__content, .page-header--image .page-header__content, .page-header--video .page-header__content {
  padding-bottom: 20px;
}
@media (min-width: 50em) {
  .page-header--full-height .page-header__content, .page-header--image .page-header__content, .page-header--video .page-header__content {
    padding-bottom: 30px;
    gap: 40px;
  }
}
@media (min-width: 62.5em) {
  .page-header--full-height .page-header__content, .page-header--image .page-header__content, .page-header--video .page-header__content {
    padding-top: 100px;
    padding-bottom: 60px;
  }
}

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

.page-header__title {
  margin-bottom: 0;
  text-wrap: balance;
}

.page-header__subtitle {
  line-height: 1.2;
  margin-bottom: 0;
}

@media (min-width: 50em) {
  .page-header__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 30px;
  }
}

.page-header__links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
html:has(.page-header__links) {
  scroll-behavior: smooth;
}
@media (min-width: 42.5em) {
  .page-header__links {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 50em) {
  .page-header__links {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
}

/*  ==========================================================================
    Page Header - Image
    ========================================================================== */
.page-header--image .page-header__content {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .page-header--image .page-header__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.page-header--image .page-header__content {
  padding-top: 60px;
}

/*  ==========================================================================
Page Header - Video
========================================================================== */
.page-header--video {
  margin-bottom: 0;
}
.page-header--video button.video-controls {
  top: 15px;
  right: 15px;
  bottom: auto;
}
@media (min-width: 50em) {
  .page-header--video button.video-controls {
    top: auto;
    bottom: 20px;
    right: 20px;
  }
}
@media (min-width: 72em) {
  .page-header--video button.video-controls {
    bottom: 40px;
    right: 40px;
  }
}
@media (min-width: 96.875em) {
  .page-header--video button.video-controls {
    bottom: 40px;
    right: 90px;
  }
}

.page-header__media--video {
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: 0;
  left: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: -1;
}

@media (min-width: 50em) {
  .page-header__media--video .video-container {
    min-height: 500px;
  }
}
@media (min-width: 58em) {
  .page-header__media--video .video-container {
    min-height: 800px;
  }
}
@media (min-width: 90em) {
  .page-header__media--video .video-container {
    min-height: 850px;
  }
}

/*  ==========================================================================
    Page Header - Full Height
    ========================================================================== */
.page-header--full-height {
  margin-top: calc(var(--global-header-height) * -1);
}
.page-header--full-height + .content-blocks {
  padding-top: 20px;
}
@media (min-width: 50em) {
  .page-header--full-height + .content-blocks {
    padding-top: 30px;
  }
}
@media (min-width: 62.5em) {
  .page-header--full-height + .content-blocks {
    padding-top: 60px;
  }
}
.page-header--full-height .page-header__media:before {
  position: absolute;
  content: "";
  background: linear-gradient(to top, black, transparent);
  height: 100%;
  width: 100%;
  z-index: 3;
}
.page-header--full-height .page-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 180%;
  height: 0;
}
@media (min-width: 62.5em) {
  .page-header--full-height .page-header__intrinsic-ratio {
    padding-bottom: 55.5555555556%;
  }
}
.page-header--full-height .page-header__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding-top: 0;
  color: #fff;
}
/*  ==========================================================================
	Calendar
	========================================================================== */
.calendar {
  position: relative;
  padding: 30px 0;
}
@media (min-width: 62.5em) {
  .calendar {
    padding: 40px 0;
  }
}

.calendar__inner {
  width: 100%;
}

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

.calendar__sidebar {
  order: 1;
  width: 100%;
  position: sticky;
  top: 0;
  padding: 15px 0;
  margin-top: -20px;
  z-index: 3;
  background-color: #fff;
  margin-bottom: 30px;
}
@media (min-width: 50em) {
  .calendar__sidebar {
    padding: 20px 0;
  }
}
@media (min-width: 62.5em) {
  .calendar__sidebar {
    position: sticky;
    top: 140px;
    right: 0;
    background-color: transparent;
    height: 0;
    display: flex;
    justify-content: flex-end;
    width: 100%;
    margin: 0;
    padding: 0;
    margin-top: -100px;
  }
}

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

.calendar-actions {
  display: flex;
  justify-content: space-between;
  width: 100%;
}
@media (min-width: 50em) {
  .calendar-actions {
    padding-right: 80px;
  }
}

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

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

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

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

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

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

.calendar__desktop-date-picker {
  margin-top: 30px;
  background: #FFFAF8;
  padding: 60px;
  border-left: 10px solid #87085D;
}

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

.whatson-header--extended .whatson-header__inner {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.whatson-header--extended .whatson-header__content {
  width: 100%;
}

.whatson-header__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .whatson-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.whatson-header__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (min-width: 72em) {
  .whatson-header__inner {
    margin-top: 0;
    gap: 35px;
  }
}

.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;
  text-transform: capitalize;
  width: 100%;
  line-height: 0.8;
}

@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: gt-ultra-standard, sans-serif;
  font-size: 14px;
  font-weight: 500;
  text-transform: capitalize;
  line-height: 1;
  position: relative;
  padding: 5px;
  color: #6A6A6A;
  transition: color 0.4s ease;
}
.whatson-header__tab:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -10px;
  width: 100%;
  height: 3px;
  background-color: #000;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}
@media (min-width: 50em) {
  .whatson-header__tab {
    padding: 10px 7px;
    font-size: 26px;
  }
}
@media (min-width: 62.5em) {
  .whatson-header__tab {
    font-size: 32px;
  }
}
@media (min-width: 72em) {
  .whatson-header__tab:before {
    bottom: -6px;
    height: 3px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .whatson-header__tab:hover {
    color: #000;
  }
  .whatson-header__tab:hover:before {
    transform: scaleX(100%);
  }
}

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

.whatson-header__search {
  display: none;
  padding: 7px 30px;
  background-color: rgba(121, 121, 121, 0.2);
  position: relative;
  border-radius: 3px;
  width: 100%;
}
@media (min-width: 50em) {
  .whatson-header__search {
    display: flex;
    align-items: center;
    max-width: 300px;
  }
}

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

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

@media (max-width: 49.99em) {
  .whatson-header__filter {
    width: 100%;
  }
}

/*  ==========================================================================
	Whats On - Favorites
	========================================================================== */
.whatson-favorites {
  background: linear-gradient(136deg, #BCCFFA 40%, #FFF0FA 80%, #FFFAF8);
  padding-bottom: 60px;
}
@media (min-width: 62.5em) {
  .whatson-favorites {
    padding-bottom: 120px;
  }
}

.whatson-favorites__list {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .whatson-favorites__list {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.whatson-favorites__list {
  padding-top: 40px;
  padding-bottom: 40px;
}

.favorite-card {
  max-width: 900px;
  display: block;
  margin-bottom: 40px;
}
@media (min-width: 72em) {
  .favorite-card {
    max-width: calc(100% - 450px);
  }
}

.favorite-card__content {
  display: flex;
  align-items: center;
  gap: 30px;
}
@media (max-width: 49.99em) {
  .favorite-card__content {
    flex-direction: column;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }
}

.favorite-card__media {
  width: 100%;
  position: relative;
}
@media (min-width: 50em) {
  .favorite-card__media {
    width: 50%;
  }
}

.favorite-card__image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.favorite-card__details {
  width: 100%;
}
@media (min-width: 50em) {
  .favorite-card__details {
    width: 50%;
  }
}

.favorite-card__prefix {
  margin-bottom: 5px;
  display: inline-block;
}

.favorite-card__titles {
  font-family: gt-ultra-fine, sans-serif;
  font-size: 28px;
}
@media (min-width: 50em) {
  .favorite-card__titles {
    font-size: 32px;
  }
}
@media (min-width: 72em) {
  .favorite-card__titles {
    font-size: 36px;
  }
}

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

.favorite-card__date {
  position: relative;
  font-weight: 300;
  margin: 0;
  font-size: 12px;
  transition: color 0.3s ease-in-out;
  text-wrap: nowrap;
}
@media (min-width: 50em) {
  .favorite-card__date {
    font-size: 14px;
  }
}

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

.favorite-card__btn {
  margin-top: 20px;
  width: 100%;
  text-wrap: auto;
}

/*  ==========================================================================
	Whats On - Favorites Sidebar
	========================================================================== */
.whatson-favorites__sidebar {
  order: 1;
  width: 100%;
  position: relative;
  z-index: 3;
  margin-bottom: 30px;
}
@media (min-width: 72em) {
  .whatson-favorites__sidebar {
    position: sticky;
    top: 140px;
    right: 0;
    background-color: transparent;
    height: 0;
    display: flex;
    justify-content: flex-end;
    width: 100%;
    margin: 0;
    padding: 0;
  }
}

.whatson-favorites__sticky {
  position: relative;
  width: 100%;
  padding: 0;
}
@media (min-width: 72em) {
  .whatson-favorites__sticky {
    width: 450px;
    position: sticky;
    top: calc(var(--global-header-height) + 20px);
  }
}
@media (min-width: 106em) {
  .whatson-favorites__sticky {
    width: 550px;
  }
}

.whatson-favorites__sidebar-inner {
  background: #FFFAF8;
  padding: 30px 30px 40px;
  border-left: 10px solid #87085D;
}
@media (min-width: 50em) {
  .whatson-favorites__sidebar-inner {
    padding: 30px 60px 40px;
  }
}

.whatson-favorites__content {
  border-bottom: 1px solid;
}
.whatson-favorites__content h3 {
  font-family: gt-ultra-fine, sans-serif;
  font-size: 24px;
}

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

.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;
  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;
  }
  .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);
  width: fit-content;
  margin-bottom: 0;
}
@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;
}
@media (min-width: 50em) {
  .performance-popup-item__info {
    flex-direction: row;
  }
}

.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 {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  border-top: 1px solid;
  padding-top: 10px;
}

.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%;
}
.performance-popup-item__availability.good .performance-popup-item__availability-line:after {
  width: 80%;
}

.performance-popup-item__availability-line {
  width: 120px;
  height: 8px;
  border-radius: 3px;
  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 {
  margin: var(--content-margin-small);
}

.event-details__inner {
  padding: 0 15px;
}
@media (min-width: 62.5em) {
  .event-details__inner {
    padding: 0 40px;
  }
}
@media (min-width: 80em) {
  .event-details__inner {
    padding: 0 60px;
  }
}

.event-details__title {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 24px;
  margin-bottom: 20px;
}
@media (min-width: 50em) {
  .event-details__title {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .event-details__title {
    font-size: 32px;
  }
}

.event-details__subtitle {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 400;
  font-size: 20px;
  margin-bottom: 20px;
}

.event-repertoire,
.event-artists {
  list-style: none;
  padding: 0;
  margin: 0;
}

.event-repertoire__item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 5px;
}
.event-repertoire__item .composer-button, .event-repertoire__item .works-button {
  padding: 0;
  background: transparent;
  border: none;
  text-decoration: underline;
  text-wrap: nowrap;
  cursor: pointer;
}
.event-repertoire__item .composer-button:hover, .event-repertoire__item .works-button:hover {
  text-decoration: none;
}

.event-repertoire__work,
.event-repertoire__composer {
  flex-shrink: 0;
  font-size: 12px;
}
@media (min-width: 32em) {
  .event-repertoire__work,
  .event-repertoire__composer {
    font-size: 14px;
  }
}
.event-repertoire__work p,
.event-repertoire__composer p {
  margin-bottom: 0;
  flex-shrink: 0;
}

.event-repertoire__composer {
  font-weight: 700;
  text-transform: uppercase;
}
.event-repertoire__composer .composer-button {
  font-weight: 700;
  text-transform: uppercase;
}

.event-repertoire__work p {
  text-transform: uppercase;
}

.event-repertoire__line {
  width: 100%;
  border-bottom: 1px dotted #000;
}

.event-artists {
  display: flex;
  flex-direction: column;
  gap: 15px;
  margin-top: 30px;
}
@media (min-width: 32em) {
  .event-artists {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}
@media (min-width: 42.5em) {
  .event-artists {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (min-width: 62.5em) {
  .event-artists {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 80em) {
  .event-artists {
    grid-template-columns: repeat(4, 1fr);
  }
}

.event-artist__item {
  width: 100%;
}

.event-artist {
  display: flex;
  align-items: center;
  gap: 15px;
  background: none;
  border: 0;
  margin: 0;
  padding: 0;
  width: 100%;
}
@media (min-width: 32em) {
  .event-artist {
    flex-direction: column;
  }
}

.event-artist--bio {
  cursor: pointer;
}

.event-artist__media {
  width: 20%;
  height: 20%;
  border-radius: 100%;
  overflow: hidden;
}
@media (min-width: 32em) {
  .event-artist__media {
    width: 100%;
    height: 100%;
  }
}

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

.event-artist__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(1);
  transition: transform 0.3s ease;
  z-index: 1;
}
.event-artist--bio:hover .event-artist__image {
  transform: scale(1.2);
}

.event-artist__name {
  margin-bottom: 0;
  font-size: 14px;
  font-family: gt-ultra-standard, sans-serif;
  font-weight: 400;
  line-height: 1.2;
  text-align: left;
  text-wrap: balance;
  color: #000;
}
.event-artist--bio .event-artist__name {
  text-decoration: underline;
}
@media (min-width: 32em) {
  .event-artist__name {
    text-align: center;
  }
}

.event-details__description {
  margin-top: 30px;
}
.event-details__description p:last-child {
  margin-bottom: 0;
}

.event-details__program-book {
  margin-top: 30px;
}
@media (max-width: 31.99em) {
  .event-details__program-book {
    width: 100%;
  }
}

/*  ==========================================================================
	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;
    border-top: 1px solid;
    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;
}
@media (min-width: 50em) {
  .event-sticky-bar__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.event-sticky-bar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 60px;
}

.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: 20px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.event-sticky-bar__item {
  display: flex;
}

.event-sticky-bar__link {
  white-space: nowrap;
  font-size: 16px;
  font-weight: 700;
}

@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;
  position: relative;
  transition: color 0.4s ease;
}
.event-sticky-bar__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) {
  .event-sticky-bar__link:hover:before {
    transform: scaleX(100%);
  }
}

/*  ==========================================================================
	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: gt-ultra-fine, 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: gt-ultra-standard, 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: gt-ultra-standard, 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: #fff;
  color: #000;
}
@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: #000;
}

@media (min-width: 50em) {
  .embed-video.embed-video--full-width .video-item {
    display: block;
  }
  .embed-video.embed-video--full-width .video-item .video-item__details {
    width: 100%;
  }
  .embed-video.embed-video--full-width .video-item .video-item__media {
    width: 100%;
  }
}
@media (min-width: 62.5em) {
  .embed-video.embed-video--full-width .video-item .video-item__details {
    width: 100%;
  }
  .embed-video.embed-video--full-width .video-item .video-item__media {
    width: 100%;
  }
}

.embed-video.embed-video--black {
  background-color: #000;
  color: #fff;
}
.user-is-tabbing .embed-video.embed-video--black 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
	========================================================================== */
@media (min-width: 50em) {
  .embed-video .video-item {
    display: flex;
    align-items: center;
    gap: 60px;
  }
}
.embed-video .video-item .video-item__title {
  margin-bottom: 5px;
  border-bottom: 1px solid;
  padding-bottom: 15px;
  margin-bottom: 15px;
}
.embed-video .video-item .video-item__details {
  width: 100%;
}
@media (min-width: 50em) {
  .embed-video .video-item .video-item__details {
    width: 40%;
  }
}
@media (min-width: 62.5em) {
  .embed-video .video-item .video-item__details {
    width: 30%;
  }
}
.embed-video .video-item .video-item__description {
  margin-bottom: 30px;
}
.embed-video .video-item .video-item__media {
  display: block;
}
@media (min-width: 50em) {
  .embed-video .video-item .video-item__media {
    width: 60%;
  }
}
@media (min-width: 62.5em) {
  .embed-video .video-item .video-item__media {
    width: 70%;
  }
}
.embed-video .video-item .video-item__intrinsic-ratio {
  display: block;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  width: 100%;
  overflow: hidden;
}
.embed-video .video-item .video-item__image {
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  z-index: 2;
  transition: transform 0.4s ease;
}
.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: #000;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  z-index: 2;
  transition: transform 0.4s ease;
  padding: 10px;
}
.embed-video .video-item .video-item__icon .o-icon {
  width: 100%;
  height: 100%;
  color: #fff;
  margin-left: 15%;
}
@media (min-width: 32em) {
  .embed-video .video-item .video-item__icon {
    width: 70px;
    height: 70px;
    padding: 15px;
  }
}
@media (min-width: 62.5em) {
  .embed-video .video-item .video-item__icon {
    width: 90px;
    height: 90px;
    padding: 20px;
  }
}
.embed-video .video-item .video-item__media:hover .video-item__image,
.embed-video .video-item .video-item__media:focus .video-item__image {
  transform: scale(1.05);
}
.embed-video .video-item .video-item__media:hover .video-item__icon,
.embed-video .video-item .video-item__media:focus .video-item__icon {
  transform: scale(0.95);
}

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

.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;
  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__title {
  font-size: 32px;
  margin-bottom: 15px;
  width: auto;
}
@media (min-width: 50em) {
  .grouped-info__title {
    font-size: 42px;
    width: 50%;
  }
}
@media (min-width: 58em) {
  .grouped-info__title {
    font-size: 56px;
  }
}

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

.grouped-info__item-title {
  font-family: gt-ultra-fine, 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__title {
    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 #D0D0D0;
  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__title {
  font-size: 20px;
  text-transform: capitalize;
  margin-bottom: 0;
  height: fit-content;
  width: 100%;
}
@media (min-width: 50em) {
  .grouped-info--4up .grouped-info__title {
    font-size: 24px;
  }
}
@media (min-width: 58em) {
  .grouped-info--4up .grouped-info__title {
    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__months .feature-banner {
  margin-top: 60px;
}

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

.calendar-list-month__title {
  text-transform: capitalize;
  font-weight: 700;
  font-family: gt-ultra-fine, sans-serif;
  margin-bottom: 20px;
  padding-bottom: 10px;
  top: 60px;
  background-color: #fff;
  z-index: 2;
  font-size: 26px;
}
@media (min-width: 50em) {
  .calendar-list-month__title {
    position: sticky;
    font-size: 42px;
  }
}
@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: 25px;
}
@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__events div:last-child .calendar-list-event {
  padding-bottom: 0;
}

.calendar-list-day__title {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: sticky;
  top: 115px;
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  margin-bottom: 0;
  padding: 5px 0 0;
  border-right: 1px solid;
  border-top: 0;
  align-items: center;
  height: 100%;
}
@media (min-width: 50em) {
  .calendar-list-day__title {
    top: 130px;
    padding: 35px 0;
  }
}
@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: 18px;
  font-weight: lighter;
  text-transform: uppercase;
  font-family: gt-ultra-standard, sans-serif;
  margin-bottom: 6px;
}
@media (min-width: 50em) {
  .calendar-list-day__day {
    font-size: 14px;
  }
}

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

.calendar-list-event {
  display: flex;
  flex-direction: column;
  gap: 20px;
  background: none;
  padding: 0 15px 25px;
  border-width: 0;
  text-align: left;
  width: 100%;
  cursor: pointer;
}
@media (min-width: 50em) {
  .calendar-list-event {
    padding: 20px 20px 25px;
  }
}
.calendar-list-event:hover .calendar-list-event__header::before {
  width: 5px;
}

.calendar-list-event__header {
  position: relative;
}
.calendar-list-event__header:before {
  content: "";
  position: absolute;
  top: 0;
  left: -25px;
  width: 0;
  background: linear-gradient(136deg, #D73E23 20%, #87085d 40%, #000 80%);
  height: 100%;
  transition: width 0.1s ease-in-out;
}

.calendar-list-event__title {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 22px;
  margin-bottom: 0;
  transition: color 0.4s ease;
  color: #000;
}
@media (min-width: 50em) {
  .calendar-list-event__title {
    font-size: 32px;
  }
}
@media (min-width: 80em) {
  .calendar-list-event__title {
    font-size: 38px;
  }
}
@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: gt-ultra-standard, sans-serif;
  font-weight: 300;
  margin-bottom: 5px;
  display: inline-block;
  font-size: 13px;
}
@media (min-width: 50em) {
  .calendar-list-event__prefix,
  .calendar-list-event__suffix {
    font-size: 16px;
    margin-bottom: 10px;
  }
}
@media (min-width: 62.5em) {
  .calendar-list-event__prefix,
  .calendar-list-event__suffix {
    font-size: 18px;
  }
}

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

.calendar-list-event__spacer {
  display: inline-block;
  margin: 0 10px;
}

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

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

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

.calendar-category {
  background-color: var(--theme-color-dark);
  color: #fff;
  padding: 7px 10px;
  font-family: gt-ultra-standard, 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;
}
@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: gt-ultra-standard, sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

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

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

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

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

.calendar-filters__checkbox:checked + .calendar-filters__label::before {
  /* your styles here */
  background-color: #49454F;
  border-color: #49454F;
}

/*  ==========================================================================
	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;
  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: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 26px;
  text-transform: capitalize;
  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;
  border: 2px solid #000;
  background: transparent;
  border-radius: 50%;
  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;
  fill: #000;
}
.date-selector__button:last-child {
  margin-right: 0;
}
@media (hover: hover) and (pointer: fine) {
  .date-selector__button:hover {
    background-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: gt-ultra-fine, 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: gt-ultra-standard, sans-serif;
}

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

.date-selector__day--today {
  opacity: 1;
  position: relative;
  color: #87085D;
}
.date-selector__day--today:after {
  content: "";
  width: 32px;
  height: 32px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: transparent;
  z-index: -1;
  border-radius: 100%;
  border: 1px solid #87085D;
}

/*  ==========================================================================
	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__action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  position: sticky;
  bottom: 0;
  margin-top: 20px;
  padding-bottom: 15px;
  box-shadow: 0 -6px 20px 10px #fff;
}
.calendar-filters__action .calendar-filters__btn {
  width: 100%;
  outline-offset: 2px;
}
@media (min-width: 50em) {
  .calendar-filters__action {
    padding-bottom: 40px;
  }
}

.calendar-filters__body {
  display: flex;
  flex-direction: column;
  position: fixed;
  background-color: #fffaf8;
  border-left: 10px solid #87085D;
  top: 0;
  right: 0;
  padding: 20px 15px 0;
  height: 100svh;
  width: 100%;
  max-width: 316px;
  overflow-y: auto;
  translate: 100% 0;
  z-index: 20;
}
@media (min-width: 30em) {
  .calendar-filters__body {
    max-width: 400px;
  }
}
@media (min-width: 50em) {
  .calendar-filters__body {
    max-width: 650px;
    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 #000;
  outline-offset: 5px;
  overflow: hidden;
}
.calendar-filters__body .calendar-filters__reset {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 16px;
  font-weight: 500;
  color: #000;
}
.filters-open .calendar-filters__body {
  translate: 0;
  box-shadow: 0 0 25px 5px rgba(0, 0, 0, 0.1);
}

.calendar-filter__header {
  position: relative;
}

.calendar-filters__title {
  font-size: 20px;
  font-weight: 700;
  font-family: gt-ultra-fine, 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;
  border-width: 0 0 1px 0;
  background-color: transparent;
  width: 100%;
}
.user-is-tabbing .calendar-filters__group__header:focus {
  outline: 2px solid #000;
  outline-offset: 5px;
  overflow: hidden;
}

.calendar-filters__group__name {
  font-size: 18px;
  font-weight: 700;
  font-family: gt-ultra-fine, 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 #000;
  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: #fff;
  color: #000;
  padding: 40px 0;
  overflow: hidden;
}
.event-scroller:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 50%;
}
@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: #000;
}

.event-scroller--primary:before {
  background: linear-gradient(316deg, #D73E23 20%, #87085d 40%, #000 80%);
}

.event-scroller--blackberry:before {
  background: linear-gradient(316deg, #000, #87085D);
}

.event-scroller--blueberry:before {
  background: linear-gradient(316deg, #02ECFF 20%, #1754DD 40%, #870D5D 80%);
}

.event-scroller--dusk:before {
  background: linear-gradient(316deg, #F7E94D 20%, #F2900F 40%, #D73E23 80%);
}

.event-scroller--matcha:before {
  background: linear-gradient(136deg, #62D5C6 60%, #F7E94D);
}

.event-scroller--blossom:before {
  background: linear-gradient(136deg, #62D5C6 40%, #46B2C7 60%, #F498BC);
}

.event-scroller--dawn:before {
  background: linear-gradient(316deg, #BCCFFA 40%, #FFF0FA 80%, #FFFAF8);
}

.event-scroller--beige:before {
  background: #E6D6CF;
}

.event-scroller__inner {
  width: 100%;
  max-width: 1440px;
  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: 60px;
  display: flex;
  align-items: flex-end;
  gap: 20px;
}
@media (min-width: 50em) {
  .event-scroller__header {
    align-items: center;
  }
}

.event-scroller__details {
  display: flex;
  gap: 20px;
  align-items: center;
  flex-wrap: wrap;
}
@media (min-width: 62.5em) {
  .event-scroller__details {
    gap: 40px;
  }
}

.event-scroller__title {
  margin-bottom: 0;
}

.event-scroller__link {
  display: inline-block;
  text-decoration: underline;
}
@media (min-width: 62.5em) {
  .event-scroller__link {
    font-size: 24px;
  }
}

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

.event-scroller__previous,
.event-scroller__next {
  background: none;
  border: 2px solid #000;
  border-radius: 100%;
  padding: 10px;
  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-flex;
  }
}
.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: 100%;
  height: 100%;
  color: #000;
  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: #000;
  }
  .event-scroller__previous:not(.swiper-button-disabled):hover .o-icon,
  .event-scroller__next:not(.swiper-button-disabled):hover .o-icon {
    color: #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--color-white {
  color: #fff;
}
.event-scroller--color-white .event-scroller__previous,
.event-scroller--color-white .event-scroller__next {
  border-color: #fff;
}
.event-scroller--color-white .event-scroller__previous .o-icon,
.event-scroller--color-white .event-scroller__next .o-icon {
  color: #fff;
}
@media (hover: hover) and (pointer: fine) {
  .event-scroller--color-white .event-scroller__previous:not(.swiper-button-disabled):hover,
  .event-scroller--color-white .event-scroller__next:not(.swiper-button-disabled):hover {
    background-color: #fff;
  }
  .event-scroller--color-white .event-scroller__previous:not(.swiper-button-disabled):hover .o-icon,
  .event-scroller--color-white .event-scroller__next:not(.swiper-button-disabled):hover .o-icon {
    color: #000;
  }
}

.event-scroller--color-black {
  color: #000;
}

.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;
  position: relative;
  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__item--past {
  filter: grayscale(1);
}

/*  ==========================================================================
    Event Scroller - Production Archive
    ========================================================================== */
.page-production-archive .event-scroller {
  background: #fff;
  color: #000;
}
.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: #000;
  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 Scroller - On Event Page
    ========================================================================== */
.event-components .event-scroller {
  padding: 0;
  margin: var(--content-margin-small);
}
.event-components .event-scroller__header {
  margin-bottom: 20px;
}
.event-components .event-scroller__title {
  margin-bottom: 0;
}
@media (min-width: 62.5em) {
  .event-components .event-scroller {
    width: 100%;
  }
  .event-components .event-scroller__inner {
    padding: 0 40px;
  }
  .event-components .event-scroller__item {
    width: 75%;
    max-width: 400px;
  }
}
@media (min-width: 80em) {
  .event-components .event-scroller__inner {
    padding: 0 60px;
  }
}

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

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

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

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

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

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

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

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

.event-item__button {
  min-height: 24px;
  width: 24px;
}

.event-item__cite {
  margin: 0;
}

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

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

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

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

/*  ==========================================================================
	Event Item Poster
	========================================================================== */
.event-item--poster {
  color: #000;
  width: 100%;
}
@media (min-width: 32em) {
  .event-item--poster {
    width: calc(50% - 10px);
  }
}
@media (min-width: 62.5em) {
  .event-item--poster {
    width: calc(25% - 15px);
  }
}
.event-item--poster .event-item__media {
  position: relative;
  height: 0;
  padding-bottom: 133.3333333333%;
  overflow: hidden;
}
.event-item--poster .event-item__intrinsic-ratio {
  position: relative;
  height: 0;
  padding-bottom: 133.3333333333%;
}

/*  ==========================================================================
	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: #000;
}
@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: gt-ultra-standard, 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;
    width: 360px;
    max-width: 100%;
  }
}

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

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

.breadcrumbs__list {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 1rem;
  border: 1px solid #E6D6CF;
  background-color: #fff;
}

.breadcrumbs__item {
  --arrow-size: 1.1em;
  --arrow-width: 1.2em;
  position: relative;
  padding: 0.1em 0.5em;
  line-height: 1.8;
  white-space: nowrap;
}
.breadcrumbs__item::before, .breadcrumbs__item::after {
  content: " ";
  display: block;
  width: 0;
  height: 0;
  border-top: var(--arrow-size) solid transparent;
  border-bottom: var(--arrow-size) solid transparent;
  border-left: var(--arrow-width) solid var(--arrow-color);
  position: absolute;
  top: 50%;
  margin-top: calc(var(--arrow-size) * -1);
  left: 100%;
}
.breadcrumbs__item::before {
  --arrow-color: #fff;
  z-index: 2;
}
.breadcrumbs__item::after {
  --arrow-color: #E6D6CF;
  margin-left: 1px;
  z-index: 1;
}
.breadcrumbs__item:not(:first-of-type) {
  padding-inline-start: 1em;
}
.breadcrumbs__item:last-of-type {
  padding-inline-end: 1em;
}
.breadcrumbs__item:last-of-type::before, .breadcrumbs__item:last-of-type::after {
  display: none;
}
@media (min-width: 32em) {
  .breadcrumbs__item {
    --arrow-size: 1.4em;
    --arrow-width: 1.5em;
    padding: 0.4em 1em;
  }
  .breadcrumbs__item:not(:first-of-type) {
    padding-inline-start: 1.4em;
  }
  .breadcrumbs__item:last-of-type {
    padding-inline-end: 1.4em;
  }
}

.breadcrumb {
  transition: color 0.3s ease;
}
.breadcrumb:hover, .breadcrumb:focus {
  color: #396EEA;
}

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

.article-list__header {
  padding-bottom: 45px;
}
@media (min-width: 80em) {
  .article-list__header {
    padding-bottom: 65px;
  }
}

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

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

.article-list__item .post-item {
  height: auto;
}

/*  ==========================================================================
    Article List Header
    ========================================================================== */
.article-list-header {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.article-list-header .btn--pause-mobile {
  top: 15px;
}
.article-list-header .btn--pause-desktop {
  position: absolute;
  right: 15px;
  top: 15px;
  bottom: initial;
}
@media (min-width: 90em) {
  .article-list-header .btn--pause-desktop {
    right: 30px;
    top: 30px;
  }
}

.article-list-header__inner {
  display: flex;
  flex-direction: column-reverse;
  position: relative;
  width: 100%;
  margin: 0 auto;
}

.article-list-header__media {
  position: relative;
  isolation: isolate;
}
.article-list-header__media:before {
  position: absolute;
  content: "";
  background-color: rgba(0, 0, 0, 0.5);
  height: 100%;
  width: 100%;
  z-index: 3;
}

.article-list-header__figure {
  position: relative;
  margin-bottom: 0;
  z-index: -1;
}

.article-list-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 71.4285714286%;
  height: 0;
}
@media (min-width: 62.5em) {
  .article-list-header__intrinsic-ratio {
    padding-bottom: 33.3333333333%;
  }
}

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

.article-list-header__content {
  width: 100%;
  max-width: 1000px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-list-header__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.article-list-header__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 30px;
  padding: 20px;
  position: absolute;
  inset: 0;
  color: #fff;
  text-align: center;
  z-index: 2;
}
@media (min-width: 50em) {
  .article-list-header__content {
    padding-bottom: 30px;
    gap: 40px;
  }
}
@media (min-width: 62.5em) {
  .article-list-header__content {
    padding-top: 100px;
    padding-bottom: 60px;
  }
}

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

.article-list-header__title {
  margin-bottom: 0;
  line-height: 1.2;
  text-wrap: balance;
}

.article-list-header__description {
  text-wrap: balance;
}
.article-list-header__description p:last-child {
  margin-bottom: 0;
}

.article-list-header__footer {
  padding: 15px;
}
@media (min-width: 50em) {
  .article-list-header__footer {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
  }
}
@media (min-width: 62.5em) {
  .article-list-header__footer {
    padding: 20px;
  }
}

.article-list-header__links {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media (min-width: 42.5em) {
  .article-list-header__links {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 50em) {
  .article-list-header__links {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
  }
}

/*  ==========================================================================
    Article List Header - Image
    ========================================================================== */
.article-list-header--image .article-list-header__content {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-list-header--image .article-list-header__content {
    padding-left: 15px;
    padding-right: 15px;
  }
}

/*  ==========================================================================
    Article List Header - Video
    ========================================================================== */
.article-list-header--video {
  margin-bottom: 0;
}
.article-list-header--video button.video-controls {
  top: 15px;
  right: 15px;
  bottom: auto;
}
@media (min-width: 50em) {
  .article-list-header--video button.video-controls {
    top: auto;
    bottom: 20px;
    right: 20px;
  }
}
@media (min-width: 72em) {
  .article-list-header--video button.video-controls {
    bottom: 40px;
    right: 40px;
  }
}
@media (min-width: 96.875em) {
  .article-list-header--video button.video-controls {
    bottom: 40px;
    right: 90px;
  }
}

.article-list-header__media--video {
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: 0;
  left: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: -1;
}

@media (min-width: 50em) {
  .article-list-header__media--video .video-container {
    min-height: 500px;
  }
}
@media (min-width: 58em) {
  .article-list-header__media--video .video-container {
    min-height: 800px;
  }
}
@media (min-width: 90em) {
  .article-list-header__media--video .video-container {
    min-height: 2000px;
  }
}

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

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

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

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

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

.article-header__title {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 28px;
  margin-bottom: 0;
  line-height: 1.1;
}
@media (min-width: 50em) {
  .article-header__title {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .article-header__title {
    font-size: 60px;
  }
}

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

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

@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;
  align-items: center;
  flex-wrap: wrap;
  flex-shrink: 0;
  gap: 5px 10px;
  width: 100%;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid;
}
@media (min-width: 50em) {
  .article-header__footer {
    gap: 5px 20px;
    margin-top: 30px;
    padding-top: 25px;
  }
}
.article-header__footer .o-icon {
  width: 12px;
  height: 12px;
}

/*  ==========================================================================
	Article Header - Media
	========================================================================== */
.article-header__media {
  position: relative;
}
@media (min-width: 62.5em) {
  .article-header__media {
    margin-top: 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-start;
  text-align: right;
  margin-top: 10px;
  font-size: 14px;
  font-weight: 300;
  max-width: 800px;
}

/*  ==========================================================================
	Event Inline
	========================================================================== */
.event-inline {
  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;
}
@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: gt-ultra-standard, 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: gt-ultra-fine, 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 Grid
	========================================================================== */
.page-grid {
  position: relative;
  margin: var(--content-margin);
  overflow: hidden;
}
.page-grid:last-child {
  margin-bottom: 0;
}

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

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

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

.page-grid__list {
  display: grid;
  gap: 40px;
}
@media (min-width: 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: gt-ultra-standard, 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: #D0D0D0;
}

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

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

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

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

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

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

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

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

.site-search__nav {
  padding-bottom: 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--disabled {
  pointer-events: none;
  cursor: default;
}

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

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

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

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

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

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

.search-result {
  display: block;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
  margin: 20px 0;
  transform: scale(1);
  transition: transform 0.3s ease;
}
.search-result:last-child {
  border-bottom: none;
}
@media (min-width: 50em) {
  .search-result {
    margin: 40px 0;
    padding-bottom: 40px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .search-result:hover, .search-result:focus {
    transform: scale(1.01);
  }
}
.search-result .search-result__title {
  margin-bottom: 0;
  line-height: 1.1;
}
.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: gt-ultra-standard, 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: #000;
    background-color: #000;
    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;
  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: gt-ultra-standard, 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: gt-ultra-standard, 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;
  text-wrap: balance;
  margin-top: 15px;
  font-size: 14px;
  max-width: 800px;
  gap: 3px;
}
@media (min-width: 50em) {
  .image-block__figcaption {
    font-size: 16px;
  }
}

.image-block__credit {
  font-style: italic;
}

.image-block__image.image-block__uncropped-image {
  position: relative;
}

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

.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;
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.feature-card-item__image {
  position: relative;
  width: 100%;
  height: auto;
  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: gt-ultra-standard, 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: gt-ultra-standard, 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-posts .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;
}
@media (min-width: 58em) {
  .featured-post-item {
    flex-direction: row;
  }
}
@media (min-width: 62.5em) {
  .featured-post-item {
    flex-direction: column;
  }
}

.featured-post-item__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  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__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__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: gt-ultra-fine, 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: gt-ultra-standard, 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%;
  }
}

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

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

.embed-iframe__title {
  margin-bottom: 0;
  padding-top: 10px;
  font-family: gt-ultra-fine, sans-serif;
}
@media (min-width: 50em) {
  .embed-iframe__title {
    padding-top: 15px;
  }
}

.embed-iframe__media {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  margin-top: 20px;
}
@media (min-width: 72em) {
  .embed-iframe__media {
    margin-top: 40px;
  }
}

@media (max-width: 49.99em) {
  .embed-iframe__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;
}
@media (min-width: 50em) {
  .season-header__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.season-header__inner {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 72em) {
  .season-header__inner {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    gap: 40px;
  }
}

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

.season-header__titles {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
@media (min-width: 50em) {
  .season-header__titles {
    max-width: calc(100% - 220px);
  }
}
@media (min-width: 72em) {
  .season-header__titles {
    max-width: 100%;
  }
}

.season-header__title {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  font-family: gt-ultra-standard, 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: gt-ultra-standard, sans-serif;
  font-weight: 800;
  font-size: 22px;
  text-transform: uppercase;
  line-height: 0.8;
}
@media (min-width: 50em) {
  .season-header__prefix,
  .season-header__suffix {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .season-header__prefix,
  .season-header__suffix {
    font-size: 38px;
  }
}
@media (min-width: 72em) {
  .season-header__prefix,
  .season-header__suffix {
    font-size: 48px;
  }
}

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

/*  ==========================================================================
	Season Info
	========================================================================== */
.season-info {
  margin: 30px 0;
}
@media (min-width: 50em) {
  .season-info {
    margin: 40px 0;
  }
}
@media (min-width: 62.5em) {
  .season-info {
    margin: 80px 0;
  }
}

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

.season-info__body {
  width: 100%;
  max-width: 820px;
}
.season-info__body:only-child {
  margin: 0 auto;
}

.season-info__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: fixed;
  bottom: 0;
  right: 0;
  padding: 15px;
  width: 100%;
  background-color: #fff;
  box-shadow: 0px 0px 20px 6px rgba(0, 0, 0, 0.2588235294);
  z-index: 5;
}
@media (min-width: 30em) {
  .season-info__actions {
    flex-direction: row;
  }
  .season-info__actions > * {
    flex-basis: 100%;
  }
}
@media (min-width: 50em) {
  .season-info__actions {
    flex-direction: column;
    position: sticky;
    gap: 15px;
    top: 15px;
    bottom: unset;
    padding: 0;
    box-shadow: none;
    max-width: 300px;
  }
}
@media (min-width: 72em) {
  .season-info__actions {
    top: calc(var(--global-header-height) + 15px);
  }
}

/*  ==========================================================================
	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--primary {
  background-color: #E6D6CF;
}

.event-grid--light {
  background-color: #FFFAF8;
}

.event-grid--red {
  background-color: #D73E23;
}

.event-grid--blue {
  background-color: #396EEA;
}

.event-grid--teal {
  background-color: #62D5C6;
}

.event-grid--berry {
  background-color: #87085D;
}

.event-grid--green {
  background-color: #2F8609;
}

.event-grid--orange {
  background-color: #F2900F;
}

.event-grid--yellow {
  background-color: #F7E94D;
}

.event-grid--pink {
  background-color: #DF0C98;
}

.event-grid--purple {
  background-color: #7D0BDA;
}

.event-grid--mauve {
  background-color: #A36272;
}

.event-grid--black {
  background-color: #000;
}

.event-grid__inner {
  width: 100%;
  max-width: 1440px;
  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: 26px;
  font-weight: 700;
  margin-bottom: 0;
  font-family: gt-ultra-fine, sans-serif;
}
@media (min-width: 50em) {
  .event-grid__title {
    font-size: 28px;
  }
}
@media (min-width: 62.5em) {
  .event-grid__title {
    font-size: 32px;
  }
}

.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: 30px 25px;
  }
}

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

.event-grid__item--fullwidth {
  grid-column: 1/-1;
}
@media (max-width: 89.99em) {
  .event-grid__item--fullwidth {
    margin: 0 -15px;
    width: calc(100% + 30px);
  }
}
.event-grid__item--fullwidth .feature-banner {
  width: 100%;
}

/*  ==========================================================================
	Event Grid Poster
	========================================================================== */
.event-grid--poster .event-grid__list {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

/*  ==========================================================================
    Home Hero
    ========================================================================== */
.home-hero {
  display: flex;
  flex-direction: column-reverse;
  background-color: #000;
  color: #fff;
  position: relative;
  overflow: hidden;
  max-height: 85svh;
}
@media (min-width: 50em) {
  .home-hero {
    flex-direction: column;
  }
  .home-hero:after {
    content: "";
    position: absolute;
    background: linear-gradient(to top, #000, transparent);
    width: 100%;
    height: 60%;
    left: 0;
    bottom: 0;
  }
}

.home-hero + .content-blocks > *:first-child {
  margin-top: 0;
}

.home-hero__inner {
  display: flex;
  justify-content: center;
}

.home-hero__body {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .home-hero__body {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.home-hero__body {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
}
.home-hero__body:before {
  position: absolute;
  content: "";
  background: linear-gradient(to top, black, transparent);
  height: 100px;
  width: 100%;
  top: 0;
  left: 0;
  transform: translateY(-100%);
}
@media (min-width: 50em) {
  .home-hero__body {
    position: absolute;
    bottom: 0;
    padding-bottom: 40px;
  }
  .home-hero__body:before {
    display: none;
  }
}
@media (min-width: 62.5em) {
  .home-hero__body {
    padding-bottom: 40px;
  }
}
@media (min-width: 80em) {
  .home-hero__body {
    padding-bottom: 80px;
  }
}

.home-hero__title {
  display: flex;
  flex-direction: column;
  text-wrap: balance;
  text-shadow: 5px 5px 7px rgba(0, 0, 0, 0.25);
  width: 100%;
  max-width: 1000px;
  margin-bottom: 15px;
}

.home-hero__event-details {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.home-hero__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 2px 7px;
  text-transform: uppercase;
  font-size: 14px;
}
@media (min-width: 30em) {
  .home-hero__meta {
    font-size: 16px;
  }
}
@media (min-width: 50em) {
  .home-hero__meta {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .home-hero__meta {
    font-size: 20px;
  }
}
.home-hero__meta .o-icon {
  color: #fff;
  width: 10px;
  height: 10px;
}

.home-hero__date,
.home-hero__venue {
  margin-bottom: 0;
}

@media (max-width: 31.99em) {
  .home-hero__btn {
    width: 100%;
  }
}

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

.home-hero__intrinsic-ratio {
  position: relative;
  padding-bottom: 133.3333333333%;
  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 - Video
    ========================================================================== */
.home-hero--video {
  margin-bottom: 0;
}
.home-hero--video button.video-controls {
  top: 15px;
  right: 15px;
  bottom: auto;
}
@media (min-width: 50em) {
  .home-hero--video button.video-controls {
    top: auto;
    bottom: 20px;
    right: 20px;
  }
}
@media (min-width: 72em) {
  .home-hero--video button.video-controls {
    bottom: 40px;
    right: 40px;
  }
}
@media (min-width: 96.875em) {
  .home-hero--video button.video-controls {
    bottom: 40px;
    right: 90px;
  }
}

.home-hero__media--video {
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: 0;
  left: 0;
  pointer-events: none;
  overflow: hidden;
}
@media (min-width: 50em) {
  .home-hero__media--video {
    height: 150%;
  }
}
@media (min-width: 62.5em) {
  .home-hero__media--video {
    height: 100%;
  }
}

@media (min-width: 50em) {
  .home-hero__media--video .video-container {
    min-height: 500px;
  }
}
@media (min-width: 58em) {
  .home-hero__media--video .video-container {
    min-height: 800px;
  }
}
@media (min-width: 90em) {
  .home-hero__media--video .video-container {
    min-height: 2000px;
  }
}

.home-hero__pause {
  position: absolute;
  right: 15px;
}

.home-hero__pause.btn--pause-mobile {
  top: 60px;
}

/*  ========================================================================== */
/*  Header Video
/*  ========================================================================== */
.video-container,
.video-container iframe {
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  width: 2000px;
  height: 100%;
  z-index: 2;
  transition: opacity 1s ease;
}
@media (min-width: 90em) {
  .video-container,
  .video-container iframe {
    width: 100%;
    height: 105%;
  }
}

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

.video-container-overlay {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  z-index: 3;
}

button.video-controls {
  display: flex;
  align-items: center;
  gap: 0 8px;
  position: absolute;
  bottom: -40px;
  right: 15px;
  padding: 10px 20px;
  color: #fff;
  background-color: #383839;
  border-radius: 20px;
  cursor: pointer;
  opacity: 0;
  transition: opacity 1s ease;
  z-index: 3;
}
.header-video:has(.video-container--loaded) button.video-controls, .header-video.video-container--loaded button.video-controls {
  opacity: 1;
}
button.video-controls.playing .video-control--pause {
  display: block;
}
button.video-controls.playing .video-control--play {
  display: none;
}
button.video-controls.paused .video-control--play {
  display: block;
}
button.video-controls.paused .video-control--pause {
  display: none;
}
@media (min-width: 50em) {
  button.video-controls {
    bottom: 10px;
    right: 10px;
  }
}
@media (min-width: 62.5em) {
  button.video-controls {
    bottom: 15px;
    right: 15px;
  }
}

.video-control {
  height: 20px;
  width: 11px;
}
.video-control .o-icon {
  width: 100%;
  height: 100%;
}

.video-control--text {
  font-size: 14px;
}

/*  ==========================================================================
	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: gt-ultra-standard, sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  width: 100%;
  line-height: 0.8;
}

.venue-header__prefix,
.venue-header__suffix {
  font-family: gt-ultra-standard, 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: #000;
}
.venue-scroller__previous:not(.swiper-button-disabled):hover .o-icon,
.venue-scroller__next:not(.swiper-button-disabled):hover .o-icon {
  color: #fff;
}

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

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

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

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

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

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

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

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

.venue-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 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: gt-ultra-standard, 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: gt-ultra-standard, 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;
  }
}

.video-series {
  padding: 40px 0;
}
@media (min-width: 50em) {
  .video-series {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .video-series {
    padding: 80px 0;
  }
}
.video-series--black {
  background-color: #000;
  color: #fff;
}
.video-series--black .video-series__previous,
.video-series--black .video-series__next {
  background-color: #000;
  color: #fff;
}

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

.video-series__header {
  padding-bottom: 25px;
}

.video-series__title {
  border-bottom: 1px solid;
  padding-bottom: 15px;
  margin-bottom: 15px;
  font-family: gt-ultra-fine, sans-serif;
  font-size: 26px;
}
@media (min-width: 50em) {
  .video-series__title {
    font-size: 42px;
  }
}

.video-series__description {
  font-weight: 300;
}

.video-series__intrinsic-ratio {
  position: relative;
  margin-bottom: 20px;
}

.video-series__image {
  width: 100%;
}

.video-series__icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60px;
  height: 60px;
}
@media (min-width: 50em) {
  .video-series__icon {
    width: 80px;
    height: 80px;
  }
}
.video-series__icon .o-icon {
  width: 100%;
  height: 100%;
}

.video-series__list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 60px;
  border-bottom: 1px solid;
  margin-bottom: 40px;
}
@media (min-width: 50em) {
  .video-series__list-header {
    margin-top: 100px;
  }
}

.video-series__subtitle {
  font-size: 22px;
}
@media (min-width: 50em) {
  .video-series__subtitle {
    font-size: 26px;
  }
}

.video-series__actions {
  display: flex;
  gap: 0 8px;
  justify-content: flex-end;
  margin-bottom: 10px;
}

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

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

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

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

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

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

/*  ==========================================================================
    Featured Post
    ========================================================================== */
.featured-post {
  position: relative;
  margin: var(--content-margin);
}

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

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

.featured-post__content {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 50em) {
  .featured-post__content {
    flex-direction: row;
    align-items: center;
    gap: 40px;
  }
  .featured-post__content .featured-post__media {
    width: 50%;
  }
  .featured-post__content .featured-post__body {
    width: 50%;
  }
}
@media (min-width: 62.5em) {
  .featured-post__content {
    gap: 60px;
  }
  .featured-post__content .featured-post__media {
    width: 70%;
  }
}
@media (min-width: 72em) {
  .featured-post__content {
    gap: 80px;
  }
  .featured-post__content .featured-post__media {
    width: 100%;
  }
}

.featured-post__media {
  width: 100%;
}

.featured-post__intrinsic-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
}

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

.featured-post__body {
  display: flex;
  flex-direction: column;
  gap: 50px;
}

.featured-post__titles {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #000;
}

.featured-post__heading {
  font-family: gt-ultra-standard, sans-serif;
  font-weight: 400;
  font-size: 24px;
  text-wrap: balance;
  line-height: 1;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .featured-post__heading {
    font-size: 26px;
  }
}
@media (min-width: 62.5em) {
  .featured-post__heading {
    font-size: 32px;
  }
}

.featured-post__subtitle {
  font-family: gt-ultra-standard, sans-serif;
  font-weight: 400;
  font-size: 16px;
  text-wrap: balance;
  margin: 0;
  line-height: 1;
}
@media (min-width: 50em) {
  .featured-post__subtitle {
    font-size: 18px;
  }
}
@media (min-width: 62.5em) {
  .featured-post__subtitle {
    font-size: 20px;
  }
}

.featured-post__summary {
  text-wrap: pretty;
  margin-bottom: 0;
}

.featured-post__cta {
  margin-bottom: 0 !important;
  width: 100%;
}

/*  ==========================================================================
    Featured Post - Related
    ========================================================================== */
.featured-post--related .featured-post__content {
  align-items: flex-start;
}

.featured-post-related {
  margin-top: 30px;
}

.featured-post-related__title {
  font-family: gt-ultra-standard, sans-serif;
  font-weight: 400;
  text-transform: uppercase;
  margin-bottom: 20px;
}

.featured-post-related__list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding-left: 15px;
}

.featured-post-related__link {
  text-decoration: underline;
  font-weight: 300;
  font-size: 14px;
}
@media (min-width: 50em) {
  .featured-post-related__link {
    font-size: 16px;
  }
}
@media (min-width: 62.5em) {
  .featured-post-related__link {
    font-size: 18px;
  }
}

/*  ==========================================================================
    Feature Grid
    ========================================================================== */
.feature-grid {
  position: relative;
  margin: var(--content-margin);
  padding: 40px 0;
  background-color: #E6D6CF;
}
@media (min-width: 50em) {
  .feature-grid {
    padding: 80px 0;
  }
}

.feature-grid__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .feature-grid__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.feature-grid__inner {
  display: flex;
  flex-direction: column;
  gap: 60px;
}
@media (min-width: 50em) {
  .feature-grid__inner {
    flex-direction: row;
    gap: 40px;
  }
}
@media (min-width: 80em) {
  .feature-grid__inner {
    gap: 60px;
  }
}

.feature-grid__items {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 50em) {
  .feature-grid__items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px 20px;
  }
}
@media (min-width: 72em) {
  .feature-grid__items {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 80em) {
  .feature-grid__items {
    gap: 40px;
  }
}

.feature-grid__item {
  width: 100%;
}

.feature-grid__info {
  width: 100%;
}
@media (min-width: 50em) {
  .feature-grid__info {
    position: sticky;
    top: 30px;
    max-width: 300px;
  }
}
@media (min-width: 80em) {
  .feature-grid__info {
    max-width: 385px;
  }
}

.feature-grid__title {
  text-wrap: balance;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #000;
}

.feature-grid__subtitle {
  font-size: 24px;
  font-family: gt-ultra-fine, sans-serif;
  line-height: 1.2;
}

.feature-grid__description {
  margin-bottom: 0;
}

.feature-grid__cta {
  margin-top: 40px;
}
@media (max-width: 31.99em) {
  .feature-grid__cta {
    width: 100%;
  }
}

/*  ==========================================================================
    Feature Grid - Item
    ========================================================================== */
.feature-grid-item {
  display: flex;
  gap: 20px;
}
@media (min-width: 32em) {
  .feature-grid-item {
    flex-direction: column;
  }
}

.feature-grid-item__body {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.feature-grid-item__title {
  line-height: 1.3;
  text-wrap: balance;
}

.feature-grid-item__cta {
  text-decoration: underline;
  font-weight: 300;
  font-size: 14px;
  margin-top: 15px;
}
@media (max-width: 31.99em) {
  .feature-grid-item__cta {
    margin-top: auto;
  }
}
@media (min-width: 50em) {
  .feature-grid-item__cta {
    font-size: 16px;
  }
}
@media (min-width: 62.5em) {
  .feature-grid-item__cta {
    font-size: 18px;
  }
}

.feature-grid-item__media {
  margin-bottom: 0;
  width: 100%;
}

.feature-grid-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
  overflow: hidden;
}
@media (min-width: 32em) {
  .feature-grid-item__intrinsic-ratio {
    padding-bottom: 56.25%;
  }
}

.feature-grid-item__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
}

/*  ==========================================================================
    Article Nav
    ========================================================================== */
.article-nav {
  position: sticky;
  top: 0;
  background-color: #FFFAF8;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.1);
  padding: 15px 0;
  z-index: 5;
  overflow-x: hidden;
}
@media (min-width: 72em) {
  .article-nav {
    top: var(--global-header-height);
  }
}

.article-nav__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .article-nav__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.article-nav__inner {
  display: flex;
  align-items: center;
  gap: 30px;
  position: relative;
}

.article-nav__text {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 0;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}
.article-nav__text:before {
  position: absolute;
  content: "";
  background-color: #FFFAF8;
  width: 500px;
  height: 100%;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  z-index: -1;
}

.article-nav__actions {
  display: flex;
  gap: 0 40px;
  margin-left: auto;
  flex-shrink: 0;
  position: absolute;
  left: 0;
  width: 100%;
  z-index: 2;
}

.article-nav__previous,
.article-nav__next {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  color: #000;
  border: none;
  padding: 0;
  cursor: pointer;
  width: 40px;
  height: 40px;
  opacity: 1;
  transition: background-color 0.4s ease, opacity 0.4s ease;
}
.article-nav__previous.swiper-button-disabled,
.article-nav__next.swiper-button-disabled {
  cursor: not-allowed;
  opacity: 0;
}
.article-nav__previous .o-icon,
.article-nav__next .o-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  transition: color 0.4s ease;
}
.article-nav__previous:after,
.article-nav__next:after {
  position: absolute;
  content: "";
  width: 50px;
  height: 100%;
  z-index: -1;
}
@media (hover: hover) and (pointer: fine) {
  .article-nav__previous:not(.swiper-button-disabled):hover,
  .article-nav__next:not(.swiper-button-disabled):hover {
    background-color: color-mix(in srgb, var(--theme-color-light) 75%, #fff);
  }
}

.article-nav__previous {
  margin-right: 0;
  left: 97px;
}
.article-nav__previous .o-icon {
  transform: rotate(180deg);
}
.article-nav__previous:active .o-icon {
  transform: scale(0.9) rotate(180deg);
}
.article-nav__previous:after {
  left: 0;
  background: linear-gradient(to left, rgba(255, 250, 248, 0), rgba(255, 250, 248, 0.9), #FFFAF8);
}

.article-nav__next {
  margin-right: 15px;
  right: -20px;
}
.article-nav__next:active .o-icon {
  transform: scale(0.9);
}
.article-nav__next:after {
  right: 0;
  background: linear-gradient(to right, rgba(255, 250, 248, 0), rgba(255, 250, 248, 0.9), #FFFAF8);
}

.article-nav__scroll {
  display: flex;
  align-items: center;
  margin: 0 -20px;
  padding-left: 20px;
  -webkit-overflow-scrolling: touch;
  overflow-x: scroll;
}
.article-nav__scroll::-webkit-scrollbar {
  display: none;
}

.article-nav__list {
  display: flex;
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  -webkit-overflow-scrolling: touch;
}

.article-nav__item {
  flex-shrink: 0;
  padding-right: 30px;
}
@media (min-width: 50em) {
  .article-nav__item {
    padding-right: 60px;
  }
}
@media (min-width: 72em) {
  .article-nav__item {
    padding-right: 100px;
  }
}

.article-nav__link {
  font-size: 18px;
}
.article-nav__link:hover, .article-nav__link:focus {
  text-decoration: underline;
}

/*  ==========================================================================
    Event Page
    ========================================================================== */
.event-container {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
@media (min-width: 62.5em) {
  .event-container {
    flex-direction: row;
    min-height: 100svh;
  }
}

.event-sticky {
  width: 100%;
}
@media (min-width: 62.5em) {
  .event-sticky {
    position: sticky;
    top: 0;
    left: 0;
    width: 50%;
    min-height: 100svh;
    background-color: #000;
  }
}
@media (min-width: 72em) {
  .event-sticky {
    top: var(--global-header-height);
  }
}
.event-sticky .event-sticky__heart {
  z-index: 3;
}

.event-body {
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-start;
  position: relative;
  width: 100%;
}
@media (min-width: 62.5em) {
  .event-body {
    flex-direction: row;
    width: 50%;
  }
}

.event-components {
  width: 100%;
}
@media (min-width: 62.5em) {
  .event-components {
    overflow: hidden;
  }
}
.event-components .feature-panel {
  margin: var(--content-margin-small);
}
.event-components .feature-item {
  background-color: #E6D6CF;
}

.event-nav {
  position: sticky;
  top: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
  padding: 15px;
  width: 100%;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.1);
  z-index: 5;
}
@media (min-width: 50em) {
  .event-nav {
    padding: 20px;
  }
}
@media (min-width: 62.5em) {
  .event-nav {
    top: 0;
    right: 0;
    width: auto;
    box-shadow: none;
  }
}
@media (min-width: 72em) {
  .event-nav {
    top: var(--global-header-height);
  }
}

.event-nav__title {
  text-transform: uppercase;
  text-decoration: underline;
  text-underline-offset: 10px;
  margin-bottom: 30px;
  white-space: nowrap;
}
@media (max-width: 62.49em) {
  .event-nav__title {
    display: none;
  }
}

.event-nav__list {
  display: flex;
  justify-content: space-around;
  gap: 30px;
  margin: 0;
  padding: 0;
  list-style: none;
  width: 100%;
}
@media (min-width: 62.5em) {
  .event-nav__list {
    flex-direction: column;
    gap: 60px;
  }
}

.event-nav__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  text-align: center;
  line-height: 1.3;
  width: 100%;
  max-width: 70px;
  font-size: 12px;
  text-transform: uppercase;
}
.event-nav__link .o-icon {
  flex-shrink: 0;
}

@media (max-width: 62.49em) {
  .event-nav__text {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
  }
}

/*  ==========================================================================
    Date Picker
    ========================================================================== */
@media (min-width: 62.5em) {
  .event-header__date-picker--mobile {
    display: none;
  }
}

.event-header__date-picker--desktop {
  display: none;
}
@media (min-width: 62.5em) {
  .event-header__date-picker--desktop {
    display: block;
  }
}

.date-picker__list {
  display: flex;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 15px;
  overflow-x: auto;
}
@media (min-width: 50em) {
  .date-picker__list {
    flex-wrap: wrap;
    overflow: hidden;
    padding: 0;
  }
}

.date-picker__item {
  flex-shrink: 0;
}

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

.date-picker__inner {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 14px;
  text-transform: uppercase;
  border: 1px solid #000;
  background-color: transparent;
  padding: 10px;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}
.date-picker__radio:checked + .date-picker__inner {
  background-color: #D73E23;
  border-color: #D73E23;
  color: #fff;
}
@media (min-width: 50em) {
  .date-picker__inner {
    flex-direction: column;
    gap: 5px;
    padding: 10px;
    border-radius: 3px;
    text-transform: uppercase;
    position: relative;
    transition: border-color 0.3s ease;
  }
  .date-picker__inner:after {
    opacity: 0;
    position: absolute;
    content: "Buy Tickets";
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #D73E23;
    color: #fff;
    width: 100%;
    height: 100%;
    width: 100%;
    font-size: 20px;
    text-align: center;
    line-height: 1;
    transition: opacity 0.3s ease;
  }
  .date-picker__inner:hover {
    border-color: #D73E23;
  }
  .date-picker__inner:hover:after {
    opacity: 1;
  }
}

.date-picker__header {
  display: flex;
  align-items: center;
  gap: 5px;
  line-height: 1;
}
.date-picker__header .o-icon {
  width: 8px;
  height: 8px;
}
@media (min-width: 50em) {
  .date-picker__header {
    font-size: 10px;
  }
  .date-picker__header .o-icon:nth-child(2 of .o-icon) {
    display: none;
  }
}

.date-picker__day {
  letter-spacing: 1px;
}

.date-picker__date {
  margin-bottom: 0;
  line-height: 1;
  text-align: center;
}
@media (min-width: 50em) {
  .date-picker__date {
    font-size: 26px;
  }
}

.date-picker__availability {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  color: #D73E23;
  font-size: 12px;
  text-align: center;
  margin-top: 5px;
  margin-bottom: 0;
}
.date-picker__availability .o-icon {
  width: 12px;
  height: 12px;
}
@media (min-width: 50em) {
  .date-picker__availability {
    font-size: 10px;
  }
}

.date-picker__btn {
  width: 100%;
  margin: 0;
  padding: 20px;
  background-color: #D73E23;
  color: #fff;
  border: 0;
  text-transform: uppercase;
  font-weight: 700;
}
@media (min-width: 50em) {
  .date-picker__btn {
    display: none;
  }
}

/*  ==========================================================================
    Dining Panel
    ========================================================================== */
.dining-panel {
  margin: var(--content-margin-small);
}

.dining-panel__inner {
  padding: 0 15px;
}
@media (min-width: 62.5em) {
  .dining-panel__inner {
    padding: 0 40px;
  }
}
@media (min-width: 80em) {
  .dining-panel__inner {
    padding: 0 60px;
  }
}

.dining-panel__title {
  margin-bottom: 20px;
}

.dining-panel__heading {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 400;
  font-size: 20px;
  margin-top: 25px;
  margin-bottom: 20px;
}

.dining-panel__description {
  margin-top: 20px;
}
.dining-panel__description p:last-child {
  margin-bottom: 0;
}

.dining-panel__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
  margin-top: 20px;
  width: 100%;
}
.dining-panel__btns > * {
  flex-grow: 1;
}

.dining-panel__figure {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
}

.dining-panel__intrinsic-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
}

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

/*  ==========================================================================
    Special Programs
    ========================================================================== */
.special-programs {
  margin: var(--content-margin-small);
}

.special-programs__inner {
  padding: 0 15px;
}
@media (min-width: 62.5em) {
  .special-programs__inner {
    padding: 0 40px;
  }
}
@media (min-width: 80em) {
  .special-programs__inner {
    padding: 0 60px;
  }
}

.special-programs__title {
  margin-bottom: 20px;
}

.special-programs__heading {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 400;
  font-size: 20px;
  margin-top: 25px;
  margin-bottom: 20px;
}

.special-programs__subtitle {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 20px;
}

.special-programs__description {
  margin-top: 20px;
}
.special-programs__description p:last-child {
  margin-bottom: 0;
}

.special-programs__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
  margin-top: 20px;
  width: 100%;
}
.special-programs__btns > * {
  flex-grow: 1;
}

.special-programs__figure {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
}

.special-programs__intrinsic-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
}

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

.program-family {
  margin-top: 40px;
}

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

.accessibility-panel__inner {
  padding: 0 15px;
}
@media (min-width: 62.5em) {
  .accessibility-panel__inner {
    padding: 0 40px;
  }
}
@media (min-width: 80em) {
  .accessibility-panel__inner {
    padding: 0 60px;
  }
}

.accessibility-panel__title {
  margin-bottom: 20px;
}

.accessibility-panel__heading {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 400;
  font-size: 20px;
  margin-top: 25px;
  margin-bottom: 20px;
}

.accessibility-panel__description {
  margin-top: 20px;
}
.accessibility-panel__description p:last-child {
  margin-bottom: 0;
}

.accessibility-panel__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
  margin-top: 20px;
  width: 100%;
}
.accessibility-panel__btns > * {
  flex-grow: 1;
}

/*  ==========================================================================
    Info Panel
    ========================================================================== */
.info-panel {
  margin: var(--content-margin-small);
}

.info-panel__inner {
  padding: 0 15px;
}
@media (min-width: 62.5em) {
  .info-panel__inner {
    padding: 0 40px;
  }
}
@media (min-width: 80em) {
  .info-panel__inner {
    padding: 0 60px;
  }
}

.info-panel__title {
  margin-bottom: 20px;
}

.info-panel__heading {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 400;
  font-size: 20px;
  margin-top: 25px;
  margin-bottom: 20px;
}

.info-panel__description {
  margin-top: 20px;
}
.info-panel__description p:last-child {
  margin-bottom: 0;
}

.info-panel__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
  margin-top: 20px;
  width: 100%;
}
.info-panel__btns > * {
  flex-grow: 1;
}

/*  ==========================================================================
    Collection Block
    ========================================================================== */
.collection {
  position: relative;
  margin: var(--content-margin);
  padding: 40px 0;
}
@media (max-width: 49.99em) {
  .collection__top-corners, .collection__bottom-corners {
    display: none;
  }
}
@media (min-width: 50em) {
  .collection {
    padding: 80px 0;
  }
}

.collection__inner {
  display: flex;
  flex-direction: column;
  gap: 60px;
}
@media (min-width: 50em) {
  .collection__inner {
    width: 100%;
    max-width: 1440px;
    padding-left: 15px;
    padding-right: 15px;
    margin-left: auto;
    margin-right: auto;
    align-items: flex-start;
    flex-direction: row;
    gap: 40px;
    padding-left: 30px !important;
  }
}
@media (min-width: 50em) and (min-width: 50em) {
  .collection__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
@media (min-width: 80em) {
  .collection__inner {
    gap: 60px;
    padding-left: 40px !important;
  }
}

.collection__items {
  display: grid;
  padding: 0 15px;
  gap: 30px;
  width: 100%;
}
@media (min-width: 50em) {
  .collection__items {
    grid-template-columns: 1fr;
    gap: 30px 20px;
    padding: 0;
  }
}
@media (min-width: 62.5em) {
  .collection__items {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 80em) {
  .collection__items {
    gap: 60px;
  }
}

.collection__info {
  width: 100%;
  background-color: #E6D6CF;
  position: relative;
  padding: 15px;
  padding-top: 40px;
}
.collection__info .collection__top-corners,
.collection__info .collection__bottom-corners {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  pointer-events: none;
}
.collection__info .collection__top-corners:before, .collection__info .collection__top-corners:after,
.collection__info .collection__bottom-corners:before,
.collection__info .collection__bottom-corners:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 60px;
  height: 20px;
  background-color: #E6D6CF;
}
.collection__info .collection__top-corners:before,
.collection__info .collection__bottom-corners:before {
  left: -3px;
}
.collection__info .collection__top-corners:after,
.collection__info .collection__bottom-corners:after {
  right: -3px;
}
@media (min-width: 50em) {
  .collection__info .collection__top-corners:before, .collection__info .collection__top-corners:after,
  .collection__info .collection__bottom-corners:before,
  .collection__info .collection__bottom-corners:after {
    width: 60px;
    height: 28px;
  }
  .collection__info .collection__top-corners:before,
  .collection__info .collection__bottom-corners:before {
    left: -8px;
  }
  .collection__info .collection__top-corners:after,
  .collection__info .collection__bottom-corners:after {
    right: -8px;
  }
}
.collection__info .collection__top-corners:before, .collection__info .collection__top-corners:after {
  top: 0;
}
.collection__info .collection__top-corners:before {
  transform: skew(20deg);
}
.collection__info .collection__top-corners:after {
  transform: skew(-20deg);
}
@media (min-width: 50em) {
  .collection__info .collection__top-corners:before {
    transform: skew(30deg);
  }
  .collection__info .collection__top-corners:after {
    transform: skew(-30deg);
  }
}
.collection__info .collection__bottom-corners:before, .collection__info .collection__bottom-corners:after {
  bottom: 0;
}
.collection__info .collection__bottom-corners:before {
  transform: skew(-20deg);
}
.collection__info .collection__bottom-corners:after {
  transform: skew(20deg);
}
@media (min-width: 50em) {
  .collection__info .collection__bottom-corners:before {
    transform: skew(-30deg);
  }
  .collection__info .collection__bottom-corners:after {
    transform: skew(30deg);
  }
}
@media (min-width: 50em) {
  .collection__info {
    position: sticky;
    top: 30px;
    width: 50%;
    padding: 30px 40px;
  }
}
@media (min-width: 72em) {
  .collection__info {
    top: calc(var(--global-header-height) + 60px);
  }
}
@media (min-width: 80em) {
  .collection__info {
    max-width: 385px;
  }
}

.collection__title {
  line-height: 1.2;
  text-wrap: balance;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #000;
}

.collection__subtitle {
  font-size: 24px;
  font-family: gt-ultra-fine, sans-serif;
  line-height: 1.2;
}

.collection__description {
  margin-bottom: 0;
}

.collection__cta {
  margin-top: 40px;
}
@media (max-width: 31.99em) {
  .collection__cta {
    width: 100%;
  }
}

.collection__resources {
  margin-top: 30px;
}

.collection-resources__title {
  margin-bottom: 20px;
}

ul.collection-resources__list .collection-resource {
  padding-left: 0;
  padding-right: 0;
}
@media (max-width: 31.99em) {
  ul.collection-resources__list {
    flex-direction: row;
    margin-top: 0;
    margin-bottom: 10px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  ul.collection-resources__list::-webkit-scrollbar {
    display: none;
  }
  ul.collection-resources__list .collection-resource {
    flex-shrink: 0;
    padding: 0 15px 0 0;
    margin: 0 15px 0 0;
    border-width: 0 1px 0 0;
  }
  ul.collection-resources__list .collection-resource:last-child {
    border-width: 0;
    padding-right: 0;
    margin-right: 0;
  }
  ul.collection-resources__list .collection-link {
    display: flex;
    align-items: center;
    height: 50px;
  }
}

.collection-resource {
  margin-left: 0 !important;
}

/*  ==========================================================================
    Collection - Item
    ========================================================================== */
.collection-item {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.collection-item__body {
  display: flex;
  flex-direction: column;
}

.collection-item__title {
  line-height: 1.3;
  text-wrap: balance;
}

.collection-item__cta {
  text-decoration: underline;
  font-weight: 300;
  font-size: 14px;
}
@media (max-width: 29.99em) {
  .collection-item__cta {
    margin-top: auto;
  }
}
@media (min-width: 50em) {
  .collection-item__cta {
    font-size: 16px;
  }
}
@media (min-width: 62.5em) {
  .collection-item__cta {
    font-size: 18px;
  }
}

.collection-item__media {
  margin-bottom: 0;
  width: 100%;
}

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

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

.program-listing {
  padding: 40px 0;
  background-color: #E6D6CF;
}
@media (min-width: 50em) {
  .program-listing {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .program-listing {
    padding: 80px 0;
  }
}

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

.program-listing__list {
  display: grid;
  padding: 20px 0;
  gap: 30px;
}
@media (min-width: 50em) {
  .program-listing__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px 20px;
    padding: 40px 0;
  }
}
@media (min-width: 62.5em) {
  .program-listing__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 80em) {
  .program-listing__list {
    gap: 60px 25px;
  }
}

.program-listing__header {
  padding-bottom: 25px;
}

.program-listing__title {
  border-bottom: 1px solid;
  padding-bottom: 15px;
  margin-bottom: 15px;
  font-family: gt-ultra-fine, sans-serif;
  font-size: 26px;
}
@media (min-width: 50em) {
  .program-listing__title {
    font-size: 42px;
  }
}

.program-listing__description {
  font-weight: 300;
}

.program-listing__dropdown {
  border: 1px solid;
  border-radius: 3px;
  padding: 10px 15px;
  width: 430px;
  max-width: 100%;
  background: transparent;
  font-size: 16px;
  margin-top: 15px;
}

/*  ==========================================================================
    Program Grid
    ========================================================================== */
.program-grid {
  padding: 40px 0;
}
@media (min-width: 50em) {
  .program-grid {
    padding: 60px 0;
  }
}
@media (min-width: 62.5em) {
  .program-grid {
    padding: 80px 0;
  }
}

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

.program-grid__list {
  display: grid;
  padding: 20px 0;
  gap: 30px;
}
@media (min-width: 50em) {
  .program-grid__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px 20px;
    padding: 40px 0;
  }
}
@media (min-width: 62.5em) {
  .program-grid__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 80em) {
  .program-grid__list {
    gap: 60px 25px;
  }
}

.program-grid__title {
  border-bottom: 1px solid;
  padding-bottom: 15px;
  margin-bottom: 15px;
}

/*  ==========================================================================
    Featured Highlight
    ========================================================================== */
.featured-highlight {
  position: relative;
  margin: 0;
  padding: 25px 0 40px;
  background: var(--gradient-color, var(--theme-color, #000));
  color: var(--gradient-text-color, var(--theme-text-color, #fff));
}
@media (min-width: 62.5em) {
  .featured-highlight {
    padding: 60px 0;
  }
}
.featured-highlight:last-child {
  margin-bottom: 0;
}

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

/*  ==========================================================================
    Featured Highlight Item
    ========================================================================== */
.featured-highlight-item {
  display: flex;
  flex-direction: column;
  gap: 20px;
  text-align: center;
}
@media (min-width: 50em) {
  .featured-highlight-item {
    flex-direction: row;
    align-items: center;
    gap: 40px;
  }
}
@media (min-width: 80em) {
  .featured-highlight-item {
    gap: 60px;
  }
}

.featured-highlight-item__body {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (min-width: 50em) {
  .featured-highlight-item__body {
    width: 45%;
  }
}
@media (min-width: 80em) {
  .featured-highlight-item__body {
    gap: 20px;
  }
}

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

.featured-highlight-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
}

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

.featured-highlight-item__prefix {
  margin-bottom: -10px;
}

.featured-highlight-item__title {
  text-wrap: balance;
  line-height: 1.1;
  margin-bottom: 0;
}

.featured-highlight-item__description {
  margin-bottom: 0;
  text-wrap: pretty;
}
.featured-highlight-item__description p {
  margin-bottom: 0;
}

.featured-highlight-item__cta {
  padding-top: 15px;
}
@media (min-width: 50em) {
  .featured-highlight-item__cta {
    padding-top: 20px;
  }
}
@media (min-width: 80em) {
  .featured-highlight-item__cta {
    padding-top: 30px;
  }
}

@media (max-width: 31.99em) {
  .featured-highlight-item__btn {
    width: 100%;
  }
}
@media (hover: hover) and (pointer: fine) {
  .featured-highlight-item:has(.featured-highlight-item__btn:hover) .featured-highlight-item__image {
    transform: scale(1.05);
  }
}

/*  ==========================================================================
    Bio Header
    ========================================================================== */
.bio-header {
  margin: var(--content-margin-small);
}

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

.bio-header__wrapper {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (min-width: 50em) {
  .bio-header__wrapper {
    flex-direction: row;
    align-items: flex-start;
  }
  .bio-header__wrapper .bio-header__sticky {
    max-width: 300px;
    position: sticky;
    top: 20px;
  }
}
@media (min-width: 62.5em) {
  .bio-header__wrapper {
    gap: 60px;
  }
  .bio-header__wrapper .bio-header__sticky {
    max-width: 400px;
  }
}
@media (min-width: 72em) {
  .bio-header__wrapper .bio-header__sticky {
    top: calc(var(--global-header-height) + 30px);
  }
}

.bio-header__breadcrumbs {
  margin-bottom: 20px;
}
.bio-header__breadcrumbs .breadcrumbs {
  margin-top: 0;
}

.bio-header__sticky {
  width: 100%;
}

.bio-header__name {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 28px;
  margin-bottom: 0;
  line-height: 1.1;
  overflow-wrap: break-word;
}
@media (min-width: 50em) {
  .bio-header__name {
    font-size: 42px;
  }
}
@media (min-width: 62.5em) {
  .bio-header__name {
    font-size: 60px;
  }
}

.bio-header__role {
  margin-top: 15px;
  margin-bottom: 0;
  font-size: 16px;
}
@media (min-width: 50em) {
  .bio-header__role {
    font-size: 18px;
  }
}

.bio-header__position {
  border-top: 1px solid;
  padding-top: 10px;
  margin-top: 10px;
  margin-bottom: 0;
  font-weight: 300;
  font-size: 16px;
}
@media (min-width: 50em) {
  .bio-header__position {
    font-size: 18px;
  }
}

.bio-header__media {
  margin-top: 30px;
  overflow: hidden;
  width: 100%;
}

.bio-header__intrinsic-ratio {
  position: relative;
  padding-bottom: 100%;
  height: 0;
}

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

.bio-header__content {
  width: 100%;
}

/*  ==========================================================================
   Orchestra Roster
    ========================================================================== */
.orchestra-roster {
  background-color: #E6D6CF;
  padding: 60px 0;
}

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

.orchestra-roster__title {
  font-size: 20px;
  font-family: gt-ultra-fine, sans-serif;
  text-transform: capitalize;
  border-bottom: 1px solid #000;
  padding-bottom: 20px;
  margin-bottom: 30px;
}
@media (min-width: 50em) {
  .orchestra-roster__title {
    font-size: 38px;
    padding-bottom: 30px;
  }
}

.orchestra-roster__navigation {
  display: flex;
  justify-content: center;
  gap: 20px;
  height: 50px;
  font-family: gt-ultra-standard, sans-serif;
  letter-spacing: normal;
}
.orchestra-roster__navigation .btn:hover :after, .orchestra-roster__navigation :hover:where([data-component*=dialog] menu button) :after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 12px;
  background-color: #000;
  transform: translateY(8px);
}

.orchestra-roster__switch {
  color: #000;
  padding-bottom: 5px;
  font-size: 20px;
  letter-spacing: normal;
  text-decoration: none;
  text-transform: capitalize;
}
@media (min-width: 50em) {
  .orchestra-roster__switch {
    font-size: 24px;
    padding-bottom: 10px;
  }
}
.orchestra-roster__switch:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  background-color: #000;
  transform: translateY(8px);
  transition: height ease-in-out 0.25s;
}

.orchestra-roster__switch:hover {
  color: #000;
  text-decoration: none;
}
.orchestra-roster__switch:hover:after {
  height: 11px;
  background-color: #000;
}

.orchestra-roster__switch--active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 11px;
  background-color: #000;
  transform: translateY(8px);
}

.orchestra-roster__group--conductors .orchestra-roster__grid {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media (min-width: 50em) {
  .orchestra-roster__group--conductors .orchestra-roster__grid {
    flex-direction: row;
  }
}
.orchestra-roster__group--conductors .person {
  flex-direction: row;
  gap: 20px;
  margin-bottom: 40px;
  width: 100%;
}
@media (min-width: 50em) {
  .orchestra-roster__group--conductors .person {
    flex-direction: column;
    margin-bottom: 0;
    width: calc(25% - 20px);
  }
}
.orchestra-roster__group--conductors .person__media {
  width: 100%;
}
.orchestra-roster__group--conductors .person__details {
  width: 100%;
}
.orchestra-roster__group--conductors .person__role {
  margin-top: 0;
}

.orchestra-roster__instrument-name {
  margin-bottom: 0;
  padding: 20px 0;
  font-family: gt-ultra-fine, sans-serif;
  font-size: 18px;
  font-weight: 700;
}
@media (min-width: 50em) {
  .orchestra-roster__instrument-name {
    font-size: 28px;
    padding: 40px 0;
  }
}

.orchestra-roster__group {
  padding: 20px 0;
}
@media (min-width: 50em) {
  .orchestra-roster__group {
    padding: 40px 0;
  }
}

.orchestra-roster__grid {
  margin-bottom: 40px;
}
.orchestra-roster__grid .person__image {
  object-fit: cover;
}
.orchestra-roster__grid .person__position {
  font-size: 14px;
}

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

.orchestra-roster__section--instrument {
  display: none;
}

.orchestra-roster__section.active {
  display: block;
}

.orchestra-roster__section--names .person__media {
  display: none;
}
.orchestra-roster__section--names .person__details {
  width: 100%;
}

.orchestra-roster__names .orchestra-roster__grid {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 30px 20px;
  align-items: flex-start;
}
@media (min-width: 50em) {
  .orchestra-roster__names .orchestra-roster__grid {
    flex-direction: row;
  }
}
.orchestra-roster__names .person {
  margin-bottom: 20px;
  width: 100%;
}
@media (min-width: 50em) {
  .orchestra-roster__names .person {
    width: calc(25% - 20px);
  }
}

.orchestra-roster__letter-heading {
  text-transform: uppercase;
  border-bottom: 1px solid #000;
  margin-bottom: 30px;
}

.orchestra-ensemble__alphabet {
  position: sticky;
  top: 0;
  margin: 40px 0;
  padding: 15px 0;
  background-color: #E6D6CF;
}
@media (min-width: 72em) {
  .orchestra-ensemble__alphabet {
    top: var(--global-header-height);
  }
}
.orchestra-ensemble__alphabet:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 30px;
  background: linear-gradient(to right, rgba(251, 249, 245, 0) 0, #E6D6CF 75%);
  z-index: 2;
}

.orchestra-ensemble__letters {
  background-color: transparent;
  display: flex;
  overflow-x: scroll;
  scrollbar-width: none;
  text-transform: uppercase;
}

.orchestra-ensemble__letter {
  position: relative;
  background-color: #FFFAF8;
  z-index: 2;
  height: 40px;
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  font-size: 20px;
  flex-shrink: 0;
}
.orchestra-ensemble__letter:hover {
  color: #fff;
}
.orchestra-ensemble__letter:hover:after {
  height: 100%;
  background-color: #87085D;
}
.orchestra-ensemble__letter:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #000;
  transition: height ease-in-out 0.25s, background-color ease-in-out 0.25s;
  z-index: -1;
}
.orchestra-ensemble__letter.disabled {
  cursor: not-allowed;
  background-color: transparent;
  margin-right: 0;
  margin-left: -10px;
}
.orchestra-ensemble__letter.disabled:after {
  content: none;
}
.orchestra-ensemble__letter.disabled:hover {
  color: initial;
}

.program-header {
  background: linear-gradient(136deg, #000, #87085D);
  color: #fff;
}
@media (min-width: 62.5em) {
  .program-header {
    display: flex;
  }
}

.program-header__media {
  width: 100%;
  position: relative;
}
@media (min-width: 62.5em) {
  .program-header__media {
    width: 50%;
  }
}

.program-header__figure {
  margin: 0;
}

.program-header__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}
@media (max-width: 62.49em) {
  .program-header__image {
    max-height: 460px;
  }
}
@media (min-width: 62.5em) {
  .program-header__image {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
  }
}

.program-header__content {
  padding: 80px 15px 60px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  width: 100%;
}
@media (min-width: 62.5em) {
  .program-header__content {
    width: 50%;
    min-height: calc(100vh - 122px);
    padding: 100px;
  }
}

.program-header__inner {
  max-width: 700px;
  margin: 0 auto;
}
@media (min-width: 62.5em) {
  .program-header__inner {
    max-width: 900px;
  }
}

.program-header__prefix {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: 700;
  font-size: 16px;
  text-transform: uppercase;
  margin-bottom: 15px;
}

.program-header__title {
  margin-bottom: 25px;
}

.program-header__copy {
  margin-bottom: 25px;
}

.program-header__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.program-header__item {
  border-top: 1px solid rgba(255, 255, 255, 0.4);
  padding: 12px 0;
  font-size: 14px;
  font-weight: 700;
  display: flex;
  align-items: center;
}

.program-header__item .o-icon {
  margin-right: 10px;
  height: 20px;
  width: 20px;
}

html:has(.program-info) {
  scroll-behavior: smooth;
}

.program-info {
  padding: 80px 0;
}
@media (min-width: 62.5em) {
  .program-info {
    padding: 120px 0;
  }
}

.program-info__inner {
  width: 100%;
  max-width: 1440px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .program-info__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.program-info__inner {
  display: flex;
  gap: 30px;
}
@media (max-width: 62.49em) {
  .program-info__inner {
    flex-direction: column;
    max-width: 720px;
  }
}

@media (min-width: 62.5em) {
  .program-info__content {
    order: 2;
    flex: 2;
  }
}

.artist-info {
  margin-bottom: 60px;
}
.artist-info p {
  margin-bottom: 24px;
}
.artist-info ol {
  padding-left: 40px;
  margin: 20px 0;
}
.artist-info:last-child {
  margin-bottom: 0;
}

.program-details {
  list-style: none;
  padding: 0;
  margin: 32px 0;
}

.program-details li {
  border-top: 1px solid rgba(0, 0, 0, 0.4);
  padding: 12px 0;
  font-size: 14px;
  display: flex;
  align-items: center;
}

.program-details li .o-icon {
  margin-right: 12px;
  height: 18px;
  width: 18px;
}

.program-content, .program-item {
  margin-bottom: 48px;
}
.program-content:last-child, .program-item:last-child {
  margin-bottom: 0;
}

.program-content__title {
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

.program-content__subtitle {
  margin-bottom: 30px;
}

@media (min-width: 62.5em) {
  .program-info__nav {
    position: relative;
    order: 1;
    flex: 1;
  }
}

@media (min-width: 62.5em) {
  .program-info__artist-nav {
    position: relative;
    order: 3;
    flex: 1;
  }
}

.program-nav, .artist-nav {
  top: 180px;
  padding-top: 21px;
}
@media (min-width: 62.5em) {
  .program-nav, .artist-nav {
    position: sticky;
  }
}

.program-nav__title, .artist-nav__title {
  font-size: 24px;
  font-family: gt-ultra-fine, sans-serif;
  padding-bottom: 25px;
  margin-bottom: 25px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

.program-nav__list {
  list-style: none;
  padding: 0px;
  margin: 25px 0;
  border: 1px solid rgba(0, 0, 0, 0.4);
  border-radius: 5px;
  overflow: hidden;
}
.program-nav__list li {
  display: block;
}
.program-nav__list li a {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 18px;
  background-color: #fff;
  color: #000;
  text-decoration: none;
  transition: 0.3s;
}
.program-nav__list li a:hover {
  background-color: #000;
  color: #fff;
}
.program-nav__list li ~ li {
  border-top: 1px solid rgba(0, 0, 0, 0.4);
}

.program-nav__tag {
  text-transform: uppercase;
  word-break: initial;
}

.program-nav__small-title {
  text-align: right;
  font-size: 14px;
}

.artist-nav p {
  margin-bottom: 25px;
}
.artist-nav .btn, .artist-nav :where([data-component*=dialog] menu button) {
  width: 100%;
}
@media (max-width: 62.49em) {
  .artist-nav {
    margin-bottom: 48px;
  }
}

.program-item__header, .feature-artist__header {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px;
  margin-left: 32px;
  margin-bottom: 25px;
  border: 1px solid rgba(0, 0, 0, 0.4);
  border-radius: 5px;
  background-color: #fff;
}
@media (min-width: 50em) {
  .program-item__header, .feature-artist__header {
    margin-left: 40px;
    padding: 24px;
  }
}
.program-item__header .program-item__img, .program-item__header .feature-artist__img, .feature-artist__header .program-item__img, .feature-artist__header .feature-artist__img {
  margin-left: -64px;
  margin-bottom: 0;
  width: 80px;
  height: 80px;
  flex-shrink: 0;
  border-radius: 50%;
  overflow: hidden;
  background-color: #000;
}
.program-item__header .program-item__img img, .program-item__header .feature-artist__img img, .feature-artist__header .program-item__img img, .feature-artist__header .feature-artist__img img {
  object-fit: cover;
  object-position: center center;
}
.program-item__header .program-item__title, .program-item__header .feature-artist__name, .feature-artist__header .program-item__title, .feature-artist__header .feature-artist__name {
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 0;
  line-height: 1.2;
}
.program-item__header .program-item__composer, .program-item__header .feature-artist__role, .feature-artist__header .program-item__composer, .feature-artist__header .feature-artist__role {
  font-weight: 700;
  margin: 12px 0 0;
}

.program-item__composer-link {
  text-decoration: underline;
}

.program-text-link {
  color: #007bff;
}
.program-text-link:hover {
  color: #0056b3;
  text-decoration: underline;
}

.program-item__movements-list {
  margin-left: 15px;
}

.program-item__orchestration {
  margin-top: 20px;
  font-style: italic;
}
.program-item__orchestration strong {
  font-style: normal;
}

.program-item__description {
  margin-top: 20px;
}

.call-to-action .btn, .call-to-action :where([data-component*=dialog] menu button) {
  font-weight: 700;
}

.call-to-action__inner {
  width: 100%;
}
@media (min-width: 50em) {
  .call-to-action__inner {
    display: flex;
  }
}

.call-to-action__media {
  overflow: hidden;
  width: 100%;
  position: relative;
}
@media (max-width: 49.99em) {
  .call-to-action__media:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    height: 10vh;
    z-index: 2;
    max-height: 50%;
  }
}
@media (min-width: 50em) {
  .call-to-action__media {
    width: 50%;
    margin-bottom: 0;
  }
}

.call-to-action__intrinsic-ratio {
  position: relative;
  padding-bottom: 50%;
  height: 0;
  min-height: 100%;
}

.call-to-action__image {
  height: 100%;
  position: absolute;
  right: 0;
  transform: scale(1);
  transition: transform 0.4s ease;
  width: 100%;
  min-height: 100%;
  object-fit: cover;
}

.call-to-action__details {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 15px;
  padding: 60px 20px;
  margin: 0 auto;
  position: relative;
}
@media (min-width: 50em) {
  .call-to-action__details {
    padding: 60px;
    width: 50%;
  }
}
@media (min-width: 62.5em) {
  .call-to-action__details {
    margin: 0;
    gap: 25px;
    padding: 120px;
  }
}

.call-to-action__title {
  margin-bottom: 0;
}

.call-to-action__description {
  margin-bottom: 0;
}
.call-to-action__description p {
  margin-bottom: 0;
}

.call-to-action__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;
}
.call-to-action__cta .o-icon {
  width: 27px;
  height: 27px;
}
@media (min-width: 50em) {
  .call-to-action__cta .o-icon {
    width: 30px;
    height: 30px;
  }
}
@media (min-width: 50em) {
  .call-to-action__cta {
    font-size: 22px;
    color: #000;
  }
}

@media (min-width: 50em) {
  .call-to-action--right .call-to-action__inner {
    justify-content: flex-end;
  }
  .call-to-action--right .call-to-action__media {
    order: 2;
  }
  .call-to-action--right .call-to-action__details {
    order: 1;
  }
}

.call-to-action--primary {
  background: linear-gradient(136deg, #D73E23 20%, #87085d 40%, #000 80%);
}

.call-to-action--blackberry {
  background: linear-gradient(136deg, #000, #87085D);
}

.call-to-action--blueberry {
  background: linear-gradient(136deg, #02ECFF 20%, #1754DD 40%, #870D5D 80%);
}

.call-to-action--dusk {
  background: linear-gradient(136deg, #F7E94D 20%, #F2900F 40%, #D73E23 80%);
}

.call-to-action--matcha {
  background: linear-gradient(136deg, #62D5C6 60%, #F7E94D);
}

.call-to-action--blossom {
  background: linear-gradient(136deg, #62D5C6 40%, #46B2C7 60%, #FFFAF8);
}

.call-to-action--dawn {
  background: linear-gradient(136deg, #BCCFFA 40%, #FFF0FA 80%, #FFFAF8);
}

/*  ==========================================================================
    Donation Page
    ========================================================================== */
.donation-page {
  background-color: #000;
  color: #fff;
  position: relative;
}

.donation-page__inner {
  width: 100%;
  max-width: 1280px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .donation-page__inner {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.donation-page__inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 20px;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 2;
}
@media (min-width: 50em) {
  .donation-page__inner {
    padding: 40px 20px;
  }
}

@media (max-width: 49.99em) {
  .donation-page__media {
    position: relative;
    height: 0;
    padding-bottom: 55.5555555556%;
  }
}

.donation-page__image {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
}
@media (min-width: 50em) {
  .donation-page__image {
    object-fit: cover;
  }
}

/*  ==========================================================================
    Donation Page - Form
    ========================================================================== */
.donation-form {
  left: 0;
  width: 100%;
  max-width: none;
  padding: 0;
  z-index: 10;
}
@media (min-width: 50em) {
  .donation-form {
    width: 50%;
    max-width: 500px;
  }
}

@media (max-width: 49.99em) {
  .donation-form__top-corners,
  .donation-form__bottom-corners {
    display: none;
  }
}

.donation-form__inner .donation-form__top-corners,
.donation-form__inner .donation-form__bottom-corners {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  pointer-events: none;
}
.donation-form__inner .donation-form__top-corners:before, .donation-form__inner .donation-form__top-corners:after,
.donation-form__inner .donation-form__bottom-corners:before,
.donation-form__inner .donation-form__bottom-corners:after {
  content: "";
  display: inline-block;
  position: absolute;
  width: 60px;
  height: 20px;
  background-color: #fff;
}
.donation-form__inner .donation-form__top-corners:before,
.donation-form__inner .donation-form__bottom-corners:before {
  left: -3px;
}
.donation-form__inner .donation-form__top-corners:after,
.donation-form__inner .donation-form__bottom-corners:after {
  right: -3px;
}
@media (min-width: 50em) {
  .donation-form__inner .donation-form__top-corners:before, .donation-form__inner .donation-form__top-corners:after,
  .donation-form__inner .donation-form__bottom-corners:before,
  .donation-form__inner .donation-form__bottom-corners:after {
    width: 60px;
    height: 28px;
  }
  .donation-form__inner .donation-form__top-corners:before,
  .donation-form__inner .donation-form__bottom-corners:before {
    left: -8px;
  }
  .donation-form__inner .donation-form__top-corners:after,
  .donation-form__inner .donation-form__bottom-corners:after {
    right: -8px;
  }
}
.donation-form__inner .donation-form__top-corners:before, .donation-form__inner .donation-form__top-corners:after {
  top: 0;
}
.donation-form__inner .donation-form__top-corners:before {
  transform: skew(20deg);
}
.donation-form__inner .donation-form__top-corners:after {
  transform: skew(-20deg);
}
@media (min-width: 50em) {
  .donation-form__inner .donation-form__top-corners:before {
    transform: skew(30deg);
  }
  .donation-form__inner .donation-form__top-corners:after {
    transform: skew(-30deg);
  }
}
.donation-form__inner .donation-form__bottom-corners:before, .donation-form__inner .donation-form__bottom-corners:after {
  bottom: 0;
}
.donation-form__inner .donation-form__bottom-corners:before {
  transform: skew(-20deg);
}
.donation-form__inner .donation-form__bottom-corners:after {
  transform: skew(20deg);
}
@media (min-width: 50em) {
  .donation-form__inner .donation-form__bottom-corners:before {
    transform: skew(-30deg);
  }
  .donation-form__inner .donation-form__bottom-corners:after {
    transform: skew(30deg);
  }
}
.donation-form__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  background-color: #FFFAF8;
  color: #000;
  position: relative;
  padding: 30px 15px;
}
@media (min-width: 50em) {
  .donation-form__inner {
    padding: 40px 30px;
  }
}

.donation-form__details {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.donation-form__title {
  margin-bottom: 0;
  text-align: left;
}

.donation-form__description {
  line-height: 1.3;
  text-align: left;
}
.donation-form__description p:last-child {
  margin: 0;
}

.donation-form__controls {
  display: flex;
  border-radius: 50px;
}

.donation-form__control:first-of-type .donation-form__type {
  border-top-left-radius: 50rem;
  border-bottom-left-radius: 50rem;
}
.donation-form__control:last-of-type .donation-form__type {
  border-top-right-radius: 50rem;
  border-bottom-right-radius: 50rem;
}

.donation-form__type {
  position: relative;
  display: block;
  padding: 10px 30px;
  cursor: pointer;
  background-color: transparent;
  font-weight: 500;
  transition: all 0.2s ease;
  border: 1px solid #000;
}
.donation-form__type svg {
  position: absolute;
  top: 50%;
  left: 6px;
  transform: translateY(-50%);
  opacity: 0;
}

.donation-form__controls input[type=radio]:checked + .donation-form__type {
  background-color: #000;
  color: #fff;
}
.donation-form__controls input[type=radio]:checked + .donation-form__type svg {
  opacity: 1;
}

.donation-form__amounts {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 15px;
  width: auto;
}
@media (min-width: 62.5em) {
  .donation-form__amounts {
    width: 450px;
  }
}

.donation-form__amount {
  width: calc(50% - 8px);
}
@media (min-width: 32em) {
  .donation-form__amount {
    width: calc(25% - 12px);
  }
}
.donation-form__amount:first-child .donation-form__button {
  margin-left: 0;
}

.donation-form__button {
  align-items: center;
  background-color: #FFFAF8;
  border: 1px solid black;
  border-radius: 4px;
  color: #000;
  cursor: pointer;
  display: flex;
  font-size: 14px;
  font-weight: 700;
  justify-content: center;
  margin: 0;
  padding: 10px 25px;
  transform: scale(1);
  transition: all 0.3s ease-in-out;
}
.donation-form__button:focus-visible {
  outline: none;
  border: none;
}
@media (min-width: 62.5em) {
  .donation-form__button {
    font-size: 16px;
  }
}

.donation-form__amount-container {
  display: flex;
  flex-direction: column;
  gap: 15px;
  width: 100%;
}
@media (min-width: 62.5em) {
  .donation-form__amount-container {
    flex-direction: row;
  }
}

.donation-form__custom {
  width: 100%;
  height: 48px;
  border: 1px solid black;
  border-radius: 4px;
  background-color: #FFFAF8;
  cursor: none;
  color: #000;
  padding: 0 10px;
}
.donation-form__custom::placeholder {
  color: #000;
}
.donation-form__custom:hover {
  background-color: initial;
  cursor: pointer;
  color: initial;
  transform: none;
  text-decoration: none;
}

.donation-form__select {
  border: 1px solid #000;
  border-radius: 4px;
  width: 100%;
  height: 48px;
  min-width: 265px;
  padding: 10px;
  color: #000;
  appearance: base-select;
  align-items: center;
}
.donation-form__select::picker(select) {
  appearance: base-select;
  border: 1px solid #000;
  border-radius: 0 0 4px 4px;
  top: calc(anchor(bottom));
  left: anchor(0%);
  opacity: 0;
  transition: opacity ease-in 0.4s;
}
.donation-form__select::picker-icon {
  display: flex;
  align-items: end;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48IS0tIUZvbnQgQXdlc29tZSBGcmVlIDYuNy4yIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlL2ZyZWUgQ29weXJpZ2h0IDIwMjUgRm9udGljb25zLCBJbmMuLS0+PHBhdGggZD0iTTIzMy40IDQwNi42YzEyLjUgMTIuNSAzMi44IDEyLjUgNDUuMyAwbDE5Mi0xOTJjMTIuNS0xMi41IDEyLjUtMzIuOCAwLTQ1LjNzLTMyLjgtMTIuNS00NS4zIDBMMjU2IDMzOC43IDg2LjYgMTY5LjRjLTEyLjUtMTIuNS0zMi44LTEyLjUtNDUuMyAwcy0xMi41IDMyLjggMCA0NS4zbDE5MiAxOTJ6Ii8+PC9zdmc+");
  background-position: center;
  background-repeat: no-repeat;
  color: transparent;
  font-size: 20px;
  padding: 5px;
  transition: 0.4s rotate;
}
.donation-form__select option {
  padding: 5px 5px 5px 10px;
  transition: 0.4s;
}
.donation-form__select option::checkmark {
  display: none;
}
.donation-form__select option:hover {
  background-color: #E6D6CF;
  cursor: pointer;
}
.donation-form__select:hover {
  background-color: initial;
  cursor: pointer;
  color: initial;
  transform: none;
  text-decoration: none;
}
.donation-form__select:open {
  border-bottom: none;
  border-radius: 4px 4px 0 0;
}
.donation-form__select:open::picker-icon {
  rotate: 180deg;
}
.donation-form__select:open::picker(select) {
  opacity: 1;
}

.donation-amount__select-description {
  font-size: 14px;
  padding-left: 5px;
  text-align: left;
  width: 100%;
}
@media (min-width: 62.5em) {
  .donation-amount__select-description {
    padding-left: 0;
    text-align: center;
  }
}

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

.donation-form__input:checked + .donation-form__button,
.donation-form__button:hover,
.donation-form__button:focus {
  background-color: #000;
  text-decoration: none;
  color: #fff;
  transform: scale(1.1);
}
@media (min-width: 50em) {
  .donation-form__input:checked + .donation-form__button,
  .donation-form__button:hover,
  .donation-form__button:focus {
    transform: scale(1.15);
  }
}

.donation-form__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.donation-form__submit {
  border: none;
  color: #fff;
  font-weight: 700;
  width: 100%;
}

.donation-form__more {
  font-size: 16px;
  letter-spacing: 1px;
  text-decoration: underline;
}
@media (min-width: 62.5em) {
  .donation-form__more {
    font-size: 18px;
  }
}

.tippy-content {
  position: relative;
  transition: opacity 0.3s ease, transform 0.3s ease;
  opacity: 0;
  transform: translateY(0);
  background-color: rgba(0, 0, 0, 0.8);
  color: #fff;
  padding: 10px 15px;
  border-radius: 15px;
  font-size: 14px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}
.tippy-content a {
  text-decoration: underline;
}

/* Show tooltip */
.tippy-box[data-state=visible] .tippy-content {
  opacity: 1;
  transform: translateY(4px);
}

/* Bottom arrow */
.tippy-content::after {
  content: "";
  position: absolute;
  top: 95%;
  left: 50%;
  transform: translateX(-50%) translateY(-1px);
  border-width: 6px;
  border-style: solid;
  border-color: rgba(0, 0, 0, 0.8) transparent transparent transparent; /* arrow pointing down */
  transition: transform 0.3s ease, opacity 0.3s ease;
  opacity: 0;
}

/* Animate arrow along with tooltip */
.tippy-box[data-state=visible] .tippy-content::after {
  opacity: 1;
  transform: translateX(-50%) translateY(3px); /* move down along with tooltip */
}

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

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

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

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

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

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

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

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

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

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

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

/*  ==========================================================================
	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: #000;
}
.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 rgba(0, 0, 0, 0.1);
  transition: border-bottom 0.3s ease-in-out;
}

.post-item__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
  height: 100%;
  width: 100%;
}
@media (min-width: 62.5em) {
  .post-item__inner {
    gap: 25px;
  }
}

.post-item__media {
  border-radius: 4px;
  overflow: hidden;
}

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

.post-item__image {
  position: absolute;
  width: 100%;
  height: auto;
}

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

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

.post-item__post-type {
  font-family: gt-ultra-standard, 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: gt-ultra-standard, sans-serif;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 20px;
}
@media (min-width: 50em) {
  .post-item__title {
    font-size: 22px;
  }
}
@media (min-width: 62.5em) {
  .post-item__title {
    font-size: 24px;
  }
}
@media (min-width: 72em) {
  .post-item__title {
    font-size: 28px;
  }
}

.post-item__details,
.post-item__cta {
  font-size: 16px;
}

.post-item__cta {
  text-decoration: underline;
}

/*  ==========================================================================
    Works List - People/Bio Page
    ========================================================================== */
.works-list {
  position: relative;
  margin: var(--content-margin-small);
}

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

/*  ==========================================================================
    Works Page
    ========================================================================== */
.works {
  position: relative;
  margin: var(--content-margin-small);
}
@media (min-width: 50em) {
  .works {
    margin: var(--content-margin);
  }
}

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

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

.works-info {
  list-style: none;
  padding: 0;
  margin: 32px 0;
}

.works-info li {
  border-top: 1px solid rgba(0, 0, 0, 0.4);
  padding: 12px 0;
  font-size: 14px;
  display: flex;
  align-items: center;
}

.works-info li .o-icon {
  margin-right: 12px;
  height: 18px;
  width: 18px;
}

.works-info__composer {
  font-size: 16px;
}
@media (min-width: 50em) {
  .works-info__composer {
    font-size: 20px;
  }
}

.works-info__composer-link {
  text-decoration: underline;
}

.works-info__movements-list {
  margin-left: 15px;
}

.works-info__orchestration {
  margin-top: 20px;
  font-style: italic;
}
.works-info__orchestration strong {
  font-style: normal;
}

.works-info__description {
  margin-top: 20px;
}

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

.calendar-list {
  position: relative;
}
.calendar-list__group {
  margin-bottom: 40px;
}
.calendar-list__group--year:first-child .calendar-list__year, .calendar-list__group--year:first-child div:first-of-type .calendar-list__month {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.calendar-list__year {
  display: inline-block;
  position: relative;
  line-height: 1.2;
  background: linear-gradient(180deg, var(--theme-color) 0, var(--theme-color));
  background-position: 0 100%;
  background-size: 100% 50%;
  background-repeat: no-repeat;
  text-decoration: none;
  padding: 0 5px 5px;
  font-weight: 700;
  font-size: var(--global-header-size-2);
  font-family: museo-sans, sans-serif;
  margin: 0 auto 5px;
}
.calendar-list__month {
  font-weight: 700;
  margin-bottom: 15px;
}
@media (min-width: 62.5em) {
  .calendar-list__groups {
    padding-top: 30px;
  }
  .calendar-list__group {
    margin-bottom: 60px;
  }
}

/*  ==========================================================================
	Calendar List - Performance
	========================================================================== */
.calendar-performance {
  display: flex;
  background-color: #fff;
  margin-bottom: 2px;
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow 0.3s ease, transform 0.3s ease, background-color 0.5s ease;
}
.calendar-performance--focused {
  background-color: #aaa;
  transform: scale(1.1);
  transition: background-color 0s, transform 0s;
}
@media (min-width: 50em) {
  .calendar-performance {
    border-radius: 8px;
    margin-bottom: 10px;
  }
  .calendar-performance:hover, .calendar-performance:focus {
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
    transform: scale(1.01);
    z-index: 2;
  }
}
@media (min-width: 62.5em) {
  .calendar-performance {
    border-radius: 15px;
  }
}

.calendar-performance__date-holder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-color: #757575;
  color: #fff;
  width: 50px;
  flex-shrink: 0;
  padding: 10px 0;
}
@media (min-width: 50em) {
  .calendar-performance__date-holder {
    width: 70px;
  }
}
@media (min-width: 62.5em) {
  .calendar-performance__date-holder {
    width: 100px;
  }
}

.calendar-performance__day,
.calendar-performance__month {
  display: block;
  text-transform: uppercase;
  font-size: var(--global-body-size-2);
}
@media (min-width: 62.5em) {
  .calendar-performance__day,
  .calendar-performance__month {
    font-size: var(--global-body-size-4);
  }
}

.calendar-performance__date {
  display: block;
  font-weight: bold;
  line-height: 1;
  font-size: var(--global-header-size-5);
}
@media (min-width: 62.5em) {
  .calendar-performance__date {
    font-size: var(--global-header-size-8);
  }
}

.calendar-performance__details {
  padding: 20px 15px;
  align-self: center;
  margin-right: auto;
  flex-grow: 1;
}
@media (min-width: 62.5em) {
  .calendar-performance__details {
    padding: 15px 30px;
  }
}

.calendar-performance__title {
  font-family: gt-ultra-fine, sans-serif;
  font-weight: bold;
  margin-bottom: 0;
  line-height: 1.2;
}

.calendar-performance__prefix,
.calendar-performance__suffix {
  display: block;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: var(--global-body-size-1);
}
@media (min-width: 50em) {
  .calendar-performance__prefix,
  .calendar-performance__suffix {
    font-size: var(--global-body-size-2);
  }
}

.calendar-performance__prefix {
  margin-bottom: 2px;
}

.calendar-performance__suffix {
  margin-top: 2px;
  margin-bottom: 10px;
}

.calendar-performance__meta {
  display: block;
  font-size: var(--global-body-size-2);
}
@media (min-width: 62.5em) {
  .calendar-performance__meta {
    margin-top: 10px;
  }
}
@media (min-width: 72em) {
  .calendar-performance__meta {
    font-size: var(--global-body-size-4);
  }
}

.calendar-performance__time {
  font-weight: bold;
}

.calendar-performance__tags {
  display: flex;
  flex-wrap: wrap;
  margin-top: 10px;
}
@media (min-width: 32em) {
  .calendar-performance__tags {
    margin-top: 15px;
  }
}

.calendar-performance__tag {
  border: 1px solid rgba(0, 0, 0, 0.25);
  font-weight: bold;
  padding: 3px 8px;
  font-size: var(--global-body-size-1);
}
@media (min-width: 62.5em) {
  .calendar-performance__tag {
    font-size: var(--global-body-size-2);
  }
}

.calendar-performance__media {
  display: none;
  flex-shrink: 0;
}
@media (min-width: 32em) {
  .calendar-performance__media {
    display: block;
    width: 150px;
  }
}
@media (min-width: 72em) {
  .calendar-performance__media {
    width: 200px;
  }
}

.calendar-performance__intrinsic-ratio {
  position: relative;
  padding-bottom: 83.3333333333%;
  height: 0;
  overflow: hidden;
}

.calendar-performance__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ==========================================================================
   Calendar Popup
   ========================================================================== */
.calendar-popup {
  width: 100%;
  max-width: 1120px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .calendar-popup {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.calendar-popup {
  margin: auto;
  padding: 0;
  width: 100%;
  background-color: transparent;
}
@media (max-width: 49.99em) {
  .calendar-popup {
    height: 100%;
    max-width: 100%;
    max-height: 100%;
  }
}

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

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

.calendar-popup-item {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 15px;
}
@media (min-width: 50em) {
  .calendar-popup-item {
    flex-direction: row;
  }
  .calendar-popup-item > * {
    width: 50%;
  }
}
@media (min-width: 62.5em) {
  .calendar-popup-item {
    padding: 40px;
    gap: 40px;
  }
}

.calendar-popup-item__body {
  display: flex;
  flex-direction: column;
}

.calendar-popup-item__title {
  font-weight: 800;
  text-transform: uppercase;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__title {
    font-size: 42px;
  }
}

.calendar-popup-item__prefix,
.calendar-popup-item__suffix {
  font-family: gt-ultra-standard, sans-serif;
  font-weight: 800;
  font-size: 18px;
  text-transform: uppercase;
}
@media (min-width: 50em) {
  .calendar-popup-item__prefix,
  .calendar-popup-item__suffix {
    font-size: 20px;
  }
}
@media (min-width: 62.5em) {
  .calendar-popup-item__prefix,
  .calendar-popup-item__suffix {
    font-size: 22px;
  }
}

.calendar-popup-item__prefix {
  margin-bottom: -5px;
}

.calendar-popup-item__suffix {
  margin-top: -3px;
}

.calendar-popup-item__date {
  margin-top: 5px;
  margin-bottom: 0;
  font-size: 16px;
}
@media (min-width: 50em) {
  .calendar-popup-item__date {
    font-size: 18px;
  }
}

.calendar-popup-item__venue {
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__venue {
    font-size: 18px;
  }
}

.calendar-popup-item__footer {
  border-top: 1px solid;
  padding-top: 20px;
  margin-top: 20px;
}
.calendar-popup-item__footer .calendar-info {
  flex-wrap: wrap;
}
@media (min-width: 50em) {
  .calendar-popup-item__footer {
    order: 1;
    margin-bottom: 30px;
  }
}

.calendar-popup-item__description {
  margin-top: 20px;
  padding-bottom: 60px;
  font-size: 16px;
}
.calendar-popup-item__description p:last-child {
  margin-bottom: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__description {
    font-size: 18px;
    padding-bottom: 0;
    max-height: 250px;
    overflow-y: auto;
  }
}

.calendar-popup-item__media {
  margin-bottom: 0;
  position: relative;
}

.calendar-popup-item__intrinsic-ratio {
  position: relative;
  padding-bottom: 66.6666666667%;
  height: 0;
}
@media (min-width: 50em) {
  .calendar-popup-item__intrinsic-ratio {
    padding-bottom: 70%;
  }
}

.calendar-popup-item__image {
  width: 100%;
  height: auto;
  position: absolute;
  right: 0;
  z-index: 2;
}

.calendar-popup-item__actions {
  display: flex;
  justify-content: end;
  gap: 15px;
  position: sticky;
  bottom: 0;
  width: 100%;
  order: 2;
  margin: -15px 0;
  padding: 15px;
  padding-right: 0;
  background-color: #fff;
}
@media (max-width: 49.99em) {
  .calendar-popup-item__actions {
    position: fixed;
    right: 0;
    margin: 0;
    padding: 15px;
  }
  .calendar-popup-item__actions > .btn, .calendar-popup-item__actions > :where([data-component*=dialog] menu button) {
    flex-basis: 100%;
    padding-left: 0;
    padding-right: 0;
  }
}

.calendar-scroller__list {
  display: flex;
}

.calendar-event {
  min-width: 350px;
  padding: 20px 15px;
}

.favorite-button {
  position: absolute;
  top: 10px;
  right: 10px;
  border: none;
  background: none;
  z-index: 2;
  padding: 13px;
  background: #757575;
  border-radius: 50%;
  cursor: pointer;
}
.favorite-button .o-icon {
  width: 18px;
  height: 18px;
  fill: transparent;
}

.favorite-button:hover {
  background: #757575;
  border-color: transparent;
}
.favorite-button:hover .o-icon {
  fill: #D73E23;
}

.favorite-button__icon--filled .o-icon {
  fill: #D73E23;
}

/* ==========================================================================
   Utilities
   ========================================================================== */
/* ==========================================================================
   Utilities: Visibility
   ========================================================================== */
/**
 * JS helpers
 */
.no-js .u-visible-js, .supports-js .u-hidden-js {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

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

/**
 * Hide from browsers, but not screenreaders
 */
.visually-hidden, .u-visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

/**
 * Hide from both screenreaders and browsers: h5bp.com/u
 */
[hidden], .u-hidden {
  display: none !important;
  visibility: hidden;
}

/**
 * Hide visually and from screenreaders, but maintain layout
 */
.u-invisible {
  visibility: hidden;
}

/**
 * Image Replacement
 */
.u-ir {
  display: block;
  text-indent: -999999px;
  overflow: hidden;
}

/*  ==========================================================================
	Dialog
	========================================================================== */
[data-component*=dialog] * {
  box-sizing: border-box;
  outline-color: var(--theme-color);
}

:where([data-component*=dialog]) {
  width: 100%;
  max-width: 650px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  :where([data-component*=dialog]) {
    padding-left: 15px;
    padding-right: 15px;
  }
}
:where([data-component*=dialog]) {
  padding: 20px;
  border: none;
  border-radius: 15px;
}
@media (min-width: 50em) {
  :where([data-component*=dialog]) {
    padding: 30px;
  }
}
:where([data-component*=dialog])::backdrop {
  background-color: rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(30px) brightness(50%) contrast(120%);
}

:where([data-component=no-dialog]:not([hidden])) {
  display: block;
  inset-block-start: 30px;
  inset-inline-start: 50%;
  position: fixed;
  z-index: 999;
  transform: translateX(-50%);
  box-shadow: 0 0 1000px 1000px rgba(0, 0, 0, 0.5);
}

:where([data-component*=dialog] menu) {
  display: flex !important;
  gap: 15px;
  justify-content: flex-end;
  margin: 0;
  padding: 0;
}

:where([data-component*=dialog] [data-ref=fieldset]) {
  border: none;
  margin: unset !important;
  padding: unset !important;
}

:where([data-component*=dialog] [data-ref=message]) {
  font-size: var(--global-body-text-big);
  line-height: 1.5;
  margin-block-end: 20px;
}

:where([data-component*=dialog] [data-ref=template]:not(:empty)) {
  margin-block-end: 20px;
  width: 100%;
}

/* hack for Firefox */
@-moz-document url-prefix() {
  [data-component=no-dialog]:not([hidden]) {
    inset-inline-start: 0;
    transform: none;
  }
}
/* added to `body` when browser do not support `<dialog>` */
.dialog-open {
  background-color: rgba(0, 0, 0, 0.2);
  overflow: hidden;
}

/* ==========================================================================
   Utilities: Layout
   ========================================================================== */
.u-constrained {
  width: 100%;
  max-width: 1640px;
  padding-left: 15px;
  padding-right: 15px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 50em) {
  .u-constrained {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.u-fullwidth {
  display: block;
  width: 100%;
}

.u-inset {
  padding-top: 16px;
  padding-bottom: 16px;
}

.u-padded {
  padding: 16px;
}

.u-ratio {
  position: relative;
  height: 0;
  /*  Maintain layout, based on 4:3 aspect-ratio */
  padding-bottom: 75%;
}

.u-ratio--5-3 {
  /*  Maintain layout, based on 5:3 aspect-ratio */
  padding-bottom: 60%;
}

.u-ratio--16-9 {
  /*  Maintain layout, based on 5:3 aspect-ratio */
  padding-bottom: 56.25%;
}

.u-ratio--square {
  /*  Maintain layout, based on square aspect-ratio */
  padding-bottom: 100%;
}

.u-button-reset {
  padding: 0;
  border: 0;
  outline: none;
  background: transparent;
}

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

.u-tone-bg-tint {
  color: contrasting(#D0D0D0, , #000);
  background-color: #D0D0D0;
  border-color: currentColor;
}

.u-tone-bg-primary {
  color: contrasting(#E6D6CF, , #000);
  background-color: #E6D6CF;
  border-color: currentColor;
  color: #fff;
}

.u-tone-bg-dark {
  color: contrasting(#757575, , #000);
  background-color: #757575;
  border-color: currentColor;
  color: #fff;
}

/* ==========================================================================
   Utilities: Text
   ========================================================================== */
.u-font-scale-display-1 {
  font-size: 16px;
}

.u-font-scale-display-2 {
  font-size: 18px;
}

.u-font-scale-display-3 {
  font-size: 20px;
}

.u-font-scale-display-4 {
  font-size: 22px;
}

.u-font-scale-display-5 {
  font-size: 24px;
}

.u-font-scale-display-6 {
  font-size: 26px;
}

.u-font-scale-display-7 {
  font-size: 28px;
}

.u-font-scale-display-8 {
  font-size: 32px;
}

.u-font-scale-display-9 {
  font-size: 38px;
}

.u-font-scale-display-10 {
  font-size: 42px;
}

.u-font-scale-display-11 {
  font-size: 48px;
}

.u-font-scale-display-12 {
  font-size: 56px;
}

.u-font-scale-display-13 {
  font-size: 60px;
}

.u-font-scale-display-14 {
  font-size: 72px;
}

.u-font-scale-display-15 {
  font-size: 90px;
}

.u-font-scale-display-16 {
  font-size: 96px;
}

.u-font-scale-body-1 {
  font-size: 8px;
}

.u-font-scale-body-2 {
  font-size: 10px;
}

.u-font-scale-body-3 {
  font-size: 12px;
}

.u-font-scale-body-4 {
  font-size: 14px;
}

.u-font-scale-body-5 {
  font-size: 16px;
}

.u-font-scale-body-6 {
  font-size: 18px;
}

.u-font-scale-body-7 {
  font-size: 20px;
}

.u-font-scale-body-8 {
  font-size: 22px;
}

.u-font-scale-body-9 {
  font-size: 24px;
}

.u-font-scale-body-10 {
  font-size: 26px;
}

.u-font-scale-body-11 {
  font-size: 28px;
}

.u-font-scale-body-12 {
  font-size: 32px;
}

.u-font-scale-caption-1 {
  font-size: 11px;
}

.u-font-scale-caption-2 {
  font-size: 12px;
}

.u-font-scale-caption-3 {
  font-size: 14px;
}

.u-font-scale-caption-4 {
  font-size: 16px;
}

.u-font-scale-monospace-1 {
  font-size: 14px;
}

.u-font-scale-monospace-2 {
  font-size: 16px;
}

.u-block-link {
  display: block;
  height: 100%;
}

.u-list-unstyled {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* ==========================================================================
   Print (inlined for performance)
   ========================================================================== */
/* ==========================================================================
   Print
   ========================================================================== */
@media print {
  * {
    background: transparent !important;
    color: #000 !important; /* Black prints faster: h5bp.com/s */
    box-shadow: none !important;
    text-shadow: none !important;
  }
  a, a:visited {
    text-decoration: underline;
  }
  a[href]:after {
    content: " (" attr(href) ")";
  }
  abbr[title]:after {
    content: " (" attr(title) ")";
  }
  /*
   * Don't show links for images, or javascript/internal links
   */
  a[href^="javascript:"]:after, a[href^="#"]:after {
    content: "";
  }
  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }
  thead {
    display: table-header-group; /* h5bp.com/t */
  }
  tr, img {
    page-break-inside: avoid;
  }
  img {
    max-width: 100% !important;
  }
  p, h2, h3 {
    orphans: 3;
    widows: 3;
  }
  h2, h3 {
    page-break-after: avoid;
  }
}
/* ------------------------------------*\
    #ANNOTATIONS
\*------------------------------------ */
/**
 * Annotated elements styles
 * 1) Annotation styles that appear inside the iframe
 * 2) For elements in the DOM that have an annotation, we want to
 * provide styles that help the user understand that annotations are available.
 * We do this with some cursor helpers and a
 */
.pl-has-annotation {
  cursor: help !important;
  outline: 1px dotted #808080;
  outline-offset: -4px;
  transition: box-shadow 0.2s ease;
}
.pl-has-annotation a,
.pl-has-annotation input {
  cursor: help !important;
}
.pl-has-annotation:hover {
  box-shadow: 0 0 3px #808080;
}
.pl-has-annotation.active {
  box-shadow: inset 0 0 6px #4d4d4d;
  outline: 1px dotted #808080;
  outline-offset: -1px;
}

/*# sourceMappingURL=style.css.map */
