/*custom font*/
@import url(//fonts.googleapis.com/css?family=Montserrat);

/*basic reset*/
* {margin: 0; padding: 0;}

html {
    height: 100%;
    /*Image only BG fallback
    background: url('../../../../uploads/media/gs.png');
    background = gradient + image pattern combo*/
}

body {
	background-color: transparent;
    font-family: montserrat, arial, verdana;
}

:invalid {
  box-shadow: none;
}

:-moz-submit-invalid {
  box-shadow: none;
}

:-moz-ui-invalid {
  box-shadow:none;
}

/* Booking Module */
.book-wrap {
	background-color: #EEEEEE;
    margin: 0 auto;
	min-height: 450px;
}

#content.book-wrap > .row {
    margin: 0;
}

#content.book-wrap > .row > .col-sm-12 {
    padding: 0;
}

.book-wrap .nav.nav-tabs > li {
    background-color: #FFFFFF;
    text-align: center;
}

.book-wrap .nav.nav-tabs > li.third {
    width: 33.3%;
}
.book-wrap .nav.nav-tabs > li.quarter {
    width: 25%;
}

.book-wrap .nav.nav-tabs > li::before {
    content: "";
}

.book-wrap .nav.nav-tabs > li a {
    border: medium none;
    border-radius: 0;
    color: #aaa;
    font-size: 20px;
	margin-right: 0;
    padding: 6px 0;
}

.book-wrap .nav.nav-tabs > li.completed a {
    background-color: #AAAAAA;
    color: #ffffff;
}

.book-wrap .nav.nav-tabs > li:last-child a, .book-wrap .nav.nav-tabs > li:nth-last-child(2) a {
    margin-right: 0;
}

.book-wrap .nav.nav-tabs > li.active a {
    background-color: #34495E;
    color: #ffffff;
}

/*.book-wrap .nav.nav-tabs > li:not(.active) a, .book-wrap .nav.nav-tabs > li:not(.completed) a {
    color: #aaa;
}*/

.reservation uib-tab-heading > span:not(.icon) {
    font-family: Montserrat;
    font-size: 12px;
}

.uib-tab.promotion-step uib-tab-heading span {
    font-size: 16px;
}
/*.reservation.book-wrap .nav.nav-tabs > li.quarter:last-child .nav-link span {
    display: block;
    line-height: 13px;
    margin: 0 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 70px;
}*/

.book-wrap .nav.nav-tabs {
    border: 1px solid #ccc;
}

.book-wrap .tab-content .tab-pane {
    background-color: #eeeeee;
	max-height: 380px;
	overflow: auto;
}

.book-wrap .shift-wrap, .book-wrap .paxpicker-wrap, .book-wrap .packages-wrap {
    padding: 10px;
}

.paxpicker-wrap > p, .packages-wrap > p {
    text-align: center;
    text-transform: uppercase;
}



/* Datepicker custom */

.book-wrap .uib-datepicker {
    background-color: transparent;
    border: medium none;
    margin-bottom: 0;
	padding: 0;
}

.book-wrap .uib-datepicker > table {
    width: 100%;
}

.uib-datepicker thead {
    border: 1px solid #34495e;
}

.uib-datepicker .uib-title {
    border-bottom: 1px solid #aaaaaa;
    font-size: 18px;
    font-weight: normal !important;
	pointer-events: none;
    text-transform: uppercase;
}

.uib-datepicker .uib-right, .uib-datepicker .uib-left {
    padding: 10px;
}

.uib-datepicker .uib-right:hover, .uib-datepicker .uib-left:hover {
	background-color: #FFFFFF;
}

.uib-datepicker thead > tr:last-child th {
    padding: 10px 0;
}

.uib-datepicker .uib-weeks .uib-day {
	background-color: #eeeeee;
    border: 1px solid #eeeeee;
}

.uib-datepicker .uib-weeks .uib-day input {
    font-size: 16px;
    min-width: 40px;
    padding: 12px 0;
    width: 100%;
}

.uib-datepicker .uib-weeks .uib-day input[disabled="disabled"] {
    background-color: #eee;
    color: #aaa;
	outline: 1px solid #cccccc;
}

.text-info {
    color: #31708f !important;
}

.uib-daypicker tbody tr td input:hover, .uib-daypicker tbody tr td input:hover span {
	color: #FFFFFF;
}

.uib-datepicker .btn-info {
    background-color: #34495e;
}

.uib-datepicker .btn-info span {
    color: #FFFFFF;
}




/* Time Picker custom */

.book-wrap .shift-wrap p {
    text-align: center;
    text-transform: uppercase;
}

.book-wrap .intervals-wrapper .action-button {
    min-width: 25%;
    background-color: #FFF;
    color: #333333;
    border-radius: 0 !important;
    border: 1px solid #DDDDDD !important;
    outline: 1px solid #DDDDDD;
	margin: 0;
	padding: 10px !important;
}

.book-wrap .intervals-wrapper .action-button:hover {
    background-color: #1abc9c;
	color: #FFFFFF;
}

.book-wrap .intervals-wrapper .action-button.selected {
	color: #FFFFFF;
}

.book-wrap .intervals-wrapper .action-button[disabled="disabled"] {
    background-color: #efefef !important;
    border-color: #efefef !important;
    color: #cccccc;
    cursor: not-allowed;
}



/* PAX Picker custom */

.paxpicker-wrap {
    text-align: center;
}

.paxpicker input {
    min-width: 25%;
    background-color: #FFF !important;
    color: #333333 !important;
    border-radius: 0 !important;
    border: 1px solid #DDDDDD !important;
    outline: 1px solid #DDDDDD;
}

.paxpicker input:hover {
    background-color: #1abc9c !important;
    color: #FFFFFF !important;
}

.paxpicker input:disabled {
    background-color: #aaaaaa !important;
    color: #ffffff !important;
    cursor: default;
}

.paxpicker input.selected {
    color: #FFFFFF !important;
}

.paxpicker select {
    border: 2px solid #dddddd;
    margin-bottom: 40px;
    margin-top: 20px;
    padding: 10px 30px;
    text-align: center;
}

.paxpicker select option {
    border-right: 2px solid #aaa;
}



.paxpicker-wrap button:hover, #reservationform > input:hover {
    background-color: #48C9B0 !important;
    box-shadow: none !important;
}

#reservationform > input:focus {
    box-shadow: none !important;
}


/* Packages Picker custom */

.book-wrap .packages-picker {
    margin-bottom: 16px;
    overflow-x: hidden;
    overflow-y: auto;
}

.book-wrap .packages-picker ul {
    max-height: 250px;
    overflow-y: auto;
    overflow-x: hidden;
}

.book-wrap .packages-picker > ul > li {
	background-color: #fff;
    border: 1px solid #cccccc;
    border-radius: 5px;
    cursor: pointer;
    margin-bottom: 10px;
    padding: 10px;
}

/*.book-wrap .packages-picker > ul > li:hover {
	background-color: #CCCCCC;
    border: 1px solid #CCCCCC;
	color: #FFFFFF ;
}*/

.book-wrap .packages-wrap .packages-picker > ul > li.selected:hover {
    color: #333333;
}

.book-wrap .packages-picker hr {
    margin: 4px 0 10px;
}

.book-wrap .packages-wrap .packages-picker .package-desc {
    color: #999999;
    font-size: 12px;
    font-style: italic;
}


.book-wrap .packages-wrap .packages-picker > ul > li.selected:hover .package-desc {
    color: #999999;
}

/*.book-wrap .packages-wrap .packages-picker > ul > li:hover .package-desc, .book-wrap .packages-wrap .packages-picker > ul > li.selected .package-desc {
    color: #FFFFFF;
}*/


.book-wrap .paxpicker-wrap button, .book-wrap .packages-wrap button, #reservationform > input, #payment-gates form button {
    background-color: #1abc9c !important;
    border: none !important;
    border-radius: 3px;
    color: #fff;
    font-size: 20px;
	margin-top: 20px;
    padding: 10px;
    text-transform: uppercase;
    transition: all 0.2s ease-in-out 0s;
    width: 100%;
}

.promotion-step button {
    font-size: 16px !important;
    text-transform: inherit !important;
}

/*.book-wrap .packages-wrap .packages-picker ul li.selected {
    background-color: #efefef !important;
    border: 4px solid #34495e !important;
}*/

.book-wrap .packages-wrap .packages-picker ul li .col-xs-3, .book-wrap .packages-wrap .packages-picker ul li .col-sm-2 {
    text-align: right;
}

.book-wrap .packages-wrap .packages-picker ul li .package-selector {
    border: 1px solid #cccccc;
    /*border-radius: 50%;*/
	display: inline-block;
    height: 30px;
    width: 30px;
}

.book-wrap .packages-wrap .packages-picker ul li:hover .package-selector {
	background-color: #1ABC9C;
    border: 1px solid #1ABC9C;
}

.book-wrap .packages-wrap .packages-picker ul li.selected .package-selector {
	background-color: #34495E;
    border: 1px solid #34495E;
}

.book-wrap .packages-wrap .packages-picker ul li .package-selector i {
    color: #eeeeee;
    display: block;
    font-size: 20px;
    line-height: 26px;
    margin: 0 auto;
    text-align: center;
}

.book-wrap .packages-wrap .packages-picker ul li.selected .package-selector i {
    color: #ffffff;
}




/* Booking complete */

#completeBooking {
    text-align: center;
}

#completeBooking > h3, .payment-resume > h3 {
    font-size: 20px;
    margin-top: 4px;
}

.client-bookingdata {
    font-size: 14px;
    line-height: 24px;
    margin-top: 10px;
    text-transform: capitalize;
}

.client-bookingdata span i {
    font-size: 20px;
    margin-left: 10px;
}



/*#completeBooking .client-bookingdata span {
    display: block;
    float: left;
    width: 50%;
}

#completeBooking .client-bookingdata span {
    display: block;
    float: left;
    width: 50%;
}

#completeBooking .client-bookingdata span:last-child {
    overflow: hidden;
    padding: 0 20px;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 50%;
}

#completeBooking .client-bookingdata span:nth-child(2n+1) {
    border-right: 2px solid #999999;
}*/

#completeBooking .client-bookingdata + p {
    margin-bottom: 50px;
}

#completeBooking .client-bookingdata + p a {
    color: #1abc9c;
}

#completeBooking #reservationform {
    display: block;
    padding: 10px;
}

#completeBooking #reservationform > .row {
    margin-bottom: 30px;
}

#completeBooking #reservationform .col-xs-6:nth-child(2n) {
    padding-left: 5px;
}

#completeBooking #reservationform .col-xs-6:nth-child(2n+1) {
    padding-right: 5px;
}


/* Success page */

.success-step {
    border: 1px solid #cccccc;
    padding: 10px;
    text-align: center;
}

.success-step h3 {
    font-size: 20px;
    margin-bottom: 30px;
}

.success-step h5 {
    color: #777;
    font-size: 16px;
    font-style: italic;
    margin-bottom: 20px;
}

.success-step h6 {
    font-size: 14px;
    text-decoration: underline;
    text-transform: uppercase;
}

.success-step p {
    color: #777777;
}

.intl-tel-input {
    display: block;
    margin-bottom: 5px;
}

.packages-picker ul li {
    list-style-type: none;
}

.uib-tab.promotion-step {
    width:100%;
}

.process-steps ul li {
    list-style-type: none;
    display: inline-block;
    border: 1px solid #bbb;
}

.process-steps li.third  {
    width: 33%
}
.process-steps li.quarter  {
    width: 24%
}
.process-steps li.active {
    background: #48C9B0;
}
.process-steps li.disabled {
    background: #bbb;
}
.process-steps li.disabled a{
    disabled:disabled
}


/* Payment page */

.payment-step {
    text-align: center;
}

.payment-resume {
    padding: 0 15px;
}

.payment-resume p span {
    display: inline-block;
    text-align: left;
    width: 50%;
}

.payment-resume p span:last-child {
    text-align: right;
}

.payment-resume p:last-child {
    border-bottom: 1px solid #cccccc;
    font-size: 20px;
    font-weight: bold;
    padding: 20px 0;
    text-align: right;
}

#payment-gates {
	padding: 15px;
}

#payment-gates form label {
    cursor: pointer;
    display: block;
    float: left;
    margin: 20px 0;
    width: 50%;
}
/* Absolute Center Spinner */
.loading2 {
  position: fixed;
  z-index: 999;
  height: 2em;
  width: 2em;
  overflow: show;
  margin: auto;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}

.loading2 {
  z-index: 990;
}

/* Transparent Overlay */
.loading2:before {
  content: '';
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #EEEEEE;
}

/* :not(:required) hides these rules from IE9 and below */
.loading2:not(:required) {
  /* hide "loading..." text */

}

.loading2:not(:required):after {
  content: '';
  display: block;
  font-size: 10px;

  margin-top: -0.5em;
  font-size: 10px;
   border-top: 1.1em solid rgba(26,188,156, 0.2);
  border-right: 1.1em solid rgba(26,188,156, 0.2);
  border-bottom: 1.1em solid rgba(26,188,156, 0.2);
  border-left: 1.1em solid #1abc9c;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation: load8 1.1s infinite linear;
  animation: load8 1.1s infinite linear;
  }
.loading2,
.loading2:after {
  border-radius: 50%;
  width: 10em;
  height: 10em;
}

/* Animation */

@-webkit-keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}



/*************** Media Queires ***************/


@media only screen and (max-device-width : 360px) and (orientation : portrait) {
	#completeBooking #reservationform > .row > .col-xs-6 {
		width: 100% !important;
	}
	
	#completeBooking #reservationform .col-xs-6:nth-child(2n) {
		padding-left: 15px;
	}

	#completeBooking #reservationform .col-xs-6:nth-child(2n+1) {
		padding-right: 15px;
	}
}