﻿@font-face { font-family: 'FontAwesome'; font-display: swap; }

@font-face { font-family: 'Ubuntu'; font-display: swap; }

* { font-family: "Ubuntu", sans-serif; }

body, a { color: #626262; font-size: 12px; }

input:focus, select:focus { outline: none; }

.transition { -webkit-transition: all 0.3s ease-out; -moz-transition: all 0.3s ease-out; -o-transition: all 0.3s ease-out; transition: all 0.3s ease-out; }
.striped:not(.ng-hide):nth-child(2n) { background: #f8f8f8 !important; }

/*
.striped.hidden:nth-child(even) + .striped:nth-of-type(odd) + .striped:nth-of-type(even),
.striped.ng-hide:nth-child(even) + .striped:nth-of-type(odd) + .striped:nth-of-type(even),
.striped.hidden:nth-child(even) + .striped.hidden:nth-child(odd) ~ .striped:nth-of-type(odd),
.striped.ng-hide:nth-child(even) + .striped.ng-hide:nth-child(odd) ~ .striped:nth-of-type(odd) { background: #f3f3f3 !important; }
*/


/* HEADER */
header { position: relative; }

	header img { max-width: 150px; margin: .5rem; }

	header .lang { width: 18px; height: 15px; }

	header .lang { background: url(../images/it-flag.jpg) no-repeat center center transparent; }

	header .lang-en { background-image: url(../images/en-flag.jpg); }

	header .lang-zh { background-image: url(../images/zh-flag.jpg); }

	header .lang:last-child { border-left: none; }

	/*.header { display: block; width: 100%; padding: 0 20px; font-weight: 500; z-index: 3; }
.header > * { position: relative; display: inline; vertical-align: middle; }
*/


	/* MAIN MENU */
	header ul { list-style: none; padding: 0; }

	header a { color: #3D5760; text-decoration: none; }

	header #navMainMenu { display: none; }

		header #navMainMenu nav .header-mobile-menu { display: none; }

		header #navMainMenu nav .back-history { display: none !important; }

		header #navMainMenu .nav.navbar-nav { position: relative; list-style: none; display: table; margin: 0 auto; width: 100%; text-align: center; }

			header #navMainMenu .nav.navbar-nav > li:hover { background-color: #f8f8f8; }

			header #navMainMenu .nav.navbar-nav > li { display: table-cell; height: 65px; padding: 0 10px; vertical-align: middle; }

				header #navMainMenu .nav.navbar-nav > li a { white-space: nowrap; }

				header #navMainMenu .nav.navbar-nav > li .fa-chevron-right { display: none; }

		header #navMainMenu .menu-viewer { position: absolute; top: 100%; left: 0; min-height: 255px; z-index: 20; }

			header #navMainMenu .menu-viewer .menu-viewer-history li:last-child .fa-caret-right { display: none; }

	header .countries-language-box { position: absolute; z-index: 3; min-width: 320px; right: 0; }
		header .countries-language-box .list-group-item { padding: 5px 10px; background-color: #FFF; border: none; line-height: 30px; font-size: 14px; }
			header .countries-language-box .list-group-item:hover { background-color: #dcdcdc; cursor: pointer; }

.navbarDropdownUser { position: relative; width: 40px; height: 40px; margin-left: auto; margin-right: auto; }
	.navbarDropdownUser label { margin: auto; font-size: 20px; margin-top: 4px; }

/* SUB MENU */
#section-sub-menu-container { text-align: center; text-transform: uppercase; }

#section-sub-menu { display: block; margin: 0; list-style: none; padding: 0; }

	#section-sub-menu > li { display: block; padding: 15px 20px; text-align: center; }
		#section-sub-menu > li.active { background: #FFF; border-top: 2px solid #e4e4e4; }
		#section-sub-menu > li > a { font-size: 14px; }

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {
	#section-sub-menu { display: inline-block; }
		#section-sub-menu > li { display: inline-block; }
}


/* Small devices (landscape phones, max whi576px)*/
@media (max-width: 576px) {
	nav .navbar-nav .menu-viewer { display: none; }

	header #navMainMenu nav .header-mobile-menu { display: flex; }

	header #navMainMenu nav .back-history { display: block; }

		header #navMainMenu nav .back-history a { font-size: .8rem !important; text-decoration: underline; text-transform: unset !important; display: inline-block !important; }

	.navbar-nav .dropdown-menu { position: absolute; top: 0; width: 100%; height: 1000px; border-radius: 0; margin: 0; border: 0; }

	header #navMainMenu.show-mobile { display: block; position: absolute; top: 0; right: 0; padding: 0; background-color: #fff; height: 1000px; width: 100%; z-index: 4; }

		header #navMainMenu.show-mobile .nav.navbar-nav { display: block; }

			header #navMainMenu.show-mobile .nav.navbar-nav li { display: block; height: auto; margin-bottom: 20px; padding: 0 1rem; }

			header #navMainMenu.show-mobile .nav.navbar-nav > li .fa-chevron-right { display: inherit; float: right; font-size: 1.5rem; line-height: 2.5rem; }

			header #navMainMenu.show-mobile .nav.navbar-nav li a { display: block; font-size: 1.2rem; font-weight: 400; text-transform: uppercase; }
}

/* WEB CHECK-IN LITE */
.wcl-container { position: fixed; top: 0; right: 0; left: 0; height: 100%; background-color: #FFF; padding: 2em; overflow-y: auto; z-index: 200; }
    .wcl-container #wcNeos { display: none }

/* FOOTER */
.footer a { color: #555; text-decoration: underline; }

.footer .header-mobile-menu, .footer .back-history { display: none !important; }

.footer .social-network { padding: 0px; list-style: none; }

	.footer .social-network li { float: left; width: 35px; height: 35px; margin-right: 8px; border-radius: 50%; border: 2px solid #555; }

		.footer .social-network li i { margin: auto; font-size: 18px; }

		.footer .social-network li.facebook i { margin-top: 8px; margin-left: 10px; }

		.footer .social-network li.twitter i { margin-top: 7px; margin-left: 8px; }

		.footer .social-network li.instagram i { margin-top: 7px; margin-left: 8px; }

		.footer .social-network li.youtube i { margin-top: 6px; margin-left: 6px; }

		.footer .social-network li.linkedin i { margin-top: 7px; margin-left: 8px; }

		.footer .social-network li.google i { margin-top: 6px; margin-left: 6px; }

.footer .navbar-menu-bottom .menu-viewer { display: none !important; }

.footer .navbar-menu-bottom { display: table; list-style: none; padding: 0; }

	.footer .navbar-menu-bottom > li { display: table-cell; margin-right: 40px; }

		.footer .navbar-menu-bottom > li > a { display: block; }

		.footer .navbar-menu-bottom > li > .dropdown-menu { display: block; background-color: inherit; border: none; }


/* USER BOX */

.user-box-container .user-box { position: fixed; top: 0; right: 0; width: 320px; height: 100%; visibility: hidden; background: #fff; opacity: 0; filter: alpha(0); z-index: -1; }

.user-box-container #user-box { width: 200px; }

/* .user-box-container:hover .user-box, */
.user-box-container .user-box.active { visibility: visible; opacity: 1; filter: alpha(100); z-index: 100; }


/* OFFER */
.container-offer .offer > div { display: block; overflow: hidden; position: relative; width: 100%; height: 256px; }

.container-offer .offer { overflow: hidden; }

	.container-offer .offer a { color: #fff; display: block; overflow: hidden; }

		.container-offer .offer a img { height: 100%; position: absolute; }

	.container-offer .offer.square img { position: relative !important; }

	.container-offer .offer .offer-body { position: absolute; bottom: 0; width: 100%; padding: 10px 10px 0 10px; font-weight: 400; line-height: 20px; background-color: rgba(0, 0, 0, 0.55); -webkit-box-shadow: 0px -4px 15px -7px rgba(0,0,0,0.5); -moz-box-shadow: 0px -4px 15px -7px rgba(0,0,0,0.5); box-shadow: 0px -4px 15px -7px rgba(0,0,0,0.5); }

		.container-offer .offer .offer-body .title { text-transform: uppercase; font-weight: 300; margin-bottom: 0; line-height: 15px; }

		.container-offer .offer .offer-body .price-offer { text-transform: uppercase; font-size: 22px; margin-top: 10px; }

#containerOffers .offer > div { background-color: #f3f3f3; }
#containerOffers .offer .btn { background-color: #6c757d; color: #fff; }

#containerOffers .offer:hover { text-decoration: none; color: #fff; border-color: #6c757d; }
	#containerOffers .offer:hover > div { background-color: #6c757d; }
	#containerOffers .offer:hover .btn { background-color: #5c6369; color: #fff; font-weight: 500; }

/* DETAILS FLIGHT */
.border-left-before:before { content: ""; position: absolute; top: 0; bottom: 0; left: 0; margin-left: 10px; width: 4px; background: #279bd4; z-index: 0; border: 2px solid #fff; box-sizing: content-box; }
.special-controller .list-group-item { background-color: transparent; border: none; padding: 0; margin-bottom: 0 !important; }
	.special-controller .list-group-item a { padding: 2px; font-size: 14px; }

.nav-link .fa-caret-right { position: absolute; right: -15px; font-size: 58px; top: -12px; transform: scale(0.5, 1); -webkit-transform: scale(0.5, 1); /* Safari and Chrome */ -moz-transform: scale(0.5, 1); /* Firefox */ -ms-transform: scale(0.5, 1); /* IE 9+ */ -o-transform: scale(0.5, 1); /* Opera */ }
	.nav-link .fa-caret-right.prev { right: unset; left: -6px; }
.nav-link .my-chevron-right { position: absolute; right: -22px; font-size: 93px; top: -26px; color: #cacaca; transform: scale(0.2, 1); -webkit-transform: scale(0.2, 1); /* Safari and Chrome */ -moz-transform: scale(0.2, 1); /* Firefox */ -ms-transform: scale(0.2, 1); /* IE 9+ */ -o-transform: scale(0.2, 1); /* Opera */ }
.nav-link.active .my-chevron-right { display: none; }
.nav-link .fa-caret-right { display: none; }
.nav-link.active .fa-caret-right { display: inline; }


@media (min-width: 576px) {
	.details-flight-navigation > .nav-item .nav-link { padding: 5px; }
	.nav-link .fa-caret-right { right: -13px; font-size: 48px; top: -10px; }
		.nav-link .fa-caret-right.prev { left: -6px; }
}

@media (min-width: 768px) {
	.nav-link .fa-caret-right { right: -13px; font-size: 48px; top: -10px; }
		.nav-link .fa-caret-right.prev { left: -5px; }
}

@media (min-width: 992px) {
	.nav-link .fa-caret-right { right: -20px; font-size: 74px; top: -16px; }
		.nav-link .fa-caret-right.prev { left: -9px; }
}
/* ------------- */

/* Small devices (landscape phones, 576px and up)*/
@media (min-width: 576px) {
	.border-left-before:before { margin-left: 10px; }
}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {
	.border-left-before:before { margin-left: 16px; }
}

/* Large devices (desktops, 992px and up) */
@media (min-width: 992px) {
	.border-left-before:before { margin-left: 28px; }
	.user-box-container .user-box { position: absolute; top: 100%; right: 0; width: 320px; height: unset; }
}


.border-left-dashed-before:before { content: ""; position: absolute; top: 0px; bottom: -14px; left: -4px; margin-left: -94px; width: 4px; background: #279bd4; z-index: 0; border: 2px dashed #fff; }

/*.section-title-page { border: 0.1rem solid #dcdcdc; border-left: 0; border-right: 0; margin-bottom: 20px; background-color: #dcdcdc; padding: 5px 0; }*/
.section-title-page { border-top: 0.1rem solid #e1e1e1; border-left: 0; border-right: 0; margin-bottom: 20px; background-color: #f8f8f8; padding: .5rem 0; }
	.section-title-page h3 { text-transform: uppercase; margin: 0; }
		.section-title-page h3 small { text-transform: lowercase; font-size: 60%; font-weight: 300; }

/* PAYMANT CONTROL */
.ul-pay-options { list-style: none; padding: 0; }

	.ul-pay-options li { display: inline-block; margin-right: 20px; }
/* ############## */


/* LOADING CONTAINER */
.loading-container { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(255, 255, 255, 0.8); background: rgba(255, 255, 255, 0.8); z-index: 9999; }
	.loading-container img { position: relative; top: 50%; left: 50%; margin-left: -50px; margin-top: -35px; width: 100px; }
	.loading-container.on-load { background-color: rgba(255, 255, 255, 1); background: rgba(255, 255, 255, 1); }
/* ################# */


/* PRIVATE RESERVATION VIEW */
.container-modify-reservation { position: fixed; top: 0; right: -320px; background-color: #FFF; width: 100%; max-width: 320px; height: 100%; padding: 10px; border-left: 1px solid #e4e4e4; z-index: 2; }
	.container-modify-reservation .confirm-content { position: absolute; bottom: 40px; width: 100%; }

/*  #################  */

/* Small devices (landscape phones, 576px and up)*/
@media (min-width: 576px) {
}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {
	/*  header img { max-width: 150px; margin: .3rem 1.5rem; }*/

	header #navMainMenu { display: block; }
}

/* Large devices (desktops, 992px and up) */
@media (min-width: 992px) {
}

/* Extra large devices (large desktops, 1200px and up) */
@media (min-width: 1200px) {
	.container { max-width: 1200px; }
}

/*  CMS PAGE EDITOR */
#img-full { width: 100%; }
.edit-cms { position: relative; background-color: #fafafa; opacity: 0.8; border-style: dotted; border-width: 2px; -webkit-transition: all 0.5s ease-out; -moz-transition: all 0.5s ease-out; -o-transition: all 0.5s ease-out; transition: all 0.5s ease-out; }
	.edit-cms .edit-cms-item { position: absolute; top: 0; left: 0; height: 30px; width: 100%; z-index: 9999; }
/* ################ */

/* ICON */
.icon { position: relative; }

	.icon::before, .icon::after { display: inline-block; font-style: normal; font-variant: normal; text-rendering: auto; -webkit-font-smoothing: antialiased; position: absolute; top: 0; font-family: "Font Awesome 5 Pro"; font-weight: 900; }

	.icon::before { left: 0; }

	.icon::after { right: 0; }

.icon-rules { display: inline-block; background: url(/assets/images/class-property.png) no-repeat transparent; width: 20px; height: 22px; }
	.icon-rules.icon-rules-white { background: url(/assets/images/class-property-white.png) no-repeat transparent; }
	.icon-rules.icon-seat-C { background-position: 0px 0px; }
	.icon-rules.icon-seat-Y { background-position: 0px -22px; }
	.icon-rules.icon-briefcase { background-position: 0px -42px; }
	.icon-rules.icon-suitcase { background-position: 0px -67px; }
	.icon-rules.icon-meal { background-position: 0px -91px; }
	.icon-rules.icon-checkin { background-position: 0px -114px; }
	.icon-rules.icon-vip-lounge { background-position: 0px -136px; }
	.icon-rules.icon-fast-track { background-position: 0px -158px; }
	.icon-rules.icon-tablet { background-position: 0px -181px; }
	.icon-rules.icon-change { background-position: 0px -204px; }
	.icon-rules.icon-refund { background-position: 0px -223px; }

.chevron-right-before::before, .chevron-right-after::after { content: "\f054"; }

/* ANGULAR */
input.ng-invalid-piva, input.ng-invalid-sdi, input.ng-invalid-email, input.ng-invalid-number, input.ng-invalid-zip, input.ng-invalid-mobile { background-color: #FFE4E4 !important; }
