/***
 - Timeline Style
 - Timeline Mobile Style
 - Timeline Tablet & Desktop Style
 
 - Reservation Top Info Style
 - Reservation Top Info Mobile Style
 - Reservation Top Info Tablet & Desktop Style
***/


/* Reservation Top Info Style Start */
/* Reservation Top Info Style End */

/* Reservation No Show Start */
/* Reservation No Show End */

/* Timeline Style Start */
.timeline-wrapper,
.timeline-wrapper .timeline-item .timeline-header,
.timeline-wrapper .timeline-item .timeline-line{
    display: flex;
}

.timeline-wrapper{}
.timeline-wrapper .timeline-item{
    width: 100%;
}
.timeline-wrapper .timeline-item .timeline-header{
    justify-content: space-between;
    align-items: flex-end;
}
.timeline-wrapper .timeline-item .timeline-header p{
    margin: 0;
    font-size: 14px;
    font-weight: normal;
    color: #363b44;
}
.timeline-wrapper .timeline-success .timeline-header p.description{
    color: #34d74e;
}
.timeline-wrapper .timeline-alert .timeline-header p.description,
.timeline-wrapper .timeline-warning .timeline-header p.description{
    color: #f66a6a;
}
.timeline-wrapper .timeline-alert .timeline-header p:first-child,
.timeline-wrapper .timeline-warning .timeline-header p:first-child{
    visibility: hidden;
}
.nonRefundable-timeline .timeline-alert .timeline-header p:first-child,
.nonRefundable-timeline .timeline-warning .timeline-header p:first-child{
    visibility: visible;
}
.timeline-wrapper .timeline-item:last-child .timeline-header p:last-child{
    text-align: right;
}
.timeline-wrapper .timeline-item:first-child .timeline-header p:first-child,
.timeline-wrapper .timeline-item:last-child .timeline-header p:last-child{
    display: flex;
    flex-direction: column;
}
.timeline-wrapper .timeline-item .timeline-header p .sub-title{
    margin-bottom: 8px;
    font-size: 14px;
    font-weight: normal;
    color: #c3c5c7;
}

.timeline-wrapper .timeline-item .timeline-line{
    position: relative;
    align-items: center;
    justify-content: center;
    border: solid #d8d8d8;
}
.timeline-wrapper .timeline-item .timeline-line hr{
    width: 100%;
    margin: 0;
    border: 2px solid;
}
.timeline-wrapper .timeline-success .timeline-line hr{
    border-color: #34d74e;
}
.timeline-wrapper .timeline-alert .timeline-line hr{
    border-color: #fbd3d3;
}
.timeline-wrapper .timeline-alert .timeline-line .badge-alert{
    background-color: #fbd3d3 !important;
}
.timeline-wrapper .timeline-warning .timeline-line hr{
    border-color: #f66a6a;
}

.timeline-wrapper .timeline-item .timeline-line .badge{
    position: absolute;
}
.timeline-wrapper .timeline-item .timeline-desc{
    text-align: center;
}
.timeline-wrapper .timeline-item .timeline-desc p{
    font-size: 14px;
    font-weight: normal;
}
.timeline-wrapper .timeline-success .timeline-desc p{color: #34d74e;}
.timeline-wrapper .timeline-alert .timeline-desc p,
.timeline-wrapper .timeline-warning .timeline-desc p{color: #f66a6a;}
/* Timeline Style End */

@media (min-width: 320px){
    /* Reservation Top Info Mobile Style Start */
    .reservation-detail-page .top-info .top-info-inner{
        padding: 0;
    }
    .reservation-detail-page .top-info .top-info-inner ul li{
        width: 100%;
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: flex-start;
    }
    .reservation-detail-page .top-info .top-info-inner ul li .res-code{
        padding: 0;
        margin: 0;
        color: #c1c6cc;
    }
    .reservation-detail-page .top-info .top-info-inner ul li .res-code b{
        color: #363b44;
    }
    .reservation-detail-page .res-hotel .button-group-row{
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        margin: 32px 0;
    }
    .reservation-detail-page .res-hotel .button-group-row .currency-type{
        margin: 0;
        padding: 0;
    }
    .reservation-detail-page .res-hotel .button-group-row .res-cancel{
        margin: 24px 0;
    }
    /* Reservation Top Info Mobile Style End */
    /* Timeline Mobile Style Start */
    .reservation-detail-page .reservation-conditions .conditions-body{
        padding: 16px;
    }
    .timeline-wrapper{
        flex-direction: column;
    }
    .timeline-wrapper .timeline-item{
        display: flex;
        flex-direction: row-reverse;
        justify-content: flex-end;
        height: 150px;
    }
    .timeline-wrapper .timeline-item:first-child .timeline-header p:first-child{
        width: 100%;
    }
    .timeline-wrapper .timeline-item .timeline-header{
        flex-direction: column;
        margin-left: 30px;
        align-items: flex-start;
    }
    .timeline-wrapper .timeline-item .timeline-header p.description{
        display: block;
    }
    .timeline-wrapper .timeline-item .timeline-line{
        padding: 0 8px;
        border-top-width: 1px;
        border-bottom-width: 1px;
        border-left-width: 0;
        border-right-width: 0;
    }
    .timeline-wrapper .timeline-item .timeline-line hr{
        height: 100%;
    }
    .timeline-wrapper .timeline-item .timeline-line .badge{
        display: none;
    }
    .timeline-wrapper .timeline-item .timeline-desc{
        display: none;
    }
    /* Timeline Mobile Style End */
}
@media (min-width: 768px){
    /* Reservation Top Info Tablet & Desktop Style Start */
    .reservation-detail-page .top-info .top-info-inner{
        padding: 0 15px;
    }
    .reservation-detail-page .top-info .top-info-inner ul li{
        width: 100%;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-start;
    }
    .reservation-detail-page .top-info .top-info-inner ul li:last-child{
        justify-content: flex-end;
    }
    .reservation-detail-page .top-info .top-info-inner ul li .res-code{
        padding: 0;
        margin: 0;
        margin-right: 40px;
        color: #c1c6cc;
    }
    .reservation-detail-page .top-info .top-info-inner ul li .res-code:last-child{
        margin-right: 0;
    }
    .reservation-detail-page .top-info .top-info-inner ul li .res-code b{
        color: #363b44;
    }
    .reservation-detail-page .top-info .top-info-inner ul li .res-code:last-child{
        width: auto;
        margin-top: 0;
        display: block;
        align-items: center;
    }
    .reservation-detail-page .top-info .top-info-inner ul li .res-code:last-child b{
        margin-top: 5px;
        margin-left: 0;
        font-size: 18px;
        color: #363b44;
    }
    /* Reservation Top Info Tablet & Desktop Style End */
    /* Timeline Tablet & Desktop Style Start */
    .reservation-detail-page .reservation-conditions .conditions-body{
        padding: 16px 0;
    }
    .timeline-wrapper{
        flex-direction: row;
    }
    .timeline-wrapper .timeline-item{
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        height: auto;
    }
    .timeline-wrapper .timeline-item:first-child .timeline-header p:first-child{
        width: 50%;
    }
    .timeline-wrapper .timeline-item .timeline-header{
        flex-direction: row;
        margin-left: 0;
        align-items: flex-end;
    }
    .timeline-wrapper .timeline-item .timeline-header p.description{
        display: none;
    }
    .timeline-wrapper .timeline-item .timeline-line{
        padding: 8px 0;
        border-top-width: 0;
        border-bottom-width: 0;
        border-left-width: 1px;
        border-right-width: 1px;
    }
    .timeline-wrapper .timeline-item .timeline-line hr{
        height: auto;
    }
    .timeline-wrapper .timeline-item .timeline-line .badge{
        display: block;
    }
    .timeline-wrapper .timeline-item .timeline-desc{
        display: block;
    }
    /* Timeline Tablet & Desktop Style End */
}
@media (max-width:991px){
	#modalDetailMap .map-contents{
		position:absolute;
	}
	#modalDetailMap .close{
		z-index:10;
	}
}
div#modalGuestNameChange .modal-content {
    padding:0;
}
.reservation-detail-page.modal-open .modal-sign .modal-dialog.modal-dialog-centered{
    max-width: 768px;
}
.reservation-detail-page.modal-open .modal-sign .modal-dialog.modal-dialog-centered .modal-content {
    padding:0;
}
/* Reservation No Show Start */
.reservation-detail-page.no-show .booking-details .check {
    width:fit-content;
}
.reservation-detail-page.no-show .booking-details .check:first-of-type{
    margin-right:50px;
}
.reservation-detail-page.no-show .container header{
    margin: 12px auto 0;
    text-align:center;
}
.reservation-detail-page.no-show header .help-image {
    width:62px;
    margin-bottom: 20px;
}
.reservation-detail-page.no-show header h1 {
    font-size:24px;
    font-weight:bold;
    margin-bottom:52px;
}
.reservation-detail-page.no-show .container.content-body {
    background:#fff;
    border: solid 1px rgba(54, 59, 68, 0.1);
    padding: 48px 55px;
        margin-bottom: 120px;
}
.reservation-detail-page.no-show .info-content {
    margin: 0 19px 22px;
    border-bottom: 1px solid #ddd;
    border-bottom-style: dotted;
    padding-bottom: 20px;
}
.reservation-detail-page.no-show .hotel-location span{
    cursor: inherit;
}
.reservation-detail-page.no-show .res-hotel, 
.reservation-detail-page.no-show .check-reservation,
.reservation-detail-page.no-show .cancel-period{
    margin: 0 18px 22px;
}
.reservation-detail-page.no-show .res-hotel{
    padding:0;
}
.reservation-detail-page.no-show .res-hotel .room-card {
    margin-bottom:0;
    position: relative;
}
.reservation-detail-page.no-show .res-hotel .room-card:after{
    content:"";
    display:inline-block;
    width: 12px;
    height: 12px;
    background-color: #fbfbfb;
    position: absolute;
    bottom: -7px;
    left: 32px;
    transform: rotate(45deg);
    border-bottom: 0.5px solid #ededee;
    border-right: 0.5px solid #ededee;
}
.reservation-detail-page.no-show .cancel-period{
    background:#fbfbfb;
    background-color: #eaebec20;
    padding:16px 22px;
    display:flex;
    align-items:center;
}
.reservation-detail-page.no-show .cancel-period p {
    margin: 0 0 0 24px;
}
.reservation-detail-page.no-show .check-reservation h5 {
    font-size: 18px;
}
.reservation-detail-page.no-show .check-reservation .buttons {
    display:flex;
    justify-content:flex-end;
    padding-right: 0;
}
.reservation-detail-page.no-show .check-reservation .buttons .btn {
    width: fit-content;
    padding: 12px 30px;
    font-weight:normal!important;
    font-size:16px;
    margin-left:25px;
}
.reservation-detail-page.no-show .check-reservation .buttons .btn.btn-primary{
    background-color: #34d74e!important;
}
.reservation-detail-page.no-show .check-reservation .buttons .btn.btn-secondary {
    background-color: #fd6a6a!important;
    color:#fff!important;
}
.reservation-detail-page.no-show .check-reservation .buttons button.btn.btn-secondary-outline {
    border-radius: 6px;
    border: solid 1px #6e737a;
}
.reservation-detail-page.no-show .hotel-location {
    padding-left:0;
}
.reservation-detail-page.no-show .booking-details {
    padding-right:0;
    justify-content: flex-end;
}
.reservation-detail-page.no-show .room-card .room-content h5{
    font-size: 16px;
    font-weight: bold;
    margin-bottom:16px;
}
.reservation-detail-page.no-show .possibility li .badge{
    padding:0;
    margin:0;
    font-size:14px;
    font-weight:normal;
}
.reservation-detail-page.no-show .possibility li i {
    margin-right: 8px;
    font-size: 12px;
    color: #363b4450;
}
.reservation-detail-page.no-show .possibility li .badge var{
    font-style:normal;
}
.reservation-detail-page.no-show .selected-conditions .col-8 {
    padding-left: 0;
}
.top-info-section i{
	width: 24px;
	font-size: 18px;
}
.top-info-section img{
	width: 20px;
}
.payNowInfo{
	background: #fff;
    box-shadow: 0px 2px 4px rgb(0 0 0 / 5%);
    border-radius: 8px;
    padding: 24px;
    margin-top: 16px;
    overflow: auto;
}
.payNowInfo .table{
	color:#363B44;
	margin-bottom:0px;
}
.table .payment-thead th {
    color:#363B44;
    background-color: #FAFAFA;
    border-color: #FAFAFA;
    font-size: 14px;
    padding: 8px 16px;
}
.payNowInfo .table td{
	border-top: 1px dashed #C3C4C7;
}
.payNowInfo .table.payment-info-table tr:nth-last-child(2) td{
	border-bottom: 1px solid #E5E5E5;
}
.payNowInfo .table tr p{
	margin:0px;
}
.currencyChangeArea {
    font-weight: normal;
}
.table .payment-total-price .currencyChangeArea  {
	font-weight: bold !important;
}
.refundDemandPrice{
	color: #FD6A6A !important;
}
@media (max-width:991px){
    .reservation-detail-page.no-show header h1 {
        margin-bottom: 24px;
    }
    .reservation-detail-page.no-show .container.content-body{
        padding: 0px;
        margin-bottom: 40px;
        margin-left: 10px;
        margin-right: 10px;
        width: auto;
    }
    .reservation-detail-page.no-show .hotel-location{
        padding: 15px;
        border-bottom: 1px solid #ddd;
        border-bottom-style: dotted;
        margin-bottom: 20px;
    }
    .reservation-detail-page.no-show .booking-details {
        justify-content: flex-start;
        padding-left: 0;
    }
    .reservation-detail-page.no-show .cancel-period{
        display:block;
    }
    .reservation-detail-page.no-show .info-content {
        border: none;
        padding: 0;
    }
    .reservation-detail-page.no-show .cancel-period p{
        margin:15px 0 0;
    }
    .reservation-detail-page.no-show .possibility{
        margin-bottom:0;
    }
    .reservation-detail-page.no-show .check-reservation .buttons {
        display: block;
        margin: auto;
        text-align: center;
    }
    .reservation-detail-page.no-show .check-reservation .buttons .btn {
        margin: 20px auto 0;
    }
    .reservation-detail-page.no-show .selected-conditions .col-4 {
        padding-right:0;
    }
    .reservation-detail-page.no-show .check-reservation h5 {
        text-align: center;
    }
    .reservation-detail-page.no-show .res-hotel .room-card:after {
        display:none;
    }
    .reservation-detail-page.no-show .content-body.mobile-help {
	    margin-bottom: 0;
	}
	.payNowInfo .table tr:first-child td{
		border-top: none;
		padding-top:0px;
	}
	.payNowInfo .table td{
		padding-bottom:4px;
	}
	.payNowInfo{
		font-size:14px;
	}
	.payNowInfo .payment-info-cc{
		font-size: 10px;
		color: #5E6269;
	}
	.payNowInfo .table  .payment-info-cc{
    	border-top: none;
    	padding-top: 0px;
    	padding-bottom:16px;
	}
}
/* Reservation No Show End */

@media (min-width:991px){
    .reservation-detail-page .room-search-dates-container {
        max-width: 46%;
        flex-basis: 46%;
    }
    .room-search-guest-container {
        max-width: 32%;
        flex-basis: 32%;
    }
    .room-search-btn-container {
        padding-left: 0;
        padding-right: 0;
        max-width: 22%;
        flex-basis: 22%;
    }
}