/* Mobiscroll enhancements */
.mbsc-ios.mbsc-range-day:after {
    background-color: #e9e9e9;
}
.mbsc-calendar-header {
    border-top: 1px solid #ccc;
    margin-bottom: 20px;
    background: linear-gradient(to bottom,rgba(0,0,0,.05) 0,rgba(0,0,0,0) 100%);
}
.custom-header {
    font-size: 0.9em;
    line-height: 1.428572em;
    color: #707070;
    padding: 0 20px 0 20px;
}
.mbsc-ios.mbsc-popup-header{
color: #707070;
font-size: 0.9em!important;
font-weight: 400!important;
}
.mbsc-datepicker .vacation-check-in.mbsc-calendar-cell.mbsc-calendar-day-empty, .mbsc-datepicker .vacation-check-out.mbsc-calendar-cell.mbsc-calendar-day-empty {
    background: transparent;
}
.mbsc-ios.mbsc-segmented {
    background: #fff!important; 
}
.mbsc-ios.mbsc-segmented, .mbsc-ios.mbsc-segmented-button.mbsc-button, .mbsc-ios.mbsc-segmented-selectbox-inner {
    border-radius: 0!important;
}
.mbsc-ios.mbsc-segmented-selectbox.mbsc-selected {
    display: block;
    border-bottom-style: solid;
    border-bottom-width: 4px;
    border-radius: 0;
    box-shadow: none!important;
}
.mbsc-ios.mbsc-segmented-selectbox-inner.mbsc-selected{
box-shadow: none!important;
}
.REQUEST {
    background-color: #f4f9fb!important;
}
.AVAILABLE:not(.mbsc-calendar-day-empty){
    background:#ddf1e3!important;
}
.loadingStyle .mbsc-ios.mbsc-calendar-label{
color: transparent!important;
filter: blur(2px);
text-shadow: 0 0 2px rgba(0,0,0,.12);
}

.mbsc-disabled.loadingStyle .mbsc-calendar-labels{
    display:none
}
.mbsc-calendar-label-text {
    text-align: center;
    font: 400 10px/14px Open Sans,"Helvetica Neue",Arial,sans-serif;
}
.mbsc-popup .btn_cancel {
    border: solid 1px #ccc;
    height: 32px;
    background: #fff;
    width: 32px;
}
.mbsc-ios.mbsc-calendar-today, .mbsc-ios.mbsc-calendar-week-nr {
    color: #000;
    background: #dedede;
}
.mbsc-popup .btn_cancel:active, .mbsc-popup .btn_cancel:focus, .mbsc-popup .btn_oneway:hover, .mbsc-popup .btn_oneway:active {
    background: #f6fafe
}
.mbsc-popup .mbsc-ios.mbsc-button.btn_set, .mbsc-popup .btn_oneway {
    padding: 0 24px 0 24px;
    height: 32px;
}
.mbsc-popup .btn_set:hover, .mbsc-popup .btn_set:active {
    background: #e5e5e5
}
.mbsc-ios.mbsc-range-control-wrapper .mbsc-segmented {
    width: 22em!important;
}
.mbsc-segmented-item {
    font-size: 1.1em!important;
} 
.mbsc-ios.mbsc-range-control-label.active, .mbsc-ios.mbsc-range-control-value.active {
    font-weight: 400!important;
color: #3f3d3a;
}
 /* Mobiscroll enhancements end */
.mbsc-popup .btn_set:hover, .mbsc-popup .btn_set:active {
    background: #e5e5e5
}
.search-container_outter {
    margin: 0 0 30px;
    box-shadow: 0 0 0 1px rgb(0 10 30 / 20%);
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    border-left-width: 5px;
    border-left-style: solid;
    background: #f7f7f7;
}
.search-container_outter .innerWrapper{
        padding: 20px;
}

.control_group {
    display: flex;
    flex-direction: column;
    flex-flow: column;
}
.control_group .form-group {
    width: 100%;
    margin: 0
}
.control_group .btn {
    font-size: 14px;
    border-radius: 4px;
}
.flex_col {
    margin-bottom: 15px
}
@media only screen and (min-width: 769px) {
    .search-container_outter {
        margin: -30px 0 30px;
        }

    .control_group {
        flex-direction: row;
        flex-flow: row;
        align-items: center;
        border: #acabab solid 1px;
        border-radius: 4px;
        background: #fff;
    }
    .flex_col {
        flex-basis: 40%;
        margin-bottom: 0
    }
    .btn_col {
        flex-grow: 1;
        padding-left: 10px;
        padding-right: 10px
    }
    .control_group .input-set {
        border: none;
        border-radius: 4px;
    }
    .control_group .flex_col input.brd-l {
        border-left: 1px #acabab solid;
    }
    input.brd-l-rounded{
        -webkit-border-top-left-radius: 4px;
-webkit-border-bottom-left-radius: 4px;
-moz-border-radius-topleft: 4px;
-moz-border-radius-bottomleft: 4px;
border-top-left-radius: 4px;
border-bottom-left-radius: 4px;
    }
}
.input-set {
    border: 1px solid #bfbcb5;
    height: 64px;
    background: #fff;
    position: relative;
    padding: 0!important
}
.input-set label {
    position: absolute;
    left: 16px;
    top: 21px;
    color: #7b766c;
    margin: 0;
    display: inline;
    font-size: 16px;
    font-weight: 400;
    transition: .2s ease all;
    -moz-transition: .2s;
    -webkit-transition: .2s;
    pointer-events: none;
    padding-left: 0
}
.input-set label.top-set {
    top: 6px;
    font-size: 13px;
    color: #3f3d3a
}
.input-set input[type=text], .input-set input[type=password],  .input-set select, .input-set input[type=number] {
    width: 100%;
    height: 100%;
    border: none;
    font-size: 16px;
    padding: 20px 10px 0 16px;
    color: #3f3d3a;
}
.input-set input[type=text]:focus, .input-set input[type=password]:focus, .input-set select:focus {
    background: #f7f6f6
}

.input-info {
    position: absolute;
    right: 10px;
    z-index: 2;
    width: 22px;
    height: 22px;
    display: block;
    cursor: pointer;
    color: #757067;
    fill: #757067;
    bottom: 0;
    top: 0;
    margin: auto;
    font-size: 22px;
}

.results-data {
    padding-top: 30px;
}

.-container{
    width:100%;
    margin-bottom:20px;
}
.float-labels input:focus::-webkit-input-placeholder {
    color: transparent;
}
.float-labels input:focus:-moz-placeholder {
    color: transparent;
}
.float-labels input:focus::-moz-placeholder {
    color: transparent;
}
.float-labels input:focus:-ms-input-placeholder {
    color: transparent;
}
.tf-flight__duration {
    font-size: 13px;
    line-height: 1.5;
    color: #767676;
    -ms-flex-positive: 1;
    flex-grow: 1
}


.tf-flight {
    background-color: #fff;
    box-shadow: 0 2px 4px -1px #c5c5c5;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 20px;
}
.tf-flight.tf-flight__selected {
    border-width:2px;
    border-style: solid;
    -webkit-animation: select-animate-flight 0.3s 1;
    animation: select-animate-flight 0.3s 1;
}
@-webkit-keyframes select-animate-flight {
    0%,100% {
        transform: scale(1)
    }

    50% {
        transform: scale(0.95)
    }
}

@keyframes select-animate-flight {
    0%,100% {
        transform: scale(1)
    }

    50% {
        transform: scale(0.95)
    }
}
.tf-flight__carddetail-content__header {
 padding: 20px 25px 0 15px;
 flex-grow: 1;
}
.tf-flight__status-container {
    padding: 20px 25px 20px 15px;
    border-right: solid #eeeeee 1px;
}
.tf-flight__carddetail-content {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-direction: column;
    flex-direction: column;
   
}
.tf-flight-header__item span {
    position: relative;
    padding-left: 18px;
}
.tf-flight-header__item span.outgoing-flight:before, .tf-flight-header__item span.return-flight:before {
    content: "\e901";
    font-family: 'tf-portal' !important;
    font-weight:normal;
    position: absolute;
    top: 0;
    left: 0;
}
.package-styling .tf-flight-header__item span.return-flight:before {
    content: "\e902";
}
@media (min-width: 993px) {
.tf-flight-header__item span.return-flight {
    margin-left:10px
}
}
@media (max-width: 768px) {
    .tf-flight-header__item span {
    display: flex;
    flex-direction: column;
    }

    .tf-flight-header__item span.return-flight {
        margin-top:10px;
    }
}
@media (max-width: 1199px) {
.extended .tf-flight-header__item span.return-flight{
    margin-top:0;
    margin-left:0
}
.extended .tf-flight-header__item span{
    display: block;
    margin-bottom: 10px;
}
}
.tf-flight__carddetail-header {
    padding: 10px 15px;
    border-bottom: 1px solid #eee;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    -ms-flex-pack: space-between;;
    justify-content: space-between;
    -ms-flex-align: center;
    align-items: center;
   }

.tf-flight__carddetail-header .utility-btn-list__item{
    margin-bottom:0
}

@media only screen and (min-width:992px) {
    .tf-flight__carddetail-header {
        padding: 0 15px 8px 15px;
    }

 .tf-flight__carddetail-content__header, .tf-flight__carddetail-content__body {
border-right: 1px solid #eee;
}
.tf-flight__carddetail-content__body {
    padding: 20px 25px 0 25px;
    -ms-flex-preferred-size: 55%;
    flex-basis: 55%
}
.extended .tf-flight__carddetail-content__body {
    -ms-flex-preferred-size: 85%;
    flex-basis: 85%
}
    .tf-flight__carddetail-content__footer {
        padding: 20px 15px 20px 0;
        flex-grow: 1;
        display: flex;
 align-items: center;
 flex: 1;
    }
    .tf-flight__carddetail-content {
        -ms-flex-direction: row;
        flex-direction: row
    }
}
.my_tf-booking span[class*=" status-"]:after{
    margin-left: 10px!important;
}
@media only screen and (max-width:991px) {

    .tf-flight__carddetail-content__body {
        padding: 15px;
    }
    .tf-flight__carddetail-content__footer {
        padding: 15px 15px 0 15px;
        border-top: 1px solid #eee
    }
    .tf-flight__carddetail-content__header {
     padding: 15px;
        border-bottom: 1px solid #eee
    }
    .tf-flight__status-container{
        padding: 10px 15px;
        border-right: none;
        border-bottom: solid #eeeeee 1px;
    }
}

@media only screen and (min-width:992px) {
    .tf-flight__carddetail-content__footer {
     padding: 20px 15px 0 15px!important;
    }
}

.tf-flighttime-wrap {
    width: 100%
}

.tf-flighttime-wrap__row {
    display: -ms-flexbox;
    display: flex
}

.tf-flighttime-wrap__departingtime {
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
}

.tf-flighttime-wrap__arrivingtime {
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
    text-align: right
}

.tf-flighttime-wrap__flightline{
    display: -ms-flexbox;
    display: flex;
    -ms-flex: 0 0 auto;
    flex: 1 1 auto;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 10px 0;
}
.fml-flighttime-flightline {
    width: 100%;
    position: relative;
    align-items: center;
    justify-content: center;
    height: 2px;
    background-color: #eae9e9;
}
.fml-flighttime-flightline:before, .fml-flighttime-flightline:after{
    content: "";
    display: block;
    background-color: #fff;
    border-style: solid;
    border-width:2px;
    position: absolute;
    border-radius: 50%;
    z-index: 1;
    top: -4px;
}

.fml-flighttime-flightline:before {
    left: 0;
    width: 10px;
    height: 10px;
}
.fml-flighttime-flightline:after {
    right: 0;
    width: 10px;
    height: 10px;
}
.tf-flight__carddetail-content__footer .btn {
    border-radius: 4px;
}
.flightline-center{
    text-align: center;
    flex-grow: 1;
    flex-basis: 40%;

}
.tf-flighttime-wrap__arrivingcity,
.tf-flighttime-wrap__departingcity {

    font-weight: 400;
    color: #767676;
    display: block
}
.package-styling h5 {
    font-weight: 400;
    color: rgb(50, 50, 50);
}
@media only screen and (min-width:992px) {
    .tf-flighttime-wrap__flightline{
        padding: 0 20px 0;
    }

}

.tf-flighttime__time {
    vertical-align: baseline;
    font-weight: 400
}

.tf-flighttime__suffix {
    font-size: 67%;
    vertical-align: baseline;
    font-weight: 400
}

.tf-flighttime--large {
    font-size: 24px;
    line-height: 1
}


.tf-flighttimestatus {
    display: inline-block;
    padding: 0 0 5px 0;
}

.tf-flighttimestatus__main {
    display: block
}

.my_tf-booking {
    position: relative;
}

.tf-booking__item {
    padding-bottom: 25px;
    position: relative;
}
.tf-flight__carddetail-content__header .tf-flight-carddetail-item, .tf-flight__status-container .tf-flight-carddetail-item {
    display: block;
    margin-bottom: 10px;
    margin-right:0
}
.tf-flight__carddetail-content__header .tf-flight-carddetail-item:last-child, .tf-flight__status-container .tf-flight-carddetail-item:last-child {
    margin-bottom: 0;
}
.tf-flight__duration .btn-lg {
    font-size: 13px;
}
.trip-type{
    margin-top: -26px;
}
.-item__paxInfo {
    border-bottom-style:dotted;
    border-bottom-width: 1px;
    display: inline-block;
    cursor: pointer;
}
.trip-type:before {
 font-family: 'tf-portal' !important;
 padding-right: 5px;
}

.type-return .trip-type:before {
 content: "\f0ec";
}
.type-oneway .trip-type:before, .type-one-way .trip-type:before {
 content: "\f178";
}
span.open-booking {
    display: block;
    margin-top: 12px;
    font-size: 14px;
    position: relative;
    margin-left: 48px;
    margin-bottom: 9px;
    margin-top: 19px;
}
span.open-booking.op__no-time:before {
    font-family: 'tf-portal' !important;
    content: "\f017";
    font-style: normal;
    font-weight: normal;
    font-size: 33px;
    top: 0;
    left: -48px;
    position: absolute;
    top: -10px;
    z-index: 0;
}
span.open-booking.op__no-time:after {
	content: "?";
    font-weight: 700;
    font-size: 13px;
    color: #fff;
    text-align: center;
    display: inline-block;
    width: 24px;
    height: 24px;
    -moz-border-radius: 12px;
    -webkit-border-radius: 12px;
    border-radius: 12px;
    background-color: #a4a3a3;
    position: absolute;
    left: -28px;
    top: -4px;
    z-index: 1;
    border: solid 2px #fff;
}
.date-cancelled {
    text-decoration: line-through;
    color: #a94442;
}
.date-cancelled:after {
    display: inline-block;
    min-width: 10px;
    padding: 3px 7px;
    font-weight: 700;
    line-height: 1;
    color: #fff;
    text-align: center;
    white-space: nowrap;
    background-color: #777;
    border-radius: 10px;
    color: #a94442;
    background-color: #f2dede;
    border-color: #ebccd1;
    margin-left:5px;
    font-weight: 400;
    font-size: 90%;
}
.badge.badge-success {
 background: #4caf50;
}
.badge.badge-warning {
 background: #f0ad4e;
}
.badge.badge-danger {
 background: #d9534f
}
.badge.badge-info {
 background: #5bc0de
}
.waitlisted .tf-flight {
    background: #faf9f9;
    box-shadow: none;
}
@media only screen and (max-width: 991px) {
	.my_tf-booking span.return-flight {
		display: block;
		margin-top: 10px;
	}
}

#bookingFilter .btn, #bookingFilter .form-control {
    font-size: 12px;
    font-size: 12px;
    height: auto;
    border-color: #acabab;
    background:#fff!important
}
#bookingSearch.form-group, #bookingFilter .btn, .flightFilter .sort{
    position:relative
}
#filterOptions .btn:not(#removeFilters.btn) {
    padding-right: 25px;
}

#bookingFilter .btn span {
    color: #fff;
    padding: 4px;
    line-height: 1;
    display: inline-block;
    border-radius: 4px;
    font-size: 80%;
    margin-left: 4px;
    position: absolute;
}
#open-filter{
    padding-right: 23px;   
}
#open-filter.disabled{
    pointer-events: none;
}
#open-filter.sort:after, #open-filter.sort:before, .flightFilter .sort:before, .flightFilter .sort:after{
    content: "";
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    right: 8px;
    top: 50%;
}
#open-filter.sort:not(.desc, .asc):after, .flightFilter .sort:not(.desc, .asc):after {
    border: 4px solid transparent;
    border-bottom-color: #666;
    margin-top: -9px;
}
#open-filter.sort:not(.desc, .asc):before {
    border: 4px solid transparent;
    border-top-color: #666;
    margin-top: 1px;
}
#open-filter.sort.asc:after, .flightFilter .sort:after {
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid #666;
}
#open-filter.sort.desc:after {
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-bottom: 4px solid #666;
}
#filterOptions li{
    position:relative
}
#filterOptions .selected:active, #filterOptions .selected:hover, #filterOptions .btn-default:active:hover{
box-shadow:none
}
#filterOptions .selected:after {
    content: "";
    width: 100%;
    height: 2px;
    position: absolute;
    bottom: -1px;
    left: 0;
}
#bookingSearch.form-group input{
    width:220px;
    padding-left:30px
}
@media only screen and (max-width: 992px) {
    #bookingSearch.form-group input{
        width:100%
    }
}
#bookingSearch.form-group:before{
    content: "\f002";
    font-family: 'tf-portal' !important;
    position: absolute;
    top: 7px;
    left: 10px;
    font-size: 15px;
    color: #333333;
  }
#filterOptions i{
    color: #333333;
}
/*  Hybrid Booking Management */
    .request_approval .tf-flight__carddetail-header{
    background:#ffe7c4;
        color:#945e22
    }
    .request_approval .tf-flight {
        background-color: #fff;
        box-shadow: none;
        border: 1px solid #f5a54d;
    }
    .request_approval .fml-flighttime-flightline:before, .request_approval .fml-flighttime-flightline:after{
        border-color: #eae9e9;
    }
    .approve-action__row {
        border: 0;
        width: 100%;
    }
    .approve-action__row .btn.btn-wide-flex {
        /*flex: 1 1 auto;*/
        margin-left: 10px;
    }
    .approval-modal{
        padding: 15px;  
    }
    #default-portal.mt-0 .search-container_outter {
        margin-top: 30px;
    }

/* Booking History data table */
.bookings-table th.fit {
    white-space: nowrap;
    width: 1%;
}

.bookings-table .fit {
    white-space: nowrap;
    width: 1%;
}
.bookings-table {
	border-collapse: separate;
	border-spacing: 0 10px;
	background: #f7f7f7;
}
.bookings-table tbody tr th:first-child, .bookings-table tbody tr td:first-child {
	border-top-left-radius: 7px;
	border-bottom-left-radius: 7px;
}
.bookings-table tbody tr th:last-child, .bookings-table tbody tr td:last-child {
	border-top-right-radius: 7px;
	border-bottom-right-radius: 7px;
}
.bookings-table thead th {
	border: none;
	font-size: 12px;
}
.bookings-table tbody tr {
	margin-bottom: 10px;
	-webkit-box-shadow: 0px 5px 12px -12px rgba(0, 0, 0, 0.29);
	-moz-box-shadow: 0px 5px 12px -12px rgba(0, 0, 0, 0.29);
	box-shadow: 0px 5px 12px -12px rgba(0, 0, 0, 0.29);
    background: #fff;
}
.bookings-table tbody th, .table tbody td {
	border: none!important;
	padding-top: 20px!important;
	padding-bottom: 20px!important;
	padding-left: 15px!important;
	padding-right: 15px!important;
	font-size: 12px;
	color: #777;
	vertical-align: middle!important;
}

.bookings-table:hover td {
    cursor: default
}
.bookings-table .thead-light th {
	color: #2b323a;
	background-color: #f7f7f7;
	border-color: #f7f7f7;
}
table.dataTable thead .sorting:after, table.dataTable thead .sorting_asc:after, table.dataTable thead .sorting_desc:after, table.dataTable thead .sorting_asc_disabled:after, table.dataTable thead .sorting_desc_disabled:after {
	position: relative!important;
	bottom: -2px!important;
	display: inline!important;
	padding-left: 5px;
	right: 0!important;
}
.bookings-table span.open-booking {
	display: block;
	margin-top: 12px;
	font-size: 12px;
	position: relative;
	margin-left: 30px;
	margin-bottom: 0;
	margin-top: 10px;
}
.bookings-table span.open-booking.op__no-time:before {
	font-family: 'tf-portal' !important;
	content: "\f017";
	font-style: normal;
	font-weight: normal;
	font-size: 24px;
	top: 0;
	left: -35px;
	position: absolute;
	top: -10px;
	z-index: 0;
}
.bookings-table span.open-booking.op__no-time:after {
	content: "?";
	font-weight: 700;
	font-size: 11px;
	color: #fff;
	text-align: center;
	display: inline-block;
	width: 20px;
	height: 20px;
	-moz-border-radius: 12px;
	-webkit-border-radius: 12px;
	border-radius: 12px;
	background-color: #a4a3a3;
	position: absolute;
	left: -21px;
	top: -4px;
	z-index: 1;
	border: solid 2px #fff;
}
.dataTables_wrapper>div.row:first-child {
	background: #f1f1f1;
	padding: 20px;
	border: solid 1px #dedede;
	border-radius: 7px;
	display: flex;
}
.dataTables_wrapper>div.row:first-child label {
	margin-bottom: 0
}
.dataTables_wrapper>div.row .col-sm-6:last-child {
	display: flex;
	justify-content: flex-end!important;
}
.table.dataTable thead .sorting_asc:after {
	opacity: 0.7;
	font-weight: normal;
}
.modal-comment .modal-footer, .modal-comment .modal-header, .modal-comment .modal-body {
    border-spacing: 0;
}
.modal-comment .modal-body p{
    font-size:13px!important;
    white-space: initial;
}
.bookings-table .thead-light th.sorting_asc, .bookings-table .thead-light th.sorting_desc {
    background: #edebeb;
    border-radius: 8px;
}