/* ============ ACME ============ */
/* colors */
/* breakpoints */
/* fonts */
/* type scale */
/* transitions */
/* _typography.scss */
@import url("https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500&family=Montserrat:ital,wght@0,400;0,700;1,400&display=swap");
@import url("https://use.typekit.net/ojw7qsb.css");
main {
  color: #052E21;
}

body,
button,
input,
select,
textarea,
p,
li {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.4rem, 1.4rem + 2 * (100vw - 360px) / 1080, 1.6rem);
  font-weight: normal;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  clear: both;
  margin: 0 0 0.8rem;
  overflow-wrap: normal;
  vertical-align: top;
}

h1 {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(4.3rem, 4.3rem + 47 * (100vw - 360px) / 1080, 9rem);
  font-weight: bold;
  line-height: 1.3;
  text-transform: uppercase;
}

h2 {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(3rem, 3rem + 20 * (100vw - 360px) / 1080, 5rem);
  font-weight: bold;
  line-height: 1.3;
  text-transform: uppercase;
}

h3 {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.4rem, 2.4rem + 13 * (100vw - 360px) / 1080, 3.7rem);
  font-weight: bold;
  line-height: 1.3;
  text-transform: uppercase;
}

h4 {
  font-family: "Montserrat", sans-serif;
  font-size: 2.2rem;
  font-weight: bold;
}

h5 {
  font-family: "Barlow Condensed", serif;
  font-size: clamp(1.9rem, 1.9rem + 4 * (100vw - 360px) / 1080, 2.3rem);
  font-weight: 500;
  letter-spacing: 0.05rem;
  text-transform: uppercase;
}

h6 {
  font-family: "Barlow Condensed", serif;
  font-size: clamp(1.6rem, 1.6rem + 4 * (100vw - 360px) / 1080, 2rem);
  font-weight: 500;
  letter-spacing: 0.05rem;
  text-transform: uppercase;
}

main p {
  color: #052E21;
  margin: 0 0 1.6rem 0;
}
main p:last-child {
  margin-bottom: 0;
}

ul, ol {
  padding-left: 2.4rem;
}
a {
  color: #1963B0;
  cursor: pointer;
  text-decoration: underline;
  transition: all 0.3s ease 0s;
}
a:hover {
  color: #0C2340;
}

hr {
  border: 1px solid #052E21;
  margin: 1.6rem 0;
}

.invert {
  color: #ffffff;
}
.invert *:not(.button):not(input) {
  color: #ffffff !important;
}
.invert a:not(.button):not(input):hover {
  color: #3CCBDA !important;
}

[data-elementor-type=header] p {
  font-weight: bold;
  font-size: 1rem;
}

[data-elementor-type=header] ul.sub-menu a {
  font-size: 1.3rem;
}

.goog-te-combo {
  padding: 0 0 0 8px;
  line-height: 1.4;
  min-height: 0;
}

.text-widget {
  margin-bottom: 1.6rem;
}

button {
  appearance: none;
  border: none;
  background: transparent;
  padding: 0;
}

.button {
  background-color: #3CCBDA;
  border: 1px solid #052E21;
  border-radius: 3px;
  color: #052E21 !important;
  cursor: pointer;
  display: table;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.2rem, 1.2rem + 2 * (100vw - 360px) / 1080, 1.4rem);
  font-weight: bold;
  letter-spacing: 0.025rem;
  line-height: 1.6;
  min-width: 10rem;
  overflow: hidden;
  padding: 1rem 2.8rem;
  position: relative;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  transition: background-color 0.25s ease;
  vertical-align: top;
  white-space: nowrap;
  width: auto;
  z-index: 1;
}
.button[disabled] {
  opacity: 0.5;
  pointer-events: none;
  user-select: none;
}
.button:hover {
  background-color: #00C389;
}
.button .fa {
  color: #052E21;
}
.button--blue {
  background-color: #1963B0;
  color: #ffffff;
}
.button--small {
  font-size: 1.2rem !important;
  padding: 0.4rem 0.8rem !important;
}
.button--stretch {
  width: 100%;
}
.button--icon-left .fa {
  margin-right: 0.8rem;
}
.button--icon-right .fa {
  margin-left: 0.8rem;
}
.button--error {
  border-color: #d94a40;
  color: #d94a40;
}
.button--success {
  border-color: #27985f;
  color: #27985f;
}
p .button, td .button {
  margin: 1.6rem 0 0;
}
.button + .button {
  margin-top: 1.6rem;
}

.link {
  background-color: transparent !important;
  border: none !important;
  color: #1963B0 !important;
  cursor: pointer;
  padding: 0 !important;
  text-decoration: underline;
  transition: all 0.3s ease 0s;
}
.link:hover {
  color: #0C2340;
}

/* _forms.scss */
/* Input Styles */
label {
  display: block;
  font-weight: bold;
  margin-bottom: 0.4rem;
}

input[type=text],
input[type=tel],
input[type=email],
input[type=url],
input[type=date],
input[type=number],
input[type=time],
select {
  background-color: #ffffff;
  border: 0.1rem solid #0C2340;
  border-radius: 0;
  color: #052E21;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.4rem, 1.4rem + 2 * (100vw - 360px) / 1080, 1.6rem);
  min-height: 3.2rem;
  line-height: 1.6;
  margin: 0 0 1.2rem;
  padding: 0 0.8rem;
  position: relative;
  transition: border-color 0.25s;
  width: 100%;
  width: 100%;
}
@media only screen and (min-width: 1024px) {
  input[type=text],
  input[type=tel],
  input[type=email],
  input[type=url],
  input[type=date],
  input[type=number],
  input[type=time],
  select {
    padding: 1.2rem;
  }
}
input[type=text]::placeholder,
input[type=tel]::placeholder,
input[type=email]::placeholder,
input[type=url]::placeholder,
input[type=date]::placeholder,
input[type=number]::placeholder,
input[type=time]::placeholder,
select::placeholder {
  color: rgba(12, 35, 64, 0.66);
}
input[type=text]:focus, input[type=text]:hover, input[type=text]:active,
input[type=tel]:focus,
input[type=tel]:hover,
input[type=tel]:active,
input[type=email]:focus,
input[type=email]:hover,
input[type=email]:active,
input[type=url]:focus,
input[type=url]:hover,
input[type=url]:active,
input[type=date]:focus,
input[type=date]:hover,
input[type=date]:active,
input[type=number]:focus,
input[type=number]:hover,
input[type=number]:active,
input[type=time]:focus,
input[type=time]:hover,
input[type=time]:active,
select:focus,
select:hover,
select:active {
  outline: none;
}
input[type=text].error,
input[type=tel].error,
input[type=email].error,
input[type=url].error,
input[type=date].error,
input[type=number].error,
input[type=time].error,
select.error {
  background-color: #fff6f6;
  border-color: #d94a40;
  color: #d94a40;
  font-weight: bold;
  outline: 1px solid #d94a40;
}
input[type=text].success,
input[type=tel].success,
input[type=email].success,
input[type=url].success,
input[type=date].success,
input[type=number].success,
input[type=time].success,
select.success {
  border-color: #27985f;
  color: #27985f;
}
input[type=text] + .button,
input[type=tel] + .button,
input[type=email] + .button,
input[type=url] + .button,
input[type=date] + .button,
input[type=number] + .button,
input[type=time] + .button,
select + .button {
  margin-top: 0.8rem;
}

select {
  margin-bottom: 0.8rem;
}

input[type=checkbox],
input[type=radio] {
  appearance: none;
  border: none !important;
  cursor: pointer;
  left: 0;
  height: 2rem;
  margin: 0;
  min-width: 2rem;
  position: relative;
  top: 0.3rem;
  width: 2rem;
}
input[type=checkbox]::before,
input[type=radio]::before {
  background-color: #ffffff;
  border: 0.1rem solid #0C2340;
  border-radius: 0;
  content: "";
  height: 100%;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: border-color 0.25s;
  width: 100%;
}
input[type=checkbox]:checked::before,
input[type=radio]:checked::before {
  background-color: #1963B0;
}
input[type=checkbox]:checked::after,
input[type=radio]:checked::after {
  display: block;
}
input[type=checkbox]:focus,
input[type=radio]:focus {
  box-shadow: 0 0 0.5rem #1963B0;
  outline: none;
}
input[type=checkbox]::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 60%;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 60%;
}
input[type=checkbox]::before {
  border-radius: 0.2rem;
}
input[type=checkbox]:checked::after {
  background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg width='220.15pt' height='174.3pt' version='1.1' viewBox='0 0 220.15 174.3' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform='translate(-239.92 -192.85)'%3E%3Cpath d='m428.4 192.85-15.926 15.75-97.125 97.125-29.051-25.375-16.801-14.699-29.574 33.773 16.977 14.699 44.801 39.199 15.75 13.824 142.62-142.62z' fill='%23fff'/%3E%3C/g%3E%3C/svg%3E");
}

input[type=radio] {
  border-radius: 50% !important;
}
input[type=radio]::before {
  border-radius: 50%;
}
input[type=radio]::after {
  background-color: #ffffff;
  border-radius: 50%;
  content: "";
  display: none;
  height: 45%;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 45%;
}

textarea {
  background-color: #ffffff;
  border: 0.1rem solid #0C2340;
  border-radius: 0;
  color: #052E21;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.4rem, 1.4rem + 2 * (100vw - 360px) / 1080, 1.6rem);
  min-height: 3.2rem;
  line-height: 1.6;
  margin: 0 0 1.2rem;
  padding: 0 0.8rem;
  position: relative;
  transition: border-color 0.25s;
  width: 100%;
  min-height: 12rem;
  width: 100%;
}
@media only screen and (min-width: 1024px) {
  textarea {
    padding: 1.2rem;
  }
}
textarea::placeholder {
  color: rgba(12, 35, 64, 0.66);
}
textarea:focus, textarea:hover, textarea:active {
  outline: none;
}
textarea.error {
  background-color: #fff6f6;
  border-color: #d94a40;
  color: #d94a40;
  font-weight: bold;
  outline: 1px solid #d94a40;
}
textarea.success {
  border-color: #27985f;
  color: #27985f;
}
textarea + .button {
  margin-top: 0.8rem;
}

.form-columns {
  display: grid;
  gap: 1.6rem;
  grid-template-columns: 1fr 1fr;
}

.fieldgroup {
  margin: 0 0 1.6rem;
}
.fieldgroup input,
.fieldgroup select,
.fieldgroup textarea {
  margin-bottom: 0;
}
.fieldgroup--checkbox {
  align-items: flex-start;
  display: flex;
  gap: 0 1.6rem;
}
.fieldgroup--checkbox label {
  margin-top: 0.2rem;
}
.fieldgroup--radio {
  display: flex;
  gap: 0 1.6rem;
}
.fieldgroup--columns {
  display: grid;
  gap: 0 1.6rem;
  grid-template-columns: 1fr 1fr;
}
.fieldgroup--columns label {
  grid-column: 1/-1;
}

fieldset {
  background-color: #1963B0;
  border: 1px solid #0C2340;
  color: #ffffff;
  margin-bottom: 2.4rem;
  padding: 2.4rem 3.2rem 1.6rem;
}

footer .elementor-form input[type=email] {
  font-size: 15px;
  line-height: 1.4;
  min-height: 40px;
  padding: 5px 14px;
}
footer .elementor-form button {
  margin-bottom: 12px;
}

/* _layout.scss */
main {
  overflow: visible !important;
}

#default-main {
  padding-top: 4rem;
  padding-bottom: 12rem;
}

/* _tickets.scss */
.page-template-page-tickets {
  background-color: #fffff7;
}
.page-template-page-tickets #default-banner {
  background: linear-gradient(#0C2340, #052E21);
  display: flex;
  flex-direction: column;
  height: 240px;
  justify-content: center;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
@media (min-width: 1024px) {
  .page-template-page-tickets #default-banner {
    height: 300px;
  }
}
.page-template-page-tickets #default-banner .banner-title {
  line-height: 1.2;
  position: relative;
  z-index: 1;
}
@media (min-width: 1024px) {
  .page-template-page-tickets #default-banner .banner-title {
    margin-bottom: 4rem;
  }
}
.page-template-page-tickets #default-banner .banner-image {
  height: calc(100% - 1px);
  left: 0;
  object-fit: cover;
  position: absolute;
  top: 0;
  width: 100%;
}
@media (max-width: 1023px) {
  .page-template-page-tickets #default-banner .banner-image--desktop {
    display: none;
  }
}
@media (min-width: 1024px) {
  .page-template-page-tickets #default-banner .banner-image--mobile {
    display: none;
  }
}
.page-template-page-tickets #default-banner .banner-wave {
  bottom: -1px;
  left: 0;
  position: absolute;
  width: 100%;
}
.page-template-page-tickets #default-main {
  position: relative;
}
.page-template-page-tickets #default-main::before {
  background-image: url("../../../uploads/2023/06/Repeating-BG-Subpage-Desktop.png");
  background-position: top center;
  background-repeat: repeat-y;
  background-size: cover;
  content: "";
  display: block;
  height: 100%;
  left: 50%;
  opacity: 0.35;
  pointer-events: none;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 100vw;
}
.page-template-page-tickets #tickets {
  position: relative;
}

@media only screen and (min-width: 1024px) {
  .ticket-landing {
    gap: 2.4rem;
    grid-template-columns: 1fr 1fr;
  }
}

.ticket__ad {
  background-color: #fff;
  margin-bottom: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .ticket__ad {
    display: flex;
  }
}
@media only screen and (min-width: 1024px) {
  .ticket__ad {
    grid-column: -1/1;
    margin-bottom: 0;
  }
}
.ticket__ad img {
  display: block;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .ticket__ad img {
    width: auto;
  }
}
.ticket__ad div {
  border: 2px solid #052E21;
  border-top: none;
  padding: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .ticket__ad div {
    border-left: none;
    border-top: 2px solid #052E21;
  }
}

.ticket__ad-heading {
  grid-column: 1/-1;
  margin: 1.6rem auto 0.8rem;
  text-align: center;
}
@media only screen and (min-width: 1024px) {
  .ticket__ad-heading {
    margin: 0.8rem auto 0;
  }
}

.ticket__card {
  border: 1px solid #052E21;
  padding: 2.4rem;
  position: relative;
}
.ticket__card + .ticket__card {
  margin-top: 1.6rem;
}
@media only screen and (min-width: 1024px) {
  .ticket__card + .ticket__card {
    margin-top: 0;
  }
}
.ticket__card::before {
  background-position: center;
  background-size: 200% auto;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
}
.ticket__card:nth-of-type(1) {
  background: linear-gradient(#2676CB, #4A5FA9);
}
@media only screen and (min-width: 1024px) {
  .ticket__card:nth-of-type(1) {
    background: linear-gradient(-90deg, #4A5FA9, #2676CB);
  }
}
.ticket__card:nth-of-type(1)::before {
  background-image: url("../../../uploads/2023/06/animal-modal-bg.svg");
}
.ticket__card:nth-of-type(2) {
  background: linear-gradient(#4760AC, #7A5EA8);
}
@media only screen and (min-width: 1024px) {
  .ticket__card:nth-of-type(2) {
    background: linear-gradient(-90deg, #7A5EA8, #4760AC);
  }
}
.ticket__card:nth-of-type(2)::before {
  background-image: url("../../../uploads/2023/06/animal-modal-bg.svg");
  background-position: 23% 42%;
}

.wa-resident-fieldgroup {
  margin-top: 1.6rem;
}

.wa-resident-confirmation {
  margin-bottom: 1.6rem;
}

.wa-resident-note {
  font-size: 1.4rem;
  font-style: italic;
  margin-bottom: 2.4rem;
  margin-top: -1.6rem;
}

.member-cta {
  border-bottom: 1px solid #c4c4c4;
  border-top: 1px solid #c4c4c4;
  margin: 2.4rem 0;
  padding: 1.6rem 0 2.4rem;
}

.ticket-select__header {
  align-items: center;
  display: flex;
  margin-bottom: 2.4rem;
}
.ticket-select__header-actions {
  align-items: flex-end;
  display: flex;
  flex-direction: column;
  text-align: right;
}
.ticket-select__calendar {
  margin-right: auto;
  position: relative;
}
.ticket-select__calendar-trigger {
  align-items: center;
  display: flex;
  gap: 0.8rem;
}
.ticket-select__calendar-icon {
  width: 1.6rem;
}
.ticket-select__date-options {
  margin-bottom: 2.4rem;
}
.ticket-select__legend {
  align-items: center;
  color: #052E21;
  display: flex;
  font-size: 1rem;
  font-weight: 600;
  justify-content: center;
  line-height: 0;
  margin: 2.4rem 0 1.6rem;
  text-transform: uppercase;
}
.ticket-select__legend-icons {
  background: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAzOS45IDM5LjkiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDpub25lO308L3N0eWxlPjwvZGVmcz48ZyBpZD0iQXJ0Ym9hcmRfMSI+PHBhdGggaWQ9Ikljb25fYXdlc29tZS10aWNrZXQtYWx0IiBkPSJtMTMuMywzMS4xVjguOWgxMy4zdjIyLjJoLTEzLjNaTTIwLDMuM2MxLjgsMCwzLjMtMS41LDMuMy0zLjNoNi43YzEuOCwwLDMuMywxLjUsMy4zLDMuM2gwdjMzLjNjMCwxLjgtMS41LDMuMy0zLjMsMy4zaC02LjdjMC0xLjgtMS41LTMuMy0zLjMtMy4zaDBjLTEuOCwwLTMuMywxLjUtMy4zLDMuM2gtNi43Yy0xLjgsMC0zLjMtMS41LTMuMy0zLjNoMFYzLjNjMC0xLjgsMS41LTMuMywzLjMtMy4zaDYuN2MwLDEuOCwxLjUsMy4zLDMuMywzLjNoMFptLTcuMiwzLjRjLS45LDAtMS43LjctMS43LDEuN3YyMy4zYzAsLjkuNywxLjcsMS43LDEuN2gxNC40Yy45LDAsMS43LS43LDEuNy0xLjdWOC4zYzAtLjktLjctMS43LTEuNy0xLjdoLTE0LjR2LjFaIi8+PC9nPjxyZWN0IGNsYXNzPSJjbHMtMSIgd2lkdGg9IjM5LjkiIGhlaWdodD0iMzkuOSIvPjwvc3ZnPg==") left center/auto 100% repeat-x;
  height: 12px;
  margin: 0 6px;
}
.ticket-select__legend-icons--high {
  aspect-ratio: 5/1;
}
.ticket-select__legend-icons--low {
  aspect-ratio: 1;
}
.ticket-select__legend-span {
  background-color: #052E21;
  height: 1px;
  width: 24px;
}
.ticket-select__ticket-choices--general-capacity-reached .guest-ticket-selector__options .counter__button--increment {
  color: #c4c4c4;
  pointer-events: none;
}
.ticket-select__ticket-choices--member-capacity-reached .member-ticket-selector__option .counter__button--increment, .ticket-select__ticket-choices--member-capacity-reached .member-ticket-selector__option input[type=checkbox]:not(:checked) {
  color: #c4c4c4;
  pointer-events: none;
}
.ticket-select__time-options {
  margin-bottom: 2.4rem;
}
.ticket-select__ages {
  border: 1px solid #eeeee8;
  display: grid;
  gap: 1.6rem;
  grid-template-columns: repeat(3, 1fr);
  list-style: none;
  margin-top: 0;
  padding: 0.8rem 1.6rem;
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .ticket-select__ages {
    padding: 0.8rem 3.2rem;
  }
}
.ticket-select__ages li {
  display: flex;
  flex-direction: column;
}
.ticket-select__group-text, .ticket-select__capacity-text, .ticket-select__expired-text {
  background-color: #1963B0;
  border-radius: 0.2rem;
  color: #ffffff;
  padding: 0.8rem 1.6rem;
  width: 100%;
}
.ticket-select__group-text a, .ticket-select__capacity-text a, .ticket-select__expired-text a {
  color: #ffffff !important;
}
.ticket-select__group-text .fa, .ticket-select__capacity-text .fa, .ticket-select__expired-text .fa {
  margin-right: 0.8rem;
}
.ticket-select__total {
  display: flex;
  flex-wrap: wrap;
  font-size: 2.4rem;
  margin: 4rem 0 2.4rem;
}
.ticket-select__total-title {
  margin-right: auto;
}
.ticket-select__total-amount {
  font-weight: bold;
}
.ticket-select__add-to-cart {
  width: 100%;
}
.ticket-select__schedule {
  margin-top: 4rem;
}
.ticket-select__schedule-header {
  align-items: center;
  background-color: #eeeee8;
  border-radius: 0.2rem;
  cursor: pointer;
  display: flex;
  gap: 0.8rem;
  margin-bottom: 0.8rem;
  padding: 0.8rem 1.6rem;
}
.ticket-select__schedule-header-icon {
  width: 40px;
}
.ticket-select__schedule-header-text * {
  margin: 0;
}
.ticket-select__schedule-header-toggle {
  background: none !important;
  border: none !important;
  margin-left: auto;
  padding: 0 !important;
}
.ticket-select__schedule-header-toggle--open {
  transform: rotate(180deg);
}
.ticket-select__schedule-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.ticket-select__schedule-list-item {
  background-color: #0C2340;
  color: #ffffff;
  display: flex;
  gap: 2.4rem;
  justify-content: space-between;
  padding: 1.2rem;
}
.ticket-select__schedule-list-item:not(:last-child) {
  margin-bottom: 0.4rem;
}
.ticket-select__schedule-name {
  font-family: "Barlow Condensed", serif;
  font-weight: 500;
  letter-spacing: 0.05rem;
  text-transform: uppercase;
}
.ticket-select__schedule-time {
  color: #3CCBDA;
  font-family: "Barlow Condensed", serif;
  font-weight: 500;
  letter-spacing: 0.05rem;
  min-width: 64px;
  text-align: right;
  text-transform: uppercase;
}

.ticket-summary__header {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
.ticket-summary__steps {
  align-items: center;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin: 1.6rem 0;
}
@media only screen and (min-width: 768px) {
  .ticket-summary__steps {
    justify-content: space-between;
    border-radius: 0.2rem;
    border: 1px solid #eeeee8;
    padding: 0.8rem 1.6rem;
  }
}
.ticket-summary__steps .fieldgroup {
  align-items: center;
  gap: 0 0.4rem;
  margin: 0 0 0 12px;
}
.ticket-summary__steps .fieldgroup.enabled input {
  pointer-events: auto;
}
.ticket-summary__steps .fieldgroup.enabled input, .ticket-summary__steps .fieldgroup.enabled label {
  cursor: pointer;
  text-decoration: underline;
}
@media only screen and (min-width: 768px) {
  .ticket-summary__steps .fieldgroup {
    margin: 0;
  }
}
.ticket-summary__steps input {
  border: none !important;
  height: 1.2rem;
  min-width: 1.2rem;
  pointer-events: none;
  top: 0;
  user-select: none;
  width: 1.2rem;
}
.ticket-summary__steps label {
  font-size: 1.2rem;
  font-weight: normal;
  margin: 0;
}
.ticket-summary__title {
  margin-bottom: 2.4rem;
  text-transform: uppercase;
}
.ticket-summary__title span {
  float: right;
}
.ticket-summary__heading {
  align-items: center;
  display: flex;
  gap: 1.6rem;
  white-space: nowrap;
}
.ticket-summary__heading ~ h6 {
  margin-left: 1.6rem;
}
.ticket-summary__list {
  list-style: none;
  margin: 0 0 1.6rem;
  padding: 0 0 0 1.6rem;
}
.ticket-summary__list li {
  margin-bottom: 0.8rem;
}
.ticket-summary__list li span {
  float: right;
}
.ticket-summary__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  list-style: none;
  margin: 0 0 1.6rem;
  padding: 0 0 0 1.6rem;
}
.ticket-summary__grid li {
  text-align: center;
}
.ticket-summary__grid li p {
  margin-bottom: 0.4rem;
}
.ticket-summary__promo-input--error {
  border-color: #d94a40 !important;
}
.ticket-summary__promo-input--success {
  border-color: #27985f !important;
}
.ticket-summary__promo-message {
  font-weight: bold;
  margin-top: 0.8rem;
}
.ticket-summary__promo-message--error {
  color: #d94a40;
}
.ticket-summary__promo-message--success {
  color: #27985f;
}
.ticket-summary__total {
  border-top: 2px solid #052E21;
  display: flex;
  flex-wrap: wrap;
  font-size: 2.4rem;
  margin: 2.4rem 0;
  padding-top: 2.4rem;
}
.ticket-summary__total-title {
  margin-right: auto;
}
.ticket-summary__total-amount {
  font-weight: bold;
}
.ticket-summary__next {
  margin-top: 0.8rem;
  width: 100%;
}
.ticket-summary__error-text {
  background-color: #1963B0;
  border-radius: 0.2rem;
  color: #ffffff;
  padding: 0.8rem 1.6rem;
  width: 100%;
}
.ticket-summary__error-text a {
  color: #ffffff !important;
}
.ticket-summary__error-text .fa {
  margin-right: 0.8rem;
}
.ticket-summary__link {
  position: relative;
  margin-left: 0;
  margin-right: 1em;
}
.ticket-summary__link + .button {
  margin-left: auto;
}
.ticket-summary__link:after {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  height: 0.75em;
  top: calc(50% - 0.325em);
  left: -0.5em;
  background: currentColor;
}
.ticket-summary__link:first-child:after {
  display: none;
}
@media (max-width: 680px) {
  .ticket-summary__header {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
  .ticket-summary__link {
    width: 100%;
  }
  .ticket-summary__link + .button {
    margin-top: 1em;
  }
  .ticket-summary__link:after {
    display: none;
  }
}

.calendar-picker {
  background-color: #ffffff;
  border: 1px solid #052E21;
  display: none;
  left: 0;
  max-width: 400px;
  padding: 1.6rem;
  position: absolute;
  top: calc(100% + 1.6rem);
  width: calc(100vw - 4rem);
  z-index: -1;
}
.calendar-picker--active {
  display: block;
  z-index: 10;
}
.calendar-picker__note {
  padding: 0 48px 0 16px;
}
.calendar-picker__close {
  aspect-ratio: 1;
  background-color: transparent !important;
  border: none !important;
  cursor: pointer;
  padding: 0 !important;
  position: absolute;
  right: 20px;
  top: 8px;
  width: 4rem;
}
.calendar-picker__month-nav {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 1.6rem;
}
.calendar-picker__month-nav-button {
  background-color: transparent !important;
  border: none !important;
  padding: 0 !important;
  width: 15%;
}
.calendar-picker__month-name {
  margin: 0;
}
.calendar-picker__month-grid {
  text-align: center;
  width: 100%;
}
.calendar-picker__month-grid tr {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
}
.calendar-picker__month-grid tbody {
  display: flex;
  flex-wrap: wrap;
}
.calendar-picker__day {
  aspect-ratio: 1;
  background-color: transparent !important;
  border-radius: 50%;
  border: none !important;
  color: #052E21;
  cursor: pointer;
  display: grid;
  padding: 0 !important;
  place-content: center;
  width: 14.2857142857%;
}
.calendar-picker__day[dayoftheweek=Mon]:first-child {
  margin-left: 14.2857142857%;
}
.calendar-picker__day[dayoftheweek=Tue]:first-child {
  margin-left: 28.5714285714%;
}
.calendar-picker__day[dayoftheweek=Wed]:first-child {
  margin-left: 42.8571428571%;
}
.calendar-picker__day[dayoftheweek=Thu]:first-child {
  margin-left: 57.1428571429%;
}
.calendar-picker__day[dayoftheweek=Fri]:first-child {
  margin-left: 71.4285714286%;
}
.calendar-picker__day[dayoftheweek=Sat]:first-child {
  margin-left: 85.7142857143%;
}
.calendar-picker__day[disabled] {
  opacity: 0.5;
  pointer-events: none;
  user-select: none;
}
.calendar-picker__day--selected {
  background-color: #1963B0 !important;
  color: #ffffff !important;
}

.carousel-selector {
  position: relative;
  margin: 0;
}
.carousel-selector__carousel {
  -ms-overflow-style: -ms-autohiding-scrollbar;
  -webkit-overflow-scrolling: touch;
  border-left: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
  display: flex;
  flex-wrap: nowrap;
  margin: 0;
  overflow-x: auto;
  padding: 0;
  scroll-behavior: smooth;
}
.carousel-selector__carousel::-webkit-scrollbar {
  display: none;
}
@keyframes fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.carousel-selector__day, .carousel-selector__time {
  animation: fade-in 0.4s forwards;
  opacity: 0;
  background-color: #1963B0;
  border-left: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
  color: #ffffff;
  cursor: pointer;
  flex: 0 0 33.3333%;
  padding: 1.2rem;
  transition: background-color 0.2s ease;
}
.carousel-selector__day:nth-child(1), .carousel-selector__time:nth-child(1) {
  animation-delay: 0.08s;
}
.carousel-selector__day:nth-child(2), .carousel-selector__time:nth-child(2) {
  animation-delay: 0.16s;
}
.carousel-selector__day:nth-child(3), .carousel-selector__time:nth-child(3) {
  animation-delay: 0.24s;
}
.carousel-selector__day:nth-child(4), .carousel-selector__time:nth-child(4) {
  animation-delay: 0.32s;
}
.carousel-selector__day:nth-child(5), .carousel-selector__time:nth-child(5) {
  animation-delay: 0.4s;
}
.carousel-selector__day:nth-child(6), .carousel-selector__time:nth-child(6) {
  animation-delay: 0.48s;
}
.carousel-selector__day:nth-child(7), .carousel-selector__time:nth-child(7) {
  animation-delay: 0.56s;
}
.carousel-selector__day:hover, .carousel-selector__time:hover {
  background-color: #134a83;
}
@media only screen and (min-width: 1024px) {
  .carousel-selector__day, .carousel-selector__time {
    flex: 0 0 20%;
  }
}
@media only screen and (min-width: 1440px) {
  .carousel-selector__day, .carousel-selector__time {
    flex: 0 0 14.2857%;
  }
}
.carousel-selector__day[disabled], .carousel-selector__time[disabled] {
  background-color: #56789a !important;
  pointer-events: none;
  user-select: none;
}
.carousel-selector__day--selected, .carousel-selector__time--selected {
  background-color: #0C2340 !important;
  color: #ffffff;
}
.carousel-selector__day--selected .carousel-selector__ticket-meter, .carousel-selector__time--selected .carousel-selector__ticket-meter {
  filter: invert(1);
}
.carousel-selector__day > *, .carousel-selector__time > * {
  pointer-events: none;
}
.carousel-selector__day .carousel-selector__ticket-number {
  display: none !important;
}
.carousel-selector__time .carousel-selector__ticket-meter {
  display: none !important;
}
.carousel-selector__date, .carousel-selector__time-slot {
  margin-bottom: 0.2rem;
}
.carousel-selector__price {
  margin-bottom: 0.8rem;
}
.carousel-selector__price-amount {
  font-weight: bold;
}
.carousel-selector__ticket-meter {
  aspect-ratio: 1;
  background: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAzOS45IDM5LjkiPjxkZWZzPjxzdHlsZT4uY2xzLTF7ZmlsbDpub25lO308L3N0eWxlPjwvZGVmcz48ZyBpZD0iQXJ0Ym9hcmRfMSI+PHBhdGggaWQ9Ikljb25fYXdlc29tZS10aWNrZXQtYWx0IiBkPSJtMTMuMywzMS4xVjguOWgxMy4zdjIyLjJoLTEzLjNaTTIwLDMuM2MxLjgsMCwzLjMtMS41LDMuMy0zLjNoNi43YzEuOCwwLDMuMywxLjUsMy4zLDMuM2gwdjMzLjNjMCwxLjgtMS41LDMuMy0zLjMsMy4zaC02LjdjMC0xLjgtMS41LTMuMy0zLjMtMy4zaDBjLTEuOCwwLTMuMywxLjUtMy4zLDMuM2gtNi43Yy0xLjgsMC0zLjMtMS41LTMuMy0zLjNoMFYzLjNjMC0xLjgsMS41LTMuMywzLjMtMy4zaDYuN2MwLDEuOCwxLjUsMy4zLDMuMywzLjNoMFptLTcuMiwzLjRjLS45LDAtMS43LjctMS43LDEuN3YyMy4zYzAsLjkuNywxLjcsMS43LDEuN2gxNC40Yy45LDAsMS43LS43LDEuNy0xLjdWOC4zYzAtLjktLjctMS43LTEuNy0xLjdoLTE0LjR2LjFaIi8+PC9nPjxyZWN0IGNsYXNzPSJjbHMtMSIgd2lkdGg9IjM5LjkiIGhlaWdodD0iMzkuOSIvPjwvc3ZnPg==") left center/auto 100% repeat-x;
  filter: invert(1);
  height: 12px;
  margin: 8px 0 4px;
  visibility: hidden;
}
.carousel-selector__ticket-meter[data-availability="1"] {
  aspect-ratio: 1;
  visibility: visible;
}
.carousel-selector__ticket-meter[data-availability="2"] {
  aspect-ratio: 2;
  visibility: visible;
}
.carousel-selector__ticket-meter[data-availability="3"] {
  aspect-ratio: 3;
  visibility: visible;
}
.carousel-selector__ticket-meter[data-availability="4"] {
  aspect-ratio: 4;
  visibility: visible;
}
.carousel-selector__ticket-meter[data-availability="5"] {
  aspect-ratio: 5;
  visibility: visible;
}
.carousel-selector__ticket-meter[data-availability=NaN] {
  display: none;
}
.carousel-selector__nav {
  align-items: center;
  bottom: 0;
  display: flex;
  height: 0;
  justify-content: space-between;
  left: 50%;
  overflow: visible;
  position: absolute;
  transform: translateX(-50%);
  width: calc(100% + 3.2rem);
  z-index: 1;
}
.carousel-selector__nav-button {
  background: linear-gradient(-90deg, #00C389, #6AC8D7);
  border: 1px solid #0C2340;
  cursor: pointer;
  height: 3.2rem;
  padding: 0 !important;
  transition: opacity 0.25s ease;
  width: 3.2rem;
}
.carousel-selector__nav-button[disabled] {
  opacity: 0;
}
.carousel-selector__nav-button--prev i {
  rotate: 90deg;
}
.carousel-selector__nav-button--next i {
  rotate: -90deg;
}
.carousel-selector__nav-button i {
  aspect-ratio: 1;
  background: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAzOTYgMzU4LjAzIj48ZGVmcz48c3R5bGU+LmNscy0xe2ZpbGw6IzA1MmUyMTt9PC9zdHlsZT48L2RlZnM+PHBhdGggY2xhc3M9ImNscy0xIiBkPSJtMzkwLjk3LDE0Ny44OWMtNi43LTYuNy0xNy41Ni02LjctMjQuMjcsMGwtMTUxLjU1LDE1MS41NVYxNy4xNmMwLTkuNDgtNy42OC0xNy4xNi0xNy4xNi0xNy4xNnMtMTcuMTYsNy42OC0xNy4xNiwxNy4xNnYyODIuMjhMMjkuMjksMTQ3Ljg5Yy02LjctNi43LTE3LjU2LTYuNy0yNC4yNywwLTMuMzUsMy4zNS01LjAzLDcuNzQtNS4wMywxMi4xM3MxLjY4LDguNzgsNS4wMywxMi4xM2wxODAuODIsMTgwLjgyYy40MS40MS44NC44LDEuMjksMS4xNy4xNS4xMi4zMS4yMy40Ni4zNS4yOS4yMi41OC40NS44OC42NS4yMS4xNC40NC4yNy42Ni40LjI2LjE2LjUxLjMyLjc4LjQ2LjI0LjEzLjQ4LjIzLjcyLjM1LjI3LjEzLjUzLjI2LjguMzcuMjQuMS40OC4xOC43My4yNy4yOC4xLjU2LjIxLjg2LjMuMjUuMDcuNS4xMy43NS4xOS4yOS4wNy41OC4xNi44OC4yMS4yOS4wNi41OS4wOS44OS4xNC4yNi4wNC41MS4wOS43Ny4xMS41Ni4wNiwxLjEzLjA5LDEuNjkuMDksMCwwLDAsMCwwLDBoMGMuNTYsMCwxLjEzLS4wMywxLjY5LS4wOS4yNi0uMDMuNTEtLjA3Ljc3LS4xMS4zLS4wNC41OS0uMDguODktLjE0LjMtLjA2LjU4LS4xNC44OC0uMjEuMjUtLjA2LjUtLjEyLjc1LS4xOS4yOS0uMDkuNTctLjIuODUtLjMuMjQtLjA5LjQ5LS4xNy43My0uMjcuMjctLjExLjU0LS4yNS44LS4zNy4yNC0uMTEuNDgtLjIyLjcyLS4zNS4yNy0uMTQuNTItLjMuNzgtLjQ2LjIyLS4xMy40NC0uMjYuNjYtLjQuMzEtLjIuNTktLjQzLjg4LS42NS4xNS0uMTIuMzEtLjIyLjQ2LS4zNS40NS0uMzcuODgtLjc2LDEuMjktMS4xN2wxODAuODItMTgwLjgyYzYuNy02LjcsNi43LTE3LjU2LDAtMjQuMjdaIi8+PC9zdmc+") center/80% no-repeat;
  display: block;
  height: 100%;
  pointer-events: none;
}
.carousel-selector + p {
  font-size: 1.3rem;
  line-height: 1.3;
  margin-top: 1.6rem;
}

.member-ticket-selector__options {
  display: flex;
  flex-direction: column;
}
.member-ticket-selector__option {
  align-items: flex-start;
  display: flex;
  gap: 1.6rem;
}
.member-ticket-selector__option--last {
  order: 1;
}
.member-ticket-selector__option input[type=checkbox][disabled] {
  opacity: 0.5;
  pointer-events: none;
}
.member-ticket-selector__option input[type=checkbox][disabled] + label {
  opacity: 0.5;
  pointer-events: none;
}
.member-ticket-selector__option label {
  min-width: 48px;
}
.member-ticket-selector__option label div {
  font-size: 1.3rem;
  font-weight: normal;
}
.guest-ticket-selector__options {
  color: #052E21;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media only screen and (min-width: 768px) {
  .guest-ticket-selector__options {
    background-color: #eeeee8;
    justify-content: space-around;
    padding: 2.4rem;
  }
}
.guest-ticket-selector__options + .guest-ticket-selector__options {
  margin-top: 1.6rem;
}
.guest-ticket-selector__heading {
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .guest-ticket-selector__heading {
    text-align: center;
  }
}
.guest-ticket-selector__option {
  text-align: center;
}
.guest-ticket-selector__option + .guest-ticket-selector__heading {
  margin-top: 4rem;
}
.guest-ticket-selector__title {
  margin-bottom: 0;
}
.guest-ticket-selector__description {
  margin-bottom: 0.4rem;
}
.guest-ticket-selector__price {
  margin-bottom: 0.8rem;
}

.counter {
  align-items: center;
  background-color: #ffffff;
  border: 1px solid #0C2340;
  display: inline-flex;
}
.counter__button {
  background-color: #ffffff !important;
  border: none !important;
  cursor: pointer;
  display: grid;
  font-size: 2.4rem !important;
  font-weight: bold !important;
  height: 32px;
  padding: 0 !important;
  place-content: center;
  user-select: none;
  width: 32px;
}
.counter__button:active {
  background-color: #3CCBDA;
  color: #ffffff;
}
.counter__button[disabled] {
  color: #c4c4c4;
  pointer-events: none;
}
.counter__amount[type=number] {
  -moz-appearance: textfield;
  background: none;
  border: none !important;
  border-left: 1px solid #0C2340 !important;
  border-right: 1px solid #0C2340 !important;
  border-radius: 0;
  font-size: 1.6rem;
  font-weight: bold;
  height: 32px;
  margin: 0;
  padding: 0;
  pointer-events: none;
  text-align: center;
  user-select: none;
  width: 36px;
}
.counter__amount[type=number]::-webkit-outer-spin-button, .counter__amount[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.drawer {
  background-color: #eeeee8;
  border-radius: 0.2rem;
  margin-bottom: 1.6rem;
  padding: 0.4rem 0.8rem;
}
@media only screen and (min-width: 768px) {
  .drawer {
    padding: 0.8rem 1.6rem;
  }
}
.drawer + .drawer {
  margin-top: -0.8rem;
}
.drawer__header {
  align-items: center;
  cursor: pointer;
  display: flex;
  gap: 0.8rem;
}
.drawer__title {
  margin: 0;
}
.drawer__toggle {
  background-color: transparent !important;
  border: none !important;
  cursor: pointer;
  margin-left: auto;
  padding: 0 !important;
}
.drawer__toggle--open {
  transform: rotate(180deg);
}
.drawer__content {
  overflow: hidden;
  transition: height 0.5s ease;
  height: 0;
}
.drawer__inner-content {
  padding-top: 1.6rem;
}

.drawer .drawer .drawer__title {
  font-size: 2rem;
}

@media only screen and (min-width: 1024px) {
  .donation-content {
    align-items: center;
    display: grid;
    grid-gap: 2.4rem;
    grid-template-columns: 1fr 1fr;
  }
}
@media only screen and (min-width: 1440px) {
  .donation-content {
    grid-template-columns: 2fr 1fr;
  }
}

.donation-form {
  margin-top: 2.4rem;
}
.donation-form .fieldgroup--radio {
  flex-wrap: wrap;
}
.donation-form .fieldgroup--radio label {
  font-size: 1.6rem;
}
.donation-form .fieldgroup--radio span {
  margin-left: 3.6rem;
  width: 100%;
}

.payment-form fieldset:first-of-type {
  background: linear-gradient(#2676CB, #506aba);
}
.payment-form fieldset:last-of-type {
  background: linear-gradient(#506aba, #7A5EA8);
}
@keyframes shake {
  10%, 90% {
    transform: translate3d(-1px, 0, 0);
  }
  20%, 80% {
    transform: translate3d(2px, 0, 0);
  }
  30%, 50%, 70% {
    transform: translate3d(-4px, 0, 0);
  }
  40%, 60% {
    transform: translate3d(4px, 0, 0);
  }
}
.payment-form__error-text {
  animation: shake 1s ease forwards;
  background-color: #1963B0;
  border-radius: 0.2rem;
  color: #ffffff;
  margin-bottom: 2.4rem;
  padding: 0.8rem 1.6rem;
  width: 100%;
}
.payment-form__error-text .fa {
  margin-right: 0.8rem;
}

.addons-options__title {
  text-transform: none !important;
}
.addons-options__list {
  padding: 0;
  list-style-type: none;
}

.addon-option {
  display: flex;
  align-content: flex-start;
  align-items: center;
  margin-bottom: 12px;
  padding: 12px 24px;
  border: 1px solid #0C2340;
}
.addon-option .counter {
  margin-left: auto;
}
.addon-option__image {
  width: 100px;
  height: 100px;
  object-fit: contain;
}
.addon-option__placeholder {
  margin-right: 24px;
}
.addon-option__title {
  font-size: 16pt !important;
  margin-bottom: 0;
  text-transform: none !important;
}
.addon-option__title, .addon-option__description {
  margin-right: 24px;
}
.addon-option .has-lightbox {
  cursor: pointer;
}
.addon-option .image-lightbox {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.25s ease-in-out;
  z-index: -1;
}
.addon-option .image-lightbox.open {
  opacity: 1;
  z-index: 999;
  cursor: pointer;
}
.addon-option .overlay {
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.75);
}
.addon-option .overlay .close-lightbox {
  position: absolute;
  top: 24px;
  right: 24px;
  border: none !important;
  background: none !important;
}
.addon-option .lightbox-content {
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 48px;
}
.addon-option .lightbox-content img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  box-shadow: 6px 6px 12px rgba(0, 0, 0, 0.5);
}
.addon-option .lightbox-trigger {
  width: auto !important;
  height: auto !important;
  margin-right: 24px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.addons-summary__list {
  list-style-type: none;
}

.addon-summary {
  display: flex;
  justify-content: space-between;
  align-content: flex-start;
  margin-bottom: 12px;
}

@media (max-width: 768px) {
  .addon-option {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 24px;
  }
  .addon-option .counter {
    margin-top: 24px;
    margin-left: 0;
  }
  .addon-option__image {
    margin: 0;
    width: 140px;
    height: 140px;
  }
  .addon-option__title, .addon-option__description {
    margin-top: 12px;
    margin-left: 0;
    margin-right: 0;
    text-align: center;
  }
}
.page-template-page-membership {
  background-color: #fffff7;
}
.page-template-page-membership #default-banner {
  background: linear-gradient(#0C2340, #052E21);
  display: flex;
  flex-direction: column;
  height: 240px;
  justify-content: center;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
@media (min-width: 1024px) {
  .page-template-page-membership #default-banner {
    height: 300px;
  }
}
.page-template-page-membership #default-banner .banner-title {
  position: relative;
  z-index: 1;
}
@media (min-width: 1024px) {
  .page-template-page-membership #default-banner .banner-title {
    margin-bottom: 4rem;
  }
}
.page-template-page-membership #default-banner .banner-image {
  height: calc(100% - 1px);
  left: 0;
  object-fit: cover;
  position: absolute;
  top: 0;
  width: 100%;
}
.page-template-page-membership #default-banner .banner-wave {
  bottom: -1px;
  left: 0;
  position: absolute;
  width: 100%;
}
.page-template-page-membership #default-main {
  position: relative;
}
.page-template-page-membership #default-main::before {
  background-image: url("../../../uploads/2023/06/Repeating-BG-Subpage-Desktop.png");
  background-position: top center;
  background-repeat: repeat-y;
  background-size: cover;
  content: "";
  display: block;
  height: 100%;
  left: 50%;
  opacity: 0.35;
  pointer-events: none;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 100vw;
}
.page-template-page-membership #membership {
  position: relative;
}

.membership__header-actions {
  align-items: center;
  display: flex;
  gap: 1.6rem;
  justify-content: flex-end;
  margin-bottom: 2.4rem;
}
.membership__header-actions-query {
  margin-left: auto;
}
.membership__sign-out {
  margin-left: auto;
}
.membership__level-cards {
  margin-bottom: 4rem;
  margin-top: 2.4rem;
}
@media only screen and (min-width: 1440px) {
  .membership__level-cards {
    display: grid;
    gap: 1.6rem;
    grid-template-columns: repeat(3, 1fr);
  }
}
.membership__actions, .membership__additional-levels {
  border-bottom: 2px solid #052E21;
  margin-bottom: 2.4rem;
  margin-top: 4rem;
}
.membership__actions .drawer, .membership__additional-levels .drawer {
  border-top: 2px solid #052E21;
  background: none;
  padding-top: 1.6rem;
}
.membership__actions .drawer__title, .membership__additional-levels .drawer__title {
  font-size: 2.4rem;
}
.membership__actions .level-card:last-child, .membership__additional-levels .level-card:last-child {
  padding-bottom: 1.6rem;
}
.membership__reserve .button {
  margin-bottom: 0.8rem;
}
.membership__login-form {
  background: linear-gradient(90deg, #2676CB, #7A5EA8);
  border: 1px solid #052E21;
  padding: 2.4rem;
}
.membership__tabs {
  border-bottom: 1px solid #052E21;
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin: 1.6rem 0;
}
.membership__tabs-item {
  cursor: pointer;
  font-size: clamp(1.6rem, 1.6rem + 4 * (100vw - 360px) / 1080, 2rem);
  padding: 0.8rem 0;
}
.membership__tabs-item--active {
  border-bottom: 3px solid #052E21;
  font-weight: bold;
}
.membership__home .drawer {
  margin-bottom: 1.6rem;
}
.membership__expiration {
  background-color: #1963B0;
  border: 1px solid #052E21;
  margin-bottom: 2.4rem;
  margin-top: 3.2rem;
  padding: 1.6rem 2.4rem;
  position: relative;
}
.membership__expiration p {
  margin: 0;
}
.membership__expiration-tag {
  background-color: #0C2340;
  border-radius: 4rem;
  color: #ffffff;
  padding: 0.8rem 1.6rem;
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(1.6rem, -50%);
}
.membership__total {
  align-items: center;
  display: flex;
  font-size: 2.4rem;
  justify-content: space-between;
  margin-bottom: 2.4rem;
}
.membership__total-amount {
  font-weight: bold;
}
.membership__error-text {
  background-color: #1963B0;
  border-radius: 0.2rem;
  color: #ffffff;
  padding: 0.8rem 1.6rem;
  width: 100%;
}
.membership__error-text a {
  color: #ffffff !important;
}
.membership__error-text .fa {
  margin-right: 0.8rem;
}

.membership-checkout-steps {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 1.6rem 0;
}
@media only screen and (min-width: 768px) {
  .membership-checkout-steps {
    border-radius: 0.2rem;
    border: 1px solid #eeeee8;
    padding: 0.8rem 1.6rem;
  }
}
.membership-checkout-steps .fieldgroup {
  align-items: center;
  gap: 0 0.4rem;
  margin: 0;
}
.membership-checkout-steps input {
  border: none !important;
  height: 1.2rem;
  min-width: 1.2rem;
  pointer-events: none;
  top: 0;
  user-select: none;
  width: 1.2rem;
}
.membership-checkout-steps label {
  font-size: 1.2rem;
  font-weight: normal;
  margin: 0;
}

.membership-selection__designation {
  margin-bottom: 2.4rem;
}

.level-card {
  border-top: 1px solid #052E21;
  padding-top: 1.6rem;
}
.level-card--split {
  border: 1px solid #052E21;
  padding: 0;
  position: relative;
}
.level-card--split::before {
  background-position: center;
  background-size: 400% auto;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
}
.level-card--split:nth-of-type(1) {
  background: linear-gradient(#2676CB, #4A5FA9);
}
.level-card--split:nth-of-type(1)::before {
  background-image: url("../../../uploads/2023/06/animal-modal-bg.svg");
}
.level-card--split:nth-of-type(2) {
  background: linear-gradient(#4760AC, #595295);
}
.level-card--split:nth-of-type(2)::before {
  background-image: url("../../../uploads/2023/06/animal-modal-bg.svg");
  background-position: 23% 42%;
}
.level-card--split:nth-of-type(3) {
  background: linear-gradient(#595295, #7A5EA8);
}
.level-card--split:nth-of-type(3)::before {
  background-image: url("../../../uploads/2023/06/animal-modal-bg.svg");
  background-position: 46% 84%;
}
@media only screen and (min-width: 1440px) {
  .level-card--split:nth-of-type(1) {
    background: linear-gradient(90deg, #2676CB, #4A5FA9);
  }
  .level-card--split:nth-of-type(2) {
    background: linear-gradient(90deg, #4760AC, #595295);
  }
  .level-card--split:nth-of-type(3) {
    background: linear-gradient(90deg, #595295, #7A5EA8);
  }
  .level-card--split + .level-card {
    margin-top: unset !important;
  }
}
.level-card--split .level-card__top {
  border-bottom: 1px solid #052E21;
  padding: 1.6rem 2.4rem;
}
@media only screen and (min-width: 1440px) {
  .level-card--split .level-card__top {
    min-height: 24rem;
  }
}
.level-card--split .level-card__bottom {
  padding: 1.6rem 2.4rem;
}
@media only screen and (min-width: 1440px) {
  .level-card--split .level-card__bottom {
    padding-bottom: 2.4rem;
  }
}
.level-card--split .level-card__bottom .level-card__title {
  font-size: 2.2rem !important;
  font-weight: bold;
}
@media only screen and (min-width: 1440px) {
  .level-card--split .level-card__details {
    display: flex;
    flex-direction: column;
  }
}
.level-card:not(.level-card--split) .level-card__title {
  font-size: 2.2rem;
}
.level-card + .level-card {
  margin-top: 2.4rem;
}
.level-card__title {
  font-size: 2.2rem !important;
  display: flex;
  justify-content: space-between;
  text-transform: none !important;
}
.level-card__details {
  display: grid;
  gap: 1.6rem;
  grid-template-columns: 1fr auto;
}
.level-card .button {
  align-self: start;
  margin-top: 0;
}

.action-card-wrap {
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
  margin-bottom: 2.4rem;
}

.action-card {
  align-items: flex-start;
  background-color: #1963B0;
  border: 1px solid #052E21;
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
  padding: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .action-card {
    flex-direction: row;
  }
}
.action-card__meta {
  flex-grow: 1;
}
.action-card__highlight {
  background-color: #0C2340;
  max-width: 100%;
  padding: 1.6rem;
  text-align: center;
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .action-card__highlight {
    min-width: 24rem;
    width: 24rem;
  }
}

.level-summary {
  background-color: #1963B0;
  border: 1px solid #052E21;
  margin-bottom: 2.4rem;
  margin-top: 3.2rem;
  padding: 1.6rem 2.4rem;
  position: relative;
}
.level-summary .drawer {
  background: none;
  padding: 0;
}
.level-summary .drawer__toggle {
  margin-left: 0;
}
.level-summary__discount-price + p {
  opacity: 0.75;
  text-decoration: line-through;
}
.level-summary__discount-price + p b {
  font-weight: normal;
}

.member-info-form fieldset:nth-of-type(1) {
  background: linear-gradient(#2676CB, #4A5FA9);
}
.member-info-form fieldset:nth-of-type(2) {
  background: linear-gradient(#4760AC, #595295);
}
.member-info-form fieldset:nth-of-type(3) {
  background: linear-gradient(#595295, #7A5EA8);
}
@keyframes shake {
  10%, 90% {
    transform: translate3d(-1px, 0, 0);
  }
  20%, 80% {
    transform: translate3d(2px, 0, 0);
  }
  30%, 50%, 70% {
    transform: translate3d(-4px, 0, 0);
  }
  40%, 60% {
    transform: translate3d(4px, 0, 0);
  }
}
.member-info-form__error-text {
  animation: shake 1s ease forwards;
  background-color: #1963B0;
  border-radius: 0.2rem;
  color: #ffffff;
  margin-bottom: 2.4rem;
  padding: 0.8rem 1.6rem;
  width: 100%;
}
.member-info-form__error-text .fa {
  margin-right: 0.8rem;
}

/* _ticket-sign.scss */
.page-template-page-ticket-sign {
  color: #ffffff;
}
.page-template-page-ticket-sign * {
  color: #ffffff;
  font-family: "myriad-pro", "Myriad", sans-serif !important;
}
.page-template-page-ticket-sign header,
.page-template-page-ticket-sign [data-elementor-type=header] {
  display: none !important;
}
.page-template-page-ticket-sign footer,
.page-template-page-ticket-sign [data-elementor-type=footer] {
  display: none !important;
}
.page-template-page-ticket-sign #full-width {
  background-color: #0C2340;
  background-position: center;
  background-size: cover;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100vh;
}
.page-template-page-ticket-sign .fa-spinner {
  font-size: 4rem;
  left: 50%;
  position: fixed;
  top: 50%;
  transform: translate(-50%, -50%);
}
.page-template-page-ticket-sign .grecaptcha-badge {
  display: none !important;
}

.ticket-sign {
  line-height: 1.4;
  padding-left: 4rem;
  padding-right: 4rem;
  width: 100%;
}
.ticket-sign h1 {
  color: #C3D451;
  text-transform: none;
}
.ticket-sign p {
  font-size: 2.4rem;
  max-width: 120rem;
}
.ticket-sign__title {
  margin-bottom: 2.4rem;
  text-align: center;
}
.ticket-sign__table {
  border-collapse: collapse;
  margin-bottom: 4rem;
  width: 100%;
}
.ticket-sign__table tr > *:first-child {
  width: 40%;
}
.ticket-sign__table tr > *:first-child ~ * {
  width: 20%;
}
.ticket-sign__table th {
  color: #C3D451;
  border-bottom: 2px solid #6C7573;
  font-size: 4.8rem;
  font-weight: 600;
  padding: 1.2rem 0;
}
.ticket-sign__table th span {
  font-size: 3.2rem;
  font-weight: normal;
}
.ticket-sign__table th div {
  color: #ffffff;
  font-size: 3.2rem;
  font-style: italic;
  font-weight: normal;
}
.ticket-sign__table td {
  border-bottom: 2px solid #6C7573;
  font-size: 4.8rem;
  font-weight: 600;
  padding: 1.2rem 0;
}
.ticket-sign__table thead tr:first-child > * {
  border: none;
}
.ticket-sign__table thead th {
  text-align: center;
}
.ticket-sign__table tbody th {
  text-align: left;
}
.ticket-sign__table tbody td {
  text-align: center;
}

/*# sourceMappingURL=acme.css.map */
