#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: inherit
}

#reservation-window.hidden {
    display: none
}

#reservation-window.active {
    display: block
}

#reservation-container {
    background: #fff;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    padding: 1em;
    width: 90%;
    background-color: #fff;
    white-space: normal;
    height: 90%;
    overflow-y: scroll;
    max-width: 45em
}

.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 #fff
}

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: 700
}

.strike {
    text-decoration: line-through;
    opacity: .5
}

.product-group .radio .material-symbols-outlined {
    font-size: 2em;
    color: #fff;
    border-radius: 1em;
    display: inline-block
}

.product-group .radio.unchecked .material-symbols-outlined {
    display: none
}

.radio.unchecked {
    background-color: #fff
}

.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 {
    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: 700;
    border: 0
}

.ui-datepicker-calendar th span {
    font-weight: 400
}

.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: #145586;
    color: #fff;
    padding: 0 .25em .25em 2em
}

.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: #fff;
    font-weight: 400;
    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: 700
}

@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
}

#package-title {
    line-height: 1em;
    font-size: 1.75em;
    display: block!important;
    width: 100%;
    text-align: center;
    padding-top: 2em
}

.next-btn,.prev-btn {
    background-color: #dfbc00;
    color: #145586;
    font-size: 1.15em;
    padding: .5em 2.5em;
    border-radius: 2em;
    text-transform: capitalize;
    margin-top: .5em;
    margin-left: .5em;
    cursor: pointer;
    border: 0;
    font-weight: 700
}

.next-btn:hover,.prev-btn:hover {
    background-color: gold;
    color: darkgreen
}

.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;
    border-bottom: .1em solid #f7795629;
    padding: .5em;
    margin: 0 auto
}

.price-left {
    width: 60%;
    display: table-cell;
    text-align: left;
    padding-bottom: 1em
}

.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
}

.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: 50%;
    width: 3.5em;
    height: 1em;
    top: 1.6em;
    line-height: 2em;
    border-top: .15em solid #333;
    transform: translateX(-50%);
}

.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
}

.sale-price::before {
    content: "sale";
    display: block;
    font-size: .8em;
    text-transform: capitalize;
    font-weight: lighter
}

.price-list {
    text-align: right;
    display: inline-block
}

.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
}

.minus-button,.plus-button {
    color: #145586;
    background: #fff0;
    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;
    font-size: .9em
}

#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: #fff;
    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: #fff
}

#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: #fff;
    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;
    vertical-align: middle;
}

.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
}

#addToCartSubmit {
    background-color: gold;
    color: darkgreen;
    font-size: 1.25em;
    padding: .5em 1em;
    border-radius: 2em;
    text-transform: capitalize;
    border: 0;
    margin-top: .5em;
    margin-left: .5em;
    cursor: pointer;
    transition: .3s;
    font-weight: 700
}

.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: rgb(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: #fff
}

#cutoff-window p {
    font-size: 1em;
    padding: 1em;
    color: #fff;
    font-weight: 700
}

#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: #fff;
    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 #fff;
    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: #fff;
    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
}

#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 rgb(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 #fff0;
    border-right: 1em solid #fff0;
    border-bottom: 2em solid #41a0b8;
    position: absolute;
    left: 1em;
    top: -1.5em
}

#security-dialogue::after {
    content: "x";
    color: #fff;
    font-size: 1.15em;
    background-color: #41a0b8;
    border-radius: 1em;
    padding: .1em .4em .1em .4em;
    position: absolute;
    right: .25em;
    top: .25em;
    border: .125em solid #fff
}

#security-dialogue p {
    color: #fff;
    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: -.5em;
    right: -.5em
}

.error.hidden {
    display: none
}

p#page-message {
    padding: 1em;
    max-width: 20em;
    font-weight: 700;
    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: #fff;
    background-color: #fff
}

#close-reservation {
    color: #333
}

.product-group {
    background: gainsboro
}

.price {
    color: #333
}

.product-group .radio .material-symbols-outlined {
    color: #fff
}

.radio.unchecked {
    background-color: #fff
}

.radio.checked {
    background-color: green
}

.ui-widget-header {
    background: #fff;
    color: #333
}

.ui-state-default,.ui-widget-content .ui-state-default,.ui-button,.ui-button {
    background: green;
    color: #fff
}

.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: #fff;
    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: #498192!important
}

.highlighted.thanks-giving .ui-state-default {
    background: #d35a1f;
    color: #fff
}

.highlighted.christmas .ui-state-default {
    background: #237032;
    color: #fff
}

#thanks-giving .key-mark {
    background-color: orangered
}

#christmas .key-mark {
    background-color: #237032
}

#package-title {
    color: #b4007a
}

.next-btn,.prev-btn {
    background-color: #ffc700;
    color: #1c531f
}

.next-btn:hover,.prev-btn:hover {
    background-color: skyblue;
    color: #063c52
}

.price-container {
    border-bottom: .1em solid #f7795629
}

.list-price,.sale-price {
    color: #063c52
}

.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: #333
}

.collector-container .hasDatepicker {
    font-size: .8em
}

.ui-datepicker-title {
    font-size: 1.15em
}

.ui-datepicker .ui-datepicker-prev,.ui-datepicker .ui-datepicker-next {
    border: .15em solid #333;
    border-radius: 2em;
    cursor: pointer;
    height: 2em;
    width: 2em
}

.ui-datepicker .ui-datepicker-prev {
    position: relative;
    float: left
}

.ui-datepicker .ui-datepicker-next {
    position: relative;
    float: right
}

.ui-datepicker .ui-datepicker-prev span,.ui-datepicker .ui-datepicker-next span {
    background-image: none;
    border-top: .5em solid #fff0;
    border-bottom: .5em solid #fff0;
    margin-top: -.5em;
    width: auto
}

.ui-datepicker .ui-datepicker-prev span {
    border-right: .75em solid #333;
    transform: translateX(-50%);
    margin-left: -.05em;
    width: auto
}

.ui-datepicker .ui-datepicker-next span {
    border-left: .75em solid #333;
    margin-left: -.25em
}

.custom-checkbox:hover {
    background-color: gainsboro;
    color: dimgrey
}

.custom-checkbox.checked {
    background: royalblue;
    border: 2px solid royalblue;
    color: #fff
}

.collector-container select {
    border: 2px solid gainsboro;
    background: #fff
}

.multi-select-list label {
    color: purple;
    width: 10em;
    padding: 0.5em;
}

.multi-select-list {
    text-align: center;
    padding: .5em
}

#addToCartSubmit {
    background-color: #ffc700;
    color: purple
}

#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: #fff
}

#calendar-message .material-symbols-outlined,#price-message .material-symbols-outlined,#collector-message .material-symbols-outlined {
    border: 2px solid #fff
}

#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: #fff
}

#security-header {
    color: #333
}

#security-dialogue {
    background: #41a0b8
}

#security-dialogue {
    display: none
}

#security-dialogue::before {
    border-left: 1em solid #fff0;
    border-right: 1em solid #fff0;
    border-bottom: 2em solid #41a0b8
}

#security-dialogue::after {
    color: #fff;
    background-color: #41a0b8;
    border: .125em solid #fff
}

#security-dialogue p {
    color: #fff
}

#trust-logo-container {
    background: ivory
}

.price-container.with-image {
    width: 49%;
    display: inline-block;
    overflow: hidden;
    border-bottom: .15em solid gainsboro;
    padding: .5em;
    vertical-align: top;
}

.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
    }
}
