/*
 Theme Name: Exhibition
 Theme URI: http://gala-engine.com
 Description: Theme for festivals
 Version: 1.0
 Author: Gala
 Author URI: http://gala-engine.com
 */
/*--------------------------------------------------------------
 # Base
 --------------------------------------------------------------*/
html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%; }

body {
  margin: 0; }

article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, summary {
  display: block; }

audio, canvas, progress, video {
  display: inline-block;
  vertical-align: baseline; }

audio:not([controls]) {
  display: none;
  height: 0; }

[hidden], template {
  display: none; }

a {
  background-color: transparent; }

a:active, a:hover {
  outline: 0; }

abbr[title] {
  border-bottom: 1px dotted; }

b, strong {
  font-weight: bold; }

dfn {
  font-style: italic; }

h1 {
  font-size: 2em;
  margin: 0.67em 0; }

mark {
  background: #ff0;
  color: #000; }

small {
  font-size: 80%; }

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

img {
  border: 0; }

svg:not(:root) {
  overflow: hidden; }

figure {
  margin: 1em 40px; }

hr {
  box-sizing: content-box;
  height: 0; }

pre {
  overflow: auto; }

code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em; }

button, input, optgroup, select, textarea {
  font: inherit;
  margin: 0; }

button {
  overflow: visible; }

button, select {
  text-transform: none; }

button, html input[type="button"], input[type="reset"], input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer; }

button[disabled], html input[disabled] {
  cursor: default; }

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0; }

input {
  line-height: normal; }

input[type="checkbox"], input[type="radio"] {
  box-sizing: border-box;
  padding: 0; }

input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button {
  height: auto; }

input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

legend {
  border: 0;
  padding: 0; }

textarea {
  overflow: auto; }

optgroup {
  font-weight: bold; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

td, th {
  padding: 0; }

html, body {
  background-color: #fff; }

html {
  box-sizing: border-box; }

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

hr {
  background-color: #ccc;
  border: 0;
  height: 1px;
  margin-bottom: 1.5em; }

ul, ol {
  margin: 0 0 1.5em 3em; }

ul {
  list-style: disc; }

ol {
  list-style: decimal; }

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

dt {
  font-weight: bold; }

dd {
  margin: 0 1.5em 1.5em; }

img {
  height: auto;
  /* Make sure images are scaled correctly. */
  max-width: 100%;
  /* Adhere to container width. */ }

embed, iframe, object {
  max-width: 100%; }

figure {
  margin: 1em 0;
  /* Extra wide images within figure tags don't overflow the content area. */ }

table {
  margin: 0 0 1.5em;
  width: 100%; }

.alignleft {
  display: inline;
  float: left;
  margin-right: 1.5em; }

.alignright {
  display: inline;
  float: right;
  margin-left: 1.5em; }

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto; }

svg {
  max-width: 100%; }

body {
  color: #3c3d41;
  font-family: Montserrat;
  line-height: 1.5; }

h1, h2, h3, h4, h5, h6 {
  font-family: Montserrat;
  clear: both;
  font-weight: bold; }

h1 {
  font-size: 36px; }

h2 {
  font-size: 28px; }

h3 {
  font-size: 24px; }

h4 {
  font-size: 20px; }

h5 {
  font-size: 18px; }

h6 {
  font-size: 14px;
  text-transform: uppercase; }

p, ul {
  margin-bottom: 1.5em;
  font-size: 16px; }

button, input, select, optgroup, textarea {
  color: #656b6f; }

@media (max-width: 767px) {
  h1 {
    font-size: 40px; }

  h2 {
    font-size: 32px; }

  h3 {
    font-size: 24px; }

  h4 {
    font-size: 18px; }

  h5 {
    font-size: 14px; }

  h6 {
    font-size: 12px; } }

dfn, cite, em, i {
  font-style: italic; }

blockquote {
  margin: 0 1.5em; }

address {
  margin: 0 0 1.5em; }

pre {
  background: #eee;
  font-family: "Courier 10 Pitch", Courier, monospace;
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 1.6;
  margin-bottom: 1.6em;
  max-width: 100%;
  overflow: auto;
  padding: 1.6em; }

code, kbd, tt, var {
  font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
  font-size: 15px;
  font-size: 0.9375rem; }

abbr, acronym {
  border-bottom: 1px dotted #666;
  cursor: help; }

mark, ins {
  background: #fff9c0;
  text-decoration: none; }

big {
  font-size: 125%; }

a {
  color: #39b54a;
  outline: 0; }
  a:visited {
    color: #39b54a; }
  a:hover, a:focus, a:active {
    color: #39b54a;
    text-decoration: none; }

h1 > a:not(.ab-item):not(.btn):not(.button), h2 > a:not(.ab-item):not(.btn):not(.button), h3 > a:not(.ab-item):not(.btn):not(.button), h4 > a:not(.ab-item):not(.btn):not(.button), h5 > a:not(.ab-item):not(.btn):not(.button), h6 > a:not(.ab-item):not(.btn):not(.button), p > a:not(.ab-item):not(.btn):not(.button), li > a:not(.ab-item):not(.btn):not(.button) {
  background: transparent 0 100%/100% 2px no-repeat;
  transition: background 0.3s ease-in-out; }
  h1 > a:not(.ab-item):not(.btn):not(.button):hover, h2 > a:not(.ab-item):not(.btn):not(.button):hover, h3 > a:not(.ab-item):not(.btn):not(.button):hover, h4 > a:not(.ab-item):not(.btn):not(.button):hover, h5 > a:not(.ab-item):not(.btn):not(.button):hover, h6 > a:not(.ab-item):not(.btn):not(.button):hover, p > a:not(.ab-item):not(.btn):not(.button):hover, li > a:not(.ab-item):not(.btn):not(.button):hover, h1 > a:not(.ab-item):not(.btn):not(.button):focus, h2 > a:not(.ab-item):not(.btn):not(.button):focus, h3 > a:not(.ab-item):not(.btn):not(.button):focus, h4 > a:not(.ab-item):not(.btn):not(.button):focus, h5 > a:not(.ab-item):not(.btn):not(.button):focus, h6 > a:not(.ab-item):not(.btn):not(.button):focus, p > a:not(.ab-item):not(.btn):not(.button):focus, li > a:not(.ab-item):not(.btn):not(.button):focus, h1 > a:not(.ab-item):not(.btn):not(.button):active, h2 > a:not(.ab-item):not(.btn):not(.button):active, h3 > a:not(.ab-item):not(.btn):not(.button):active, h4 > a:not(.ab-item):not(.btn):not(.button):active, h5 > a:not(.ab-item):not(.btn):not(.button):active, h6 > a:not(.ab-item):not(.btn):not(.button):active, p > a:not(.ab-item):not(.btn):not(.button):active, li > a:not(.ab-item):not(.btn):not(.button):active, h1 > a:not(.ab-item):not(.btn):not(.button):focus-visible, h2 > a:not(.ab-item):not(.btn):not(.button):focus-visible, h3 > a:not(.ab-item):not(.btn):not(.button):focus-visible, h4 > a:not(.ab-item):not(.btn):not(.button):focus-visible, h5 > a:not(.ab-item):not(.btn):not(.button):focus-visible, h6 > a:not(.ab-item):not(.btn):not(.button):focus-visible, p > a:not(.ab-item):not(.btn):not(.button):focus-visible, li > a:not(.ab-item):not(.btn):not(.button):focus-visible, h1 > a:not(.ab-item):not(.btn):not(.button).focus-visible, h2 > a:not(.ab-item):not(.btn):not(.button).focus-visible, h3 > a:not(.ab-item):not(.btn):not(.button).focus-visible, h4 > a:not(.ab-item):not(.btn):not(.button).focus-visible, h5 > a:not(.ab-item):not(.btn):not(.button).focus-visible, h6 > a:not(.ab-item):not(.btn):not(.button).focus-visible, p > a:not(.ab-item):not(.btn):not(.button).focus-visible, li > a:not(.ab-item):not(.btn):not(.button).focus-visible {
    background: linear-gradient(#39b54a, #39b54a) 0 100%/100% 2px no-repeat;
    border-radius: initial;
    box-shadow: initial;
    opacity: initial;
    outline: initial; }

h5.tax-title {
  text-transform: uppercase;
  letter-spacing: 0.1em; }

h1.page__title, h1.entry__title {
  font-size: 28px;
  margin-bottom: 0.5rem;
  margin-top: 0;
  text-align: center; }
  @media (max-width: 767px) {
  h1.page__title, h1.entry__title {
    font-size: 32px; } }

input[type="text"], input[type="email"], input[type="url"], input[type="password"], input[type="search"], input[type="number"], input[type="tel"], input[type="range"], input[type="date"], input[type="month"], input[type="week"], input[type="time"], input[type="datetime"], input[type="datetime-local"], input[type="color"], textarea {
  color: #000;
  border: none;
  border-radius: 0;
  padding: 10px 15px;
  height: 45px;
  outline: 0;
  font-size: 14px; }
  input[type="text"]:focus, input[type="email"]:focus, input[type="url"]:focus, input[type="password"]:focus, input[type="search"]:focus, input[type="number"]:focus, input[type="tel"]:focus, input[type="range"]:focus, input[type="date"]:focus, input[type="month"]:focus, input[type="week"]:focus, input[type="time"]:focus, input[type="datetime"]:focus, input[type="datetime-local"]:focus, input[type="color"]:focus, textarea:focus {
    color: #3c3d41; }

.dropdown-toggle:after {
  content: "";
  width: 8px;
  height: 8px;
  border: solid #fff;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
  position: relative;
  top: 1px;
  right: -4px; }

.select-style {
  width: 100%;
  border-radius: 0;
  overflow: hidden;
  background: #fff;
  height: 45px;
  position: relative;
  border: 1px solid; }
  .select-style:before {
    content: "";
    position: absolute;
    right: 20px;
    top: 16px;
    width: 8px;
    height: 8px;
    border: solid #000;
    border-width: 0 3px 3px 0;
    transform: rotate(45deg); }
  .select-style select {
    padding: 10px 15px;
    font-size: 14px;
    height: 45px;
    width: 100%;
    border: none;
    box-shadow: none;
    background: transparent;
    background-image: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    color: #000;
    position: relative; }
  .select-style select:focus {
    outline: none; }
  .select-style.select-style-sm {
    height: 35px; }
  .select-style.select-style-sm:before {
    right: 10px;
    top: 12px;
    border-width: 0 2px 2px 0;
    width: 7px;
    height: 7px; }
  .select-style.select-style-sm select {
    padding: 5px 25px 5px 15px;
    height: 35px; }

textarea {
  width: 100%; }

button, input[type="button"], input[type="reset"], input[type="submit"] {
  border: none;
  border-radius: 0;
  display: inline-block;
  font-size: 12px;
  font-weight: bold;
  text-transform: uppercase;
  padding: 0 2.5em;
  height: 45px;
  line-height: 38px;
  background: #39b54a;
  color: #fff;
  transition: all 0.3s ease-in-out;
  text-decoration: none;
  outline: 0; }
  button.outline, input[type="button"].outline, input[type="reset"].outline, input[type="submit"].outline {
    background: none;
    border: 2px solid #3c3d41; }
  button:hover, input[type="button"]:hover, input[type="reset"]:hover, input[type="submit"]:hover, button:active, input[type="button"]:active, input[type="reset"]:active, input[type="submit"]:active, button:focus, input[type="button"]:focus, input[type="reset"]:focus, input[type="submit"]:focus {
    outline: 0;
    background: rgba(57, 181, 74, 0.7); }

.custom-checkbox {
  display: block;
  position: relative;
  padding-left: 35px;
  cursor: pointer;
  user-select: none;
  font-size: 14px;
  font-weight: 500; }
  .custom-checkbox label {
    margin: 0; }
  .custom-checkbox input {
    position: absolute;
    opacity: 0 !important;
    cursor: pointer;
    left: 0; }
  .custom-checkbox .checkbox {
    position: absolute;
    top: 3px;
    left: 0;
    height: 25px;
    width: 25px;
    background: #fff;
    border: 1px solid; }
  .custom-checkbox .checkbox:after {
    content: "";
    position: absolute;
    display: none;
    left: 8px;
    top: 2px;
    width: 8px;
    height: 15px;
    border: solid #000;
    border-width: 0 3px 3px 0;
    transform: rotate(45deg); }
  .custom-checkbox input:checked ~ .checkbox:after {
    display: block; }

.stripe-checkout-button-container {
  display: flex; }
  .stripe-checkout-button-container .select-style {
    max-width: 85px;
    margin-right: 10px; }

a {
  text-decoration: underline; }
/*
 This will hide the focus indicator if the element receives focus via the mouse,
 but it will still show up on keyboard focus.
 */
.js-focus-visible *:focus:not(.focus-visible) {
  outline: none !important; }
/*
 Keyboard focus indicator.
 */
*:not(html).js-focus-visible, a:focus-visible, a.focus-visible, button:focus-visible, button.focus-visible, [role="link"]:focus-visible, [role="link"].focus-visible, [role="button"]:focus-visible, [role="button"].focus-visible, [role="checkbox"]:focus-visible, [role="checkbox"].focus-visible {
  border-radius: 3px;
  box-shadow: inset 0 0 0 1px #000;
  opacity: 1;
  outline: 1px solid #fff; }

input:focus, input:focus-visible, input.focus-visible {
  border-radius: 3px;
  box-shadow: inset 0 0 0 1px #000;
  opacity: 1;
  outline: 1px solid #fff; }

select:focus, select:focus-visible, select.focus-visible {
  font-weight: bold;
  box-shadow: initial;
  opacity: 1;
  text-decoration: underline; }
/* Text meant only for screen readers. */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */ }
  .screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    clip-path: none;
    color: #3c3d41;
    display: block;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
    /* Above WP toolbar. */ }
/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
  outline: 0; }

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

#page {
  padding-top: 120px; }

.page-content {
  padding: 50px 0; }
/* =WordPress Core
 -------------------------------------------------------------- */
.alignnone {
  margin: 5px 20px 20px 0; }

.aligncenter, div.aligncenter {
  display: block;
  margin: 5px auto 5px auto; }

.alignright {
  float: right;
  margin: 5px 0 20px 20px; }

.alignleft {
  float: left;
  margin: 5px 20px 20px 0; }

a img.alignright {
  float: right;
  margin: 5px 0 20px 20px; }

a img.alignnone {
  margin: 5px 20px 20px 0; }

a img.alignleft {
  float: left;
  margin: 5px 20px 20px 0; }

a img.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto; }

.wp-caption {
  background: #fff;
  border: 1px solid #f0f0f0;
  max-width: 96%;
  /* Image does not overflow the content area */
  padding: 5px 3px 10px;
  text-align: center; }

.wp-caption.alignnone {
  margin: 5px 20px 20px 0; }

.wp-caption.alignleft {
  margin: 5px 20px 20px 0; }

.wp-caption.alignright {
  margin: 5px 0 20px 20px; }

.wp-caption img {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 98.5%;
  padding: 0;
  width: auto; }

.wp-caption p.wp-caption-text {
  font-size: 11px;
  line-height: 17px;
  margin: 0;
  padding: 0 4px 5px; }
/* Text meant only for screen readers. */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */ }

.screen-reader-text:focus {
  background-color: #eee;
  clip: auto !important;
  clip-path: none;
  color: #444;
  display: block;
  font-size: 1em;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar. */ }

.gallery:after {
  content: "";
  display: table;
  clear: both; }

img.aligncenter, div.aligncenter, figure.aligncenter, img.wp-post-image {
  display: block;
  margin: 1em auto; }

img.alignright, div.alignright, figure.alignright {
  float: right;
  margin: 1em 0 1em 2em; }

img.alignleft, div.alignleft, figure.alignleft, img.wp-post-image.attachment-thumb {
  float: left;
  margin: 1em 1em 2em 0; }

figure {
  max-width: 100%;
  height: auto;
  margin: 1em 0; }

p img.alignright, p img.alignleft {
  margin-top: 0; }

.gallery figure img {
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  display: block; }

.gallery figure {
  float: left;
  margin: 0 2% 1em 0; }

.gallery.gallery-columns-1 figure {
  width: 100%;
  margin: 0 0 1em 0;
  float: none; }

.gallery.gallery-columns-3 figure {
  width: 32%; }

.gallery.gallery-columns-3 figure:nth-of-type(3n+3) {
  margin-right: 0; }

.gallery.gallery-columns-3 figure:nth-of-type(3n+4) {
  clear: left; }

.gallery.gallery-columns-2 figure {
  width: 49%; }

.gallery.gallery-columns-2 figure:nth-of-type(even) {
  margin-right: 0; }

.gallery.gallery-columns-2 figure:nth-of-type(odd) {
  clear: left; }

.gallery.gallery-columns-4 figure {
  width: 23.25%; }

.gallery.gallery-columns-4 figure:nth-of-type(4n+4) {
  margin-right: 0; }

.gallery.gallery-columns-4 figure:nth-of-type(4n+5) {
  clear: left; }

.gallery.gallery-columns-5 figure {
  width: 18%; }

.gallery.gallery-columns-5 figure:nth-of-type(5n+5) {
  margin-right: 0; }

.gallery.gallery-columns-5 figure:nth-of-type(5n+6) {
  clear: left; }

.gallery.gallery-columns-6 figure {
  width: 14.2%; }

.gallery.gallery-columns-6 figure:nth-of-type(6n+6) {
  margin-right: 0; }

.gallery.gallery-columns-6 figure:nth-of-type(6n+7) {
  clear: left; }

.gallery.gallery-columns-7 figure {
  width: 12%; }

.gallery.gallery-columns-7 figure:nth-of-type(7n+7) {
  margin-right: 0; }

.gallery.gallery-columns-7 figure:nth-of-type(7n+8) {
  clear: left; }

.gallery.gallery-columns-8 figure {
  width: 10.2%; }

.gallery.gallery-columns-8 figure:nth-of-type(8n+8) {
  margin-right: 0; }

.gallery.gallery-columns-8 figure:nth-of-type(8n+9) {
  clear: left; }

.gallery.gallery-columns-9 figure {
  width: 8.85%; }

.gallery.gallery-columns-9 figure:nth-of-type(9n+9) {
  margin-right: 0; }

.gallery.gallery-columns-9 figure:nth-of-type(9n+10) {
  clear: left; }

@media (max-width: 767px) {
  img.alignright, div.alignright, figure.alignright, img.alignleft, div.alignleft, figure.alignleft, img.wp-post-image.attachment-thumb {
    display: block;
    margin: 1em auto;
    float: none; }

  .gallery.gallery-columns-4 figure, .gallery.gallery-columns-5 figure, .gallery.gallery-columns-6 figure, .gallery.gallery-columns-7 figure, .gallery.gallery-columns-8 figure, .gallery.gallery-columns-9 figure {
    width: 100%;
    margin: 0 0 1em 0;
    float: none; } }

input[name=post_password] {
  border: 1px solid #3c3d41; }
/*--------------------------------------------------------------
 # Vendor
 --------------------------------------------------------------*/
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0; }
  .slick-list:focus {
    outline: none; }
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand; }

.slick-slider .slick-track, .slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  .slick-track:before, .slick-track:after {
    content: "";
    display: table; }
  .slick-track:after {
    clear: both; }
  .slick-loading .slick-track {
    visibility: hidden; }

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none; }
  [dir="rtl"] .slick-slide {
    float: right; }
  .slick-slide img {
    display: block; }
  .slick-slide.slick-loading img {
    display: none; }
  .slick-slide.dragging img {
    pointer-events: none; }
  .slick-initialized .slick-slide {
    display: block; }
  .slick-loading .slick-slide {
    visibility: hidden; }
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent; }

.slick-arrow.slick-hidden {
  display: none; }

.slick-dots {
  list-style: none;
  margin: 0;
  padding: 0; }
  .slick-dots li {
    display: inline-block;
    margin: 0 8px; }
  .slick-dots li button {
    text-indent: -9999em;
    border-radius: 50%;
    width: 16px;
    height: 16px;
    padding: 0;
    background: transparent;
    border: 1px solid rgba(57, 181, 74, 1);
    outline: 0; }
  .slick-dots li.slick-active button {
    background: #39b54a; }
/*--------------------------------------------------------------
 # Components
 --------------------------------------------------------------*/
#masthead {
  background: #fff;
  position: fixed;
  height: 120px;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1001;
  border-bottom: 1px solid #3c3d41; }
  .admin-bar #masthead {
    top: 32px; }
  @media (max-width: 782px) {
    .admin-bar #masthead {
      top: 46px; } }
  #masthead .container {
    height: 100%;
    position: relative; }
  #masthead .container .site-branding {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    height: 100%;
    max-height: 120px; }
    @media (min-width: 768px) {
    #masthead .container .site-branding {
      padding: 10px 0; } }
    #masthead .container .site-branding .site-logo {
      align-items: center;
      display: flex;
      height: 100%;
      margin-left: 15px;
      max-height: inherit; }
      @media (min-width: 576px) {
    #masthead .container .site-branding .site-logo {
      margin-left: 0; } }
      #masthead .container .site-branding .site-logo a {
        height: auto;
        max-height: inherit;
        overflow: hidden;
        text-decoration: none; }
      #masthead .container .site-branding .site-logo img {
        aspect-ratio: unset;
        height: 100%;
        max-height: inherit;
        object-fit: contain;
        object-position: left;
        padding: 10px 0;
        width: 100%; }
    #masthead .container .site-branding .site-title {
      line-height: 1.1em; }
      #masthead .container .site-branding .site-title a {
        font-size: 16px;
        font-weight: bold;
        letter-spacing: 0.05em;
        color: #3c3d41;
        text-decoration: none; }
        #masthead .container .site-branding .site-title a:hover {
          text-decoration: none; }
  #masthead .container #navigation {
    display: flex;
    flex-direction: column-reverse; }
    #masthead .container #navigation #aux-area {
      display: flex;
      justify-content: flex-end;
      align-items: center;
      height: 60px; }
      #masthead .container #navigation #aux-area .social-menu {
        display: flex;
        list-style: none;
        margin: 0;
        padding: 0 10px 0 0; }
        #masthead .container #navigation #aux-area .social-menu li {
          padding: 0 10px; }
          #masthead .container #navigation #aux-area .social-menu li a:focus, #masthead .container #navigation #aux-area .social-menu li a.focus-visible {
            border-radius: initial;
            box-shadow: initial;
            opacity: initial;
            outline: initial; }
          #masthead .container #navigation #aux-area .social-menu li svg g.facebook, #masthead .container #navigation #aux-area .social-menu li svg g.twitter, #masthead .container #navigation #aux-area .social-menu li svg g.instagram, #masthead .container #navigation #aux-area .social-menu li svg g.youtube {
            fill: #3c3d41; }
      #masthead .container #navigation #aux-area #site-search {
        padding: inherit; }
        #masthead .container #navigation #aux-area #site-search form {
          margin: 0;
          position: relative; }
          #masthead .container #navigation #aux-area #site-search form input[type=text] {
            padding: 0 30px 0 0;
            border-bottom: 2px solid #3c3d41;
            height: 30px;
            width: 210px;
            margin: 0;
            font-size: 13px;
            background-color: #fff; }
            #masthead .container #navigation #aux-area #site-search form input[type=text]::placeholder {
              color: rgba(101, 107, 111, 0.7); }
          #masthead .container #navigation #aux-area #site-search form input[type=submit] {
            background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIj8+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB2aWV3Qm94PSIwIDAgMzAgMzAiIHdpZHRoPSIzMHB4IiBoZWlnaHQ9IjMwcHgiPgogICAgPHBhdGggc3R5bGU9ImxpbmUtaGVpZ2h0Om5vcm1hbDt0ZXh0LWluZGVudDowO3RleHQtYWxpZ246c3RhcnQ7dGV4dC1kZWNvcmF0aW9uLWxpbmU6bm9uZTt0ZXh0LWRlY29yYXRpb24tc3R5bGU6c29saWQ7dGV4dC1kZWNvcmF0aW9uLWNvbG9yOiMwMDA7dGV4dC10cmFuc2Zvcm06bm9uZTtibG9jay1wcm9ncmVzc2lvbjp0Yjtpc29sYXRpb246YXV0bzttaXgtYmxlbmQtbW9kZTpub3JtYWwiIGQ9Ik0gMTMgMyBDIDcuNDg4OTk3MSAzIDMgNy40ODg5OTcxIDMgMTMgQyAzIDE4LjUxMTAwMyA3LjQ4ODk5NzEgMjMgMTMgMjMgQyAxNS4zOTY1MDggMjMgMTcuNTk3Mzg1IDIyLjE0ODk4NiAxOS4zMjIyNjYgMjAuNzM2MzI4IEwgMjUuMjkyOTY5IDI2LjcwNzAzMSBBIDEuMDAwMSAxLjAwMDEgMCAxIDAgMjYuNzA3MDMxIDI1LjI5Mjk2OSBMIDIwLjczNjMyOCAxOS4zMjIyNjYgQyAyMi4xNDg5ODYgMTcuNTk3Mzg1IDIzIDE1LjM5NjUwOCAyMyAxMyBDIDIzIDcuNDg4OTk3MSAxOC41MTEwMDMgMyAxMyAzIHogTSAxMyA1IEMgMTcuNDMwMTIzIDUgMjEgOC41Njk4Nzc0IDIxIDEzIEMgMjEgMTcuNDMwMTIzIDE3LjQzMDEyMyAyMSAxMyAyMSBDIDguNTY5ODc3NCAyMSA1IDE3LjQzMDEyMyA1IDEzIEMgNSA4LjU2OTg3NzQgOC41Njk4Nzc0IDUgMTMgNSB6IiBmb250LXdlaWdodD0iNDAwIiBmb250LWZhbWlseT0ic2Fucy1zZXJpZiIgd2hpdGUtc3BhY2U9Im5vcm1hbCIgb3ZlcmZsb3c9InZpc2libGUiLz4KPC9zdmc+Cg==') center right no-repeat;
            position: absolute;
            right: 0px;
            width: 15px;
            background-size: 15px;
            top: 0px;
            font-size: 0px;
            padding: 0px;
            height: 30px; }
    #masthead .container #navigation #site-navigation {
      align-items: stretch;
      display: flex;
      height: inherit;
      justify-content: flex-end; }
      #masthead .container #navigation #site-navigation .menu-toggle {
        display: none; }
      #masthead .container #navigation #site-navigation .main-nav-container {
        display: flex; }
        #masthead .container #navigation #site-navigation .main-nav-container input[type=text] {
          width: 100%;
          border: 1px solid;
          border-bottom: none; }
          @media (min-width: 1025px) {
    #masthead .container #navigation #site-navigation .main-nav-container input[type=text] {
      display: none; } }
        @media (min-width: 1025px) {
    #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      align-items: stretch; }
      #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li {
        margin: 0 0 0 25px;
        position: relative;
        bottom: -2px;
        display: flex;
        align-items: center; }
        #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li > a {
          display: block;
          font-size: 16px;
          font-weight: bold;
          text-decoration: none;
          position: relative;
          color: #3c3d41;
          background: none;
          border-bottom-width: 0;
          white-space: nowrap; }
        #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:after {
          content: '';
          display: block;
          position: absolute;
          top: calc(50% + 10px);
          height: 3px;
          width: 100%;
          background: transparent;
          transition: background 0.3s ease-in-out; }
        #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:hover:after {
          background: #39b54a; }
        #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:focus-within:after, #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:focus-visible:after, #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li .focus-visible:after {
          background: #39b54a; }
        #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:focus-visible, #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li .focus-visible {
          border-radius: 0;
          outline: none;
          box-shadow: none; }
        #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:hover ul.sub-menu, #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:focus ul.sub-menu, #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:focus-within ul.sub-menu, #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li:focus-visible ul.sub-menu, #masthead .container #navigation #site-navigation .main-nav-container ul#primary-menu > li.focus-visible ul.sub-menu {
          display: block; }
    #masthead .container #navigation #site-navigation .main-nav-container li.menu-item-has-children a:hover + ul.sub-menu {
      display: block; }
    #masthead .container #navigation #site-navigation .main-nav-container li.menu-item-has-children a[aria-expanded="true"] + ul.sub-menu {
      display: block; }
    #masthead .container #navigation #site-navigation .main-nav-container ul.sub-menu {
      display: none;
      position: absolute;
      top: 100%;
      left: -20px;
      background: #fff;
      padding: 5px 20px;
      border-radius: 2px;
      margin: 0;
      min-width: calc(100% + 80px); }
      #masthead .container #navigation #site-navigation .main-nav-container ul.sub-menu li {
        display: block;
        margin: 20px 0;
        white-space: nowrap;
        font-size: 14px;
        line-height: 1.1em; }
        #masthead .container #navigation #site-navigation .main-nav-container ul.sub-menu li a {
          color: #3c3d41;
          text-decoration: none;
          white-space: initial; }
          #masthead .container #navigation #site-navigation .main-nav-container ul.sub-menu li a:hover {
            text-decoration: none; }
      #masthead .container #navigation #site-navigation .main-nav-container ul.sub-menu:hover {
        display: block; } }
  #masthead .row {
    height: 100%; }

@media (max-width: 480px) {
  #masthead {
    max-height: 3em; }

  #page {
    padding-top: 3em; } }

@media (max-width: 1024px) {
  #masthead .container .site-branding .site-logo a {
    height: 100%;
    margin-right: 20px; }
    #masthead .container .site-branding .site-title a {
      color: #3c3d41; }
    #masthead .container #navigation {
      flex-direction: initial;
      height: inherit; }
    #masthead .container #navigation #aux-area .social-menu {
      display: none; }
      #masthead .container #navigation #aux-area #site-search {
        display: none; }
    #masthead .container #navigation #site-navigation {
      align-items: center;
      place-self: center;
      width: 50px; }
      #masthead .container #navigation #site-navigation .menu-toggle {
        color: #3c3d41;
        cursor: pointer;
        display: flex;
        flex-flow: column nowrap;
        font-size: 12px;
        font-weight: bold;
        height: 100%;
        padding: 0.5rem;
        text-transform: uppercase;
        z-index: 9999; }
        #masthead .container #navigation #site-navigation .menu-toggle .hamburger-icon, #masthead .container #navigation #site-navigation .menu-toggle .close-icon {
          height: 100%;
          width: 100%; }
          #masthead .container #navigation #site-navigation .menu-toggle .hamburger-icon span, #masthead .container #navigation #site-navigation .menu-toggle .close-icon span {
            height: inherit;
            width: inherit; }
          #masthead .container #navigation #site-navigation .menu-toggle .hamburger-icon svg, #masthead .container #navigation #site-navigation .menu-toggle .close-icon svg {
            height: inherit;
            width: inherit; }
            #masthead .container #navigation #site-navigation .menu-toggle .hamburger-icon svg *, #masthead .container #navigation #site-navigation .menu-toggle .close-icon svg * {
              fill: #39b54a; }
        #masthead .container #navigation #site-navigation .menu-toggle .close-icon svg {
          padding: 6px; }
      #masthead .container #navigation #site-navigation .main-nav-container {
        display: block;
        position: fixed;
        z-index: 9998;
        background: #fff;
        top: 0;
        right: -110%;
        bottom: 0;
        width: 90%;
        padding: 95px 20px 20px;
        transition: right 0.6s cubic-bezier(0.19, 1, 0.22, 1);
        overflow-y: scroll;
        -webkit-overflow-scrolling: touch;
        box-shadow: -3px 0px 6px -1px rgba(0, 0, 0, 0.2); }
        body.admin-bar #masthead .container #navigation #site-navigation .main-nav-container {
          top: 46px; }
        #masthead .container #navigation #site-navigation .main-nav-container ul {
          margin: 0;
          padding: 0;
          list-style: none; }
          #masthead .container #navigation #site-navigation .main-nav-container ul > li {
            margin: 0;
            display: block;
            border-top: 1px solid #3c3d41; }
            #masthead .container #navigation #site-navigation .main-nav-container ul > li > a {
              display: block;
              font-size: 16px;
              font-weight: bold;
              text-transform: uppercase;
              text-decoration: none;
              padding: 15px 0;
              color: #3c3d41;
              border-bottom-width: 0;
              background: none; }
          #masthead .container #navigation #site-navigation .main-nav-container ul.sub-menu li a {
            text-transform: none;
            font-weight: normal;
            padding: 15px;
            color: #3c3d41;
            border-bottom-width: 0; }
            #masthead .container #navigation #site-navigation .main-nav-container ul.sub-menu li a:after {
              display: none; }
      #masthead .container #navigation #site-navigation #menu-toggle__open {
        display: inline-block;
        flex-flow: column nowrap;
        justify-content: center;
        align-items: center;
        height: 100%;
        overflow: hidden; }
      #masthead .container #navigation #site-navigation #menu-toggle__close {
        display: none; }
      #masthead .container #navigation #site-navigation.menu-open .main-nav-container {
        right: 0; }
        #masthead .container #navigation #site-navigation.menu-open #menu-toggle__open {
          display: none; }
        #masthead .container #navigation #site-navigation.menu-open #menu-toggle__close {
          display: inline-block;
          flex-flow: column nowrap;
          justify-content: center;
          align-items: center;
          height: 100%;
          overflow: hidden; } }

.floating-cart {
  position: fixed;
  width: 90px;
  top: 152px;
  right: 0;
  z-index: 1002;
  background: #39b54a;
  padding: 10px 20px;
  text-align: center;
  font-weight: bold;
  font-size: 14px;
  transition: right 0.5s ease-in-out; }
  .floating-cart a {
    color: #fff;
    text-decoration: none; }
  .floating-cart .quantity {
    margin-top: 14px;
    height: 40px;
    width: 45px; }
  .floating-cart .cart-link {
    text-decoration: underline; }
  .floating-cart svg {
    fill: #fff;
    width: 50px;
    height: 50px;
    position: absolute;
    left: 20px;
    top: 10px; }
  .floating-cart.empty {
    right: -90px; }

@media screen and (max-width: 600px) {
  #wpadminbar {
    position: fixed !important; } }

a.button, .button {
  display: inline-block;
  font-size: 12px;
  font-weight: bold;
  text-transform: uppercase;
  padding: 1em;
  min-height: 45px;
  background: #39b54a;
  color: #fff;
  transition: all 0.3s ease-in-out;
  text-decoration: none;
  outline: 0; }
  a.button.outline, .button.outline {
    background: none;
    border: 2px solid #fff;
    color: #fff; }
  a.button:hover, .button:hover, a.button:active, .button:active, a.button:focus, .button:focus, a.button:focus-visible, .button:focus-visible, a.button.focus-visible, .button.focus-visible {
    background: #fff;
    color: #39b54a;
    border-radius: initial;
    box-shadow: initial;
    opacity: 1;
    outline: initial; }
  a.button:hover.outline, .button:hover.outline, a.button:active.outline, .button:active.outline, a.button:focus.outline, .button:focus.outline, a.button:focus-visible.outline, .button:focus-visible.outline, a.button.focus-visible.outline, .button.focus-visible.outline {
    background: #39b54a;
    border: 2px solid #39b54a;
    border-radius: initial;
    color: #fff;
    box-shadow: initial;
    opacity: 1;
    outline: initial; }

.btn {
  text-decoration: none;
  border-radius: 1px; }
  .btn.outline {
    background: none;
    border: 2px solid #fff;
    color: #fff; }
  .btn.outline.btn-sm {
    border-width: 1px; }
  .btn.outline:hover {
    background: #fff;
    color: #39b54a; }
  .btn.btn-secondary {
    color: #3c3d41;
    border: none; }
  .btn.btn-secondary:hover {
    border: none; }

.overlay .button.outline {
  border-color: #fff;
  color: #fff; }
  .overlay .button.outline:hover, .overlay .button.outline:focus, .overlay .button.outline:focus-visible, .overlay .button.outline.focus-visible {
    color: #39b54a;
    background: #fff;
    border-radius: initial;
    box-shadow: initial;
    opacity: 1;
    outline: initial; }

a.arrow-link {
  text-transform: uppercase;
  font-size: 18px;
  font-weight: bold;
  display: inline-block;
  position: relative;
  line-height: 20px;
  padding-right: 28px;
  text-decoration: none;
  transition: opacity 0.3s ease-in-out;
  text-align: right; }
  a.arrow-link:hover, a.arrow-link:focus, a.arrow-link:active {
    opacity: 0.7; }
  a.arrow-link .arrow {
    display: block;
    width: 22px;
    height: 20px;
    position: absolute;
    right: 0;
    top: 0; }
  a.arrow-link .arrow g {
    fill: #39b54a; }
  a.arrow-link.reverse-arrow {
    padding: 0 0 0 28px;
    text-align: left; }
  a.arrow-link.reverse-arrow .arrow {
    right: auto;
    left: 0;
    transform: rotate(180deg); }
  a.arrow-link:last-child {
    flex: 1; }
/**
 Buy Tickets dropdown
 */
.buy-tickets-dropdown {
  min-width: 200px; }
  .buy-tickets-dropdown .button.dropdown-toggle {
    min-width: 100%;
    border-radius: 0;
    border: 0; }
  .buy-tickets-dropdown .button.dropdown-toggle:hover {
    color: #fff;
    background: #39b54a; }
  .buy-tickets-dropdown .button.dropdown-toggle:focus {
    box-shadow: none; }
  .buy-tickets-dropdown .button.dropdown-toggle:active {
    box-shadow: none; }
  .buy-tickets-dropdown.show .button.dropdown-toggle {
    background-color: #39b54a; }
  .buy-tickets-dropdown .dropdown-menu {
    min-width: 100%;
    border-radius: 0;
    margin: 0;
    border: 0;
    background-color: #39b54a;
    color: #fff; }
  .buy-tickets-dropdown form.buy-tickets-options {
    display: flex;
    flex-direction: column; }
  .buy-tickets-dropdown form.buy-tickets-options label {
    display: flex;
    padding: 2px 10px;
    justify-content: space-between;
    font-size: 0.85rem; }
  .buy-tickets-dropdown form.buy-tickets-options input {
    width: 28px;
    border: 1px solid;
    text-align: center; }
  .buy-tickets-dropdown form.buy-tickets-options button.add-to-cart {
    margin: 0 10px;
    min-width: 0px;
    padding: 0 0.5em;
    border-color: #fff; }
    .buy-tickets-dropdown form.buy-tickets-options button.add-to-cart:hover, .buy-tickets-dropdown form.buy-tickets-options button.add-to-cart:active {
      background: #fff;
      color: #39b54a; }

.buy-ticket-external {
  min-width: 200px; }

.buy-tickets-sold-out {
  display: inline-block;
  font-size: 12px;
  font-weight: bold;
  text-transform: uppercase;
  padding: 1em;
  min-height: 45px;
  color: #39b54a;
  border: 2px solid #39b54a;
  transition: all 0.3s ease-in-out;
  text-decoration: none;
  outline: 0; }

.carousel-control-prev, .carousel-control-next {
  top: 0;
  width: auto; }

.carousel-control-prev {
  margin-left: 2em; }

.carousel-control-next {
  margin-right: 2em; }

.carousel-controls {
  align-items: center;
  clear: both;
  display: flex;
  flex-flow: row nowrap;
  justify-content: flex-end;
  position: relative;
  width: 100%; }

.carousel-controls > a {
  max-width: 2em; }

.carousel[data-status="playing"] + .carousel-controls .carousel-control-play {
  display: none; }

.carousel[data-status="playing"] + .carousel-controls .carousel-control-pause {
  display: inline-flex; }

.carousel[data-status="paused"] + .carousel-controls .carousel-control-play {
  display: inline-flex; }

.carousel[data-status="paused"] + .carousel-controls .carousel-control-pause {
  display: none; }

.video-hero-control {
  color: #fff;
  display: none; }

.carousel[data-carousel-item-type="video"] .video-hero-control {
  bottom: 2rem;
  max-height: 1.5rem;
  max-width: 1.5rem;
  position: absolute;
  right: 1.5rem; }
  @media (min-width: 768px) {
    .carousel[data-carousel-item-type="video"] .video-hero-control {
      max-height: 2rem;
      max-width: 2rem; } }
  .carousel[data-carousel-item-type="video"] .video-hero__play {
    display: none; }
  .carousel[data-carousel-item-type="video"] .video-hero__pause {
    display: inline-block; }

body.filmbot-vbg-paused .carousel[data-carousel-item-type="video"] .video-hero__play {
  display: inline-block; }
  body.filmbot-vbg-paused .carousel[data-carousel-item-type="video"] .video-hero__pause {
    display: none; }

#footer {
  padding: 15px 0;
  background: #d1d2d4;
  color: rgba(60, 61, 65, 0.95);
  font-size: 14px;
  line-height: 1.3em;
  z-index: 1;
  position: relative; }
  #footer p {
    margin: 0 0 15px;
    color: rgba(60, 61, 65, 0.95); }
  #footer a, #footer a:visited {
    color: rgba(60, 61, 65, 0.95); }
  #footer a:hover, #footer a:visited:hover {
    text-decoration: underline; }
  #footer .semi-trans {
    opacity: 0.5; }
  #footer .semi-trans-30 {
    opacity: 0.3; }
  #footer .footer-widget {
    margin: 40px 0; }
  @media (min-width: 768px) {
    #footer .last {
      text-align: right; } }
  @media (max-width: 767px) {
  #footer .g-col {
    margin: 10px 0; } }
  #footer .row {
    padding: 35px 0; }
  #footer .row:last-child {
    font-size: 12px; }
  #footer .row.space-between {
    justify-content: space-between; }
  #footer .footer-menu {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap; }
  #footer .footer-menu li:not(:first-child):before {
    content: '\/';
    margin: 0 10px; }
    #footer .footer-menu li a {
      color: rgba(60, 61, 65, 0.95);
      text-decoration: underline; }
      #footer .footer-menu li a:hover, #footer .footer-menu li a:focus, #footer .footer-menu li a:focus-visible, #footer .footer-menu li a.focus-visible {
        text-decoration: none; }
  #footer .follow {
    margin-top: 12px; }
  #footer .social-menu {
    margin: 20px 0 0;
    padding: 0;
    list-style: none;
    display: flex; }
  @media (max-width: 767px) {
    #footer .social-menu {
      justify-content: flex-start; }
      #footer .social-menu li {
        margin-right: 20px; } }
  #footer .social-menu li {
    margin-right: 20px; }
    #footer .social-menu li a {
      display: flex;
      width: 45px;
      height: 45px;
      border-radius: 50%;
      border: 1px solid rgba(60, 61, 65, 1);
      justify-content: center;
      align-items: center; }
      #footer .social-menu li a svg g.facebook, #footer .social-menu li a svg g.twitter, #footer .social-menu li a svg g.instagram, #footer .social-menu li a svg g.youtube {
        fill: rgba(60, 61, 65, 0.95); }
      #footer .social-menu li a:hover {
        border-color: #39b54a;
        background: none; }
        #footer .social-menu li a:hover svg g.facebook, #footer .social-menu li a:hover svg g.twitter, #footer .social-menu li a:hover svg g.instagram, #footer .social-menu li a:hover svg g.youtube {
          fill: #39b54a; }
  #footer h4 {
    margin: 0 0 20px;
    color: rgba(60, 61, 65, 0.95); }
  #footer form {
    position: relative; }
  #footer input {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    border: none;
    height: 45px;
    padding: 10px 45px 10px 15px;
    outline: 0;
    vertical-align: top;
    font-size: 14px;
    border-radius: 4px;
    width: 300px;
    max-width: 100%; }
  #footer [type=submit] {
    text-indent: -9999em;
    display: block;
    position: absolute;
    width: 40px;
    height: 45px;
    padding: 0;
    left: 260px;
    z-index: 9;
    background: url('../images/right-carat.svg') center center no-repeat;
    top: 0; }
  @media (min-width: 768px) and (max-width: 991px) {
    #footer [type=submit] {
      left: auto;
      right: 0; } }
  #footer .youtube-oembed {
    height: auto; }
  #footer .sponsors-widget .carousel-inner {
    height: 100%; }
    #footer .sponsors-widget .carousel-inner .carousel-item {
      height: 100%;
      text-align: center; }
      #footer .sponsors-widget .carousel-inner .carousel-item img {
        margin-top: 0;
        height: 100%;
        width: auto; }
  #footer .sponsors-widget .carousel-controls {
    display: grid;
    grid-template-columns: 2fr 1fr 2fr;
    grid-template-areas: 'prev playpause next';
    margin-top: 1em; }
    #footer .sponsors-widget .carousel-controls > a {
      bottom: initial;
      height: 100%;
      justify-content: initial !important;
      margin: 0;
      max-height: 1.5rem;
      max-width: 1.5rem;
      opacity: initial;
      position: relative;
      text-align: initial;
      top: initial;
      width: 100%; }
    #footer .sponsors-widget .carousel-controls .carousel-control-prev {
      grid-area: prev;
      justify-self: end;
      transform: rotate(180deg) !important; }
    #footer .sponsors-widget .carousel-controls .carousel-control-play, #footer .sponsors-widget .carousel-controls .carousel-control-pause {
      grid-area: playpause;
      justify-self: center; }
    #footer .sponsors-widget .carousel-controls .carousel-control-next {
      grid-area: next;
      justify-self: start; }
    #footer .sponsors-widget .carousel-controls svg {
      height: 100%; }

#itinerary-builder {
  background: #39b54a;
  color: #fff;
  position: fixed;
  width: 100%;
  bottom: 0;
  transform: translateY(100%);
  z-index: 998;
  transition: transform 0.6s cubic-bezier(0.19, 1, 0.22, 1); }
  #itinerary-builder.ib-open {
    transform: translateY(0);
    z-index: 1002; }
  #itinerary-builder.ib-open .tab:before {
    transform: rotate(45deg);
    top: 16px; }
  @media (max-width: 480px) {
      #itinerary-builder.ib-open .ib-inner {
        max-height: calc(100vh - 4em);
        overflow: scroll; } }
  #itinerary-builder .container {
    position: relative; }
  #itinerary-builder .container.ib-inner {
    padding-top: 20px; }
  #itinerary-builder .tab {
    position: absolute;
    background: #39b54a;
    display: inline-block;
    font-weight: bold;
    cursor: pointer;
    font-size: 1em;
    height: 2.5625em;
    left: -5px;
    line-height: 2.5625em;
    padding: 0 40px 0 20px;
    top: -40px; }
  #itinerary-builder .tab:before {
    content: "";
    position: absolute;
    border: solid #fff;
    transform: rotate(225deg);
    border-width: 0 3px 3px 0;
    right: 20px;
    top: 18px;
    width: 8px;
    height: 8px; }
  #itinerary-builder #ib-status {
    color: #fff;
    display: inline-block;
    margin: 5px 0 0 0;
    font-weight: bold;
    margin-bottom: 16px; }
  @media (min-width: 480px) {
    #itinerary-builder #ib-status {
      margin: 0 0 20px 0; } }
  #itinerary-builder a.start-over {
    color: #fff;
    display: inline-block;
    font-size: 11px;
    font-weight: bold;
    margin: 0; }
  @media (min-width: 480px) {
    #itinerary-builder a.start-over {
      font-size: 1em;
      margin: 0 0 0 20px; } }
  #itinerary-builder #open-itinerary {
    background: rgba(255, 255, 255, 0.3); }
  #itinerary-builder .ib-row {
    display: flex;
    margin: 0 -8px; }
  @media (max-width: 480px) {
    #itinerary-builder .ib-row {
      flex-direction: column; } }
  @media (max-width: 1023px) {
    #itinerary-builder .ib-row {
      flex-wrap: wrap; } }
  #itinerary-builder .ib-col {
    flex-grow: 1;
    margin: 0 8px 16px; }
  #itinerary-builder .label {
    font-weight: bold;
    margin: 0 0 5px;
    white-space: nowrap; }
  @media (min-width: 480px) {
    #itinerary-builder .label {
      font-size: 14px; } }
  #itinerary-builder input {
    background: rgba(0, 0, 0, 0.15);
    color: rgba(255, 255, 255, 0.7);
    width: 100%; }
  #itinerary-builder input::placeholder {
    color: rgba(255, 255, 255, 0.7); }
  @media (max-width: 480px) {
    #itinerary-builder input {
      height: 30px;
      padding: 0 5px; } }
  #itinerary-builder .bottom-align {
    align-self: flex-start; }
  @media (min-width: 480px) {
    #itinerary-builder .bottom-align {
      align-self: flex-end; } }
  #itinerary-builder .add-to-cal a {
    color: #fff;
    font-size: 12px;
    font-weight: bold; }
    @media (min-width: 480px) {
    #itinerary-builder .add-to-cal a {
      font-size: initial;
      line-height: 45px; } }
  #itinerary-builder .share {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex; }
  #itinerary-builder .share li {
    margin: 0 6px 0 0; }
    #itinerary-builder .share li:last-child {
      margin: 0; }
    #itinerary-builder .share li a {
      display: flex;
      width: 45px;
      height: 45px;
      background: #39b54a;
      justify-content: center;
      align-items: center; }
      #itinerary-builder .share li a:hover {
        background: rgba(57, 181, 74, 0.7); }
  @media (max-width: 480px) {
    #itinerary-builder a.button {
      font-size: 11px;
      min-height: auto; } }
  #itinerary-builder .gala-tooltip {
    background: #3c3d41;
    font-size: 13px;
    font-weight: 500;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    line-height: 16px;
    text-align: center;
    display: inline-block;
    position: relative; }
  @media (min-width: 480px) {
    #itinerary-builder .gala-tooltip {
      top: -10px;
      margin-left: 5px; } }
/* Override some ugly bootstrap modal stuff */
.modal:not(.bootbox) .modal-content {
  background: none;
  border: 0;
  border-radius: 0; }
  .modal:not(.bootbox) .modal-body {
    padding: 0; }
  .modal:not(.bootbox) .iframe-holder {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding-bottom: 56.25%;
    height: 0; }
  .modal:not(.bootbox) .iframe-holder-inner {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%; }
  @media (max-width: 480px) {
    .modal:not(.bootbox) .iframe-holder-inner iframe {
      height: auto; } }
  .modal:not(.bootbox) .close-modal {
    cursor: pointer;
    display: flex;
    height: 40px;
    justify-content: center;
    line-height: 1;
    padding: 0;
    position: absolute;
    right: -40px;
    top: 0;
    width: 40px; }
  .modal:not(.bootbox) .close-modal span {
    font-size: 32px; }

.bootbox .modal-content {
  background: #f5f5f5;
  color: #000; }
  .bootbox .modal-header {
    display: block; }
  .bootbox .modal-body ul {
    margin-left: 0; }
  .bootbox .modal-footer button {
    border-radius: 0px;
    font-size: 12px;
    font-weight: 700; }
  .bootbox .bootbox-close-button:hover {
    background: inherit; }
/*--------------------------------------------------------------
 # Layouts
 --------------------------------------------------------------*/
/*--------------------------------------------------------------
 # Components
 --------------------------------------------------------------*/
p.subheader {
  font-size: 20px; }

.hero {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; }
  .hero .hero-overlay {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3); }
  .hero .hero-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    padding: 8.125em 1.875em 12.5em;
    color: #fff;
    position: relative; }
  @media (max-width: 768px) {
    .hero .hero-content {
      padding: 3.75em 1.875em; } }
  .hero .hero-content.fill-viewport {
    min-height: calc(100vh - 95px);
    align-items: center; }
  .hero .hero-content .hero-subtitle {
    font-size: 20px;
    margin: 0 0 40px;
    color: #fff;
    text-transform: uppercase; }
    @media (max-width: 767px) {
    .hero .hero-content .hero-subtitle {
      font-size: 18px; } }
  .hero .hero-content h1.hero-title {
    margin: 0 0 40px;
    color: #fff; }
    .hero .hero-content h1.hero-title em {
      font-weight: normal; }
  .hero .hero-content p.hero-text {
    color: #fff;
    font-size: 48px;
    line-height: 1.1em;
    margin: 0 0 35px; }
    @media (max-width: 767px) {
    .hero .hero-content p.hero-text {
      font-size: 28px; } }
  .hero .video-background-img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center; }
  .hero .video-background-img iframe {
    max-width: 1000%; }

.hero {
  min-height: calc(100vh - 120px);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  max-width: 100%;
  overflow: hidden; }
  .hero .hero-content {
    min-height: calc(100vh - 120px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    align-items: center;
    padding: 3.125em 1.875em;
    color: #fff;
    position: relative;
    z-index: 3; }
  .hero .hero-content .hero-subtitle {
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 40px;
    text-transform: uppercase; }
    @media (max-width: 767px) {
    .hero .hero-content .hero-subtitle {
      font-size: 18px; } }
  .hero .hero-content h1.hero-title {
    color: #fff;
    margin: 0 0 40px; }
    .hero .hero-content h1.hero-title em {
      font-weight: normal; }
  .hero .hero-content p.hero-text {
    color: #fff;
    font-size: 48px;
    line-height: 1.1em;
    margin: 0 0 35px; }
    @media (max-width: 767px) {
    .hero .hero-content p.hero-text {
      font-size: 28px; } }

.arrow {
  opacity: 1; }

.panel {
  padding: 50px 0;
  text-align: center; }

.sections {
  text-align: center;
  background-color: rgba(101, 107, 111, 0.3); }
  .sections p {
    font-size: 16px; }
  .sections p.subheader {
    font-size: 20px; }
  .sections .section-holder {
    margin: 25px 0;
    position: relative; }
  .sections .section-holder a {
    text-decoration: none;
    display: block;
    position: relative;
    overflow: hidden;
    height: 100%; }
  .sections .section-holder:hover .section-overlay {
    opacity: 0.9;
    transition: 0.3s opacity ease-in-out; }
  .sections .section .section__title {
    color: #3c3d41;
    font-size: 14px;
    letter-spacing: 0.1em;
    text-transform: uppercase; }
    @media (max-width: 767px) {
    .sections .section .section__title {
      font-size: 12px; } }
  .sections .section img {
    width: 100%;
    margin: 0 0 20px; }
  .sections .section p {
    color: #3c3d41; }
  .sections .section-overlay {
    background-color: #39b54a;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0; }
  .sections .section-overlay .section-overlay__title {
    color: #fff;
    font-size: 20px;
    text-transform: uppercase;
    padding: 10px; }
    @media (max-width: 767px) {
    .sections .section-overlay .section-overlay__title {
      font-size: 18px; } }

.module-overlay {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.3); }

.promo {
  background-color: #39b54a;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative; }
  .promo .promo-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    padding: 5em 1.875em 3.125em;
    color: #fff;
    position: relative; }
  .promo .promo-content h2 {
    margin: 0 0 20px;
    color: #fff; }
  .promo .promo-content p {
    color: #fff;
    margin: 0 0 35px; }

.show-grid.panel .post-archives {
  padding-top: 0; }

.show-slider {
  position: relative; }
  .show-slider .show-carousel .slick-slide {
    box-shadow: 0px 1px 1px 1px rgba(0, 0, 0, 0.1);
    padding: 15px;
    text-align: left;
    border-radius: 2px;
    margin: 15px; }
  .show-slider .show-carousel .card {
    border: none;
    border-radius: 0;
    background: none; }
    .show-slider .show-carousel .card .card-img-top {
      max-height: 250px;
      width: auto; }
    .show-slider .show-carousel .card .card-title {
      font-size: 20px; }
      @media (max-width: 767px) {
    .show-slider .show-carousel .card .card-title {
      font-size: 18px; } }
      .show-slider .show-carousel .card .card-title a {
        text-decoration: none; }
    .show-slider .show-carousel .card .card-body {
      background: none; }
    .show-slider .show-carousel .card .category {
      margin-bottom: 5px; }
      .show-slider .show-carousel .card .category a {
        text-decoration: none; }
    .show-slider .show-carousel .card .card-footer {
      background: none; }
    .show-slider .show-carousel .card .button {
      white-space: nowrap; }
  .show-slider .show-slider-next, .show-slider .show-slider-prev {
    position: absolute;
    top: calc(50% - 35px);
    right: 45px;
    cursor: pointer;
    width: 70px;
    height: 70px;
    border-radius: 50%;
    background: rgba(101, 107, 111, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    isolation: isolate;
    z-index: 900; }
  .show-slider .show-slider-next.show-slider-prev, .show-slider .show-slider-prev.show-slider-prev {
    right: auto;
    left: 45px; }
  .show-slider .show-slider-next:hover, .show-slider .show-slider-prev:hover {
    background: rgba(101, 107, 111, 1); }
  @media (max-width: 767px) {
    .show-slider .show-slider-next, .show-slider .show-slider-prev {
      display: none !important; } }

div.search {
  background-color: rgba(101, 107, 111, 0.3);
  padding: 50px 0;
  text-align: center; }

.search-form {
  margin: 40px 0 0;
  text-align: left; }
  .search-form .input {
    padding: 20px 0; }
  .search-form .input input {
    width: 100%; }
    .search-form .input input[type="text"] {
      border: 1px solid; }
  .search-form .submit-btn {
    text-align: center;
    margin: 30px 0 20px; }

.news {
  padding-bottom: 0; }
  .news h5 a {
    text-transform: uppercase; }
  .news .news-grid {
    margin: 50px 0 0; }
  .news .news-square {
    margin: 0 -15px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative; }
  .news .news-square:before {
    content: '';
    display: block;
    height: 0;
    padding-top: 100%; }
  .news .news-square .overlay {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 25% 35px 32%;
    transition: 0.3s background ease-in-out; }
    .news .news-square .overlay h3 {
      color: #fff;
      line-height: 1.1em;
      font-weight: normal; }
    .news .news-square .overlay .button {
      color: #fff;
      border-color: #fff; }
  .news .news-square:hover .overlay {
    background: rgba(57, 181, 74, 0.7); }
    .news .news-square:hover .overlay h3 {
      color: #fff; }
    .news .news-square:hover .overlay .button {
      color: #fff;
      border-color: #fff; }
    .news .news-square:hover .overlay .button:hover {
      color: #39b54a;
      border-color: #fff;
      background: #fff; }

.schedule {
  background-color: rgba(101, 107, 111, 0.3); }
  .schedule .schedule-holder {
    margin: 40px 0 20px; }
  .schedule .schedule-holder .col-sm-6.col-lg-3 {
    display: flex; }
  .schedule .schedule-holder .schedule-item {
    position: relative;
    background: #fff;
    margin: 0 0 30px; }
    .schedule .schedule-holder .schedule-item a {
      text-decoration: none; }
    .schedule .schedule-holder .schedule-item img {
      width: 100%; }
    .schedule .schedule-holder .schedule-item p {
      margin: 10px 0; }
    .schedule .schedule-holder .schedule-item p.date {
      text-transform: uppercase;
      color: #39b54a;
      letter-spacing: 2px;
      font-weight: bold; }
    .schedule .schedule-holder .schedule-item .details {
      padding: 10px; }
    .schedule .schedule-holder .schedule-item .overlay {
      opacity: 0;
      position: absolute;
      top: 0;
      left: 0;
      bottom: 0;
      right: 0;
      background: rgba(57, 181, 74, 0.9);
      color: #fff;
      padding: 40px 0;
      transition: 0.3s opacity ease-in-out; }
    .schedule .schedule-holder .schedule-item .overlay .overlay__date {
      color: #fff;
      font-size: 28px;
      font-weight: bold;
      line-height: 1.1em;
      margin: 0 0 20px; }
      @media (max-width: 767px) {
      .schedule .schedule-holder .schedule-item .overlay .overlay__date {
        font-size: 32px; } }
    .schedule .schedule-holder .schedule-item:hover, .schedule .schedule-holder .schedule-item:focus, .schedule .schedule-holder .schedule-item:focus-visible, .schedule .schedule-holder .schedule-item.focus-visible, .schedule .schedule-holder .schedule-item:focus-within {
      box-shadow: initial;
      outline: initial; }
    .schedule .schedule-holder .schedule-item:hover .overlay, .schedule .schedule-holder .schedule-item:focus .overlay, .schedule .schedule-holder .schedule-item:focus-visible .overlay, .schedule .schedule-holder .schedule-item.focus-visible .overlay, .schedule .schedule-holder .schedule-item:focus-within .overlay {
      opacity: 1; }

.sponsors.panel {
  background-color: rgba(101, 107, 111, 0.3); }

.freeform-content {
  text-align: left; }

.share-buttons a {
  display: flex;
  align-items: center;
  background: none;
  margin: 0 0 20px;
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: 0.1em;
  text-decoration: none;
  transition: opacity 0.3s ease-in-out; }
  .share-buttons a:hover, .share-buttons a:focus, .share-buttons a:active {
    opacity: 0.7;
    color: #999; }
  .share-buttons a img {
    width: 28px;
    height: 22px;
    margin-right: 8px;
    flex-shrink: 0; }

.post-archives, .search-results {
  text-align: center;
  padding: 50px 0; }
  .post-archives .search-shows, .search-results .search-shows {
    padding: 30px 0 40px;
    display: flex;
    justify-content: center; }
  .post-archives .search-shows .search-field, .search-results .search-shows .search-field {
    margin: 0 15px 0 0;
    width: 285px; }
    .post-archives .search-shows .search-field input, .search-results .search-shows .search-field input {
      border: 1px solid;
      width: 100%;
      font-size: 14px; }
  .post-archives .search-shows .search-button, .search-results .search-shows .search-button {
    width: 150px;
    text-align: right; }
    .post-archives .search-shows .search-button button, .search-results .search-shows .search-button button {
      display: block;
      width: 100%; }
    .post-archives .search-shows .search-button a, .search-results .search-shows .search-button a {
      display: inline-block;
      margin-top: 20px;
      text-transform: uppercase;
      color: #3c3d41;
      font-size: 14px; }
  .post-archives .items-list, .search-results .items-list, .post-archives .results-list, .search-results .results-list {
    text-align: center;
    margin-top: 50px; }
  .post-archives .items-list .item-holder, .search-results .items-list .item-holder, .post-archives .results-list .item-holder, .search-results .results-list .item-holder {
    margin: 0 0 60px;
    position: relative; }
    .post-archives .items-list .item-holder a, .search-results .items-list .item-holder a, .post-archives .results-list .item-holder a, .search-results .results-list .item-holder a {
      text-decoration: none;
      display: block;
      position: relative;
      overflow: hidden;
      height: 100%; }
    .post-archives .items-list .item-holder:hover, .search-results .items-list .item-holder:hover, .post-archives .results-list .item-holder:hover, .search-results .results-list .item-holder:hover, .post-archives .items-list .item-holder:focus-visible, .search-results .items-list .item-holder:focus-visible, .post-archives .results-list .item-holder:focus-visible, .search-results .results-list .item-holder:focus-visible, .post-archives .items-list .item-holder.focus-visible, .search-results .items-list .item-holder.focus-visible, .post-archives .results-list .item-holder.focus-visible, .search-results .results-list .item-holder.focus-visible, .post-archives .items-list .item-holder:focus-within, .search-results .items-list .item-holder:focus-within, .post-archives .results-list .item-holder:focus-within, .search-results .results-list .item-holder:focus-within {
      border-radius: 0;
      outline: none;
      box-shadow: none; }
    .post-archives .items-list .item-holder:hover .item-overlay, .search-results .items-list .item-holder:hover .item-overlay, .post-archives .results-list .item-holder:hover .item-overlay, .search-results .results-list .item-holder:hover .item-overlay, .post-archives .items-list .item-holder:focus-visible .item-overlay, .search-results .items-list .item-holder:focus-visible .item-overlay, .post-archives .results-list .item-holder:focus-visible .item-overlay, .search-results .results-list .item-holder:focus-visible .item-overlay, .post-archives .items-list .item-holder.focus-visible .item-overlay, .search-results .items-list .item-holder.focus-visible .item-overlay, .post-archives .results-list .item-holder.focus-visible .item-overlay, .search-results .results-list .item-holder.focus-visible .item-overlay, .post-archives .items-list .item-holder:focus-within .item-overlay, .search-results .items-list .item-holder:focus-within .item-overlay, .post-archives .results-list .item-holder:focus-within .item-overlay, .search-results .results-list .item-holder:focus-within .item-overlay {
      opacity: 0.9; }
  .post-archives .items-list .item, .search-results .items-list .item, .post-archives .results-list .item, .search-results .results-list .item {
    min-height: 300px; }
    .post-archives .items-list .item .item__subtitle, .search-results .items-list .item .item__subtitle, .post-archives .results-list .item .item__subtitle, .search-results .results-list .item .item__subtitle {
      font-size: 14px;
      text-transform: uppercase; }
    .post-archives .items-list .item .item__subtitle.section, .search-results .items-list .item .item__subtitle.section, .post-archives .results-list .item .item__subtitle.section, .search-results .results-list .item .item__subtitle.section {
      text-transform: none;
      font-weight: normal; }
    @media (max-width: 767px) {
      .post-archives .items-list .item .item__subtitle, .search-results .items-list .item .item__subtitle, .post-archives .results-list .item .item__subtitle, .search-results .results-list .item .item__subtitle {
        font-size: 12px; } }
    .post-archives .items-list .item .item__title, .search-results .items-list .item .item__title, .post-archives .results-list .item .item__title, .search-results .results-list .item .item__title {
      font-size: 20px; }
    @media (max-width: 767px) {
      .post-archives .items-list .item .item__title, .search-results .items-list .item .item__title, .post-archives .results-list .item .item__title, .search-results .results-list .item .item__title {
        font-size: 18px; } }
    .post-archives .items-list .item img, .search-results .items-list .item img, .post-archives .results-list .item img, .search-results .results-list .item img {
      height: 100%;
      margin: 0 auto 10px;
      max-height: 210px;
      max-width: 100%;
      object-fit: cover;
      object-position: center center;
      overflow: hidden;
      width: 100%; }
  .post-archives .items-list .item-overlay, .search-results .items-list .item-overlay, .post-archives .results-list .item-overlay, .search-results .results-list .item-overlay {
    color: #fff;
    background-color: #39b54a;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    min-height: 300px;
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: 0.3s opacity ease-in-out;
    padding: 20px; }
    .post-archives .items-list .item-overlay h4, .search-results .items-list .item-overlay h4, .post-archives .results-list .item-overlay h4, .search-results .results-list .item-overlay h4 {
      text-transform: uppercase;
      text-align: center;
      padding: 10px; }
    .post-archives .items-list .item-overlay p, .search-results .items-list .item-overlay p, .post-archives .results-list .item-overlay p, .search-results .results-list .item-overlay p {
      padding: 0 20px; }
    .post-archives .items-list .item-overlay p.director, .search-results .items-list .item-overlay p.director, .post-archives .results-list .item-overlay p.director, .search-results .results-list .item-overlay p.director {
      margin: 0 0 10px; }
    .post-archives .items-list .item-overlay .item-overlay__title, .search-results .items-list .item-overlay .item-overlay__title, .post-archives .results-list .item-overlay .item-overlay__title, .search-results .results-list .item-overlay .item-overlay__title {
      font-size: 23px; }
    @media (max-width: 767px) {
      .post-archives .items-list .item-overlay .item-overlay__title, .search-results .items-list .item-overlay .item-overlay__title, .post-archives .results-list .item-overlay .item-overlay__title, .search-results .results-list .item-overlay .item-overlay__title {
        font-size: 21px; } }
    .post-archives .items-list .item-overlay .item-overlay__subtitle, .search-results .items-list .item-overlay .item-overlay__subtitle, .post-archives .results-list .item-overlay .item-overlay__subtitle, .search-results .results-list .item-overlay .item-overlay__subtitle {
      clear: both;
      display: block;
      font-size: 14px;
      font-weight: bold;
      letter-spacing: 0.05em;
      text-transform: uppercase; }
    @media (max-width: 767px) {
      .post-archives .items-list .item-overlay .item-overlay__subtitle, .search-results .items-list .item-overlay .item-overlay__subtitle, .post-archives .results-list .item-overlay .item-overlay__subtitle, .search-results .results-list .item-overlay .item-overlay__subtitle {
        font-size: 12px; } }
    .post-archives .items-list .item-overlay .item-overlay__terms, .search-results .items-list .item-overlay .item-overlay__terms, .post-archives .results-list .item-overlay .item-overlay__terms, .search-results .results-list .item-overlay .item-overlay__terms {
      clear: both;
      display: block;
      font-size: 18px;
      font-weight: bold; }
    @media (max-width: 767px) {
      .post-archives .items-list .item-overlay .item-overlay__terms, .search-results .items-list .item-overlay .item-overlay__terms, .post-archives .results-list .item-overlay .item-overlay__terms, .search-results .results-list .item-overlay .item-overlay__terms {
        font-size: 14px; } }
  .post-archives .post-navigation, .search-results .post-navigation {
    padding: 30px 0; }
  .post-archives .search, .search-results .search {
    padding: 0;
    background: none; }
  .post-archives .search .search-form, .search-results .search .search-form {
    margin: 0;
    text-align: left; }
  .post-archives .search .centered, .search-results .search .centered {
    justify-content: center; }
    .post-archives .search .centered .col-lg, .search-results .search .centered .col-lg {
      flex-grow: 0; }
  .post-archives .search .input, .search-results .search .input {
    padding: 20px 0; }
    .post-archives .search .input .select-style, .search-results .search .input .select-style {
      width: 100%;
      border: 1px solid #000; }
  .post-archives .search .submit-btn, .search-results .search .submit-btn {
    text-align: center;
    margin: 30px 0 20px; }
  .post-archives .search .custom-checkbox, .search-results .search .custom-checkbox {
    white-space: nowrap; }

.post-archives a[data-toggle="collapse"] .search-icon__open {
  display: none; }
  .post-archives a[data-toggle="collapse"] .search-icon__close {
    display: inline-block; }
  .post-archives a[data-toggle="collapse"].collapsed .search-icon__open {
    display: inline-block; }
    .post-archives a[data-toggle="collapse"].collapsed .search-icon__close {
      display: none; }

.show-featured-image {
  position: relative;
  max-width: 888px;
  margin: 0 auto; }
  .show-featured-image .watch-trailer {
    position: absolute;
    bottom: 30px;
    right: 30px; }
  @media (max-width: 767px) {
    .show-featured-image .watch-trailer {
      left: 0;
      right: 0;
      width: 60%;
      margin-left: auto;
      margin-right: auto;
      bottom: 70px; } }
  .show-featured-image .img-slider-container {
    position: relative;
    max-height: 500px;
    margin-bottom: 25px; }
  .show-featured-image .img-slider-container .slick-slider {
    max-height: 500px; }
  .show-featured-image .img-slider-container .slide-item .slide-item-inner {
    position: relative;
    text-align: center; }
    .show-featured-image .img-slider-container .slide-item .slide-item-inner img {
      max-height: 500px;
      height: auto;
      width: auto;
      margin: 0 auto; }
  .show-featured-image .img-slider-container .prev-arrow, .show-featured-image .img-slider-container .next-arrow {
    position: absolute;
    top: calc(50% - 35px);
    right: 45px;
    cursor: pointer;
    width: 70px;
    height: 70px;
    border-radius: 50%;
    background: rgba(101, 107, 111, 0.5);
    display: flex;
    align-items: center;
    justify-content: center; }
    .show-featured-image .img-slider-container .prev-arrow.prev-arrow, .show-featured-image .img-slider-container .next-arrow.prev-arrow {
      right: auto;
      left: 45px; }
    .show-featured-image .img-slider-container .prev-arrow:hover, .show-featured-image .img-slider-container .next-arrow:hover {
      background: rgba(101, 107, 111, 1); }
    @media (max-width: 767px) {
    .show-featured-image .img-slider-container .prev-arrow, .show-featured-image .img-slider-container .next-arrow {
      display: none !important; } }
  .show-featured-image .img-slider-container .slick-dots {
    text-align: center;
    position: absolute;
    z-index: 99;
    height: 30px;
    bottom: 0px;
    left: 0px;
    right: 0px; }
  @media (max-width: 767px) {
    .show-featured-image .img-slider-container {
      margin-right: -15px;
      margin-left: -15px;
      max-height: none; }
      .show-featured-image .img-slider-container .slick-slider {
        max-height: none; }
        .show-featured-image .img-slider-container .slick-slider .slide-item-inner {
          height: auto;
          display: flex;
          align-items: center;
          justify-content: center; }
          .show-featured-image .img-slider-container .slick-slider .slide-item-inner img {
            max-height: 300px;
            width: auto; } }

.show-details {
  align-items: center;
  column-gap: 5px;
  display: flex;
  flex-flow: row wrap;
  overflow: hidden;
  place-content: space-around;
  position: relative;
  row-gap: 20px;
  text-align: center;
  word-break: break-word; }
  @media (max-width: 767px) {
  .show-details {
    padding-bottom: 95px; } }
  @media (max-width: 1024px) {
  .show-details {
    flex-flow: column wrap; } }
  .show-details h1 {
    flex: 1 calc(100% - 8rem);
    font-size: 28px;
    margin: 20px auto 10px;
    max-width: 800px;
    padding: 0;
    line-height: 1.1em; }
  @media (min-width: 767px) {
    .show-details h1 {
      font-size: 36px;
      padding: 0 100px; } }
  .show-details h4 {
    font-style: italic; }
  .show-details ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    flex: 1 100%;
    justify-content: center; }
  .show-details ul li {
    font-size: 14px;
    font-weight: bold;
    text-transform: uppercase; }
    .show-details ul li:not(:last-child):after {
      content: '|';
      padding: 0 10px; }
  .show-details .share-buttons {
    position: absolute;
    left: 0;
    top: 0px; }
  @media (max-width: 767px) {
    .show-details .share-buttons {
      bottom: 0;
      top: auto; } }

.show-description {
  text-align: left;
  margin: 50px 0; }
  @media (max-width: 767px) {
  .show-description {
    margin-top: 20px; } }
  .show-description .row {
    justify-content: space-between; }
  .show-description .date-times {
    background: rgba(216, 216, 216, 0.3);
    padding: 25px 40px 10px;
    margin-bottom: 40px; }
  .show-description .date-times .date-times__section-title {
    font-size: 16px;
    text-transform: uppercase; }
    @media (max-width: 767px) {
    .show-description .date-times .date-times__section-title {
      font-size: 14px; } }
  .show-description .date-times .date-times__venue-title {
    font-size: 14px;
    text-transform: none; }
    @media (max-width: 767px) {
    .show-description .date-times .date-times__venue-title {
      font-size: 12px; } }
  .show-description .date-times hr {
    margin: initial; }
  .show-description .date-times h5.related-title {
    font-weight: bold;
    font-size: 14px;
    margin: 10px 0; }
  .show-description .date-times .showing {
    justify-content: space-between;
    margin-bottom: 20px; }
    .show-description .date-times .showing .showing-details p {
      padding-right: 15px;
      font-size: 14px;
      line-height: 1.4;
      margin-bottom: 5px; }
    .show-description .date-times .showing .showing-details h6 {
      margin-bottom: 0px;
      text-transform: none;
      font-size: 14px;
      padding-right: 10px; }
    .show-description .date-times .showing .buy-tickets {
      text-align: center; }
    .show-description .date-times .showing .buy-tickets .buy-tickets-dropdown {
      min-width: 100%; }
    .show-description .date-times .showing .buy-tickets .button.dropdown-toggle {
      line-height: 1.2em;
      font-size: 10px;
      width: 80px;
      padding: 10px;
      height: 45px;
      letter-spacing: 0.1em; }
    .show-description .date-times .showing .buy-tickets .dropdown-menu {
      min-width: 0px;
      width: 100%; }
      .show-description .date-times .showing .buy-tickets .dropdown-menu .add-to-cart {
        font-size: 11px;
        height: 30px;
        line-height: 28px; }
    .show-description .date-times .showing .buy-ticket-external {
      width: 100%;
      min-width: 0px; }
  .show-description .date-times .past-showtimes {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    .show-description .date-times .past-showtimes .showing {
      margin: 5px 0;
      width: 50%; }
  .show-description .credits {
    margin: 30px 0; }
  .show-description .credits ul {
    display: table;
    margin: 10px 0 0;
    padding: 0;
    list-style: none; }
    .show-description .credits ul li {
      display: table-row; }
    .show-description .credits ul li span {
      display: table-cell; }
      .show-description .credits ul li span.label {
        font-weight: bold;
        padding-right: 15px; }

.show-single {
  text-align: center; }
  .show-single .directed-by {
    display: inline-block;
    flex: 1 100%;
    font-size: 18px;
    line-height: 1.2;
    margin-bottom: 0; }
  @media (max-width: 767px) {
    .show-single .directed-by {
      font-size: 14px; } }
  .show-single p.cast {
    flex: 1 100%;
    margin-bottom: 0; }
  .show-single .sections {
    padding: 30px 0 50px;
    border-top: 1px solid #979797; }
  .show-single .sections h3 {
    color: #000; }
  .show-single .sections .view-all {
    text-align: right; }
  .show-single img.wp-post-image {
    max-height: 500px;
    width: auto; }
  .show-single .sponsor img.wp-post-image {
    max-width: 60%;
    height: auto;
    display: block;
    margin: 30px auto; }

body.page-template-show-listing .post-archives > h1 {
  font-size: 28px;
  line-height: 1.2;
  margin-bottom: 0.5rem;
  margin-top: 0; }
  @media (max-width: 767px) {
      body.page-template-show-listing .post-archives > h1 {
        font-size: 32px; } }

.venue-single .item > img, .venue-archives .item > img {
  margin-bottom: 0.5rem; }
  .venue-single .item__title, .venue-archives .item__title {
    font-size: 20px; }
  @media (max-width: 767px) {
    .venue-single .item__title, .venue-archives .item__title {
      font-size: 18px; } }
  .venue-single .venue-term-content, .venue-archives .venue-term-content {
    margin: 20px auto 50px;
    padding: 0 30px;
    position: relative; }
  @media (max-width: 767px) {
    .venue-single .venue-term-content, .venue-archives .venue-term-content {
      padding: 0; } }
  @media (max-width: 768px) {
      .venue-single .venue-term-content .single-entry-content, .venue-archives .venue-term-content .single-entry-content {
        position: relative;
        padding-bottom: 85px; } }
  .venue-single .venue-term-content .address, .venue-archives .venue-term-content .address {
    display: inline-block;
    font-size: 18px;
    margin-bottom: 0.5rem;
    text-align: center;
    width: 100%; }
  @media (max-width: 767px) {
      .venue-single .venue-term-content .address, .venue-archives .venue-term-content .address {
        font-size: 14px; } }

.guide-date {
  margin-bottom: 40px; }

.guide-show {
  margin-bottom: 20px; }

.sponsors {
  padding: 100px 0;
  text-align: center; }
  .sponsors .sponsors-title, .sponsors .sponsor-level {
    margin: 30px 0 20px; }
  .sponsors .sponsor-level {
    font-size: 24px; }
  @media (max-width: 767px) {
    .sponsors .sponsor-level {
      font-size: 24px; } }
  .sponsors ul {
    list-style: none;
    margin: 20px 0 60px 0;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    background: rgba(216, 216, 216, 0.3); }
  .sponsors ul li {
    margin: 0 25px; }
  .sponsors ul li a {
    background: none; }
  .sponsors ul li a:after {
    display: none; }
  .sponsors ul li img {
    max-height: 80px;
    margin: 20px;
    height: auto;
    width: auto; }

.sponsored-by__container h3 {
  font-size: 20px; }
  @media (max-width: 767px) {
    .sponsored-by__container h3 {
      font-size: 18px; } }

.blog-single .blog-post-content, .blog-archive .blog-post-content {
  max-width: 800px;
  margin: 20px auto 50px;
  padding: 0 30px;
  position: relative; }
  @media (max-width: 767px) {
    .blog-single .blog-post-content, .blog-archive .blog-post-content {
      padding: 0; } }
  @media (max-width: 768px) {
      .blog-single .blog-post-content .single-entry-content, .blog-archive .blog-post-content .single-entry-content {
        position: relative;
        padding-bottom: 85px; } }
  .blog-single .blog-post-content h5.category, .blog-archive .blog-post-content h5.category {
    text-align: center;
    letter-spacing: 0.1em;
    text-transform: uppercase; }
  .blog-single .blog-post-content h2, .blog-archive .blog-post-content h2 {
    margin: 20px 0 30px;
    line-height: 1.1em;
    text-align: center; }
  .blog-single .blog-post-content h6.date, .blog-archive .blog-post-content h6.date {
    margin: 0 0 15px; }
  .blog-single .blog-post-content .img-holder, .blog-archive .blog-post-content .img-holder {
    margin: 0 0 20px; }
  .blog-single .blog-post-content .img-holder img, .blog-archive .blog-post-content .img-holder img {
    width: 100%; }
  .blog-single .blog-post-content .img-holder .caption, .blog-archive .blog-post-content .img-holder .caption {
    margin: 5px 0 0;
    color: rgba(60, 61, 65, 0.7);
    font-size: 12px; }
  .blog-single .blog-post-content .share-buttons, .blog-archive .blog-post-content .share-buttons {
    position: absolute;
    right: 100%;
    margin: 10px 30px 0 0; }
  @media (max-width: 768px) {
      .blog-single .blog-post-content .share-buttons, .blog-archive .blog-post-content .share-buttons {
        right: auto;
        bottom: 0; } }
  .blog-single .news-teasers, .blog-archive .news-teasers {
    border-top: 1px solid #39b54a;
    margin: 40px -30px 0;
    padding: 40px 0 0; }
  @media (max-width: 767px) {
    .blog-single .news-teasers, .blog-archive .news-teasers {
      margin: 40px -15px 0; } }
  .blog-single .news-teasers h3.news-header, .blog-archive .news-teasers h3.news-header {
    text-transform: uppercase;
    text-align: center; }
  .blog-single .news-teasers .post-teaser, .blog-archive .news-teasers .post-teaser {
    padding: 30px 0;
    margin: 0; }
  .blog-single .news-teasers .post-teaser:not(:last-child), .blog-archive .news-teasers .post-teaser:not(:last-child) {
    border-bottom: 1px solid #39b54a; }
  @media (min-width: 768px) {
      .blog-single .news-teasers .post-teaser > div:first-child, .blog-archive .news-teasers .post-teaser > div:first-child {
        padding-left: 0; }
        .blog-single .news-teasers .post-teaser > div:last-child, .blog-archive .news-teasers .post-teaser > div:last-child {
          padding-right: 0; } }
  .blog-single .news-teasers .post-teaser h3 a, .blog-archive .news-teasers .post-teaser h3 a {
    text-decoration: none; }
  .blog-single .news-teasers .post-teaser p, .blog-archive .news-teasers .post-teaser p {
    color: inherit; }
  @media (max-width: 767px) {
      .blog-single .news-teasers .post-teaser img, .blog-archive .news-teasers .post-teaser img {
        margin-bottom: 20px; } }

.blog-archive .blog-post-content {
  padding: 0; }
  .blog-archive .blog-post-content .news-teasers {
    border-top: none;
    margin: 40px 0 0;
    padding: 0; }
  .blog-archive .blog-post-content .news-teasers .post-teaser .category {
    font-size: 16px;
    text-transform: uppercase; }
  .blog-archive .blog-post-content h2 {
    text-align: center;
    margin: 0 0 30px; }

.post-navigation {
  padding: 60px 0;
  display: flex;
  justify-content: space-between; }

.page-template-cart .floating-cart {
  display: none; }

.cart-checkout {
  padding-bottom: 50px; }
  .cart-checkout .cart__title {
    font-size: 24px;
    text-transform: uppercase;
    margin: 0;
    padding: 20px 0;
    text-align: center; }
  @media (max-width: 767px) {
    .cart-checkout .cart__title {
      font-size: 24px; } }
  .cart-checkout .success-header {
    padding: 50px 0 0 0; }
  .cart-checkout .success-header h1 {
    font-size: 28px;
    margin-bottom: 0.5em;
    margin-top: 0; }
  @media (max-width: 767px) {
      .cart-checkout .success-header h1 {
        font-size: 32px; } }
  .cart-checkout .success-header h3 {
    font-size: 20px; }
  @media (max-width: 767px) {
      .cart-checkout .success-header h3 {
        font-size: 18px; } }
  .cart-checkout .order-id {
    font-size: 24px;
    letter-spacing: normal;
    text-transform: none;
    padding-top: 0;
    text-align: left; }
  @media (max-width: 767px) {
    .cart-checkout .order-id {
      font-size: 24px; } }

.cart__title {
  font-size: 24px;
  text-transform: uppercase;
  margin: 0;
  padding: 20px 0;
  text-align: center; }
  @media (max-width: 767px) {
  .cart__title {
    font-size: 24px; } }

.checkout__title {
  font-size: 24px;
  margin: 0;
  padding: 20px 0;
  text-align: center;
  text-transform: uppercase; }
  @media (max-width: 767px) {
  .checkout__title {
    font-size: 24px; } }

.cart[data-ticket_pack_offer] .cart-item__title {
  text-align: center; }

.required-description {
  clear: both;
  display: block;
  font-weight: 400;
  margin: 0 !important;
  padding: 0 0 1em 0;
  text-align: center;
  width: 100%; }

body.filmbot-live--active .cart-checkout .order-id {
  display: none; }
  body.filmbot-live--active h3.confirmed {
    text-transform: none;
    text-align: left; }

@media (min-width: 1201px) {
    .cart {
      padding-right: 25px; } }
  .cart .cart-row {
    position: relative;
    margin-bottom: 30px; }
  .cart .cart-row .film-img img.wp-post-image {
    margin-top: 0; }
  .cart .cart-row .showing-details .cart-row__title {
    font-size: 20px;
    letter-spacing: normal; }
  .cart .cart-row .showing-details .cart-row__title a {
    text-decoration: none; }
  @media (max-width: 767px) {
        .cart .cart-row .showing-details .cart-row__title {
          font-size: 18px; } }
  .cart .cart-row .tickets .ticket-type {
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    padding-bottom: 25px;
    margin-bottom: 25px; }
  .cart .cart-row .tickets .ticket-type label {
    font-size: 14px;
    font-weight: 500; }
  .cart .cart-row .tickets .ticket-quantity {
    min-width: 55px;
    margin-left: 5px; }
  .cart .cart-row .tickets .remove-ticket_type-btn {
    position: absolute;
    right: 0;
    bottom: 0;
    text-transform: uppercase;
    font-size: 11px;
    text-decoration: none;
    font-weight: bold; }
  .cart .cart-row.discount-code input[type=text] {
    width: 100%;
    border: 1px solid #3c3d41;
    margin-right: 10px; }
  @media (max-width: 768px) {
        .cart .cart-row.discount-code input[type=text] {
          margin-bottom: 10px; } }
  .cart .cart-row.discount-code button {
    width: 100%;
    height: 45px; }
  .cart .cart-row.discount-code button.applied {
    padding: 0; }

.checkout {
  background-color: rgba(101, 107, 111, 0.3); }
  .checkout .checkout-rows {
    padding: 0 50px 50px; }
  .checkout .checkout-rows .row {
    margin-bottom: 30px; }
  @media (max-width: 480px) {
    .checkout .checkout-rows {
      padding: 0 20px 20px; } }
  .checkout .payment-address {
    width: 100%;
    position: relative;
    margin: 0 0 20px; }
  .checkout .payment-address input {
    font-size: 14px;
    width: 100%; }
  .checkout .payment-address input:not(:last-child) {
    margin-right: 20px; }
  .checkout .submit-row {
    text-align: center; }
  @media (max-width: 480px) {
  .checkout .checkout-rows .row {
    margin-bottom: 15px; }
  .checkout .name-fields .col {
    flex-basis: auto; }
    .checkout .name-fields .col:first-of-type {
      margin-bottom: 15px; }
  .checkout .name-fields .row {
    flex-flow: column nowrap; } }

.checkout__address-header {
  font-size: 18px; }
  @media (max-width: 767px) {
  .checkout__address-header {
    font-size: 14px; } }

.checkout .cart-error, .cart .cart-error {
  display: none;
  border-radius: 0; }
  .checkout .error-message, .cart .error-message {
    width: 100%;
    color: #a42325; }
  .checkout .error-message ul, .cart .error-message ul {
    margin-left: 0;
    padding: 0 0 0 1rem; }
  .checkout .ticket-totals, .cart .ticket-totals {
    border-top: 1px solid #3c3d41; }
  .checkout .ticket-totals .ticket-total-row, .cart .ticket-totals .ticket-total-row {
    width: 100%;
    display: flex;
    justify-content: space-between;
    font-size: 18px;
    font-weight: bold;
    margin: 20px 0; }
  @media (max-width: 767px) {
      .checkout .ticket-totals .ticket-total-row, .cart .ticket-totals .ticket-total-row {
        font-size: 14px; } }
  .checkout .ticket-totals .ticket-total-row .label, .cart .ticket-totals .ticket-total-row .label {
    text-transform: uppercase; }
  .checkout .ticket-totals .ticket-total-row .data, .cart .ticket-totals .ticket-total-row .data {
    text-align: right; }
  .checkout .custom-checkbox input, .cart .custom-checkbox input {
    opacity: 0 !important; }
  .checkout .custom-checkbox input.error ~ .error-message, .cart .custom-checkbox input.error ~ .error-message {
    display: block; }
  .checkout .custom-checkbox .checkbox, .cart .custom-checkbox .checkbox {
    top: -3px; }
  .checkout .submit, .cart .submit {
    margin-top: 1rem; }

.single-ticket_pack_offer .floating-cart {
  display: none; }

.single-rental_pass_offer .cart h1 {
  font-size: 24px; }
  @media (max-width: 767px) {
    .single-rental_pass_offer .cart h1 {
      font-size: 24px; } }
  .single-rental_pass_offer .checkout h2 {
    font-size: 24px;
    margin: 0 0 0.67em 0;
    padding: 0.67em 0 0 0;
    text-align: center; }
  @media (max-width: 767px) {
    .single-rental_pass_offer .checkout h2 {
      font-size: 24px; } }
  .single-rental_pass_offer .checkout h3 {
    font-size: 18px; }
  @media (max-width: 767px) {
    .single-rental_pass_offer .checkout h3 {
      font-size: 14px; } }
  .single-rental_pass_offer .success-header h1.page__title {
    font-size: 28px;
    text-align: left; }
  @media (max-width: 767px) {
    .single-rental_pass_offer .success-header h1.page__title {
      font-size: 32px; } }
  .single-rental_pass_offer .success-header + h2 {
    font-size: 24px; }
  @media (max-width: 767px) {
    .single-rental_pass_offer .success-header + h2 {
      font-size: 24px; } }
/**
 * Donation checkbox on checkout.
 */
.addition-donation {
  height: auto;
  min-height: 30px; }
  .addition-donation input[type=checkbox] {
    position: absolute;
    z-index: -1;
    opacity: 0; }
  .addition-donation label {
    display: block;
    position: relative;
    line-height: 1.5em; }
  .addition-donation .checkbox-indicator {
    position: absolute;
    top: 5px;
    left: 0;
    width: 30px;
    height: 30px;
    border: 2px solid #3c3d41;
    cursor: pointer; }
  .addition-donation .checkbox-indicator:after {
    content: '';
    left: 9px;
    top: 4px;
    width: 8px;
    height: 16px;
    border: solid #fff;
    border-width: 0 3px 3px 0;
    transform: rotate(45deg);
    position: absolute;
    visibility: hidden; }
  .addition-donation input:checked ~ .checkbox-indicator {
    background: #3c3d41; }
  .addition-donation input:checked ~ .checkbox-indicator:after {
    visibility: visible; }
/**
 * Memberships Cart
 */
.cart-membership-checkout .cart-membership-details input[type=text], .cart-membership-checkout .cart-membership-details input[type=email] {
  border: 1px solid #3c3d41;
  width: 100%; }
  .cart-membership-checkout .cart-membership-details select {
    font-size: 14px;
    padding: 10px 15px; }
  .cart-membership-checkout .cart-membership-details .row {
    margin-bottom: 1em; }
  .cart-membership-checkout .membership-birthday-field-group select {
    width: 100%; }
  .cart-membership-checkout .membership-signup-step .select-type {
    text-align: center; }
  .cart-membership-checkout .cart-membership-title {
    text-align: center; }
  .cart-membership-checkout input#member_email {
    margin-top: 0.35em; }
  .cart-membership-checkout select#country, .cart-membership-checkout select#state, .cart-membership-checkout input#mailing_postal_code {
    width: inherit; }
  .cart-membership-checkout .membership--hide-if-type-single {
    display: none; }
  .cart-membership-checkout.cart-membership-checkout--type-dual .membership--hide-if-type-single {
    display: block; }

.cart-membership-payment-details {
  z-index: 10; }

#user-interests.row {
  margin-bottom: 0; }
  #user-interests.row .col-12:last-of-type label {
    margin-bottom: 0; }

#membership-select-type .plan-type-inline:first-of-type {
  margin-right: 1em; }

.schedule-page {
  padding: 10px 0; }
  @media (min-width: 480px) {
  .schedule-page {
    padding: 50px 0; } }
  .schedule-page h1 {
    font-size: 28px;
    text-align: center;
    margin: 0 0 10px; }
  @media (min-width: 480px) {
    .schedule-page h1 {
      margin: 0 0 50px; } }
  @media (max-width: 767px) {
    .schedule-page h1 {
      font-size: 32px; } }
  .schedule-page .schedule-filters {
    padding: 10px 20px; }
  @media (min-width: 480px) {
    .schedule-page .schedule-filters {
      padding: 25px 20px 10px; } }
  .schedule-page .schedule-filters .filters-row .input {
    margin: 0 0 20px; }
  .schedule-page .schedule-filters .filters-row select {
    width: 200px;
    width: 100%;
    font-size: 14px; }
  .schedule-page .schedule-list .date-row {
    margin: 40px 0 30px; }
  .schedule-page .schedule-list .date-row h2 {
    font-size: 20px; }
  .schedule-page .schedule-list .date-row:first-of-type {
    margin-top: 10px; }
  @media (min-width: 480px) {
        .schedule-page .schedule-list .date-row:first-of-type {
          margin-top: 40px; } }
  .schedule-page .schedule-list .time-length {
    font-size: 18px; }
  @media (max-width: 767px) {
      .schedule-page .schedule-list .time-length {
        font-size: 14px; } }
  .schedule-page .schedule-list .event-row {
    padding: 35px 40px;
    margin-bottom: 30px;
    width: 100%;
    background: rgba(216, 216, 216, 0.3);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap; }
  .schedule-page .schedule-list .event-row a {
    text-decoration: none; }
  .schedule-page .schedule-list .event-row a:hover, .schedule-page .schedule-list .event-row a:active {
    background: linear-gradient(#353535, #353535) 0 100%/100% 2px no-repeat; }
  .schedule-page .schedule-list .event-row .event-info {
    max-width: 25%; }
  .schedule-page .schedule-list .event-row .event-section .film-title {
    font-size: 24px; }
    .schedule-page .schedule-list .event-row .event-section .film-title .original-title {
      font-size: 80%;
      display: block; }
  .schedule-page .schedule-list .event-row .section {
    margin: 0;
    font-weight: normal; }
  .schedule-page .schedule-list .event-row a.watch-trailer {
    margin-top: 6px;
    color: #39b54a;
    border-color: #39b54a; }
  .schedule-page .schedule-list .event-row a.watch-trailer:hover, .schedule-page .schedule-list .event-row a.watch-trailer:focus-visible {
    background-color: #39b54a;
    color: #fff;
    border-radius: 0;
    outline: none;
    box-shadow: none; }
  .schedule-page .schedule-list .event-row .buttons {
    justify-content: flex-end;
    display: flex;
    align-items: center; }
  .schedule-page .schedule-list .event-row .buttons .text-no-tickets {
    min-width: 200px;
    font-weight: bold;
    text-align: center; }
  .schedule-page .schedule-list .event-row .buttons .buy-tickets-dropdown {
    padding-right: 20px; }
  .schedule-page .schedule-list .event-row .buttons .add-to-itinerary {
    display: flex;
    align-items: center;
    margin: 0; }
    .schedule-page .schedule-list .event-row .buttons .add-to-itinerary .heart-border {
      fill: #39b54a; }
    .schedule-page .schedule-list .event-row .buttons .add-to-itinerary .heart-fill {
      fill: transparent; }
    .schedule-page .schedule-list .event-row .buttons .add-to-itinerary:hover .heart-border, .schedule-page .schedule-list .event-row .buttons .add-to-itinerary.saved .heart-border {
      fill: transparent; }
      .schedule-page .schedule-list .event-row .buttons .add-to-itinerary:hover .heart-fill, .schedule-page .schedule-list .event-row .buttons .add-to-itinerary.saved .heart-fill {
        fill: #39b54a; }
  @media (max-width: 1023px) {
      .schedule-page .schedule-list .event-row .event-col {
        width: 100%;
        max-width: 100%;
        text-align: center; }
        .schedule-page .schedule-list .event-row .event-col:not(:last-child) {
          margin-bottom: 15px; }
        .schedule-page .schedule-list .event-row .event-col.buttons {
          justify-content: center; } }
/*
 * Player elements.
 */
.watch__title {
  margin-top: 1.5em !important;
  text-align: center; }

.watch__showtime-date {
  font-size: 1.75em;
  text-align: center; }

.watch-player__cta--small, .fl-player__cta--small {
  margin-top: 1em; }

.fl-player__code-input {
  border-radius: 0.25em !important; }

.fl-player__code-button {
  line-height: 1; }

.fl-player__code-confirm {
  line-height: 1 !important; }

body.filmbot-live--watch h4.directed-by {
  font-style: normal; }

body.filmbot-live--watch .show-description {
  margin-top: 2em !important; }
/*
 * Cutomization override allowances.
 *
 * Use of !important is to override styles found in filmbot-live dist.js bundle.
 */
.watch__title {
  color: #3c3d41 !important;
  font-family: Montserrat !important;
  font-size: 36px !important; }

.watch__showtime-date {
  color: #3c3d41 !important;
  font-family: Montserrat !important;
  font-size: 24px !important; }

.fl-countdown {
  color: #3c3d41 !important;
  font-family: Montserrat !important; }

.fl-player__info, .fl-player__info--small, .fl-player__cta--small {
  color: #fff !important;
  font-family: Montserrat !important; }

.fl-player__view-count {
  color: #fff !important;
  font-family: Montserrat !important; }
  .fl-player__view-count:first-of-type {
    color: #3c3d41 !important;
    text-align: center;
    width: 100%; }

.fl-player__ended .fl-player__info {
  color: #3c3d41 !important;
  font-family: Montserrat !important; }

.fl-player__code-button {
  background: #39b54a !important;
  color: #fff !important; }
  .fl-player__code-button:hover {
    background: #57ca67 !important;
    color: #fff !important; }

.fl-player__code-input {
  background: #656b6f !important;
  color: #fff !important; }

.fl-player.fl-player--auth-confirm .fl-player__confirm {
  background: #656b6f !important;
  color: #fff !important;
  font-family: Montserrat !important; }
  .fl-player.fl-player--auth-confirm .fl-player__confirm a, .fl-player.fl-player--auth-confirm .fl-player__confirm a:link, .fl-player.fl-player--auth-confirm .fl-player__confirm a:hover, .fl-player.fl-player--auth-confirm .fl-player__confirm a:visited {
    color: #fff !important;
    text-decoration: underline; }
  .fl-player.fl-player--auth-confirm .fl-player__confirm .mobile-only {
    display: none; }
  @media screen and (max-width: 1024px) {
    .fl-player.fl-player--auth-confirm .fl-player__confirm .mobile-only {
      display: initial; } }
  @media screen and (max-width: 1024px) {
    .fl-player.fl-player--auth-confirm .fl-player__confirm .desktop-only {
      display: none; } }

.fl-player__code-confirm {
  background: #000 !important;
  color: #fff !important; }
  .fl-player__code-confirm:hover {
    background: #1a1a1a !important;
    color: #fff !important; }

.fl-player.fl-player--ended {
  background: #000 !important; }
  .fl-player.fl-player--ended .fl-player__info {
    color: #fff !important; }

@media screen and (max-width: 768px) {
  body.filmbot-live--watch .show-description {
    margin-top: 0 !important; }
    body.filmbot-live--watch .show-details {
      padding-bottom: 1em !important; } }
/*
 * Q & A Submission Form
 */
#fl-qa {
  margin-top: 2.5em; }

.fl-qa__resubmit {
  display: inline-block;
  margin-top: 0.5em; }

.fl-qa--instructions p {
  font-size: 1.15em; }

.fl-qa__field {
  margin: 0 0 2em 0; }
  .fl-qa__field label {
    font-size: 1.15em;
    height: auto !important;
    margin-bottom: 0; }
  .fl-qa__field input {
    background: none;
    border: 0 none;
    border-bottom: 1px solid #3c3d41;
    border-radius: 0;
    color: #3c3d41;
    font-size: 1.15em;
    height: auto !important;
    padding: 0; }
  .fl-qa__field textarea {
    background: none;
    border: 1px solid #3c3d41;
    border-radius: 0;
    color: #3c3d41;
    font-size: 1.15em;
    height: auto !important;
    line-height: 1.5;
    width: 100% !important;
    padding: 10px; }

.fl-qa__error {
  color: #3c3d41;
  font-size: 1.15em;
  margin-top: 1em;
  text-align: center; }

.fl-qa__thank-you {
  font-size: 1.25em;
  margin-top: 1em; }

.fl-qa__resubmit {
  background: #39b54a !important;
  border-radius: 0;
  color: #fff !important;
  cursor: pointer !important;
  font-size: 1.25em;
  padding: 0.5em 1em; }
  .fl-qa__resubmit:hover {
    background: #57ca67 !important;
    color: #fff !important;
    cursor: pointer !important; }

.fl-qa--loading .fl-qa__spinner {
  border-color: #39b54a !important;
  border-top-color: #fff !important; }

@media screen and (min-width: 992px) {
  .fl-qa__form {
    margin: 0 auto;
    width: 80%; } }
/**
 * Geoblocked notice.
 */
.show-geoblocked-notice {
  padding: 1em;
  text-align: center;
  width: 100%; }
/*
 * Rental pass template.
 */
h2.rental-pass__passholder {
  font-size: 16px;
  font-weight: normal;
  line-height: 1.5;
  margin-bottom: 1.5em; }
/*
 * Player elements.
 */
.show-details h1.rental__title {
  margin-bottom: 0;
  max-width: 100%;
  position: relative;
  text-align: center;
  width: 100%; }
  @media (min-width: 1024px) {
  .show-details h1.rental__title {
    margin: 20px -8rem 30px auto;
    padding: 0 8rem; } }

body.fl-rental--watch .show-details {
  margin-top: 25px; }
  @media (min-width: 767px) {
    body.fl-rental--watch .show-details {
      margin-top: 50px; } }
  body.fl-rental--watch .fl-player {
    margin-bottom: 2em; }
  body.fl-rental--watch .rental__directed-by {
    font-size: 20px;
    font-style: normal;
    font-weight: bold;
    margin: 1em 0 20px; }
  @media (max-width: 767px) {
    body.fl-rental--watch .rental__directed-by {
      font-size: 18px; } }
  body.fl-rental--watch .rental__original-title {
    font-size: 20px;
    font-style: italic;
    margin: 10px 0 20px; }
  @media (max-width: 767px) {
    body.fl-rental--watch .rental__original-title {
      font-size: 18px; } }
  body.fl-rental--watch .show-description {
    margin-top: 2em !important; }
  body.fl-rental--watch .watch-trailer {
    flex: 1 100%;
    height: 100%;
    line-height: 25px;
    max-height: calc(25px + 2em);
    max-width: 100%;
    width: 100%; }
  @media (min-width: 768px) {
    body.fl-rental--watch .watch-trailer {
      flex: 1 8rem;
      max-width: 8rem; } }
  body.fl-rental--watch .rental__watch-window {
    flex: 1 100%;
    font-size: 20px;
    font-style: normal;
    font-weight: bold;
    margin: 0; }
  @media (max-width: 767px) {
    body.fl-rental--watch .rental__watch-window {
      font-size: 18px; } }

.rental__geoblocked-message {
  padding: 2em 1em;
  text-align: center;
  width: 100%; }

.rental__watch-window-no-player {
  background: #000;
  color: #fff;
  line-height: 1;
  margin-bottom: 1.5em;
  padding: calc(28.125% - 27px) 1em;
  text-align: center;
  width: 100%; }

@media screen and (max-width: 768px) {
  body.fl-rental--watch .show-description {
    margin-top: 0 !important; }
    body.fl-rental--watch .show-details {
      padding-bottom: 1em !important; } }
/*
 * Rental watch window
 */
.filmbot-live-rental-watch-window {
  color: #3c3d41; }
/*
 * The Rental Terms modal.
 */
#rental-terms-modal .modal-content, #rental-terms-modal .modal:not(.bootbox) .modal-content {
  background: #000;
  color: #fff; }

#rental-terms-modal .modal-body, #rental-terms-modal .modal:not(.bootbox) .modal-body {
  margin: 0 auto !important;
  max-width: 80em !important;
  padding: 2em; }
/*
 * Customization override allowances.
 *
 * Selectors and !important are to override general show-details styles, and some styles from filmbot-live.
 */
.show-details h1.rental__title {
  color: #3c3d41 !important;
  font-family: Montserrat !important;
  font-size: 28px; }
  @media (min-width: 767px) {
  .show-details h1.rental__title {
    font-size: 36px; } }

.rental-purchase-options .rental-purchase-button {
  width: 100%;
  text-align: center; }
