#reservation-window {
  width:100%;
  height:100%;
  position:fixed;
  z-index:998;
  background-color:#000000cf;
  top:0;
  left:0;
  display:none;
  white-space:normal;
  overflow-y:hidden;
}
#reservation-window p,
#reservation-window li,
#reservation-window a,
#reservation-window button,
#reservation-window div,
#reservation-window input,
#reservation-window option,
#reservation-window select,
#reservation-window textarea {
  font-family:"Montserrat";
  box-shadow:
}
#reservation-window.hidden {
  display:none
}
#reservation-window.active {
  display:block
}
.hidden {
}
#reservation-container {
  background:#fff;
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  padding:1em;
  width:90%;
  background-color:white;
  white-space:normal;
  height:90%;
  overflow-y:scroll;
  max-width:45em;
  font-size: 0.8em;
}
input#option-update {
}
.page-0-option {
  padding:.25em;
  max-width:30em;
  margin:0 auto;
  width:98%
}
.custom-radio {
  width:2em;
  height:2em;
  display:inline-block;
  vertical-align:middle;
  border-radius:3em;
  border:.15em solid grey;
  margin-left:.25em;
  cursor:pointer
}
.custom-radio.checked {
  background-color:green;
  border:.5em double white
}
label.page-0-label {
  font-size:1.25em;
  color:#333;
  pointer-events:none
}
#close-reservation {
  position:absolute;
  right:.5em;
  top:.5em;
  background:none;
  border:none;
  color:#333;
  cursor:pointer
}
#close-reservation .material-symbols-outlined {
  font-size:2.5em
}
.reservation-page.active {
  display:block
}
.group-left {
  display:inline-block;
  text-align:left;
  padding:.5em;
  vertical-align:middle;
  width:80%
}
.radio {
  display:inline-block;
  width:2em;
  height:2em;
  border-radius:2em;
  vertical-align:middle
}
.page-0-input {
  opacity:0;
  width:0;
  height:0;
  overflow:hidden;
  position:absolute;
  z-index:-1
}
.product-group {
  width:100%;
  background:gainsboro;
  border:0;
  margin:.25em;
  padding:.5em;
  border-radius:2em;
  text-align:left;
  display:inline-block;
  max-width:20em;
  font-size:1em;
  cursor:pointer
}
.group-left .title {
  font-size:1.25em;
  display:block;
  width:100%;
  text-align:left;
  padding:0
}
.price {
  display:inline-block;
  font-size:1em;
  color:#333
}
.price span {
  font-size:1.15em;
  margin-left:.25em;
  font-weight:bold
}
.strike {
  text-decoration:line-through;
  opacity:.5
}
.product-group .radio .material-symbols-outlined {
  font-size:2em;
  color:white;
  border-radius:1em;
  display:inline-block
}
.product-group .radio.unchecked .material-symbols-outlined {
  display:none
}
.radio.unchecked {
  background-color:white
}
.radio.checked {
  background-color:#145586
}
#datepicker {
  max-width:30em;
  margin:0 auto;
  width:95%
}
#dateInput {
  height:0;
  width:0;
  position:absolute;
  z-index:-1;
  opacity:0
}
.ui-datepicker-inline.ui-datepicker.ui-widget.ui-widget-content.ui-helper-clearfix.ui-corner-all {
  background:#f5f5f5
}
.ui-datepicker-title {
  background:#f5f5f5
}
.ui-datepicker-header.ui-widget-header.ui-helper-clearfix.ui-corner-all {
  background:#f5f5f5
}
.ui-datepicker-inline.ui-datepicker.ui-widget.ui-widget-content.ui-helper-clearfix.ui-corner-all {
  max-width:50em;
  width:100%
}
.ui-state-default {
  height:3.5em
}
.ui-datepicker {
  width:auto;
  max-width:40em
}
.ui-datepicker-header.ui-widget-header.ui-helper-clearfix.ui-corner-all {
  font-size:1.25em
}
.ui-widget-header {
  background:#fff;
  color:#333;
  font-weight:bold;
  border:0
}
.ui-datepicker-calendar th span {
  font-weight:normal
}
.ui-widget.ui-widget-content {
  margin:0 auto;
  border:none
}
.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-button,
.ui-button {
  border:none;
  background:#D96456;
  color:white;
  padding:0 .25em .25em 2em;
  font-size:1.25em;
}
.ui-state-disabled,
.ui-widget-content .ui-state-disabled,
.ui-widget-header .ui-state-disabled {
  opacity:.5
}
.ui-state-hover,
.ui-widget-content .ui-state-hover,
.ui-widget-header .ui-state-hover,
.ui-state-focus,
.ui-widget-content .ui-state-focus,
.ui-widget-header .ui-state-focus,
.ui-button:hover,
.ui-button:focus {
  border:none;
  background:white;
  font-weight:normal;
  color:#212121
}
.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active,
a.ui-button:active,
.ui-button:active,
.ui-button.ui-state-active:hover {
  background:#e1c115!important;
  color:#145586!important;
  font-weight:bold
}
@media (max-width:600px) {
  #datepicker {
    font-size:.8em;
    max-width:95%;
    margin:0 auto
  }
  .ui-state-default {
    height:4.5em
  }
}
#page2 {
  overflow-x:hidden
}
#page3 {
  height:auto
}
#cart-heading {
  width:100%;
  margin-top:1.5em;
  text-align:center;
  font-weight:bold;
  color:#333;
  font-size:1.5em
}
#package-title {
  text-transform:capitalize;
  color:#167ac6;
  line-height:1em;
  font-size:1.75em;
  display:block!important;
  width:100%;
  text-align:center;
  padding-top:1em
}
.next-btn,
.prev-btn,
#addToCartSubmit {
  display:inline-block;
  border-radius:.5em;
  background-color:#F7B538;
  text-align:center;
  padding:.5em 2em;
  vertical-align:middle;
  color:#333;
  text-transform:capitalize;
  font-size:1.25em;
  line-height:1em;
  margin:.15em;
  cursor:pointer;
  border:none;
  font-weight:bold;
}
.next-btn,
.prev-btn {
  background-color:#9D3124;
  color:#fff;
  border-radius:.5em;
  font-weight: bold !important;
}
.next-btn:hover,
.prev-btn:hover {
  background-color:skyblue;
  color:#063c52;
  font-weight: bold;
}
.next-btn p,
.prev-btn p,
.next-btn span,
.prev-btn span {
  display:inline-block;
  vertical-align:middle;
  font-weight: bold;
}
.reservation-page.hidden {
  display:none
}
.reservation-page.active {
  display:block;
  text-align:center
}
.price-container {
  display:table;
  list-style-type:none;
  width:95%;
  margin-top:.5em;
  padding:.5em;
  margin:0 auto
}
.price-left {
  width:60%;
  display:table-cell;
  text-align:left;
  padding-bottom:1em;
  font-size:1.15em
}
.price-right {
  display:table-cell;
  width:40%;
  text-align:right;
  padding:0 .25em
}
p.group-schedule-message {
  padding:1em;
  text-align:left;
  max-width:20em;
  margin:0 auto
}
.price-container li {
  vertical-align:middle
}
.price-description {
  font-family:inherit
}
.price-description {
  display:block;
  width:100%;
  text-align:left;
  font-weight: bold;
}
.list-price,
.sale-price {
  display:inline-block;
  text-align:center;
  color:#145586;
  font-size:1.25em;
  margin-bottom:.25em;
  margin-top:.25em;
  position:relative;
  width:4.5em
}
.list-price.strike-price {
  opacity:.5
}
.list-price.strike-price:after {
  content:"";
  position:absolute;
  left:.25em;
  width:4em;
  height:.25em;
  top:1.5em;
  line-height:2em;
  border-top:.15em solid #333
}
.list-price {
  color:#333;
  text-decoration:none!important
}
.list-price::before {
  content:"list";
  display:block;
  font-size:.8em;
  text-transform:capitalize;
  text-align:center;
  font-weight:lighter;
  font-weight:bold
}
.sale-price::before {
  content:"sale";
  display:block;
  font-size:.8em;
  text-transform:capitalize;
  font-weight:lighter;
  font-weight:bold
}
.price-list {
  text-align:right;
  display:inline-block;
  font-size:1.15em
}
.spinner-container {
  border-radius:5em;
  max-width:8em;
  background:#fff;
  border:.15em solid #1e4e62;
  font-size:1em;
  m;
  9em;
  display:inline-block;
  margin-top:.5em;
  lock
}
.spinner {
  width:2em;
  font-size:1em;
  vertical-align:middle;
  display:inline-block;
  border:0;
  padding:.25em .2em;
  text-align:center;
  font-weight: bold;
}
.minus-button,
.plus-button {
  color:#145586;
  background:transparent;
  border:0;
  border-radius:5em;
  cursor:pointer;
  vertical-align:middle
}
.collector-container {
  padding-top:1em;
  padding-bottom:1em;
  text-align:center;
  position:relative
}
.collector-container label {
  display:block;
  color:#333;
  font-size:1.2em;
  text-align:center;
  max-width:20em;
  margin:0 auto;
  position:relative
}
.collector-date-input {
  width:;
  font-size:0;
  opacity:0
}
.collector-container .hasDatepicker {
  font-size:.8em
}
.collector-container input[type="text"],
.collector-container input[type="email"],
#reservation-window textarea {
  padding:1em;
  width:90%;
  max-width:25em;
  margin:1em auto;
  border-radius:.75em;
  border:.15em solid gainsboro;
}
#reservation-window textarea {
  height:10em
}
.collector-container input[type="text"].spinner {
  padding:0;
  width:;
  max-width:2em;
  border:0;
  margin:0;
  border-radius:0
}
.custom-checkbox {
  width:1.5em;
  height:1.5em;
  border:2px solid #333;
  cursor:pointer;
  display:block;
  margin:1em auto;
  color:white;
  position:relative;
  border-radius:.33em
}
.custom-checkbox .material-symbols-outlined {
  font-size:1.25em;
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  font-weight:800!important
}
.custom-checkbox::after {
  content:"I Agree.";
  color:#444;
  position:absolute;
  left:1.5em;
  z-index:999;
  display:block;
  width:5em
}
.custom-checkbox:hover {
  background-color:gainsboro;
  color:dimgrey
}
.collector-container input[type='checkbox'] {
  height:0;
  width:0;
  opacity:0;
  overflow:hidden;
  position:absolute;
  z-index:-1;
  font-size:0
}
.custom-checkbox.checked {
  background:#145586;
  border:2px solid #145586;
  color:white
}
#reservation-controls {
  text-align:center;
  padding-top:1em;
  padding-bottom:3em
}
.collector-container select {
  padding:1em;
  width:100%;
  max-width:25em;
  margin:1em auto;
  border-radius:.75em;
  border:2px solid gainsboro;
  background:white;
  cursor:pointer;
  font-size:.9em;
  line-height:2em;
  text-align:center
}
.multi-select-list label {
  color:#145586;
  display:inline-block;
  font-size:1em;
  min-width:12em
}
.multi-select-list {
  text-align:center;
  padding:.5em
}
.multi-select-list .ui-spinner {
  width:2.5em;
  height:1.5em;
  font-size:1.25em;
  margin:.5em
}
.collector-container .ui-datepicker-inline.ui-datepicker.ui-widget.ui-widget-content.ui-helper-clearfix.ui-corner-all {
  max-width:30em
}
@media(max-width:750px) {
  .collector-container .hasDatepicker {
    overflow-x:scroll;
    width:90%;
    margin:0 auto
  }
}
#cutoff-window {
  position:fixed;
  left:50%;
  top:50%;
  width:100%;
  transform:translate(-50%,-50%);
  padding:3em;
  border-radius:.8em;
  box-shadow:0 0 2em #0000009c;
  height:100%;
  background:rgba(0,0,0,.75)
}
#cutoff-message-content {
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:100%
}
#cutoff-window .material-symbols-outlined {
  font-size:3em;
  color:white
}
#cutoff-window p {
  font-size:1em;
  padding:1em;
  color:white;
  font-weight:bold
}
#cutoff-window {
  display:none
}
#cutoff-window.active {
  display:block
}
#window-button {
  background-color:cadetblue;
  color:#fafafa;
  font-size:1em;
  padding:.5em 2.5em;
  border-radius:2em;
  text-transform:capitalize;
  border:0;
  margin-top:.5em;
  margin-left:.5em;
  cursor:pointer;
  transition:.3s
}
#calendar-message,
#price-message,
#collector-message {
  display:block;
  background-color:#d03b3b;
  text-align:center;
  padding:.25em 0;
  border-radius:2em;
  margin:0 auto;
  font-size:1em;
  max-width:21em
}
#calendar-message span,
#calendar-message p,
#price-message span,
#price-message p,
#collector-message span,
#collector-message p {
  color:white;
  font-size:1em;
  display:inline-block;
  vertical-align:middle
}
#calendar-message.hidden,
#price-message.hidden,
#collector-message.hidden {
  width:0;
  overflow:hidden;
  height:0
}
#calendar-message.visible,
#price-message.visible,
#collector-message.visible {
  width:100%
}
#calendar-message .material-symbols-outlined,
#price-message .material-symbols-outlined,
#collector-message .material-symbols-outlined {
  font-size:1.25em;
  border:2px solid white;
  border-radius:50%;
  padding:.15em;
  margin:0 .25em
}
#unavailable-package {
  text-align:center;
  padding:2em;
  overflow:hidden
}
#unavailable-package .material-symbols-outlined {
  font-size:5em;
  color:#3336
}
#unavailable-package h2 {
  color:#333;
  max-width:16em;
  margin:0 auto;
  line-height:1em;
  margin:1em auto
}
#unavailable-package p {
  font-size:1.1em;
  color:#333
}
#schedule-select {
  position:relative
}
#schedule-select label {
  display:block;
  color:#333;
  font-size:1.2em;
  text-align:center;
  position:relative;
  margin:0 auto;
  max-width:20em;
  padding:.5em
}
#schedule-select select {
  padding:1em;
  width:100%;
  max-width:25em;
  margin:1em auto;
  border-radius:.75em;
  border:2px solid gainsboro;
  background:white;
  cursor:pointer;
  font-size:.9em;
  text-align:center;
  color:#333
}
#security-header {
  background:none;
  border:0;
  color:#333;
  cursor:pointer;
  text-align:left;
  float:left;
  font-size:1em;
  position:absolute;
  left:.5em;
  top:.5em
}
#security-header img {
  width:2em;
  display:inline-block;
  vertical-align:middle
}
#security-header span {
  font-size:1.25em;
  vertical-align:middle;
  display:inline-block
}
#security-dialogue {
  position:absolute;
  top:4em;
  background:#41a0b8;
  max-width:40em;
  width:90%;
  padding:2em;
  border-radius:.5em;
  z-index:2;
  box-shadow:0 .25em .5em rgba(0,0,0,.33);
  cursor:pointer
}
#security-dialogue {
  display:none
}
#security-dialogue.active {
  display:block
}
#security-dialogue::before {
  content:"";
  width:0;
  height:0;
  border-left:1em solid transparent;
  border-right:1em solid transparent;
  border-bottom:2em solid #41a0b8;
  position:absolute;
  left:1em;
  top:-1.5em
}
#security-dialogue::after {
  content:"x";
  color:white;
  font-size:1.15em;
  background-color:#41a0b8;
  border-radius:1em;
  padding:.1em .4em .1em .4em;
  position:absolute;
  right:.25em;
  top:.25em;
  border:.125em solid white
}
#security-dialogue p {
  color:white;
  line-height:2em
}
#trust-logo-container {
  background:ivory;
  text-align:center;
  padding-bottom:1em;
  max-width:1200px;
  margin:0 auto
}
#reservation-book {
  display:block;
  text-align:center;
  width:100%;
  margin-top:1em
}
@media(max-height:450px) {
  #reservation-book {
  }
}
@media(max-width:400px) {
  .ui-datepicker table {
    width:100%
  }
}
@media(max-width:750px) {
  #reservation-container {
    width:100%;
    height:100%;
    max-height:100%;
    text-align:center;
    padding:0;
    padding-top:.75em;
    overflow-x:hidden;
    overflow-y:scroll;
    max-width:100%
  }
  #reservation-book {
    position:relative;
    margin-top:1em;
    margin-left:0
  }
  .ui-datepicker table {
    width:100%
  }
  .price-container {
    padding:0
  }
}
div#legend-icon {
  height:1.5em;
  width:1.5em;
  display:inline-block;
  vertical-align:middle
}
p#legend-content {
  font-size:1.25em;
  text-transform:capitalize;
  vertical-align:middle;
  display:inline-block;
  margin-left:.5em
}
.error {
  color:red;
  font-size:1.75em;
  position:absolute;
  top:0;
  right:0
}
.error.hidden {
  display:none
}
p#page-message {
  padding:1em;
  max-width:20em;
  font-weight:bold;
  margin:0 auto
}
.ui-state-default[data-highlight=true] {
  background:darkred!important
}
#legend-icon {
  background:darkred;
  border:1px solid #333
}
#page-1-error {
  color:darkred;
  font-size:1.25em;
  text-transform:capitalize
}
#page-1-error.visible {
  display:block
}
#page-1-error.hidden {
  display:none
}
#reservation-container {
  background-color:whitesmoke
}
#close-reservation {
  color:#333
}
.product-group {
  background:gainsboro
}
.price {
  color:#333
}
.product-group .radio .material-symbols-outlined {
  color:white
}
.radio.unchecked {
  background-color:white
}
.radio.checked {
  background-color:#9d3124;
}
.ui-widget-header {
  background:#fff;
  color:#333
}
.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-button,
.ui-button {
  color:white
}
.ui-state-hover,
.ui-widget-content .ui-state-hover,
.ui-widget-header .ui-state-hover,
.ui-state-focus,
.ui-widget-content .ui-state-focus,
.ui-widget-header .ui-state-focus,
.ui-button:hover,
.ui-button:focus {
  background:white;
  color:#212121
}
.ui-state-active,
.ui-widget-content .ui-state-active,
.ui-widget-header .ui-state-active,
a.ui-button:active,
.ui-button:active,
.ui-button.ui-state-active:hover {
  background:#e1c115!important;
  color:#18243f!important
}
.highlighted.thanks-giving .ui-state-default {
  background:#d35a1f;
  color:white
}
.highlighted.christmas .ui-state-default {
  background:#237032;
  color:white
}
#thanks-giving .key-mark {
  background-color:orangered
}
#christmas .key-mark {
  background-color:#237032
}
#package-title {
  color:#3B1E6FC4;
}
.next-btn p,
.prev-btn p,
.next-btn span,
.prev-btn span {
}
.next-btn:hover,
.prev-btn:hover {
}
.price-container {
  background:#f5f5f5;
  padding:.5em;
  margin-bottom:.5em
}
.list-price,
.sale-price {
  color:#063c52;
  font-weight: bold;
}
.list-price.strike-price:after {
  border-top:.15em solid #333;
}
.list-price {
  color:#333
}
.spinner-container {
  background:#fff;
  border:.15em solid #1e4e62
}
.minus-button,
.plus-button {
  color:#063c52
}
.collector-container label {
  color:#18243f;
  font-weight:bold
}
.collector-container .hasDatepicker {
  font-size:.8em
}
.ui-datepicker-title {
  font-size:1.15em
}
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
  border:.2em solid #333;
  border-radius:2em;
  cursor:pointer;
  height:2em;
  width:2em;
  background: none !important;
}

.ui-datepicker .ui-datepicker-next span {
  margin-left:-.25em;
}

.ui-datepicker .ui-datepicker-prev {
  position:relative;
  float:left;
}
.ui-datepicker .ui-datepicker-next {
  position:relative;
  float:right;
  background: none !important;
}
.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
  background-image:none;
}
.ui-datepicker-next.ui-corner-all:after {
  font-family:"Material Symbols Outlined"!important;
  content:"\e5cc";
  font-weight: bold;
}
.ui-datepicker-prev.ui-corner-all:after {
  font-family:"Material Symbols Outlined"!important;
  content:"\f46b";
  font-weight: bold;
}
.ui-datepicker-next.ui-corner-all:after,
.ui-datepicker-prev.ui-corner-all:after {
  background-color:white;
  color:black;
  position:absolute;
  z-index:999;
  line-height:0;
  font-size:2em;
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
}


.custom-checkbox:hover {
  background-color:gainsboro;
  color:dimgrey
}
.custom-checkbox.checked {
  background:royalblue;
  border:2px solid royalblue;
  color:white
}
.collector-container select {
  border:2px solid gainsboro;
  background:white
}
.multi-select-list label {
  color:purple
}
.multi-select-list {
  text-align:center;
  padding:.5em
}
#window-button {
  background-color:cadetblue;
  color:#fafafa
}
#calendar-message,
#price-message,
#collector-message {
  background-color:#8a0000
}
#calendar-message span,
#calendar-message p,
#price-message span,
#price-message p,
#collector-message span,
#collector-message p {
  color:white
}
#calendar-message .material-symbols-outlined,
#price-message .material-symbols-outlined,
#collector-message .material-symbols-outlined {
  border:2px solid white
}
#unavailable-package .material-symbols-outlined {
  color:#3336
}
#unavailable-package h2 {
  color:#333
}
#unavailable-package p {
  color:#333
}
#schedule-select {
  position:relative
}
#schedule-select label {
  color:#333
}
#schedule-select select {
  border:2px solid gainsboro;
  background:white
}
#security-header {
  color:#333
}
#security-dialogue {
  background:#41a0b8
}
#security-dialogue {
  display:none
}
#security-dialogue::before {
  border-left:1em solid transparent;
  border-right:1em solid transparent;
  border-bottom:2em solid #41a0b8
}
#security-dialogue::after {
  color:white;
  background-color:#41a0b8;
  border:.125em solid white
}
#security-dialogue p {
  color:white
}
#trust-logo-container {
  background:ivory
}
.error {
}
.price-container.with-image {
  width:49%;
  display:inline-block;
  overflow:hidden;
  border-bottom:.15em solid gainsboro;
  padding:.5em
}
.price-image {
  position:relative;
  height:14em;
  overflow:hidden;
  width:100%
}
.price-image img {
  position:absolute;
  width:100%;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%)
}
.price-container.with-image .price-description {
  text-align:center
}
.price-container.with-image .price-description {
  font-size:1.5em;
  padding-top:.25em
}
.price-container.with-image .price-left,
.price-container.with-image .price-right {
  display:block;
  width:100%;
  text-align:center
}
.price-container.with-image .price-list {
  display:block;
  width:100%;
  text-align:center
}
.price-container.with-image .list-price,
.price-container.with-image .sale-price {
  width:50%;
  text-align:center
}
@media(max-width:500px) {
  .price-container.with-image {
    width:90%;
    max-width:20em;
    display:block;
    margin:0 auto
  }
}
