html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

header,
main,
nav {
    display: block
}

a {
    background-color: transparent
}

a:active,
a:hover {
    outline-width: 0
}

b {
    font-weight: inherit
}

b {
    font-weight: bolder
}

*,
*:before,
*:after {
    box-sizing: border-box
}

html {
    box-sizing: border-box;
    background-attachment: fixed
}

body {
    color: #777;
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

p:empty {
    display: none
}

a {
    -ms-touch-action: manipulation;
    touch-action: manipulation
}

.col {
    position: relative;
    margin: 0;
    padding: 0 15px 30px;
    width: 100%
}

.col-inner {
    position: relative;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat;
    -ms-flex: 1 0 auto;
    flex: 1 0 auto
}

@media screen and (min-width: 850px) {
    .col:first-child .col-inner {
        margin-left: auto;
        margin-right: 0
    }

    .col+.col .col-inner {
        margin-right: auto;
        margin-left: 0
    }
}

@media screen and (max-width: 849px) {
    .col {
        padding-bottom: 30px
    }
}

@media screen and (min-width: 850px) {
    .large-12 {
        max-width: 100%;
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%
    }
}

body,
.container,
.row {
    width: 100%;
    margin-left: auto;
    margin-right: auto
}

.container {
    padding-left: 15px;
    padding-right: 15px
}

.container,
.row {
    max-width: 1080px
}

.flex-row {
    -js-display: flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row nowrap;
    flex-flow: row nowrap;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%
}

.header .flex-row {
    height: 100%
}

.flex-col {
    max-height: 100%
}

.flex-grow {
    -ms-flex: 1;
    flex: 1;
    -ms-flex-negative: 1;
    -ms-flex-preferred-size: auto !important
}

.flex-center {
    margin: 0 auto
}

.flex-left {
    margin-right: auto
}

.flex-right {
    margin-left: auto
}

.flex-has-center>.flex-row>.flex-col:not(.flex-center),
.flex-has-center>.flex-col:not(.flex-center) {
    -ms-flex: 1;
    flex: 1
}

.row {
    width: 100%;
    -js-display: flex;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap
}

.row>div:not(.col):not([class^="col-"]) {
    width: 100% !important
}

.row .row:not(.row-collapse),
.container .row:not(.row-collapse) {
    padding-left: 0;
    padding-right: 0;
    margin-left: -15px;
    margin-right: -15px;
    width: auto
}

.row .container {
    padding-left: 0;
    padding-right: 0
}

.nav p {
    margin: 0;
    padding-bottom: 0
}

.nav,
.nav ul:not(.nav-dropdown) {
    margin: 0;
    padding: 0
}

.nav {
    width: 100%;
    position: relative;
    display: inline-block;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
    -ms-flex-align: center;
    align-items: center
}

.nav>li {
    display: inline-block;
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
    margin: 0 7px;
    transition: background-color .3s
}

.nav>li>a {
    padding: 10px 0;
    display: inline-block;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -ms-flex-align: center;
    align-items: center
}

.html .nav>li>a {
    padding-top: 0;
    padding-bottom: 0
}

.nav-small .nav>li>a,
.nav.nav-small>li>a {
    vertical-align: top;
    padding-top: 5px;
    padding-bottom: 5px;
    font-weight: normal
}

.nav-small.nav>li.html {
    font-size: .75em
}

.nav-center {
    -ms-flex-pack: center;
    justify-content: center
}

.nav-left {
    -ms-flex-pack: start;
    justify-content: flex-start
}

.nav-right {
    -ms-flex-pack: end;
    justify-content: flex-end
}

@media (max-width: 849px) {
    .medium-nav-center {
        -ms-flex-pack: center;
        justify-content: center
    }
}

.nav>li>a {
    color: rgba(102, 102, 102, 0.85);
    transition: all .2s
}

.nav>li>a:hover {
    color: rgba(17, 17, 17, 0.85)
}

.nav li:first-child {
    margin-left: 0 !important
}

.nav li:last-child {
    margin-right: 0 !important
}

.nav-uppercase>li>a {
    letter-spacing: .02em;
    text-transform: uppercase;
    font-weight: bolder
}

@media (min-width: 850px) {
    .nav-divided>li {
        margin: 0 .7em
    }

    .nav-divided>li+li>a:after {
        content: "";
        position: absolute;
        top: 50%;
        width: 1px;
        border-left: 1px solid rgba(0, 0, 0, 0.1);
        height: 15px;
        margin-top: -7px;
        left: -1em
    }
}

li.html .row {
    margin: 0
}

.nav:hover>li:not(:hover)>a:before {
    opacity: 0
}

a.icon:not(.button) {
    font-family: sans-serif;
    margin-left: .25em;
    margin-right: .25em;
    font-size: 1.2em
}

.header a.icon:not(.button) {
    margin-left: .3em;
    margin-right: .3em
}

.header .nav-small a.icon:not(.button) {
    font-size: 1em
}

a {
    color: #334862;
    text-decoration: none
}

a:focus {
    outline: none
}

a:hover {
    color: #000
}

ul {
    list-style: disc
}

ul {
    margin-top: 0;
    padding: 0
}

ul ul {
    margin: 1.5em 0 1.5em 3em
}

li {
    margin-bottom: .6em
}

.col-inner ul li {
    margin-left: 1.3em
}

p,
ul {
    margin-bottom: 1.3em
}

body {
    line-height: 1.6
}

p {
    margin-top: 0
}

.nav>li>a {
    font-size: .8em
}

.nav>li.html {
    font-size: .85em
}

.container:after,
.row:after {
    content: "";
    display: table;
    clear: both
}

@media (min-width: 850px) {
    .show-for-medium {
        display: none !important
    }
}

@media (max-width: 849px) {
    .hide-for-medium {
        display: none !important
    }
}

.full-width {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    display: block
}

.fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    right: 0;
    bottom: 0;
    padding: 0 !important;
    margin: 0 !important
}

.bg-fill {
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-position: 50% 50%
}

.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    color: #21759b;
    display: block;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000
}

.box-shadow {
    box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23)
}

.nav-dark .nav>li>a {
    color: rgba(255, 255, 255, 0.8)
}

.nav-dark .nav>li>a:hover {
    color: #fff
}

.nav-dark .nav-divided>li+li>a:after {
    border-color: rgba(255, 255, 255, 0.2)
}

.nav-dark .nav>li.html {
    color: #fff
}

html {
    overflow-x: hidden
}

#wrapper,
#main {
    background-color: #fff;
    position: relative
}

.page-wrapper {
    padding-top: 30px;
    padding-bottom: 30px
}

.header,
.header-wrapper {
    width: 100%;
    z-index: 30;
    position: relative;
    background-size: cover;
    background-position: 50% 0;
    transition: background-color .3s, opacity .3s
}

.header-bg-color {
    background-color: rgba(255, 255, 255, 0.9)
}

.header-top {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    margin-bottom: 20px;
}

.header-bg-image,
.header-bg-color {
    background-position: 50% 0;
    transition: background .4s
}

.header-top {
    background-color: #446084;
    z-index: 11;
    position: relative;
    min-height: 20px
}

.header-main {
    z-index: 10;
    position: relative
}

.top-divider {
    margin-bottom: -1px;
    border-top: 1px solid currentColor;
    opacity: 0.1
}

.nav-dark .top-divider {
    display: none
}

@media (max-width: 849px) {
    .header-main li.html.custom {
        display: none
    }
}

html {
    background-color: #5b5b5b
}

.logo {
    line-height: 1;
    margin: 0
}

.logo a {
    text-decoration: none;
    display: block;
    color: #446084;
    font-size: 32px;
    text-transform: uppercase;
    font-weight: bolder;
    margin: 0
}

.nav-dark .logo a {
    color: #fff
}

.logo-left .logo {
    margin-left: 0;
    margin-right: 30px
}

@media screen and (max-width: 849px) {
    .header-inner .nav {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap
    }
}