/*! tailwindcss v4.1.4 | MIT License | https://tailwindcss.com */
@layer properties {
    @supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))) {

        *,
        :before,
        :after,
        ::backdrop {
            --tw-border-style: solid
        }
    }
}

@layer theme {
    :root {
        --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
        --color-black: #0a0a0a;
        --color-white: #fff;
        --spacing: 1rem;
        --font-weight-normal: 400;
        --font-weight-bold: 700;
        --default-font-family: var(--font-sans)
    }
}

@layer base {

    *,
    :after,
    :before,
    ::backdrop {
        box-sizing: border-box;
        border: 0 solid;
        margin: 0;
        padding: 0
    }

    ::file-selector-button {
        box-sizing: border-box;
        border: 0 solid;
        margin: 0;
        padding: 0
    }

    html {
        -webkit-text-size-adjust: 100%;
        -moz-tab-size: 4;
        -o-tab-size: 4;
        tab-size: 4;
        line-height: 1.5;
        font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
        font-feature-settings: var(--default-font-feature-settings, normal);
        font-variation-settings: var(--default-font-variation-settings, normal);
        -webkit-tap-highlight-color: transparent
    }

    h1,
    h2 {
        font-size: inherit;
        font-weight: inherit
    }

    a {
        color: inherit;
        -webkit-text-decoration: inherit;
        text-decoration: inherit
    }

    strong {
        font-weight: bolder
    }

    ul {
        list-style: none
    }

    img {
        vertical-align: middle;
        display: block
    }

    img {
        max-width: 100%;
        height: auto
    }

    button {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        opacity: 1;
        background-color: #0000;
        border-radius: 0
    }

    ::file-selector-button {
        font: inherit;
        font-feature-settings: inherit;
        font-variation-settings: inherit;
        letter-spacing: inherit;
        color: inherit;
        opacity: 1;
        background-color: #0000;
        border-radius: 0
    }

    ::file-selector-button {
        margin-inline-end: 4px
    }

    ::-moz-placeholder {
        opacity: 1
    }

    ::placeholder {
        opacity: 1
    }

    @supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px) {
        ::-moz-placeholder {
            color: currentColor
        }

        ::placeholder {
            color: currentColor
        }

        @supports (color:color-mix(in lab, red, red)) {
            ::-moz-placeholder {
                color: color-mix(in oklab, currentcolor 50%, transparent)
            }

            ::placeholder {
                color: color-mix(in oklab, currentcolor 50%, transparent)
            }
        }
    }

    ::-webkit-search-decoration {
        -webkit-appearance: none
    }

    ::-webkit-date-and-time-value {
        min-height: 1lh;
        text-align: inherit
    }

    ::-webkit-datetime-edit {
        display: inline-flex
    }

    ::-webkit-datetime-edit-fields-wrapper {
        padding: 0
    }

    ::-webkit-datetime-edit {
        padding-block: 0
    }

    ::-webkit-datetime-edit-year-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-month-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-day-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-hour-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-minute-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-second-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-millisecond-field {
        padding-block: 0
    }

    ::-webkit-datetime-edit-meridiem-field {
        padding-block: 0
    }

    button {
        -webkit-appearance: button;
        -moz-appearance: button;
        appearance: button
    }

    ::file-selector-button {
        -webkit-appearance: button;
        -moz-appearance: button;
        appearance: button
    }

    ::-webkit-inner-spin-button {
        height: auto
    }

    ::-webkit-outer-spin-button {
        height: auto
    }

    @mixin default-font {
        font-family: Arial, Helvetica, sans-serif;
    }

    html {
        -webkit-text-size-adjust: none;
        -webkit-font-smoothing: subpixel-antialiased;
        -webkit-font-smoothing: antialiased;
        scroll-behavior: smooth;
        scroll-padding-top: 10.24rem;
        font-size: 62.5%;
        overflow-x: hidden !important
    }

    @include on_min_tablet {
        scroll-padding-top: 11.6rem;
    }

    @include on_min_md_desktop {
        scroll-padding-top: 11.8rem;
    }

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

    body {
        box-sizing: border-box;
        margin: 0;
        font-family: Arial, Helvetica, sans-serif;
        font-size: 1.6rem;
        color: #0A0A0A;
    }

    ::-moz-selection {
        color: #fff;
        background: #000
    }

    ::selection {
        color: #fff;
        background: #000
    }

    ::-webkit-selection {
        color: #fff;
        background: #000
    }

    h1,
    h2,
    p {
        margin: 0
    }

    button {
        color: inherit;
        vertical-align: middle;
        text-align: center;
        text-transform: none;
        font: inherit;
        cursor: pointer;
        -webkit-user-select: none;
        -moz-user-select: none;
        user-select: none;
        background: 0 0;
        border: 0;
        outline: 0;
        margin: 0;
        padding: 0;
        line-height: normal;
        text-decoration: none;
        display: inline-block;
        overflow: visible
    }

    button {
        display: flex
    }

    @mixin clearfix {
        :scope::after {
            content: "";
            display: table;
            clear: both;
        }
    }

    @mixin no-list-list {
        list-style: none;
        margin: 0;
        padding: 0;
    }

    @mixin img-background {
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center;
    }

    .hamburger {
        transition: $basic-transition;
        z-index: 999;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: .5rem;
        width: 5rem;
        height: 5rem;
        display: flex;
        position: relative
    }

    -bar.hamburger {
        width: 3rem;
        height: .3rem;
        transition: $basic-transition;
        border-radius: .1rem;
        margin: 0 auto;
        display: block;
        position: absolute
    }

    -bar.hamburger:first-of-type {
        top: 50%;
        transform: translateY(calc(-50% - .8rem))
    }

    -bar.hamburger:nth-of-type(3) {
        top: 50%;
        transform: translateY(calc(.8rem - 50%))
    }
}

@layer components;

@layer utilities {
    .mx-auto {
        margin-inline: auto
    }

    .my-1 {
        margin-block: calc(var(--spacing)*1)
    }

    .mb-\[1\.6rem\] {
        margin-bottom: 1.6rem
    }

    .ml-\[2rem\] {
        margin-left: 2rem
    }

    .flex {
        display: flex
    }

    .hidden {
        display: none
    }

    .h-\[8rem\] {
        height: 8rem
    }

    .h-\[12\.3rem\] {
        height: 12.3rem
    }

    .h-auto {
        height: auto
    }

    .h-full {
        height: 100%
    }

    .w-\[16rem\] {
        width: 16rem
    }

    .w-\[17rem\] {
        width: 17rem
    }

    .w-\[20rem\] {
        width: 20rem
    }

    .w-full {
        width: 100%
    }

    .max-w-\[1024px\] {
        max-width: 1024px
    }

    .max-w-\[1220px\] {
        max-width: 1220px
    }

    .shrink-0 {
        flex-shrink: 0
    }

    .list-outside {
        list-style-position: outside
    }

    .list-disc {
        list-style-type: disc
    }

    .flex-col {
        flex-direction: column
    }

    .items-center {
        align-items: center
    }

    .items-start {
        align-items: flex-start
    }

    .justify-between {
        justify-content: space-between
    }

    .justify-end {
        justify-content: flex-end
    }

    .gap-1 {
        gap: calc(var(--spacing)*1)
    }

    .gap-\[1\.6rem\] {
        gap: 1.6rem
    }

    .gap-\[3\.2rem\] {
        gap: 3.2rem
    }

    .border-b-\[0\.6rem\] {
        border-bottom-style: var(--tw-border-style);
        border-bottom-width: .6rem
    }

    .border-b-\[2px\] {
        border-bottom-style: var(--tw-border-style);
        border-bottom-width: 2px
    }

    .border-b-\[\#b7b7b8\] {
        border-bottom-color: #018ef7
    }

    .bg-\[\#000066\] {
        background-color: #1662b1
    }

    .bg-\[\#F1F2F2\] {
        background-color: #f1f2f2
    }

    .bg-white {
        background-color: var(--color-white)
    }

    .object-cover {
        -o-object-fit: cover;
        object-fit: cover
    }

    .p-2 {
        padding: calc(var(--spacing)*2)
    }

    .px-1 {
        padding-inline: calc(var(--spacing)*1)
    }

    .px-3 {
        padding-inline: calc(var(--spacing)*3)
    }

    .py-4 {
        padding-block: calc(var(--spacing)*4)
    }

    .py-\[1\.5rem\] {
        padding-block: 1.5rem
    }

    .py-\[10rem\] {
        padding-block: 10rem
    }

    .paragraph {
        font-family: Arial, Helvetica, sans-serif;
        font-size: 2rem;
        line-height: normal
    }

    .text-\[1\.8rem\] {
        font-size: 1.8rem
    }

    .text-\[2rem\] {
        font-size: 2rem
    }

    .text-\[28\.8px\] {
        font-size: 28.8px
    }

    .leading-\[1\.6\] {
        line-height: 1.6
    }

    .lh-normal {
        line-height: normal
    }

    .font-bold {
        font-weight: var(--font-weight-bold)
    }

    .font-normal {
        font-weight: var(--font-weight-normal)
    }

    .text-\[\#000066\] {
        color: #1662b1
    }

    .text-\[\#b7b7b8\] {
        color: #b7b7b8
    }

    .text-black {
        color: var(--color-black)
    }

    .text-white {
        color: var(--color-white)
    }

    .uppercase {
        text-transform: uppercase
    }

    @media (hover:hover) {
        .hover\:underline:hover {
            text-decoration-line: underline
        }
    }

    @media (min-width:48rem) {
        .md\:h-auto {
            height: auto
        }

        .md\:flex-row {
            flex-direction: row;
            justify-content: space-between
        }
    }

    @media (min-width:64rem) {
        .lg\:block {
            display: block
        }

        .lg\:hidden {
            display: none
        }

        .lg\:h-auto {
            height: auto
        }

        .lg\:w-\[21\.5rem\] {
            width: 21.5rem
        }

        .lg\:justify-start {
            justify-content: flex-start
        }

        .lg\:gap-4 {
            gap: calc(var(--spacing)*4)
        }

        .lg\:py-\[4\.8rem\] {
            padding-block: 4.8rem
        }

        .lg\:pl-\[3\.2rem\] {
            padding-left: 3.2rem
        }

        .lg\:text-\[4\.8rem\] {
            font-size: 4.8rem
        }

        .lg\:px-0 {
            padding-left: 0;
            padding-right: 0;
        }
    }
}

.drawer-overlay {
    z-index: 40;
    background: #0006;
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0
}

.drawer {
    z-index: 50;
    color: #fff;
    background-color: #1662b1;
    width: 300px;
    height: 100%;
    padding: 1rem;
    transition: right .3s ease-in-out;
    position: fixed;
    top: 0;
    right: -300px;
    overflow: auto;
}

.drawer-header {
    justify-content: flex-end;
    align-items: center;
    font-weight: 700;
    display: none;
}

.drawer.open {
    right: 0;
    box-shadow: 0 0 35px #000000bf
}

.drawer.open .drawer-header {
    display: flex;
}

.drawer ul {
    display: none;
}

.drawer.open ul {
    display: block;
}

.link-tag {
    color: #43494f;
    text-decoration: none;
    position: relative
}

.mobile-menu .link-tag {
    color: #C5C5C5;
}

.link-tag:after {
    content: "";
    background-color: #1662b1;
    width: 0;
    height: 2px;
    transition: width .3s;
    position: absolute;
    bottom: -8px;
    left: 0
}

.link-tag:hover:after {
    width: 100%
}

.link-tag:hover {
    color: #1662b1;
}




.split-footer-socials {
    align-items: center;
    display: flex
}

.split-footer-socials .split-footer-social-list-item a {
    text-align: center;
    color: #018ef7;
    border-radius: 4.8rem;
    width: 40px;
    margin: 8px;
    padding: 4px;
    display: inline-block
}

.split-footer-socials .split-footer-social-list-item a:hover {
    color: #999
}

.split-footer-socials .split-footer-social-list-item a i {
    padding: 2px;
    font-size: 27.2px
}

@property --tw-rotate-x {
    syntax: "*";
    inherits: false
}

@property --tw-rotate-y {
    syntax: "*";
    inherits: false
}

@property --tw-rotate-z {
    syntax: "*";
    inherits: false
}

@property --tw-skew-x {
    syntax: "*";
    inherits: false
}

@property --tw-skew-y {
    syntax: "*";
    inherits: false
}

@property --tw-border-style {
    syntax: "*";
    inherits: false;
    initial-value: solid
}

@property --tw-leading {
    syntax: "*";
    inherits: false
}

@property --tw-font-weight {
    syntax: "*";
    inherits: false
}

@property --tw-tracking {
    syntax: "*";
    inherits: false
}

@property --tw-duration {
    syntax: "*";
    inherits: false
}

@property --tw-ease {
    syntax: "*";
    inherits: false
}


.open-jobs {
    padding: 48px 0;
    background-color: #1662b1;
}

.open-jobs h2 {
    font-size: 28.8px;
    line-height: normal;
    color: white;
    font-weight: bold;
    text-align: center;
    font-family: Arial,
        Helvetica,
        sans-serif;
}


.link-tag.active {
    color: #1662b1;
}

.link-tag.active::after {
    width: 100%;
    background-color: #1662b1;
}


.mobile-menu .link-tag.active {
    color: white;
}

.mobile-menu .link-tag.active::after {
    background-color: white;
}

.mobile-menu .link-tag:hover {
    color: white;
}

.mobile-menu .link-tag:hover::after {
    background-color: white;
}

.split-footer-social-link {
    color: #018ef7;
}

.custom-shadow {
    box-shadow: 0px 1px 12px -4px black;
    position: relative;
    z-index: 2;
}

.text-shadow {
    text-shadow: 1px 1px rgba(0, 0, 0, 0.4);
    font-weight: normal;
    color: #fff;
}


.page-template__inner p,
.page-template__inner ol li {
    font-size: 2rem;
    line-height: normal;
    margin-bottom: 16px;
}

.page-template__inner h2 {
    font-size: 28.8px;
    font-weight: 700;
}

.page-template__inner ol {
    margin-left: 20px;
    list-style-position: outside;
}

.results-list__item-street--icon {
    display: flexs;
}

.page-template__inner a {
    color: #2199e8;
}

.page-template__inner a:hover {
    color: #1585cf;
}

.react-select_jobs-sort-by_item__single-value {
    min-width: 100px;
}

.summary-list-item:has(.summary-value:empty) {
    display: none;
}

.action-hero {
    min-height: 350px
}


.text-white {
    color: #ffffff;
}

.constrained {
    padding: 2rem;
    max-width: 1220px;
    margin: 0 auto;
}

@media (min-width: 768px) {

    .action-hero .content.constrained {
        padding-top: 7.2rem;
        padding-bottom: 4.5rem;
        text-align: left;
    }
}


body.template h1 {
    font-size: 2.88rem;
    font-weight: bold;
    font-family: Arial, Helvetica, sans-serif;
    text-align: center;
    color: white;
}

#openDrawer {
    color: #1662b1;
}


.split-footer-recruiting-message {
    color: #545a5f;
    font-size: 2rem;
    line-height: normal;
}

.split-footer-recruiting-message a {
    text-decoration: underline;
}

.intro-section {
    padding: 2rem;
    max-width: 1220px;
    margin: 0 auto;
}

.intro-section p {
    font-size: 20px;
    color: #3E4953;
    font-family: Arial,
        Helvetica,
        sans-serif;

    margin-bottom: 24px;

    text-align: center;
    line-height: normal;
    max-width: 960px;
    margin-right: auto;
    margin-left: auto;
}

@media (min-width: 768px) {
    body.template h1 {
        font-size: 4.8rem;
    }

    .intro-section {
        padding: 7.2rem 2rem;
    }

    .intro-section p {
        text-align: left;
    }
}

h2.sub-header {
    padding-top: 20px;
    font-size: 28.8px;
    line-height: normal;
    font-weight: bold;
    text-align: center;
}

@media (min-width: 768px) {

    h2.sub-header,
    body.template h1 {
        text-align: left;
    }
}

@media (min-width: 768px) {
  section.hero {
    min-height: 750px;
  }
}

a:focus-visible,
button:focus-visible,
select:focus-visible {
    outline: 2px solid blue;
}