/* SINGLE ROOM VIEW
***************************************************
***************************************************
*/

/*** TITLE ***/
h1.mphb-room-type-title {
    font-size: 3.2rem;
    padding-bottom: 0.5rem;
}
/*** GALLERY ***/
.bv-room-gallery {
    display: grid;
    grid-gap: 15px;
    grid-template-columns: repeat(5, 2fr);
    margin-top: 15px;
    grid-auto-rows: 1fr;
    max-height: 35rem;
    grid-column: span 5;
    position: relative;
}
.bv-room-gallery figure.gallery-item:first-of-type {
    grid-row: span 2;
    grid-column: span 3;
}
.bv-room-gallery figure.gallery-item:nth-child(4) {
    grid-column: span 2;
}
.bv-room-gallery figure.gallery-item:nth-child(5), .bv-room-gallery figure.gallery-item:nth-child(6) {
    grid-column: span 2;
}
.bv-room-gallery figure.gallery-item {
    border-radius: 8px;
    margin: 0 !important;
    overflow: hidden;
}
.bv-room-gallery figure.gallery-item a {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
}
.bv-room-gallery figure.gallery-item .gallery-icon {
    width: 100%;
    height: 100%;
}
.bv-room-gallery figure.gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mphb-single-room-type-gallery-wrapper {
    display: grid;
    grid-gap: 15px;
    grid-template-columns: repeat(7, 1fr);
    margin-top: 0px;
    grid-auto-rows: 1fr;
    max-height: 35rem;
    margin-bottom: 1.5em;
}
.gallery-item-map {
    grid-column: span 2;
    border-radius: 8px;
    overflow: hidden;
    margin-top: 15px;
    margin-bottom: 1.5em;
}
.gallery-item-map .gallery-map {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
}
.gallery-item-map img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.img-gall-num {
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
    background: var(--green);
    color: #FFF;
    text-decoration: none;
    text-transform: uppercase;
    padding: 1rem 2.2rem;
    border-radius: 4px;
    font-size: 1rem;
    font-weight: 600;
    display: inline-block;
    min-width: 10rem;
    text-align: center;
    transition: all 0.3s ease-in-out;
    cursor: pointer;
    /*pointer-events: none;*/
}
.img-gall-num:hover {
    background: var(--lightgray);
}
figure.gallery-item.gallery-item-extra {
    display: none;
}

/*** BELOW GALLERY ICONS ***/
.apt-mainicons {
    display: flex;
    align-items: center;
    padding-top: 1rem;
    font-size: 0.8rem;
    color: #000;
}
.apt-mainicons-icon {
    display: flex;
    align-items: center;
    padding-right: 1rem;
}
.apt-mainicons-icon:after {
    content: '';
    width: 1px;
    height: 22px;
    background: #000;
    display: inline-block;
    position: relative;
    margin-left: 1rem;
}
.apt-mainicons-icon:last-of-type:after {
    display: none;
}
.apt-mainicons-icon img {
    margin-right: 0.5rem;
}
.alignfull.full_sepline {
    border-top: 1px solid #000;
    max-width: calc(100% - 4rem);
    margin: 2rem auto 2.5rem auto;
}

/*** INCLUDED SERVICES ***/
.tbv_servizi_toggle {
    display: inline-block;
    position: relative;
}
.tbv_servizi_toggle:after {
    content: '';
    display: block;
    position: absolute;
    top: 20px;
    right: 0.75rem;
    transition: all 0.3s ease-in-out;
    background-image: url('/wp-content/uploads/2024/02/arrow_dn.svg');
    background-repeat: no-repeat;
    width: 20px;
    height: 10px;
}
.tbv_servizi_toggle.active:after {
    transform: rotate(180deg);
}
.tbv_servizi_toggle_btn {
    color: #FFF;
    text-decoration: none;
    text-transform: uppercase;
    padding: 1rem 3rem 1rem 1.5rem;
    border-radius: 4px;
    font-size: 1rem;
    font-weight: 600;
    display: inline-block;
    min-width: 18rem;
    text-align: center;
    transition: all 0.3s ease-in-out;
    cursor: pointer;
}
.tbv_servizi_toggle_open {
    background: var(--red);
}
.tbv_servizi_toggle_close {
    background: var(--orange);
}
.tbv_servizi_toggle_open, .tbv_servizi_toggle_close {
    display: none;
}
.tbv_servizi_toggle_open.active, .tbv_servizi_toggle_close.active {
    display: block;
}
.tbv_servizi_inclusi {
    display: none;
    background-color: #FFF;
    border-radius: 8px;
    padding: 3rem 1.5rem 1.5rem 1.5rem;
    box-shadow: 5px 5px 10px 2px #33333320;
    margin-top: -1.5rem;
}

h3.tbv_serv_tit {
    text-transform: uppercase;
    color: var(--darkgray);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: normal;
    border-bottom: 1px solid var(--darkgray);
}
.tbv_serv_group {
    display: grid;
    grid-gap: 15px;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 15px;
    position: relative;
    margin-bottom: 15px;
    padding: 0 1rem;
}
.tbv_serv_icon {
    display: flex;
    align-items: center;
}
.tbv_serv_icon span {
    margin-right: 1rem;
    min-width: 3rem;
    text-align: center;
}
.tbv_serv_icon p {
    margin: 0 !important;
    font-size: 0.8rem;
    color: var(--darkgray);
}
.tbv_tiposerv_legrow {
    font-size: 0.7rem;
    color: var(--darkgray);
    line-height: 1.4;
    padding-top: 0.5rem;
}

.tbv_mainroom_cont {
    display: flex;
}
.tbv_mainroom_cont_sx {
    width: 71.43%;
    padding-right: 2rem;
    padding-bottom: 3rem;
}
.tbv_mainroom_cont_dx {
    width: 28.57%;
    padding-bottom: 3rem;
}

.tbv_room_desc {
    padding: 2rem 0;
}
.tbv_room_rules_tit {
    font-size: 1rem;
    font-weight: 600;
    color: var(--darkgray);
    border-bottom: 1px solid var(--red);
    padding-bottom: 0.5rem;
    margin-bottom: 1.5rem;
}
.tbv_room_rule_desc p {
    margin: 0;
    line-height: 1.4;
}
.tbv_room_rule_row {
    display: flex;
    align-items: flex-start;
    padding-bottom: 1rem;
}
.tbv_room_rule_tit {
    width: 30%;
}
.tbv_room_rule_desc {
    width: 70%;
}
.tbv_room_location {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.9rem;
    color: var(--darkgray);
}
.tbv_roomaddress {
    display: flex;
    align-items: baseline;
}
.tbv_roomaddress img {
    margin-right: 0.5rem;
    width: 14px;
}

/*** HIDE ELEMENTS & CALENDAR ***/
/*.single-mphb_room_type h2.mphb-calendar-title, .single-mphb_room_type .mphb-calendar, .mphb-single-room-type-attributes, .mphb-details-title, .mphb-regular-price {
    display: none !important;
}*/
.single-mphb_room_type h2.mphb-calendar-title, .single-mphb_room_type .mphb-calendar, .mphb-single-room-type-attributes, .mphb-details-title, .mphb-regular-price {
    display: none !important;
}
.tbv_mainroom_cont .mphb-regular-price {
    display: block !important;
}
.alignwide.hide-room-elements {
    display: none;
}

/** SINGLE ROOM BOOKING FORM ***/
/*.mphb-booking-form {
    display: flex;
    flex-wrap: wrap;
}*/
.tbv-roombookform-top {
    display: flex;
    flex-wrap: wrap;
    padding: 0 1rem 1.5rem 1rem;
    background-color: #52525230;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    margin: 0 1rem;
}
input.mphb-reserve-btn.button {
    width: 100%;
    border-color: unset;
    border: 0;
    background: var(--green);
    color: #FFF;
    text-transform: uppercase;
    padding: 1.5rem 1rem;
    border-radius: 8px;
    font-size: 1.2rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease-in-out;
}
.tbv-roombookform-bottom {
    display: flex;
    flex-wrap: wrap;
    padding: 1rem 1rem 1.5rem 1rem;
    background-color: #52525230;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
    margin: 0 1rem;
}
.mphb-rooms-quantity-wrapper.mphb-rooms-quantity-single {
    color: var(--darkgray);
    font-size: 0.9rem;
}
input.button.mphb-button.mphb-confirm-reservation {
    width: 100%;
    border-color: unset;
    border: 0;
    background: var(--red);
    color: #FFF;
    text-transform: uppercase;
    padding: 1.5rem 1rem;
    border-radius: 8px;
    font-size: 1.2rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease-in-out;
}
input.mphb-reserve-btn.button:hover, input.button.mphb-button.mphb-confirm-reservation:hover {
    background-color: var(--darkgray);
}
p.mphb-reserve-btn-wrapper {
    margin: 0 !important;
}
p.mphb-required-fields-tip {
    display: none;
}
p.mphb-check-in-date-wrapper, p.mphb-check-out-date-wrapper {
    width: 50%;
}
.mphb_sc_booking_form-wrapper label {
    display: none;
}
.mphb_sc_booking_form-wrapper br {
    display: none;
}
p.mphb-check-in-date-wrapper, p.mphb-check-out-date-wrapper {
    width: 50%;
    background: #FFF;
    padding: 0.8rem;
    position: relative;
}
p.mphb-check-in-date-wrapper {
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;
    border-right: 1px solid var(--lightgray);
}
p.mphb-check-out-date-wrapper {
    border-top-right-radius: 8px;
    border-bottom-right-radius: 8px;
}
p.mphb-check-in-date-wrapper:after, p.mphb-check-out-date-wrapper:after {
    content: '';
    width: 18px;
    height: 12px;
    background-image: url('/wp-content/uploads/2024/02/calendar_icon.svg');
    background-repeat: no-repeat;
    background-size: contain;
    right: 20px;
    display: block;
    position: absolute;
    top: calc(50% + 5px);
    z-index: 9;
}
p.mphb-check-in-date-wrapper label, p.mphb-check-out-date-wrapper label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--lightgray);
}
input.mphb-datepick {
    width: calc(100% - 40px);
    border: 0;
    border-radius: 0;
    font-size: 0.8rem;
    font-weight: 300;
    margin-top: 0.5rem;
    padding: 0;
}
p.mphb-adults-wrapper.mphb-capacity-wrapper select {
    width: 100%;
    text-align: center;
}
p.mphb-adults-wrapper.mphb-capacity-wrapper {
    width: 100%;
}

.mphb-capacity-wrapper {
    width: 100%;
    background: #FFF;
    border-radius: 8px;
    padding: 0.8rem;
}
.mphb-capacity-wrapper input[type="number"] {
    -webkit-appearance: textfield;
    -moz-appearance: textfield;
    appearance: textfield;
}

.mphb-capacity-wrapper input[type=number]::-webkit-inner-spin-button,
.mphb-capacity-wrapper input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
}

.mphb-capacity-wrapper .number-input {
    border: 2px solid #ddd;
    display: inline-flex;
}

.mphb-capacity-wrapper .number-input,
.mphb-capacity-wrapper .number-input * {
    box-sizing: border-box;
}

.mphb-capacity-wrapper .number-input button {
    outline: none;
    -webkit-appearance: none;
    background-color: transparent;
    border: none;
    align-items: center;
    justify-content: center;
    width: 1.2rem;
    cursor: pointer;
    margin: 0;
    position: relative;
    padding: 0;
}

.mphb-capacity-wrapper .number-input button:before,
.mphb-capacity-wrapper .number-input button:after {
    display: inline-block;
    position: absolute;
    content: '';
    width: 1rem;
    height: 2px;
    background-color: #000000;
    transform: translate(-50%, -50%);
    bottom: 6px;
}
.mphb-capacity-wrapper .number-input button.plus:after {
    transform: translate(-50%, -50%) rotate(90deg);
}

.mphb-capacity-wrapper .number-input input[type=number] {
    padding: .5rem;
    border: 0;
    text-align: center;
    outline: none;
    border: 0;
    border-radius: 0;
    font-size: 0.8rem;
    font-weight: 300;
    margin-top: 0.5rem;
    padding: 0;
}
.mphb-capacity-wrapper .number-input {
    border: 0;
    border-width: 0;
    width: 100%;
    display: flex;
    justify-content: space-between;
    padding-top: 0.25rem;
}
.mphb-capacity-wrapper label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--lightgray);
}
.ospiti-title, .ospiti-num {
    display: inline-block;
}
.ospiti-num {
    font-weight: 600;
}
.mphb-reserve-btn-wrapper.mphb-hide {
    display: block !important;
}

.mphb-reserve-room-section {
    width: 100%;
}

@media screen and (max-width: 1430px) {
input.mphb-reserve-btn.button, input.button.mphb-button.mphb-confirm-reservation {
    font-size: 1rem;
    white-space: normal;
}
}
@media screen and (max-width: 1239px) {
.tbv_mainroom_cont_sx {
    width: 66%;
    padding-right: 2rem;
    padding-bottom: 3rem;
}
.tbv_mainroom_cont_dx {
    width: 34%;
    padding-bottom: 3rem;
}
}
@media screen and (max-width: 1079px) {
.tbv_mainroom_cont_sx {
    width: 60%;
    padding-right: 2rem;
    padding-bottom: 3rem;
}
.tbv_mainroom_cont_dx {
    width: 40%;
    padding-bottom: 3rem;
}
}

@media screen and (max-width: 767px) {
.tbv_mainroom_cont {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column-reverse;
}
.tbv_mainroom_cont_sx {
    width: 100%;
    padding-right: 2rem;
    padding-bottom: 3rem;
}
.tbv_mainroom_cont_dx {
    width: 100%;
    padding-bottom: 3rem;
}

.bv-room-gallery figure.gallery-item {
    display: none;
}
.bv-room-gallery figure.gallery-item:first-of-type {
    grid-row: span 4;
    grid-column: span 5;
    display: block;
}
.single-mphb_room_type .apt-mainicons {
    display: flex;
    align-items: center;
    padding-top: 0rem;
    font-size: 0.8rem;
    color: #000;
    flex-wrap: wrap;
}
.single-mphb_room_type .apt-mainicons-icon {
    display: flex;
    align-items: center;
    padding-right: 1rem;
    width: 100%;
    padding-bottom: 0.3rem;
}
.single-mphb_room_type .apt-mainicons-icon:after {
    display: none;
}
.mphb-single-room-type-gallery-wrapper {
    margin-bottom: 0;
}
.single-mphb_room_type .apt-mainicons-icon img {
    margin-right: 0.5rem;
    max-width: 20px;
}
}

@media screen and (max-width: 459px) {
.tbv_room_rule_row {
    display: flex;
    align-items: flex-start;
    padding-bottom: 1rem;
    flex-wrap: wrap;
}
.tbv_room_rule_tit {
    width: 100%;
}
.tbv_room_rule_desc {
    width: 100%;
}
.img-gall-num {
    position: absolute;
    bottom: 0rem;
    right: 0rem;
    background: var(--green);
    color: #FFF;
    text-decoration: none;
    text-transform: uppercase;
    padding: 0.5rem 0.1rem;
    border-radius: 8px;
    font-size: 0.8rem;
    font-weight: 600;
    display: inline-block;
    min-width: 10rem;
    text-align: center;
    transition: all 0.3s ease-in-out;
    cursor: pointer;
    /* pointer-events: none; */
    /* width: 100%; */
}
}

/*** RELATED SHORTCODE ***/
.tbv_related_row.alignfull {
    position: relative;
    margin-bottom: 2rem;
}
.tbv_related_row.alignfull:before {
    content: '';
    width: calc(100% - 4rem);
    height: 50%;
    border-radius: 10px;
    background-color: var(--red);
    display: block;
    position: absolute;
    top: 25%;
    z-index: -1;
    left: 2rem;
}
.tbv_related_slider_card {
    background: #FFF;
    border-radius: 8px;
    box-shadow: 5px 5px 10px 2px #33333320;
    margin-top: 1rem;
    margin-bottom: 1rem;
}
.tbv_related_img {
    width: 100%;
    padding-bottom: 60%;
    border-radius: 8px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}
.tbv_related_info_top, .tbv_related_info_middle, .tbv_related_info_bottom {
    padding: 0.3rem 1rem;
}
.tbv_related_info_bottom {
    padding-bottom: 1.5rem;
}
.tbv_related_info_middle_sx {
    font-weight: 600;
}
.tbv_related_info_size {
    display: block;
    font-size: 0.7rem;
    font-weight: 300;
}
.tbv_related_info_middle {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.tbv_related_info_middle_dx img {
    width: 22px;
    margin-right: 0.5rem;
}
.tbv_related_info_middle_dx {
    display: flex;
    align-items: center;
    font-size: 0.7rem;
}
.tbv_related_info_bottom .apt-mainicons {
    display: flex;
    align-items: center;
    padding-top: 0rem;
    font-size: 0.7rem;
    color: #000;
}
.tbv_related_info_top_sx {
    font-size: 0.7rem;
    color: var(--lightgray);
}
.tbv_related_info_top {
    padding-top: 0.6rem;
}
.tbv_related_info_bottom .apt-mainicons img {
    max-width: 22px;
    max-height: 22px;
}
.tbv_related_info_top .mphb-regular-price {
    display: block !important;
    font-size: 0.7rem;
}
.tbv_related_info_top {
    padding-top: 0.6rem;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
}
.tbv_related_slider_card a {
    text-decoration: none !important;
    color: unset !important;
}

/*** SEARCH RESULTS MOD ***/
.tbv_resultsapt_row .tbv_related_slider_card a {
    display: flex;
}
.tbv_resultsapt_row .tbv_related_img {
    width: 40%;
    padding-bottom: 0;
    max-width: 20rem;
    aspect-ratio: 3 / 2;
}
.tbv_resultsapt_row .tbv_related_info_box {
    /* width: 100%; */
    flex-grow: 1;
}
.tbv_resultsapt_row .tbv_related_info_bottom {
    padding-top: 3rem;
}
.tbv_resultsapt_row .tbv_related_items {
    position: relative;
}
.tbv_resultsapt_row .mphb-reserve-room-section {
    position: absolute;
    display: block;
    z-index: 9;
    right: 3rem;
    bottom: 1rem;
}
.tbv_resultsapt_row button.button.mphb-button {
    width: 100%;
    border-color: unset;
    border: 0;
    background: var(--red);
    color: #FFF;
    text-transform: uppercase;
    padding: 0.8rem 1rem;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease-in-out;
}
.tbv_resultsapt_row button.button.mphb-button:hover {
    background-color: var(--darkgray);
}


/*** SEARCH FORM ***/
.html-code {
    position: relative;
}
.search-shortcode {
    position: relative;
    margin-top: -40px;
    display: block;
    z-index: 9;
    width: 100%;
}


.tbv-roombookform-search {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: rgba(0,0,0,0.2);
    padding: 1rem 1.5rem;
    border-radius: 8px;
    margin: 0 1rem;
}
.mphb_sc_search-check-in-out {
    display: flex;
    background: #FFF;
    position: relative;
    border-radius: 8px;
}
p.mphb_sc_search-check-in-date {
    border-right: 1px solid var(--lightgray);
}
p.mphb_sc_search-check-in-date, p.mphb_sc_search-check-out-date {
    width: 50%;
    padding: 0.8rem;
    margin: 0 !important;
    position: relative;
}

p.mphb_sc_search-check-in-date label, p.mphb_sc_search-check-out-date label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--lightgray);
}
p.mphb_sc_search-check-in-date::after, p.mphb_sc_search-check-out-date::after {
    content: '';
    width: 18px;
    height: 12px;
    background-image: url(/wp-content/uploads/2024/02/calendar_icon.svg);
    background-repeat: no-repeat;
    background-size: contain;
    right: 20px;
    display: block;
    position: absolute;
    top: calc(50% + 5px);
    z-index: 9;
}
.tbv-roombookform-search .mphb-capacity-wrapper .number-input {
    border: 0;
    border-width: 0;
    width: 100%;
    display: flex;
    justify-content: space-between;
    padding-top: 0;
}
.tbv-roombookform-search .mphb-capacity-wrapper {
    width: auto;
    min-width: 10rem;
}
p.mphb_sc_search-room-type-2 {
    background: #FFF;
    border-radius: 8px;
    padding: 0.8rem;
    margin: 0 !important;
}
p.mphb_sc_search-room-type-2 label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--lightgray);
}
p.mphb_sc_search-room-type-2 select {
    border: 0;
    font-size: 0.8rem;
    font-weight: 300;
    margin-top: 0.2rem;
}
p.mphb_sc_search-submit-button-wrapper {
    margin: 0 !important;
}
p.mphb_sc_search-submit-button-wrapper input.button {
    width: 100%;
    border-color: unset;
    border: 0;
    background: var(--green);
    color: #FFF;
    text-transform: uppercase;
    padding: 1.5rem 2rem;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease-in-out;
}
p.mphb_sc_search-submit-button-wrapper input.button:hover {
    background-color: var(--darkgray);
}

p.mphb_sc_search_results-info {
    font-weight: 500;
    margin: 2rem 1rem;
}



.mphb_sc_search_results-wrapper .tbv_resultsapt_row .mphb-reserve-room-section {
    position: absolute;
    display: block;
    z-index: 9;
    right: 1rem;
    bottom: 1rem;
}
.tbv_resultsapt_row .mphb-reserve-room-section {
    width: auto;
}


@media screen and (max-width: 1039px) {
.tbv-roombookform-search {
    flex-wrap: wrap;
}
.mphb_sc_search-check-in-out {
    width: 100%;
    margin-bottom: 1rem;
}
.tbv-roombookform-search .mphb-capacity-wrapper {
    width: auto;
    min-width: 33%;
}
p.mphb_sc_search-room-type-2 {
    min-width: 33%;
}
p.mphb_sc_search-submit-button-wrapper {
    margin: 0 !important;
    max-width: 30%;
}
p.mphb_sc_search-submit-button-wrapper input.button {
    padding: 1.5rem 1rem;
    font-size: 0.85rem;
}
}

@media screen and (max-width: 767px) {
p.mphb_sc_search-submit-button-wrapper {
    margin: 0 !important;
    max-width: unset;
    width: 100%;
    margin-top: 1rem !important;
}
.tbv-roombookform-search .mphb-capacity-wrapper {
    width: auto;
    min-width: calc(50% - 0.5rem);
}
p.mphb_sc_search-room-type-2 {
    min-width: calc(50% - 0.5rem);
}
.tbv_resultsapt_row .tbv_related_slider_card a {
    display: flex;
    flex-wrap: wrap;
}
.tbv_resultsapt_row .tbv_related_img {
    width: 100%;
    padding-bottom: 0;
    max-width: 100%;
    aspect-ratio: 3 / 2;
}
}

@media screen and (max-width: 459px) {
    .tbv-roombookform-search {
    padding: 0.5rem 0.5rem;
    border-radius: 8px;
    margin: 0;
}
p.mphb_sc_search-room-type-2 select {
    border: 0;
    font-size: 0.7rem;
}

.tbv_related_info_top {
    flex-wrap: wrap;
}
.tbv_related_info_top_dx {
    width: 100%;
}
.tbv_related_info_bottom .apt-mainicons {
    flex-wrap: wrap;
}
.tbv_related_info_bottom .apt-mainicons-icon {
    display: flex;
    align-items: center;
    padding-right: 0;
    width: 100%;
    padding-bottom: 0.3rem;
}
.tbv_related_info_bottom .apt-mainicons-icon:after {
    display: none;
}
.tbv_resultsapt_row .tbv_related_info_bottom {
    padding-top: 1rem;
}

/*.mphb_sc_search_results-wrapper .tbv_resultsapt_row .mphb-reserve-room-section {
    bottom: 4rem;
}*/
}

/*** HIDE RECOMMENDATION ***/
h2.mphb-recommendation-title, .mphb-recommendation, .mphb-reservation-cart {
    display: none;
}


/*** CHECKOUT ***/
.tbv_checkout_cols {
    display: flex;
}
.tbv_checkout_sx {
    width: 40%;
}
.tbv_checkout_dx {
    width: 60%;
    padding-left: 2rem;
}
.tbv_checkout_cols .tbv_related_info_top_sx {
    font-size: 1rem;
    color: var(--black);
    padding-top: 0.3rem;
    font-weight: 600;
}
section#mphb-customer-details {
    background: #52525230;
    padding: 1rem 2rem;
    border-radius: 8px;
    margin-bottom: 2rem;
}
h3.mphb-customer-details-title {
    display: none;
}
.mphb-customer-details input {
    width: 100%;
    border: 0;
    padding: 0.6rem 0.3rem;
}
section#mphb-customer-details textarea#mphb_note {
    border: 0;
    border-radius: 6px;
}
section#mphb-customer-details select#mphb_country {
    padding: 0.5rem;
    border-radius: 6px;
    width: 100%;
}
.mphb-customer-details input {
    border-radius: 6px;
}
section#mphb-customer-details input:focus, section#mphb-customer-details textarea:focus, section#mphb-customer-details select:focus {
    outline: none;
}
section#mphb-customer-details label {
    font-size: 0.8rem;
}
p.mphb-customer-name, p.mphb-customer-last-name, p.mphb-customer-email, p.mphb-customer-phone {
    display: inline-block;
    width: 47%;
}
p.mphb-customer-name, p.mphb-customer-email {
    margin-right: 2%;
}
p.mphb-customer-last-name, p.mphb-customer-phone {
    margin-left: 2%;
}
.mphb-customer-details input {
    width: 100%;
}
table.mphb-price-breakdown .mphb-hide {
    display: table-row !important;
}
tr.mphb-price-breakdown-booking {
    display: none !important;
}
/*.tbv_checkout_sx p.mphb-adults-chooser, */.tbv_checkout_sx p.mphb-guest-name-wrapper {
    display: none;
}
.tbv_checkout_cols .tbv_related_slider_card {
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    margin-top: 1rem;
    margin-bottom: 1rem;
}
.tbv_checkout_cols .tbv_related_info_top {
    padding: 0.6rem 0 0 0;
}
.tbv_checkout_cols .tbv_related_info_top, .tbv_checkout_cols .tbv_related_info_middle, .tbv_checkout_cols .tbv_related_info_bottom {
    padding: 0;
}
.tbv_checkout_cols .tbv_related_info_bottom .apt-mainicons {
    display: block;
}
.tbv_checkout_cols .apt-mainicons-icon {
    display: flex;
    align-items: center;
    padding-right: 0rem;
    padding-bottom: 0.5rem;
}
.tbv_checkout_cols .apt-mainicons-icon:after {
    display: none;
}
.tbv_checkout_cols .tbv_related_info_bottom {
    padding-bottom: 1.5rem;
    padding-top: 1rem;
}
/*.tbv_checkout_cols p.mphb-adults-chooser {
    display: none;
}*/
.tbv_checkout_titles {
    text-transform: uppercase;
    font-weight: 600;
    color: var(--darkgray);
    font-size: 0.85rem;
    border-bottom: 1px solid var(--red);
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
}
.tbv_checkout_cols p.mphb-check-in-date, .tbv_checkout_cols p.mphb-check-out-date {
    display: inline-block;
    width: 40%;
}
.tbv_checkout_cols p.mphb-check-in-date span:first-of-type, .tbv_checkout_cols p.mphb-check-out-date span:first-of-type {
    display: block;
}
.tbv_checkout_cols .ospiti-title, .tbv_checkout_cols .ospiti-num {
    display: none;
}
.tbv_checkout_cols h4.mphb-price-breakdown-title {
    display: none;
}
.tbv_checkout_cols table.mphb-price-breakdown th {
    text-align: left !important;
    padding-top: 0.5rem;
}
.tbv_checkout_cols section#mphb-price-details {
    font-size: 0.85rem;
    color: var(--darkgray);
}
.tbv_checkout_cols tr.mphb-price-breakdown-total {
    color: #000;
    font-size: 1rem;
}

.mphb_checkout-services-list, .mphb_sc_checkout-services-list {
    list-style: none;
    margin: 1rem 0 2rem 0;
    padding: 0;
}
.tbv_checkout_cols h4.mphb-services-details-title {
    display: none;
}

.tbv_checkout_cols #mphb-billing-details {
    font-size: 0.85rem;
    color: var(--darkgray);
}
.tbv_checkout_cols .mphb_cb_checkout_form .mphb-billing-fields, .mphb_sc_checkout-form .mphb-billing-fields {
    margin-bottom: 1em;
    border: none;
    padding: 0;
}

p.mphb_sc_checkout-submit-wrapper input[type="submit"] {
    background-color: var(--red);
    color: #FFF;
    text-decoration: none;
    text-transform: uppercase;
    padding: 1rem 1.4rem;
    border-radius: 4px;
    font-size: 0.9rem;
    font-weight: 600;
    text-align: center;
    float: right;
    transition: all 0.3s ease-in-out;
    border: 0;
    cursor: pointer;
}
p.mphb_sc_checkout-submit-wrapper input[type="submit"]:hover {
    background-color: var(--darkgray);
}
.tbv_checkout_apt_addr {
    font-size: 0.75rem;
    margin-top: 0.3rem;
}

.tbv_checkout_sx table.mphb-price-breakdown .mphb-hide.mphb-price-breakdown-dates, .tbv_checkout_sx table.mphb-price-breakdown .mphb-hide.mphb-price-breakdown-date, .tbv_checkout_sx table.mphb-price-breakdown .mphb-hide.mphb-price-breakdown-dates-subtotal {
    display: none !important;
}
input#mphb_phone::placeholder {
    color: #d4d4d4 !important;
}

@media screen and (max-width: 767px) {
.tbv_checkout_cols {
    display: flex;
    flex-wrap: wrap;
}
.tbv_checkout_sx {
    width: 100%;
}
.tbv_checkout_dx {
    width: 100%;
    padding-left: 0;
}
p.mphb-customer-name, p.mphb-customer-email {
    margin-right: 0;
}
p.mphb-customer-last-name, p.mphb-customer-phone {
    margin-left: 0;
}
p.mphb-customer-name, p.mphb-customer-last-name, p.mphb-customer-email, p.mphb-customer-phone {
    display: block;
    width: 100%;
}
}