footer, body, aside, #breadcrumb, .no-critical, .no-lazy {
  opacity: 1!important;
}
/* =================================
	Text select
=================================== */
::selection {
  background: #E5E5E5;
  /* WebKit/Blink Browsers */ }

::-moz-selection {
  background: #E5E5E5;
  /* Gecko Browsers */ }

/* =================================
	CSS
=================================== */


html, body {
  height: 100%;
  margin: 0;
  padding: 0;
  background-color: #fff;
}

body {
  display: flex;
  flex-direction: column;
  color: #666;
  line-height: 1.5;
  font-size: 1rem;
  overflow-x: hidden;
  font-weight: 400;
}
h2 {
	padding-bottom: 42px!important;
}
h2::before,
.home .panel h5::before {
  content: "";
  position: absolute;
  left: 0;
  background: #eb901b;
}
.text-center h2::before {
	left: 50%;
	transform: translateX(-50%);
}
h2::before {
	width: 85px;
	bottom: 28px;
	height: 3px;
}


address {
  font-style: normal;
}

aside, footer {
	opacity: 1!important;
}

#flex {
	flex-grow: 1;
	flex-shrink: 1;
	/* 2 */
	flex: 1 0 auto;
	position: relative;
	min-height: 1px;
	background-color: #fff;
}
#flex main {
	padding-top: 35px;
	padding-bottom: 35px;
}
body.home #flex main,
body.has-hero #flex main {
	padding-top: 0;
}
body.blog #flex main,
body.home #flex main {
	padding-bottom: 0;
}

/* MAIN */
.full-width {
	width: 100vw;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
}

ul.reset,
footer ul,
header ul,
.breadcrumb {
	list-style-type: none;
	padding-left: 0;
	margin-bottom: 0;
	border: 0;
}


/* =================================
	Header
=================================== */

header .meta li[title] .fa:after {
    display: none;
}

body > header .container {
	position: relative;
}
body > header {
  font-size: 1em;
	min-height: 55px;
	background-color: #fff;
	position: absolute;
	z-index: 999;
  right: 0;
  left: 0;
	height: 60px;
}

@media (min-width: 992px) {
  header::after {
    content: "";
    height: 50px;
    background-color: #eb901b;
    bottom: 0;
    right: 0;
    left: 0;
    z-index: 1;
    position: absolute;
  }
}

.scrolled-122:not(.scrolling-up) header #nav:after,
.scrolled-122:not(.scrolling-up) header #nav:before {
  opacity: 0;
}

@media (max-width: 767.98px) {
  header .roles {
    margin-top: 0;
    right: 10px;

  }
  header::after {
    opacity: 0;
  }
}

/* =================================
	Logo
=================================== */
header a#logo {
	position: absolute;
	z-index: 999;
}
header a#logo img {
	height: 30px;
    margin-top: 15px;
    padding-left: 18px;
}
@media (min-width: 768px) {
	body > header {
		height: 60px;
	}
	header a#logo img {
		height: 48px;
		margin-top: 8px;
		padding-left: 0;
	}
}
@media (min-width: 992px) {
  body > header {
    height: 134px;
  }
  header a#logo img {
    height: 68px;
  }
}

/* =================================
	Footer
=================================== */

/* FOOTER */
footer {
	clear: both;
	background: #1a3f73;
  padding-bottom: 70px;
}
footer,
footer a {
	color: #d4dadf;
}
footer a:hover {
	text-decoration: underline;
}
footer a:focus,
footer a:hover,
footer h5 a,
footer h5 {
	color: #fff;
}

footer > div:first-child {
	padding-top: 2rem;
	padding-bottom: 1rem;
}
footer ul.main li li {
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}
footer address {
  font-style: normal;
}

footer ul.main > li > h5 {
  font-size: 18px;
}
footer ul.main > li {
	padding-bottom: 2rem;
}

@media (min-width: 768px) {
  footer {
  padding-bottom: 0;
  }
}

@media (min-width: 1024px) {
	footer ul.main > li {
		clear: none !important;
		clear: unset !important;
	}
}

/* footer sub */
footer .sub {
	padding: 2rem 0 2rem;
	border-top: 1px solid #9eb7cb;
	text-align: center;
	margin: 0;
	font-size: 90%;
}
@media (min-width: 768px) and (max-width: 1023px) {
	footer .sub > div > ul {
		text-align: left;
	}
}

footer .sub > div > ul li {
	display: inline-block;
	padding: 5px 8px;
}
footer .btn {
  position: relative;
  padding-left: 50px;
  width: 275px;
  margin-top: 10px;
}
footer .btn:after {
  content: "";
  background: url("../img/btn-logo.png") center no-repeat;
  background-size: 100%;
  top: 0;
  position: absolute;
  bottom: 0;
  left: 6px;
  width: 40px;
  border-radius:50%;
}


/* =================================
	Side-nav
=================================== */
aside .item .wrapper  {
	position: relative;
  max-width: 300px;
  padding: 1.5rem 0.5rem 1rem;
}
aside h3 {
	font-size: 1.3em;
}
aside img {
  width: 100%;
  border-radius: 0.5rem;
}
aside p {
  margin: 0;
}
