/* Public site header, navigation, and dropdown composition. */
:root {
    --site-nav-height: clamp(74px, 4.25vw, 132px);
    --site-nav-brand-size: clamp(1.18rem, 0.92vw, 1.75rem);
    --site-nav-link-size: clamp(1rem, 0.78vw, 1.38rem);
    --site-nav-link-padding: clamp(0.82rem, 1.15vw, 2rem);
    --site-logo-max-width: clamp(240px, 15vw, 440px);
    --site-logo-max-height: clamp(52px, 3.4vw, 104px);
    --site-logo-rail-padding: clamp(1.75rem, 2.2vw, 3.6rem);
    --site-logo-rail-width: calc(min(34vw, var(--site-logo-max-width)) + var(--site-logo-rail-padding));
    --site-theme-toggle-width: clamp(106px, 6.8vw, 176px);
    --public-nav-panel-bg: color-mix(in srgb, var(--surface), var(--blue) 7%);
    --public-nav-panel-hover: color-mix(in srgb, var(--surface), var(--blue) 11%);
    --public-nav-panel-border: color-mix(in srgb, var(--blue), transparent 76%);
    --public-nav-panel-active-border: #5d37d9;
    --public-nav-active-link-border-width: 4px;
    --public-nav-panel-link: #202124;
    --cms-z-public-mobile-nav: 220;
}

:root[data-site-theme="dark"] {
    --public-nav-panel-bg: #252529;
    --public-nav-panel-hover: #34343a;
    --public-nav-panel-border: #3a3a41;
    --public-nav-panel-active-border: #9b7cff;
    --public-nav-active-link-border-width: 4px;
    --public-nav-panel-link: #f4f2ec;
}

.public-header {
    position: sticky;
    top: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid rgba(16, 19, 24, 0.1);
    background: rgba(251, 252, 247, 0.92);
    padding: clamp(0.95rem, 1vw, 1.45rem) var(--site-edge-gap);
    backdrop-filter: blur(14px);
}

.cms-site-public-header {
    min-height: var(--site-nav-height);
    border-top: 1px solid rgba(16, 19, 24, 0.1);
    border-bottom: 1px solid rgba(16, 19, 24, 0.16);
    background: rgba(251, 252, 247, 0.96);
    padding-block: 0;
    padding-right: 0;
}

.public-brand-shell {
    position: relative;
    display: inline-flex;
    align-items: stretch;
    flex: 0 0 var(--site-logo-rail-width);
    width: var(--site-logo-rail-width);
    min-width: var(--site-logo-rail-width);
}

.cms-site-public-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    box-sizing: border-box;
    flex: 1 1 auto;
    width: 100%;
    min-width: 0;
    min-height: var(--site-nav-height);
    padding-right: var(--site-logo-rail-padding);
    border-right: 1px solid rgba(16, 19, 24, 0.16);
    font-size: var(--site-nav-brand-size);
}

.site-logo-image,
.cms-responsive-picture.site-logo-image > img {
    display: block;
    width: auto;
    max-width: var(--site-logo-max-width);
    max-height: var(--site-logo-max-height);
    object-fit: contain;
}

.cms-site-public-brand span {
    color: var(--blue);
}

.public-header-actions {
    display: flex;
    align-items: stretch;
    justify-content: flex-end;
    gap: 0;
    min-width: 0;
    flex: 1;
}

.public-mobile-nav-toggle {
    display: none !important;
    align-self: stretch;
    min-width: var(--site-nav-height);
    min-height: var(--site-nav-height);
    margin: 0 !important;
    border: 1px solid transparent;
    border-radius: 0;
    background: transparent;
    color: var(--ink);
    transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.cms-site-public-nav {
    display: flex;
    flex: 0 1 auto;
    flex-wrap: nowrap;
    gap: 0;
}

.public-utility-nav {
    display: flex;
    align-items: center;
    align-self: stretch;
    gap: 0;
}

.public-utility-nav-mobile {
    display: none;
}

.public-utility-nav > a {
    display: inline-flex;
    align-items: center;
    min-height: var(--site-nav-height);
    padding: 0 clamp(0.68rem, 0.78vw, 1.1rem);
    border-left: 1px solid transparent;
    border-right: 1px solid transparent;
    color: color-mix(in srgb, var(--ink), var(--blue) 28%);
    font-size: clamp(0.82rem, 0.58vw, 1rem);
    font-weight: 700;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0;
    white-space: nowrap;
    transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.public-utility-nav > a:hover,
.public-utility-nav > a:focus-visible,
.public-utility-nav > a.is-active {
    border-color: rgba(16, 19, 24, 0.16);
    background: color-mix(in srgb, var(--surface), var(--blue) 5%);
    color: var(--blue);
}

.cms-site-public-nav > * + * {
    margin-left: -1px;
}

.cms-site-public-nav > a,
.public-nav-trigger,
.public-nav-item > button {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    min-height: var(--site-nav-height);
    border: 0;
    border-left: 1px solid transparent;
    border-right: 1px solid transparent;
    background: transparent;
    color: var(--ink);
    padding: 0 var(--site-nav-link-padding);
    font-size: var(--site-nav-link-size);
    font-weight: 650;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.cms-site-public-nav > a:hover,
.cms-site-public-nav > a.is-active,
.public-nav-item.is-open > .public-nav-trigger,
.public-nav-trigger:focus-visible,
.public-nav-item:hover > button,
.public-nav-item > button:focus-visible,
.public-mobile-nav-toggle.is-open,
.public-mobile-nav-toggle:hover,
.public-mobile-nav-toggle:focus-visible,
.public-theme-toggle:hover,
.public-theme-toggle:focus-visible {
    border-color: rgba(16, 19, 24, 0.16);
    background: color-mix(in srgb, var(--surface), var(--blue) 7%);
    color: var(--blue);
}

.public-nav-item.has-children.is-open > .public-nav-trigger,
.public-nav-item.has-children.is-active > .public-nav-trigger,
.public-nav-item.has-children > .public-nav-trigger:hover,
.public-nav-item.has-children > .public-nav-trigger:focus-visible {
    border-color: rgba(16, 19, 24, 0.16);
    background: var(--public-nav-panel-bg);
    color: var(--ink);
    text-decoration: none;
}

.public-nav-item.has-children.is-open > .public-nav-trigger,
.public-nav-item.has-children.is-active > .public-nav-trigger {
    box-shadow: inset 0 calc(var(--public-nav-active-link-border-width) * -1) 0 var(--public-nav-panel-active-border);
}

.public-header :is(.public-nav-trigger, .public-theme-toggle, .public-mobile-nav-toggle):hover,
.public-header :is(.public-nav-trigger, .public-theme-toggle, .public-mobile-nav-toggle):focus-visible,
.public-header :is(.public-nav-trigger, .public-theme-toggle, .public-mobile-nav-toggle):active {
    transform: none;
}

.public-theme-toggle {
    align-self: stretch;
    flex: 0 0 var(--site-theme-toggle-width);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: auto;
    min-width: var(--site-theme-toggle-width);
    min-height: var(--site-nav-height);
    margin: 0 !important;
    margin-left: -1px !important;
    border: 1px solid transparent;
    border-radius: 0;
    background: transparent;
    color: var(--ink);
}

.public-header-actions > .mud-tooltip-root:has(.public-theme-toggle) {
    display: flex;
    flex: 0 0 var(--site-theme-toggle-width);
    align-self: stretch;
    min-width: var(--site-theme-toggle-width);
    margin: 0;
    padding: 0;
}

.public-header-actions > .mud-tooltip-root:has(.public-theme-toggle) .public-theme-toggle {
    width: 100%;
    height: 100%;
}

:root[data-site-theme="light"] .public-theme-toggle {
    color: #101318 !important;
}

:root[data-site-theme="light"] .public-theme-toggle:hover,
:root[data-site-theme="light"] .public-theme-toggle:focus-visible,
:root[data-site-theme="light"] .public-mobile-nav-toggle.is-open,
:root[data-site-theme="light"] .public-mobile-nav-toggle:hover,
:root[data-site-theme="light"] .public-mobile-nav-toggle:focus-visible,
:root[data-site-theme="light"] .public-utility-nav > a:hover,
:root[data-site-theme="light"] .public-utility-nav > a:focus-visible,
:root[data-site-theme="light"] .public-utility-nav > a.is-active {
    border-color: rgba(16, 19, 24, 0.2) !important;
    background: color-mix(in srgb, #ffffff, var(--blue) 9%) !important;
    color: #032b92 !important;
}

:root[data-site-theme="light"] .public-theme-toggle:hover .theme-mode-toggle-track,
:root[data-site-theme="light"] .public-theme-toggle:focus-visible .theme-mode-toggle-track {
    background: color-mix(in srgb, #ffffff, var(--blue) 15%) !important;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--blue), transparent 35%);
}

:root[data-site-theme="light"] .public-theme-toggle:hover .theme-mode-toggle-thumb,
:root[data-site-theme="light"] .public-theme-toggle:focus-visible .theme-mode-toggle-thumb {
    background: #ffffff;
    box-shadow: 0 7px 20px rgba(3, 43, 146, 0.22);
}

:root[data-site-theme="dark"] .public-theme-toggle {
    border-color: transparent;
    background: transparent;
    color: var(--ink) !important;
}

:root[data-site-theme="dark"] .cms-site-public-nav > a:hover,
:root[data-site-theme="dark"] .cms-site-public-nav > a.is-active,
:root[data-site-theme="dark"] .public-nav-item.is-open > .public-nav-trigger,
:root[data-site-theme="dark"] .public-nav-trigger:focus-visible,
:root[data-site-theme="dark"] .public-nav-item:hover > button,
:root[data-site-theme="dark"] .public-nav-item > button:focus-visible,
:root[data-site-theme="dark"] .public-theme-toggle:hover,
:root[data-site-theme="dark"] .public-theme-toggle:focus-visible,
:root[data-site-theme="dark"] .public-mobile-nav-toggle.is-open,
:root[data-site-theme="dark"] .public-mobile-nav-toggle:hover,
:root[data-site-theme="dark"] .public-mobile-nav-toggle:focus-visible {
    border-color: rgba(255, 255, 255, 0.18);
    background: color-mix(in srgb, var(--surface-elevated), var(--blue) 10%);
    color: var(--blue) !important;
}

:root[data-site-theme="dark"] .public-nav-item.has-children.is-open > .public-nav-trigger,
:root[data-site-theme="dark"] .public-nav-item.has-children.is-active > .public-nav-trigger,
:root[data-site-theme="dark"] .public-nav-item.has-children > .public-nav-trigger:hover,
:root[data-site-theme="dark"] .public-nav-item.has-children > .public-nav-trigger:focus-visible {
    border-color: rgba(255, 255, 255, 0.18);
    background: var(--public-nav-panel-bg);
    color: var(--public-nav-panel-link) !important;
    text-decoration: none;
}

:root[data-site-theme="dark"] .public-nav-item.has-children.is-open > .public-nav-trigger,
:root[data-site-theme="dark"] .public-nav-item.has-children.is-active > .public-nav-trigger {
    box-shadow: inset 0 calc(var(--public-nav-active-link-border-width) * -1) 0 var(--public-nav-panel-active-border);
}

:root[data-site-theme="dark"] .public-nav-dropdown {
    background: color-mix(in srgb, #29292b, transparent 12%);
}

:root[data-site-theme="dark"] .public-nav-dropdown::before {
    box-shadow: 0 34px 76px rgba(0, 0, 0, 0.34);
}

:root[data-site-theme="dark"] .public-nav-dropdown > a:hover,
:root[data-site-theme="dark"] .public-nav-dropdown > a:focus-visible {
    background: transparent;
    color: var(--public-nav-panel-link);
}

.public-theme-toggle.theme-mode-toggle {
    border-radius: 0;
    border-color: transparent;
    background: transparent;
    padding: 0 clamp(0.55rem, 0.9vw, 1rem);
}

:root[data-site-theme="dark"] .public-theme-toggle .theme-mode-toggle-track {
    background: #202023;
}

.public-nav-item {
    position: relative;
}

.public-nav-item.has-children {
    display: inline-flex;
    align-items: stretch;
}

.public-nav-trigger .mud-icon-root {
    color: currentColor;
    transition: transform 0.18s ease;
}

.public-nav-trigger-label-input {
    width: min(10rem, 26vw);
    min-width: 5rem;
    border: 1px solid transparent;
    border-radius: 4px;
    background: color-mix(in srgb, var(--public-nav-panel-bg), transparent 22%);
    color: inherit;
    font: inherit;
    font-weight: 650;
    line-height: 1.1;
    padding: 0.22rem 0.35rem;
}

.public-nav-trigger-label-input:hover,
.public-nav-trigger-label-input:focus {
    border-color: color-mix(in srgb, var(--public-nav-panel-active-border), transparent 35%);
    background: color-mix(in srgb, var(--public-nav-panel-bg), #ffffff 10%);
    outline: none;
}

.public-nav-item.is-open > .public-nav-trigger .mud-icon-root {
    transform: rotate(180deg);
}

.public-nav-dropdown {
    --public-nav-panel-left: calc(var(--site-edge-gap) + var(--site-logo-rail-width));
    --public-nav-panel-height: clamp(300px, 32vh, 430px);
    --public-nav-panel-inner-gap: clamp(2rem, 4vw, 4.5rem);
    --public-nav-panel-vertical-padding: clamp(1rem, 2.2vw, 1.5rem);
    --public-nav-panel-content-height: calc(var(--public-nav-panel-height) - (var(--public-nav-panel-vertical-padding) * 2));
    --public-nav-panel-content-width: calc(100vw - var(--public-nav-panel-left) - var(--public-nav-panel-inner-gap) - var(--site-edge-gap));
    position: fixed;
    inset: var(--site-nav-height) 0 0 0;
    z-index: 90;
    display: grid;
    width: auto;
    max-width: none;
    min-height: calc(100dvh - var(--site-nav-height));
    height: calc(100dvh - var(--site-nav-height));
    grid-template-columns: repeat(3, minmax(12rem, 1fr));
    align-content: start;
    align-items: start;
    column-gap: clamp(1.5rem, 4vw, 4rem);
    row-gap: 0.9rem;
    border-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    background: transparent;
    box-shadow: 0 26px 65px rgba(16, 19, 24, 0.22);
    overflow-y: auto;
    padding: var(--public-nav-panel-vertical-padding) var(--site-edge-gap);
    padding-left: max(var(--site-edge-gap), calc(var(--public-nav-panel-left) + var(--public-nav-panel-inner-gap)));
    isolation: isolate;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    clip-path: inset(0 0 100% 0);
    transform: translateY(-18px);
    transform-origin: top center;
    transition:
        clip-path 0.34s cubic-bezier(0.2, 0.8, 0.2, 1),
        opacity 0.22s ease,
        transform 0.34s cubic-bezier(0.2, 0.8, 0.2, 1),
        visibility 0s linear 0.34s;
}

.public-nav-dropdown-glass {
    position: absolute;
    inset: 1px 0 0 0;
    z-index: 0;
    background: color-mix(in srgb, var(--site-canvas), transparent 12%);
    backdrop-filter: blur(96px) saturate(0.82) contrast(0.74);
    -webkit-backdrop-filter: blur(96px) saturate(0.82) contrast(0.74);
    pointer-events: none;
}

.public-nav-dropdown::before {
    content: "";
    position: absolute;
    inset: 0 0 auto var(--public-nav-panel-left);
    z-index: 1;
    height: var(--public-nav-panel-height);
    border-top: 1px solid var(--public-nav-panel-border);
    border-bottom: 1px solid var(--public-nav-panel-border);
    border-left: 1px solid var(--public-nav-panel-border);
    background: var(--public-nav-panel-bg);
    box-shadow: 0 34px 76px rgba(16, 19, 24, 0.18);
    pointer-events: none;
}

.public-nav-dropdown::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: auto;
    left: var(--public-nav-panel-left);
    z-index: 3;
    width: 1px;
    height: var(--public-nav-panel-height);
    background: var(--public-nav-panel-border);
    box-shadow: -1px 0 0 var(--public-nav-panel-border);
    pointer-events: none;
}

.public-nav-item.is-open > .public-nav-dropdown {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    clip-path: inset(0 0 0 0);
    transform: translateY(0);
    transition-delay: 0s;
}

.public-nav-dropdown > a,
.public-nav-dropdown-link-list > a {
    position: relative;
    z-index: 2;
    display: inline-grid;
    justify-self: start;
    gap: 0.2rem;
    min-height: auto;
    align-content: start;
    border: 0;
    color: var(--public-nav-panel-link);
    padding: 0.45rem 0 0.5rem;
    text-decoration: none;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.32em;
    transition: text-decoration-color 0.16s ease, color 0.16s ease;
}

.public-nav-dropdown-custom {
    position: relative;
    z-index: 2;
    display: grid;
    grid-column: 1 / -1;
    align-self: stretch;
    gap: 0;
    width: calc(var(--public-nav-panel-content-width) + var(--public-nav-panel-inner-gap));
    max-width: none;
    min-height: var(--public-nav-panel-height);
    margin-left: calc(var(--public-nav-panel-inner-gap) * -1);
    margin-top: calc(var(--public-nav-panel-vertical-padding) * -1);
    margin-bottom: calc(var(--public-nav-panel-vertical-padding) * -1);
    overflow: visible;
}

.public-nav-dropdown-link-list {
    display: contents;
}

.public-nav-dropdown-mobile-link {
    display: none !important;
}

.public-nav-dropdown-custom > *,
.public-nav-dropdown-custom :is(.public-section, .public-hero, .public-image-block, .public-card-block, .cms-mud-paper-block, .public-alert-block, .cms-layout-stack, .cms-layout-columns, .cms-layout-column) {
    width: 100% !important;
    max-width: 100% !important;
    margin-inline: 0 !important;
    min-width: 0;
}

.public-nav-dropdown-custom :is(.public-section, .cms-layout-stack, .cms-mud-paper-block, .cms-layout-columns) {
    padding: 0 !important;
}

.public-nav-dropdown-custom .cms-layout-columns {
    min-height: var(--public-nav-panel-height);
    align-items: stretch;
}

.public-nav-dropdown-custom .cms-layout-grid-item > .site-block,
.public-nav-dropdown-custom .site-block-type-column,
.public-nav-dropdown-custom .cms-layout-column {
    align-content: stretch;
    min-height: 100%;
}

.public-nav-dropdown-custom .site-block-type-column:has(> .cms-layout-column.layout-media),
.public-nav-dropdown-custom .cms-layout-column.layout-media[style*="--cms-block-bg-media"] {
    height: 100%;
    min-height: var(--public-nav-panel-content-height);
}

.public-nav-dropdown-custom .public-image-block,
.public-nav-dropdown-custom .public-image-block img,
.public-nav-dropdown-custom .cms-image-placeholder {
    height: 100%;
    max-height: none;
}

.public-nav-dropdown-custom .cms-mud-nav-links {
    display: grid !important;
    grid-auto-flow: row;
    align-items: stretch;
    gap: var(--cms-block-gap, 0.75rem);
    width: 100% !important;
    max-width: 100% !important;
}

.public-nav-dropdown-custom .cms-mud-nav-links a {
    position: relative;
    display: grid;
    width: 100%;
    min-width: 0;
}

.public-nav-dropdown > a:nth-child(3n),
.public-nav-dropdown > a:last-child,
.public-nav-dropdown-link-list > a:nth-child(3n),
.public-nav-dropdown-link-list > a:last-child {
    border-right: 0;
}

.public-nav-dropdown > a:hover,
.public-nav-dropdown > a:focus-visible,
.public-nav-dropdown > a.is-active,
.public-nav-dropdown-link-list > a:hover,
.public-nav-dropdown-link-list > a:focus-visible,
.public-nav-dropdown-link-list > a.is-active,
.public-nav-dropdown-custom .cms-mud-nav-links a:hover,
.public-nav-dropdown-custom .cms-mud-nav-links a:focus-visible,
.public-nav-dropdown-custom .cms-mud-nav-links a.is-active {
    background: transparent;
    color: var(--public-nav-panel-link);
    text-decoration: underline;
}

.public-nav-dropdown > a.is-active,
.public-nav-dropdown-link-list > a.is-active,
.public-nav-dropdown-custom .cms-mud-nav-links a.is-active {
    color: var(--blue);
    text-decoration-color: currentColor;
}

.public-nav-dropdown-link-list > a.is-active::before,
.public-nav-dropdown-custom .cms-mud-nav-links a.is-active::before {
    content: "";
    position: absolute;
    top: 0.45rem;
    bottom: 0.5rem;
    left: -0.7rem;
    width: 3px;
    border-radius: 999px;
    background: var(--public-nav-panel-active-border);
}

.public-nav-dropdown span {
    font-size: clamp(1rem, 1vw, 1.22rem);
    font-weight: 750;
    line-height: 1.2;
}

.public-nav-dropdown small {
    display: none;
    overflow: hidden;
    color: var(--ink-muted);
    font-size: 0.82rem;
    font-weight: 500;
    line-height: 1.3;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.public-nav-dropdown-overview {
    color: var(--ink);
}

@media (prefers-reduced-motion: reduce) {
.public-nav-dropdown {
        transform: none;
        transition: opacity 0.01ms linear, visibility 0s linear;
    }

}

.public-mega-menu {
    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    z-index: 80;
    display: none;
    min-width: 420px;
    max-width: min(960px, calc(100vw - 2rem));
    grid-template-columns: repeat(2, minmax(180px, 1fr));
    border: 1px solid rgba(16, 19, 24, 0.16);
    background: #ffffff;
    box-shadow: 0 18px 50px rgba(16, 19, 24, 0.14);
}

.public-nav-item:hover .public-mega-menu,
.public-nav-item:focus-within .public-mega-menu {
    display: grid;
}

.public-mega-menu.expertise {
    width: min(980px, calc(100vw - 2rem));
    grid-template-columns: repeat(3, minmax(180px, 1fr)) minmax(210px, 0.75fr);
}

.public-nav-item.compact .public-mega-menu {
    right: 0;
    left: auto;
}

.public-mega-menu section,
.public-mega-menu aside {
    display: grid;
    align-content: start;
    gap: 0.45rem;
    min-height: 270px;
    border-right: 1px solid rgba(16, 19, 24, 0.12);
    padding: 1.1rem;
}

.public-mega-menu h3 {
    margin-bottom: 0.35rem;
    color: var(--ink);
    font-size: 0.85rem;
    text-transform: uppercase;
}

.public-mega-menu a {
    border-bottom: 1px solid #edf0f4;
    color: #263241;
    padding: 0.45rem 0;
    font-size: 0.95rem;
    font-weight: 800;
    text-decoration: none;
}

.public-mega-menu a:hover {
    color: var(--blue);
}

.public-mega-menu aside {
    border-right: 0;
    background: #f2f5f9;
}

.public-mega-menu aside strong {
    align-self: end;
    font-size: 1.35rem;
}

.public-mega-menu aside span {
    color: var(--ink-muted);
}

.public-nav-cta {
    margin-left: auto;
    border-left: 1px solid color-mix(in srgb, var(--accent), transparent 45%) !important;
    background: var(--accent) !important;
    color: #ffffff !important;
}

.public-nav-cta:hover {
    background: var(--accent-hover, var(--accent)) !important;
}

.public-brand {
    color: var(--ink);
    font-size: var(--site-nav-brand-size);
    font-weight: 900;
    text-decoration: none;
}

.public-nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
}

.public-nav a {
    font-size: var(--site-nav-link-size);
    font-weight: 650;
    text-decoration: none;
}

@media (prefers-color-scheme: dark) {
.public-header,
.cms-site-public-header {
        border-color: var(--line-strong);
        background: var(--site-header-bg);
        color: var(--ink);
    }

.cms-site-public-brand,
.cms-site-public-nav > a,
.public-nav-item > button,
.public-brand {
        color: var(--ink);
    }

.cms-site-public-nav > a:hover,
.public-nav-item:hover > button,
.public-nav-item:focus-within > button {
        background: var(--surface-elevated);
        color: var(--blue);
    }

.public-mega-menu,
.public-mega-menu aside {
        border-color: var(--line-strong);
        background: var(--surface-alt);
        color: var(--ink);
    }

.cms-site-public-brand span {
        color: var(--blue);
    }

.public-nav-cta {
        background: var(--inverse-surface) !important;
        color: var(--inverse-ink) !important;
    }

}

:root[data-site-theme="light"] .public-header,
:root[data-site-theme="light"] .cms-site-public-header,
:root[data-site-theme="dark"] .public-header,
:root[data-site-theme="dark"] .cms-site-public-header {
    border-color: var(--line-strong);
    background: var(--site-header-bg);
    color: var(--ink);
}

:root[data-site-theme="light"] .cms-site-public-brand,
:root[data-site-theme="dark"] .cms-site-public-brand {
    border-right: 1px solid var(--line-strong);
}

@media (min-width: 1500px) {
.cms-site-public-header,
.cms-site-public-brand,
.cms-site-public-nav > a,
.public-nav-item > button,
.public-theme-toggle {
        min-height: var(--site-nav-height);
    }

.public-header {
        gap: clamp(1.2rem, 1.8vw, 2.8rem);
    }

.public-header-actions {
        gap: 0;
    }

.cms-site-public-nav > a,
.public-nav-item > button,
.public-nav a {
        letter-spacing: 0;
        font-size: max(var(--site-nav-link-size), 1.08rem);
    }

.cms-site-public-brand,
.public-brand {
        font-size: max(var(--site-nav-brand-size), 1.32rem);
    }

}

@media (min-width: 1900px) {
.cms-site-public-nav > a,
.public-nav-item > button,
.public-nav a {
        font-size: max(var(--site-nav-link-size), 1.22rem);
    }

.cms-site-public-brand,
.public-brand {
        font-size: max(var(--site-nav-brand-size), 1.52rem);
    }

}

@media (max-width: 960px) {
:root {
        --site-logo-max-width: clamp(150px, 48vw, 260px);
        --site-logo-max-height: 58px;
        --cms-mobile-public-header-height: 64px;
    }

.public-brand-shell {
        min-width: 0;
    }

.public-header {
        align-items: flex-start;
        flex-direction: column;
    }

.cms-site-public-brand {
        flex-basis: auto;
        min-width: 0;
    }

.cms-site-public-nav {
        flex-wrap: wrap;
        justify-content: flex-start;
    }

.public-header-actions {
        width: 100%;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

.public-theme-toggle {
        align-self: auto;
        width: 70px;
        min-width: 70px;
        min-height: 42px;
        border: 1px solid var(--line-strong);
        border-radius: 999px;
    }

.public-header-actions > .mud-tooltip-root:has(.public-theme-toggle) {
        flex: 0 0 70px;
        align-self: auto;
        min-width: 70px;
    }

.cms-site-public-brand,
.cms-site-public-nav > a,
.public-nav-item > button {
        min-height: 42px;
        border: 0;
        padding-inline: 0;
    }

.public-mega-menu,
.public-mega-menu.expertise {
        position: static;
        width: 100%;
        min-width: 100%;
        grid-template-columns: 1fr;
        box-shadow: none;
    }

.public-mega-menu section,
.public-mega-menu aside {
        min-height: auto;
        border-right: 0;
    }

}

@media (max-width: 640px) {
:root {
        --site-nav-height: 64px;
        --site-logo-max-width: min(64vw, 240px);
        --site-logo-max-height: 48px;
        --site-nav-brand-size: 1.05rem;
        --site-nav-link-size: 0.95rem;
        --site-nav-link-padding: 0.85rem;
    }

.public-brand-shell {
        width: 100%;
        min-width: 0;
        max-width: 100%;
    }

.public-header,
.cms-site-public-header {
        position: sticky;
        display: grid;
        grid-template-columns: 1fr;
        gap: 0.75rem;
        min-height: auto;
        padding: 0.75rem var(--site-edge-gap);
    }

.cms-site-public-brand,
.public-brand {
        width: 100%;
        min-width: 0;
        max-width: 100%;
    }

.cms-site-public-brand,
.public-brand {
        min-height: auto;
        border-right: 0 !important;
        padding: 0;
    }

.site-logo-image {
        max-width: var(--site-logo-max-width);
        max-height: var(--site-logo-max-height);
    }

.public-header-actions {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        width: 100%;
        gap: 0.65rem;
    }

.cms-site-public-nav,
.public-nav {
        display: flex;
        flex-wrap: nowrap;
        justify-content: flex-start;
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        overscroll-behavior-x: contain;
        scrollbar-width: thin;
        -webkit-overflow-scrolling: touch;
    }

.cms-site-public-nav > a,
.public-nav-item > button,
.public-nav a {
        flex: 0 0 auto;
        min-height: 40px;
        border: 1px solid var(--line-strong);
        border-radius: 999px;
        background: var(--site-canvas);
        padding: 0.55rem 0.85rem;
        font-size: var(--site-nav-link-size);
        line-height: 1.1;
        white-space: nowrap;
    }

.public-theme-toggle,
.public-header-actions > .mud-tooltip-root:has(.public-theme-toggle) {
        width: 58px;
        min-width: 58px;
        min-height: 40px;
    }

}

@media (max-width: 420px) {
.public-header,
.cms-site-public-header {
        padding-inline: 0.85rem;
    }

.cms-site-public-nav > a,
.public-nav-item > button,
.public-nav a {
        padding-inline: 0.75rem;
        font-size: 0.9rem;
    }

}

@media (max-width: 960px) {
.public-header,
.cms-site-public-header {
        z-index: var(--cms-z-public-mobile-nav);
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: stretch;
        gap: 0;
        min-height: var(--cms-mobile-public-header-height);
        padding: 0 0 0 var(--site-edge-gap);
    }

.cms-site-public-brand,
.public-brand {
        width: auto;
        min-height: var(--cms-mobile-public-header-height);
        padding-right: 1rem;
        border-right: 0 !important;
    }

.site-logo-image {
        max-width: min(58vw, 250px);
        max-height: 48px;
    }

.public-header-actions {
        display: flex;
        align-items: stretch;
        justify-content: flex-end;
        width: auto;
        min-width: 0;
        gap: 0;
    }

.public-mobile-nav-toggle {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        order: 1;
        width: var(--cms-mobile-public-header-height);
        min-width: var(--cms-mobile-public-header-height);
        min-height: var(--cms-mobile-public-header-height);
        border-left: 1px solid var(--line-strong);
    }

.public-header-actions > .mud-tooltip-root:has(.public-theme-toggle) {
        order: 2;
        display: flex;
        flex: 0 0 var(--cms-mobile-public-header-height);
        align-self: stretch;
        width: var(--cms-mobile-public-header-height);
        min-width: var(--cms-mobile-public-header-height);
    }

.public-theme-toggle {
        align-self: stretch;
        flex: 0 0 var(--cms-mobile-public-header-height);
        width: var(--cms-mobile-public-header-height);
        min-width: var(--cms-mobile-public-header-height);
        height: var(--cms-mobile-public-header-height);
        min-height: var(--cms-mobile-public-header-height);
        border-top: 0;
        border-right: 0;
        border-bottom: 0;
        border-left: 1px solid var(--line-strong);
        border-radius: 0;
    }

.public-theme-toggle .theme-mode-toggle-track {
        width: 52px;
        min-width: 52px;
        height: 30px;
    }

.cms-site-public-nav,
.public-nav {
        position: absolute;
        top: 100%;
        right: 0;
        left: 0;
        bottom: auto;
        z-index: var(--cms-z-public-mobile-nav);
        isolation: isolate;
        display: none !important;
        width: 100%;
        max-width: none;
        height: calc(100dvh - var(--cms-mobile-public-header-height));
        max-height: none;
        grid-template-columns: 1fr;
        align-content: start;
        gap: 0;
        border-top: 1px solid var(--line-strong);
        border-bottom: 1px solid var(--line-strong);
        background: var(--site-canvas);
        box-shadow: 0 18px 45px rgba(16, 19, 24, 0.18);
        overflow-x: hidden;
        overflow-y: auto;
        overscroll-behavior: contain;
        padding: 0;
    }

.public-utility-nav-desktop {
        display: none;
    }

.public-utility-nav-mobile {
        display: grid;
        width: 100%;
        border-bottom: 1px solid var(--line-strong);
        background: color-mix(in srgb, var(--site-canvas), var(--blue) 5%);
    }

.public-utility-nav-mobile > a {
        justify-content: space-between;
        width: 100%;
        min-height: 48px;
        border: 0;
        border-bottom: 1px solid var(--line-strong);
        padding: 0 1.15rem;
        background: transparent;
        color: var(--ink);
        font-size: 0.86rem;
        text-transform: uppercase;
    }

.public-utility-nav-mobile > a:last-child {
        border-bottom: 0;
    }

.public-utility-nav-mobile > a.is-active {
        color: var(--blue);
        box-shadow: inset 4px 0 0 var(--public-nav-panel-active-border);
    }

:root[data-site-theme="light"] .cms-site-public-nav,
:root[data-site-theme="light"] .public-nav {
        background: #fbfcf7;
    }

:root[data-site-theme="dark"] .cms-site-public-nav,
:root[data-site-theme="dark"] .public-nav {
        background: #29292b;
    }

.cms-site-public-nav.is-open,
.public-nav.is-open {
        display: grid !important;
    }

.cms-site-public-nav > * + * {
        margin-left: 0;
    }

.cms-site-public-nav > a,
.public-nav-trigger,
.public-nav-item > button,
.public-nav a {
        display: flex;
        justify-content: space-between;
        width: 100%;
        min-height: 56px;
        border: 0;
        border-bottom: 1px solid var(--line-strong);
        border-radius: 0;
        background: inherit;
        padding: 0 1.15rem;
        color: var(--ink);
        font-size: 1rem;
        font-weight: 650;
        line-height: 1.2;
        white-space: normal;
    }

.public-nav-item,
.public-nav-item.has-children {
        position: relative;
        z-index: 1;
        display: grid;
        width: 100%;
    }

.public-nav-trigger {
        border-bottom: 1px solid var(--line-strong);
    }

.public-nav-trigger .mud-icon-root {
        transform: none !important;
    }

.public-nav-dropdown {
        position: relative;
        inset: auto;
        top: auto;
        right: auto;
        bottom: auto;
        left: auto;
        z-index: 1;
        display: none;
        width: 100%;
        max-width: none;
        min-height: 0;
        height: auto;
        grid-template-columns: 1fr;
        border: 0;
        border-bottom: 1px solid var(--line-strong);
        background: inherit;
        box-shadow: none;
        padding: 0;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        clip-path: none;
        transform: none;
        transition: none;
    }

.public-nav-dropdown::before {
        content: none;
    }

.public-nav-dropdown::after {
        content: none;
    }

.public-nav-dropdown-glass {
        display: none;
    }

.public-nav-item.is-open > .public-nav-dropdown {
        display: block !important;
    }

.public-nav-item.is-open {
        z-index: 2;
    }

.public-nav-dropdown-desktop-content,
.public-nav-dropdown-custom {
        display: none !important;
    }

.public-nav-item.is-open > .public-nav-dropdown > .public-nav-dropdown-mobile-link {
        display: flex !important;
        justify-content: space-between;
        width: 100%;
        min-height: 48px;
        border-right: 0;
        border-bottom: 1px solid var(--line-strong);
        padding: 0.65rem 1.15rem 0.65rem 2rem;
        background: inherit;
        color: var(--ink);
        text-decoration: none;
    }

.public-nav-item.is-open > .public-nav-dropdown > .public-nav-dropdown-mobile-link:last-of-type {
        border-bottom: 0;
    }

.public-nav-item.is-open > .public-nav-dropdown > .public-nav-dropdown-mobile-link.is-active {
        color: var(--blue);
        background: color-mix(in srgb, var(--site-canvas), var(--blue) 7%);
        box-shadow: inset 4px 0 0 var(--public-nav-panel-active-border);
    }

.public-nav-dropdown-mobile-link span {
        font-size: 0.94rem;
        font-weight: 700;
    }

.public-nav-dropdown small {
        display: none;
    }

.cms-site-public-nav > a:last-child,
.public-nav a:last-child {
        border-bottom: 0;
    }

}

@media (max-width: 420px) {
:root {
        --site-logo-max-width: min(68vw, 210px);
        --cms-mobile-public-header-height: 60px;
    }

.public-header,
.cms-site-public-header {
        min-height: var(--cms-mobile-public-header-height);
        padding-left: var(--site-edge-gap);
    }

.cms-site-public-brand,
.public-brand,
.public-mobile-nav-toggle,
.public-theme-toggle,
.public-header-actions > .mud-tooltip-root:has(.public-theme-toggle) {
        min-height: var(--cms-mobile-public-header-height);
    }

.public-mobile-nav-toggle,
.public-theme-toggle,
.public-header-actions > .mud-tooltip-root:has(.public-theme-toggle) {
        flex-basis: 58px;
        width: 58px;
        min-width: 58px;
        height: var(--cms-mobile-public-header-height);
    }

.site-logo-image {
        max-width: min(52vw, 210px);
        max-height: 44px;
    }

.cms-site-public-nav,
.public-nav {
        top: 100%;
        height: calc(100dvh - var(--cms-mobile-public-header-height));
    }

}
