:root {
	/* Layout */
	--bg-color: #fff;
	--text: #383838;
    --booking-link: #e1261c;

	/* Booking Steps */
	--booking-steps-color: #666;
	--booking-steps-done-color: #333;
	--booking-steps-active-color: var(--booking-link);
	--booking-steps-bg-color: var(--bg-color);

	/* Buttons */
	--btn-bg-color: var(--booking-link);
	--btn-bg-hover-color: var(--text);
	--btn-color: #fff;
	--btn-hover-color: #fff;
	--btn-ghost-color: #5f5f5f;
	--btn-ghost-hover-color: var(--booking-link);

	/* Cabin */
	--bg-cabin-option: #e8e8e8;
	--cabin-option-hdr: #191919;

	--border-color: #cdcdcd;
}

/* Event Custom
   ========================================================================== */

/***************************************************************************
* Ticketing
***************************************************************************/

.TicketListTab .SelectedTicketListTab a {
	background-color: #ed1c2f !important;
}

.TicketListTab ul li a {
	background-color: #e9bd4a;
}

body.ticketing .page-wrapper {
	min-width: 1110px;
}

body.ticketing .page-wrap {
	min-width: 1110px;
}

body.ticketing .Masthead {
	min-width: 1110px;
}

body.ticketing .Footer {
	min-width: 1110px;
}

body.ticketing .navbar-default {
	min-width: 1110px;
}

/* Booking Pages
   ========================================================================== */

.interior .bg-page {
	color: inherit;
}

.Ftr__contact div {
	margin-bottom: 8px;
}

.Ftr__contact h3 {
	font-size: 4rem;
    font-family: 'proxima-nova', sans-serif;
}

body {
	color: var(--text);
	font-family: 'Roboto', sans-serif;
}

h1,
h2,
h3,
h4 {
	color: var(--text);
}

h1.lede {
	color: var(--text);
	font-family: 'proxima-nova', sans-serif;
    font-weight: 700;
}

@media (min-width: 320px) {
	h1.lede {
		font-size: calc(3rem + 1.5 * (100vw - 320px) / 880);
	}
}

@media (min-width: 1200px) {
	h1.lede {
		font-size: 5.5rem;
	}
}

h2,
h2.hdr {
	text-shadow: none;
	color: var(--text);
	letter-spacing: 0;
	font-family: 'proxima-nova', sans-serif;
	font-size: 1.9rem;
	font-weight: 700;
	font-style: normal;
}

@media (min-width: 768px) {
	h2,
	h2.hdr {
		font-size: 2.2rem;
	}
}

@media (min-width: 1200px) {
	h2,
	h2.hdr {
		font-size: 2.5rem;
	}
}

h3,
h3.hdr {
	text-shadow: none;
	color: var(--text);
	letter-spacing: 0;
	font-family: 'proxima-nova', sans-serif;
	font-size: 1.9rem;
	font-weight: 700;
}

@media (min-width: 768px) {
	h3,
	h3.hdr {
		font-size: 2.2rem;
	}
}

@media (min-width: 1200px) {
	h3,
	h3.hdr {
		font-size: 2.5rem;
	}
}

h2.guests-hdr,
h3.guests-hdr {
	font-size: 2.5rem;
	margin-bottom: 2.4rem;
}

@media screen and (min-width: 768px) {
	h2.guests-hdr,
	h3.guests-hdr {
		font-size: 3rem;
		text-align: center;
	}
}

h3.guests-info {
	margin: 24px 0 8px;
}

.chat-open {
	display: none;
}

label {
	color: var(--text);
}

.hide {
	display: none;
}

.navbar {
	margin-bottom: 0;
}

select {
	color: #000;
}

ul {
	margin-bottom: 16px;
}

.text-left {
	text-align: left;
}

.text-right {
	text-align: right;
}

.clear {
	clear: both;
	float: none;
	height: 0;
}

@media screen and (max-width: 767px) {
	.profile-old {
		margin-top: 25px;
	}
}

@media screen and (max-width: 767px) {
	#loginForm .row {
		margin-left: 10px;
		margin-right: 10px;
	}
}

/* Layout
   ========================================================================== */

.page-wrap {
	font-size: 1.7rem;
}

.navbar-default {
	z-index: 100;
}

.navbar-default .phone {
	color: #fff;
	font-weight: 700;
	font-size: 2rem;
}

.navbar-default .phone a {
	color: #fff !important;
}

/* Main
   ========================================================================== */

#main-content ul {
	margin: 8px 0 16px 32px;
}

#main-content li {
	list-style: disc;
	margin-bottom: 8px;
}

.interior .main {
	background-color: var(--bg-color);
}

/* Footer
   ========================================================================== */

/* Custom CSS
   ========================================================================== */

.svg-icon svg,
svg.svg-icon {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

.interior .bg-page {
	background-image: none;
	background-color: var(--bg-color);
}

th,
td,
caption {
	padding: 4px 10px 4px 5px;
}

.text-right {
	text-align: right;
}

select {
	padding: 8px;
}

select,
select.form-control {
	font-size: 16px;
    background-color: #fff;
}

@media screen and (max-width: 767px) {
	select,
    select.form-control {
		font-size: 16px;
	}
}

.form-check-input {
    border: 1px solid rgba(0, 0, 0, 0.5) !important;
}

.form-control {
	height: inherit;
}

input.row1 {
	margin-right: 5px;
}

#login-tabs .nav-tabs .nav-item.show .nav-link,
#login-tabs .nav-tabs .nav-link.active {
	color: #545454;
	background-color: transparent;
	border-color: transparent transparent #ccc;
	border-bottom: 3px solid !important;
	font-size: 1.5rem;
	font-weight: 500;
}

#login-tabs .nav-tabs .nav-link {
	background-color: transparent;
	border: 1px solid transparent;
	border-bottom: 3px solid transparent;
	border-top-left-radius: 0.25rem;
	border-top-right-radius: 0.25rem;
	color: #545454;
	font-size: 1.5rem;
	font-weight: 500;
	padding-top: 12px;
	padding-bottom: 12px;
	letter-spacing: 0.4px;
	text-transform: uppercase;
}

#login-tabs .nav-tabs {
	border-bottom: 1px solid #ccc;
}

p.login-tabs__intro {
	margin-top: 18px;
	margin-bottom: 20px;
}

button:focus {
	outline: 1px dotted;
	outline: 5px auto -webkit-focus-ring-color;
}

button:focus:not(.focus-visible),
button:focus:not(:focus-visible) {
	outline: 0;
}

input[type='text'],
input[type='tel'],
input[type='email'],
input[type='password'],
input[type='date'],
select,
textarea {
	font-family: 'Roboto', sans-serif;
	border: 1px solid #ccc;
	box-shadow: none;
}

input[type='text'],
input[type='date'],
input[type='password'] {
	padding: 8px;
}

input[type='date'] {
    font-size: 1.6rem;
    height: 3.5rem;
    color: #111;
}

@media screen and (min-width: 992px) {
    input[type='date'] {
        font-size: 1.7rem;
    }
}

form .input-text {
	width: 270px;
}

form .input-label {
	text-align: right;
	font-weight: 700;
}

form .inline {
	display: inline;
}

.form-group {
	margin-bottom: 1.5rem;
}

button#toggle-password,
button#toggle-presale-password,
button#toggle-profile-password {
	background: none;
	border: none;
	cursor: pointer;
	font-weight: 400;
	padding: 0;
	position: absolute;
	top: 0;
	right: 0;
	color: var(--text);
}

.btn-transparent {
	border: none;
	background: none;
	appearance: none;
}

/*
table.prices td {
	padding: 2px 10px 2px 5px;
}
*/

/*
table.prices tr:hover {
	background-color: #fff;
}
*/

.prices h2 {
	margin-bottom: 8px;
}

.prices td a {
	font-weight: 700;
}

@media screen and (min-width: 767px) {
	th.d-md-block,
	td.d-md-block {
		display: table-cell !important;
	}
}

.arb-table td {
	font-size: 1.3rem;
	border-bottom: 1px solid #dee2e6;
}

@media (min-width: 992px) {
	.arb-table td {
		font-size: 1.4rem;
	}
}

.payment-options .dataentrytext {
	font-size: 1.4rem;
}

.chooseCabin {
	font-weight: 700;
}

@media screen and (max-width: 767px) {
	.chooseCabin {
		font-size: 1.4rem;
	}
}

table.choose-cabin th {
	line-height: 1.1;
}

@media screen and (max-width: 767px) {
	table.choose-cabin th {
		padding: 10px 3px 3px;
		font-size: 1.2rem;
		border-bottom: 1px solid;
	}

	table.choose-cabin td {
		padding: 4px 3px 3px 3px;
		font-size: 1.1rem;
		line-height: 1.5;
	}

	table.choose-cabin td a {
		font-size: 1.6rem;
	}
}

select.upgrade {
	min-width: 200px;
}

/* Category
   ========================================================================== */

#categoryForm .prices td a.cabin-cat {
	color: #333;
}

#cabin-desc .img-item:hover {
	background-color: transparent;
}

#cabin-desc .img-item:hover img {
	opacity: 1;
}

.prices-sold-out {
	color: #999;
}

.prices-table tr.even {
    background-color: #efefef;
}

table.prices tr:hover,
table.prices-table tr.even:hover {
    background-color: #e8e8e8;
}

/*
.prices-table th {
	padding: 10px 2px 10px 2px;
	line-height: 1.3;
}

@media screen and (min-width: 992px) {
	.prices-table th {
		padding: 7px 2px 7px 10px;
	}
}

@media (max-width: 767px) {
	.sm-pp {
		font-size: 7px;
	}

	table.prices td {
		padding: 10px 2px 10px 2px;
	}

	table.prices-table td {
		line-height: 1.3;
	}

	table.prices-table td a {
		font-size: 12px;
	}
}

@media (min-width: 768px) {
    .prices-table thead th {
        position: sticky;
        top: 0;
    }
}
*/

@media (max-width: 559px) {
	.prices-table-wrapper {
		margin-right: -15px;
	}
}

.ship__location svg {
	width: 24px;
	height: 24px;
	margin-right: 8px;
}

/* Cabin
   ========================================================================== */

.deck-legend {
	display: block;
	margin: 15px auto 10px;
	text-align: center;
}

.cabin__option {
	background-color: var(--bg-cabin-option);
	padding: 10px;
	margin-bottom: 15px;
	transition: transform 0.2s ease-in-out;
}

.cabin__option:hover {
	cursor: pointer;
	transform: scale(1.01);
}

.cabin__info {
	width: 70%;
}

.small {
	line-height: 1.3;
}

.cabin__option h3 {
	width: 30%;
	text-align: center;
	margin-bottom: 0;
}

.cabin__option h3 a {
	color: var(--cabin-option-hdr);
}

.cabin__option h3 button {
    color: var(--text);
}

.cabin__details {
	font-size: 1.2rem;
}

.cabin__details svg {
	width: 13px;
	height: 13px;
	fill: currentColor;
}

.cabin__details-comments {
	font-size: 1.1rem;
	line-height: 1.3;
}

@media screen and (min-width: 992px) {
	.cabin__details-comments {
		min-height: 30px;
	}
}

.cabin__type {
	font-size: 1.3rem;
}

/* Summary
   ========================================================================== */

.flex-1,
.flex1 {
	flex: 1;
}

.booking__box-border {
	border-top: 1px solid var(--border-color);
	border-right: 2px solid var(--border-color);
	border-bottom: 2px solid var(--border-color);
	border-left: 1px solid var(--border-color);
}

.booking__box-padding {
	padding: 15px;
}

@media screen and (min-width: 768px) {
	.booking__box-padding {
		padding: 20px;
	}
}

@media screen and (min-width: 992px) {
	.booking__box-padding {
		padding: 30px;
	}
}

.summary__cabin-desc {
	padding: 0 0 20px 10px;
}

@media screen and (min-width: 375px) {
	.summary__cabin-desc {
		padding: 0 5px 20px 15px;
	}
}

@media screen and (min-width: 768px) {
	.summary__cabin-desc {
		padding: 0;
	}
}

.summary__cabin h2 {
	font-weight: bold;
	margin-bottom: 5px;
	font-size: 2.2rem;
}

@media screen and (min-width: 992px) {
	.summary__cabin h2 {
		font-size: 2.4rem;
	}
}

@media screen and (min-width: 1200px) {
	.summary__cabin h2 {
		font-size: 2.6rem;
	}
}

.summary__cabin-number {
	padding-top: 20px;
}

.summary__bedding {
	font-size: 80%;
	padding-top: 15px;
	padding-right: 10px;
}

@media screen and (min-width: 768px) {
	.summary__bedding {
		padding-top: 20px;
		padding-right: 20px;
	}
}

.summary__bedding p {
	margin-bottom: 10px;
	line-height: 1.4;
}

@media screen and (min-width: 768px) {
	.summary__bedding p {
		margin-bottom: 5px;
	}
}

@media screen and (min-width: 992px) {
	.summary__bedding p {
		margin-bottom: 10px;
	}
}

.summary__total h1 {
	/* font-weight: bold; */
	font-size: 2.2rem;
}

@media screen and (min-width: 768px) {
	.summary__total h1 {
		font-size: 2.6rem;
	}
}

@media screen and (min-width: 992px) {
	.summary__total h1 {
		font-size: 3rem;
	}
}

.summary__guest-total {
	text-align: right;
}

hr.summary__hr {
	border-color: var(--border-color);
	margin: 2.2rem 0;
}

.summary__deposit h2 {
	margin-bottom: 0;
	font-size: 1.6rem;
}

@media screen and (min-width: 768px) {
	.summary__deposit h2 {
		font-size: 2.2rem;
	}
}

@media screen and (min-width: 992px) {
	.summary__deposit h2 {
		font-size: 2.4rem;
	}
}

@media screen and (min-width: 1200px) {
	.summary__deposit h2 {
		font-size: 2.6rem;
	}
}

.summary__disclaimer {
	font-size: 1.1rem;
	line-height: 1.4;
}

.summary__btn {
	margin-top: 30px;
}

@media screen and (min-width: 425px) {
	.summary__btn {
		margin-left: 20px;
		margin-top: 0;
	}
}

/* Guests
   ========================================================================== */

/*
@media screen and (min-width: 960px) {
.invisible-md,
.invisible-lg {
    visibility: hidden;
    margin-left: -80px;
}
}
*/

.load-profile {
	display: none;
}

@media screen and (min-width: 992px) {
	.guests-referral input.form-control {
		width: 49%;
	}
}

.guests-row {
	margin-bottom: 1.6rem;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.guests-label {
	font-size: 1.4rem;
	font-weight: 400;
	text-align: left;
	line-height: 1.3;
	padding-bottom: 8px;
}

@media screen and (min-width: 768px) {
	.guests-label {
		text-align: right;
		padding-bottom: 0;
	}
}

.guests-or {
	padding: 8px 0 8px 4px;
	font-weight: 700;
}

@media screen and (min-width: 992px) {
	.guests-or {
		padding: 16px 0 16px 4px;
	}
}

.sms label,
.specialneeds,
.mailinglist label {
	font-size: 1.4rem;
}

.specialneeds .form-check {
	margin-bottom: 4px;
}

@media screen and (max-width: 767px) {
	ul.guests-ul {
		padding-left: 20px;
	}
}

ul.guests-ul li {
	padding-bottom: 8px;
}

a.active-toggle {
	color: #130040;
}

a.active-toggle:hover {
	color: #8f191c;
}

#toggle button {
	border: none;
	background: none;
	appearance: none;
	padding: 0;
	margin: 0 0 1.6rem 0;
	color: var(--btn-bg-color);
	font-weight: 700;
}

#toggle svg {
	width: 20px;
	height: 20px;
	margin-right: 8px;
}

button.collapsed svg.minus-circle {
	display: none;
}

button:not(.collapsed) svg.minus-circle {
	display: inline-block;
}

button:not(.collapsed) svg.plus-circle {
	display: none;
}

.continue-below a {
	color: var(--text);
	font-weight: 400;
}

/* Address Verification
   ========================================================================== */

.well {
	min-height: 20px;
	padding: 20px;
	margin-bottom: 20px;
	background-color: #f5f5f5;
	border: 1px solid #e3e3e3;
	border-radius: 4px;
	-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
	color: #000;
}

.well h3 {
	color: #000;
}

.well .btn {
	margin-bottom: 20px;
}

#error-msg0,
#error-msg1,
#error-msg2,
#error-msg3,
#error-msg4,
#error-msg-emerg0,
#error-msg-emerg1,
#error-msg-emerg2,
#error-msg-emerg3,
#error-msg-emerg4 {
	color: #c33;
	font-size: 1.2rem;
}

@media screen and (min-width: 768px) {
	#error-msg0,
	#error-msg1,
	#error-msg2,
	#error-msg3,
	#error-msg4,
	#error-msg-emerg0,
	#error-msg-emerg1,
	#error-msg-emerg2,
	#error-msg-emerg3,
	#error-msg-emerg4 {
		font-size: 1.3rem;
	}
}

#valid-msg0,
#valid-msg1,
#valid-msg2,
#valid-msg3,
#valid-msg4,
#valid-msg-emerg0,
#valid-msg-emerg1,
#valid-msg-emerg2,
#valid-msg-emerg3,
#valid-msg-emerg4 {
	color: #040;
	font-size: 1.4rem;
}

@media screen and (min-width: 768px) {
	#valid-msg0,
	#valid-msg1,
	#valid-msg2,
	#valid-msg3,
	#valid-msg4,
	#valid-msg-emerg0,
	#valid-msg-emerg1,
	#valid-msg-emerg2,
	#valid-msg-emerg3,
	#valid-msg-emerg4 {
		font-size: 1.5rem;
	}
}

input[type='tel'].error,
#homephone.error,
#emergencyphone.error {
	border: 1px solid #c33;
}

/* Disclaimer
   ========================================================================== */

.insurance-even {
	background-color: #e8e8e8;
}

@media screen and (max-width: 767px) {
	.insurance-rates {
		font-size: 1.1rem;
		line-height: 1.5;
	}
}

.terms-hdr {
	margin-bottom: 12px;
}

.disclaimer-row {
	padding-bottom: 16px;
}

h2.header {
	font-family: 'proxima-nova', sans-serif;
	font-size: 2.5rem;
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: 24px;
}

@media (min-width: 768px) {
	h2.header {
		font-size: 3.5rem;
		margin-bottom: 40px;
	}
}

.terms-conditions h2.header {
	margin-top: 32px;
}

@media (min-width: 768px) {
	.terms-conditions h2.header {
		margin-top: 40px;
	}
}

@media (min-width: 992px) {
	.terms-conditions h2.header {
		margin-top: 64px;
	}
}

.travel-protection h3 {
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: 8px;
}

.travel-protection ul {
	list-style: none;
	padding: 0;
	margin-bottom: 24px;
}

.travel-protection li {
	font-size: 1.3rem;
	margin-bottom: 16px;
	display: flex;
	align-items: baseline;
	line-height: 1.3;
}

@media (min-width: 768px) {
	.travel-protection li {
		margin-bottom: 16px;
	}
}

.travel-protection li span {
	font-size: 1.4rem;
	font-weight: 700;
}

@media (min-width: 992px) {
	.travel-protection li span {
		font-size: 1.6rem;
	}
}

.travel-protection svg {
	fill: #509bc8;
	width: 14px;
	height: 14px;
	margin-right: 12px;
}

.travel-protection__cost {
	font-size: 1.3rem;
	margin-bottom: 24px;
}

.travel-protection__cost-cost {
	color: #509bc8;
	font-size: 2rem;
	font-weight: 700;
}

.travel-protection__choose {
	border-left: 1px solid var(--border-color);
	border-right: 1px solid var(--border-color);
	border-bottom: 1px solid var(--border-color);
	position: -webkit-sticky;
	position: sticky;
	top: 16px;
	border-radius: 8px;
	font-size: 1.4rem;
	margin-bottom: 32px;
}

@media (min-width: 768px) {
	.travel-protection__choose {
		margin-bottom: 0;
	}
}

@media (min-width: 992px) {
	.travel-protection__choose {
		font-size: 1.5rem;
	}
}

.travel-protection__guest {
	margin-bottom: 24px;
	padding: 0 8px 0 16px;
}

.travel-protection__guest-name {
	font-weight: 700;
	font-size: 1.8rem;
	margin-bottom: 4px;
}

.travel-protection__guest-amount {
	font-size: 1.2rem;
	text-transform: uppercase;
	color: #666;
	margin-bottom: 8px;
}

.travel-protection__guest label {
	margin-bottom: 2px;
}

.travel-protection__blue {
	color: #417a9c;
	font-weight: 700;
}

.travel-protection__border {
	height: 8px;
	background-color: #f2f2f2;
	margin: 32px 0;
}

@media (min-width: 768px) {
	.travel-protection__border {
		margin: 40px 0;
	}
}

h2.travel-protection__choose-hdr {
	background-color: var(--text);
	color: #fff;
	padding: 12px 8px;
	text-transform: uppercase;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 700;
	letter-spacing: 1px;
	border-bottom: 4px solid #509bc8;
	border-radius: 8px 8px 0 0;
}

@media (min-width: 992px) {
	h2.travel-protection__choose-hdr {
		font-size: 1.8rem;
	}
}

@media (min-width: 1400px) {
	h2.travel-protection__choose-hdr {
		font-size: 2rem;
	}
}

.travel-protection__disclaimer {
	font-size: 1.3rem;
	line-height: 1.5;
}

@media (min-width: 992px) {
	.travel-protection__disclaimer {
		font-size: 1.4rem;
	}
}

.travel-protection__list {
	order: 2;
}

@media (min-width: 768px) {
	.travel-protection__list {
		order: 1;
	}
}

.travel-protection__selection {
	order: 1;
}

@media (min-width: 768px) {
	.travel-protection__selection {
		order: 2;
	}
}

/* Checkout
   ========================================================================== */

.checkout-table td,
.checkout-table th {
	padding: 4px 2px;
}

.checkout-table,
.checkout-table .table {
	font-size: 1.6rem;
	color: var(--text);
}

@media (max-width: 767px) {
	.checkout-table,
	.checkout-table .table {
		font-size: 1.2rem;
	}

	.payment-options {
		font-size: 1.4rem;
	}
}

.checkout__room-box {
	margin-bottom: 4rem;
	font-size: 1.5rem;
}

@media (min-width: 992px) {
	.checkout__room-box {
		margin-bottom: 4.8rem;
		font-size: 1.6rem;
	}
}

h2.checkout__hdr {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 4px;
}

.checkout__deck {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 4px;
}

.checkout__room span {
	font-size: 2rem;
	font-weight: 700;
}

@media (min-width: 414px) {
	.checkout__financial {
		border: 1px solid var(--border-color);
		padding: 1.2rem;
	}
}

@media (min-width: 768px) {
	.checkout__financial {
		padding: 2.4rem;
	}
}

#checkoutForm h3 a {
	text-decoration: none;
}

.payment-options h3 svg {
	width: 24px;
	height: 24px;
	fill: currentColor;
	margin-right: 8px;
}

.credit-card-wrapper {
	padding: 0 0 1.2rem;
}

@media (min-width: 360px) {
	.credit-card-wrapper {
		padding: 1.2rem;
		border: 1px solid var(--border-color);
	}
}

@media (min-width: 768px) {
	.credit-card-wrapper {
		padding: 2.4rem;
	}
}

.checkout-label {
	font-weight: 400;
	font-size: 1.5rem;
	text-align: left;
	display: block;
	padding-bottom: 8px;
}

.hint {
	font-size: 1.1rem;
}

.other_cc h3 {
	font-size: 1.7rem;
}

.other_cc h3 button {
	background: none;
	border: none;
	appearance: none;
	padding: 0;
	margin: 0;
	color: var(--btn-bg-color);
	display: flex;
	align-items: center;
}

.other_cc h3 svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
	margin-right: 8px;
}

/* Confirmation
   ========================================================================== */

.interior.confirmation .main-content {
	z-index: 99;
	position: relative;
}

.confetti {
	display: none;
}

.confirmation .confetti {
	display: block;
}

canvas {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 3;
}

.confirm-bigger {
	font-size: 18px;
	text-align: center;
}

.share--wrapper {
	float: left;
	width: 95%;
	position: relative;
	margin-top: 10px;
	margin-bottom: 20px;
	background-color: transparent;
	padding: 10px;
}

.share--wrapper svg {
	width: 40px;
	height: 40px;
	fill: currentColor;
}

.share--text {
	float: left;
	font-weight: 700;
	font-size: 16px;
	width: 100%;
	padding: 10px 20px 15px 0;
}

@media screen and (min-width: 992px) {
	.share--text {
		width: 55%;
	}
}

.share--twitter {
	float: left;
	margin-right: 20px;
}

.share--action {
	padding-left: 5px;
	padding-top: 30px;
	line-height: 60px;
	clear: left;
	float: none;
}

.share--fb {
	float: left;
}

.share--twitter span.fa,
.share--fb span.fa {
	font-size: 40px;
}

#tick,
#cross {
	font-size: 1.3rem;
}

#tick {
	display: none;
	color: #090;
}

#tick img {
	padding-right: 15px;
	vertical-align: middle;
}

#cross {
	display: none;
	color: #c33;
}

#cross img {
	padding-right: 15px;
	vertical-align: middle;
}

body.start .container-fluid {
	max-width: 1300px;
}

.start .profile-forms h3.hdr {
	font-size: 45px;
}

.profile-new {
	border-right: 1px solid #444;
}

@media (min-width: 768px) {
	.profile-forms .form-horizontal .control-label {
		text-align: left;
	}
}

@media (min-width: 992px) {
	.profile-forms .form-horizontal .control-label {
		text-align: right;
	}
}

/* Guests Accordion
   ========================================================================== */

#toggle ul,
#toggle ol {
	margin-left: 0;
	padding-left: 0;
}

#toggle ul li,
#toggle ol li {
	list-style: none outside none;
}

a.togglehead {
	font-weight: bold;
	font-size: 1.5rem;
	text-decoration: none;
	display: block;
	margin-bottom: 15px;
}

@media (min-width: 992px) {
	a.togglehead {
		font-size: 1.8rem;
	}
}

.toggleheadText {
	padding: 5px 0 20px 20px;
}

.video-embed {
	display: block;
}

/* Input
   ========================================================================== */

input[type='text'],
input[type='tel'],
input[type='email'],
input[type='password'],
input[type='date'],
select,
textarea {
	border-radius: 4px;
}

/* Buttons
   ========================================================================== */

.a-button {
	margin: 0;
	color: var(--btn-color);
	background-color: var(--btn-bg-color);
	border: 2px solid var(--btn-bg-color);
	font-size: 1.2rem;
	line-height: inherit;
	padding: 6px 20px;
	text-transform: uppercase;
	text-align: center;
	letter-spacing: 0.0892857143em;
	cursor: pointer;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	border-radius: none;
	-webkit-transition: background-color 0.2s;
	-o-transition: background-color 0.2s;
	transition: background-color 0.2s;
	will-change: transform, opacity;
	zoom: 1;
}

.a-button:hover {
	background-color: var(--btn-bg-hover-color);
	border-color: var(--btn-bg-hover-color);
	color: var(--btn-hover-color);
}

.a-button.a-button-ghost {
	background-color: transparent;
	border-color: var(--btn-ghost-color);
	color: var(--btn-ghost-color);
}

.a-button.a-button-ghost:hover {
	background-color: transparent;
	border-color: var(--btn-ghost-hover-color);
	color: var(--btn-ghost-hover-color);
}

.a-button-raised {
	-webkit-box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2),
		0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
	box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2),
		0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
	-webkit-transition: -webkit-box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1);
	transition: -webkit-box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1);
	-o-transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1);
	transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1);
	transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1),
		-webkit-box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.a-button-raised:hover,
.a-button-raised:focus {
	-webkit-box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2),
		0px 4px 5px 0px rgba(0, 0, 0, 0.14),
		0px 1px 10px 0px rgba(0, 0, 0, 0.12);
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2),
		0px 4px 5px 0px rgba(0, 0, 0, 0.14),
		0px 1px 10px 0px rgba(0, 0, 0, 0.12);
}

/* Booking Steps
   ========================================================================== */

.main-nav-wrap {
	height: 0;
}

@media (min-width: 768px) {
	.main-nav-wrap {
		height: 5px;
	}
}

.booking-steps-pt {
	width: 100%;
	height: 35px;
}

.booking-steps {
	position: relative;
	margin: 0 auto 30px;
	width: 100%;
	max-width: 700px;
	padding: 0 12px;
}

@media (min-width: 768px) {
	.booking-steps {
		padding: 0 20px;
	}
}

.booking-steps .progress-bar-container {
	left: 20px;
	right: 20px;
	position: absolute;
	height: 1px;
	background-color: transparent;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

.booking-steps .progress-bar {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	height: 100%;
	width: 33%;
	background-color: var(--booking-steps-done-color);
	-webkit-transition: width 900ms ease;
	-o-transition: width 900ms ease;
	transition: width 900ms ease;
}

.booking-steps .progress-bar.progress-20 {
	width: 20%;
}

.booking-steps .progress-bar.progress-25 {
	width: 25%;
}

.booking-steps .progress-bar.progress-33 {
	width: 33%;
}

.booking-steps .progress-bar.progress-40 {
	width: 40%;
}

.booking-steps .progress-bar.progress-50 {
	width: 50%;
}

.booking-steps .progress-bar.progress-60 {
	width: 60%;
}

.booking-steps .progress-bar.progress-66 {
	width: 66%;
}

.booking-steps .progress-bar.progress-75 {
	width: 75%;
}

.booking-steps .progress-bar.progress-80 {
	width: 80%;
}

.booking-steps .progress-bar.progress-100 {
	width: 100%;
}

.booking-steps__steps {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.booking-steps__steps .booking-steps__step {
	height: 40px;
	width: 40px;
	background-color: var(--booking-steps-bg-color);
	border-radius: 50%;
	position: relative;
	text-align: center;
	vertical-align: middle;
	line-height: 35px;
	border: 1px solid var(--booking-steps-color);
	color: var(--booking-steps-color);
}

.booking-steps__steps .booking-steps__step.done {
	color: var(--booking-steps-done-color);
	border-color: var(--booking-steps-done-color);
}

.booking-steps__steps .booking-steps__step.active {
	color: var(--booking-steps-active-color);
	border-color: var(--booking-steps-active-color);
	font-weight: bold;
}

.booking-steps__steps.booking-steps__step.done,
.booking-steps__steps.booking-steps__step.active {
}

.booking-steps__steps .booking-steps__step.active:after {
	/*content: "";
	height: 16px;
	width: 16px;
	background-color: #ECECEC;
	position: absolute;
	border-radius: 50%;
	top: 50%;
	left: 50%;
	margin-top: -8px;
	margin-left: -8px;*/
}

.booking-steps__title {
	line-height: 1.3;
	width: 70px;
	display: inline-block;
	text-align: center;
	margin-top: 7px;
	margin-left: -40%;
	font-size: 1rem;
}

@media (min-width: 375px) {
	.booking-steps__title {
		font-size: 1rem;
	}
}

@media (min-width: 992px) {
	.booking-steps__title {
		width: 120px;
		font-size: 1.3rem;
		margin-left: -100%;
	}
}

.booking-steps__steps .booking-steps__step svg {
	width: 18px;
	height: 18px;
	fill: var(--booking-steps-color);
}

.booking-steps__steps .booking-steps__step.done svg {
	fill: var(--booking-steps-done-color);
}

.booking-steps__steps .booking-steps__step.active svg {
	fill: var(--booking-steps-active-color);
}

.steps-hover:hover {
	cursor: pointer;
}

.booking-steps__steps button {
	appearance: none;
	padding: 0;
	margin: 0;
}

/* Floating label form
   ========================================================================== */

.form-floating.form-floating-dark input[type='text'].form-control,
.form-floating.form-floating-dark input[type='email'].form-control,
.form-floating.form-floating-dark input[type='search'].form-control,
.form-floating.form-floating-dark input[type='password'].form-control {
	color: var(--text);
}

.form-floating-dark .form-label-group:hover label,
.form-floating.form-floating-dark .btn-icon:hover {
	color: var(--text);
}

.form-floating.form-floating-dark .btn-icon:hover svg {
	fill: var(--text);
}

.form-floating.form-floating-dark
	input[type='email']:focus:not([readonly])
	+ label,
.form-floating.form-floating-dark
	input[type='search']:focus:not([readonly])
	+ label,
.form-floating.form-floating-dark
	input[type='text']:focus:not([readonly])
	+ labell {
	color: var(--text);
}

.form-floating.form-floating-dark .form-label-group {
	border-bottom: 1px solid var(--text);
}

.form-label-group > input,
.form-label-group > input[type='text'],
.form-label-group > input[type='email'],
.form-label-group > input[type='password'],
.form-label-group > label {
	padding: 1.5rem 1rem 1.5rem 0;
}

.form-floating-dark .form-label-group > label {
	color: var(--text);
}

.form-floating-dark .form-label-group input::-webkit-input-placeholder {
	color: transparent;
}

.form-floating-dark .form-label-group input:-ms-input-placeholder {
	color: transparent;
}

.form-floating-dark .form-label-group input::-ms-input-placeholder {
	color: transparent;
}

.form-floating-dark .form-label-group input::-moz-placeholder {
	color: transparent;
}

.form-floating-dark .form-label-group input::placeholder {
	color: transparent;
}

.form-floating-dark .form-label-group input:not(:placeholder-shown) ~ label {
	color: var(--text);
}

.form-floating.form-floating-dark .form-control:focus {
	color: var(--text);
}

/* Print
   ========================================================================== */

@media print {
	.masthead,
	#steps-wrapper,
	.booking-steps,
	.share--wrapper,
	.footer,
	.confetti,
	.slaask-mini {
		display: none !important;
	}
}


/* ==========================================================================
   Magnific Popup
   ========================================================================== */

.mfp-bg {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1042;
  overflow: hidden;
  position: fixed;
  background: #0b0b0b;
  opacity: 0.8; }

.mfp-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1043;
  position: fixed;
  outline: none !important;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.mfp-container {
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 0 8px;
  box-sizing: border-box; }

.mfp-container:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle; }

.mfp-align-top .mfp-container:before {
  display: none; }

.mfp-content {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto;
  text-align: left;
  z-index: 1045; }

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto; }

.mfp-ajax-cur {
  cursor: progress; }

.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: -moz-zoom-out;
  cursor: -webkit-zoom-out;
  cursor: zoom-out; }

.mfp-zoom {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in; }

.mfp-auto-cursor .mfp-content {
  cursor: auto; }

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none; }

.mfp-loading.mfp-figure {
  display: none; }

.mfp-hide {
  display: none !important; }

.mfp-preloader {
  color: #CCC;
  position: absolute;
  top: 50%;
  width: auto;
  text-align: center;
  margin-top: -0.8em;
  left: 8px;
  right: 8px;
  z-index: 1044; }
  .mfp-preloader a {
    color: #CCC; }
    .mfp-preloader a:hover {
      color: #FFF; }

.mfp-s-ready .mfp-preloader {
  display: none; }

.mfp-s-error .mfp-content {
  display: none; }

button.mfp-close,
button.mfp-arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  box-shadow: none;
  touch-action: manipulation; }

button::-moz-focus-inner {
  padding: 0;
  border: 0; }

.mfp-close {
  width: 44px;
  height: 44px;
  line-height: 44px;
  position: absolute;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  opacity: 0.65;
  padding: 0 0 18px 10px;
  color: #FFF;
  font-style: normal;
  font-size: 28px;
  font-family: Arial, Baskerville, monospace; }
  .mfp-close:hover,
  .mfp-close:focus {
    opacity: 1; }
  .mfp-close:active {
    top: 1px; }

.mfp-close-btn-in .mfp-close {
  color: #333; }

.mfp-image-holder .mfp-close,
.mfp-iframe-holder .mfp-close {
  color: #FFF;
  right: -6px;
  text-align: right;
  padding-right: 6px;
  width: 100%; }

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  color: #CCC;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap; }

.mfp-arrow {
  position: absolute;
  opacity: 0.65;
  margin: 0;
  top: 50%;
  margin-top: -55px;
  padding: 0;
  width: 90px;
  height: 110px;
  -webkit-tap-highlight-color: transparent; }
  .mfp-arrow:active {
    margin-top: -54px; }
  .mfp-arrow:hover,
  .mfp-arrow:focus {
    opacity: 1; }
  .mfp-arrow:before,
  .mfp-arrow:after {
    content: '';
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
    margin-top: 35px;
    margin-left: 35px;
    border: medium inset transparent; }
  .mfp-arrow:after {
    border-top-width: 13px;
    border-bottom-width: 13px;
    top: 8px; }
  .mfp-arrow:before {
    border-top-width: 21px;
    border-bottom-width: 21px;
    opacity: 0.7; }

.mfp-arrow-left {
  left: 0; }
  .mfp-arrow-left:after {
    border-right: 17px solid #FFF;
    margin-left: 31px; }
  .mfp-arrow-left:before {
    margin-left: 25px;
    border-right: 27px solid #3F3F3F; }

.mfp-arrow-right {
  right: 0; }
  .mfp-arrow-right:after {
    border-left: 17px solid #FFF;
    margin-left: 39px; }
  .mfp-arrow-right:before {
    border-left: 27px solid #3F3F3F; }

.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px; }
  .mfp-iframe-holder .mfp-content {
    line-height: 0;
    width: 100%;
    max-width: 900px; }
  .mfp-iframe-holder .mfp-close {
    top: -40px; }

.mfp-iframe-scaler {
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%; }
  .mfp-iframe-scaler iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #000; }

/* Main image in popup */
img.mfp-img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  box-sizing: border-box;
  padding: 40px 0 40px;
  margin: 0 auto; }

/* The shadow behind the image */
.mfp-figure {
  line-height: 0; }
  .mfp-figure:after {
    content: '';
    position: absolute;
    left: 0;
    top: 40px;
    bottom: 40px;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #444; }
  .mfp-figure small {
    color: #BDBDBD;
    display: block;
    font-size: 12px;
    line-height: 14px; }
  .mfp-figure figure {
    margin: 0; }

.mfp-bottom-bar {
  margin-top: -36px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  cursor: auto; }

.mfp-title {
  text-align: left;
  line-height: 18px;
  color: #F3F3F3;
  word-wrap: break-word;
  padding-right: 36px; }

.mfp-image-holder .mfp-content {
  max-width: 100%; }

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer; }

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
  /**
       * Remove all paddings around the image on small screen
       */
  .mfp-img-mobile .mfp-image-holder {
    padding-left: 0;
    padding-right: 0; }
  .mfp-img-mobile img.mfp-img {
    padding: 0; }
  .mfp-img-mobile .mfp-figure:after {
    top: 0;
    bottom: 0; }
  .mfp-img-mobile .mfp-figure small {
    display: inline;
    margin-left: 5px; }
  .mfp-img-mobile .mfp-bottom-bar {
    background: rgba(0, 0, 0, 0.6);
    bottom: 0;
    margin: 0;
    top: auto;
    padding: 3px 5px;
    position: fixed;
    box-sizing: border-box; }
    .mfp-img-mobile .mfp-bottom-bar:empty {
      padding: 0; }
  .mfp-img-mobile .mfp-counter {
    right: 5px;
    top: 3px; }
  .mfp-img-mobile .mfp-close {
    top: 0;
    right: 0;
    width: 35px;
    height: 35px;
    line-height: 35px;
    background: rgba(0, 0, 0, 0.6);
    position: fixed;
    text-align: center;
    padding: 0; } }

@media all and (max-width: 900px) {
  .mfp-arrow {
    -webkit-transform: scale(0.75);
    transform: scale(0.75); }
  .mfp-arrow-left {
    -webkit-transform-origin: 0;
    transform-origin: 0; }
  .mfp-arrow-right {
    -webkit-transform-origin: 100%;
    transform-origin: 100%; }
  .mfp-container {
    padding-left: 6px;
    padding-right: 6px; } }
