﻿/* ========== Login Modal ========== */
.login-modal, .forgot-modal {
    width: 250px;
    padding: 1em;
}
.forgot-modal button {
width: 100%;
}

.login-form {
    margin-top: 1em;
}

.login-form button {
    margin: 0;
}


.login-modal .forgot-pass-link {
    display: block;
}

.forgot-modal button {
    padding-left: 0;
    padding-right: 0;
}

.register-modal {
    padding: 1em;
}

.register-modal.form .fields .item {
    margin-right: 0.9em;
    width: 162px;
}



.register-modal.form .fields .last-name input {
    width: 210px;
}

.register-modal.form .fields .email, .register-modal.form .fields .password {
    width: 240px;
    margin-right: 0.9em;
}

    .register-modal.form .fields .email input, .register-modal.form .fields .password input {
        width: 228px;
    }


.register-modal.form .fields .country {
    width: calc(100% - 5px) !important;
}

.register-modal.form .fields .country input {
    width: 100% !important;
}

.register-modal.form .fields .item:last-child {
    margin-right: 0;
}

.register-modal.form .fields .item {
    float: left;
}

.register-modal.form .fields .item.checkbox {
    width: 100%;
    float: none;
}

.register-modal.form .buttons {
    text-align: right;
    margin-bottom: 0;
    width: 96%;
}

.register-modal.form .fields button {
    float: none;
}

.register-modal.form .disclaimer-text {
    width: 96%;
    font-size: 14.4px;
    min-height: 60px;
}

.register-modal.form .disclaimer-text div p{
    font-size: 14.4px;
}

.register-modal.form .fields .privacy-policy {
    margin-right: 1em;
}

.ab-wrapper {
    margin-right: 0;
}

/* ========== Booking Header ========== */
div.header-wrapper.booking {
    height: 100px;
    text-align: center;
    border-bottom: 1px solid #acacac;
}

header h1 {
    color: #fff;
    margin-bottom: 0;
}

header a {
    color: #fff;
}

header a:visited {
    color: #fff;
}

.logo {
    margin-top: 5px;
    float: left;
}

header div.center-content {
    float: left;
    margin-top: 25px;
    margin-left: 6%;
    text-align: center;
}

header div.oc-phone-num {
    float: right;
    color: #fff;
    font-size: 200%;
    margin: 10px 0 5px 0;
    list-style: none;
}
header div.button-row {
    float: right;
    clear: right;
}

header button {
    margin-right: 0;
    margin-left: 1em;
}

/*==== Booking Statement ====*/
div.header-wrapper.booking {
    margin-bottom: 1em;
    color: #fff;
    position: relative;
}
.booking-stmt-status {
    position: absolute;
    right: 0;
    top: 65px;
}
/* ========== Cruise Header ========== */
.booking-statement .cruise-header {
    margin-bottom: 1em;
}

.booking-statement .cruise-header .cruise-ports {
    float: left;
    margin-bottom: 0;
    width: auto;
    display: inline-block;
    text-transform: uppercase;
    width: 100%;
}

.booking-statement .cruise-header .cruise-name {
    clear: left;
    color: #333;
    text-transform: uppercase;
    margin-bottom: 1em;
}

.booking-statement .cruise-header .region {
    display: block;
    text-align: left;
}

.booking-statement .cruise-header .cruise-dates {
}

.booking-statement .cruise-header .ship-name {
    color: #735a24;
    font-style: italic;
    text-align: center;
}

.booking-statement .cruise-header .cruise-info {
    float: left;
    clear: both;    
    padding-right: 2em;
    text-align: center;
    width: 292px;
}

.booking-statement .cruise-header .voy-ship, .cruise-header .cruise-dates {
    float: left;
    vertical-align: middle;
    margin-top: 0;
}

.booking-statement .cruise-header .voy-ship {
    margin-top: 1em;
    margin-right: 2em;
}

.booking-statement .cruise-header .cruise-booking-num-wrapper {
	clear: both;
	text-transform: uppercase;
    font-size: 125%;
}

.booking-statement .cruise-header .cruise-booking-num {
    color: #735a24;
}


.booking-statement .cruise-header .actions {
	float: right;
	clear: none;
	/*width: 180px;*/

}

.booking-statement .cruise-header .actions * {
        vertical-align: top;
    }

.booking-statement .cruise-header .actions ul {
    margin-top: .70em;
    padding: 0.25em;
    vertical-align: top;
    width: 250px;
}

.booking-statement .cruise-header .actions ul li {
    text-align: left;
}


.booking-statement .cruise-header .cruise-content {
    clear: none;
    width: auto;
    float: left;
    margin-bottom: 1em;
}


.booking-statement .cruise-header .center-content {
    width: 300px;
	float: left;
}

.booking-statement .cruise-header .suite {
    text-transform: uppercase;
}


.booking-statement .cruise-header .deposit-info {
    margin-top: 1em;
    vertical-align: top;
}

.booking-statement .cruise-header .deposit-info ul {
    vertical-align: top;
    width: 90%;
}

.booking-statement .cruise-header .deposit-info ul li {
    list-style-type: none;
}
.booking-statement .cruise-header ul li:nth-child(even) {
}



.booking-statement .cruise-header span.label {
    display: inline-block;

}
.booking-statement .cruise-header span.value {
    float: right;
    display: inline-block;
}


.booking-statement ol.guest-list {
    margin-bottom: 1.5em;
}

.booking-statement ol.guest-list li{
    float:left;
    width: 245px;
}


.booking-statement table {

    margin-bottom: 3em;
}

.booking-statement table thead tr td {
    background-color: #bfa874;
    color: #fff;
}

.booking-statement table tbody tr {
    background-color: #fff;
}

.booking-statement .cart table tfoot tr td {
    background-color: #efeadf;
    text-align: right;
    text-transform: uppercase;
}

.booking-statement table td:last-child {
    
}
.booking-statement table td {
    width: 12%;
     border-right: 1px solid #e4dcc9;
}

.booking-statement table td:first-child {
    width: 52%;
}

.booking-statement table td:nth-child(2) {
    text-align:center;
}
.booking-statement table td:nth-child(3) {
    text-align: right;
}

.booking-statement table td:nth-child(4) {
    text-align: right;
}

.booking-statement table td:nth-child(5) {
    text-align: right;
}
 

.booking-statement table tbody tr:nth-child(odd) { /* override default alrernating row color */
    background-color: #fff;
}

.booking-statement table tr td:last-child {
    border-right: none;
}

.booking-statement table tr.no-td-border td {
    border-right: none;
}

.booking-statement table tbody tr.no-td-border {
    background-color: #ececec;
}

/* specific tables */

.booking-statement table tfoot tr:nth-child(even), table tfoot tr:nth-child(odd) {
    background-color: #efeadf;
}

.booking-statement table tfoot tr:last-child {
    border-bottom: none;
}


.booking-statement .balance {
    font-size: 125%;
}

/* special styling for table various cells/rows */

.booking-statement .bold {
    font-weight: bold;
}

.booking-statement .pad {
    padding-left: 1.5em;
}

.booking-statement .double-line {
    border-bottom: 4px double #AD9869;
}

.booking-statement .cmsn
{
    display: none;
}
.booking-statement-bottom-text
{
}
/*=== End Booking Summary ===*/

/* ========== Universal Page Top ========== */

.booking h1.page-title {
    margin-bottom: 0;
    float: left;
    margin-top: 0.35em;
    width: 75%;
}

h3.cruise-name {
    clear: left;
    float: left;
    display: inline-block;
}

div.voyage-info-top {
    float: left;
    display: inline-block;
    margin-left: 50px;
    font-size: 160%;
    color: #735a24;
}

div.rate-code-container {
    float: left;
    display: inline-block;
    margin-left: 50px;
    font-size: 160%;
    color: #735a24;
    display: none;
}

.ship-name {
    font-style: italic;
}

.cruise-dates {
    float: right;
    clear: none;
    margin-top: 0.5em;
    margin-bottom: 0.5em;
}


/* ========== Begin Booking Engine Navigation ========== */
ul.booking-navigation {
    border: 1px solid #acacac;
    vertical-align: top;
    height: 38px;
    line-height: 36px;
    -webkit-border-radius: 2px;
    border-radius: 2px;
    background: transparent url(/img/booking/bkg-gradient-default.png) repeat-x;
    clear: both;
    overflow: hidden;
}


ul.booking-navigation li {
    vertical-align: top;
    list-style-type: none;
    float: left;
    text-align: center;
    font-weight: bold;
    background: transparent url(/img/booking/bkg-gradient-default.png) repeat-x;
}

ul.booking-navigation li a {
    height: 38px;
    line-height: 36px;
    width: 100%;
    display: block;
    background: transparent url(/img/booking/divider-default.png) no-repeat left top;
    /*padding-left: 6px;*/
}


ul.booking-navigation li > a.default {
    cursor: default;
}

ul.booking-navigation li a.default:hover, ul.booking-navigation li a.next:hover {
    color: #336699;
}
ul.booking-navigation li.current a, ul.booking-navigation li.current a.default:hover {
    color: #000;
    cursor: default;
}


ul.booking-navigation li:first-child a {
    background-image: none;
}

ul.booking-navigation li.current {
    background: transparent url(/img/booking/bkg-gradient-current.png) repeat-x;
}


ul.booking-navigation li a.current { /*ul.booking-navigation li a.current*/
    background: transparent url(/img/booking/divider-current.png) no-repeat left top;
}

ul.booking-navigation li a.next {
    background: transparent url(/img/booking/divider-next.png) no-repeat left top;
    /*cursor: default;*/
}

ul.booking-navigation li a.pending {
    background-color: transparent;
}

ul.booking-navigation li.complete {
    background-image: none;
    background-color: #fff;
}

ul.booking-navigation li a.complete {
    cursor: pointer;
    color: #336699;
}

ul.booking-navigation li a.complete:hover {
    color: #5e91c3;
}

/*ul.booking-navigation li:first-child {
    border-left: 1px solid #fff;
}*/

ul.booking-navigation li:nth-child(1), ul.booking-navigation li:first-child
{
    width: 8em;
}

ul.booking-navigation li:nth-child(2), ul.booking-navigation li:nth-child(3), ul.booking-navigation li:first-child + li, ul.booking-navigation li:first-child + li + li
{
    width: 13.5em;
}

ul.booking-navigation li:nth-child(4), ul.booking-navigation li:first-child + li + li + li
{
    width: 10.9em;
}

ul.booking-navigation li:nth-child(5), ul.booking-navigation li:first-child + li + li + li + li
{
    width: 6em
}

ul.booking-navigation li:nth-child(6), ul.booking-navigation li:nth-child(7), ul.booking-navigation li:first-child + li + li + li + li + li, ul.booking-navigation li:first-child + li + li + li + li + li + li
{
    width: 8em;
}


/*ul.booking-navigation li:nth-child(odd) {
    width: 20%;
}

ul.booking-navigation li:nth-child(even) {
    width: 13%;
}*/

ul.booking-navigation li:last-child a.default {
}



/* ========== Previous / Next underneath the booking nav ========== */
div.booking-navigation-prev-next {
    margin: 0.5em 0;
    text-align: center;
}

div.booking-navigation-prev-next .next, div.booking-navigation-prev-next .prev {
    text-transform: uppercase;
    font-weight: bold;
    font-size: 110%;
}

div.booking-navigation-prev-next.bottom {
    float: left;
    width: 100%;
    clear: none;
    margin: 2em 0;
    text-align: center;
}

.booking-prev {
    text-align: left;
}

.booking-next {
    text-align: right;
}

.booking-next .icon-arrow-right {
    float: right;
    margin-top: 4px;
}

.prev-step-name {
    display: inline-block;
    margin-left: 15px;
}

.next-step-name {
    margin-right: 15px;

}


/* ========== Booking Engine Navigation - jQuery UI Active Tab Override ========== */
.booking-navigation .ui-tabs-active a, .sub-steps .ui-tabs-active a {
    border-bottom: none;
}

.booking-navigation .ui-tabs-active a:visited, .sub-steps .ui-tabs-active a:visited {
    border-bottom: none;
}

/* ========== End Booking Engine Navigation ========== */


/* ========== Booking Error ========== */
.booking-message-line {
    margin-bottom: 1em;
}



/* ========== Main tab content container ========== */
.tab-content {

}

.tab-content.default-view {
    width: 725px;
}

.tab-content.wide-view {
    width: 100%;
}

.panel {
    margin-top: 1em;
}


/* ========== Begin Booking Summary ========== */
.booking-summary {
    width: 225px;
    margin-top: 0;
}

.booking-summary-content {
    border: 1px solid #acacac;
    padding: 0.5em;
}

.booking-summary ul li {
    list-style-type: none;
    padding-bottom: 1px;
}

.booking-summary h5 {
    /*cursor: pointer;*/
}

.booking-summary h5 span {
    display: inline-block;
    padding-bottom: 3px;
    font-size: 90%;
}

.booking-summary .not-selected span {
    font-style: italic;
} 

ul.bs-guests li {
    margin-bottom: 0.5em;
}

ul.bs-suite li {
}

ul.bs-suite .suitePrice {
    float: right;
}

ul.bs-options li {
    padding-left: 0.25em;
    padding-right: 0.25em;
}

ul.bs-options li:nth-child(odd) {
    background-color: #efeadf;
}

.option-label {
}

.option-content {
    float: right;
}

ul.fare-container {
    margin-top: 0.5em;
}

ul.fare-container li {
    padding-left: 0.25em;
    padding-right:0.25em;
}

.fare-total {
    text-align: right;
    font-size: 110%;
    font-weight: bold;
}

a.edit-link {
    float: right;
    font-weight: normal;
    font-size: 80%;
}
.ada-stateroom {
    font-style: italic;
}
.ada-stateroom-invoice {
    width: 47%;
}


/* ========== Begin Booking Engine Step 1: Voyage Information ========== */


.chosen-container {
    margin: 0; /* applies to all steps */
}

#step1 label.question {
    display: inline-block;
    vertical-align: middle;
    margin-right: 1em;
    clear: none;
    width: 350px;
}

ul.rate-codes {
    margin-top: 0.5em;
}

ul.rate-codes li {
    list-style-type: none;
    margin-bottom: 0.5em;
    
}
ul.rate-codes li label {
    font-weight: normal;
    cursor: pointer;
}

ul.rate-codes li label span:first-of-type {
    display: inline-block;
    width: 100px;
}

.select-guests {
    float: left;
    clear: none;
    min-width: 100px;
    max-width: 100px;
    display: inline-block;
    vertical-align: top;
}

.air-question label.air-label {
    width: 60px;
    vertical-align: middle;
    cursor: pointer;
    font-weight: normal;
    display: inline-block;
}

#step1 .club-level {
    width: 200px;
}

#step1 button {
    float: right;
}


/* ========== Begin Booking Engine Step 2: Suite ========== */

.qtip-content {
    line-height: 2;
}

.qtip-content ul li {
    list-style-position: outside;
    margin-left: 1.25em;
}

.suite-selection {
    overflow: hidden;
}
.suite-selection-panel {
    display: none;
}

.suite-selection-panel .left {
    width: 450px;
}

.suite-selection-panel .right {
    margin-top: 1em;
}

.suite-selection-panel hr {
    clear: both;
}

.suite-category-selection-panel, .suite-selection-panel, .suite-guarantee-panel {
    float: left;
    clear: none;
    width: 100%;
}


.suite-category-selection-panel table tr:nth-child(4n+1) {
    background-color: #efeadf;
}

.suite-category-selection-panel table tr:nth-child(4n+3) {
    background-color: #fff;
}

.suite-category-selection-panel table tr:nth-child(even) {
    background-color: #ececec;
}



/* ===== Suite Category Selection ===== */
.suite-category-selection-panel table {
}


.suite-category-selection-panel table td {
    text-align: center;
}

.suite-category-selection-panel table tr td:first-child {
    text-align: left;
}

.suite-category-selection-panel table td:last-child {
    text-align: right;
}

.suite-category-selection-panel table tr {
}

.suite-category-selection-panel table tr.selected {
    /*background-color: gold;*/
}

.suite-category-selection-panel table tr td:nth-child(1) {
    width: 266px;
}

.suite-category-selection-panel table tr td:nth-child(2) {
    width: 84px;
}
.suite-category-selection-panel table tr td:nth-child(3) {
    width: 104px;
}
.suite-category-selection-panel table tr td:nth-child(4) {
    width: 103px;
}
.suite-category-selection-panel table tr td:nth-child(5) {
    width: 110px;
}

/* disabled categories*/
.suite-category-selection-panel table td.disabled a {
    cursor: default;
    color: #000;
}
.suite-category-selection-panel table td:nth-child(5).disabled a {
    cursor: default;
    padding-right: 1em;
}
.suite-category-selection-panel table td.disabled a:hover {
    color: #000;
}
.suite-category-selection-panel table td.disabled .icon-arrow-right {
    display: none;
}


.suite-category-selection-panel table tr.selected {
    background-color: gold;
}

.suite-category-selection-panel table tr.suite-info {
    padding: 0;
}

.suite-category-selection-panel table tr.suite-info td {
    width: 705px;
    text-align: left;
    padding: 0;
}

.suite-category-selection-panel .suite-info div.suite-info-content {
    display: none;
    padding: 10px;
    float: left;
    clear: both;
    width: 100%;
}

.suite-category-selection-panel .amenities a
{
    cursor: default;
}




.suite-info img {
    margin-bottom: 0.5em;
    background-color: #fff;
}


.suite-info .left {
    text-align: left;
    width: 350px;
}

.suite-info .left.img-wrap {
    margin-left: 0;
    width: 324px;
    text-align: center;
}

.suite-info li {
    list-style-position: outside;
    margin-left: 1.2em;

}

.suite-info .suite-size {
}

.suite-info .ul-wrap {
    float: left;
    width: 160px;
    margin-left: 1em;
}


/* ===== Suite Selection ===== */

.suite-selection-panel {
    margin-left: 725px;
}

a.back-to-category-selection {
    clear: both;
    margin-bottom: 1em;
}

.selected-category-name {
    font-weight: bold;
}

.suite-selection-panel table {
    width: 200px;
}

.suite-selection-panel tbody {
    cursor: pointer;
}

.suite-selection-panel thead td {
    text-align: center;
}
.suite-selection-panel tbody tr td:last-child {
    text-align: center;
}

.suite-table tbody label {
    cursor: pointer;
}

.suite-selection-panel button.suite-choose-button {
    float: right;
    width: 100%;
    margin-top: 1em;
}

.suite-selection-panel button.suite-choose-button .icon-arrow-right {
    font-size: 125%;
}

.ada-suite-title {
    margin-top: 18px;
    margin-left: 17px;
}

.ada-term-conditions label {
    margin-top: 25px;
    margin-bottom: -1px;
    display: flex;
}

.ada-term-conditions a {
    margin-left: 25px;
}

.ada-term-conditions span {
    margin-left: 10px;
}

.fixed-suites {
    width: 200px;
}


/* ========== Suite Filters ========== */
.suite-filters {
    clear: both;
    float: left;
    margin-left: 1em;
    margin-top: 2em;
}

.suite-filters .search-container {
    position: relative;
    clear: both;
    display: inline;
    width: 212px;
}

.suite-filters .search-term {
	float: left;
	clear: both;
	margin: 0;
	width: 200px;
}

.suite-filters .search-term-clicker {
	position: absolute;
	right: 1px;
	top: 1px;
	background-color: #fff;
	height: 29px;
	width: 35px;
    font-size: 115%;
    text-align: center;
}

.suite-filters .icon-search {
	position: absolute;
	top: 7px;
	right: 10px;
	cursor: pointer;
	color: #d1d1d1;
	border-left: 1px solid #d8d8d8;
	height: 18px;
	padding-left: 7px;
    font-weight: normal;
}

.suite-filters label {
    float: left;
    clear: both;
    margin-bottom: 0.25em;
}

.suite-filters ul {
    clear: both;
    float: left;
    margin-bottom: 1em;
}

.suite-filters ul li {
    height: 25px;
    line-height: 25px;
    padding: 0 1em;
    float: left;
    margin-right: 0.5em;
    border: 1px solid black;
    list-style-type: none;
    text-align: center;
}

.suite-filters li.enabled {
	background-color: #dbe2ea;
	border: 1px solid #acacac;
	cursor: pointer;
}

.suite-filters li.disabled {
	border: 1px solid #acacac;
	opacity: .5;
	cursor: default;
}

.suite-filters li.selected {
	background-color: #326195;
	color: #fff;
}


/* ========== Suite Guarantee ========== */
.suite-guarantee-panel {
    margin-left: 725px;
}

.suite-guarantee-panel .guarantee-price {
    float: right;
    clear: none;
    font-weight: bold;
}

.guarantee-suite-info {
    margin-top: 1em;
}

.guarantee-suite-info h5 {
    clear: both;
}

.guarantee-suite-info img {
    float: left;
    clear: both;
}

.guarantee-suite-info p {
    float: left;
    clear: none;
    margin-left: 1.5em;
    width: 350px;
}


/* ========== Suite Deck Plan SVG  ========== */

svg {
    width: 100%;
    height: 50%;
}










/* ========== Begin Booking Engine Step 3: Options & Amenities ========== */

.booking .options {
    width: 725px;
}

/* ========== Options & Amenities: Sub Steps ========== */

ul.sub-steps {
    text-align: center;
    width: 100%;
    display: block;
}

ul.sub-steps li {
    list-style-type: none;
    float: left;
    width: 33%;
    cursor: pointer;
}



ul.sub-steps .sub-step-highlight {
    display: inline-block;
    background-color: #808080;
    height: 15px;
    width: 100%;
    border-right: 1px solid #fff;
    margin-right: -1px;

}

ul.sub-steps .sub-step-num {
    width: 25px;
    height: 25px;
    line-height: 25px;
    background-color: #808080;
    color: #fff;
    border-radius: 50px;
    display: inline-block;
    color: #fff;
}

ul.sub-steps .sub-step-text {
    color: #808080;
    border-top: 1px solid #808080;
    padding-top: 0.25em;
}

ul.sub-steps .ui-tabs-active .sub-step-highlight {
    background-color: #5e91c3;
}

ul.sub-steps .ui-tabs-active .sub-step-text {
    color: #5e91c3;
}

.sub-step-content {
    clear: both;
    float: left;
    width: 100%;
}

.sub-step-content .v-nav {
    width: 180px;
}



/* ========== Air Panel ========== */
.air-travel-panel .chosen-container {
    width: 100% !important;
}

.air-travel-panel {
    /*display: none;*/
}

.air-travel-panel button {
    float: right;
    margin-top: 1em;
}

.option-air-panel label {
    display: inline-block;
    vertical-align: middle;
    margin-right: 1em;
    clear: none;
    width: 350px;
}
.option-air-panel label.air-label {
    width: 60px;
    vertical-align: middle;
    cursor: pointer;
    font-weight: normal;
}



/* ========== Hotels ========== */
.option-hotels-panel .chosen-container
{
    width: 100% !important;
}
.option-hotels-panel .h-nav {
    margin-top: 1em;
}

.option-hotels-panel li {
    list-style-type: none;
}

.option-hotels-panel img {
    float: left;
    margin-right: 1.0em;
}

.option-hotels-panel .hotel-content {
    width: 475px;
    float: left;
}

.option-hotels-panel h5 {
    margin-bottom: 0.25em;
}

.option-hotels-panel button {
    float: right;
    clear: none;
    margin-right: 0;
    margin-bottom: 0.5em;
}

.option-hotels-panel h6 {
    border-bottom: 1px solid #acacac;
}



.option-hotels-panel .pricing {
    width: 100%;
    float: left;
    width: auto;
}

.option-hotels-panel .pricing div {
    float:left;
    clear: none;
}

/* Vertical line image */
.option-hotels-panel .pricing img {
    margin: 0 2em;
}

.option-hotels-panel .pricing ul li {
    width: 250px;
    margin-bottom: 0.25em;
}

.option-hotels-panel .pricing label {
    font-weight: normal;
    cursor: pointer;
}

.option-hotels-panel .pre-cruise-hotels > ul > li, .option-hotels-panel .post-cruise-hotels > ul > li {
    border-bottom: 1px solid #bfa874;
    padding: 0.5em;
}

.option-hotels-panel .pre-cruise-hotels > ul > li:nth-child(odd), .option-hotels-panel .post-cruise-hotels > ul > li:nth-child(odd) {
    background-color: #efeadf;
}

.option-hotels-panel .pricing .hotel-selections {
    /*width: 250px;*/
}

.option-hotels-panel .pricing .hotel-price {
    margin-left: 1em;
    float: right;
}

.option-hotels-panel .hotel-descrip {
    overflow: hidden;
    height: 40px;
    float: left;
    clear: both;
    width: 100%;
    margin-top: 0.5em;
}


.option-hotels-panel .button-row {
    float: right;
    clear: both;
}

.option-hotels-panel button {
    margin-left: 1em;
}

.option-hotels-panel .remove-link {
    line-height: 39px;
}



.more-hotel-details-link {
    clear: none;
    text-align: right;
    float: right;
    margin-right: 0.5em;
    margin-top: 0.5em;
}


/* ========== Land Programs ========== */

.option-land-panel .h-nav {
    margin-top: 1em;
}

.option-land-panel img {
    float: left;
    margin-right: 1em;
}

.option-land-panel .section > ul > li, .option-land-panel .section > ul > li {
    border-bottom: 1px solid #bfa874;
    padding: 0.5em;
}

.option-land-panel .section > ul > li:nth-child(odd), .option-land-panel .section > ul > li:nth-child(odd) {
    background-color: #efeadf;
}



.option-land-panel .land-program-content {
    float: left;
    width: 485px;
}

.option-land-panel .land-program-descrip {
    overflow: hidden;
    margin-top: 0.5em;
    margin-bottom: 0.5em;
    width: 100%;
    height: 40px;
    float: left;
    clear: both;
}

.option-land-panel .land-pricing {
    float: right;
    clear: none;
    margin-top: -25px;
    line-height : 1;
    text-align: right;
}

.option-land-panel .land-price {
    font-weight: bold;
    font-size: 125%;
}

.option-land-panel button {
    float: right;
    vertical-align: middle;
}

.option-land-panel .chosen {
    width: 350px;
    vertical-align: bottom;
    margin-top: 0.5em;
    display: inline-block;
}

.option-land-panel .chosen-container {
    margin-top: 5px;
}

.more-land-details-link {
    clear: none;
    text-align: right;
    float: right;
    margin-right: 0.5em;
    margin-bottom: 0.5em;
}

.option-land-panel a.remove-link {
    clear: right;
    float: right;
}



/* ========== Transfers & Visas ========== */

.option-transfers-visas-panel .h-nav li {
    width: 30%;
}

.option-transfers-visas-panel .h-nav li:last-child {
    width: 15%;
}

.transfers ul {
    margin-bottom: 2em;
}

.transfers li {
    list-style-type: none;
}

.transfers li:first-child {
    border-top: 2px solid #bfa874;
}

.transfers h5 {
    color: #333;
}

.transfers label {
    font-weight: normal;
    width: 80px;
    display: inline-block;
    cursor: pointer;
}

.transfers .transfer-pricing {
    float: right;
}

.transfers ul > li, .transfers ul > li {
    border-bottom: 1px solid #bfa874;
    padding: 0.5em;
}

.transfers ul > li:nth-child(odd), .transfers ul > li:nth-child(odd) {
    background-color: #efeadf;
}

.transfers .transfer-service {
    margin-left: 3em;
}

.transfers button {
    float: right;
}




.visas-panel .content {
    display:block;
    float: left;
}

ul.visa-selections {
    border-top: 1px solid #acacac;
    margin-top: 0.5em;
    float: left;
    width: 100%;
    margin-bottom: 1em;
}

ul.visa-selections li {
    list-style-type: none;
    border-bottom: 1px solid #acacac;
    padding: 0.5em;
    float: left;
    width: calc(100% - 1em);
}

ul.visa-selections li label {
    display: inline-block;
    cursor: pointer;
    font-weight: normal;
}

ul.visa-selections li span.visa-price{
    float: right;
}

.visas-panel p > label {
    margin-bottom: 1em;
    float: left;
    cursor: pointer;
}

.visas-panel h5 {
    margin-bottom: 0;
    margin-top: 1em;
}

.visas-panel button {
    float: right;
}


/* ========== Amenities ========== */

.amenities-list {
    float: left;
}

.amenities-list li {
    list-style-type: none;
    padding: 0.5em;
}

.amenities-list label {
    font-weight: normal;
    cursor: pointer;
    display: inline;
}

.amenities-promo-code {
    float: right;
    clear: none;
    text-align: center;
    background-color: #efeadf;
    border: 1px solid #acacac;
    padding: 1em;
    width: 200px;
}

    .amenities-promo-code label {
        margin-bottom: 0.5em;
    }

.amenities-promo-code button {
    margin-bottom: 0;
    float: none;
}

.amenities-list li.disabled {
	opacity: .8;
}
.amenities-list li.disabled input {
	cursor: default;
    opacity: .8;
}

.amenities-list li.disabled label {
    cursor: default;
    opacity: .8;
}
.amenities-list li.disabled span {
	color: #ff0000;
    opacity: 1.0;
}



/* ========== Value Packages ========== */

.option-value-panel ul.h-nav li {
    width: 30%;
}


.beverage div.content {
    width: 45%;
    float: left;
    margin: 0 1em;
    text-align: center;
    padding-bottom: 2em;
}

.beverage div.house {
    background: transparent url(/img/common/v-line.png) no-repeat right top;
    background-size: 1px 100%;
    padding-right: 1em;
}

.beverage h5 {
    font-size: 110%;
    margin-bottom: 1em;
}

.beverage p {
    text-align: justify;
    min-height: 80px;
}

.beverage .pricing div {
    float: left;
    width: 50%;

}

.beverage .pricing .price {
    font-size: 125%;
}

.beverage .selections {
    float: left;
    margin-top: 1em;
    width: 100%;
}

.beverage tr {
    background-color: #fff;
}
.beverage tr:last-child {
    border-bottom: none;
}

.beverage input[type="radio"] + label {
    font-weight: normal;
    cursor: pointer;
}
/* for some reason this radio does not vertically align - putting in a hack for now so I can move on... */
.beverage input[type="radio"] + label:before {
    margin-top: -3px;
}



/* ========== Internet ========== */


.option-value-panel .internet {
}

.option-value-panel .internet li {
    list-style-type: none;
    float: left;
    width: 30%;
    background: #fff url(/img/common/v-line.png) no-repeat top right;
    background-size: 1px 100%;
    padding: 1em;
    text-align: center;
}

.option-value-panel .internet li:first-child {
    padding-left: 0;
}

.option-value-panel .internet li:last-child {
    background-image: none;
    padding-right: 0;
}

.option-value-panel .internet h5 {
}

.option-value-panel .internet .pricing {
    clear: both;
}

.option-value-panel .internet p {
    clear: both;
}

.option-value-panel .internet .price {
    font-weight: bold;
}


.option-value-panel .internet p {
    margin-bottom: 0;
    margin-top: 0.5em;
}


.option-value-panel .internet .selections {
    float: left;
    margin-top: 1em;
    width: 100%;
}

.option-value-panel .internet tr {
    background-color: #fff;
}
.option-value-panel .internet tr:last-child {
    border-bottom: none;
}

.option-value-panel .internet input[type="radio"] + label {
    font-weight: normal;
    cursor: pointer;
}
/* for some reason this radio does not vertically align - putting in a hack for now so I can move on... */
.option-value-panel .internet input[type="radio"] + label:before {
    margin-top: -3px;
}




/* ========== Step 4 - Review ========== */

.review-panel tfoot td:first-child {
    text-align: right;
}

.review-panel .minus {
    color: red;
}

.review-panel td {
    border-right: 1px solid rgba(0,0,0,0.05);
}

.review-panel td:last-child {
    border-right: none;
}

.review-panel tbody {
    border-bottom: 3px double #ad9869;
}

.review-panel tfoot tr {
    background-color: #ececec
}
.review-panel tfoot td:first-child {
    font-weight: bold;
}


.review-panel button {
    float: right;
    margin-top: 1em;
}



/* ========== Step 5 - Guest Information Form with Travel Protection ========== */

.guest-info-panel .form {
    margin-bottom: 2em;
}

.guest-info-panel .form .left {
    width: 500px;
    background: transparent url(/img/common/v-line.png) no-repeat top right;
    background-size: 1px 100%;
    min-height: 200px;
}
/* chonsen left border gets cut off for some reason - only in bookin engine */
.guest-info-panel .form .item.city, .guest-info-panel .form .item.month, .guest-info-panel .form .item.day {
    margin-right: 2.1em;
}

.guest-info-panel .form .item. {
}

.guest-info-panel .form .left hr {
    width: calc(100% - 30px);
}

.guest-info-panel .form .right {
    width: 460px;
}

.guest-info-panel .form .address, .form .country {
    width: calc(100% - 1em) !important;
}

    .guest-info-panel .form .country .chosen-container {
        width: calc(100% - .75em) !important;
    }

.guest-info-panel .form .phone {
}|


.guest-info-panel {
}

.view-details-clicker {
    float: right;
}

ul.insurance-selections {
    margin-top: 0.5em;
    margin-bottom: 1em;
}

ul.insurance-selections .learn-more-clicker {
    margin-left: 1em;
    font-size: 75%;
}

.learn-more-content {
    display: none;
    border: 1px solid #acacac;
    background-color: #fff;
    padding: 0.5em 0.5em 0 0.5em;
    float: left;
    width: calc(100% - 1em);
    margin-bottom: 1em;
}

ul.insurance-selections li {
    list-style-type: none;
    /*border-bottom: 1px solid #acacac;*/
    padding: 0.5em;
    float: left;
    width: calc(100% - 1em);
    background-color: #efeadf;
}

ul.insurance-selections li label {
    display: inline-block;
    margin-left:  2em;
    cursor: pointer;
    font-weight: normal;
}

ul.insurance-selections li .terms-link {
    float: right;
}

ul.insurance-selections li .terms-content {
    border: 1px solid #acacac;
    background-color: #fff;
    padding: 0.5em;
    display: none;
    float: left;
    width: calc(100% - 1em);
    clear: both;
}

.insurance-disclaimer {
    padding: 0.5em;
    width: calc(100% - 1em);
    background-color: #efeadf;
    margin-bottom: 1em;
}


.insurance-selections .price {
    margin-left: 4em;
}

.view-details-content {
    border: 1px solid #acacac;
    background-color: #ececec;
    padding: 0.5em;
    display: block;
    display: none;
    float: left;
    width: calc(100% - 1em);
    clear: both;
    margin-bottom: 1em;

}
.form .fields, .form .fields label
{
    cursor: default;
}
.form .fields .disabled {
	opacity: .8;
}





/* ========== Confirm & Pay ========== */

.payment-panel tfoot td:first-child {
    text-align: right;
}

.payment-panel .minus {
    color: red;
}

.payment-panel table {
    margin-bottom: 1em;
}

.payment-panel table .min-due-disclaimer {
    width: 300px;
}

.payment-panel tr.commission {
    background-color: rgba(0,255,0,0.05);
}

.payment-panel td.text-right {
    text-align: right;
}

.payment-panel td {
    border-right: 1px solid rgba(0,0,0,0.05);
}

.payment-panel td:last-child {
    border-right: none;
}

.payment-panel td.pad {
    padding-left: 1.5em;
}

.payment-panel tbody {
    border-bottom: 3px double #ad9869;
}

.payment-panel tfoot tr {
    background-color: #ececec
}





.payment-panel tfoot td:first-child {
    font-weight: bold;
}

.payment-panel .guest-list {
    margin-bottom: 2em;
}

.payment-panel .guest-list span {
    display: inline-block;
}

.payment-panel .guest-list li {
    border-bottom: 1px solid #acacac;
    padding: 0.5em;
}

.payment-panel .guest-list span.label {
    font-weight: bold;
}

.payment-panel .guest-name {
    width: 250px;
}

.guest-club-num, .guest-club-level, .guest-rewards {
    margin-left: 3em;
}


/* Travel Agent Buttons */
.button-row {
    display: block;
}
.button-row button {
    margin-left: 1em;
}


/* Send Quote Panel for agent */
.send-quote {
    display: none;
    background-color: #ececec;
    border: 1px solid #acacac;
    padding: 1em;
    clear: both;
    margin-bottom: 2em;
}

.send-quote .item label {
    cursor: pointer;
}

.send-quote input[type="checkbox"] + label:before {
    font-weight: normal;
}

.send-quote span {
    vertical-align: top;
    padding: 0.5em;
}

.send-quote span.item span + span {
    display: inline-block;
    width: 80%;
    margin-left: 8px;
}

.send-quote span.item {
    display: inline-block;
    width: 39%;
}


.send-quote input {
    margin-bottom: 0;
}

/*.send-quote div {
    float: right;
    height: 40px;
}
.send-quote button {
    clear: both;
    margin: 0;
    display: block;
    float: none;
}*/

.send-quote button {
    margin-top: 65px;

}
.send-quote button.consumer {
    margin-top: 35px;

}


/* payment form */
.cc-form {
    /*display: none;*/
}

.cc-form .panel {
    display: inline-block;
}

.cc-form .panel.left {
    width: 530px;
    background: transparent url(/img/common/v-line.png) no-repeat top right;
    background-size: 1px 100%;
}

.cc-form .panel.right {
    width: 400px;
}

.cc-form h4 {
    margin-bottom: 1em;
}

.cc-form .responsible, .cc-form .responsible .chosen-container {
    width: 350px !important;
}

.cc-form.form .fields .country, .cc-form.form .fields .country .chosen-container {
    width: 350px !important;
}

.cc-form .fields .address {
    width: 350px;
}

.cc-guest-name {
    /*display: none;*/
}


/* payment information (credit card) */
.cc-form .cards {
    margin-bottom: 2em;
    float: left;
}

.cc-form .cards input[type='radio']{
    vertical-align:middle;
}

.cc-form .cards label {
    margin-bottom: 0.5em;
    /*display: inline-block;*/
    vertical-align: middle;
}

.cc-form .cards img {
    /*float: left;*/
    border: 1px solid #ccc;
    text-align: center;
    clear: none;
    padding: 3px;
    margin-right: 1em;
    margin-top: 0.25em;
    vertical-align: middle;
    -webkit-border-radius: 2px;
    -moz-border-radius: 2px;
    border-radius: 2px;
}

.cc-form .cards img:last-child {
    margin-right: 0;
}


.cc-form .cards img.success {
    background-color: #A2EAA5;
}

.fields .item.cc-num {
    width: 200px;
}

.fields .item.cc-cv {
    width: 75px;
    margin-right: 0;
}


.fields .cc-month, .fields .cc-month .chosen-container {
    width: 150px !important;
}

.fields .cc-year, .fields .cc-year .chosen-container {
    width: 100px !important;
    margin-right: 0;
}

.payment-bz-installments {
    margin-top: 15px;
}


/* payment amount */

.payment-amount-container {
    margin-top: 2em;
    width: 60%;
    margin: auto;
    text-align: center;
	clear:both;
}

.payment-amount-container div {
    text-align: left;
}


.payment label {
    margin-bottom: 0.5em;
    cursor: pointer;
    font-weight: normal;
}


.payment.left {
    float: left;
    width: auto;
}

.cc-payment-amount {
    float: right;
    clear: none;
}

.agree {
    clear: right;
}
.agree label{
    cursor: pointer;
    font-weight: normal;
}

.cc-payment-amount label {
    margin-left: 1em;
}

.financial-symbol {
    font-size: 150%;
    display: inline-block;
    vertical-align: top;
    line-height: 39px;
    height: 39px;

}
.cc-type
{
    float:left;
    margin-right: 3px;
}
.cc-payment-amount input {
    font-size: 150%;
    width: 120px;
    vertical-align: middle;
    text-align: right;
}

.payment-amount-container button {
    clear: both;
    margin-top: 2em;
}

/* Colorbox - Login Panel */
#cboxContent {

    overflow: visible;
    background: #fff;
    border: 3px solid #333;
}

#cboxClose {
    top: 0
}

#cboxLoadedContent {
    background: #fff;
}

    #cboxOverlay {
        background: #000;opacity: 0.5;
    }

#cboxLoadedContent{background:#fff; padding:1px;}
#cboxLoadingOverlay{background:#fff;}
.form input.invalid + label {
    /*-- override forms.css (don't highlight the label) --*/
    border: none;
    background-color: #fff;
}
#travelProtectionChoice
{
    float:left;
}
.form div.invalid/*.insurance-selections */
{
    border: 1px solid #820000;
    padding: 3px;
}
.booking-summary-inner-content
{
    position:relative;
}
.dimmed
{
    opacity: 0.5;
}
.summary-pacifier {
    width: 200px;
    border: 1px solid #333;
    background-color: #fff;
    position: absolute;
    left: 0;
    right: 0;
    top: 40%;
    margin: 2px;
    padding: .4em .2em .4em .2em;
    z-index: 5;
    opacity: 1;
}
.summary-pacifier span
{
    text-align: center;
}
.summary-pacifier img
{
    width: 200px;
}
.sendquote-response-modal, .sendquote-response-modal h5
{
    text-align: center;
    vertical-align: middle;
}
.invoice-panel
{
    clear: both;
}

.anchor-legend {
margin-left: 5em;
font-weight: normal;
text-transform: none;
}

.icon-anchor {
color: #735a24;
}
.icon-anchor {
margin-left: 5px;
}

.itinerary
{
    margin-top: .5em;
}

.linkdisabled 
{
    text-decoration: none;
    cursor: default;
    color: grey;
}

#cboxContent {
	background-color: transparent;
}

.modal .content-container {
	float: left;
	width: 100%;
	background-color: white;
}

.modal .content-container button {
	margin-right: 20px;
}

.booking-invoice-guest-manage-booking-row {
    text-align: center;
}

.booking-invoice-guest-manage-booking-row h3 {
    font-weight: bold;
}

.booking-invoice-guest-manage-booking-row-button {
    float: none;
    margin: 15px;
    width: 80px;
}

.payment-amount {
    clear: both;
    margin-bottom: 2em;
}

.payment-amount.-highlighted {
    background-color: #ececec;
    border: 1px solid #acacac;
    padding: 1em;
}

.payment-amount .payment-amount-wrapper {
    width: 40%;
    margin-left: auto;
}

.payment-amount .payment.left {
    width: 50%;
    min-height: 95px;
}

.payment-amount .payment-amount-title {
    margin-bottom: 20px;
    text-align: center;
}

.payment-amount .booking-engine-button {
    margin: 0;
}

.payment-amount .cc-payment-amount input {
    margin-bottom: 40px;
    text-align: left;
}

.payment-amount .cc-payment-amount label {
    font-weight: normal;
}

.payment-amount .payment-amount-form input[type="radio"] ~ .disclaimer {
    display: none;
}

.payment-amount .payment-amount-form input[type="radio"]:checked ~ .disclaimer {
    display: block;
}

/* New FEXCO Payment Page ///////////////////////////////////////////////////////////*/

.payment-booking .payment-iframe iframe {
    width: 100%;
    height: 650px;
}

.payment-booking .payment-booking-navigation-center {
    width: 50%;
    margin: 0 auto;
    text-align: center;
}

.payment-booking .payment-booking-navigation-center_item.-twoLines .payment-booking-navigation-center_item-price-label {
    display: block;
    margin-bottom: 8px;
}

.payment-booking .payment-booking-navigation-center_item.-twoLines .payment-booking-navigation-center_item-price-amount {
    font-weight: bold;
    font-size: 18px;
}

.payment-booking-navigation-center_item-price-amount {
    color: #735a24;
}

.payment-booking .payment-booking-navigation {
    margin-bottom: 8px;
}

.payment-booking .payment-booking-error-button {
    margin-top: 10px;
    margin-bottom: 0;
    float: none;
}

/* End New FEXCO Payment Page ///////////////////////////////////////////////////////*/