/* #Site Styles
================================================== */

/* Wraps
-------------------------------------------------- */

	.wrap {
		width: 100%;
		position: relative;
		padding: 80px 0 70px;
	}
	.wrap.header {
		position: fixed;
		padding: 40px 0 40px;
		z-index: 100;
		transition: background 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	}
		.wrap.header.shadow {
			background: rgba(41,50,50,0.98);
		}

	.breadcrumb {
		background: #fff;
		border-bottom: 1px solid rgba(0,0,0,0.1);
		padding: 12px 0 11px;
		z-index: 2;
	}
	.wrap.notice {
		padding: 33px 0 15px;
		background: #fc0;
	}
		.wrap.notice p {
			text-transform: uppercase;
			font-size: 1.125em;
		}
	.content {
		background: #fff;
		border-top: 1px solid rgba(0,0,0,0.08);
		box-shadow: 0 -1px 5px 0 rgba(0, 0, 0, 0.06);
	}
	.content.bg {
		background: #fff url(../images/bg-content.png) center top repeat-y;
	}
	.mapHolder {
		padding: 0;
	}
	.wrap.footer {
		padding: 40px 0 30px;
		background: rgba(41,50,50,1);
	}
	
	.wrap.planes {
		height: 40.5vW;
		min-height: 600px;
		padding: 0;
		background-color: rgb(41,50,50);
		background-color: linear-gradient(180deg, rgba(51,60,60,1) 0%, rgba(30,36,36,1) 100%);
		background-size: contain;
		background-position: right;
		background-repeat: no-repeat;
		border-bottom: 4px solid #9cf0f0;
	}
		.wrap.planes.bgImage {
			background-size: cover;
			background-position: center;
		}
	.wrap.planes .overlay {
		background: linear-gradient(180deg, rgba(41,50,50,0.6) 0%, rgba(30,36,36,0.6) 100%);
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		z-index: 2;
	}
	.wrap.planes .bgVid {
		width: 100%;
		height: 100%;
		position: absolute;
		bottom: 15%;
		z-index: 1;
		display: flex;
		align-items: flex-end;
	}
	.wrap.planes #container {
		width: 100%;
		height: 100%;
		position: absolute;
	}
	.wrap.planes .container {
		z-index: 3;
		height: 100%;
	}
	.wrap.planes h1,
	.wrap.planes p {
		color: #fff;
	}
	.wrap.planes h1 {
		margin-top: 40px;
	}
	.wrap.planes p {
		font-size: 1.125em;
		margin-bottom: 40px;
	}
	.wrap.planes .vAlign {
		align-self: center;
	}

.wrap.split {
	padding-bottom: 0;
}


/* Header
-------------------------------------------------- */

#logo a {
	display: block;
	background: rgba(41,50,50,0);
	width: 220px;
	/*padding: 15px;
	margin: -15px 0 0 -15px;*/
	float: left;
	box-sizing: border-box;
	transition: background 0.9s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}
/*.wrap.header.shadow #logo a {
	background: rgba(41,50,50,1);
	
}*/
#logo svg {
	display: block;
	width: 100%;
	height: auto;
}


/* Breadcrumb
-------------------------------------------------- */
	
.breadcrumb ul, .breadcrumb li {
	list-style: none;
	padding: 0;
	margin: 0;
}

.breadcrumb li {
	font-size: 0.9em;
	font-style: italic;
	float: left;
	margin: 0;
	color: #aaa;
}

.breadcrumb li a {
	color: #656565;
	text-decoration: none;
}
	.breadcrumb li a:hover {
		color: #000;
		text-decoration: underline;
	}


/* Map
-------------------------------------------------- */
		
#gMapHolder {
	margin-bottom: 20px;
	background: #000;
	padding: 0 !important;
}

#gMap {
	max-width: 100%;
	height: 550px;
	background: #000;
}
		
		
/* Content
-------------------------------------------------- */

.motif {
	width: 135px;
	margin: 60px auto 20px;
	animation-name: float;
	animation-duration: 1s;
	animation-iteration-count: infinite;
	animation-timing-function: ease-in-out;
}
.motif.sm {
	width: 100px;
	margin: 0 auto 40px;
}

/* sub navigation */

ul.subNav, ul.subNav li {
	margin: 0;
	padding: 0;
	list-style: none;
    background: none;
}
ul.subNav {
	margin: 0 0 44px;
}
ul.subNav li a {
	display: block;
	font-size: 1.1em;
	padding: 12px 0 12px 5px;
	border-bottom: 1px solid rgba(0,0,0,0.25);
}
ul.subNav li a:after {
	display: block;
	content: "";
	float: right;
	background: url('../images/sprite.png') no-repeat -55px -175px;
	background-size: 500px 500px;
	width: 8px;
	height: 14px;
	margin-right: 10px;
	margin-top: 9px;
	transition: all 0.2s ease-out;
}
	ul.subNav li a:hover::after {
		background: url('../images/sprite.png') no-repeat -40px -175px;
		background-size: 500px 500px;
	}
ul.subNav li a.selected, ul.subNav li a.selected:hover {
	color: #222;
	padding-left: 15px;
}
ul.subNav li a.selected, ul.subNav li a.selected:hover {
	color: #000;
	border-left: 1px solid rgba(0,0,0,0.25);
	padding-left: 15px;
}
	ul.subNav li a.selected::after {
		background: url('../images/sprite.png') no-repeat -40px -175px;
		background-size: 500px 500px;
	}
	ul.subNav li:first-child a {
		border-top: 1px solid rgba(0,0,0,0.25);
	}
ul.subNav li a:hover {
	color: #333;
	background: #f9f9f9;
	padding-left: 15px;
}
	/* sub sub */
	ul.subNav li ul {
		margin: 0;
	}

	ul.subNav li li a {
		text-transform: none;
		color: #615d59;
		background: #f5f4f4;
		display: block;
		padding: 11px 0 11px 15px;
		border-bottom: 1px solid #ccc;
	}
		ul.subNav li li a:after {
			display: none;
		}
	ul.subNav li li a:hover {
		color: #000;
		border-bottom: 1px solid #ccc;
		padding: 11px 0 11px 20px;
	}
	ul.subNav li li a.selected, ul.subNav li li a.selected:hover {
		background: rgba(255,118,119,0.1);
		color: #615d59;
		padding-left: 20px;
	}
	
/* video embed */

.embedVideo {
	position: relative;
	padding-bottom: 56.25%; /* 16/9 ratio */
	padding-top: 0; /* IE6 workaround*/
	height: 0;
	overflow: hidden;
	/*max-width: 100%;*/
	height: auto;
	box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1);
}
	.embedVideo.narrow {
		padding-bottom: 46.9%;
	}
.embedVideo.bgSize {
	padding-bottom: 25%; /* 4/1 ratio */
	flex: 1;
}

.embedVideo iframe,
.embedVideo object,
.embedVideo embed,
.embedVideo video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* feature */

.flexrow {
	display: flex;
	flex-wrap: wrap;
	margin: 2em 10px 3.6em;
	justify-content: center;
	transition: transform 1s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}
.flexrow.top {
	align-items: flex-start;
}
.columns .flexrow {
	margin-left: 0;
	margin-right: 0;
}
.flexitem {
	display: flex;
	flex: 0 1 50%;
	position: relative;
	box-sizing: border-box;
}
.flexrow.top .flexitem:nth-child(odd) {
	border-right: 1px solid rgba(129,130,133,0.3);
}
.flexitem .text {
	padding: 4em 5em;
	align-self: center;
}	
.flexitem p.icon {
	margin-bottom: 0;
}
.flexitem img {
	z-index: 1;
	margin-bottom: 0;
	box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1);
}

/* split box */
.flexrow.half {
	margin: 0;
}
.flexrow.half + .flexrow.half {
	margin-top: 5em;
}
.flexrow.half.reverse {
	flex-direction: row-reverse;
}
.flexrow.half .flexitem .text {
	padding: 4em 5em;
}

/* grid */

.gridholder {
    display: grid;
    margin-top: 2em;
    margin-left: 1em;
    margin-right: 1em;
    margin-bottom: 2em;
    grid-template-columns: repeat(6, 1fr);
    grid-gap: 2em;
    grid-row-gap: 2em;
    width: 100%;
}
.griditem {
	padding: 1.5em 1em 2em;
	background: #f1f1f1;
	grid-column: span 2;
	border-radius: 5px;
}
.griditem h3 {
	color: #1fd1d1;
}
.griditem p {
	margin-bottom: 10px;
}
.griditem.pricing {
	text-align: center;	
}
.griditem .priceblock {
	position: relative;
}
.griditem .currency {
	font-family: "Helvetica Neue LT W05_75 Bold", sans-serif;
    font-size: 1.75em;
    line-height: 1.4;
    color: #111324;
    position: absolute;
    top: 10px;
}
.griditem .figure {
	font-family: "Helvetica Neue LT W05_75 Bold", sans-serif;
    font-size: 7em;
    line-height: 1em;
    margin: 0;
    padding: 0 0 0 20px;
}
.griditem .month {
	font-family: "Helvetica Neue LT W05_75 Bold", sans-serif;
}
	
/* feature */

.feature * {
	transition: all 0.2s ease-out;
}

.feature {
	position: relative;
	margin-bottom: 10px;
	text-align: center;
}
.feature::before {
    display: block;
    content: "";
    width: 1px;
    height: 52px;
    background: #ddd;
    position: absolute;
    margin-left: -1px;
    left: 50%;
    top: -52px;
}
.feature::after {
    display: block;
    content: "";
    width: 1px;
    height: 52px;
    background: #ddd;
    position: absolute;
    margin-left: -1px;
    left: 50%;
    bottom: -52px;
}
.feature .text {
	background: #f8f8f8;
	padding: 25px 25px 32px;
}
	.feature:hover .text {
		background: #9cf0f0;
	}
.feature a {
	display: block;
}
	.feature a:hover {
		color: #000;
	}
.feature img {
	z-index: 1;
	margin-bottom: 0;
}
	.feature:hover img {
		filter: brightness(1.1)
	}
.feature h3 {
	font-size: 2em;
	
}
.feature p {
	margin-bottom: 0;
}


.segment {
	margin-bottom: 10px;
	break-inside: avoid;
}
.segment ul {
	break-inside: avoid;
}

/* call out box */

	.callOut {
	padding: 25px 25px 10px 25px;
	margin-bottom: 20px !important;
	border: 1px solid rgba(0,0,0,0.1);
	border-radius: 4px;
	box-sizing: border-box;
}
	.callOut p, .callOut li {
		font-size: 0.9em;
	}
	.callOut ul, .callOut ol {
		margin-left: 16px;
	}

		
/* Footer
-------------------------------------------------- */

#goTop a {
	display: block;
	background: url('../images/sprite.png') no-repeat 0 -170px;
	background-size: 500px 500px;
	width: 24px;
	height: 24px;
	margin: 0 auto;
	float: right;
}

#goTop a:hover {
	margin-top: -5px;
}

.footer ul, #footer li {
	list-style: none;
	margin: 0 0 20px;
	padding: 0;
}
.footer li {
	font-size: 0.875em;
	margin: 0 0 3px;
}
.footer p {
	font-size: 0.875em;
	color: #9cf0f0;
	margin: 0;
}
.footer a {
	color: #9cf0f0;
	padding: 0;
}
.footer a:hover {
	color: #fff;
}

/* social buttons */

#social, #social li {
	list-style: none;
	margin: 0;
	padding: 0;
}

#social {
	margin-bottom: 20px;
}

#social li {
	float: left;
	margin-right: 4px;
}

#social li:last-child{
	margin-right: 0;
}

#social li a {
	display: block;
	width: 32px;
	height: 32px;
	background-size: 500px 500px !important;
	text-decoration: none;
	transform-origin: center center;
	-webkit-transition: all 300ms ease-in-out;
	-moz-transition: all 300ms ease-in-out;
	-ms-transition: all 300ms ease-in-out;
	transition: all 300ms ease-in-out;
}
	#social li a.fb  {
		background: url('../images/sprite.png') no-repeat -36px 0;
	}
	#social li a.in  {
		background: url('../images/sprite.png') no-repeat 0 -420px;
	}
	#social li a.tw  {
		background: url('../images/sprite.png') no-repeat 0 0;
	}
	#social li a.ho  {
		background: url('../images/sprite.png') no-repeat 0 -350px;
	}

		#social li a.fb:hover {
			background: url('../images/sprite.png') no-repeat -36px -32px;
			transform: rotate(90deg)
		}
		#social li a.in:hover {
			background: url('../images/sprite.png') no-repeat 0 -452px;
			transform: rotate(90deg)
		}
		#social li a.tw:hover  {
			background: url('../images/sprite.png') no-repeat 0 -32px;
			transform: rotate(90deg)
		}
		#social li a.ho:hover  {
			background: url('../images/sprite.png') no-repeat 0 -382px;
			transform: rotate(90deg)
		}


/* #Media Queries
================================================== */
@media only screen and (min-width: 1280px) and (max-width: 1480px) {
	.threeCol {
		column-gap: 6em;
	}
}

/* Tablet Landscape size to wide monitor  */
@media only screen and (max-width: 1279px) {
	body {
		font-size: 14px;
	}
	h1 {
		font-size: 2.2em;
	}
	h2 {
		font-size: 2.2em;
		color: #1fd1d1;
	}
	h3 {
		font-size: 1.5em;
		margin-bottom: 10px;
	}
	h4 {
		font-size: 1.2em;
	}
	.button, input[type="submit"], input[type="button"], .ms-options-wrap button {
		padding: 12px 10px 9px;
	}
	input[type="text"], input[type="password"], input[type="email"], input[type="number"], textarea, select {
		padding: 12px;
	}
}

/* Tablet Landscape size to wide monitor  */
@media only screen and (min-width: 960px) and (max-width: 1279px) {
	.threeCol {
		column-gap: 4em;
	}
}

@media only screen and (max-width: 959px) {
	h1 {
		font-size: 2em;
	}
	h2 {
		font-size: 2em;
		color: #1fd1d1;
	}
	h3 {
		font-size: 1.3em;
		margin-bottom: 10px;
	}
	h4 {
		font-size: 1.1em;
	}
	hr {
		padding-top: 30px;
		margin-bottom: 50px;
		height: 0;
	}
	.infogrid img {
		width: 16px !important;
	}
	.threeCol {
		column-gap: 5em;
	}
}

@media only screen and (max-width: 880px) {
	.wrap.planes {
		background-position: -50vW bottom;
		background-size: 130vW;
	}
	.wrap.planes .vAlign {
		align-self: flex-start;
		margin-top: 60px;
		padding-left: 5%;
		padding-right: 15%;
	}
	.wrap.planes .bgVid {
		width: 140%;
		height: 140%;
		position: absolute;
		bottom: 0;
		right: 0;
		z-index: 2;
		display: flex;
		align-items: flex-end;
	}
}

/* Tablet Portrait size to standard 960  */
@media only screen and (min-width: 881px) and (max-width: 959px) {
	
	label, legend, input[type="text"], input[type="password"], input[type="email"], textarea,  select {
		width: 100%
	}
	.no-mob-all{
		display: none;
	}
	.mob-only-all {
		display: block !important;
	}
	.no-tab {
		display: none !important;
	}
	.tab-only {
		display: block !important;
	}
	.wrap.planes {
		height: 50vH;
	}
}

/* All Mobile Sizes  */
@media only screen and (max-width: 880px) {
	.no-mob, .no-mob-all {
		display: none !important;
	}
	.mob-only, .mob-only-all {
		display: block !important;
	}
	hr, hr.narrow {
		margin-right: 0;
		margin-left: 0;
	}
	.divider.mob-only {
		display: inline-block !important;
	}
	label, legend, input[type="text"], input[type="password"], input[type="email"], textarea,  select {
		width: 100%
	}
	.motif.sm {
		width: 80px;
		margin: 0 auto 30px;
	}
	.wrap.header {
		padding: 22px 0;
	}
	/*.wrap.content {
		background: #fff;
	}*/
	.wrap {
		padding: 50px 0 40px;
	}
	.wrap.footer {
		padding: 30px 0 20px;
	}
	#logo a {
		width: 180px;
	}
	.splitter {
		display: none;
	}
	.feature {
		margin-bottom: 30px;
	}
	.feature::before {
		display: none;
	}
	.feature::after {
		height: 30px;
		bottom: -30px;
	}
	.griditem .currency {
		top: 0;
	}
	.flexrow {
		margin: 0 0 20px;
	}
	.flexrow.half{
		flex-direction: column;
	}
	.flexrow.half .flexitem .text{
		padding: 3em 2em;
	}
}

/* Mobile Landscape Size to Tablet Portrait  */
@media only screen and (min-width: 480px) and (max-width: 767px) {
	.threeCol {
		column-gap: 5em;
		column-count: 2;
	}
	.gridholder {
		grid-template-columns: repeat(4, 1fr);
	}
	.gridholder .griditem:nth-child(3n) {
		grid-column: span 4;
	}
}

/* Mobile Portrait Size to Mobile Landscape Size  */
@media only screen and (max-width: 479px) {
	
	.no-mob-p {
		display: none !important;
	}
	.mob-only-p {
		display: block;
	}
	.twoCol,
	.threeCol {
		column-count: 1;
		column-gap: 0;
	}
	td.mob-only-p {
		display: table-cell;
	}
	.wrap.planes h1,
	.wrap.planes p {
		padding-right: 0;
	}
	.wrap.planes .vAlign {
		align-self: flex-start;
		margin-top: 50px;
		padding-left: 5%;
		padding-right: 5%;
	}
	.wrap.planes {
		background-position: -70vW bottom;
		background-size: 160vW;
	}
	.wrap.planes .bgVid {
		width: 175%;
		height: 175%;
	}
	.gridholder {
		grid-template-columns: repeat(2, 1fr);
	}
}
	
html {
    opacity: 1;
}
