:hoverhtml { padding:0; margin:0; height: 100%; }
body { margin:0 auto; overflow-y: scroll; overflow-x: hidden; }



/* ********************************************** Header & Menu ********************************************** */

#topbar{ background:#001d4d; background: rgba(0,29,77,0.9); top:0;left:0;position:absolute;width:100%;border-bottom: 0 solid #163e82;z-index:103; text-align:center; }
#topbar.home{ position:fixed; }
#topbar.home.open{ position:fixed; height:80px; }
#topbar #position{ position:relative;width:100%; max-width:1578px; margin: 0 auto; }
#home #topbar #position{ max-width:1564px; }

#home #hellobar{ position:absolute;top:30px;left:calc(51% - 275px);width: 550px;color:#00a3ad;z-index:200;text-align:center; font-family: 'Gotham SSm A', 'Gotham SSm B'; font-style: normal; font-weight: 500; font-size: .9em; line-height: 1.5; letter-spacing: -0.5px; }

#topbar .fal { color: #ffffff; }

#topbar #progress{ position:absolute;width:0%;background-color:#142a4e;height:100%;z-index:0; }
#topbar #menu-position{ position:absolute;right:0;padding:24px 110px 25px 25px; }
#topbar #search-position{ right:120px;position:absolute;padding:33px 25px 25px 25px; }
#topbar #search-position .far{ font-size: 1em; }
#topbar #search-position a { color: #ffffff; }
#topbar #logo-position { position:absolute;left: calc(50% - 120px);padding:40px; margin: 0 auto; }
#topbar #logo { width: 180px;height: 40px; background-size: 86px 18px; margin-top:3px; }
#topbar #tagline-position { text-align:center; position:relative; padding:33px 0 26px 0; display: inline-block; }
#topbar #tagline { color: #ffffff; }
#topbar #tagline a{ float: left; display: block; padding: 0 10px; color: #ffffff; opacity: 0.66; font-weight: 300; font-size: 0.9em; letter-spacing: 0.25px; }
/* #topbar #tagline label { font-weight: 300; font-size: 0.7em; padding-top: 4px; } */
#topbar #tagline a.active{ color: #ffffff; opacity: 1; }
#topbar #tagline .spacer{ display: none; }

#topbar #tagline .nuxt-link-active{ opacity: 1; font-weight: 500; }
#topbar #tagline .nuxt-link-exact-active { opacity: 1; }
#topbar #tagline > span:first-child > label.spacer { display: none; }

#home #topbar{ background-color: transparent; border:0; height:80px; position: absolute;  }

#home #topbar #menu-position{ right: 22px; padding-top: 44px; }
#home #topbar #search-position{ right: 87px; padding-top: 53px; }
#home #topbar #tagline-position{ display: none; }
#home #topbar #tagline{ display: none; }

#menu-icon { width: 0; cursor: pointer; height: 12px; position: relative; display: block; padding: 10px; z-index: 100; text-decoration: none; transition: all 0.25s ease-out; }
#menu-icon::before { -o-transition: all 0.25s ease-out; transition: all 0.25s ease-out; -webkit-transition: all 0.25s ease-out; }
#menu-icon .line { background: #ffffff; width: 20px; height: 2px; position: absolute; left: 0; border-radius: 0; -o-transition: all 0.25s; transition: all 0.25s; -webkit-transition: all 0.25s; -moz-transition: all 0.25s; }
#menu-icon .line.line-1 { top: 30%; }
#menu-icon .line.line-2 { top: 50%; }
#menu-icon .line.line-3 { top: 70%; }

.non-mobile #menu-icon:hover::before { color: #00a3ad; }
.non-mobile #menu-icon:hover .line-1 { background: #00a3ad; -ms-transform: translateY(-1px); transform: translateY(-1px); -webkit-transform: translateY(-1px); -moz-transform: translateY(-1px); }
.non-mobile #menu-icon:hover .line-2 { background: #00a3ad; }
.non-mobile #menu-icon:hover .line-3 { background: #00a3ad; -ms-transform: translateY(1px); transform: translateY(1px); -webkit-transform: translateY(1px); -moz-transform: translateY(1px); }
.non-mobile #menu-icon:hover::after { color: #00a3ad; }

#menu-icon.active .line-1 { -ms-transform: translateY(6.2px) translateX(0) rotate(45deg) !important; transform: translateY(6.2px) translateX(0) rotate(45deg) !important; -webkit-transform: translateY(6.2px) translateX(0) rotate(45deg) !important; -moz-transform: translateY(6.2px) translateX(0) rotate(45deg) !important; }
#menu-icon.active .line-2 { opacity: 0; }
#menu-icon.active .line-3 { -ms-transform: translateY(-6.2px) translateX(0) rotate(-45deg) !important; transform: translateY(-6.2px) translateX(0) rotate(-45deg) !important; -webkit-transform: translateY(-6.2px) translateX(0) rotate(-45deg) !important; -moz-transform: translateY(-6.2px) translateX(0) rotate(-45deg) !important; }

#menu-icon::after { content: 'MENU'; font-family: "Gotham SSm A", "Gotham SSm B"; font-style: normal; font-weight: 700; font-size: 1em; color: #ffffff; right: -60px; padding-left: 10px; position: absolute; top: 8px; -o-transition: all 0.25s ease-out; transition: all 0.25s ease-out; -webkit-transition: all 0.25s ease-out;  }


#menu { width: 100%; height: calc(100% - 75px); position: fixed; top: 80px; left:0; z-index: 101; display: block; opacity: 0; transition: opacity 0s, z-index 0s; z-index: -1; background: linear-gradient(to right, #d9e1e2 0%, #d9e1e2 50%, #02245c 50%, #02245c 100%); overflow: none; transition: opacity 0.3s, z-index 0.3s; }
#menu.active { opacity: 1; z-index: 101; }
#menu .position{ padding: 60px 65px 0 60px; }
#menu .table{ min-height: calc(100%); width: 100%; max-width: 1600px; margin:0 auto; border: 0px solid #fff; }
#menu * { vertical-align: top; }

#home #menu{ top: 113px; }
#home #menu #branding{ left: 33px; }

#menu h3{ color: #002C77; }
#menu a h3 { color: #002C77; }
#menu h5 { color: #ffffff; padding-bottom: 6px; }
#menu #branding h5 { color: #002C77; }

#menu #branding{ width: 35%; border-right: 1px solid #0b3987;  }
#menu #nav{ width: 65%; background-color: #02245c; }

#menu #branding #tagline { margin-bottom: 20px; padding: 4px 0 20px 0; border-bottom: 0px solid #0b3987; }
#menu #branding #tagline a{ color: #00a3ad; border-bottom: 1px solid #00a3ad; }
#menu #branding #tagline p{ font-family: inherit; font-style: inherit; font-weight: inherit; font-size: inherit; line-height: inherit; letter-spacing: inherit; }
#menu #branding #must { margin-bottom: 10px; }
#menu #branding .media { position: relative; }
#menu #branding .media .caption{ display: block; background-color: #ffffff; }
#menu #branding .media .tag{ display: inline; background-color: #00a3ad; position:absolute; top:0; left:0; padding: 10px 16px; font-family: "Gotham SSm A", "Gotham SSm B"; font-style: normal; font-weight: 500; font-size: .75em; letter-spacing: .5px; color: #ffffff; text-transform: uppercase; }
#menu #branding .media h3 { padding: 20px; }
#menu #branding img{ margin-bottom: 0; width: 100%; }
#menu #branding .caption{ width: 100%; }

#menu #nav .row { display: flex; justify-content: flex-start; margin-bottom: 5px; padding: 0; }
#menu #nav .row:last-of-type { margin-bottom: 0; }
#menu #nav .column { display: inline-block; float: left; padding: 0 0 1.5em 0; text-align: left; }
#menu #nav .section { display: flex; flex-direction: column; width: 33%; }
#menu #nav .row .column span { width: 100%; display: block;  }
#menu #nav .row:first-of-type .section:nth-of-type(2) .column:first-of-type { padding-bottom: 15px; }

#menu #nav h3{ width: 160px; }
#menu #nav ul { margin: 0; padding: 5px 0 0 0; line-height: 1.2; }
#menu #nav ul:nth-of-type(2) { padding-top: 25px; }
#menu #nav ul li { margin: 0; padding: 0; list-style: none; width: 220px; text-align: left; }
#menu #nav ul li.copy { color: #ffffff; font-family: "Gotham SSm A", "Gotham SSm B"; font-style: normal; font-weight: 300; font-size: .9em; padding: 5px 0; display:block; opacity: .5; line-height: 1.5em; }
#menu #nav ul li a{ color: #00a3ad; font-family: "Gotham SSm A", "Gotham SSm B"; font-style: normal; font-weight: 300; font-size: .9em; padding: 5px 0; display:block; opacity: 0.9; transition: all 0.1s ease-out; }

#menu .mobile-show{ display: none; }
.non-mobile #menu #nav ul li a:hover{ color: #ffffff; }



/* ********************************************** Utility ********************************************** */

.table{ display:table; table-layout: fixed; position:relative; width:100%; }
.table .cell{ display:table-cell; position:relative; }
.table .cell.nowrap{ white-space: nowrap; }
.right { float: right; }
.relative { position: relative; }
.faded{ opacity: 0.35; }
.hidden { opacity: 0; transition: all .5s; }
.unhidden { opacity: 1 !important; }




/* ********************************************** Home Page ********************************************** */

#features-top{ background: #002c77; background: linear-gradient(135deg, #002c77 0%,#001d4d 100%); width:100%; position: relative;overflow: hidden; padding-top: 110px; padding-bottom: 72px; }
.bg-pattern{ position:absolute; top: -5px; left: -5px; transition: all 2s ease-out; width: 100%; overflow: hidden;}
.bg-pattern object{ opacity: 0.25; }
.bg-pattern.inside object{ opacity: 0.12; }
#bg-pattern{ width: 1800px; height: 800px; }

.feature { display: table; width: 100%; margin:0 auto; left: 0; right: 0; max-width:1600px; margin: 0 auto; padding-bottom: 50px; position: relative; }
.feature .column { display: table-cell; table-layout: fixed; vertical-align: top; transition: all 0.15s ease-out; }
.feature .column video { width:100%; }
.feature .column img { width:100%; }

.feature .column:nth-of-type(1) { width: 35%; padding: 40px 70px 40px 90px; }
.feature .column:nth-of-type(2) { width: 65%; padding: 40px 90px 40px 0; }
.feature .column h1 { padding:0; margin-bottom: 20px; font-size: 2.8em;color: #ffffff; }
.feature .column h3 { padding:0; margin-bottom: 30px; color: #9bcbeb; }



.highlights-square { width: 66.666%; display: table; table-layout: fixed; margin: 0 auto; position:relative; margin-top: -220px;z-index:5; box-shadow: 0 5px 25px rgb(201,211,226,0.4); }
.highlights-square .highlight { display: table-cell; width: 33%.3333; }
.highlights-square .highlight .row{ border:1px solid #b9c0c1; background-color: #ffffff; transition: all 0.15s ease-out; margin-top:-1px; z-index: 1; }

.highlights-square .highlight .row{ border:1px solid #c9d3e2; background-color: #ffffff; transition: all 0.15s ease-out; margin-top:-1px; z-index: 1; }
.highlights-square .highlight:nth-of-type(1) .row:nth-of-type(1) { border-right: 0; }
.highlights-square .highlight:nth-of-type(3) .row:nth-of-type(1) { border-left: 0; }
.highlights-square .highlight .row .image { width: calc(100%); height: 150px; background-size: cover; margin-bottom:25px; background-position: 0 50%; }
.highlights-square .highlight .row .cell:nth-of-type(1) { padding: 25px 25px 0 25px; }
.highlights-square .highlight .row .cell:nth-of-type(2) { padding: 10px 25px 25px 25px; }
.highlights-square .highlight .row .cell:nth-of-type(3) h5 { text-align: center; padding: 5px 0 5px 0; display: none; }
.non-mobile .highlights-square .highlight .row:hover { background-color: #f8f8ff; color: #00a3ad; }

.highlights-square .highlight h3{ font-size: 1.8em; font-weight: 700; }
.highlights-square .cell h5 { text-transform: capitalize; color: #002c77; display: inline-block; }
.highlights-square .cell h5:after{ font-family: "Font Awesome 5 Pro"; font-weight: 900; content: "\f061"; position: absolute; right: -22px; top: 0px; display: block; color: #002c77; font-size: 1em; font-style: normal; font-variant: normal; text-rendering: auto; -webkit-font-smoothing: antialiased; }

.slice-bottom{ position:absolute; width: 102%;height:100px;bottom:0;left:0;background: linear-gradient(to right bottom, transparent 49.5%, #ffffff 50%); z-index: 1; }
#home .slice-bottom{ z-index: 0; }
.slice-top{ position:absolute; width: 102%;height:100px;top:0;left:0;background: linear-gradient(to right bottom, #ffffff 49.5%, transparent 50%); }
.fake-gradient{ position:absolute; width: 100%;height:100%;top:0;left:0;background: linear-gradient(to right bottom, rgba(255,255,255,0.45) calc(0%), transparent 75%); }

.button-overlay{ z-index:20;text-align:center;position:relative;margin-top:-30px; }
.button-overlay button{ margin: 0 20px; box-shadow: 0 0px 0px rgb(201,211,226,0.4); }







/* ********************************************** Footer ********************************************** */

footer #position { position: fixed; display:inline-block;margin:30px 53px 25px 53px;text-align:left; font-family: 'Gotham SSm A', 'Gotham SSm B'; font-size: 0.9em; font-weight: 300; }
footer a { display: inline-block;margin-right:20px; padding: 10px 0; color:#ffffff;text-decoration:none;border:0; transition: color .15s linear; color: rgba(255, 255, 255, 0.95); }
.non-mobile footer a:hover { color: rgba(255, 255, 255, 1); }
footer .links { padding: 5px 0; }
footer .right a { margin-right:0; }
/*footer.bumper{ margin-bottom: 98px; } */
footer{ background-color: #00a3ad; text-align:center; }
footer .fab { font-size: 1.8em;padding: 0; margin: 0 8px; }



