/*=============================*/
#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
}
.hidden{
    
}
#reservation-container {
    background: #fff;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    padding: 1em;
    width: 90%;
    white-space: normal;
    height: 90%;
    overflow-y: scroll;
    max-width: 45em;
    background: white;
}
input#option-update {}
.page-0-option {
    padding: 0.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: 0.15em solid grey;
    margin-left: 0.25em;
    cursor: pointer;
}
.custom-radio.checked{
    background-color: green;
    border: 0.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;
    color: white;
}

.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 {
    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: #145586;
    color: white;
    padding: 0em .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: 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;}

#package-title {
    text-transform: capitalize;
    color: #167ac6;
    line-height: 1em;
    font-size: 1.75em;
    display: block!important;
    width: 100%;
    text-align: center;
    padding-top: 2em
}

.next-btn,.prev-btn,#addToCartSubmit{
    font-family: "Jaro" !important;
    font-weight: lighter;
    color: #333;
    background-color: gold;
    border: 0.15em solid;
    padding: 0.5em 2em;
    display: inline-block;
    text-transform: capitalize;
    font-size: 1.25em;
    margin-top: 1em;
    margin: 0.5em;
}


.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: .25em;
    width: 3.5em;
    height: 1em;
    top: 1.6em;
    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
}

.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: 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;
    font-size: 0.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: 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: 0.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: 0.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: 0.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 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: 0.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%;
        /* font-size: 0.8em; */
    }

    .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 {
}

#close-reservation {
    color: #333;
}

.product-group {
    background: lightslategrey;
}

.price {
    color: white;
}

.product-group .radio .material-symbols-outlined {
    color: white;
}

.radio.unchecked {
    background-color: white;
}

.radio.checked {
    background-color: #18243f;
}

.ui-widget-header {
    background: #fff;
    color: #333;
}

.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-button,
.ui-button {
    background: #728b4d;
    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: #fed702 !important;
    color: #333333 !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: #21491D;
    font-family: "Jaro";
}

.next-btn,
.prev-btn {
    /*! background-color: #ffc700; */
    /*! color: #1c531f; */
    /*! box-shadow: 0em 0.5em 1em #00000055; */
}

.next-btn:hover,
.prev-btn:hover {
    /*! background-color: skyblue; */
    /*! color: #063c52; */
}

.price-container {
    background: #ffffff8f;
    padding: 0.5em;
    border-radius: 1em;
    margin-bottom: 0.5em;
}

.list-price,
.sale-price {
    color: #22491d;
    font-weight: bold;
}

.list-price.strike-price:after {
    border-top: .15em solid #333;
}

.list-price {
    color: #333;
}

.spinner-container {
    background: #fff;
    border: .15em solid #22491d;
}

.minus-button,
.plus-button {
    color: #063c52;
}

.collector-container label {
    color: #22491d;
    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: 0.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: 0.5em solid transparent;
  border-bottom: 0.5em solid transparent;
  margin-top: -0.5em;
  width: auto;
}
.ui-datepicker .ui-datepicker-prev span{
  border-right: 0.75em solid #333;
  transform: translateX(-50%);
  margin-left: -0.05em;
  width: auto;
}
.ui-datepicker .ui-datepicker-next span {
  border-left: 0.75em solid #333;
  margin-left: -0.25em;
}


.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 {
    /* color: darkred; */
}


.price-container.with-image {
    width: 49%;
    display: inline-block;
    overflow: hidden;
    border-bottom: 0.15em solid gainsboro;
    padding: 0.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: 0.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;
	}
}