/* RESET */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,font,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}:focus{outline:0}ins{text-decoration:none}del{text-decoration:line-through}table{border-collapse:collapse;border-spacing:0}
img { display: block }
*, *:before, *:after { box-sizing: border-box;  }
html { -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-smoothing: antialiased; }

/* NOT in the DLS */
	@font-face{
		font-family:'BentonSans';
		src:url("../fonts/BentonSansBold.woff") format("woff");
		font-weight: 700;
	}

	@font-face{
		font-family:'BentonSans';
		src:url("../fonts/BentonSansMedium.woff") format("woff");
		font-weight: 500;
	}

body {
	font-family: 'BentonSans', 'Helvetica Neue', Helvetica, sans-serif; font-weight: normal;
	color: #333;
}

.inav-header  [class^="axp-global-header__dls__module___"] [class*="axp-global-header__dls__navSticky___"]  {
	top: -60px !important;
	left: 0 !important;
	position: relative !important;
}

.inav-header { height: 60px; }

.logoNav-wrap {
	width: 100%;
	background: #fff;
	border-bottom: 1px solid #ededed;
}

.logoNav {
	display: flex;
	justify-content: space-between;
	width: 100%;
	max-width: 1000px;
	padding: 0 10px;
	margin: 0 auto;
	height: 80px;
}

	.logoNav-logo { 
		color: #1e2257;
		font-family: 'BentonSans', 'Helvetica Neue', Helvetica, sans-serif;
		font-size: calc(1.9rem * .625);
		text-decoration: none;
		display: flex;
		align-items: center;
		font-weight: 500;
	}
		
	.logoNav-links {
		display: flex;
		align-items: center;
	}

	.logoNav-link {
		color: #006fcf;
		font-size: calc(1.6rem * .625);
		text-decoration: none;
		display: flex;
		align-items: center;
		height: 80px;
		margin-left: 2em;
	}
	
	.logoNav-link:hover, .logoNav-link:focus { color: #006fcf; }
	
	.logoNav-link-on {
		color: #006fcf;
		background-image: linear-gradient(#006fcf, #006fcf);
		background-size: 100% 4px;
		background-position: 0 100%;
		background-repeat: no-repeat;
	}

.greyBG {
	background: #ededed;
	padding: 40px 0;
}

.map-intro {
	width: 100%;
	border-bottom: 20px solid #ededed;
	padding-bottom: 2em;
}

.map-intro-text {
	padding: 2.5em 2.5em 0 2.5em;
	max-width: 940px;
}

.mapBG {
	width: 95%;
	max-width: 984px;
	max-width: 1000px;
	margin: 0 auto;
	position: relative;
	background: #fff;
}

.map {
	width: 100%;
	padding-top: 50.71%;
	background-image: url("../images/regions/map_base.gif");
	background-repeat: no-repeat;
	background-size: contain;
	position: relative;
}

	.map svg { position: absolute; top: 0; left; 0; width: 100%; height: 100%;}

.map-area {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-size: contain;
	opacity: 0;
	transition: opacity .125s;
	animation-fill-mode: forwards !important;
}

.spot {
	background: rgba(255,0,0,0);
	position: absolute;
	z-index: 2;
	width: 10%;
	max-width: 120px;
	height: 20%;
	max-height: 120px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	cursor: pointer;
}


 .spot::before {
	content: '';
	width: 10px;
	height: 10px;
	background: #006fcf;
	border-radius: 50%;
	display: block;
	flex-shrink: 0;
	transition: width .125s, height .125s;
}

.spot:hover::before, .spot-on::before { 
	width: 40px;
	height: 40px;
	background-color: #a8a8a8;
	background-image: url(../images/dls-icon-airplane.svg);
	background-repeat: no-repeat;
	background-position: 50% 50%;
	box-shadow: 0px 0px 9px rgba(0,0,0,.25);
	background-size: 75%;
	border: 2px solid #fff;
 }
 
 .spot-on::before { background-color: #006fcf !important; }

.Canada { left: 17%; top: 12.6%; }
.America_US { left: 17%; top: 25.65%; }
.America_Central  { left: 17%; top: 36.7%; }
.America_South { left: 27.4%; top: 53.7%; }
.Europe_West  { left: 43.8%; top: 20.6%; }
.Africa  { left: 47.8%; top: 41.3%; }
.Europe_Eastern  { left: 51.6%; top: 16.8%; }
.MiddleEast  { left: 54.8%; top: 30.7%; }
.Asia_Central  { left: 60.2%; top: 20.8%; }
.Asia_South  { left: 63.1%; top: 34.9%; }
.Asia_Eastern  { left: 68.7%; top: 16.8%; }
.Asia_SouthEast  { left: 73.2%; top: 47.3%; }
.Australia_Oceania  { left: 76.6%; top: 63.3%; }

.Canada:hover + .map-area, .Canada:focus + .map-area, .Canada-on + .map-area { background-image: url("../images/regions/Map_Canada.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.America_US:hover + .map-area, .America_US:focus + .map-area, .America_US-on + .map-area { background-image: url("../images/regions/Map_America_US.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.America_Central:hover + .map-area, .America_Central:focus + .map-area, .America_Central-on + .map-area { background-image: url("../images/regions/Map_America_Central.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.America_South:hover + .map-area, .America_South:focus + .map-area, .America_South-on + .map-area { background-image: url("../images/regions/Map_America_South.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Africa:hover + .map-area, .Africa:focus + .map-area, .Africa-on + .map-area { background-image: url("../images/regions/Map_Africa.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Europe_West:hover + .map-area,.Europe_West:focus + .map-area, .Europe_West-on + .map-area { background-image: url("../images/regions/Map_Europe_West.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Europe_Eastern:hover + .map-area, .Europe_Eastern:focus + .map-area, .Europe_Eastern-on + .map-area { background-image: url("../images/regions/Map_Europe_Eastern.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.MiddleEast:hover + .map-area, .MiddleEast:focus + .map-area, .MiddleEast-on + .map-area { background-image: url("../images/regions/Map_MiddleEast.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Asia_Central:hover + .map-area, .Asia_Central:focus + .map-area, .Asia_Central-on + .map-area { background-image: url("../images/regions/Map_Asia_Central.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Asia_South:hover + .map-area, .Asia_South:focus + .map-area, .Asia_South-on + .map-area { background-image: url("../images/regions/Map_Asia_South.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Asia_Eastern:hover + .map-area, .Asia_Eastern:focus + .map-area, .Asia_Eastern-on + .map-area { background-image: url("../images/regions/Map_Asia_Eastern.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Asia_SouthEast:hover + .map-area, .Asia_SouthEast:focus + .map-area, .Asia_SouthEast-on + .map-area { background-image: url("../images/regions/Map_Asia_SouthEast.png"); opacity: .3; filter: brightness(0) grayscale(1); }
.Australia_Oceania:hover + .map-area, .Australia_Oceania:focus + .map-area, .Australia_Oceania-on + .map-area { background-image: url("../images/regions/Map_Australia_Oceania.png"); opacity: .3; filter: brightness(0) grayscale(1); }

#one-airline .spot:hover + .map-area { opacity: 0 !important; filter: grayscale(0) !important; }
#one-airline .spot:hover { cursor: auto !important; }

.region-on { opacity: 1 !important; filter: grayscale(0) !important;}

#plane-Canada path { animation: fadeOutPlane var(--Canada); }
#plane-America_Central path { animation: fadeOutPlane  var(--America_Central);  }
#plane-America_South path { animation: fadeOutPlane  var(--America_South);  }
#plane-Africa path { animation: fadeOutPlane  var(--Africa);  }
#plane-Europe_West path { animation: fadeOutPlane  var(--Europe_West);  }
#plane-Europe_Eastern path { animation: fadeOutPlane  var(--Europe_Eastern);  }
#plane-MiddleEast path { animation: fadeOutPlane  var(--MiddleEast);  }
#plane-Asia_Central path { animation: fadeOutPlane  var(--Asia_Central);  }
#plane-Asia_South path { animation: fadeOutPlane  var(--Asia_South);  }
#plane-Asia_Eastern path { animation: fadeOutPlane  var(--Asia_Eastern);  }
#plane-Asia_SouthEast path { animation: fadeOutPlane  var(--Asia_SouthEast);  }
#plane-Australia_Oceania path { animation: fadeOutPlane  var(--Australia_Oceania);  }

.thePlane {
	 animation-fill-mode: forwards !important;
}

label {
	display: block;
	font-size: calc(1.4rem * .625);
	margin-bottom: .5em;
}

.regions {
	display: none;
	width: 90%;
	margin: 0 auto;
	max-width: 600px;
}

/* these are display none so only the right ones get turned on */
.flightpath { display: none; animation: hideLines var(--hideLines); animation-fill-mode: forwards; stroke-dasharray: 2,2; fill: none; stroke: #ccc;}

#one-airline .Canada + .map-area { background-image: url("../images/regions/Map_Canada.png"); animation: showRegion var(--Canada);  }
#one-airline .America_US + .map-area { background-image: url("../images/regions/Map_America_US.png"); animation: showRegion var(--America_US); }
#one-airline .America_Central + .map-area { background-image: url("../images/regions/Map_America_Central.png"); animation: showRegion var(--America_Central); }
#one-airline .America_South + .map-area { background-image: url("../images/regions/Map_America_South.png"); animation: showRegion var(--America_South); }
#one-airline .Africa + .map-area { background-image: url("../images/regions/Map_Africa.png"); animation: showRegion var(--Africa); }
#one-airline .Europe_West + .map-area { background-image: url("../images/regions/Map_Europe_West.png"); animation: showRegion var(--Europe_West);  }
#one-airline .Europe_Eastern + .map-area { background-image: url("../images/regions/Map_Europe_Eastern.png"); animation: showRegion var(--Europe_Eastern);  }
#one-airline .MiddleEast + .map-area { background-image: url("../images/regions/Map_MiddleEast.png"); animation: showRegion var(--MiddleEast);  }
#one-airline .Asia_Central + .map-area { background-image: url("../images/regions/Map_Asia_Central.png"); animation: showRegion var(--Asia_Central);  }
#one-airline .Asia_South + .map-area { background-image: url("../images/regions/Map_Asia_South.png"); animation: showRegion var(--Asia_South);  }
#one-airline .Asia_Eastern + .map-area { background-image: url("../images/regions/Map_Asia_Eastern.png"); animation: showRegion var(--Asia_Eastern);  }
#one-airline .Asia_SouthEast + .map-area { background-image: url("../images/regions/Map_Asia_SouthEast.png"); animation: showRegion var(--Asia_SouthEast);  }
#one-airline .Australia_Oceania + .map-area { background-image: url("../images/regions/Map_Australia_Oceania.png"); animation: showRegion var(--Australia_Oceania);  }

#one-airline .spot::before { display: none; }

#one-airline svg g {
	display: none;
}

#one-airline { pointer-events: none; }

.airlines-head, .partners-head {
	text-align: center;
	font-size: calc(1.6rem * .625);
	max-width: 1000px;
	margin: 0 auto;
	padding: 1em 0;
	line-height: 1.4em;
}

.airlines-head { padding-bottom: 3px;}	
	.airlines-head a { color: #006fcf; text-decoration: none; border-bottom: 2px solid #006fcf; }

.partnersBG {
	background: #fff;
	margin: 2em auto 0 auto;
	padding-bottom: 2em;
	width: 100%;
	max-width: 1000px;
}

.airlines {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	justify-content: center;
}

.airline {
	width: 175px;
	height: 140px;
	border: 1px solid #EDEDED;
	margin: 5px;
	display: flex;
	flex-direction: column;
	justify-content:center;
	background: #fff;
	text-decoration: none;
}

.partner-airlines .airline { width: 175px; height: 175px; }

.plane-logo { display: flex; align-items: center; justify-content: center;} 

.plane-logo img { width: 80%; }

.airline-on, .airline-on:active {
	/* outline: 2px solid #006fcf; */
	outline: 2px solid #006fcf;
	background: rgba(0,111,207,.06);
}

.airline:hover, .airline:focus {
	transform:scaleY(1.25);
	transform-origin: 0 0;
	box-shadow: 0 2px 8px 0 rgba(0,0,0,0.21);
}

.airline-cta {
	position: absolute;
	bottom: -5px;
	width: 100%;
	border-top: 1px solid #ededed;
	padding: 1em .5em;
	color: #006fcf;
	font-size: calc(1.4rem * .625);
	display: none;
	background-image: url(../images/dls-glyph-right.svg);
	background-repeat: no-repeat;
	background-position: 95% 50%;	
	/* background-color: #F7F8F9; */
	background-color: #fff;
}

.airline:hover .plane-logo, .airline:focus .plane-logo { transform: scaleY(.8); margin-top: -20%; }
.airline:hover .airline-cta, .airline:focus .airline-cta { transform: scaleY(.8); display: block;}


.accent-bar {
    background: #006fcf;
    height: 4px;
    width: 100%;
}

.airline-intro {
	display: flex;
	padding: 40px;
}

.airline-logo {
	width: 275px;
	flex-shrink: 0;
}

.airline-intro-text {
	margin-left: 4em;
}

.map-regions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	background: #f7f8fa;
	padding: 1em 0;
}

.map-regions div { 
	font-size: calc(1.5rem * .625);
	margin: 1em;
}

.map-head {
	text-align: center;
	font-size: calc(1.6rem * .625);
	padding-top: 2em;
	margin: 0 1em;
	line-height: 1.4em;
}

.alliance {
	background: #fff;
	margin: 20px auto 0 auto;
	max-width: 1000px;
	width: 100%;
}

.alliance-intro-wrap {
	border-bottom: 1px solid #ccc;
	padding: 4em 2em 1em 3em;
	background-size: 90px;
	background-repeat: no-repeat;
	background-position: 95% 50%;
	min-height: 125px;
}

.alliance p {
	max-width: 75%;
}

.alliance-partners {
	padding: 20px 30px;
	column-count: 5;
	column-gap: 2em;
}

.alliance-partner {
	display: inline-block;
	font-size: calc(1.5rem * .625);
	line-height: 1.4em;
	margin-bottom: 1.5em;
}

	.isPartner { 
		background-image: url(../images/dls-icon-airplane-blue.svg);
		background-size: 18px;
		background-repeat: no-repeat;
		background-position: 0 0;
		padding-left: 24px;
		position: relative;
	 }

.alliance-footer {
	display: flex;
	font-size: calc(1.6rem * .625);
	justify-content: space-between;
	background: #f7f8fa;
	align-items: center;
	height: 60px;
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	padding: 0 2em;
}

.alliance-footer-key { font-size: calc(1.5rem * .625); }

.alliance-footer-only { background: #fff; }

.alliance-footer-link {
	color: #006fcf;
	background-image: url(../images/dls-glyph-right.svg);
	background-repeat: no-repeat;
	background-position: 100% 50%;
	text-decoration: none;
	padding-right: 2em;
}

	.alliance-footer-link:hover, .alliance-footer-link:focus { text-decoration: underline; }

.transfer-points {
	text-align: center;
	font-size: calc(1.6rem * .625);
	margin: 2em 0 0 0;
	width: 100%;
	display: block;
}

	.transfer-points a { color: #006fcf; }

@keyframes showRegion {
  0%   { opacity: 0; }
  90% { opacity: 0; }
  100% { opacity: 1; }
}		

@keyframes fadeOutPlane {
  0%   { fill: #666; opacity: 1;}
  90% { opacity: 1; }
  100% { opacity: 0; }
}		

@keyframes hideLines {
  0%   { opacity: 1; }
  90% { opacity: 1; }
  100% { opacity: 0; }
}		

.btn {
	background: #006fcf;
	color: #fff;
	padding: 1em 0;
	text-align: center;
	margin-top: 2em;
	display: block;
	text-decoration: none;
	font-size: calc(1.6rem * .625);
	border-radius: 4px;
	transition: background .125s;
}

.btn:hover, .btn:focus { background: #005299; }

h1 {
	font-weight: normal;
	font-size: calc(2.2rem * .625);
	margin-bottom: 1em;
	line-height: 1.3em;
}

p {
	font-size: calc(1.6rem * .625);
	line-height: 1.6em;
	margin-bottom: 1em;
}

select.pretty-dropdown { 
 	background: #ffffff url("../images/dd-down.svg");
	color: #40494e;
	border: none;
	outline: none;
	border-radius: 4px;
 	border: 1px solid #b2b7bd;
	cursor: pointer;
	font-size: 16px;
	font-weight: 400;
	padding: 6px 12px;
	background-position:  right center;
	background-repeat: no-repeat;
	background-size: 36px;
	overflow: hidden;
	text-indent: 0.01px;
	-moz-appearance: none  !important; 
	appearance: none  !important;
	-ms-appearance: none  !important; 
	-o-appearance: none !important;
	-webkit-appearance: none;
	outline: none;
	box-shadow: none;
	width: 100%;
}

select.pretty-dropdown:focus {
 	background-color: #fff;
 }
 
select.pretty-dropdown:hover {
 	background-color: #ffffff;
	color: #40494e;
 	transition: background-color  .2s;
 	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

select.pretty-dropdown::-ms-expand { 
	display: none;
}

sup,
sub {
	height: 0;
	line-height: 1;
	vertical-align: baseline;
	_vertical-align: bottom;
	position: relative;
	font-size: 80%;
	display: inline-block; /* this is required so that the sup'd item doesn't get an underline on hover */
	text-decoration: none !important;
}

sup {
	bottom: 1.1ex;
}

.sticky {
  position: -webkit-sticky;
  position: -moz-sticky;
  position: -o-sticky;
  position: -ms-sticky;
  position: sticky;
  top: 0px;
  z-index: 3;
}


/* IE11 and Edge
https://blog.trigent.com/css-browser-specific-hacks/ */
_:-ms-lang(x), #one-airline svg { display: none; }
_:-ms-lang(x), #one-airline .ie11 + .map-area { animation: showRegion 0s;}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
	.airline:hover .plane-logo, .airline:focus .plane-logo { margin-top: -18px; }
}



@media screen and (max-width: 1000px) {
	.inav-fpo-left { background: url(../images/inav/inav-tablet-left.gif) no-repeat; width: 275px; }
	.alliance-partners { column-count: 4; }
}

@media screen and (max-width: 750px) {
	.airline-intro { flex-direction:column; padding: 10px 30px; }
	.airline-intro-text { margin: 2em 0 0 0; }
	.airline-logo { margin: 2em auto; }

	.alliance-partners { column-count: 3; }
}

@media screen and (max-width: 670px) {
	.spot::before { display: none; }
	.regions { display: block; margin-top: 2em; }
	.partners-head { text-align: left; font-size: calc(1.4rem * .625); margin: 2em; }
	.airlines-head { display: none; }
}

@media screen and (max-width: 600px) {
	.inav-fpo-left { background: url(../images/inav/inav-mobile-left.gif) no-repeat; width: 202px; }
	.inav-fpo-right { background: url(../images/inav/inav-mobile-right.gif) no-repeat; width: 90px; }
	.alliance-partners { column-count: 2; }
}

@media screen and (max-width: 500px) {
	.alliance-footer { flex-direction: column; padding: 2em 0 3em 0; justify-content: center;}
	.alliance-footer-key { margin: 1em 0; }
	.airline { width: 170px; }
	.logoNav-wrap { position: relative !important; }
	.logoNav, .logoNav-link { height: 50px; }
	.logoNav-logo, .logoNav-link { font-size: calc(1.4rem * .625);}
	.partner-airlines .airline { width: 150px; height: 150px; }

}
