/* RESET / BASE */
* {
  box-sizing: border-box;
}

body {
  background-color: #edeff2;
  font-family: 'Open Sans', sans-serif;
  color: #ffffff;
  font-size: 16px;
  line-height: 20px;
  margin: 0px;
}

h1{
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 24px;
  color: #ffffff;
}
h2{
  font-size: clamp(36px, 5vw, 52px);
  font-weight: 800;
  margin-bottom: 20px;
  line-height: 1.2;
  color: #ffffff;
}
h3 {
  margin-top: 20px;
  margin-bottom: 20px;
  color: #6a859c;
  font-size: 24px;
  line-height: 30px;
  font-weight: 600;
}

blockquote {
  margin: 0 0 10px 0;
  padding: 10px 20px;
  border-left: 5px solid #E2E2E2;
  font-size: 18px;
  line-height: 22px;
  background-color: #252d32;
}

a{
  color: #08438e;
  font-weight: bold;
  text-decoration: none;
}

p{
  font-size: 18px;
  line-height: 1.6;
  color: #cfe6ff;
}

img {
  max-width: 100%;
  vertical-align: middle;
  display: inline-block;
}

section { width:100%; display:block;}

/* =====================
   HEADER / NAV
===================== */

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: linear-gradient(
    180deg,
    #0b2a6f 0%,
    #061b44 100%
  );
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35);
}

.navigation-bar {
  position: relative;
  background-color: #00438e;
  background-image: linear-gradient(90deg, #001b48, #1149ff 23%, #003675 80%, #001439);
}

.navigation-bar:before, .navigation-bar:after,
.nav-container:before, .nav-container:after,
.nav-row:before, .nav-row:after {
  content: " ";
  display: table;
  grid-column-start: 1;
  grid-row-start: 1;
  grid-column-end: 2;
  grid-row-end: 2;
}

.navigation-bar .nav-container {
  position: relative;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.nav-container .nav-row {
  flex-direction: row;
  align-items: flex-start;
  display: flex;
  justify-content: stretch;
  margin-left: -10px;
  margin-right: -10px;
}

.logo-link {
  position: relative;
  justify-content: flex-start;
  display: flex;
  align-items: center;
  width: 100%;
  text-decoration: none;
  color: #ffffff;
  padding-top: 10px;
  padding-bottom: 5px;
}

.logo {
  height: 50px!important;
}

.navigation-menu {
  margin-top: 0px;
  position: relative;
  flex: 0 auto;
  align-items: flex-start;
  display: flex;
}

.navigation-menu .menu-item {
  display: inline-block;
  position: relative;
}

.navigation-menu .menu-item a, .account-button {
  position: relative;
  display: inline-block;
  vertical-align: top;
  text-decoration: none;
  text-align: left;
  margin-right: 10px;
  margin-left: 10px;
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out;
  color: #ffffff;
  font-weight: 700;
  mix-blend-mode: normal;
  padding: 20px 15px;
  white-space: nowrap;
}
.navigation-menu .menu-item.menu-item-has-children .sub-menu {
  position: absolute;
  display: none;
  background-color: #083fb7;
  width: 220px;
  left: 0%;
  z-index: 10;
}
.navigation-menu .menu-item.menu-item-has-children .sub-menu a {
  display: block;
  padding: 15px 15px;
}

.navigation-menu .menu-item.menu-item-has-children:hover .sub-menu {
  display: block;
}

.account-button {
  margin-top: 10px;
  padding: 10px 20px;
  border-radius: 2px;
  background-color: #001b48;
}

.hamburger-button {
  position: relative;
  padding: 18px;
  font-size: 24px;
  display: none;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* =====================
   HERO SECTION
===================== */
h1 span {
  color: #4fc3ff;
}

/* =====================
   FOOTER SECTION
===================== */

footer{
  position: relative;
  overflow: hidden;
  padding: 80px 24px 26px;
  background:
    radial-gradient(circle at 50% -20%, rgba(80,160,255,0.10), transparent 60%),
    linear-gradient(180deg, #020614 0%, #01030a 100%);
}

.footer-inner{
  max-width: 1200px;
  margin: 0 auto;
}

/* Top area layout */
.footer-top{
  display: grid;
  grid-template-columns: 1.75fr 0.75fr 0.75fr 0.75fr;
  gap: 22px;
  padding-bottom: 34px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

/* Brand */
.footer-brand{
  display:flex;
  flex-direction: row;
  align-items: start;
}

.footer-logo{
  display:inline-flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
}

.footer-logo img{
  width: 340px;
  height: auto;
}

.footer-tagline{
  position: relative;
  top: 30px;
  margin: 0;
  color: rgba(182,198,227,0.92);
  font-size: 14.5px;
  line-height: 1.55;
}

/* Headings */
.footer-heading{
  margin: 6px 0 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(123,188,255,0.9);
}

/* Links */
.footer-links{
  list-style:none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.footer-links a{
  color: rgba(215,228,255,0.85);
  text-decoration:none;
  font-size: 14.5px;
  transition: color .18s ease, transform .18s ease;
}

.footer-links a:hover{
  color: #5cc8ff;
  transform: translateX(2px);
}

/* Social list */
.footer-social{
  list-style:none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.footer-social a{
  display: inline-flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
  color: rgba(215,228,255,0.85);
  font-size: 14.5px;
  white-space: nowrap;
  transition: color .18s ease, transform .18s ease, filter .18s ease;
}

.footer-social i{
  width: 22px;
  font-size: 18px;
  color: rgba(92,200,255,0.95);
  filter: drop-shadow(0 0 10px rgba(92,200,255,0.18));
}

.footer-social a:hover{
  color: #ffffff;
  transform: translateX(2px);
  filter: brightness(1.08);
}

.footer-social svg{
  width: 22px;
  height: 22px;
}

/* Bottom bar */
.footer-bottom{
  margin-top: 18px;
  color: rgba(182,198,227,0.75);
  font-size: 13.5px;
}

.footer-bottom .footer-bottom-center{
  text-align: center;
}