/* ACCOUNT LOGIN / PROFILE / BOOKING PAGES */


/* Booking Page Header */

/* HEADER */

#booking_header .nav_holder {
	margin-top: 5px;
}
#booking_header .nav_holder a,
#booking_header .nav_holder .help {
	font-family: "Source Sans Pro";
	font-size: 14px;
	color: #FFFFFF;
}
#booking_header .nav_holder .login_link {
	margin-right: 5px;
}
#booking_header .nav_holder #header_logo_link img {
	float: left;
	margin-top: 0;
}
#booking_header .header_content {
	float: right;
	width: calc(100% - 93px);
	height: 64px;
	height: 74px;
	margin-top: 5px;
	font-family: "Source Sans Pro SemiBold";
	font-size: 14px;
	color: #FFFFFF;
	background-color: #007DBA;
	background-color: #2172D5;
	background-color: var(--tru-blue);
}
#booking_header .heading {
	font-family: 'Montserrat';
	font-weight: 900;
	text-transform: uppercase;
	font-size: 32px;
	margin: 16px 0px 0px 21px;
	margin: 23px 0px 0px 21px;
	float: left;
}
#booking_header .right-content {
	float: right;
	line-height: 21px;
	margin-right: 19px;
	margin-top: 2px;
	margin-top: 9px;
	text-align: right;
}
#booking_header .right-content a:hover {
	text-decoration: underline;
}
#booking_header .navbar_account_links {
	margin-top: 6px;
}
#booking_header .header_content .help a {
	text-decoration: underline;
}
#booking_header .header_content .help a:hover {
	text-decoration: none;
}

/* BREADCRUMBS */

#booking .breadcrumb {
	margin-top: 26px;
	margin-bottom: 0;
}
#booking .breadcrumb ul {
	margin-bottom: 19px;
}
#booking .breadcrumbs a:hover {
	cursor: pointer;
	text-decoration: underline;
}
#booking .breadcrumbs .active:not(.divider) {
	color: rgb(255, 63, 153);
}
#booking .breadcrumbs .disabled {
	/* color: #191919; */
	color: rgb(142, 142, 142)
}

/* FOOTER */

#booking .footer_items_container {
	display: inline-block;
	width: fit-content;
}

#booking .footer_items_container a {
	font-family: "Source Sans Pro Light";
	font-size: 14px;
	color:rgb(9, 21, 27);
}

#booking .footer_logos {
	margin: 23px 0 42px;
}
#booking .footer_inner {
	margin-bottom: 0px;
	padding-bottom: 0px;
}
#booking .nav_holder .header_logo_white {
	display: none;
}
#booking .right-content-mobile {
	display: none;
}


/* Booking Page (WIP) */

.checkout_box .payment_options {
	display: inline-flex;
	width: 100%;
	justify-content: space-evenly;
	text-align: center;
	height: 160px;
	margin: 10px auto;
	margin-top: 7px;
}
.checkout_box {
	text-align: left;
	background-color: #ffffff;
	margin-top: 10px;
	padding: 0;
	margin-top: 0px;
}
.checkout_box p {
	font-family: 'Source Sans Pro Light';
	font-size: 14px;
	color: #09151B;
}
.checkout_box .tour_date_selected .selected_container {
	width: 190px;
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: left;
}
.checkout_box .tour_date_selected .selected_container .heading {
	width: 100%;
}
.checkout_box .tour_date_selected .selected_container img {
	margin-right: 5px;
}

/* Booking/Basket Page */

.basket_summary {
	font-size: 22px;
	text-transform: uppercase;
	/* margin: 40px 0; */
}
.basket_summary .previous_stage {
	display: flex;
	margin-right: 33px;
	text-align: left;
	line-height: 1em;
	height: 60px;
	width: auto;
	border-bottom: 2px solid #EEEEEE; 
	align-items: center;
}
.basket_summary div:last-of-type {
	margin-right: 0px;
}
/* .basket_summary div a {
	color: #191919;
} */
.basket_summary .spacer {
	content: "";
	position: relative;
	display: inline-block;
	width: 27px;
	border-bottom: 1px solid #191919;
}
.basket_summary span {
	display: inline-block;
	font-size: 28px;
	width: 38px;
	height: 38px;
	line-height: 34px;
	border-radius: 19px;
	color: #007DBA;
	border: 1px solid #007DBA;
	margin-bottom: 16px;
}
.basket_summary .active span {
	background-color: #007DBA;
	color: #ffffff;
}



.checkout_wrapper {
	text-align: left;
	padding-top: 25px;
}
.checkout_wrapper.empty_basket .text {
	margin-bottom: 10px;
}
.checkout_wrapper h1, .checkout_wrapper h2, .checkout_wrapper h3 {
	font-family: 'Source Sans Pro Bold';
	font-size: 22px;
	color: #191919;
}
#booking .right-column {
	text-align: left;
}
#booking .right-column .text_content {
	font-family: 'Source Sans Pro Light';
	font-size: 14px;
	line-height: 17px;
}
#booking .section_heading,
.basket_summary .previous_stage a {
	display: inline-block;
	font-family: 'Source Sans Pro SemiBold';
	font-size: 20px;
	margin: 0;
	color: #09213E;
	vertical-align: middle;
}
.basket_summary .previous_stage:before {
	content: '';
	display: inline-block;
	background-image: url('/images/new-site-icons-23/checkbox-ticked.png');
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center;
	width: 16px;
	height: 16px;
	margin-right: 12px;
	vertical-align: middle;
}
#booking .section_heading {
	margin-bottom: 24px;
}
.checkout_wrapper .swiper-button-prev {
	left: 0px;
}
.checkout_wrapper .swiper-button-next {
	right: 0px;
}
.checkout_wrapper .ap_autocomplete_trigger {
	display: block;
	position: absolute;
	top: 37px;
	right: 40px;
}

.checkout_wrapper input[type=checkbox].checkbox_input {
	height: 16px;
	width: 16px!important;
	vertical-align: middle;
	border: none;
	background-position: center top;
}

/* Generic Form Settings */

hr {
	height: 1px;
	background-color: rgb(238, 238, 238);
	border: none;
}
hr:first-of-type {
	margin-top: 10px;
}
hr:last-of-type {
	margin: 10px 0;
}
.form_wrapper div.twin_col {
	width: 280px;
	padding-right: 20px;
	box-sizing: content-box;
}
.form_wrapper div.single_col {
	width: 140px;
	float: left;
	padding-right: 0px;
	box-sizing: border-box;
}
.register_during_checkout_message {
	color: var(--primary-color);
	font-size: 16px;
	line-height: 18px;
	margin-bottom: 6px;
}
.register_during_checkout_message ~ .input_holder .password_input_help .show_hide .eye {
	top: 44px;
	right: 25px;
}
/* .form_container, .forgotten_password_form { */
.form_container {
	max-width: 500px;
	margin: 0 auto;
}
.form_container.register, .form_container.modify_profile {
	max-width: 750px;
	margin: 0 auto;
}
.input_holder {
	position: relative;
}
.checkout_buttons, .account_buttons {
	margin-top: 10px;
	width: 100%;
}
.checkout_buttons input[type=submit] {
	width: auto;
}
.account_buttons .submit {
	background-color: #ffffff;
	width: 90px;
	height: 40px;
	padding: 12px 16px;
	font-family: 'Source Sans Pro SemiBold';
	font-size: 14px;
	text-transform: uppercase;
	color: var(--primary-color);
	border: 1px solid var(--primary-color);
	border-radius: 10px;
	cursor: pointer;
	transition: all .4s ease-in-out;
	line-height: 1px;
	min-width: 195px;
}
.account_buttons .submit:hover {
	color: #ffffff;
	background-color: var(--primary-color);
}
.forgotten_password .checkout_buttons input[type=submit] {
	margin-top: 10px;
}
.return_button_container {
	float: left;
}

/* ACCOUNT SECTION */
.account_welcome_top {
	font-family: 'Source Sans Pro';
	font-size: 18px;
	line-height: 20px;
	color: var(--primary-text-color);
}
.account_welcome_top .fullname {
	font-weight: normal;
	font-family: 'Source Sans Pro Bold';
	font-size: 36px;
	line-height: 60px;
	margin-bottom: 10px;
}

/* vip status styling */
.account_welcome_top .vip_query_help_text {
	margin-bottom: 15px;
}
.account_welcome_top .club_status {
	font-size: 14px;
	line-height: 19px;
}
.account_welcome_top .club_status .level {
	font-size: 18px;
	line-height: 20px;
}
.account_welcome_top .club_status svg {
	vertical-align: middle;
}
.account_welcome_top .club_status .level svg {
	width: 27px;
	height: 27px;
	margin-right: 6px;
}
.account_welcome_top .club_status .club_status svg path#DAYS-DONE-ICON {
	fill: #E25D96;
}
.account_welcome_top .level_info {
	margin: 12px auto 18px auto;
}
.account_welcome_top .level_info img {
	display: inline-block;
	max-width: 192px;
}
.account_welcome_top .level_info .level_inner {
	display: inline-block;
	width: calc(100% - 212px);
	margin-left: 20px;
	vertical-align: top;
}
.account_welcome_top .level_info .level_inner img.mobile {
	display: none;
}
.account_welcome_top .status_bar {
	font-size: 12px;
	width: 500px;
}
.account_welcome_top .status_bar .result {
	margin: 36px 0 20px 0;
}
.account_welcome_top .status_bar .result, .account_welcome_top .status_bar .result .result_bar {
	position: relative;
	height: 12px;
	border-radius: 6px;
	background-color: #F6F9FD;
}
.account_welcome_top .status_bar .result .level_names svg {
	position: absolute;
	top: -5px;
	right: -2px;
	width: 20px;
	height: 20px;
	z-index: 1;
}
.account_welcome_top .status_bar .result .level_names div .name, .account_welcome_top .status_bar .result .level_names div .number {
	position: relative;
}
.account_welcome_top .status_bar .result .level_names div .name {
	top: -25px;
}
.account_welcome_top .status_bar .result .level_names div.right {
	right: 0;
	text-align: right;
}
.account_welcome_top .club_status .status_bar .result .result_bar {
	position: absolute;
	top: 0;
	width: 80%;
	background-color: #E25D96;
}
.account_welcome_top .club_status.pre .status_bar .result .level_names .level1 svg path#DAYS-DONE-ICON {
	fill: #E25D96!important;
}
.account_welcome_top .status_bar .result .level_names .left, .account_welcome_top .status_bar .result .level_names .right, .account_welcome_top .status_bar .result .vip_no {
	position: absolute;
}
.account_welcome_top .status_bar .result .number {
	top: -5px;
	left: 0;
}
.account_welcome_top .status_bar .result .vip_no {
	width: max-content;
	right: 18px;
	top: -2px;
	font-family: 'Source Sans Pro Bold';
	line-height: 16px;
	font-size: 13px;
	color: #ffffff;
	text-shadow: 0px 0px 1px #000000;
}
.account_welcome_top .club_status.pre.no_days .status_bar .result .vip_no, .account_welcome_top .club_status.min_level .status_bar .result .vip_no {
	right: unset;
	left: 3px;
	color: var(--primary-text-color);
	text-shadow: none;
}
.account_welcome_top .welcome_text {
	font-weight: normal;
	margin: 30px auto;
}
/* travel credit display */
.account_welcome_top.has_travel_credit .account_details {
	float: left;
	width: 69%;
}
.account_welcome_top.has_travel_credit .account_details.right {
	float: right;
	width: 29%;
	padding-left: 2%;
}
.account_welcome_top .travel_credit {
	font-size: 18px;
	line-height: 20px;
	margin-top: 6px;
}
.account_welcome_top .travel_credit .heading {
	font-family: 'Source Sans Pro Bold';
	font-family: 'Montserrat';
	font-weight: 900;
	margin-bottom: 10px;
}
.account_welcome_top .travel_credit .amount_box {
	border: 1px solid #efefef;
	border-radius: 10px;
	display: flex;
	max-width: 300px;
	align-items: center;
	font-size: 16px;
	text-transform: uppercase;
}
.account_welcome_top .travel_credit .amount_box > * {
	width: 50%;
	padding: 10px 18px 10px 10px;
	font-family: 'Source Sans Pro SemiBold';
}
.account_welcome_top .travel_credit .amount_box .right {
	background-color: #F6F9FD;
	text-transform: none;
	padding: 14px 10px 14px 15px;
}
.account_welcome_top .travel_credit .amount_box .amount {
	display: block;
	font-family: 'Source Sans Pro Bold';
	font-size: 30px;
	line-height: 32px;
}
.account_welcome_top .travel_credit .amount_box .expiry {
	font-family: 'Source Sans Pro Light';
	font-size: 12px;
	line-height: 14px;
}
/* end of travel credit display */

.account_welcome_top .club_status.level1 svg path#DAYS-DONE-ICON {
	fill: #E25D96!important;
}
.account_welcome_top .club_status.level1 .status_bar .result .level_names .level2 svg path#DAYS-DONE-ICON {
	fill: #6CBEDC!important;
}
.account_welcome_top .club_status.level1 .status_bar .result .result_bar {
	background-color: #E25D96;
}

.account_welcome_top .club_status.level2 svg path#DAYS-DONE-ICON {
	fill: #6CBEDC!important;
}
.account_welcome_top .club_status.level2 .status_bar .result .level_names .level3 svg path#DAYS-DONE-ICON {
	fill: #F9C213!important;
}
.account_welcome_top .club_status.level2 .status_bar .result .result_bar {
	background-color: #6CBEDC;
}


.account_welcome_top .club_status.level3 svg path#DAYS-DONE-ICON {
	fill: #F9C213!important;
}
.account_welcome_top .club_status.level3 .status_bar .result .level_names .level4 svg path#DAYS-DONE-ICON {
	fill: #A046A3!important;
}
.account_welcome_top .club_status.level3 .status_bar .result .result_bar {
	background-color: #F9C213;
}


.account_welcome_top .club_status.level4 svg path#DAYS-DONE-ICON {
	fill: #A046A3!important;
}
.account_welcome_top .club_status.level4 .status_bar .result .level_names .level4 svg path#DAYS-DONE-ICON {
	fill: #A046A3!important;
}
.account_welcome_top .club_status.level4 .status_bar .result .result_bar {
	background-color: #A046A3;
}


.account_welcome_top .club_status .more_info .heading {
	cursor: pointer;
	width: max-content;
}
.account_welcome_top .club_status .more_info .heading:before, .account_welcome_top .club_status .more_info .heading:after {
	content: "";
	display: inline-block;
	background-image: url('/images/new-site-icons-23/information-icon.png');
	background-size: 100% auto;
	background-repeat: no-repeat;
	width: 12px;
	height: 12px;
}
.account_welcome_top .club_status .more_info .heading:after {
	background-image: url('/images/new-site-icons-23/expand-icon-alt.png');
	margin: 0 0 0 4px;
	height: 6px;
	transition: transform .4s ease-in-out;
}
.account_welcome_top .club_status .more_info.open .heading:after {
	transform: rotate(-180deg);
}
.account_welcome_top .club_status .more_info .more_info_inner {
	max-height: 0;
	overflow: hidden;
	margin-top: 0;
	transition: max-height .4s ease-in-out, margin-top .4s ease-in-out;
}
.account_welcome_top .club_status .more_info.open .more_info_inner {
	max-height: 300px;
	margin-top: 20px;
}
.account_welcome_top .club_status .more_info ul {
	list-style-position: inside;
}
.account_welcome_top .club_status .more_info ul li::marker {
	color: #E25D96;
}
/* end of vip status styling */
/* -------------- */

/* login with google or fb */
#account .login-with-outer.account-forms {
	margin-top: 10px;
}
#account .login-with-outer.account-forms .login-with-inner {
	display: inline-flex;
	margin: 0 auto;
}
#account .login-with-outer.account-forms .login-with-inner .login-with-option {
	float: none;
	margin: 7px 0px 0px 0px;
}
#account .login-with-outer.account-forms .login-with-inner .login-with-option:first-of-type {
	margin-right: 74px;
}
/* ----------------------- */

.ap_messages {
	color: var(--primary-text-color);
	font-family: "Source Sans Pro";
	font-size: 16px;
}
.ap_messages .ap_legend {
	display: none;
}
.forgotten_password_form .checkout_buttons input[type=submit] {
	margin-top: 10px;
}
.reset_password_password_holder .ap_label,
.reset_password_confirm_password_holder .ap_label {
	font-family: 'Source Sans Pro SemiBold';
	color: rgb(9,33,62);
	font-size: 14px;
	width: 100%;
}

/* Travellers */
.checkout_box.qty_box {
	border: 1px solid var(--primary-text-color);
    border-radius: 10px;
    margin-bottom: 40px;
    padding: 10px 19px;
	display: flex;
	justify-content: space-between;
	min-height: 59px;
	align-items: center;
}
.checkout_box.qty_box .heading {
	display: inline-block;
	/* line-height: 37px; */
	display: inline-block;
    line-height: unset;
    vertical-align: middle;
}
.checkout_box.qty_box .qty_adj {
	float: none;
}
.qty_box .qty_holder:before {
	content:"";
	display: inline-block;
	width: 35px;
	height: 26px;
	background: 0 0 url('/images/new-site-icons-23/number-of-travellers-icon.png');
	background-size: contain;
	background-repeat: no-repeat;
	position: relative;
	/* top: 7px; */
	margin-right: 10px;
}
.qty_box .qty_holder {
	display: inline-flex;
	align-items: center;
	float: right;
}
.qty_box .qty_adj {
	float: none;
	height: 16px;
}
.qty_box .input_holder {
	display: inline-block;
	padding: 0 17px;
}
.qty_box .ap_input.number_input {
	color: var(--primary-color);
	border-width: 2px;
	border-radius: 4px;
	text-align: center;
	float: none;
	margin: 0;
	-webkit-appearance: textfield;
	-moz-appearance: textfield;
	appearance: textfield;
}
.qty_box .ap_input.number_input, .pre_tour_acc .pretour_input_holder .ap_input,
.qty_box .ap_input.number_input, .pre_tour_acc .posttour_input_holder .ap_input {
	font-family: 'Source Sans Pro Bold';
	height: 25px;
}

/* View Cart / Edit Cart */
.tour_info_box {
	padding: 0;
}
.basket_tour_item {
	position: relative;
	padding-bottom: 15px;
	margin-bottom: 15px;
	font-family: 'Source Sans Pro';
	font-size: 18px;
	line-height: 26px;
	color: var(--primary-text-color);
}
.basket_tour_item_left {
	float: left;
	width: 272px;
	margin-right: 25px;
	position: relative;
	max-width: 100%;
}
.basket_tour_item_right {
	float: right;
	width: calc(100% - 297px);
	font-size: 14px;
}
.checkout_box .basket_tour_item_right .right_inner_top {
	margin-top: 19px;
}
.basket_tour_item_right .srs_input_wrapper {
	margin-top: 20px;
	padding-bottom: 15px;
	border-bottom: 1px solid #EEEEEE;
}
.basket_tour_item_right .heading {
	font-family: 'Source Sans Pro SemiBold';
	font-weight: normal;
}

.checkout_wrapper .not-available {
	margin-top: 10px;
}
.checkout_wrapper .not-available p {
	padding-top: 5px;
}

.checkout_wrapper .pre_tour_acc {
	padding-top: 20px;
	margin-top: 10px;
}
.checkout_wrapper .pre_tour_acc.post_tour {
	padding-top: 0px;
	margin-top: 0px;
}
.checkout_wrapper .pre_tour_acc .subheading, .pre_tour_acc .pretour_input_holder, .pre_tour_acc .posttour_input_holder, .checkout_wrapper .pre_tour_acc .subheading {
	font-family: 'Source Sans Pro';
	font-weight: normal;
}
.checkout_wrapper .pre_tour_acc .subheading, .checkout_wrapper .pre_tour_acc .subheading {
	display: inline-block;
	cursor: context-menu;
}
.checkout_wrapper .pre_tour_acc .pre-tour-checkbox {
	margin-top: 7px;
}
.checkout_wrapper .pre_tour_acc .pre-tour-checkbox div {
	display: inline-block;
	height: 16px;
	width: 16px;
	padding: 1px;
	background-color: #ffffff;
	cursor: pointer;
	background-size: 16px 16px;
	background-repeat: no-repeat;
	background-image: url('/images/new-site-icons-23/checkbox.png');
	margin-right: 6px;
	margin-left: 1px;
	vertical-align: sub;
}
.checkout_wrapper .pre_tour_acc .pre-tour-checkbox.checked div {
	background-image: url('/images/new-site-icons-23/checkbox-ticked.png');
}
.checkout_wrapper .pre_tour_acc .pre-tour-checkbox ~ .pretour_accom_outer {
	max-height: 0px;
	overflow: hidden;
	transition: max-height .4s ease-in-out;
}
.checkout_wrapper .pre_tour_acc .pre-tour-checkbox.checked ~ .pretour_accom_outer {
	max-height: 600px;
}

.checkout_wrapper .pre_tour_acc .post-tour-checkbox {
	margin-top: 7px;
}
.checkout_wrapper .pre_tour_acc .post-tour-checkbox div {
	display: inline-block;
	height: 16px;
	width: 16px;
	padding: 1px;
	background-color: #ffffff;
	cursor: pointer;
	background-size: 16px 16px;
	background-repeat: no-repeat;
	background-image: url('/images/new-site-icons-23/checkbox.png');
	margin-right: 6px;
	margin-left: 1px;
	vertical-align: sub;
}
.checkout_wrapper .pre_tour_acc .post-tour-checkbox.checked div {
	background-image: url('/images/new-site-icons-23/checkbox-ticked.png');
}
.checkout_wrapper .pre_tour_acc .post-tour-checkbox ~ .posttour_accom_outer {
	max-height: 0px;
	overflow: hidden;
	transition: max-height .4s ease-in-out;
}
.checkout_wrapper .pre_tour_acc .post-tour-checkbox.checked ~ .posttour_accom_outer {
	max-height: 600px;
}

.pre_tour_acc .pretour_input_holder .ap_input, .pre_tour_acc .posttour_input_holder .ap_input, .pretour_accom_outer .qty_adj {
	height: 21px;
}
.pre_tour_acc .pretour_input_holder,
.pre_tour_acc .posttour_input_holder {
	padding-left: 30px;
}
.pretour_accom_outer .qty_adj {
	float: left;
	background-position: center;
}
/* .pretour_accom_outer .qty_adj:first-of-type {
	margin-left: 20px;
} */
/* .pre_tour_acc .pretour_input_holder .ap_input,
#booking .pre-tour-rooms-outer .qty_adj
{
	margin-top: 34px;
} */
/* #booking .pre-tour-rooms-outer .qty_adj.add {
	margin-right: 30px;
} */

.pre_tour_acc .intro_text {
	margin: 8px 0 16px 0;
}
.pre_tour_acc .intro_text p {
	font-style: normal;
	font-weight: normal;
}
.pre_tour_acc .intro_text p strong, .pre_tour_acc .pretour_input_holder b, .pre_tour_acc .posttour_input_holder b, .room_type b {
	font-family: 'Source Sans Pro SemiBold';
	font-weight: normal;
}
.pre_tour_acc .input_holder {
	float: left;
	margin-right: 40px;
}
.pre_tour_acc .pre-tour-rooms-outer {
	border-top: 1px dashed #EEEEEE;
	margin-top: 12px;
	padding-top: 11px;
}
.pre_tour_acc .pre-tour-rooms-outer .number_container {
	margin-right: 40px;
}
/* .pre_tour_acc .pre-tour-rooms-outer .input_holder {
	width: 30px;
	overflow: visible;
} */
.pre_tour_acc .input_holder .ap_label {
	float: none;
	display: block;
	padding-right: 8px;
	padding-bottom: 0;
	margin-left: 5px;
}
.pre_tour_acc .disabled_input {
	padding: 10px;
	line-height: 25px;
	font-size: 15px;
	background-color: transparent;
	border: 0px;
}
.pre_tour_acc .pretour_price_holder {
	margin-top: 20px;
	padding: 5px 0 0;
	text-align: right;
	border-top: 1px dashed #EEEEEE;
	margin-bottom: 10px;
}
.pre_tour_acc .pretour_price {
	display: inline-block;
	margin-left: 5px;
}

.tour_image {
	width: 100%;
	height: 153px;
	position: relative;
	overflow: hidden;
	border-radius: 10px;
}
.tour_image img {
	object-fit: cover;
    object-position: center;
	min-width: 100%;
	min-height: 100%;
	width: 100%;
	height: auto;
	margin: auto;
	top: -1000px;
	bottom: -1000px;
	left: -1000px;
	right: -1000px;
	position: absolute;
}
.tour_description {
	font-family: 'Source Sans Pro Light';
	font-size: 14px;
	line-height: 17px;
	margin: 15px auto 11px auto;
}

.basket_tour_item .message {
	line-height: 20px;
}
.basket_tour_item .item_heading, .qty_box .heading {
	font-family: 'Source Sans Pro Bold';
	font-size: 20px;
	line-height: 20px;
}
.basket_tour_item .tour_qty {
	font-size: 20px;
	font-weight: bold;
}

/* Edit Dates (Calendar) page */
.checkout_wrapper.calendar_container {
	width: 700px;
	max-width: 100%;
}
.checkout_wrapper.calendar_container .swiper-container {
	height: 290px;
	width: 700px;
	max-width: 100%;
}

/* Passenger Details Page */
.traveller_details .ap_label {
	font-family: 'Source Sans Pro SemiBold';
	letter-spacing: 0.25px;
	padding-bottom: 5px;
	color: var(--primary-text-color);
}
.traveller_details .ap_input:not(.ap_help) {
	height: 34px;
	border-radius: 8px;
}
.traveller_details .cds {
	margin-top: -4px;
}
.traveller_details .cds.has-value {
	background-image: none;
}
.traveller_details .input_holder {
	margin-bottom: 20px;
	float: left;
}
.traveller_details .pax_email_holder_outer {
	border-bottom: 2px solid #EEEEEE;
	padding-bottom: 5px;
	margin-bottom: 10px;
	width: 100%;
}
.traveller_details .block_input {
	pointer-events: none;
	opacity: 0.5;
}
.traveller_details .ap_autocomplete_clear {
	display: none;
}
.checkout_wrapper .traveller_details .ap_autocomplete_trigger {
	top: 33px;
}
.traveller_details .sub_heading {
	font-family: "Source Sans Pro SemiBold";
	color: var(--primary-text-color);
	font-size: 20px;
	font-weight: normal;
}
.traveller_details .help_text {
	color: var(--primary-text-color);
	font-size: 12px;
	display: block;
}
.traveller_details .help_text p {
	display: inline-block;
}
.traveller_details .help_text:after {
	content: '';
	width: 12px;
	height: 12px;
	display: inline-block;
	background-image: url('/images/new-site-icons-23/information-i-icon.png');
	background-size: 12px;
	vertical-align: middle;
	margin-left: 5px;
}
.traveller_details .input_group.contact {
	border-bottom: 2px solid #EEEEEE;
	margin-bottom: 25px;
	padding-bottom: 20px;
}

/* Your Trip summary side bar */
.trip-items {
	display: flex;
	flex-wrap: wrap;
}
.trip_summary_card { 
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 2px solid #EEEEEE;
	/* max-width: 340px; */
	
	flex-grow: 1;
}
.trip_summary_card .name {
	font-family: "Source Sans Pro SemiBold";
	font-size: 20px;
	color: var(--primary-text-color);
	margin-bottom: 8px;

}
.trip_summary_card .contents {
	display: flex;
}
.trip_summary_card .tour_image_container {
	width: 110px;
}
.trip_summary_card .tour_image {
	width: 110px;
	height: 110px;
}
.trip_summary_card .details {
	font-family: "Source Sans Pro";
	font-size: 14px;
	color: var(--primary-text-color);
	padding-top: 5px;
	margin-left: 10px;
}
.trip_summary_card .details * {
	display: inline-block;
	vertical-align: middle;
}
.trip_summary_card .details div {
	line-height: 10px;
	margin-bottom: 15px;
	display: block;
}
.trip_summary_card .details img {
	width: 15px;
	margin-right: 5px;
}

/* Make Payment Popup Form */
#payment_popup {
	position: fixed;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	z-index: 1000;
	background-color: rgba(0, 0, 0, 0.5);
	font-family: 'Source Sans Pro';
	font-size: 12px;
	text-align: center;
}
#payment_popup.show {
	display: block!important;
}
#payment_popup .payment_inner {
	background-color: #ffffff;
	position: relative;
	margin: 0 auto;
	top: 50%;
	transform: translateY(-50%);
	width: 398px;
	height: auto;
	border-radius: 10px;
	z-index: 2;
	text-align: center;
	padding: 45px 40px 20px 40px;
	overflow: hidden;
}
#payment_popup .payment_inner .close_payment_box {
	display: block;
	background-image: url('/images/new-site-icons-23/exit-x-icon.png');
	background-repeat: no-repeat;
	background-size: 16px;
	width: 16px;
	height: 16px;
	position: absolute;
	top: 10px;
	right: 10px;
	cursor: pointer;
}
#payment_popup .payment_popup_heading {
	font-family: 'Source Sans Pro SemiBold';
	font-size: 14px;
	text-transform: uppercase;
	margin-bottom: 20px;
}
#payment_popup .content {
	text-align: left;
}
#payment_popup .input_amount {
	margin: 24px auto 40px auto; 
}
#payment_popup .action-button {
	float: none;
	color: var(--primary-color);
	background-color: #ffffff;
	margin: 15px auto 0 auto;
	padding: 5px;
	width: 130px;
	height: 38px;
	border: 2px solid var(--primary-color);
}
#payment_popup .action-button:hover {
	color: #ffffff;
	background-color: var(--primary-color);
}
#payment_popup .currency_input_symbol:before {
	height: 40px;
	line-height: 28px;
	background-color: transparent;
}
/* ----------------- */


/* prenight button */
.account_booking_tours .account-tour-card-summary.pre_night_available {
	float: left;
}
.account_booking_overview.mobile .tour_card_row.account_booking_tours .account-tour-card-summary.pre_night_available {
	float: none;
}
.account_booking_tours .prenight_button {
	width: 268px;
	padding-left: 8px;
	float: right;
}
/* prenight button on request with message */
.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message {
	width: calc(100% - 393px);
	width: calc(100% - 268px);
}
.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message ~ .prenight_button {
	width: 393px;
	width: 268px;
	text-align: center;
	text-align: left;
}
/* --- */
.account_booking_tours .prenight_button .button {
	float: none;
	margin: 0;
	margin-top: 50px;
	width: auto;
	min-width: 130px;
  	padding: 0px 10px;
}
.account_booking_tours .prenight_button .button.payment_popup_link_disabled {
	background-color: #6E6E6E;
	border-color: #6E6E6E;
	text-align: center;
	line-height: 33px;
	color: #ffffff;
	cursor: not-allowed;
	margin-right: 5px;
}
.account_booking_tours .prenight_button .payment_popup_link_disabled_message {
	font-size: 12px;
	line-height: 12px;
	margin-top: 5px;
	width: calc(100% - 135px);
	width: 100%;
	vertical-align: middle;
	text-transform: none;
}
.account_booking_tours .prenight_button .payment_popup_link_disabled_message, .account_booking_tours .prenight_button .payment_popup_link_disabled_message a {
	color: #6E6E6E;
}
.account_booking_tours .prenight_button .payment_popup_link_disabled_message a {
	text-decoration: underline;
}
.account_booking_tours .prenight_button .payment_popup_link_disabled_message a:hover {
	text-decoration: none;
}
.account_booking_tours .prenight_button .button ~ br {
	display: none;
}
.account_booking_overview.mobile .tour_card_row.account_booking_tours .prenight_button, .account_booking_overview.mobile .tour_card_row.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message ~ .prenight_button {
	width: 100%;
	padding: 0;
	margin: -4px auto 30px auto;
	float: none;
}
.account_booking_overview.mobile .tour_card_row.account_booking_tours .prenight_button:last-of-type {
	margin-bottom: 0;
}
.account_booking_overview.mobile .tour_card_row.account_booking_tours .prenight_button .button {
	width: 100%;
	max-width: unset;
	height: 40px;
	margin: 0 auto;
	border-radius: 5px;
	font-size: 14px;
}
.account_booking_overview.mobile .tour_card_row.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message ~ .prenight_button {
	margin: -4px auto 5px auto;
}
.account_booking_overview.mobile .tour_card_row.account_booking_tours .prenight_button .button.payment_popup_link_disabled {
	line-height: 37px;
}
/* Make prenight Popup Form */
.prenight_popup, .postnight_popup {
	position: fixed;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	z-index: 1000;
	background-color: rgba(0, 0, 0, 0.5);
	font-family: 'Source Sans Pro';
	font-size: 12px;
	text-align: center;
}
.prenight_popup.show, .postnight_popup.show {
	display: block!important;
}
.prenight_popup .prenight_inner, .postnight_popup .postnight_inner {
	background-color: #ffffff;
	position: relative;
	margin: 0 auto;
	top: 50%;
	transform: translateY(-50%);
	width: 398px;
	height: auto;
	border-radius: 10px;
	z-index: 2;
	font-size: 14px;
	line-height: 26px;
	text-align: center;
	padding: 45px 40px 20px 40px;
	overflow: hidden;
}
.prenight_popup .prenight_inner .subheading, .postnight_popup .postnight_inner .subheading {
	text-align: center;
	font-size: 16px;
}
.prenight_popup .prenight_inner .close_prenight_box, .postnight_popup .postnight_inner .close_postnight_box  {
	display: block;
	background-image: url('/images/new-site-icons-23/exit-x-icon.png');
	background-repeat: no-repeat;
	background-size: 16px;
	width: 16px;
	height: 16px;
	position: absolute;
	top: 10px;
	right: 10px;
	cursor: pointer;
}
.prenight_popup .prenight_popup_heading, .postnight_popup .postnight_popup_heading {
	font-family: 'Source Sans Pro SemiBold';
	font-size: 14px;
	text-transform: uppercase;
	margin-bottom: 20px;
}
.prenight_popup .qty_adj, .postnight_popup .qty_adj {
	display: inline-block;
	width: 16px;
	height: 16px;
	background-image: url('/images/new-site-icons-23/remove-pax.png');
	background-repeat: no-repeat;
	background-size: 16px;
	font-weight: bold;
	line-height: 16px;
	text-align: center;
	cursor: pointer;
}
.prenight_popup .qty_adj.add, .postnight_popup .qty_adj.add {
	background-image: url('/images/new-site-icons-23/add-pax.png');
}
.prenight_popup .number_container, .postnight_popup .number_container {
	display: flex;
	margin: 8px 0px 4px 0px;
}
.prenight_popup .number_container:first-of-type, .postnight_popup .number_container:first-of-type {
	margin-bottom: 12px;
}
.prenight_popup .number_container:last-of-type, .postnight_popup .number_container:last-of-type {
	margin-bottom: 0;
}
.prenight_popup .number_container .input_holder, .postnight_popup .number_container .input_holder {
	display: inline-block;
	margin: 0;
}
.prenight_popup .number_container label, .postnight_popup .number_container label {
	line-height: 16px;
}
.prenight_popup .ap_input.number_input, .postnight_popup .ap_input.number_input {
	font-family: 'Source Sans Pro Bold';
	width: 45px;
	height: 21px;
	padding: 0 8px;
	margin: 0;
	text-align: center;
	color: var(--primary-color);
	-moz-appearance: textfield;
	-webkit-appearance: textfield;
}
.prenight_popup .pretour_accom_outer, .postnight_popup .posttour_accom_outer {
	text-align: left;
}
.prenight_popup .input_amount, .postnight_popup .input_amount {
	margin: 24px auto 40px auto; 
}
.prenight_popup .pre-tour-rooms-outer, .postnight_popup .pre-tour-rooms-outer {
	border-top: 1px dashed #EEEEEE;
	margin-top: 12px;
	padding-top: 11px;
}
.prenight_popup .pre-tour-rooms-outer .number_container, .postnight_popup .pre-tour-rooms-outer .number_container {
	display: inline-flex;
	margin: 8px 17px 4px 0px;
}
.prenight_popup .action-button, .postnight_popup .action-button {
	float: none;
	color: var(--primary-color);
	background-color: #ffffff;
	margin: 15px auto 0 auto;
	padding: 5px;
	width: 130px;
	height: 38px;
	border: 2px solid var(--primary-color);
}
.prenight_popup .action-button:hover, .postnight_popup .action-button:hover {
	color: #ffffff;
	background-color: var(--primary-color);
}
.prenight_popup .currency_input_symbol:before, .postnight_popup .currency_input_symbol:before {
	height: 40px;
	line-height: 28px;
	background-color: transparent;
}
.prenight_popup .pretour_price_holder, .postnight_popup .posttour_price_holder {
	/* margin-top: 20px; */
	padding: 5px 0 0;
	text-align: right;
	border-top: 1px dashed #EEEEEE;
}
.prenight_popup .pretour_price_holder .pretour_price, .postnight_popup .posttour_price_holder .posttour_price {
	color: var(--primary-color);
	font-family: 'Source Sans Pro Bold';
	line-height: 14px;
	font-size: 14px;
	display: inline-block;
	margin-left: 5px;
}
.prenight_popup .submit.action-button, .postnight_popup .submit.action-button {
	margin: 0 auto;
	width: 120px;
	height: 40px;
	font-size: 16px;
	line-height: 20px;
	color: #ffffff;
}
/* ----------------- */
/* Make transport Popup Form */
.transport_popup {
	position: fixed;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	z-index: 1000;
	background-color: rgba(0, 0, 0, 0.5);
	font-family: 'Source Sans Pro';
	font-size: 12px;
	text-align: center;
}
.transport_popup.show {
	display: block!important;
}
.transport_popup .transport_inner {
	background-color: #ffffff;
	position: relative;
	margin: 0 auto;
	top: 50%;
	transform: translateY(-50%);
	width: 398px;
	max-width: 100%;
	height: auto;
	border-radius: 10px;
	z-index: 2;
	font-size: 14px;
	line-height: 26px;
	text-align: center;
	padding: 45px 40px 20px 40px;
	overflow: hidden;
}
.transport_popup .transport_inner .subheading {
	text-align: center;
	font-size: 16px;
}
.transport_popup .transport_inner .close_transport_box {
	display: block;
	background-image: url('/images/new-site-icons-23/exit-x-icon.png');
	background-repeat: no-repeat;
	background-size: 16px;
	width: 16px;
	height: 16px;
	position: absolute;
	top: 10px;
	right: 10px;
	cursor: pointer;
}
.transport_popup .transport_inner .text {
	margin-bottom: 10px;
}
.transport_popup .transport_popup_heading {
	font-family: 'Source Sans Pro SemiBold';
	font-size: 14px;
	text-transform: uppercase;
	margin-bottom: 20px;
}
.transport_popup .qty_adj {
	display: inline-block;
	width: 16px;
	height: 16px;
	background-image: url('/images/new-site-icons-23/remove-pax.png');
	background-repeat: no-repeat;
	background-size: 16px;
	font-weight: bold;
	line-height: 16px;
	text-align: center;
	cursor: pointer;
}
.transport_popup .qty_adj.add {
	background-image: url('/images/new-site-icons-23/add-pax.png');
}
.transport_popup .number_container {
	display: flex;
	margin: 8px 0px 4px 0px;
}
.transport_popup .number_container:first-of-type {
	margin-bottom: 12px;
}
.transport_popup .number_container:last-of-type {
	margin-bottom: 0;
}
.transport_popup .number_container .input_holder {
	display: inline-block;
	margin: 0;
}
.transport_popup .number_container label {
	line-height: 16px;
}
.transport_popup .ap_input.number_input {
	font-family: 'Source Sans Pro Bold';
	width: 45px;
	height: 21px;
	padding: 0 8px;
	margin: 0;
	text-align: center;
	color: var(--primary-color);
	-moz-appearance: textfield;
	-webkit-appearance: textfield;
}
.transport_popup .pretour_accom_outer {
	text-align: left;
}
.transport_popup .input_amount {
	margin: 24px auto 40px auto; 
}
.transport_popup .pre-tour-rooms-outer {
	border-top: 1px dashed #EEEEEE;
	margin-top: 12px;
	padding-top: 11px;
}
.transport_popup .pre-tour-rooms-outer .number_container {
	display: inline-flex;
	margin: 8px 17px 4px 0px;
}
.transport_popup .action-button {
	float: none;
	color: var(--primary-color);
	background-color: #ffffff;
	margin: 15px auto 0 auto;
	padding: 5px;
	width: 130px;
	height: 38px;
	border: 2px solid var(--primary-color);
}
.transport_popup .action-button:hover {
	color: #ffffff;
	background-color: var(--primary-color);
}
.transport_popup .currency_input_symbol:before {
	height: 40px;
	line-height: 28px;
	background-color: transparent;
}
.transport_popup .pretour_price_holder {
	/* margin-top: 20px; */
	padding: 5px 0 0;
	text-align: right;
	border-top: 1px dashed #EEEEEE;
}
.transport_popup .pretour_price_holder .pretour_price {
	color: var(--primary-color);
	font-family: 'Source Sans Pro Bold';
	line-height: 14px;
	font-size: 14px;
	display: inline-block;
	margin-left: 5px;
}
.transport_popup .submit.action-button {
	margin: 0 auto;
	width: 120px;
	height: 40px;
	font-size: 16px;
	line-height: 20px;
	color: #ffffff;
}

/* View Cart & Basket Summary Pages */
.traveller_summary {
	display: flex;
	flex-wrap: wrap;
	margin-top: 5px;
	color: var(--primary-text-color);
}
.traveller_summary .pax-inner {
	width: 50%;
	margin-bottom: 15px;
}
#booking .payment_request .traveller_summary .pax-inner {
	font-size: 14px;
	line-height: 2em;
	margin-bottom: 10px;
}
.traveller_summary .heading,
.summary_wrapper .heading,
.terms_wrapper .heading {
	font-family: 'Source Sans Pro SemiBold';
	letter-spacing: 0.25px;
	padding-bottom: 5px;
	font-size: 15px;
	margin-bottom: 5px;
	line-height: 14px;
}
.summary_wrapper .heading.cost-summary {
	font-size: 20px;
	line-height: 20px;
}
.traveller_summary .content,
.terms_wrapper .content {
	font-size: 14px;
	color: var(--primary-text-color);
}
.traveller_summary .content div {
	margin-bottom: 10px;
}
.traveller_summary .content div:before {
	content: ' - ';
}

.terms_wrapper a {
	color: var(--primary-text-color);
	text-decoration: underline;
}
.summary_wrapper {
	font-family: 'Source Sans Pro';
	font-size: 14px;
	line-height: 32px;
	padding: 0;
	border-top: 2px solid #EEEEEE;
	padding-top: 20px;
	margin-top: 20px;
	color: var(--primary-text-color);
}
.summary_wrapper .tour_holder {
	padding-bottom: 25px;
	margin-bottom: 25px;
	border-bottom: 2px solid #EEEEEE;
}
.summary_wrapper h3 {
	margin-bottom: 20px;
}
.summary_wrapper .row {
	clear: both;
	/* padding: 0 0 14px 0; */
	line-height: 14px;
    margin-bottom: 10px;
	display: flex;
	justify-content: space-between;
}
.summary_wrapper .row div {
	display: inline-block;
	/* width: 39%; */
	text-align: right;
}
.summary_wrapper #promo_summary_wrapper .heading {
	margin: 15px 0;
}
/* .summary_wrapper #promo_summary_wrapper,
.summary_wrapper #booking_promotion_row {
	max-width: 443px;
} */
.summary_wrapper .column_headings {
	font-family: 'Source Sans Pro SemiBold';
}
.summary_wrapper .row.promotion, .summary_wrapper .row.promotion .price_text {
	font-size: 14px;
	line-height: inherit;
	color: #007DBA;
	background-color: #BBDFE7;
	padding: 0;
}
.summary_wrapper .row.promotion {
	padding: 3px 5px;
	margin-bottom: 1px;
	line-height: 32px;
}
.summary_wrapper .row .item_name {
	/* width: 60%; */
	text-align: left;
}
.summary_wrapper .row.accommodation .item_name {
	/* padding-left: 50px; */
}
.summary_wrapper .row .unit_price {
	text-align: right;
}
.summary_wrapper .price_text {
	color: var(--primary-color);
	font-family: 'Source Sans Pro SemiBold';
	font-size: 16px;
}
.summary_wrapper .subscriptions .price_text {
	float: right;
}
.summary_wrapper .row .total_price { 
	display: none;
}
/* .summary_wrapper .row:after {
	clear: both;
	display: block;
	content:"";
} */
.summary_wrapper .total_price {
	text-align: right;
	padding: 10px 0px;
	/* text-transform: uppercase; */
	font-family: 'Source Sans Pro SemiBold';
}
.summary_wrapper .total_price div {
	margin-top: 24px;
}
/* .summary_wrapper .total_price.final_price_row {
	margin-top: 20px;
	border-top: 1px solid #A3A3A3;
	border-bottom: 1px solid #A3A3A3;
	padding-top: 5px;
} */
.summary_wrapper .total_price .total {
	color: var(--primary-color);
	display: inline-block;
	margin-left: 12px;
	font-size: 30px;
	font-family: 'Source Sans Pro Bold';
}
.summary_wrapper #grand_total {
	font-size: 24px;
	color: var(--button-color);
}
.remaining_section {
	margin-bottom: 25px;
}
#booking .checkout_wrapper button {
	background-color: var(--button-color);
	color: #ffffff;
	font-family: 'Source Sans Pro SemiBold';
	text-transform: none;
	cursor: pointer;
	padding: 6px 7px 7px 7px;
	border: 2px solid var(--button-color);
	display: inline-block;
	font-size: 14px;
	border-radius: 10px;
	transition: all .4s ease-in-out;
	line-height: 1px;
	font-weight: bold;
	position: relative;
	float: right;
	-webkit-appearance: none;
}
#booking .checkout_wrapper button:hover {
	background-color: #ffffff;
	color: var(--button-color);
}
#booking .checkout_wrapper button.apply_voucher {
	font-family: 'Source Sans Pro Bold';
	width: 58px;
	height: 31px;
	font-size: 11px;
	border-radius: 0px 10px 10px 0px;
}
#booking .checkout_wrapper button.submit {
	height: 36px;
	min-width: unset;
	width: 181px;
	padding: 6px 10px;
}
#booking .checkout_wrapper button.return {
	float: left;
}

/* Basket Summary Page */
.terms_wrapper {
	padding: 10px 0px;
}
#booking_promotion_row {
	margin-top: 15px;
	text-align: right;
}
#booking_promotion_row .booking_promotion_inner {
	display: inline-block;
}
#booking_promotion_row .ap_input {
	width: 140px!important;
	background-color: #EEEEEE;
	border: none;
	border-radius: 10px 0px 0px 10px;
	text-transform: uppercase;
	font-size: 11px;
	line-height: 26px;
	height: 31px;
	margin: 0;
	top: -1px;
	padding: 5px 10px;
	float: none;
}

/* New payment options */
.payment_option_holder {
	border: 1px solid #EEEEEE;
	border-radius: 10px;
	position: relative;
	margin-bottom: 20px;
	padding: 10px 20px 20px;
	color: var(--primary-text-color);
}
.payment_option_holder.disabled {
	border: 2px solid grey;
	opacity: 0.6;
}
.payment_option_holder.disabled .option_title {
	background-color: grey;
} 
.payment_option_holder .option {
	/* display: inline-block; */
	vertical-align: middle;
}
.payment_option_holder .option_title, .payment_option_holder .option_price {
	font-family: 'Source Sans Pro SemiBold';
}
.payment_option_holder .option_title {
	/* background-color: #ffa000;
	height: 100%;
	display: inline-block;
	height: 60px;
	color: #fff;
	font-size: 18px;
	line-height: 60px;
	padding: 0 20px;
	width: 260px; */
	letter-spacing: 0.25px;
	font-size: 14px;
}
.payment_option_holder.deposit_payment .option_text {
	border-right: 2px solid #ffa000;
	max-width: unset;
	display: inline-block;
	vertical-align: middle;
	width: calc(100% - 160px);
	padding-left: 0;
	font-style: unset;
}
.payment_option_holder .option_select {
	height: 0;
	width: 0;
	padding: 0;
}
.payment_option_holder .option_select .input_holder {
	position: static;
}
.payment_option_holder .option_price {
	font-size: 24px;
	color: var(--primary-color);
	font-family: 'Source Sans Pro SemiBold';
	margin-top: 10px;
	margin-bottom: 10px;
}
.payment_option_holder .option_select .ap_checkbox_label input::after {
	content: "Select";
	font-family: 'Source Sans Pro SemiBold';
	font-size: 14px;
	min-width: 74px;
	color: #000000;
	display: block;
	vertical-align: middle;
	height: 30px;
	line-height: 30px;
	border-radius: 10px;
	transform-origin: center;
	padding: 0 10px;
	box-sizing: border-box;
	border: 1px solid var(--primary-color);
	background-color: #ffffff;
	text-align: center;
	position: absolute;
	right: 0;
	top: -50%;
}
.payment_option_holder .option_select input:checked::after {
	content: 'Selected';
	background-color: var(--primary-color);
	color: #ffffff;
}
.payment_option_holder .option_select .ap_checkbox_label {
	position: absolute;
	left: 0; right: 0; top: 0; bottom: 0;
}
.payment_option_holder .option_select .ap_checkbox_label input {
	position: absolute;
	right: 20px;
	top: 50%;
	height: 20px;
	width: 20px;
	border-radius: 100%;
	margin: auto;
	-webkit-appearance: none;
	-moz-appearance:    none;
	-ms-appearance:    none;
	appearance:         none;
}
.deposit_payment.payment_option_holder .option_select .ap_checkbox_label input {
	top: 50px;
}

.payment_option_holder.deposit_payment .option_title {
	display: block;
	width: 100%;
}
.payment_deposit_holder {
	padding: 0!important;
	height: 0!important;
	width: 0!important;
	line-height: 0!important;
}
.payment_option_holder .deposit_explanation {
	display: flex;
	position: relative;
}
.payment_option_holder .deposit_icon {
	flex: 1 1 0px;
	text-align: center;
}
.payment_option_holder .deposit_icon .icon {
	height: 50px;
	width: 50px;
	background-position: center center;
	background-repeat: no-repeat;
	margin: auto;
	margin-top: 10px;
	margin-bottom: 5px;
	background-size: contain;
	position: relative;
	z-index: 1;
	background-color: #fff;
}
.payment_option_holder .deposit_icon .icon.stash ~ .heading:after {
	content: "";
	height: 2px;
	background-color: #007dba;
	width: 74%;
	position: absolute;
	display: block;
	left: 0;
	right: 0;
	margin: auto;
	margin-top: -39px;
	z-index: 0;
}
.payment_option_holder .deposit_icon .price {
	font-size: 22px;
	text-transform: uppercase;
	font-family: averia_sans_libre_bold;
	width: 131px;
	background-color: #ffffff;
	z-index: 2;
	margin: auto;
	position: relative;
}
.payment_option_holder .deposit_icon .heading {
	font-size: 18px;
	text-transform: uppercase;
	font-family: averia_sans_libre_bold;
	text-transform: uppercase;
	letter-spacing: -1px;
	margin-top: 5px;
	padding: 0 10px;
}
.payment_option_holder .deposit_icon i {
	font-weight: 600;
	margin: auto;
	padding: 10px;
	font-size: 14px;
	display: block;
	max-width: 216px;
	box-sizing: border-box;
}
.payment_option_holder.open .option_text.collapsable {
	display: block;
}
.payment_option_holder .option_text.collapsable {
	display: none;
}
.payment_option_holder .option_text {
	width: calc(100% - 70px);
	font-size: 14px;
	line-height: 15px;
	color: var(--primary-text-color);
}
.payment_option_holder .option_text ul {
	padding-left: 25px;
	margin: 10px 0;
}

/* Confirmed / Complete Booking */
.complete_dates {
	border: 1px solid #007DBA;
	padding-bottom: 50px;
}
.complete_dates h3 {
	margin-bottom: 20px;
}
.complete_dates .tour_date_info_box {
	padding: 20px 0;
}
.complete_dates .tour_date_info_box:not(:last-of-type) {
	border-bottom: 1px solid #191919;
}
.remaining_balance {
	color: #ffffff;
	background-color: #FCB406;
	text-align: right;
	padding: 15px 90px;
	letter-spacing: 2px;
	text-transform: uppercase;
	font-weight: bold;
	margin-top: -26px;
}
.remaining_balance .price {
	display: inline-block;
	width: 180px;
	font-size: 30px;
	font-family: averia_sans_libre_bold;
}

/* Sprite */
#booking_promotion_row .apply_voucher:after {
	/* content: ""; */
	display: inline-block;
	width: 18px;
	height: 18px;
	position: relative;
	top: 3px;
	left: 8px;
	background: top left url('/images/basket-sprite.png');
}

/* booking success page share section */
.share_section {
	margin-bottom: 30px;
}
.share_section .share_heading {
	font-family: 'Montserrat';
	font-weight: 900;
	color: var(--primary-text-color);
	font-size: 40px;
	text-transform: uppercase;
	border: none;
}
.share_section .share_section_inner {
	display: flex;
	align-items: center;
}
.share_section .share_sub_heading {
	font-family: 'Source Sans Pro SemiBold';
	font-size: 16px;
	color: var(--primary-text-color);
	font-weight: normal;
}
.share_section .share_sub_heading, .share_section .share_section_inner .share_settings_outer {
	display: inline-block
}
.share_section .share_section_inner .share_settings_outer {
	margin-left: 20px;
}
.share_section .share-button img {
	margin-right: 24px;
	height: 20px;
	width: auto;
	max-width: 20px;
}
.share_section .mobile {
	display: none;
}
@media screen and (max-width:1020px) {
	.share_section .mobile {
		display: inline-block;
	}
}

.checkout_wrapper.payment .heading {
	font-size: 16px;
	color: var(--primary-text-color);
	margin-bottom: 10px;
}

.checkout-items {
	margin-top: 20px;
	margin-top: 5px;
}
.complete .summary_wrapper .summary_wrapper {
	padding: 0;
	border: none;
}
.complete .summary_wrapper .total_price {
	margin-top: 0;
	padding-top: 0;
	text-align: right;
}
.complete .summary_wrapper .total_price.remaining .total {
	color: #E89D00;
}
/* REGISTER PAGE */
.ap_label {
	text-align: left;
	margin-right: 5px;
	padding-bottom: 8px;
	width: 100%;
}
.dob_container {
	min-width: 260px;
}
.dob_container_inner {
	display: inline-block;
	height: 45px;
	margin-top: 0px!important;
	padding-top: 10px!important;
	background-image: url('/images/new-site-icons-23/calendar_icon.png');
	background-repeat: no-repeat;
	background-position: 230px center;
	width: 260px;
}
.dob_container .dob_day,
.dob_container .dob_month,
.dob_container .dob_year,
.dob_container .dob_divider {
	float: left;
}
.dob_container .dob_day,
.dob_container .dob_day .ap_input.number_input{
	width: 50px;
}
.dob_container .dob_month,
.dob_container .dob_month .ap_input.select_input {
	width: 100px;
}
.dob_container .dob_year,
.dob_container .dob_year .ap_input.number_input {
	width: 65px;
}
.dob_container .dob_divider {
	position: relative;
	top: 2px;
}
.dob_container input, .dob_container select {
	height: 22px!important;
	min-height: 22px!important;
	border: 0px solid #ff6600!important;
	padding-top: 0!important;
	padding-bottom: 0!important;
	background-color: transparent!important;
	box-shadow: none!important;
}
.input_holder.register_gender_holder.single_col .ap_input.select_input {
	/* height: 45px; */
}
.input_holder.register_gender_holder.single_col {
	position: relative;
}
.ap_help:not(.password_input_help) {
	position: absolute;
	width: 16px !important;
	height: 16px;
	cursor: pointer;
	background-image: url("/images/new-site-icons-23/question_mark_symbol.png");
	background-repeat: no-repeat;
	top: 5px;
	right: 15px;
}
.ap_help:not(.password_input_help).select_input_help {
	right: 0;
}
.ap_help:not(.password_input_help) .help_inner {
	position: relative;
	float: right;
	display: none;
	flex-direction: column;
	justify-content: center;
	margin-top: 0px;
	background-color: #ffffff;
	width: 280px;
	height: 42px;
	font-size: 11px;
	top: 25px;
	padding: 2px 5px;
	text-align: left;
	left: 2px;
}
.ap_help:not(.password_input_help).select_input_help .help_inner {
	width: 145px;
	height: 55px;
}
.ap_help:not(.password_input_help):hover .help_inner {
	display: inline-flex;
}
.password_input_help {
	position: static;
	text-align: center;
	height: fit-content;
	width: fit-content !important;
	justify-content: center;
	align-content: center;
	padding: 0;
	color: rgba(9, 33, 62, 0.8);
	cursor: pointer;
	box-shadow: none;
}
.password_input_help .show_hide .eye {
	position: absolute;
	background-image: url('/images/new-site-icons-23/password-hidden-icon.png');
	background-repeat: no-repeat;
	cursor: pointer;
	top: 50px;
	right: 20px;
	width: 14px;
	height: 12px;
	margin: 0;
	background-size: 12px 10px;
	z-index: 1;
}
.register .password_input_help .show_hide .eye {
	right: 30px;
}
.checkout_buttons .sign_in {
	float: left;
	display: inline-flex;
}
/* For Pop-Ups */
#login_area .password_input_help .show_hide .eye {
	top: unset;
	right: unset;
}
.forgotten_password_form .reset_password_confirm_password_holder  .password_input_help .show_hide .eye {
	top: 130px;
	right: 20px;
}
.password_input_help .show_hide .eye.opened {
	background-image: url('/images/new-site-icons-23/password-shown-icon.png');
	width: 15px;
	height: 13px;
	background-size: 15px 13px;
}
.input_password_visible .password_input_help .show_hide .eye.closed {
	display: none;
}
.input_password .password_input_help .show_hide .eye.opened {
	display: none;
}
.form_container .section_heading, #booking .payment_request .stretch .amount {
	display: inline-block;
	font-family: 'Source Sans Pro SemiBold';
	font-size: 20px;
}
.form_container .section_heading {
	float: left;
}
.form_container .ap_label {
	font-family: 'Source Sans Pro SemiBold';
	color: rgb(9,33,62);
	font-size: 14px;
	width: 100%;
}
.form_container .ap_input::placeholder, .form_container select.placeholder {
	font-family: 'Source Sans Pro';
	font-size: 14px;
	font-weight: 100;
	color: rgb(142,142,142);
}
.form_container select.placeholder option {
	color: #000000;
}
#forgotten_password_form .input_holder input {
	margin-bottom: 10px;
}
.ap_autocomplete_trigger {
	position: absolute;
	margin-left: 0px;
	top: 40px;
	right: 30px;
}
.login .forgotten_password {
	text-align: right;
}
.forgotten_password a {
	display: inline-block;
	color: #2E68B2;
}
.forgotten_password a:hover {
	text-decoration: underline;
}
.return_button {
	font-family: 'Source Sans Pro SemiBold';
	color: var(--primary-text-color);
	transition: all .04s ease-in-out;
	text-decoration: none;
}
.return_button:hover {
	text-decoration: underline;
}
.input_has_error .input_error {
	color: #FF0000 !important;
	text-align: left;
	font-family: 'Source Sans Pro SemiBold';
	font-size: 12px;
	clear: left;
	float: none;
	display: block;
	padding-top: 4px;
	padding-bottom: 7px;
}
.input_has_error .input_error a {
	text-decoration: underline;
	color: #FF0000;
}
.input_has_error .input_error a:hover {
	text-decoration: none;
}

#booking #footer {
	min-height: 360px;
}

/* Make Payment Page */
#booking .payment_request .checkout_section_heading {
	display: flex;
	text-align: left;
	line-height: 1em;
	height: 60px;
	border-bottom: 2px solid #EEEEEE;
	align-items: center;
}
#booking .payment_request .checkout_section_heading.check_before:before {
	content: '';
	display: inline-block;
	background-image: url('/images/new-site-icons-23/checkbox-ticked.png');
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center;
	width: 16px;
	height: 16px;
	margin-right: 12px;
	vertical-align: middle;
}
#booking .payment_request .checkout_section_heading .section_heading {
	margin-bottom: 0;
}
#booking .payment_request .payment_summary_outer .summary_wrapper {
	border-top: 0;
	margin-top: 0;
}
#booking .payment_request .traveller_summary {
	padding: 0 10px;
	margin-bottom: 5px;
}
#booking .payment_request .summary_wrapper {
	padding: 10px;
}
#booking .payment_request .payment_summary_outer .summary_wrapper .summary_inner {
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid #EEEEEE;
}
#booking .payment_request .payment_summary_outer .summary_wrapper .summary_inner:last-of-type {
	border-bottom: 0;
}
#booking .payment_request .payment_summary_outer .summary_wrapper .tour_holder {
	margin: 0;
	padding: 0;
	border: 0;
}
#booking .payment_request .stretch .checkout_section_heading
 {
	justify-content: space-between;
}
#booking .payment_request .light .section_heading, #booking .payment_request .light .amount {
	font-family: 'Source Sans Pro';
}
#booking .payment_request .payments_received .checkout_section_heading {
	min-height: 60px;
	height: auto;
	align-items: unset;
}
#booking .payment_request .payments_received .section_heading {
	padding-top: 12px;
}
#booking .payment_request .payments_received .checkout_section_heading .amount {
	padding-top: 8px;
}
#booking .payment_request .payments_received .checkout_section_heading .amount div {
	margin-bottom: 8px;
	font-size: 16px;
	text-transform: none;
}
#booking .payment_request .payments_received .checkout_section_heading .amount div span {
	font-size: 12px;
}
#booking .payment_request .payments_received .checkout_section_heading .amount div.total {
	font-size: 20px;
	padding-top: 8px;
	border-top: 2px solid #EEEEEE;
}
#booking .payment_request .stretch .checkout_section_heading.amount_to_pay, #booking .payment_request .stretch .checkout_section_heading.edit_amount_to_pay
 {
	justify-content: right;
	border-bottom: 0;
	height: 45px;
}
#booking .payment_request .stretch .checkout_section_heading.edit_amount_to_pay {
	height: auto;
	font-size: 14px;
	color: var(--primary-color);
	text-decoration: underline;
	cursor: pointer;
}
#booking .payment_request .stretch .checkout_section_heading.edit_amount_to_pay:hover {
	text-decoration: none;
}
#booking .payment_request .stretch {
	font-size: 20px;
}
#booking .payment_request .stretch .section_heading, #booking .payment_request .stretch .amount {
	width: auto;
}
#booking .payment_request .stretch .amount {
	text-transform: uppercase;
	/* margin: 15px auto -15px auto; */
	min-width: 90px;
	text-align: right;
}
/* ----------------- */

/* MEDIA QUERIES */
@media screen and (max-width: 1200px) {
	.share_section .share-button img {
		margin-right: 14px;
	}
	
	/* prenight button */
	.account_booking_tours .prenight_button {
		width: 243px;
	}
	.account_booking_tours .prenight_button .button {
		margin-top: 50px;
	}
	/* prenight button on request with message */
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message {
		width: calc(100% - 243px);
	}
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message ~ .prenight_button {
		width: 243px;
		text-align: left;
	}
	/* --- */
	/* ----------------- */
	
	.account_welcome_top {
		padding: 10px!important;
	}
	/* travel credit display */
	.account_welcome_top.has_travel_credit .account_details {
		width: 68%;
		width: calc(99% - 300px);
	}
	.account_welcome_top.has_travel_credit .account_details.right {
		width: 32%;
		width: 300px;
		padding-left: 1%;
	}
	.account_welcome_top .travel_credit .amount_box > * {
		padding: 10px 15px 10px 10px;
	}
	.account_welcome_top .travel_credit .amount_box .right {
		padding: 14px 10px 14px 15px;
	}
	.account_welcome_top .travel_credit .amount_box .amount {
		font-size: 28px;
	}
	/* end of travel credit display */
}
@media screen and (max-width: 1020px) {
	.checkout_box {
		padding: 25px 40px;
	}
	#booking .right-column {
		/* padding: 20px 5px; */
	}
	.qty_box, .tour_info_box {
		padding: 0;
	}
	
	#booking #outer_wrapper {
		padding: 0 5px;
		overflow: hidden;
	}
	.share_section .share_section_inner {
		display: block;
	}
	.share_section .share_section_inner .share_settings_outer {
		margin: 10px 0 0 0;
	}
}
@media screen and (max-width: 960px) {
	/* ACCOUNT SECTION */
	.account_welcome_top .level_info img {
		width: 156px;
	}
	.account_welcome_top .level_info .level_inner {
		margin-left: 10px;
	}
	/* -------------- */
	
	/* prenight button */
	.account_booking_tours .account-tour-card-summary.pre_night_available {
		width: calc(100% - 212px);
	}
	.account_booking_tours .prenight_button {
		width: 212px;
	}
	/* prenight button on request with message */
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message {
		width: calc(100% - 312px);
	}
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message ~ .prenight_button {
		width: 312px;
		text-align: center;
	}
	.account_booking_tours .prenight_button .button.payment_popup_link_disabled {
		line-height: 27px;
	}
	/* --- */
	/* ----------------- */
}

@media screen and (max-width: 920px) {
	/* ACCOUNT SECTION */
	/* travel credit display */
	.account_welcome_top.has_travel_credit .account_details {
		float: none;
		width: 100%;
	}
	.account_welcome_top.has_travel_credit .account_details.right {
		width: 380px;
		float: none;
		padding-left: 0;
		margin: -5px auto 15px 0;
	}
	.account_welcome_top .travel_credit {
		margin: 0 auto;
	}
	.account_welcome_top .travel_credit .amount_box {
		max-width: none;
	}
	.account_welcome_top .travel_credit .amount_box .amount {
		font-size: 30px;
	}
	.account_welcome_top .travel_credit .amount_box .expiry {
		font-size: 13px;
	}
	/* end of travel credit display */
	/* -------------- */
	
	#booking .left-column, #booking .right-column {
		width: 100%;
		margin: 0;
	}
	#booking .right-column {
		padding-top: 20px;
	}
	#booking .right-column .text_content {
		max-width: unset;
	}
	.checkout_box .basket_tour_item_right .right_inner_top {
		margin-top: 19px;
	}
	
	.basket_tour_item_left {
		width: 240px;
		margin-right: 15px;
	}
	.basket_tour_item_right {
		width: calc(100% - 255px);
	}
	
	.input_holder.register_email_holder.twin_col {
		width: 100%;
	}
	#booking_header .header_content {
		/* font-size: 28px; */
		height: auto;
		min-height: 64px;
		min-height: 74px;
	}
	#booking_header .heading {
		margin-right: 15px;
		margin-top: 10px;
		margin-top: 24px;
		margin-left: 12px;
		font-size: 25px;
	}
	#booking_header .right-content {
		margin-right: 15px;
		line-height: 20px;
	}
	#booking .breadcrumb {
		display: inline-block;
	}
	
	.checkout_wrapper .basket_tour_item {font-size: 13px; line-height: 18px;}
	.checkout_wrapper .basket_tour_item .tour_qty{font-size: 13px; line-height: 18px; margin-top: 5px;}
	
	.basket_summary div {margin: 4px;}
	.checkout_box {
		padding: 20px;
	}
	.qty_box, .tour_info_box {
		padding: 0;
	}
	.checkout_wrapper h1 {font-size: 20px; padding-bottom: 15px}
	.checkout_wrapper h2 {font-size: 20px;}
	
	.summary_wrapper .total_price {
		font-size: 20px;
	}
	#passenger_information button.submit {max-width: 300px; }
	#passenger_information .traveller {padding: 25px 20px;}
	
	.checkout_box .payment_options {
		display: block;
		height: auto;
		margin: 0px auto;
	}
	.payment_option_holder.deposit_payment .option_text {
		width: 100%;
		border-right: unset;
		/* border-bottom: 2px solid #ffa000; */
		display: block;
		min-height: 50px;
		padding-right: 70px;
	}
	.payment_option_holder .option_title {
		width: 100%;
		display: block;
		width: 100%;
		height: 24px;
		line-height: 24px;
	}
	.payment_option_holder .option_price {
		width: 98%;
		margin: 0;
		box-sizing: border-box;
		/* text-align: right; */
		line-height: 50px;
	}
	.deposit_payment.payment_option_holder .option_select .ap_checkbox_label input,
	.payment_option_holder .option_select .ap_checkbox_label input {
		bottom: 20px;
		top: auto;
	}
	.payment_option_holder .deposit_icon .icon.stash ~ .heading:after {margin-top: -70px;}
	.payment_option_holder .deposit_icon .icon {
		height: 40px;
		width: 90px;
	}
	.payment_option_holder .deposit_icon .heading {
		font-size: 14px;
		padding: 0 5px;
	}
	.payment_option_holder .deposit_icon .price {font-size: 20px;}
	.payment_option_holder .deposit_icon i {
		font-size: 12px;
		padding-top: 5px;
	}
	.payment_option_holder .deposit_icon .price {width: auto;}
	
	.basket_summary div {font-size: 16px;}
	
	
	.share_section .share_section_inner {
		display: flex;
	}
	.share_section .share_section_inner .share_settings_outer {
		margin: 0 0 0 16px;
	}
	
	
	/* prenight button */
	/* prenight button on request with message */
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message {
		width: calc(100% - 212px);
	}
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message ~ .prenight_button {
		width: 212px;
		text-align: left;
	}
	/* --- */
	/* ----------------- */
}
@media screen and (max-width: 720px) {
	/* ACCOUNT SECTION */
	/* vip status styling */
	.account_welcome_top .club_status .level {
		font-size: 16px;
		line-height: 18px;
	}
	.account_welcome_top .club_status .level svg {
		margin-right: 3px;
	}
	.account_welcome_top .level_info img.desktop {
		display: none;
	}
	.account_welcome_top .level_info .level_inner {
		width: auto;
		margin: 0;
	}
	.account_welcome_top .level_info .level_inner img.mobile {
		display: inline-block;
	}
	.account_welcome_top .level_info .level_inner .content {
		display: inline-block;
		width: calc(100% - 172px);
		margin-left: 15px;
		vertical-align: top;
	}
		/* travel credit display */
	.account_welcome_top.has_travel_credit .account_details.right {
		margin: 0px auto 20px 0;
	}
		/* end of travel credit display */
	/* -------------- */
	
	#booking #outer_wrapper {
		padding: 0;
	}
	
	.basket_tour_item_left {
		width: 220px;
	}
	.basket_tour_item_right {
		width: calc(100% - 235px);
	}
	
	
	.summary_wrapper {
		/* padding: 0; */
	}
	
	#booking_header .header-wrapper {
		padding: 0;
	}
	#booking_header .header-wrapper .nav_holder {
		margin-top: 0;
	}
	#booking_header .header_content {
		display: inline;
		float: none;
		height: fit-content;
		margin-bottom: 5px;
		/* font-size: 32px; */
		width: calc(100% - 110px);
	}
	#booking_header .heading {
		font-size: 26px;
		line-height: 30px;
		display: inline;
		text-align: left;
		margin: 20px auto 10px auto;
		width: calc(100% - 120px);
		max-width: unset;
		text-wrap: wrap;
	}
	#booking_header .nav_holder {
		/* padding: 15px; */
		padding: 10px 5px 10px 5px;
		background-color: #007DBA;
		background-color: #2172D5;
		background-color: var(--tru-blue);
	}
	#booking_header .nav_holder .header_logo_blue {
		display: none;
	}
	#booking_header .nav_holder .header_logo_white {
		display: inline;
		float: left;
		/* transform: scale(0.75); */
		max-width: 80px;
		margin: -12px 10px 0 0!important;
	}
	#booking_header .navbar_account_links, #booking_header .nav_holder .help {
		text-align: left;
	}
	#booking_header .right-content {
		float: left;
		clear: left;
		margin-left: 15px;
		margin-top: 0px;
	}
	
	#booking_promotion_row .ap_input {
		top: -2px;
	}
	
	/* Make Payment Popup Form */
	#payment_popup .payment_inner {
		width: 300px;
		top: 40%;
	}
	#payment_popup .payment_inner .payment_amount_holder input#payment_amount {
		width: 180px!important;
	}
	/* ----------------- */
	
	/* Make prenight Popup Form */
	.prenight_popup .prenight_inner {
		width: 300px;
	}
	/* ----------------- */
	
	#booking .footer_logos {
		display: inline-block;
	}
	
	.form_container.forgotten_password .checkout_buttons .submit .return {
		transition: all .4s ease-in-out;
	}
	.form_container.forgotten_password .checkout_buttons .submit {
		margin-top: 0;
	}
	.form_container.forgotten_password .ap_input.text_input{
		width: 340px;
	}
	.checkout_buttons input {
		margin-top: 0px;
	}
	
	/* Edit Dates (Calendar) page */
	.checkout_wrapper {
		/* padding: 20px 10px; */
	}
	.checkout_wrapper.empty_basket {
		padding: 25px 0 0 0;
	}
	.checkout_wrapper .basket_tour_item {
		padding-bottom: 0;
		margin-bottom: 60px;
	}
	.checkout_wrapper .basket_tour_item h3 {
		font-size: 22px;
		line-height: 30px;
		margin: 0px auto 14px auto;
	}
	.checkout_box .basket_tour_item_right .stops {
		font-family: 'Source Sans Pro SemiBold';
	}
	.checkout_box .basket_tour_item_right .selected_container img {
		margin-top: 6px;
	}
	.checkout_wrapper.calendar_container .swiper-container {
		height: 230px;
		width: 500px;
		margin-top: 20px;
	}
	
	
	.checkout_box .tour_date_selected .selected_container {
		width: 160px;
	}
	
	.checkout_wrapper .tour_info_box {padding: 10px 0 0;}
	#passenger_information label.ap_label {font-size: 14px;}
	#passenger_information input.ap_input {padding: 5px; min-height: 41px;}
	#passenger_information .checkout_wrapper h3 {font-size: 18px;}
	
	.register_during_checkout_message {
		font-size: 14px;
		line-height: 16px;
		margin-bottom: 12px;
	}
	.register_during_checkout_message ~ .input_holder .password_input_help .show_hide .eye {
		top: 48px;
	}
	
	.checkout_wrapper .pre_tour_acc .pretour_input_holder, .checkout_wrapper .pre_tour_acc .posttour_input_holder {padding-left: 0;}
	
	.checkout_box .payment_options {
		margin: 16px auto;
	}
	
	/* prenight button */
	.account_booking_tours .account-tour-card-summary.pre_night_available {
		width: calc(100% - 216px);
	}
	.account_booking_tours .prenight_button {
		width: 216px;
	}
	/* prenight button on request with message */
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message {
		width: calc(100% - 216px);
	}
	.account_booking_tours .account-tour-card-summary.pre_night_available.pre_night_message ~ .prenight_button {
		width: 216px;
		text-align: left;
	}
	
	.account_booking_overview.mobile .tour_card_row.account_booking_tours .prenight_button .payment_popup_link_disabled_message {
		margin-top: 8px;
		font-size: 14px;
		text-align: center;
	}
	/* --- */
	/* ----------------- */
}
@media screen and (max-width: 660px) {
	.traveller_summary .pax-inner {
		width: 100%;
	}
	#booking .payment_request .traveller_summary .pax-inner div {
		padding: 0!important;
	}
	.basket_tour_item_left .tour_image, .basket_tour_item_left .tour_description {
		display: none;
	}
	.basket_tour_item_left, .basket_tour_item_right {
		width: 100%;
	}
	
	.checkout_box .tour_date_selected .selected_container {
		width: 40%;
	}
	.checkout_box .tour_date_selected .selected_container .heading ~ span {
		font-size: 12px;
	}
	.checkout_box .tour_date_selected a.edit_dates {
		margin-top: 26px;
	}
	.calendar_container .tour_date_selected .border-divider, .checkout_box .tour_date_selected .border-divider {
		margin-right: 5px;
	}
	
	#booking_promotion_row {
		padding: 8px 10px;
	}
	#booking_promotion_row .ap_input {
		width: 248px!important;
		font-size: 16px;
		top: -1px;
	}
	#booking .checkout_wrapper button.apply_voucher {
		font-size: 14px;
		line-height: 1em;
	}
	.summary_wrapper .total_price .total {
		font-size: 20px;
	}
	#booking .checkout_wrapper button.submit {
		height: auto;
		width: auto;
		font-size: 20px;
		min-width: 120px;
		padding: 10px 20px;
		line-height: 1em;
	}
}

@media screen and (max-width: 540px) {
	/* ACCOUNT SECTION */
	/* vip status styling */
	.account_welcome_top .level_info img {
		width: 43%;
	}
	.account_welcome_top .level_info .level_inner .content {
		width: 56%;
		margin-left: 1%;
		font-size: 13px;
		line-height: 16px;
	}
	.account_welcome_top .status_bar {
		width: 99%;
	}
	.account_welcome_top .status_bar .result {
		margin: 26px 0 20px 0;
	}
	/* -------------- */
	
	/* payment request */
	.payment_summary_outer .summary_wrapper .row.promotion {
		line-height: 18px;
	}
	.payment_summary_outer .summary_wrapper .row .price_text {
		padding-left: 20px;
		min-width: 30%;
	}
	/* -------------- */
	
	.payment_option_holder .option_text {
		width: 100%;
		padding-right: 0;
	}
	.payment_option_holder {
		padding-bottom: 60px;
	}
	#booking_header .nav_holder {
		/* padding: 20px 20px 15px 25px; */
	}
	#booking_header .footer_items_container {
		display: table-caption;
	}
	.basket_summary .spacer { width: 0}
	.basket_summary .spacer::before {
		display: inline-block;
		position: absolute;
		content: "\0020";
		top: 20px;
		left: -13px;
		width: 27px;
		height: 1px;
		background-color: #191919;
	}
	#booking_promotion_row {
		padding: 10px;
	}
	#booking_promotion_row .ap_input {
		width: 160px!important;
		font-size: 14px;
	}
	#passenger_information button.submit.return {
		margin-bottom: 20px;
	}
	.deposit_holder,
	.payment_button {
		width: 100% !important;
		max-width: none;
		margin-top: 10px !important;
	}
	
	.basket_summary div {
		font-size: 12px;
		letter-spacing: 0px;
		vertical-align: top;
	}
	
	/* Edit Dates (Calendar) page */
	.checkout_wrapper.calendar_container .swiper-container {
		width: 333px;
		height: 330px;
		margin: 0 auto;
	}
}
@media screen and (max-width: 480px) {
	/* ACCOUNT SECTION */
	/* travel credit display */
	.account_welcome_top.has_travel_credit .account_details.right {
		width: 100%;
	}
	.account_welcome_top .travel_credit .amount_box .amount {
		font-size: 26px;
	}
	/* end of travel credit display */
	/* -------------- */
	
	.checkout_wrapper.empty_basket .tour-card {
		margin: 0 auto 15px auto;
	}
}
@media screen and (max-width: 452px) {
	.qty_box .input_holder {
		padding: 0 3px;
	}
	.qty_box .qty_holder {
		float: none;
	}
	
	/* FORGOTTEN PASSWORD PAGE */
	.checkout_buttons input[type=submit] {
		width: 100%;
	}
	
	.return_button_container {
		margin-top: 20px;
		clear: right;
	}
}

@media screen and (max-width: 425px) {
	.form_container.register, .form_container.modify_profile {
		width: 100%;
	}
}

@media screen and (max-width: 418px) {
	.calendar_container .payment_option_holder .deposit_icon .icon.stash ~ .heading:after {
		margin-top: auto;
		top: 29px;
	}
	.payment_option_holder .deposit_icon .icon {width: 65px;}
}

@media screen and (max-width: 375px) {
	#booking_header .heading {
		font-size: 22px;
		line-height: 26px;
	}
	#booking .payment_request .checkout_section_heading.check_before:before {
		margin-right: 8px;
	}
	
	/* payment request */
	.payment_summary_outer .summary_wrapper .row .price_text {
		min-width: 50%;
	}
	.payment_option_holder .option_title {
		height: 40px;
		line-height: 40px;
	}
	.payment_option_holder .option_price {
		line-height: 40px;
		padding-right: 40px;
	}
	.payment_option_holder .deposit_icon .icon {
		width: 60px;
		height: 25px;
	}
	.payment_option_holder .deposit_icon .price {font-size: 14px;}
	.payment_option_holder .deposit_icon .heading {font-size: 12px;}
	.payment_option_holder .deposit_icon i {font-size: 10px;}
	.payment_option_holder .deposit_icon .icon.stash ~ .heading:after {margin-top: -52px;}
	.payment_option_holder .option_text {font-size: 12px; line-height: 14px;}
	.deposit_payment.payment_option_holder .option_select .ap_checkbox_label input,
	.payment_option_holder .option_select .ap_checkbox_label input {bottom: 14px;}
	.calendar_container .payment_option_holder .deposit_icon .icon.stash ~ .heading:after {
			margin-top: auto;
			top: 22px;
	}
	
	.share_section .share_section_inner {
		display: block;
		text-align: center;
	}
	.share_section .share_section_inner .share_settings_outer {
		display: block;
		margin: 10px 0 0 0;
	}
}







