﻿html {
    scroll-behavior: smooth
}

[id] {
    scroll-margin-top: 60px;
}

img[width][height] {
    height: auto
}

body {
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

.bodycopy, .fluid-copy {
    font-size: clamp(1.00rem, calc(0.93rem + 0.31vw), 1.13rem);
}

.bg-dark {
    background-color: #212529 !important
}

.bg-semi-light {
    background-color: #f2f2f2 !important
}

.bg-teal {
    background-color: #00738A !important
}

.bg-teal-light {
    background-color: #308FAD !important
}

.text-teal {
    color: #00738A !important
}

.text-orange {
    color: #F09006 !important
}

h1, .h1, h2, .h2, .text-uppercase {
    margin: 0
}

h3, .h3, h4, .h4, h5, .h5 {
    line-height: 1.5
}

h1, .h1, h2, .h2 {
    text-transform: uppercase
}

.h3 {
    text-transform: none
}

.text-uppercase {
    line-height: 1.2
}

figure {
    margin: 0
}

p, .bodycopy p {
    margin-bottom: 2rem
}

.bodycopy :is(h2, h3, h4, h5, h6) {
    margin-bottom: .75rem
}

    .bodycopy :is(h2, h3, h4, h5, h6):not(:first-child) {
        margin-top: 2.5rem
    }

.lead {
    font-size: clamp(1.25rem, calc(1.11rem + 0.62vw), 1.50rem)
}

h1, .h1 {
    font-size: clamp(2.19rem, calc(1.10rem + 4.62vw), 4.06rem)
}

h2, .h2 {
    font-size: clamp(1.69rem, calc(1.04rem + 2.77vw), 2.81rem)
}

h3, .h3 {
    font-size: clamp(1.44rem, calc(1.18rem + 1.08vw), 1.88rem)
}

h4, .h4 {
    font-size: clamp(1.31rem, calc(1.06rem + 1.08vw), 1.75rem)
}

h5, .h5 {
    font-size: clamp(1.25rem, calc(1.14rem + 0.46vw), 1.44rem)
}

h6, .h6 {
    font-size: clamp(1.13rem, calc(1.05rem + 0.31vw), 1.25rem)
}

p + .btn, ul + .btn {
    margin-top: 1rem
}

p:last-child {
    margin-bottom: 0
}

.relative {
    position: relative !important
}

.absolute {
    position: absolute !important
}

.static {
    position: static !important
}

.full-height {
    min-height: calc(100vh - 56px);
    display: flex;
    overflow: hidden
}
/* calc used to minus height of nav */
.rounded {
    border-radius: 30px !important
}

.text-grey {
    color: #717171
}

.no-margin {
    margin: 0 !important
}

header {
    box-shadow: 0 0px 3px rgba(0,0,0,0.3)
}

    header:focus, header:active, header:hover {
        z-index: 9999999
    }

.section-padding {
    padding: min(7rem, 16vw) .5rem
}

.section-padding-sm {
    padding: min(5rem, 12vw) .5rem
}

.section-padding:not([class*='bg-']) + .section-padding:not([class*='bg-']):not(footer),
.text-image-panel.bg-light + .text-image-panel.bg-light,
.text-image-panel:not(.bg-light) + .text-image-panel:not(.bg-light) {
    padding-top: 0
}

.text-image-panel.bg-light:has(+ .text-image-panel.bg-light ),
.text-image-panel:not(.bg-light):has(+ .text-image-panel:not(.bg-light)) {
    padding-bottom: 4rem
}

.text-image-panel .text-image-column :is(picture, img) {
    width: 100%
}

.padding {
    padding: min(2rem, 6vw) 0rem
}

    .padding.padding-bottom-only, .section-padding.padding-bottom-only {
        padding-top: 0 !important
    }

    .padding.padding-top-only, .section-padding.padding-top-only {
        padding-bottom: 0 !important
    }

    .padding.padding-sides-only, .section-padding.padding-sides-only {
        padding-bottom: 0 !important;
        padding-top: 0 !important
    }

section:not(.bodycopy) h2 {
    margin-bottom: 2rem
}

div.hero.cyan {
    background-color: #00738a;
}

.icon {
    width: auto;
    height: 90px;
    display: block;
    margin-bottom: 2rem;
    align-self: flex-start;
}

a, a:hover, .news-article h3, .transition {
    transition: all 0.3s ease
}

    a:hover, .news-article:hover h3, .social a:hover svg {
        color: #308fad;
        fill: #308fad
    }

        a:hover, a:hover * {
            text-decoration: none
        }

.bodycopy a:not([class]), .table a {
    text-decoration: underline;
}

    .bodycopy a:not([class]):hover, .table a:hover {
        color: #1f5e71
    }

img {
    max-width: 100%;
    image-rendering: -webkit-optimize-contrast;
}

/*
.heading-underlined {position: relative; padding-bottom: 2rem}
.heading-underlined:after {position: absolute; content: ""; width: 196px; display: block; height: 3px; background: #1A86A6; bottom: 0; left: calc(50% - 98px)}
*/
.armata, .lead {
    font-weight: 400;
    font-family: Armata, sans-serif
}

.btn {
    text-transform: uppercase;
    font-weight: 400;
    font-family: Armata, sans-serif;
    font-size: 1.13rem;
    text-align: center;
    padding: 1.25rem 3rem;
    white-space: normal
}

.btn-sm {
    font-size: 1rem;
    padding: 1rem 3rem
}

.btn-outline-primary {
    color: #000
}

.btn-white {
    background-color: #fff;
    color: #222
}

.container-fluid {
    max-width: 1190px;
}

.navbar-brand {
    padding: 0
}

    .navbar-brand img {
        width: 100px;
        height: auto;
        display: block
    }

.navbar {
    padding: .75rem 1rem
}

.navbar-nav {
    display: block;
    width: calc(100% + 0rem);
    margin: 1.25rem 0 0 0;
}

    .navbar-nav .dropdown-menu {
        border-radius: 0;
        border: none;
        background: #f2f2f2;
        border-bottom: 3px #1A86A6 solid;
        text-align: center;
        margin: 0;
        padding: 0;
        box-shadow: 0 1px 3px rgba(0,0,0,0.4)
    }

        .navbar-nav .dropdown-menu li {
            position: relative
        }

.dropdown-item {
    padding: 0.5rem 1.5rem
}

    .dropdown-item svg {
        width: 16px;
        height: 19px;
        vertical-align: middle;
        display: inline-block;
        margin-right: 5px
    }

.navbar-nav .dropdown-menu .dropdown-item:nth-child(even) {
    background: #fafafa
}

    .dropdown-item:focus,
    .dropdown-item:hover,
    .navbar-nav .dropdown-menu .dropdown-item:nth-child(even):hover,
    .dropdown-item:hover,
    .dropdown-item:hover svg {
        color: #fff;
        text-decoration: none;
        background-color: #222;
        fill: #fff
    }

.dropdown-item.active,
.dropdown-item:active,
.dropdown-item.active:hover {
    color: #fff;
    text-decoration: none;
    background-color: #1b85a6 !important;
    fill: #fff
}

.dropdown-item svg {
    fill: #000
}

.dropdown-item:hover svg {
    background-color: transparent !important
}

.navbar-light {
    background-color: #fff !important
}

    .navbar-nav .nav-link, .navbar-light .navbar-nav .active > .nav-link, .navbar-light .navbar-nav .nav-link {
        text-transform: uppercase;
        color: #000
    }

        .navbar-light .navbar-nav .nav-link:focus,
        .navbar-light .navbar-nav .nav-link:hover,
        .navbar-nav .nav-link,
        .navbar-light .navbar-nav .nav-link.active,
        .navbar-light .navbar-nav .active > .nav-link {
            color: #308fad
        }

    .navbar-light .navbar-nav .nav-link {
        color: #737373;
        padding: 1rem;
        background: #F5F5F5;
        text-align: center;
        white-space: nowrap;
    }

    .navbar-light .navbar-nav .nav-item:nth-child(even) .nav-link {
        background: #fafafa
    }

nav .container-fluid {
    max-width: 1350px
}

.hero {
    background-color: #D1D1D1;
    position: relative;
    overflow: hidden;
    margin-top: 56px;
    z-index: 1;
}

    .hero:not(.hero-slider, .minimal) {
        min-height: calc(100vh - 56px);
        min-height: calc(100svh - 56px);
        display: flex;
        align-items: center;
        flex-direction: column;
    }

.two-col-hero .row {
    position: relative
}

    .two-col-hero .row.full-image > div {
        background: transparent
    }

        .two-col-hero .row.full-image > div:first-child {
            position: static
        }

.two-col-hero .overlay:after {
    background: rgba(0, 0, 0, 0.5)
}

.hero.hero-slider .slick-list {
    height: 100%
}

.hero.hero-slider .slick-track {
    height: 100%;
    display: flex
}

.slick-initialized .slick-slide {
    display: flex;
    height: auto
}

.slick-initialized:not(:has(.slick-slide:nth-of-type(2))) .slick-dots {
    display: none !important;
}

.slick-dotted.slick-slider {
    margin-bottom: 0
}

.slick-dots {
    bottom: 1.25rem
}

    .slick-dots li {
        margin: 0 8px;
    }

        .slick-dots li button:before {
            content: "";
            font-family: inherit;
            width: 100%;
            height: 100%;
            border-radius: 100%;
            background: #000
        }

        .slick-dots li.slick-active button:before {
            background: #fff;
            box-shadow: 0 0 2px #000;
        }

@media (min-width:768px) {
    .slick-dots {
        bottom: 2rem
    }
}

.hero > * {
    position: relative;
}

.hero.minimal {
    height: auto;
    background: #308FAD;
    display: flex;
    align-items: center;
    padding-block: min(3rem, 7vw);
}

    .hero.minimal.news-article-page {
        padding-block-end: min(6rem, 14vw);
    }

    .hero.minimal h1 {
        margin: 0;
    }

@media (min-width:992px) {
    .hero.minimal {
        min-height: 200px !important;
    }
}

.hero-image {
    top: 0;
    left: 0;
    position: absolute;
    display: block;
    height: 100%;
    width: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

    .hero-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

.hero h1, .hero h2 {
    position: relative;
    margin: 1.5rem 0;
    z-index: 999;
    color: #fff;
    max-width: 19ch;
    text-wrap: balance
}

.hero .category {
    margin-bottom: -.5em;
    position: relative;
    z-index: 2;
}

.hero-slider .full-image h1, .hero-slider .full-image h2 {
    text-shadow: 0 0 10px rgba(0, 0, 0, .5);
}

.event-hero:after {
    background: rgba(0, 0, 0, 0.5) !Important;
}

.btn.event-btn {
    text-align: right;
    margin-left: 4.5rem;
    align-items: right;
    position: relative;
    margin-right: 4rem;
    color: #fff;
    border-color: #fff;
    font-size: 1.55em;
}

    .btn.event-btn:hover {
        border-color: #308fad;
        background-color: #308fad;
    }

.event-container {
    margin: 0 auto;
    margin-right: 7rem;
    width: 725px;
}

.search-header .search-form {
    margin-top: -50px;
    z-index: 99;
}

.search-header .hero.minimal {
    z-index: -99;
}

@media only screen and (max-width: 1024px) {
    .event-container h1 {
        margin-bottom: unset;
    }
}

@media only screen and (max-width: 767px) {
    .event-container h1 {
        margin-bottom: 2rem;
    }
}

@media only screen and (max-width: 900px) {
    .event-container {
        text-align: center !important;
        margin: unset;
    }
}

@media only screen and (max-width: 425px) {
    .event-container h1 {
        margin: unset;
    }

    .btn.event-btn {
        font-size: 1em;
    }
}

.hero h2 {
    font-size: 2rem;
    text-align: right;
}

.hero.minimal h1 {
    background: none
}

.arrow {
    z-index: 999;
    width: 30px;
    height: 30px;
    bottom: 3rem;
    left: 50%;
    transform: translateX(-15px)
}

    .arrow svg {
        opacity: 0;
        animation: nudge 2.5s infinite; /* IE 10+, Fx 29+ */
    }

.arrow-line {
    fill: none;
    stroke: #fff;
    stroke-width: 2px
}

.arrow.dark .arrow-line {
    stroke: #000
}

@keyframes nudge {
    0% {
        transform: translateY(-20px);
        opacity: 0;
    }

    30% {
        transform: translateY(0px);
        opacity: 1;
    }

    80% {
        transform: translateY(0px);
        opacity: 1;
    }

    100% {
        transform: translateY(20px);
        opacity: 0;
    }
}

.navbar-light .navbar-toggler {
    -webkit-appearance: none;
    border: none;
    background: none;
    position: relative;
    outline: none !important
}

.navbar-light .navbar-toggler-icon {
    background: #95989A;
    height: 1px;
    display: block;
    width: 20px
}


    .navbar-light .navbar-toggler .navbar-toggler-icon:first-of-type, .navbar-light .navbar-toggler-icon:last-of-type, .navbar-light .navbar-toggler-icon {
        position: relative;
        opacity: 0;
        transition: all 0.3s ease
    }

.navbar-light .navbar-toggler .navbar-toggler-icon:first-of-type {
    opacity: 1;
    top: 0px;
    transform: translateY(1px) rotate(45deg);
    transform-origin: center;
}

.navbar-light .navbar-toggler .navbar-toggler-icon:last-of-type {
    opacity: 1;
    top: 0px;
    transform: translateY(-1px) rotate(-45deg);
    transform-origin: center;
}

.navbar-light .navbar-toggler.collapsed .navbar-toggler-icon:first-of-type {
    transform: translateY(-5px)
}

.navbar-light .navbar-toggler.collapsed .navbar-toggler-icon:last-of-type {
    transform: translateY(5px)
}

.navbar-light .navbar-toggler.collapsed .navbar-toggler-icon {
    opacity: 1;
    transform: none
}



.category-picker .row {
    justify-content: center;
}

.category-picker .cat-item {
    background: #f1f1f1;
    display: flex;
    justify-content: center;
    position: relative;
    text-align: center;
}

    .category-picker .cat-item:hover {
        background: #05738A
    }

    .category-picker .cat-item::before {
        content: "";
        display: block;
        padding-bottom: 100%;
    }

    .category-picker .cat-item > div {
        display: flex;
        align-items: center;
        flex-direction: column;
    }

    .category-picker .cat-item h5 {
        width: 100%;
        transition: color 0.3s ease;
        max-width: 10ch;
    }

    .category-picker .cat-item:hover h5 {
        color: #fff
    }

    .category-picker .cat-item .cat-icon path,
    .category-picker .cat-item .cat-icon circle {
        transition: fill 0.3s ease;
        fill: #000;
        color: #000
    }

    .category-picker .cat-item:hover .cat-icon path,
    .category-picker .cat-item:hover .cat-icon circle {
        fill: #fff;
        color: #fff
    }

@media (max-width: 767px) {

    .category-picker .cat-item .cat-icon {
        width: 50px;
        height: 50px
    }

    @supports (scroll-snap-type: x mandatory) {
        .category-picker .products-scroll {
            overflow-x: auto;
            scroll-snap-type: x mandatory;
            -webkit-overflow-scrolling: touch;
            padding-left: 1rem;
        }

        .category-picker .row {
            justify-content: flex-start;
            flex-wrap: nowrap;
        }

            .category-picker .row .col-6 {
                max-width: none;
                flex: none;
                width: min(220px, 58vw);
                scroll-snap-align: center;
                display: flex;
            }
    }
}

@media (min-width: 768px) {

    .category-picker .row {
        row-gap: 2rem;
    }

    .category-picker .cat-item .cat-icon {
        width: 75px;
        height: 75px
    }
}

@media (min-width: 1200px) {

    .category-picker .row .col-6 {
        flex: 0 0 20%;
        max-width: 20%;
    }
}

.events-latest .row.padding {
    row-gap: min(5rem, 16vw);
}

.event-item .event-title {
    text-wrap: balance
}

.event-item time {
    margin: 0;
    padding: 0
}

.event-item figure {
    background: transparent;
}

    .event-item figure img {
        width: 100%;
        mix-blend-mode: multiply;
    }

@media (min-width:768px) {
    .event-item figure {
        height: 150px;
    }

        .event-item figure img {
            height: 100%;
            object-fit: contain;
        }
}

.news-articles-container {
    row-gap: min(5rem, 16vw)
}

.news-article {
    display: block
}

    .news-article:hover p, .news-article p {
        color: #000
    }

time {
    display: block;
    padding-top: 1rem;
    font-size: 1rem;
    color: #308fad
}

.news-article h3 {
    padding-top: 2rem;
    color: #000;
    margin-bottom: 0;
}

.news-article p {
    margin-top: 1rem;
}

.news-article time + h3 {
    padding-top: 0.5rem
}

.category {
    display: inline-flex;
    bottom: 0;
    right: 0;
    color: #fff;
    padding: 0.2rem .75rem;
    font-size: clamp(0.75rem, calc(0.68rem + 0.31vw), 0.88rem);
    transition: all 0.3s ease;
    background-color: #308fad;
}

.hero.minimal .category {
    background-color: #259ec4;
}

figure {
    background: rgba(0,0,0,1)
}

    figure img {
        transition: all 0.3s ease
    }

.news-article:hover figure img, a:hover figure img {
    opacity: 0.8
}

.news-article:hover .category {
    background-color: #1f5e71 !important
}

.news-article img {
    width: 100%;
    aspect-ratio: 6/4;
    object-fit: cover;
}

.no-object-fit .news-article img {
    height: auto;
    object-fit: none
}

.back-to-top {
    font-size: 0
}

    .back-to-top span {
        display: block;
        opacity: 0;
        font-size: 1rem;
        transform: translateY(-20px)
    }

    .back-to-top svg {
        width: 86px;
        height: 106px;
        display: block;
        margin: 0 auto
    }

        .back-to-top svg .path {
            fill: #909090;
            transition: all 0.3s ease
        }

    .back-to-top:hover svg {
        transform: translateY(-20px)
    }

        .back-to-top:hover svg .path {
            fill: #1A86A6
        }

    .back-to-top:hover span {
        opacity: 1;
        transform: translateY(0px)
    }

.archive-list {
    gap: 0.5rem 2rem
}

.tertiary-blocklinks a {
    color: #000;
    display: block;
    text-align: center !important;
    text-transform: uppercase !important;
    font-weight: 400;
    font-family: Armata, sans-serif;
}

footer ul {
    list-style-type: none;
}

footer a {
    font-weight: 400;
    color: #212529;
}

footer li a {
    font-family: Armata, sans-serif;
    text-transform: uppercase;
}

footer .smallprint {
    font-size: 0.88rem;
}

.tertiary-blocklinks a:hover {
    color: #308fad
}

.social li {
    display: flex;
    justify-content: center;
}

.social a {
    height: 54px;
    width: 54px;
    display: inline-block;
    position: relative;
    padding: 0
}

    .social a svg {
        height: 100%;
        width: 100%;
        color: #909090;
        fill: #909090
    }

.subnav {
    overflow: hidden;
    width: 100%;
}

    .subnav .container-fluid {
        padding: 0;
        justify-content: center
    }

    .subnav ul, .subnav ol {
        display: flex;
        justify-content: flex-start;
        padding-left: 0;
        margin-bottom: 0;
        list-style: none;
        overflow-x: scroll;
        -webkit-overflow-scrolling: touch;
    }

        .subnav ul a, .breadcrumb li {
            display: inline-block;
            padding: 1.1rem 1rem;
            color: #000;
            white-space: nowrap;
            position: relative
        }

li.breadcrumb-item {
    display: flex;
    align-items: center
}

    li.breadcrumb-item svg {
        color: #f7af34;
        fill: #f7af34;
        width: 15px;
        margin-right: 0.5rem
    }

    li.breadcrumb-item:not(:last-child) {
        padding-right: 0
    }

    li.breadcrumb-item + li.breadcrumb-item {
        padding-left: 0
    }

        li.breadcrumb-item + li.breadcrumb-item:before {
            content: "";
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='1' stroke-linecap='butt' stroke-linejoin='arcs'%3E%3Cpath d='M9 18l6-6-6-6'/%3E%3C/svg%3E");
            background-position: center;
            background-repeat: no-repeat;
            width: 30px;
            height: 12px;
            padding-right: 0;
            padding-left: 0
        }

.subnav .parent-breadcrumb {
    white-space: nowrap;
    position: relative;
    z-index: 1;
}

    .subnav .parent-breadcrumb a {
        color: #308fad;
        padding-right: calc(2rem + 10px)
    }

        .subnav .parent-breadcrumb a:after {
            content: "";
            display: block;
            position: absolute;
            opacity: 1;
            padding: 0;
            width: 30px;
            height: calc(100% + 20px);
            right: -5px;
            top: -10px;
            left: auto;
            bottom: auto;
            background: url("../images/locale-arrow.svg") no-repeat center center;
            background-size: auto 100%
        }

.subnav a:after {
    content: "";
    height: 5px;
    width: 100%;
    position: absolute;
    left: 0;
    bottom: 0;
    background-color: #308FAD;
    opacity: 0
}

.subnav a:hover {
    color: #308fad
}

.subnav .active a:after {
    opacity: 1
}

.breadcrumb {
    background-color: transparent;
    border-radius: 0;
}

nav#breadcrumb {
    width: 100%
}

.breadcrumb {
    padding: 0.25rem 0;
}

    .breadcrumb * {
        font-size: 0.9375rem
    }

    .breadcrumb a {
        color: #222
    }

        .breadcrumb a:after {
            display: none;
        }

    .breadcrumb .active {
        color: #308fad
    }

.breadcrumb-item {
    white-space: nowrap;
}

.jump-button {
    display: block;
    margin: 0.5rem
}

.jump-link {
    position: relative;
    top: -100px
}

.playbutton {
    width: 150px;
    height: 150px;
    display: inline-block;
    padding: 0;
    background: 0;
    border: none
}

    .playbutton:hover {
        cursor: pointer
    }

.playarrow {
    fill: #FFFFFF;
    stroke: #FFFFFF;
}

.playoutline {
    opacity: 0.61;
    fill: rgba(255,255,255,0);
    stroke: #FFFFFF;
    stroke-width: 7;
}

.playbutton:hover .playoutline {
    fill: rgba(255,255,255,0.4)
}

.modal-content {
    border: none;
    border-radius: 0
}

.modal-lg {
    width: 90vw;
    max-width: 1000px;
    margin-top: 0;
    margin-bottom: 0;
    top: 50vh;
    margin-left: auto;
    margin-right: auto;
}

    .modal-lg.modal-spec .modal-content {
        padding: 4rem 3rem
    }

.modal.fade .modal-dialog {
    transform: translate(0, -55%)
}

.modal.show .modal-dialog {
    transform: translate(0, -50%)
}

button.close {
    width: 40px;
    height: 40px;
    position: fixed;
    top: 2rem;
    right: 2rem;
    display: block;
    padding: 0;
    margin: 0;
    z-index: 9999
}

.close-circle {
    opacity: 0.61;
    fill: rgba(255,255,255,0);
    stroke: #FFFFFF;
    stroke-width: 3;
}

.cross {
    fill: none;
    stroke: #FFFFFF;
    stroke-width: 2
}

button.close:hover {
    cursor: pointer
}

    button.close:hover .close-circle {
        fill: rgba(255,255,255,0.5)
    }

.modal-backdrop.show {
    opacity: 0.6
}

.full-image-block img {
    width: 100%
}

.sub-heading {
    font-size: 75%;
    display: block;
    text-transform: none;
    margin-top: 0.5rem
}


.bodycopy ul:not(.social) {
    list-style-type: none;
    padding: 0;
    margin: 0 0 1.563rem 0;
    display: flex;
    flex-direction: column;
    gap: 1rem
}

.col-md-4 ul {
    margin: 0
}

.bodycopy ul:not(.social) li {
    position: relative;
    padding-left: 20px;
    line-height: 1.5
}

    .bodycopy ul:not(.social) li:before {
        content: "";
        width: 8px;
        height: 8px;
        background: #308FAD;
        position: absolute;
        left: 0;
        top: 13px;
        border-radius: 50%
    }

.bodycopy ul.large li {
    padding: 10px 0 10px 20px;
    font-size: 1.25rem
}

    .bodycopy ul.large li:last-of-type {
        padding-bottom: 0
    }

.bodycopy ul li.large:before {
    top: 20px
}

.config-boxes {
    flex-basis: 100%
}

.year-scroll-track-container > section {
    padding-right: 60px;
}

.year-scroll-track {
    position: fixed;
    right: -1px;
    top: 60px;
    bottom: 0;
    width: 60px;
    height: calc(100% - 60px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    background-image: linear-gradient( transparent 38px, rgba(144,144,144,0.3) 38px, rgba(144,144,144,0.3) 40px, transparent 40px );
    background-size: 100% 40px;
    background-position: 30px, top;
    background-repeat: no-repeat;
    background-repeat: repeat-y;
}


    .year-scroll-track a {
        background: #909090;
        padding: 0.5rem 0.5rem;
        color: #fff;
        display: block;
        font-size: 0.625rem;
        text-align: center;
        margin: 0.5rem 0;
    }

        .year-scroll-track a:hover {
            background: #5a5a5a
        }

        .year-scroll-track a.active:hover, .year-scroll-track a.active {
            background: #308FAD
        }

.event h3 {
    padding-top: 2rem;
}

.news-article-page h1 {
    text-transform: none;
}

.news-article-body {
    z-index: 2;
    margin-top: calc(-1 * min(3rem, 7vw))
}

.article-image img {
    width: 100%;
    display: block
}


.article-image-gallery img {
    display: block;
    margin: 0 auto;
    max-height: 80vh
}

.article-image-gallery figcaption {
    color: #fff;
    padding: 2rem;
    position: relative;
    min-height: 190px
}

.modal .article-image-gallery figcaption {
    padding: 2rem 5rem 2rem 2rem;
    min-height: 0
}

.gallery-padding {
    padding: 15px
}

.image-arrow {
    display: block;
    background: rgba(0, 0, 0, 1);
    color: #fff;
    padding: 1rem;
    top: 50%;
    transform: translateY(-50%)
}

    .image-arrow:hover {
        background: #308FAD;
        color: #fff
    }

    .image-arrow svg {
        display: block;
        width: 30px;
        height: 30px
    }

        .image-arrow svg * {
            stroke: #fff
        }

    .image-arrow.prev-image {
        right: 100%
    }

    .image-arrow.next-image {
        left: 100%
    }

.download-button {
    width: 42px;
    height: 42px;
    display: block;
    right: 1rem;
    top: calc(50% - 21px)
}

    .download-button svg {
        width: 100%;
        height: 100%;
        display: block
    }

        .download-button svg * {
            fill: none;
            stroke: #000;
            stroke-width: 2;
            stroke-linecap: round
        }

    .download-button.white svg * {
        stroke: #fff;
    }

    .download-button:hover svg .dl-arrow {
        transform: translateY(5px)
    }

.video-block .row + .row {
    margin-top: -2rem
}

.slideshow-section .slick-track {
    display: flex
}

.slick-slider:focus, .slick-track:focus, .slick-slide:focus {
    outline: none
}

.slick-list {
    overflow: visible
}

.slideshow-section {
    overflow: hidden;
    background: url("../images/map.svg") center center/auto 100% no-repeat;
    padding-bottom: 12rem;
}

    .slideshow-section .slideshow:not(.slick-initialized) > div:not(:first-of-type) {
        display: none;
    }

.slide-padding {
    margin: 0 15px;
    width: 100%;
    cursor: move; /* fallback if grab cursor is unsupported */
    cursor: grab;
    cursor: -moz-grab;
    cursor: -webkit-grab;
    position: relative
}

    .slide-padding:before {
        content: "";
        background-image: linear-gradient( to right, transparent 38px, rgb(48, 143, 173) 38px, rgb(48, 143, 173) 40px, transparent 40px );
        background-size: 40px 100%;
        background-position: center top;
        background-repeat: no-repeat;
        background-repeat: repeat-x;
        height: 40px;
        width: 100%;
        position: absolute;
        top: 50%;
        left: 0;
        display: block;
        transform: translateY(-50%);
        z-index: -1
    }

    .slide-padding img {
        margin: 2rem auto 2rem auto;
        max-width: 1100px;
        width: 100%;
        max-height: 600px;
        object-fit: contain;
    }

    .slide-padding p {
        position: absolute;
        top: calc(100% + 1rem);
        width: 100%;
    }

    .slide-padding .year {
        padding: 1rem 2rem;
        font-size: 1rem;
        position: absolute;
        bottom: 2rem;
        left: 50%;
        transform: translate(-50%, 50%);
        color: #fff
    }

.slick-next, .slick-prev {
    color: #fff;
    background: rgba(144, 144, 144, 1);
    padding: 1rem;
    transition: 0.3s ease;
    width: 62px;
    height: 62px;
    z-index: 9999
}

    .slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus {
        background: #308FAD
    }

.slick-next {
    right: 25px
}

.slick-prev {
    left: 25px
}

    .slick-prev:before, .slick-next:before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        opacity: 1
    }

    .slick-prev:before {
        background: url("../images/slide-arrow-left.svg") center center/20px auto no-repeat
    }

.slick-next:before {
    background: url("../images/slide-arrow-right.svg") center center/20px auto no-repeat
}

.social-share {
    position: sticky;
    bottom: 0;
    left: 0;
    width: 100%;
    color: #fff;
    z-index: 20;
    background-color: #318ead;
}

    .social-share .social {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 0;
        margin: 0
    }

    .social-share .container-fluid {
        background: #318ead;
    }

    .social-share h5 {
        color: #fff;
        font-size: 1rem
    }

    .social-share .social svg {
        color: #fff;
        fill: #fff;
        display: block
    }

    .social-share .social li:not([class]):hover svg {
        color: #ffda5b;
        fill: #ffda5b
    }

    .social-share .social a {
        width: 30px;
        height: 30px;
        display: block
    }

    .social-share .social li {
        padding: 0.5rem;
        transition: all 0.3s ease
    }

        .social-share .social li:not([class]):hover {
            background: #196b88
        }

        .social-share .social li:first-child svg {
            width: 30px;
            height: 30px;
            fill: #ffdb5a;
            transition: all 0.3s ease
        }

        .social-share .social li.share-title {
            border-right: 1px #fff solid
        }

@media (min-width: 1500px) {
    .social-share {
        position: absolute;
        width: 160px;
        inset: 5.5rem auto 5.5rem calc(900px / 2 + 50vw + 1rem);
        background-color: transparent;
    }

        .social-share .container-fluid {
            position: sticky;
            top: 7.5rem
        }

        .social-share .social {
            flex-wrap: wrap;
            padding: 1rem 0
        }

            .social-share .social li.share-title {
                border-right-width: 0;
                border-bottom: 1px #fff solid;
                width: 100%;
                margin-bottom: 1rem;
            }
}

.mission-builder {
    overflow: hidden;
}

    .mission-builder .builder-form {
        position: relative;
        z-index: 2
    }

        .mission-builder .builder-form > * {
            position: relative;
            z-index: auto;
        }

        .mission-builder .builder-form:before {
            content: "";
            position: absolute;
            background-color: #000;
            width: 100vw;
            height: 5000px;
            bottom: 0;
            left: calc(50% - 50vw);
            pointer-events: none;
        }

        .mission-builder .builder-form:after {
            content: "";
            width: 15px;
            height: 48px;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14.865' height='47.715' viewBox='0 0 14.865 47.715'%3E%3Cpath d='M748.328,2009.1l14.865,23.857-14.865,23.857' transform='translate(-748.328 -2009.102)'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: center;
            position: absolute;
            top: 100%;
            left: calc(50% + 24px);
            transform-origin: top left;
            transform: rotate(90deg)
        }

    .mission-builder .btn {
        cursor: pointer
    }

.form-group {
    margin-bottom: 2.5rem
}

.builder-inner > .form-group:last-of-type {
    margin-bottom: 0
}

.form-control, .mission-builder .form-check-label {
    padding: 0.65em 1em;
    border-radius: 0;
    border-width: 1px;
    border-color: #AA9E9E;
}

.mission-builder .form-control {
    width: auto;
    display: inline-block;
}


.mission-builder [data-name="Latitude"] .form-control,
.mission-builder [data-name="Longitude"] .form-control {
    max-width: 10ch;
}

    .mission-builder [data-name="Latitude"] .form-control + span,
    .mission-builder [data-name="Longitude"] .form-control + span {
        display: inline-block;
        transform: translate(-19px, -7px);
    }

.mission-builder [data-name="Eirp"] .form-control,
.mission-builder [data-name="GOverT"] .form-control,
.mission-builder [data-name="DataVolume"] .form-control {
    max-width: 13ch;
}

.mission-builder .builder-form [data-is-visible="false"] {
    margin: 0
}

.mission-builder .builder-form [data-is-visible="false"], .mission-builder .builder-form [data-is-visible="true"] {
    overflow: hidden;
    transition: all 0.5s ease;
    opacity: 0;
}

.mission-builder .builder-form [data-is-visible="false"] {
    max-height: 0px;
    visibility: hidden;
}

.mission-builder .builder-form [data-is-visible="true"] {
    max-height: 300px;
    overflow: visible;
    opacity: 1;
    visibility: visible;
}


.mission-builder [data-name="date"] .form-control {
    width: 20ch;
}

.mission-builder [data-theme="dark"] [data-name="StartDate"] .form-control::-webkit-input-placeholder,
.mission-builder [data-theme="dark"] [data-name="EndDate"] .form-control::-webkit-input-placeholder {
    color: #fff;
}

.mission-builder [data-theme="dark"] [data-name="StartDate"] ::-webkit-calendar-picker-indicator,
.mission-builder [data-theme="dark"] [data-name="EndDate"] ::-webkit-calendar-picker-indicator {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="15" viewBox="0 0 24 24"><path fill="%23ffffff" d="M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 18H4V8h16v13z"/></svg>');
}


.mission-builder .form-check {
    display: flex
}

.mission-builder .form-check-label {
    flex-basis: 115px;
    text-align: center;
}

    .mission-builder .form-check-label:hover {
        z-index: 10
    }

    .mission-builder .form-check-label:first-of-type {
        border-radius: 8px 0 0 8px;
    }

    .mission-builder .form-check-label:last-of-type {
        border-radius: 0 8px 8px 0
    }

    .mission-builder .form-check-label ~ .form-check-label {
        margin-left: -1px
    }


label, legend {
    font-size: 0.9375rem;
    font-weight: bolder;
    margin: 0
}

.mission-builder .tip-container {
    display: flex;
    align-items: center;
}

.mission-builder .form-group .tip-container {
    margin-bottom: .5rem;
}

.mission-builder .tip-container legend, .mission-builder .tip-container .label {
    width: auto;
    margin: 0
}

.mission-builder .tip-container .tip {
    flex: none;
    background: none;
    border-radius: 0;
    text-indent: -9999px;
    outline: none;
    border: none;
    padding: 0;
    margin: 0 0.5rem 0 0;
    width: 20px;
    height: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23308FAD' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpath d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'%3E%3C/path%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'%3E%3C/line%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
}

    .mission-builder .tip-container .tip:focus-visible,
    .mission-builder .tip-container .tip:hover {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cpath d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'%3E%3C/path%3E%3Cline x1='12' y1='17' x2='12.01' y2='17'%3E%3C/line%3E%3C/svg%3E");
    }

.tooltip.show {
    opacity: 1;
}

.tooltip-inner {
    background: #fff;
    color: #222;
    padding: 1rem;
}

.tooltip .arrow {
    transform: none;
    bottom: auto
}

.tooltip.bs-tooltip-right .arrow::before {
    border-right-color: #fff
}

.tooltip.bs-tooltip-left .arrow {
    left: auto
}

    .tooltip.bs-tooltip-left .arrow::before {
        border-left-color: #fff
    }

.mission-builder .builder-inner[data-theme="dark"] {
    color: #fff;
    flex-grow: 1
}

    .mission-builder .builder-inner[data-theme="dark"] .form-control,
    .mission-builder .builder-inner[data-theme="dark"] .form-check-label,
    .mission-builder .builder-inner[data-theme="dark"] .form-control:focus {
        background-color: #212529;
        border-color: #737373;
        color: #fff;
        font-weight: normal;
        border-style: solid;
    }

    .mission-builder .builder-inner[data-theme="dark"] .form-check-input:checked + .form-check-label,
    .mission-builder .builder-inner[data-theme="dark"] .form-check-input:checked + .form-check-label:hover {
        background-color: #308fad;
        border-color: #308fad !important
    }

.mission-builder .form-check-input:checked + .form-check-label + .form-check-input + .form-check-label {
    border-left-color: #308fad
}

.mission-builder .builder-inner[data-theme="dark"] .form-control:hover,
.mission-builder .builder-inner[data-theme="dark"] .form-check-label:hover,
.mission-builder .builder-inner[data-theme="dark"] .form-control:focus,
.mission-builder .builder-inner[data-theme="dark"] .form-check-input:focus + .form-check-label {
    border-color: #fff
}

.mission-builder .text-secondary {
    color: #B5B5B5 !important
}

.mission-builder .form-results .builder-inner > div {
    min-height: 350px;
    width: 100%;
    position: relative;
}

.mission-builder .form-results .builder-inner .result-section dl.result-text dd {
    min-width: 60px;
}

[data-is-visible="true"] {
    display: block
}

[data-is-visible="false"] {
    display: none
}


.field-validation-error, .EditingFormErrorLabel {
    color: #f32020
}

.lds-ring {
    display: inline-block;
    position: absolute;
    width: 80px;
    height: 80px;
    left: calc(50% - 40px);
    top: calc(50% - 80px);
}

    .lds-ring div {
        box-sizing: border-box;
        display: block;
        position: absolute;
        width: 64px;
        height: 64px;
        margin: 8px;
        border: 8px solid #fff;
        border-radius: 50%;
        animation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
        border-color: #fff transparent transparent transparent;
    }

        .lds-ring div:nth-child(1) {
            animation-delay: -0.45s;
        }

        .lds-ring div:nth-child(2) {
            animation-delay: -0.3s;
        }

        .lds-ring div:nth-child(3) {
            animation-delay: -0.15s;
        }

@keyframes lds-ring {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.mission-builder .form-results .builder-inner .result-section + .result-section {
    margin-top: 1.5rem;
    border-top: 1px #3B3B3B solid;
    padding-top: 1.5rem
}

.mission-builder .form-results .builder-inner .result-section .result-text {
    font-size: 0.75rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.mission-builder .form-results .builder-inner .result-section dl.result-text dt {
    flex-basis: 48%;
    margin: .5rem auto 0 0;
    font-weight: normal;
}

.mission-builder .form-results .builder-inner .result-section dl.result-text dd {
    margin: .5rem 0 0 1.5rem
}

.mission-builder .form-results .builder-inner .result-section > strong {
    display: block;
    margin-bottom: 0.5rem;
}

.share-results .btn-share {
    text-transform: none;
    display: flex;
    padding-left: 2rem;
    padding-right: 2rem;
    max-width: 100%;
    align-items: center;
    user-select: all;
}

    .share-results .btn-share span {
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap;
    }

    .share-results .btn-share:after, .share-results .btn-download:after {
        content: "";
        width: 24px;
        height: 24px;
        display: block;
        margin-left: 1rem;
        background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23308FAD' stroke-width='1.5' stroke-linecap='butt' stroke-linejoin='arcs'%3E%3Cpath d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71'%3E%3C/path%3E%3Cpath d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71'%3E%3C/path%3E%3C/svg%3E") no-repeat center
    }

.share-results .btn-download {
    display: flex;
    align-items: center;
}

    .share-results .btn-download:after {
        background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23308FAD' stroke-width='1.5' stroke-linecap='butt' stroke-linejoin='arcs'%3E%3Cpath d='M3 15v4c0 1.1.9 2 2 2h14a2 2 0 0 0 2-2v-4M17 9l-5 5-5-5M12 12.8V2.5'/%3E%3C/svg%3E") no-repeat center;
    }

    .share-results .btn-download:hover:after {
        background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23FFFFFF' stroke-width='1.5' stroke-linecap='butt' stroke-linejoin='arcs'%3E%3Cpath d='M3 15v4c0 1.1.9 2 2 2h14a2 2 0 0 0 2-2v-4M17 9l-5 5-5-5M12 12.8V2.5'/%3E%3C/svg%3E") no-repeat center;
    }

.share-results .btn-share.copied:after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23308FAD' stroke-width='1.5' stroke-linecap='butt' stroke-linejoin='arcs'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
}

.generic-form {
    padding: 2rem
}

    .generic-form .form-group:last-of-type {
        margin: 0
    }

@media (max-width: 374px) {
    .mission-builder .form-results .builder-inner .result-section dl.result-text dt {
        flex-basis: 42%;
    }
}

@media (min-width: 768px) {
    .underline-mobile-only {
        border: none;
        padding-bottom: 0 !important
    }

    .heading-underlined.underline-mobile-only:after {
        display: none
    }

    .mobile-padding + .mobile-padding {
        padding-top: 0rem
    }

    .divider .col-12 {
        padding-right: 3rem
    }

        .divider .col-12 + .col-12 {
            padding-right: 15px;
            padding-left: 3rem
        }

        .divider .col-12:first-of-type:after {
            content: "";
            position: absolute;
            width: 3px;
            background: #308fad;
            height: 100%;
            bottom: 0rem;
            right: 0;
            display: block
        }

    .icon {
        height: 120px
    }

    .jump-button {
        padding: 3rem 0.5rem
    }

    .subnav ul li.active:first-of-type {
        margin-left: 2rem
    }

    .subnav ul a {
        padding: 2rem
    }

    .navbar-brand img {
        width: 170px;
        max-width: none;
    }

    .sub-heading {
        font-size: 40%;
    }

    .hero {
        margin-top: 79px
    }

    .social-share .social a, .social-share .social li:first-child svg {
        width: 40px;
        height: 40px
    }

    .social-share h5 {
        font-size: 1.25rem
    }

    .mission-builder .group-container .form-group + .form-group {
        margin-left: 2rem
    }

    .mission-builder .form-results .builder-inner .result-section dl.result-text dd {
        min-width: 50px;
        text-align: right;
    }
}

@media (max-width: 991px) {
    .hero .pathfinder-logo {
        max-width: 150px;
        height: auto
    }

    .builder-form {
        padding-bottom: 4rem
    }

    .form-results {
        padding-top: 4rem
    }

    .two-col-hero .hero-image-container {
        aspect-ratio: 6/3;
        min-height: auto;
        flex: none;
    }

    .text-image-panel .text-image-row > .text-image-column + .text-image-column {
        margin-top: 2.5rem;
    }
}

@media (min-width: 992px) {

    [id] {
        scroll-margin-top: 80px;
    }

    .navbar-nav .dropdown-menu {
        text-align: left
    }

        .navbar-nav .dropdown-menu li .dropdown-menu {
            left: 100%;
            top: 0
        }

    .dropdown-submenu {
        display: flex;
        align-items: center;
    }

        .dropdown-submenu:after {
            transform: rotate(-90deg);
            margin: 0 0 0 0.25em
        }

    .hero:not(.hero-slider, .minimal) {
        min-height: calc(100vh - 85px);
    }

    .full-height {
        min-height: calc(100vh - 83px)
    }

    .video-block .row + .row {
        margin-top: -3rem
    }

    .padding-sml {
        padding: 2rem 0
    }

    .navbar-expand-lg .navbar-nav {
        flex-basis: 100%;
        margin-left: 4%;
        display: flex;
        margin: 0;
        width: 100%
    }

    .navbar {
        padding: 1.25rem 1rem;
    }

    .navbar-light .navbar-nav .nav-link {
        color: #000;
        background: none !important;
        text-align: left;
        padding: 0.5rem
    }

    .playbutton {
        width: 200px;
        height: 200px
    }

    .jump-link {
        top: -150px
    }

    .year-scroll-track-container > section {
        padding-right: 160px;
    }

    .year-scroll-track {
        top: 89px;
        width: 140px;
        height: calc(100% - 89px);
        background-position: 80px, top;
    }

        .year-scroll-track a {
            padding: 1rem 1rem;
            font-size: 1rem;
            margin: 2rem 0;
        }

    .modal-lg.modal-spec {
        width: auto;
        max-width: 1000px
    }

    .mission-builder {
        position: relative;
    }

        .mission-builder .builder-form {
            position: static;
        }

            .mission-builder .builder-form:before {
                width: 50vw;
                height: 5000px;
                bottom: 0;
                left: auto;
                right: 50%;
                pointer-events: none;
            }

            .mission-builder .builder-form:after {
                top: calc(50% - 24px);
                left: 50%;
                transform: none
            }

        .mission-builder .form-results .builder-inner .result-section .result-text {
            font-size: 0.9375rem
        }

        .mission-builder .form-results .builder-inner .result-section dl.result-text dt {
            flex-basis: 52%;
        }

    .generic-form {
        padding: 3rem 2.5rem
    }

    .two-col-hero .row {
        min-height: calc(100vh - 85px);
        min-height: calc(100svh - 85px);
    }

    .two-col-hero.hero-slider > div:not(.slick-initialized) .row:not(:first-of-type) {
        display: none;
    }

    .slick-slider:not(.slick-initialized) {
        height: calc(100vh - 85px);
        height: calc(100svh - 85px);
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .modal-lg {
        max-width: 65vw
    }
}

@media (min-width: 1025px) {

    .hero {
        margin-top: 90px;
    }

    .navbar-expand-lg .navbar-nav {
        flex-basis: 85%;
        margin-left: auto;
    }

    .subnav, .breadcrumb {
        flex-wrap: wrap;
    }

        .subnav ul, .subnav ol {
            overflow: hidden
        }
}

@media (min-width: 1500px) {
    .year-scroll-track-container > section {
        padding-right: 1rem;
    }
}

@media (max-width: 768px) {
    .subnav .parent-breadcrumb {
        display: none
    }
    /*	.subnav .parent-breadcrumb a{font-size: 0}
  .subnav .parent-breadcrumb a:before {content :"< back"; font-size: 1rem}
  .subnav .parent-breadcrumb a:after {display: none}*/
    .modal-open .modal {
        -webkit-overflow-scrolling: touch
    }

    .image-arrow {
        display: none
    }
}

@media (max-width: 767px) {
    .mobile-centred {
        margin: 0 auto 2rem auto;
        text-align: center
    }

    .mobile-full-width {
        width: 100%
    }

    .mobile-padding + .mobile-padding {
        padding-top: 2rem
    }

    .btn {
        font-size: 1rem;
        padding: 1rem 2rem
    }

    .table {
        font-size: 0.5625rem
    }

    .config {
        font-size: 1rem
    }

        .config br {
            display: none;
        }

    .rellax.no-mobile-parallax[style] {
        transform: none !important
    }

    .modal-lg.modal-spec {
        top: 1rem !important;
        transform: none !important;
        margin-bottom: 2rem
    }

        .modal-lg.modal-spec .modal-content {
            padding: 2rem 1rem
        }

    .galileo-specs-modal .close-circle, .galileo-specs-modal .cross {
        stroke: #000
    }

    .article-image-gallery figcaption {
        font-size: 0.875rem;
        padding: 2rem 4rem 2rem 2rem;
    }

        .article-image-gallery figcaption .download-button {
            width: 33px;
            height: 33px;
        }

    .slide-padding img {
        margin: 2rem auto
    }

    .slide-padding .year {
        padding: 0.5rem 1rem;
        font-size: 0.625rem
    }
}

/* DISCOVER OUR PRODUCTS WIDGET */

.discover {
    border: 3px solid #308fad;
    border-radius: 0.5rem;
    padding: 25px;
    margin-bottom: 30px;
}

    .discover:hover {
        color: #fff;
        background-color: #308fad;
        border-color: #308fad;
    }

.discover-title {
    margin-top: 40px;
    margin-bottom: 5px;
    text-align: center;
    text-transform: uppercase;
}

/* PLATFORM TABLE UPDATED */

.platform-table .table thead th {
    padding: 1rem 0.75rem;
    border: 3px solid white;
}

    .platform-table .table thead th.coloured-cell {
        background-color: #308fad;
        border-radius: 0.6rem;
    }

.coloured-cell a {
    color: white;
}

.platform-table .table th[scope="row"] {
    background-color: #a8a8a8;
    border-radius: 0.6rem;
    color: white;
    border-top: none;
    border: 3px solid white;
}

.platform-table .table th,
.table td {
    text-align: center;
    text-transform: uppercase;
    padding: 0.75rem 0rem 0.75rem 0rem;
    border-top: none;
    border: 3px solid white;
    position: relative;
}

.platform-table .check {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #308FAD;
    display: inline-block;
    font-size: 0;
    position: absolute;
    top: calc(50% - 15px);
    left: calc(50% - 15px);
}

@media (max-width: 767px) {
    .platform-table .check {
        width: 20px;
        height: 20px;
        top: calc(50% - 10px);
        left: calc(50% - 10px);
    }

    .platform-table .table td, .platform-table .table th {
        padding: 1.25rem 0.5rem;
    }
}

.platform-table tbody tr:nth-child(2n + 1) {
    background: #f2f2f2
}

.platform-table tbody tr:nth-child(2n + 2) {
    background: #e6e6e6
}


.table-header {
    margin-bottom: 5px;
    text-align: center;
    text-transform: uppercase;
    color: #a8a8a8;
}

.rotated {
    margin-top: 100px;
    transform: rotate(-90deg);
    height: 50px;
    position: absolute;
    top: 32%;
    left: -17%;
}

@media (max-width: 1100px) {
    .table-header {
        display: none;
    }
}

.platforms .row.padding {
    padding: 2rem 0rem;
    position: relative;
}

.platforms {
    padding: 0rem 0rem 8rem 0rem;
}

/* CONFIGUATION TICKS UPDATE */


.config-boxes {
    --min: 310px;
    display: grid !important;
    gap: 1.5rem 2rem;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--min), 100%), 1fr));
}

    .config-boxes img {
        width: min(35px, 7vw);
    }

.config {
    font-family: Armata, sans-serif;
    font-size: clamp(1.13rem, calc(0.94rem + 0.77vw), 1.44rem);
}

.config-wrap {
    display: inline-flex;
    gap: 1.5rem;
    align-items: center;
}
/* VIDEO FOR HERO */
.hero-image.full-video video {
    position: absolute;
    min-height: 100%;
    min-width: 100%;
    top: 0;
    left: 0;
    display: none;
}

@media (min-width: 767px) {
    .hero-image.full-video[style] {
        background-size: 0 0;
    }

    .hero-image.full-video video {
        display: block;
    }
}
/* Cookie Banner */
#cookiebanner {
    position: fixed;
    bottom: 0;
    width: 100%;
    z-index: 999;
    background: #fff;
    box-shadow: 0 -1px 10px rgba(0,0,0,.3);
    transform: translateY(100%);
    opacity: 0;
    transition: all .3s ease;
    padding: 20px 0px;
}

    #cookiebanner.active {
        transform: translateY(0);
        opacity: 1;
    }

    #cookiebanner .container-fluid {
        display: flex;
        align-items: center
    }

    #cookiebanner p {
        margin: 0;
        margin-right: 15px
    }

    #cookiebanner button {
        width: 35px;
        height: 35px;
        float: none;
        flex-shrink: 0;
        opacity: 1;
        position: static;
    }

button.cookieclose {
    top: unset;
}
/* OVERLAY FOR HERO */

.hero:not([data-variant="bottom-fade"]) .overlay:after {
    content: "";
    background: rgba(0, 0, 0, 0.5);
    height: 100%;
    width: 100%;
    position: absolute;
    display: block;
    top: 0
}

.hero[data-variant="bottom-fade"]:after {
    --bg: 190, 100%, 27.06%;
    content: "";
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    background: linear-gradient( to bottom, hsla(var(--bg), 0) 35%, hsla(var(--bg), 0.8) 70%, hsla(var(--bg), .95) 90%);
}

.hero[data-variant="bottom-fade"] .hero-heading-box {
    z-index: 2;
    margin-bottom: max(8vw, 3rem);
    text-shadow: 0 0 7px hsla(190, 100%, 23%, 1);
    position: relative;
}

    .hero[data-variant="bottom-fade"] .hero-heading-box > :last-child {
        margin-bottom: 0 !important;
    }

.overlay + h1 {
    background: none;
}

@media(max-width: 991px) {
    .hero[data-variant="bottom-fade"] {
        --img-height: 250px;
        min-height: 0;
        background-color: hsl(190, 100%, 27.06%);
        overflow: hidden;
    }

        .hero[data-variant="bottom-fade"]::after {
            display: none;
        }

        .hero[data-variant="bottom-fade"] .hero-image {
            height: var(--img-height);
        }

        .hero[data-variant="bottom-fade"] .hero-heading-box {
            position: relative;
            margin-top: var(--img-height);
            margin-bottom: 0;
            padding: 0 1.5rem max(8vw, 3rem) 1.5rem;
            width: calc(100% + 3rem);
            background-color: hsl(190, 100%, 27.06%);
            max-width: none;
        }

            .hero[data-variant="bottom-fade"] .hero-heading-box::after {
                --bg: 190, 100%, 27.06%;
                content: "";
                position: absolute;
                height: var(--img-height);
                bottom: 100%;
                left: 0;
                width: 100%;
                background: linear-gradient( to bottom, hsla(var(--bg), 0) 66%, hsla(var(--bg), 0.62) 80%, hsla(var(--bg), 1) 98%)
            }

        .hero[data-variant="bottom-fade"]:after {
            height: var(--img-height);
        }
}


/* -----KENTICO FIXED MASTER PAGE HEADER FIX ------ */
.DesignMode header.fixed-top,
.EditMode header.fixed-top {
    Position: static !important;
}
/* -----KENTICO PADDING HERO FIX ------ */
.DesignMode .hero,
.EditMode .hero {
    margin-top: 0px;
}
/* -------------REMOVE LI STYILNG--------------- */

.footer-logo {
    display: flex;
    max-inline-size: 250px;
}

    .footer-logo img {
        width: min(78%, 40vw)
    }

footer ul {
    padding-left: 0px;
    margin: 0
}

    footer ul li {
        list-style-type: none;
    }

    footer ul:not(.social) li + li {
        margin-top: .5rem;
    }
/* -------------TINT--------------- */
.full-tint {
    opacity: 0.5;
}

    .full-tint .container-fluid {
        position: relative;
        z-index: 9;
    }

/* ---------------SLICK SLIDE ARROWS------------- */
.slick-next:before {
    background: url(https://www.sstl.co.uk/getmedia/0f150ae6-7de6-45bf-b019-ed12a39f9e6e/slide-arrow-right) center center/20px auto no-repeat;
}

.slick-prev:before {
    background: url(https://www.sstl.co.uk/getmedia/6018d55b-100a-4a8e-bf34-fd0041a86d8f/slide-arrow-left) center center/20px auto no-repeat;
}
/* ------------------PAGINATION ARROW---------------- */
.subnav .parent-breadcrumb a:after {
    background: url(https://www.sstl.co.uk/getmedia/13070e8f-0696-4a7f-8568-9c3f7fdf1d02/locale-arrow) no-repeat center center;
}
/* ------------------DOWNLOAD PDF---------------- */
article .download-button svg {
    position: absolute;
    display: inherit;
    right: 60px;
}

article .download-button {
    left: 4rem;
    top: calc(1% - 15px);
    position: relative;
}
/* ------------------BACK TO TOP COLOUR CHANGE---------------- */
.back-to-top:hover {
    color: #f7af34;
    fill: #f7af34;
}

    .back-to-top:hover svg .path {
        fill: #f7af34
    }

/* ------------------FOOTER PADDING CHANGE---------------- */

footer {
    box-shadow: 0 0 15px hsl(0deg 0% 0% /.1);
}

    footer.section-padding {
        padding: min(4rem, 16vw) 1rem 0 1rem;
    }

    footer .smallprint {
        padding-block: 2rem;
        border-top: 1px #f1f1f1 solid;
        margin-top: min(4rem, 9vw);
        display: flex;
        flex-wrap: wrap;
        gap: .75rem 2rem;
        align-items: center;
    }

        footer .smallprint .accreditations {
            display: flex;
            gap: 1rem;
            margin-right: auto;
        }

@media (max-width: 767px) {
    footer .smallprint span {
        flex-basis: 100%;
    }
}

/* ------------------TICK CONFIGURATION SPACEPLATFORMS ANIMATION---------------- */

.config-wrap {
    opacity: 0;
    transform: translateY(100%);
}

.animate {
    opacity: 1;
    transform: translateY(0%);
    transition: .8s ease-in-out;
}


/* ------------------GALLERY IMAGE TEXT CHANGE---------------- */

.featured-title {
    position: absolute;
    bottom: 0;
    color: white;
    padding: 20px 20px 10px 20px;
    z-index: 1;
    width: 100%;
}

figure .featured-title:after {
    z-index: -1;
    content: "";
    display: block;
    position: absolute;
    bottom: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000000+0,000000+100&0+69,0.75+81 */
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 69%, rgba(0, 0, 0, 0.75) 81%, rgba(0, 0, 0, 0.75) 100%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 69%, rgba(0, 0, 0, 0.75) 81%, rgba(0, 0, 0, 0.75) 100%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.75) 28%, rgba(0, 0, 0, 0.75) 100%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#bf000000', GradientType=0);
    /* IE6-9 */
}
/* -------------- Button Overflow fix ----------------- */
.category-intros .btn {
    white-space: normal;
}
/* ------------------Discover Cards Height Fix---------------- */
@media only screen and (min-width: 767px) {
    .discover {
        min-height: 353px;
    }
}
/* ------------------Home Page Hero Mobile---------------- */
@media only screen and (min-width: 1000px) {
    .fade-mobile {
        background-image: none !Important;
    }
}

@media only screen and (max-width: 999px) {
    .hero-image.mobile-slide-hero {
        display: none;
    }

    .fade-mobile {
        background-position: center;
    }
}

/* ------------------ mission fix for black space --------------*/
@media only screen and (max-width: 767px) {
    .year-scroll-track-container > section .col-12:nth-child(1) {
        padding-right: 100px;
    }

    .year-scroll-track-container > section {
        padding-right: 7.5rem;
    }
}


@media only screen and (max-width: 598px) {
    .year-scroll-track-container > section .col-12:nth-child(1) {
        padding-right: 0px;
    }
}
/* ----------- Category 2 columns Flex for buttons ---------- */
.category-intros .icon {
    margin-right: auto;
}

.category-intros .btn {
    margin-top: auto;
    align-self: flex-start;
}

.category-intros p:last-of-type {
    margin-bottom: 1.563rem;
}

@media only screen and (max-width: 767px) {
    .category-intros .btn {
        align-self: auto;
    }
}
/* ---------------- Article Download Button Mobile Fix ------------*/
@media only screen and (max-width: 598px) {
    article .download-button {
        top: calc(1% - 40px);
    }
}
/* ---------------- Slideshow fix for IE ------------*/
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    .sy-slides-crop {
        Height: calc(100vh - 56px) !important;
    }

    .overlay:after {
        Top: 0;
        Left: 0;
    }
}
/* -------Latest articles fix for IE ------*/
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    .no-object-fit .news-article img {
        max-height: 280px;
    }

    .arrow svg {
        opacity: 1 !important
    }
}
/* Mission fix for IE ----*/
.min-100 {
    min-height: 100% !important;
}
/* Table fix for IE ----*/
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    .platform-table .check {
        top: 50%;
    }
}
/* SearchMobile */
.navbar .searchIconMobile .nav-link {
    padding: unset;
    padding-top: 5px;
}

.navbar .searchIconMobile {
    margin-left: auto;
    width: 34px;
}

@media only screen and (min-width: 991px) {
    .searchIconMobile {
        display: none;
    }
}

@media (min-width: 1400px) {
    .container-fluid {
        max-width: 1350px
    }
}

.text-blue {
    color: #308fad;
}

a.backlink {
    text-align: left !important;
    color: #737373 !important;
    cursor: pointer;
}

    a.backlink:hover {
        color: #308fad !important;
    }

/* Animated Header 2019 */
.two-col-hero .col-md-6 .hero-image {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.two-col-hero .hero-text-col {
    background: #00738A;
    align-items: center;
}

.two-col-hero .row {
    width: 100%
}

.two-col-hero .hero-text-col .hero-heading-box h1 span {
    transition: all 0.3s ease;
    display: block;
    color: #fff;
    font-size: 80px;
}

    .two-col-hero .hero-text-col .hero-heading-box h1 span:last-child {
        display: inline;
    }

        .two-col-hero .hero-text-col .hero-heading-box h1 span:last-child:after {
            content: ".";
            color: #F09006;
            margin-left: .5rem
        }

.btn-outline-white {
    color: #fff;
    background-color: transparent;
    background-image: none;
    border-color: #fff;
}

.two-col-hero .btn-outline-white:hover, .bg-teal .btn-outline-white:hover {
    background-color: #fff;
}


@media only screen and (max-width: 1284px) {
    .two-col-hero .hero-text-col .hero-heading-box h1 span {
        font-size: 55px;
    }
}

@media only screen and (max-width: 1000px) {
    .two-col-hero .hero-text-col .hero-heading-box h1 span {
        font-size: 46px;
    }

    .two-col-hero .hero-text-col .hero-heading-box .btn {
        font-size: 0.9rem;
    }
}

@media only screen and (max-width: 767px) {
    .two-col-hero .hero-text-col .hero-heading-box h1 span {
        font-size: 55px;
    }

    .two-col-hero .hero-text-col .hero-heading-box .btn {
        font-size: 1.25rem;
        white-space: normal;
    }
}

@media only screen and (max-width: 468px) {
    .two-col-hero .hero-text-col .hero-heading-box h1 span {
        font-size: 40px;
    }
}

@media only screen and (max-width: 360px) {
    .two-col-hero .hero-text-col .hero-heading-box h1 span {
        font-size: 35px;
    }
}

.jx-knightlab {
    display: none !important;
}

.form-complete-text {
    margin-top: 75px;
}

    .form-complete-text h3 {
        padding-bottom: 2rem;
    }

.cta-panel {
    overflow: hidden;
    position: relative;
}

    .cta-panel .bg-shape {
        opacity: 0.05;
        position: absolute;
        pointer-events: none;
        width: min(458px, 60vw);
    }

        .cta-panel .bg-shape[data-position="left"] {
            left: 0;
            top: 0;
            transform: translateX(-50%);
        }

        .cta-panel .bg-shape[data-position="right"] {
            right: 0;
            bottom: 0;
            transform: translate(17%, 28%);
        }

    .cta-panel .cta-title {
        font-size: clamp(1.88rem, calc(1.15rem + 3.08vw), 3.13rem);
    }

    .cta-panel .cta-copy {
        max-inline-size: 800px;
    }

.flow > * {
    margin: 0 !important
}

    .flow > * + * {
        margin-top: 2rem !important
    }

.cta-panel .cta-title {
    margin-bottom: -0.2em !important;
    text-wrap: balance
}

.cta-panel .cta-description, .lead {
    max-inline-size: 60ch;
}

.stat-panel .stat {
    display: flex;
    justify-content: center;
    text-align: center;
    flex-direction: column;
    align-items: center;
}

    .stat-panel .stat sup {
        top: -0.6em;
        font-size: 60%;
    }

    .stat-panel .stat .stat-number :is(sup, span) {
        color: #F09006
    }

    .stat-panel .stat .stat-copy {
        color: #737373;
        text-wrap: balance;
        max-inline-size: 257px;
        word-break: break-word;
        hyphens: auto;
        margin-top: .25rem;
    }

    .stat-panel .stat img {
        width: 80px;
        height: 80px;
        object-fit: contain;
        margin-bottom: .5rem;
    }

.video-container {
    position: relative;
}

    .video-container iframe, .video-container a[data-youtube], .video-container a :is(picture, img) {
        aspect-ratio: 16/9;
        width: 100%;
        display: flex;
    }

    .video-container iframe {
        position: relative;
        z-index: 3;
    }

    .video-container .play {
        position: absolute;
        width: 100%;
        top: 0;
        left: 0;
        aspect-ratio: 16/9;
        pointer-events: none;
        z-index: 2;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .video-container a[data-youtube] img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .video-container a[data-youtube]::after {
        content: "";
        position: absolute;
        inset: 0
    }

    .video-container .video-title {
        transition: color 0.3s ease
    }

.video-item {
    background: rgba(0,0,0,1)
}

    .video-item img {
        opacity: 0.8
    }

.video-container .play {
    color: #fff;
}

    .video-container .play svg {
        width: min(95px, 20vw);
    }

        .video-container .play svg * {
            transition: all 0.3s ease
        }

.video-container:hover .play {
    color: #f0c52b
}

.associates-panel {
    display: flex;
    gap: 1.5rem 3rem;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

    .associates-panel img {
        max-height: 100px;
        max-width: 230px;
        object-fit: contain;
        mix-blend-mode: multiply;
    }

.quote-box:not([data-variant="minimal"] ) {
    aspect-ratio: 8/5;
    display: grid;
    grid-template-areas: "stack";
}

.quote-box > * {
    grid-area: stack;
}

.quote-box .quote-img {
    position: relative;
}

    .quote-box .quote-img :is(picture, img) {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .quote-box .quote-img::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(to bottom, hsl(0deg 0% 0% / .1), hsl(0deg 0% 0% / .7));
    }

.quote-box .quote-text {
    z-index: 2;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    text-align: center;
    padding: 2rem;
}

    .quote-box .quote-text blockquote {
        max-inline-size: 650px;
        margin: 0
    }

        .quote-box .quote-text blockquote > * {
            margin: 0
        }

            .quote-box .quote-text blockquote > * + * {
                margin-top: 2rem
            }

        .quote-box .quote-text blockquote p {
            font-size: clamp(1.44rem, calc(1.18rem + 1.08vw), 1.88rem);
        }

            .quote-box .quote-text blockquote p::before {
                content: "\201C"
            }

            .quote-box .quote-text blockquote p::after {
                content: "\201D";
            }

        .quote-box .quote-text blockquote footer {
            box-shadow: none;
            display: flex;
            flex-direction: column;
        }

@media (max-width: 767px) {
    .quote-box {
        width: 100vw;
        position: relative;
        left: 50%;
        margin-left: -50vw;
    }

        .quote-box .quote-text blockquote {
            margin-top: 8rem;
        }

        .quote-box .quote-img::after {
            background: hsl(0deg 0% 0% / .5);
        }
}
