@font-face {
    font-family: 'bentonsans_regular';
    src: url('../fonts/bentonsans_regular-webfont.woff2') format('woff2'),
        url('../fonts/bentonsans_regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
  }

@font-face {
    font-family: 'bentonsans_mediumregular';
    src: url('../fonts/bentonsans_medium-webfont.woff2') format('woff2'),
        url('../fonts/bentonsans_medium-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'bentonsans_boldregular';
    src: url('../fonts/bentonsans_bold-webfont.woff2') format('woff2'),
        url('../fonts/bentonsans_bold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

html, body {
    height: 100%;
}

body {
	padding: 0;
	margin: 0;
	font-family: 'bentonsans_regular', Arial, sans-serif;
	background-color: #e2e2e2;
	overflow: scroll;
}

iframe {
	position: absolute;
	}

body > header {
	background-color: #00175A;
}

body > header > div {
	max-width: 984px;
	padding: 0;
	margin: 0 auto;
}

body > header img {
	padding: 10px;
	}
body > header a#menu {
	display: none;
	}
body > header h1 {
	display: none;
	}
body > header h2 {
	display: none;
	}

body > footer {
	background-color: #00175A;
}

body > footer > div {
	max-width: 944px;
	padding: 20px 20px 15px 20px;
	margin: 0 auto 9px auto;
	color: #ffffff;
}

body > footer p {
	margin: 0;
	padding: 0 0 5px 0;
	font-size: 10pt;
}

body > footer p.footer_links a {
	color: #66A9E2;
}

body > footer p.disclaimer {
	font-size: 11px;
}

h1, h2, h3, h4, h5, h6, p, ul, ol, form, a.btn {
	font-size: 1em;
	line-height: 1.4em;
	}

nav {
	display: flex;
	justify-content: center;
	background: #006FCF;
}

nav > div {
	max-width: 944px;
	width: 100%;
}

nav div.tabs {
	padding: 0 0 0 245px;
	line-height: 1.3em;
	display: flex;
}

nav div.tabs ul {
	margin: 0;
	padding: 0;
	font-size: 76%;
	list-style-type: none;
	background: url(../graphics/edge_nav_mytp_comp.png) no-repeat left top;
	}
nav div.tabs ul li {
	display: inline;
	list-style: none;
	}
nav div.tabs ul li a {
	display: block;
	padding: 8px 7px 6px 7px;
	text-align: center;
	text-decoration: none;
	white-space: nowrap;
	color: #ffffff;
	border: none;
	background: url(../graphics/edge_nav_mytp_comp.png) no-repeat right top;
	float: left;
	}
nav div.tabs ul li.here a {
	background: url(../graphics/edge_nav_mytp_comp.png) no-repeat right top #006FCF;
}

#base {
	position: relative;
	width: 984px;
	margin: 0 auto;
	padding: 0;
	min-height: 424px;
	background-color: #ffffff;
	}

#base form {
	width: auto;
	margin: 0;
	padding: 0;
	}
form:after {
	content: ".";
	display: block;
	height: 0;
	font-size: 1pt;
	clear: both;
	visibility: hidden;
	}
form h1 {
	margin: 40px 0 10px 0;
	font-size: 1.2em;
	color: #006FCF;
	}
label,
input[type="text"],
input[type="password"],
select {
	display: block;
	width: 100%;
	margin-bottom: 20px;
	padding: 6px 0;
	font-size: 1em;
	}
label {
	margin: 20px 0 0 0;
	color: #4d4f53;
	}
input[type="text"],
input[type="password"] {
	color: #777777;
	border: 1px solid #b2c2d2;
	width: 96%;
	margin-bottom: 20px;
	padding: 6px 2%;
	}
label.radio {
	display: inline-block;
	margin-top: 0;
	width: auto;
	}
.form_footer {
	padding: 20px 0;
	margin: 0;
	color: #4d4f53;
	border-top: 1px dashed #92a2b2;
	}
.form_footer p,
.form_footer a.btn {
	display: block;
	margin: 10px 0 0 0;
	width: 246px;
	}

a.btn,
input[type="submit"] {
	clear: both;
	display: block;
	margin-top: 20px;
	padding: 4px;
	text-align: center;
	text-decoration: none;
	color: #ffffff;
	background-color: #006FCF !important;
	border: none;
	border-radius: 12pt;
	line-height: 28px;
	}
input[type="submit"] {
	float: right;
	margin: 20px 0 30px 0;
	padding: 0 18px;
	font-size: 1.2em;
	}

table.dnlContent {
	margin-bottom: 20px;
	}
table.dnlContent .label {
	width: 450px;
	margin: 1px 0 0 !important;
	padding: 1px 0 0 !important;
	font-weight: bold;
	font-size: 15px !important;
	color: #4d4f53 !important;
	}
table.dnlContent .labelb {
	width: 550px !important;
	margin: 1px 0 0 !important;
	padding: 1px 0 0 !important;
	font-weight: bold;
	font-size: 15px !important;
	color: #4d4f53 !important;
	}
table.dnlContent .labelH {
	font-weight: bold;
	font-size: large !important;
	margin: 1px 0 10px !important;
	padding: 1px 0 0 !important;
	color: #4d4f53 !important;
	}
table.dnlContent .small {
	font-size: 10px;
	}
table.dnlContent a.link {
	color: #0066cc;
	font-size: 10pt;
	font-weight: normal;
	width: 50px;
	}

table.dnlContent tr td {
	width: 500px;
	}

.InvoiceSummaryHeader {
	text-align: left;
	padding: 0 20px 0 0;
	font-weight: bold;
	color: #006FCF;
	border: none;
	border-bottom: 1px solid #cccccc;
	}

.InvoiceHeading {
	font-weight: bold;
	font-size: 16px;
	margin-bottom: 10px;
	color: #4d4f53;
	}
.InvoiceText {
	color: #4d4f53;
	}
.InvoiceSummary {
	width: auto;
	text-align: left;
	margin-top: 10px;
	padding: 0 20px 0 0;
	color: #4d4f53;
	background-color: #ffffff;
	font-weight: 500;
	border: none !important;
	}

a.InvoiceSummary:link {
	color: #000000;
	}
a.InvoiceSummary:hover {
	color: #000000;
	}

.notegrey {
	width: 800px;
	font-size: 11px !important;
	color: #4d4f53;
	font-family: 'bentonsans_regular', Arial, sans-serif;
	text-align: left;
	line-height: normal;
	}

.ItinPrint {
	font-size: 1px;
	}

.bluebackground {
	background-color: #006FCF;
	color: #ffffff;
	border: none;
	background-position: left center;
	vertical-align: middle;
	padding-top: 5px;
	padding-right: 5px;
	padding-bottom: 5px;
	padding-left: 5px;
	font-weight: bold;
	text-decoration: none;
	}

a.bluebackground:hover {
	/*background-color: #000000;*/
	text-decoration: underline;
	}

/* Login / registration pages */
#base div.booking_search,
#base div.Invoice_search,
#base div.register,
#base div.registration_confirmation,
#base div.enter_new_password,
#base div.reset_password,
#base div.new_password_confirmed,
#base div.reset_password_confirmation,
#base div.change_password {
	padding: 10px 0 0 286px;
	min-height: 414px;
	background: url(../graphics/travel.png) no-repeat left 20px top 20px #ffffff;
	}

#base div.booking_search div#RadioDiv {
	position: absolute;
	visibility: hidden;
	}

#base div.booking_search form,
#base div.Invoice_search form,
#base div.register form,
#base div.registration_confirmation form,
#base div.enter_new_password form,
#base div.reset_password form,
#base div.new_password_confirmed form,
#base div.change_password form,
#base div.login #status_message,
#base div.register #status_message,
#base div.registration_confirmation #status_message,
#base div.enter_new_password #status_message,
#base div.new_password_confirmed #status_message,
#base div.change_password #status_message {
	width: 256px;
	}

#base div.reset_password_confirmation p {
	padding-right: 40px;
	}
#base #status_message p {
	margin: 0;
	}

/* Home page */
#base div.booking_search {
	min-height: 414px;
	display: none;
	padding-right: 10px;
}
#base div.booking_search form {
	width:100%;
	}

#base div.booking_search .contentWrap {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	}

#base div.booking_search .contentWrap #SelectLanguage {
	width: 120px;
	padding: 6px;
	}

#base div.booking_search .contentWrap .rightColumn {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	}

#base div.booking_search .contentWrap div:first-child {
	width: 260px;
	}

#base div.booking_search #country_select {
	position: absolute;
	visibility: hidden;
	}

.active{
	display: block !important;
	}

/* My Bookings page */
div.mybookings {
	position: relative;
	padding: 10px 50px 20px 0;
	min-height: 395px;
	text-align: left;
	background-color: #ffffff;
	}
div.mybookings h1 {
	margin-left: 246px;
	}
ul#mybookings_list {
	list-style-type: none;
	padding: 0;
	margin: 0 0 0 246px;
	min-height: 100px;
	border-top: 1px dashed #889ca8;
	}
ul#mybookings_list li {
	border-bottom: 1px dashed #889ca8;
	}
ul#mybookings_list li a {
	display: inline-block;
	padding: 8px;
	width: 100px;
	text-decoration: none;
	letter-spacing: .9pt;
	}
ul#mybookings_list li .booking_date {
	display: inline-block;
	padding: 8px;
	width: 200px;
	text-align: right;
	font-style: italic;
	color: #483c48;
	}

div.mybookings .login_admin {
	float: left;
	padding: 0 26px 0 40px;
	width: 180px;
	}
div.mybookings .login_admin h2 {
	margin: 0;
	}
div.mybookings .login_admin ul {
	margin: 8px 0 0 0;
	padding: 0;
	list-style-type: none;
	border-top: 1px solid #dddddd;
	}
div.mybookings .login_admin ul li {
	border-bottom: 1px solid #dddddd;
	}
div.mybookings .login_admin ul li a {
	display: block;
	padding: 8px 8px 8px 0;
	text-decoration: none;
	color: #006FCF;
	}

/* Itinerary for old Word-based booking */
div.itinerary {
	padding: 0 0 0 25px;
	background-color: #ffffff;
	}

#base div.invoice {
	padding: 10px 50px 20px 260px;
	min-height: 357px;
	background-color: #ffffff;
	}
#base div.invoice h1 {
	margin: 12pt 0 12pt 0;
	font-size: 1.2em;
	}
#base div.invoice table {
	margin: 5px 0 10px 0;
	}
#base div.invoice h2 {
	margin: 12pt 0 3pt 0;
	}
#base div.invoice p {
	margin: 0 0 9pt 0;
	}
#base div.invoice table img {
	display: none;
	}

/* eTicketView */
#base div.eticketview {
	padding: 10px 50px 20px 260px;
	min-height: 357px;
	background-color: #ffffff;
	}
#base div.eticketview form {
	margin: 0;
	width: 500px;
	}
div.eticketview form h1 {
	margin: 12pt 0 12pt 0;
	font-size: 1.2em;
	color: #000000;
	}

/* Help page */
#base div.help {
	padding: 10px 25px 20px 25px;
	background-color: #ffffff;
	display: flex;
}
ul#help_toc {
	list-style-type: none;
	margin: 0;
	padding: 75px 0 0 0;
	flex: 1;
	}
ul#help_toc li a {
	display: block;
	padding: 4px 0;
	text-decoration: none;
	color: #006FCF;
	}
ul#help_toc li:hover a {
	color: #006FCF;
	}
#help_content {
	margin-left: 50px;
	padding: 0;
	flex: 5;
	}
#base div.help #help_content h1 {
	margin: 12pt 0 12pt 0;
	font-size: 1.2em;
	}
#help_content h2 {
	margin: 18pt 0 6pt 0;
	font-size: 1.2em;
	color: #006FCF;
	}
#help_content h3 {
	margin-bottom: 6pt;
	}
#help_content p {
	margin-top: 6pt;
	}

/* Privacy page */
#base div.privacy {
	position: relative;
	padding: 10px 50px 20px 260px;
	min-height: 357px;
	background-color: #ffffff;
	}
#base div.privacy h3 {
	margin-bottom: 0;
	}
#base div.privacy p {
	margin-top: 0;
	}

/* D2C page */
#base div.d2c {
	position: relative;
	padding: 40px 50px 20px 20px;
	min-height: 364px;
	text-align: left;
	background-color: #ffffff;
	}

/* Message page */
#base div.message {
	position: relative;
	padding: 40px 50px 20px 260px;
	min-height: 364px;
	text-align: left;
	background-color: #ffffff;
	}
#base div.message #centre {
	text-align: left;
	}

/* Error page */
#base div.error {
	position: relative;
	padding: 40px 50px 20px 260px;
	min-height: 364px;
	text-align: left;
	background-color: #ffffff;
	}
#base div.error #centre {
	text-align: left;
	}

/* Travel Ads test block - TravelAds test results (winners & candidates) should not appear outside of QI Online. */
.QiLiveitinerary #winners,
.QiLiveitinerary #candidates {
	display: none !important;
	}