/* --------------------------------
PRIMARY STYLES
-------------------------------- */
*, *::after, *::before { box-sizing: border-box; }
body {
	font-family: sans-serif;
	font-weight: normal;
	line-height: 1;
	color: black;
}

h1, h2, h3, h4 {
	font-family: "Syne", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  line-height: 1;
	margin-bottom: .5em;
	color: #2f3b86;
}
h1 span, h2 span, h3 span, h4 span { color: black; }
h1 { font-size: 50px; }
h2 { font-size: 32px; }
h3 { font-size: 24px; }
h4 { font-size: 16px; }

table { width: 100%; }
th, td,
ul, ol, p { 
	font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
	font-size: 16px;
	line-height: 1.5;
}

a { transition: all .5s ease; text-decoration: none; }
a:hover {}

b, strong { font-weight: 700; }
i, em { font-style: italic; }

/* --------------------------------
EFFECTS
-------------------------------- */
.txt-shadow { text-shadow: 1px 1px 40px black; }
.bx-shadow,
.bx-shadow-hover:hover {
	-webkit-box-shadow: 0px 0px 50px 0px rgba(0,0,0,.2);
	-moz-box-shadow: 0px 0px 50px 0px rgba(0,0,0,.2);
	box-shadow: 0px 0px 50px 0px rgba(0,0,0,.2);
}
.opacity-hover:hover { opacity: .5; }

/* --------------------------------
BUTTONS
-------------------------------- */
.btns { cursor: pointer; }
.btn-more {
  font-family: "Syne", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  line-height: 1;
	color: #2f3b86;
  display: inline-block;
  text-decoration: none;
  transition: all .5s ease;
}
.btn-more::after {
	display: inline-block;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Free";
	font-size: .6em;
	font-weight: bold;
	content: "\f105";
	margin-left: 1em;
	transition: all .5s ease;
}
.btn-more:hover::after { margin-left: 2em; }

/* -------------------------------- 
VIDEO
-------------------------------- */
.embed-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
}
.embed-square { padding-bottom: 100%; }
.embed-container iframe,
.embed-square iframe,
.embed-container object,
.embed-container embed,
.embed-container video {
	z-index: 2;
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
}

/* --------------------------------
FORMS
-------------------------------- */
form { 
	position: relative;
	width: 100%;
	margin-bottom: 2em;
}
form .inner { padding: 0 .25em; }
textarea, select,
.input-text,
.input-submit {
	display: inline-block;
	font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
	font-weight: 400;
	font-size: 16px;
	line-height: 1;
	width: 100%;
	padding: 1em;
	margin-bottom: .5em;
	outline: none;
	transition: all .5s ease;
}
textarea { height: 120px; }

.input-submit {
  font-family: "Syne", sans-serif;
  font-weight: 700;
  background: #eef0f2;;
  border: none;
}
.input-submit:hover { color: white; background: #2f3b86; }

.wpcf7-not-valid-tip { padding: .5em 1em 1em !important; line-height: 1; }
.wpcf7-response-output { padding: 1em !important; line-height: 1; }
.wpcf7-list-item { margin: 0 !important; }

/* --------------------------------
HEADER
-------------------------------- */
header {
	z-index: 99;
	background: rgba(46,59,135,1);
	position: sticky;
	top: 0; left: 0;
	width: 100%;
	padding: 1em 0;
	transition: all .5s ease;
}
/*header.active { padding: 1em 0; background: rgb(46,59,135,.95); }
header img { transition: all .5s ease; }
header.active img { padding-right: 2em; }*/

/* --------------------------------
NAV
-------------------------------- */
nav { 
  display: none;
  background: #2f3b86;
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  height: 100vh;
  padding: 2em .5em;
}

nav ul { margin: 0 .5em; }
nav ul li a {
	font-family: "Syne", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  display: inline-block;
	color: white;
  line-height: 1;
	padding: .5em;
	transition: all .5s ease;
}
nav ul li a:hover,
nav ul li.current-menu-item > a { color: #ef8200; }
nav ul ul { display: none; }
nav ul li.menu-item-has-children { position: relative; }
nav ul li.menu-item-has-children > a::after {
	display: inline-block;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Free";
	font-size: .6em;
	font-weight: bold;
	content: "\f107";
	margin-left: .5em;
}
nav ul li.menu-item-has-children:hover > ul { display: block; z-index: 2; }
nav ul ul li a { font-family: "Montserrat", sans-serif; font-weight: 400; }

nav ul.lang { position: relative; margin-top: 2em; }

.nav-toggle {
	float: right;
	-webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: pointer;
  position: relative;
  z-index: 3;
  display: inline-block;
  height: .75rem;
  width: 1.5em;
}
.nav-toggle:hover .nav-toggle-bar,
.nav-toggle:hover .nav-toggle-bar::after,
.nav-toggle:hover .nav-toggle-bar::before { background: white; }

.nav-toggle .nav-toggle-bar,
.nav-toggle .nav-toggle-bar::after,
.nav-toggle .nav-toggle-bar::before {
	position: absolute;
	top: 50%; left: 0;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	-webkit-transition: all .5s ease;
	-moz-transition: all .5s ease;
	-ms-transition: all .5s ease;
	-o-transition: all .5s ease;
	transition: all .5s ease;
	background: white;
	content: '';
	height: .2rem;
	width: 100%;
}
.nav-toggle .nav-toggle-bar { margin-top: 0; }
.nav-toggle .nav-toggle-bar::after { margin-top: .4rem; }
.nav-toggle .nav-toggle-bar::before { margin-top: -0.4rem; }

.nav-toggle.expanded .nav-toggle-bar { background: transparent; }
.nav-toggle.expanded .nav-toggle-bar::after,
.nav-toggle.expanded .nav-toggle-bar::before { background: white; margin-top: 0; }
.nav-toggle.expanded .nav-toggle-bar::after {
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.nav-toggle.expanded .nav-toggle-bar::before {
	-ms-transform: rotate(-45deg);
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

/* -------------------------------- 
SLIDER
-------------------------------- */
.slider { margin-bottom: 0 !important; }
.slider .slide { position: relative; width: 100%;	height: 100%; }

.slick-dots { z-index: 9; bottom: 3em; width: 100%; }
.slick-dots li { width: auto; height: auto; }
.slick-dots li button { 
	width: 1em;
	height: 1em;
	background: white;
	border-radius: 50%;
	opacity: .2;
}
.slick-dots li.slick-active button { opacity: 1; }
.slick-dots li button::before,
.slick-dots li.slick-active button::before { opacity: 0 !important; }

/* --------------------------------
ARTICLE & SECTIONS
-------------------------------- */
article { overflow: hidden; margin: auto; }
section { 
	position: relative;
	width: 100%;
	line-height: 0;
	padding: 3em 0;
}
section ul { list-style: disc; }
section ol { list-style: numeric; }
section ul,
section ol { margin-left: 1em; }
section ul,
section ol,
section p { margin-bottom: 2em; }
section a { color: #2f3b86; text-decoration: none; }
section a:hover { color: #ef8200; }
section hr { border: none !important; margin: 2em; }

.super-container,
.container { margin: 0 auto; position: relative; }
.inner { padding: 0 1em; }

.desktop-hide {}
.desktop-show { display: none; }

.table-align { display: table; width: 100%; height: 100%; }
.table-cell-align { display: table-cell; vertical-align: middle; }
.table-cell-align.bottom { vertical-align: bottom; }

.last { margin-bottom: 0 !important; }
.align-h { height: 100%; }
.center { text-align: center; }
.right { text-align: right; }

.grey {	background: #eef0f2; }
.blue { background: #001d42; }
.blue * { color: white; }
.blue h4,
.blue p a { color: #4e99ce; }
.blue p a:hover { color: #ef8200; }

.hero { padding: 0; }
.hero .hero-img { position: relative; }
.hero .hero-blend {
	z-index: 1;
	position: absolute;
  top: 0; left: 0;
  width: 60%; height: 100%;
  background: rgba(47,59,134,.4);
  mix-blend-mode: color;
}
.hero .hero-img img {
	width: 100%;
	max-width: 100%;
	height: auto;
	margin: auto;
}

.hero .hero-overlay {
	z-index: 2;
	position: absolute;
	top: 0; left: 0;
	width: 100%;
	height: 100%;
}
.hero .hero-overlay .box { position: relative; }
.hero .hero-overlay .box h1,
.hero .hero-overlay .box p,
.hero .hero-overlay .box .btn-more { color: white; }
.hero .hero-overlay .box .btn-more:hover { color: #ef8200; }

.hero.no-hero { background: #2f3b86; }
.hero.no-hero .hero-overlay { position: relative; }

.intro { }
.intro .float-img { position: relative; z-index: 3; }

.usp { }
.usp ul { list-style: none; margin-left: 0; }
.usp ul li::before {
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Free";
	font-weight: bold;
	content: "\f00c";
	padding-right: .5em;
	color: #2f3b86;
	float: left;
}

.cta { background: rgba(0,0,0,.2); }
.cta a { color: black; }
.cta h4 i {
	font-size: 1.5em;
  width: 1.5em;
  text-align: center;
  transform: rotate(-5deg);
}

.tiles {}
.tiles p a { display: block; overflow: hidden; }
.tiles p a img { transition: all .5s ease; } 
.tiles p a:hover img { transform: scale(1.1); }

.faq {}
.faq ul { list-style: none; border-top: 1px solid grey; margin: 0 1em 2em; }
.faq ul li { border-bottom: 1px solid grey; padding: 1em; }
.faq ul li h4 { position: relative; cursor: pointer; }
.faq ul li h4::after {
	display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  font-family: "Font Awesome 5 Free";
  font-weight: bold;
  content: "\f107";
  transition: all .5s ease;
  position: absolute;
  right: 0;
}
.faq ul li h4.active::after { transform: rotate(180deg); }
.faq ul li h4:hover { color: #ef8200; }
.faq ul li h4,
.faq ul li p { margin-bottom: 0; }
.faq ul li p { display: none; padding: .5em 0; }

/* --------------------------------
FOOTER
-------------------------------- */
footer {
	width: 100%;
	padding: 3em 0;
	background: #2f3b86 url('img/bg-footer.jpg') no-repeat center;
	background-size: cover;
	color: white;
	overflow: hidden;
}
footer h4 { color: inherit; }
footer p,
footer ul { color: inherit; margin-bottom: 2em; }
footer a { color: inherit; }
footer a:hover { color: #ef8200; }

footer ul.expertises {}
footer ul.expertises li::before {
  position: relative;
  top: -1px; left: 0;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	-webkit-font-smoothing: antialiased;
	font-family: "Font Awesome 5 Free";
	font-size: .6em;
	font-weight: bold;
	content: "\f105";
	color: rgba(255,255,255,.4);
	margin-right: 1em;
}

footer ul.social {}
footer ul.social li {
	font-size: 28px;
	display: inline;
	margin-right: .5em;
}

/* --------------------------------
MEDIA QUERIES
-------------------------------- */
@media screen and (min-width: 35.5em) {
	.container { width: 568px; }
}
@media screen and (min-width: 48em) {
	.container { width: 768px; }
}
@media screen and (min-width: 64em) {
	.container { width: 1024px; }
	.inner { padding: 0 1.5em; }

	.desktop-hide { display: none; }
	.desktop-show { display: block; }

	h1 { font-size: 90px; }
	h2 { font-size: 48px; }
	h3 { font-size: 32px; }
	h4 { font-size: 24px; }

	th, td,
	ul, p,
	textarea, select,
	.input-text,
	.input-submit { font-size: 18px; }

	header {
		position: absolute;
		padding: 2em 0;
		background: linear-gradient(180deg,
			rgba(0,29,66, 1) 0%,
			rgba(0,29,66, 0) 100%
		);
	}

	nav {
		display: block !important;
		text-align: right;
		background: transparent;
		position: relative;
		height: auto;
		padding: 0;
	}
	nav ul,
	nav ul li { display: inline; }
	nav ul ul {
		position: absolute;
		top: calc(100% + .5em); left: -1em;
		background: #2f3b86;
		text-align: left;
		width: 200px;
		padding: .5em;
	}
	nav ul ul li { display: block; }
	nav ul.lang ul { width: auto; }
	nav ul.lang::before {
		content: "";
		position: absolute;
		top: -.5em; left: -.5em;
		width: 1px;
		height: calc(100% + 1em);
		background: rgba(255,255,255,.4);
	}

	section { padding: 5em 0; }

	.hero {
		padding: 0 0 5em;
		background: linear-gradient(90deg,
			rgba(47, 59, 134, 1) 0%,
			rgba(47, 59, 134, 1) 60%,
			rgba(238, 240, 242, 1) 60%,
			rgba(238, 240, 242, 1) 100%
		);
	}
	.hero.no-hero {
		height: 480px;
		background: #2f3b86 url('img/bg-footer.jpg') no-repeat top;
		background-size: cover;
	}

	.slick-dots { 
		bottom: -2.5em;
		width: 48%;
		text-align: right;
	}

	.intro { padding: 0; }
	.intro .float-img { top: -10em; }

	footer { padding: 5em 0; }
	footer ul.horizontal { text-align: right; }
	footer ul.horizontal li { margin: 0 0 0 1.5em; }
}
@media screen and (min-width: 80em) {
	.container { width: 1200px; }
}
@media screen and (min-width: 120em) {
	.super-container { width: 1920px; }
}

/* IE11
@media all and (-ms-high-contrast:none) {
	*::-ms-backdrop,
	[data-aos^=fade][data-aos^=fade],
	[data-aos^=zoom][data-aos^=zoom] { opacity: 1; }
}*/