.booking {
	margin-bottom:100px;	
	width: 100%;
}


.bookingBox {
	width:90%;
	min-width:360px;	
}

.stripePaymentLink a {
	  width: 320px;
	  border: 0;
	  border-radius: 10px;
	  display: inline-block;
	  background: rgb(2, 55, 95);
	  margin: 30px 0 20px;
	  padding: 10px 0;
	  color: #fff;
	  font-weight: bold;
}
.stripePaymentLink a.loading {
	background: rgba(2, 55, 95, 0.77);
}
.stripePaymentLink a div, .stripePaymentLink a span  {
	vertical-align:middle;	
}
.stripePaymentLink a span  {
	margin-left:5px;	
}
.lds-ring {
  display: inline-block;
  position: relative;
  width: 30px;
  height: 30px;
}
.lds-ring div {
  box-sizing: border-box;
  display: block;
  position: absolute;
  width: 34px;
  height: 34px;
  margin: -2px 0 0 -8px;
  border: 8px solid #fff;
  border-radius: 50%;
  animation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
  border-color: #fff transparent transparent transparent;
}
.lds-ring div:nth-child(1) {
  animation-delay: -0.45s;
}
.lds-ring div:nth-child(2) {
  animation-delay: -0.3s;
}
.lds-ring div:nth-child(3) {
  animation-delay: -0.15s;
}
@keyframes lds-ring {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}




/* popup Window */
.popup_visible #startplanning, .popup_visible .popup {
  transform: scale(1);
}
#startplanning, .popup {
	background:#fff;
	box-shadow: 0 0 6px rgba(0,0,0,0.4);
	position:relative;
	height:720px;
	margin: 0 auto;
	right: 0;
	font-family:'rregular';
}
#startplanning h2 {
	margin-bottom:20px;	
}
.popup {
	max-height:1200px;
	height:95%;
	max-width:1000px;
}
#startplanning .container , .popup .container {
	height: 100%;
	width: 100%;
	display: block;
	overflow: hidden;
	position: absolute;	
}
.startplanning_close:hover, .popupclose:hover {
	box-shadow:0 0 4px 0 rgba(255,255,255,1);	
}
#msform fieldset {
	border:none;
	padding: 35px 50px 5px;
	box-sizing: border-box;
	text-align:center;
	overflow-y: auto;
	
	/*stacking fieldsets above each other*/
	position: absolute;
	width: 100%;
	height: calc(100% - 60px);
}
/*Hide all except first fieldset*/
#msform fieldset:not(:first-of-type) {
	display: none;
}
#msform .small {
	display:block;
	line-height:10px;	
}
#msform #durationField {
	width: 100px;
	min-width: 100px;
}
.bookingInfoTable td:nth-child(1) {
	width:60%;
}
.bookingInfoTable td:nth-child(2) {
	width:25%;
}
.bookingInfoTable td:nth-child(3) {
	width:15%;
}
.hidePrice, .hideCustom {
	display:none;
}

/*inputs*/
form.contactUsForm .other {
	display:none;	
}
#msform input, #msform textarea, #msform select {
	padding: 14px;
	border: 1px solid #ccc;
	border-radius: 3px;
	margin-bottom: 10px;
	box-sizing: border-box;
	color: #00007d;
	font-size: 13px;
	font-family: 'rregular';
}
#msform input[type=text] {
	padding: 10px 15px;
	min-width:250px;
}
#msform textarea {
	width:100%;	
	height:auto;
}
/*buttons*/
#msform .action-button {
	background: rgba(75,105,176,1);
	font-weight: bold;
	color: white;
	cursor: pointer;
	padding: 11px 25px;
	min-width:250px;
	margin: 15px auto;
	display:block;
}
#msform fieldset:nth-child(3) .long {
	display:block;
	margin: 10px auto !important;
	padding: 12px 25px;
}
#msform fieldset .long {
	width:98%;
	max-width:275px;
	margin: 3px 0;
}

#msform fieldset:nth-child(2) h2, #msform fieldset:nth-child(3) h2, #msform fieldset:nth-child(4) h2 {
	margin-top:10%;
}
#msform fieldset:nth-child(5) h2 {
	margin-top:6%;
}
#msform fieldset:nth-child(2) input.eHost {
	font-size: 16px;
	min-width: 150px;
	margin: 6px 5px;
}
#msform .whatEvent, #msform .incluOther {
	display:none;	
}
#msform .datepicker, #msform .ui-datepicker {
	width: 98%;
	max-width: 500px;
	margin: 0 auto;
}
#msform .ui-datepicker .ui-datepicker-calendar .ui-state-highlight a {
	background: #00677d !important;
	color:#fff !important;
	font-weight:bold;
}
#msform fieldset:nth-child(3) label, #msform fieldset:nth-child(5) label {
	font-weight:bold;
}
#msform fieldset:nth-child(3) label, #msform fieldset:nth-child(5) label, #msform fieldset:nth-child(6) label {
	display:inline-block;
	font-size:13px;
	line-height: 15px;
	width:180px;
	text-align:left;

}
#msform fieldset:nth-child(3) input#amount {
	padding:0;
	text-align:center;
	margin:8px auto 0;
	border:0;
	font-size:16px;
	color:#f6931f;
	font-weight:bold;
}
#msform fieldset:nth-child(5) input {
	max-width:150px;
}
#msform fieldset:nth-child(6) textarea {
	height:200px;
}
#msform fieldset:nth-child(6) .agreeTANDC {
	padding: 10px 15px;
	min-width: 240px;
	vertical-align: bottom;
}
#msform fieldset:nth-child(6) .previousPlan {
	position:relative;	
	float:left;
	left:0;
}
#slider-range .ui-slider-handle {
	border: 1px solid #d3d3d3 !important;
	background: url(images/ui-bg_glass_75_e6e6e6_1x400.png) 50% 50% repeat-x #e6e6e6 !important;
	font-weight: 400 !important;
	color: #555 !important;	
}
#slider-range.ui-slider {
	border: 1px solid #aaa !important;
	width: 88%;
}
#peopleAttendField {
	margin-bottom:30px !important;	
}
#msform fieldset:nth-child(2) ul li {
	font-size:12px;
	text-align:left;
	padding:2px 0;
	box-sizing:border-box;
}
#msform fieldset:nth-child(3) #slider-range {
	margin:0 auto 30px;
}
#msform fieldset:nth-child(5) ul {
	margin:-12px 0 0 14px;	
}
#msform fieldset:nth-child(5) ul li {
	font-size:14px;
	text-align:left;
	padding:4px 0;
	box-sizing:border-box;
}
#msform input[name=next].nextPlan:not(.submitPlan), #msform input[name=previous].previousPlan {
	background:rgba(75,105,176,1);
	border: 1px solid #006e95;
	color: #fff;
	border-radius: 1px;
	padding: 10px 5px;
	min-width: 200px;
}
#msform .action-button:hover, #msform .action-button:focus {
	box-shadow: 0 0 0 2px white, 0 0 0 3px #B3B3FF;
}
#msform .submitPlan {
    position: relative !important;
    float: right;
    right: 0 !important;
}

#msform .labelTC {
	width: fit-content !important;
  	padding-left: 2.3em !important;
  	text-align: center !important;
}
#msform  .acceptTCBooking {
  width: 30px;
  height: 20px;
  display:none;
}
#msform  .acceptTCBooking + label {
  position: relative;
  cursor: pointer;
  padding-left: 1.95em;
  font-size: 0.85em;
}
#msform  .acceptTCBooking + label::before {
  content: '';
  position: absolute;
  left: 0;
  top: -4px;
  width: 20px;
  height: 20px;
  border: 2px solid #ccc;
  background: #fff;
  box-shadow: inset 0 1px 3px rgba(0,0,0,.1);
}

#msform  .acceptTCBooking + label::after {
  content: '\2713\0020';
  position: absolute;
  top: .1em;
  left: .3em;
  font-size: 1.3em;
  line-height: 0.8;
  color: #4b69b1;
  transition: all .2s;
  font-family: 'Lucida Sans Unicode', 'Arial Unicode MS', Arial;
  opacity: 0;
  transform: scale(0);
}
#msform  .acceptTCBooking:checked + label::after {
  opacity: 1;
  transform: scale(1);
}


.startPlanningBoat.drkTurqoise {
	text-shadow: 0 0 2px rgba(0, 103, 125, 0.2) !important;
}
/*headings*/
.fs-title {
	font-size: 21px;
	text-transform: uppercase;
	color: #00b4f5;
	margin-bottom: 10px;
}
.fs-title.large {
	font-size:23px;
}
.fs-subtitle {
	font-weight: normal;
	font-size: 13px;
	color: #666;
	margin-bottom: 20px;
}
#msform input[name=previous] {
	left: 50px;
	bottom: 5px;
	position: absolute;
}
#msform input[name=next] {
	border: 0 none;
}
#msform select {
	font-size:0.8em;
	padding: 5px 15px;
	width:125px;	
}

.travelInsurance  {
	display:block;	
}

#msform input[type=button] {
	background:  url(../images/buttonLayout.png) no-repeat scroll 0 0 rgba(2,55,95,1) !important;
	padding:11px 25px 11px 0px !important;
	border-radius:8px !important;
	border:none;
	min-width:250px !important;
}
#msform input[name=previous] {
	padding:11px 0px 11px 25px !important;
	background:  url(../images/reversebuttonLayout.png) no-repeat scroll 0 0 rgba(2,55,95,1) !important;
	min-width: 150px !important;
}

.selectedButton {
	border:3px solid rgba(67, 152, 209,1) !important;
	background:rgba(2,55,95,1) !important;
	box-shadow: 0 0 3px rgba(0, 103, 125, 0.8), 0 0 1px rgb(0, 103, 125, 1) !important;
}


/*progressbar*/
#progressbar {
	overflow: hidden;
	/*CSS counters to number the steps*/
	counter-reset: step;
}
#progressbar li {
	list-style-type: none;
	color: #fff;
	text-transform: uppercase;
	font-size: 1.3em;
	font-family:rregular;
	width: 20%;
	float: left;
	position: relative;
	text-align: center;
	background: rgba(204,204,204,1);
	outline:1px solid #fff;
	padding:11px 0;
}
#progressbar li span {
	font-family:rbold;
}
#progressbar li.active {
	background: rgba(75,105,176,1);	
}


.tourSummary {
	padding:20px 0 5px;
	position:relative;
}
.tourSummary > div, .tourSummary div.finalPayment > div {
	width:420px;
	margin: 0 auto;
	text-align:left;
}
.tourSummary > div > div {
	font-family:rbold;
	margin:10px 0;
}
.tourSummary  > div  > div > span, .finalPayment .txtWhite span {
	width:200px;
	display: inline-block;
}	
.tourSummary  > div  > div:not(.finalPayment) > span {
	font-family:rregular;
}
.tourSummary div.finalPayment {
	position:absolute;
	bottom:0;
	padding:10px 0;
	width:100%;
	background: rgba(75,105,176,1);
	font-size:1.2em;
}










.tourInformation {
	position:relative;
	-webkit-box-shadow: 0px 4px 6px 1px rgba(0,0,0,0.45);
	-moz-box-shadow: 0px 4px 6px 1px rgba(0,0,0,0.45);
	box-shadow: 0px 4px 6px 1px rgba(0,0,0,0.45);
}

.tourInformation .headerTitle {
	background: rgba(75,105,176,1);
	padding:11px 0 8px;
	text-align:center;
	width:100%;
}

.tourInformation .mainTripContent {
	min-height:250px;
}
.tourInformation .mainTripContent {
	padding:20px 25px;	
}
.tourInformation .tourInfoSection:not(:last-child) {
	margin:0 0 20px;
}
.tourInformation .tourInfoSection .title {
	color:rgba(75,105,176,1);
	font-size:0.68em;
}
.tourInformation .tourInfoSection .description {
	font-family:rmedium;
	font-size:1.05em;
}
.tourInformation .subdescription {
	font-size:0.88em;	
}
#msform input[name="next"]{
	position: absolute;
	bottom: 5px;
	min-width: 150px !important;
	right: 25px;
	height: 42px;
	background-image: url(../images/buttonLayout.png) !important;
	background-repeat: no-repeat !important;
	background-size: 228px 42px !important;
	background-position-x: -78.5px !important;
	background-color: rgba(2,55,95,1) !important;
}


/* Sprites */
.tourInformation .subdescription .sprites {
	vertical-align:middle;
}
.tourInformation .subdescription .first {
	background-position: -758px -155px;
	width: 38px;
	height:36px;
	margin-right:8px;
	margin-top:10px;
}
.tourInformation .subdescription .second {
	background-position: -758px -193px;
	width: 38px;
	height:36px;
	margin:5px 8px 5px 0;
}
.tourInformation .subdescription .third {
	background-position: -758px -231px;
	width: 38px;
	height:36px;
	margin-right:8px;
}
#planfinished .deals{
	top: 0;
	left: 0;
}