/* Variabili Globali del Form */
:root {
    --rzBookingFormMainColor: rgb(120 202 120);
    --eBikeTextColor: #000;
    --eBikeTextColorVar: #646464;
    --eBikeLinkColor: #f80;
    --eBikeTextSize: 25px;
    --eBikeTextSize2: 20px;
    --eBikeTextSize3: 15px;
    --eBikeBorders: 1px solid #000;
    --eBikeBorderBold: 2px solid #000;
    --eBikeInputBorder: 1px solid #b2b2b2;
    --eBikeBorderRadius: 20px;
    --eBikeTextBold: 900;
    --eBikeTextNormal: 500;
    --eBikeBoxShadow: 0 0 5px 5px #00000019;
}

/* Elementi nascosti */
#rz-form-hidden-fields {
    display: none !important;
    padding: 10px;
    border: 1px solid;
    margin: 10px 0;
}

#rz-form-hidden-fields::before {
    content: 'Hidden Fields';
    font-weight: 900;
    text-transform: uppercase;
    margin-bottom: 20px;
    display: block;
}

/* Loader */
#rz-jb-form-loader {
    display: flex;
    width: 100%;
    height: 100%;
    background-color: #ffffffef;
    position: absolute;
    inset: 0;
    z-index: 10000000000;
    border-radius: var(--eBikeBorderRadius);
    align-content: center;
    justify-content: center;
    align-items: center;
}

.loader {
    width: 50px;
    height: 50px;
    border: 5px solid #f3f3f3;
    border-top: 5px solid var(--rzBookingFormMainColor);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {.rz_select_orario label
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Popup */
#rz-popup-prenotazione-container {
    display: none;
}

#rz-popup-prenotazione-container.form_popup_active {
    display: block !important;
}

#rz-form-popup-container {
    background-color: #ffffffcc;
    display: flex;
    padding: 100px 0;
    min-height: 90vh;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 1000000;
    align-content: center;
    justify-content: center;
    align-items: center;
}

#rz-form-popup-container #rz-popup-inner-container {
    position: relative;
}

#rz-main-custom-jb-form-container {
    position: relative;
    width: 60vw;
    background-color: #fff;
    padding: 35px;
    border-radius: 25px;
    box-shadow: 0 0 25px 25px #00000038;
    max-height: 80vh;
    overflow: auto;
    border: 20px solid #fff;
}

#rz-form-popu-close-btn {
    display: block;
    width: 50px;
    height: 50px;
    background-color: rgb(50 98 140);
    position: fixed;
    right: 30px;
    top: 30px;
    transform: translate(20px, -20px);
    clip-path: polygon(20% 0%, 0% 20%, 30% 50%, 0% 80%, 20% 100%, 50% 70%, 80% 100%, 100% 80%, 70% 50%, 100% 20%, 80% 0%, 50% 30%);
    margin-left: auto;
    z-index: 10000;
}

#rz-form-confirmation-btn {
    background-color: rgb(50 98 140);
    position: sticky;
    top: 100%;
    left: 100%;
    padding: 10px;
    z-index: 1000000;
    border: 1px solid #fff;
    color: #fff;
    text-align: center;
    font-weight: 900;
}

/* Selettori tempo/giorni */
#rz-time-and-days-selectiors-container {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
}

.rz_form_calendar_type_btn {
    display: block;
    background-color: #fff;
    padding: 25px;
    text-align: center;
    border-radius: var(--eBikeBorderRadius);
    border: var(--eBikeBorders);
    font-weight: var(--eBikeTextBold);
    font-size: var(--eBikeTextSize);
}

.rz_form_calendar_type_btn:hover,
.rz_form_calendar_type_btn.rz_active {
    background-color: var(--rzBookingFormMainColor);
}

#rz-jb-form :focus {
    outline: none !important;
}

/* Jet Form Builder */
.jet-form-builder__label {
    font-size: var(--eBikeTextSize3) !important;
    font-weight: var(--eBikeTextNormal) !important;
}

/* Sconti */
.rz_sconti_container .jet-listing-dynamic-repeater__items {
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: center;
    align-items: flex-start;
}

.rz_sconto_raw {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr);
    gap: 10px;
    border: 1px solid;
}

/* Calendario */
#rz-jbf-form-calendar-container {
    font-size: var(--eBikeTextNormal);
    font-weight: var(--eBikeTextBold);
}

.rz_jet_fb_calendar_container .caption {
    background-color: #f5f5f5 !important;
}

.rz_jet_fb_calendar_container .caption .prev,
.rz_jet_fb_calendar_container .caption .next,
.rz_jet_fb_calendar_container .caption .month-name {
    color: #5a5a5a !important;
    font-size: 20px;
    font-weight: 900;
}

.rz_jet_fb_calendar_container .day {
    font-size: var(--eBikeTextSize3);
}

#rz-jbf-form-calendar-container .jet-form-builder-row {
    display: flex !important;
    flex-wrap: wrap !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-direction: column !important;
    align-items: center !important;
}

#rz-jbf-form-calendar-container .jet-form-builder__label {
    width: auto !important;
}

.rz_riepilogo_giorni_main_container {
    font-size: var(--eBikeTextNormal);
    font-weight: var(--eBikeTextBold);
    display: flex !important;
    flex-wrap: wrap;
    gap: 5px !important;
    align-content: center;
    justify-content: center !important;
    align-items: center;
}

/* Steps del form */
.rz_form_steps_container {
    margin: 35px 0;
}

.rz_form_steps_info {
    display: flex;
}

.rz_form_step_text {
    color: var(--rzBookingFormMainColor);
    font-weight: var(--eBikeTextBold);
    margin-right: 30px;
    font-size: var(--eBikeTextSize);
}

.rz_form_step_divider {
    background: linear-gradient(180deg, #fff 0%, #fff 45%, #000 45%, #000 55%, #fff 55%);
    flex-grow: 1;
}

.rz_form_step_title {
    font-weight: var(--eBikeTextBold);
    font-size: var(--eBikeTextSize);
}

/* Stile calendario */
.rz_calendar_main_container .jet-form-builder__label-text {
    text-align: center;
}

[name="check_in_and_check_out"] {
    border: none !important;
    text-align: center !important;
    font-weight: var(--eBikeTextNormal);
    font-size: var(--eBikeTextSize);
}

.rz_jet_fb_calendar_container {
    position: unset !important;
    box-shadow: unset !important;
    background-color: var(--rzBookingFormMainColor) !important;
    border-radius: var(--eBikeBorderRadius);
    padding: 35px !important;
    border: var(--eBikeBorders);
}

.rz_jet_fb_calendar_container .month-wrapper {
    height: 400px;
    background: #fff !important;
    margin: 0 !important;
}

.rz_jet_fb_calendar_container .drp_top-bar {
    display: none;
}

.rz_jet_fb_calendar_container table {
    max-width: unset !important;
    flex: unset !important;
}

/* Seleziona orari */
#rz-slots-title {
    font-weight: var(--eBikeTextBold);
    font-size: var(--eBikeTextNormal);
}

#rz-slots-radio-container {
    border: none;
    padding: 0;
    display: flex;
    gap: 25px;
    flex-direction: column;
    align-items: stretch;
}

.rz_fascia_oraria_container {
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    justify-content: center;
    align-items: flex-start;
}

.rz_select_orario_fascia {
    display: flex;
    text-transform: uppercase;
    color: var(--rzBookingFormMainColor);
    font-size: var(--eBikeTextSize);
    font-weight: var(--eBikeTextBold);
    text-align: center;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.rz_slots_container {
    display: flex;
    gap: 10px;
    margin: 10px 0;
    padding: 0;
    cursor: pointer;
    align-items: center;
    flex-wrap: wrap;
}

.rz_select_orario {
    display: flex;
    gap: 10px;
    margin: 10px 0;
    padding: 0;
    cursor: pointer;
    align-items: center;
}

.rz_select_orario label {
    border: var(--eBikeBorders);
    border-radius: var(--eBikeBorderRadius);
    margin: 0;
    padding: 10px;
    cursor: pointer;
    color: var(--eBikeTextColor);
    font-size: var(--eBikeTextSize);
    display: flex;
    justify-content: center;
    align-items: center;
    flex-grow: 1;
    min-width: 100px;
    text-align: center;
    box-sizing: border-box;
    flex-direction: column;
}

.rz_prezzo_fascia_oraria {
    font-size: var(--eBikeTextSize3);
}

.rz_select_orario input:checked + label {
    background-color: var(--rzBookingFormMainColor);
}

.rz_select_orario input {
    display: none;
}

/* Seleziona modelli */
.rz_disponibilita {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-content: stretch;
    justify-content: center;
    align-items: stretch;
}

.rz_modello_disponibilita_container {
    display: none;
    margin-bottom: 35px;
}

.rz_modello_disponibilita_record {
    display: flex;
    flex-direction: row-reverse;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
    align-content: center;
    align-items: center;
}

.rz_modello_disponibile {
    font-size: var(--eBikeTextSize2);
}

.rz_modello_disponibile_per {
    display: none;
}

.rz_modello_disponibile_numero {
    font-size: var(--eBikeTextSize2);
    color: var(--rzBookingFormMainColor);
}

.rz_selezione_modello {
    display: flex !important;
    flex-wrap: wrap;
    gap: 10px;
    height: 60px;
    align-content: center;
    align-items: center;
    justify-content: space-between;
}

.rz_selez_qty_container {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    justify-content: center;
    align-items: center;
}

.rz_item_qty_btn {
    display: flex;
    width: 35px;
    aspect-ratio: 1;
    background-color: var(--rzBookingFormMainColor);
    border-radius: 100%;
    color: #fff;
    font-weight: 900;
    font-size: 20px;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.rz_input_selezione_modello {
    -moz-appearance: textfield;
    flex-grow: 0;
    border-radius: 100%;
    border: var(--eBikeInputBorder) !important;
    width: 50px !important;
    aspect-ratio: 1;
    text-align: center;
}

.rz_input_selezione_modello::-webkit-outer-spin-button,
.rz_input_selezione_modello::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.rz_selezione_modello label {
    font-size: var(--eBikeTextSize);
    color: var(--eBikeTextColorVar);
    flex-grow: 0;
    width: auto !important;
}

.rz_selezione_modello label::before {
    content: "- ";
}

.rz_jbf_form_subtotale_modelli:not(.jet-form-builder__calculated-field) {
    padding: 10px;
    border: 1px solid;
    margin: 25px 0 0;
}

/* Extra */
#rz-no-extra {
    display: none;
}

#rz-extra-main-container {
    display: none;
}

#rz-jbf-form-extra-container #rz-no-extra,
#rz-jbf-form-extra-container #rz-extra-main-container {
    display: flex !important;
}

#rz-extra-main-container {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-content: stretch;
    justify-content: center;
    align-items: stretch;
}

.rz_extra_raw {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    height: 60px;
    align-content: center;
    justify-content: space-between;
    align-items: center;
}

.rz_item_list_info_container {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-content: center;
    justify-content: flex-start;
    align-items: center;
}

.rz_list_item_title {
    font-size: var(--eBikeTextSize2);
    font-weight: var(--eBikeTextBold);
}

.rz_list_item_price::before {
    content: '(€';
}

.rz_list_item_price::after {
    content: ')';
}

.rz_list_item_img img {
    width: 60px !important;
    aspect-ratio: 1;
    border: 1px solid grey;
    border-radius: 5px;
    margin-right: 10px;
}

.rz_extra_qty_container {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    justify-content: flex-end;
    align-items: center;
    align-content: center;
    background: transparent;
}

.rz_extra_qty_btn {
    display: flex;
    width: 35px;
    aspect-ratio: 1;
    background-color: var(--rzBookingFormMainColor);
    border-radius: 100%;
    color: #fff;
    font-weight: 900;
    font-size: 20px;
    align-content: center;
    align-items: center;
    flex-direction: column;
    justify-content: center;
}

.rz_item_input {
    -moz-appearance: textfield;
    display: flex;
    aspect-ratio: 1;
    width: 50px !important;
    border: var(--eBikeInputBorder) !important;
    align-content: center;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0;
    border-radius: 100%;
}

.rz_item_input::-webkit-outer-spin-button,
.rz_item_input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.rz_jbf_form_subtotale_extra:not(.jet-form-builder__calculated-field) {
    padding: 10px;
    border: 1px solid;
    margin: 25px 0 0;
}

.rz_jb_form_extras_summary_container #lista_extra_per_db {
    padding: 0 !important;
    border: none !important;
}

/* Sommario */
#rz-jb-form-inner-summary-container {
    font-size: var(--eBikeTextSize2) !important;
    font-weight: var(--eBikeTextBold) !important;
}

#modelli-selezionati {
    border: none;
    padding: 0;
    pointer-events: none;
}

#rz-summary-extras-list span span {
    font-weight: 400 !important;
    margin-right: 5px;
}

#rz-jb-form-inner-summary-container button[type="submit"] {
    width: 100%;
    padding: 10px;
    font-size: var(--eBikeTextSize);
    font-weight: var(--eBikeTextBold);
    background-color: var(--rzBookingFormMainColor);
    border-radius: var(--eBikeBorderRadius);
    color: #fff;
    text-shadow: 1px 1px 0 #000;
}

/* Warning */
.rz_form_warning {
    display: flex;
    color: var(--rzBookingFormMainColor);
    padding: 15px;
    border: var(--eBikeBorders);
    border-radius: var(--eBikeBorderRadius);
    font-size: var(--eBikeTextSize);
    gap: 10px;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.rz_form_warning a {
    color: var(--eBikeLinkColor);
}

/* Scrollbar */
#rz-main-custom-jb-form-container {
    scrollbar-width: thin;
    scrollbar-color: var(--rzBookingFormMainColor) transparent;
}

#rz-main-custom-jb-form-container::-webkit-scrollbar {
    width: 8px;
}

#rz-main-custom-jb-form-container::-webkit-scrollbar-track {
    background: transparent;
}

#rz-main-custom-jb-form-container::-webkit-scrollbar-thumb {
    background-color: var(--rzBookingFormMainColor);
    border-radius: 20px;
    border: 3px solid transparent;
}

/* Touch devices */
/*
@media (hover: none) {
    .rz_form_calendar_type_btn:hover {
        background-color: inherit;
    }

    .rz_form_calendar_type_btn:active {
        background-color: var(--rzBookingFormMainColor);
    }
}
*/