/**
 * Foundation for Sites
 * Version 6.8.1
 * https://get.foundation
 * Licensed under MIT Open Source
 */
:root {
  --accent-color: #00afff;
  color-scheme: light;
}

@media (prefers-color-scheme: light) {
  body.mmu-drupal {
    color-scheme: light;
  }
}
@media (prefers-color-scheme: dark) {
  body.mmu-drupal {
    color-scheme: dark;
  }
}
html.light-mode body.mmu-drupal {
  color-scheme: light;
}

html.dark-mode body.mmu-drupal {
  color-scheme: dark;
}

:root {
  --body-background-color: #f2f0f0;
  --body-color: black;
  background-color: var(--body-background-color);
  color: var(--body-color);
}

@media (prefers-color-scheme: light) {
  .mmu-drupal {
    --body-background-color: #f2f0f0;
    --body-color: black;
    background-color: var(--body-background-color);
    color: var(--body-color);
  }
}
@media (prefers-color-scheme: dark) {
  .mmu-drupal {
    --body-background-color: #0d0f0f;
    --body-color: white;
    background-color: var(--body-background-color);
    color: var(--body-color);
  }
}
html.light-mode .mmu-drupal {
  --body-background-color: #f2f0f0;
  --body-color: black;
  background-color: var(--body-background-color);
  color: var(--body-color);
}

html.dark-mode .mmu-drupal {
  --body-background-color: #0d0f0f;
  --body-color: white;
  background-color: var(--body-background-color);
  color: var(--body-color);
}

:focus:not(:empty),
:is(.btn, button):focus {
  outline-color: Highlight;
  outline-color: -webkit-focus-ring-color;
  outline-color: #00afff;
  outline-style: auto;
  outline-width: 0.3em;
  outline-offset: 0.3em !important;
  box-shadow: unset;
}

.cke_editable:focus {
  outline: none;
  box-shadow: none;
}

@media (prefers-reduced-motion) {
  * {
    animation-duration: 0s !important;
    transition-duration: 0s !important;
  }
}
@media (prefers-reduced-motion: reduce) {
  * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
/* purgecss start ignore */
.messages--rutherford.alert.status--error .status--error-detail .backtrace {
  font-size: 0.875rem !important;
  line-height: 1.5;
  max-height: 200px;
  overflow-y: auto;
  -webkit-mask-image: linear-gradient(180deg, white 100px, Rgb(255 255 255/25%) 200px);
          mask-image: linear-gradient(180deg, white 100px, Rgb(255 255 255/25%) 200px);
}
.messages--rutherford.alert.status--error .status--error-detail .backtrace:first-line {
  font-size: 1rem !important;
}
.messages--rutherford.alert.status--error .status--error-detail .backtrace pre {
  overflow: hidden;
  max-width: 100%;
}

.toolbar-tray a {
  color: #565656;
}

.toolbar .toolbar-icon-admin-toolbar-tools-help:before,
.toolbar .toolbar-icon-admin-toolbar-tools-help:active:before,
.toolbar .toolbar-icon-admin-toolbar-tools-help.active:before {
  box-sizing: content-box !important;
}

/* purgecss end ignore */
html {
  scroll-behavior: smooth;
}
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto !important;
  }
}

html {
  font-size: 100%;
}

body {
  font-size: 1rem;
  font-family: realist, Helvetica Neue, sans-serif;
  font-feature-settings: "salt" 1;
  font-weight: 400;
  font-style: normal;
  font-optical-sizing: auto;
}
@Media (min-width: 80rem) {
  body {
    font-size: 1.1875rem;
  }
}

.u-text-h1,
h1,
.h1 {
  font-size: 2.25rem;
}
@Media (min-width: 80rem) {
  .u-text-h1,
  h1,
  .h1 {
    font-size: 2.375rem;
  }
}
@Media (min-width: 96rem) {
  .u-text-h1,
  h1,
  .h1 {
    font-size: 2.5rem;
  }
}

.u-text-h2,
h2,
.h2 {
  font-size: 1.875rem;
}
@Media (min-width: 80rem) {
  .u-text-h2,
  h2,
  .h2 {
    font-size: 2rem;
  }
}
@Media (min-width: 96rem) {
  .u-text-h2,
  h2,
  .h2 {
    font-size: 2.125rem;
  }
}

.u-text-h3,
h3,
.h3 {
  font-size: 1.5rem;
}
@Media (min-width: 80rem) {
  .u-text-h3,
  h3,
  .h3 {
    font-size: 1.625rem;
  }
}
@Media (min-width: 96rem) {
  .u-text-h3,
  h3,
  .h3 {
    font-size: 1.75rem;
  }
}

.u-text-h4,
h4,
.h4 {
  font-size: 1.25rem;
}
@Media (min-width: 80rem) {
  .u-text-h4,
  h4,
  .h4 {
    font-size: 1.375rem;
  }
}
@Media (min-width: 96rem) {
  .u-text-h4,
  h4,
  .h4 {
    font-size: 1.5rem;
  }
}

.u-text-h5,
h5,
.h5 {
  font-size: 1.125rem;
  line-height: 1.5;
}
@Media (min-width: 80rem) {
  .u-text-h5,
  h5,
  .h5 {
    font-size: 1.25rem;
  }
}
@Media (min-width: 96rem) {
  .u-text-h5,
  h5,
  .h5 {
    font-size: 1.375rem;
  }
}

.u-text-h6,
h6,
.h6 {
  font-size: 1.0625rem;
  line-height: 1.5;
}
@Media (min-width: 80rem) {
  .u-text-h6,
  h6,
  .h6 {
    font-size: 1.125rem;
  }
}

#main-content p,
#main-content li,
.p {
  line-height: 1.5;
}
#main-content p:last-child,
#main-content li:last-child,
.p:last-child {
  margin-bottom: 0;
}

.u-font-light.u-font-serif.u-text-large {
  font-weight: 700 !important;
  font-family: elza, sans-serif !important;
}

[class*=u-text-h],
.u-font-serif {
  font-feature-settings: initial;
}

:is(h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6, blockquote):not(:first-child) {
  margin-top: 2em;
}

html body [v-cloak] {
  display: none !important;
}

.layout-container {
  display: flex;
  flex-direction: column;
  position: relative;
  min-height: 100%;
  overflow-x: clip;
}

#main-content {
  position: relative;
  container-type: inline-size;
  container-name: main-content;
}

.u-breakout {
  width: 100cqw;
  margin-inline: -50cqw;
  position: relative;
  left: 50%;
  right: 50%;
}

.container {
  margin-inline: auto;
  padding-inline: 1rem;
}
@Media ( width >= 40rem ) {
  .container {
    max-width: calc(40rem - 1.5rem);
  }
}
@Media ( width >= 48rem ) {
  .container {
    padding-inline: 1.5rem;
    max-width: calc(48rem - 1.5rem);
  }
}
@Media ( width >= 64rem ) {
  .container {
    padding-inline: 2rem;
    max-width: calc(64rem - 1.5rem);
  }
}
@Media ( width >= 80rem ) {
  .container {
    max-width: calc(80rem - 1.5rem);
  }
}
@Media ( width >= 96rem ) {
  .container {
    max-width: calc(96rem - 1.5rem);
  }
}

.row {
  display: flex;
  flex-wrap: wrap;
}

a[href] {
  font-weight: bold;
  color: inherit;
  text-decoration: underline;
  text-decoration-color: #00afff;
  text-decoration-thickness: 0.1em;
  text-underline-offset: 0.2em;
  will-change: text-underline-offset, text-decoration-thickness;
  transition: ease-out 0.33s text-decoration-thickness, ease-out 0.33s text-underline-offset;
}
a[href]:is(:hover, :focus) {
  text-decoration-thickness: 0.2em;
  text-underline-offset: 0.3em;
}
:is(.u-bg-aqua, .u-bg-mmu-blue) a[href] {
  text-decoration-color: white;
}

.page-section a:visited:not(.btn):not(button):not(.event-item):not(.spotlight-item):not(.accordion-title) {
  color: light-dark(#4d4d4d, #9e9e9e);
}
.u-bg-black a:visited:not(.btn):not(button):not(.event-item):not(.spotlight-item):not(.accordion-title) {
  color: #969696;
}
.u-bg-mmu-blue a:visited:not(.btn):not(button):not(.event-item):not(.spotlight-item):not(.accordion-title), .u-bg-mmu-yellow a:visited:not(.btn):not(button):not(.event-item):not(.spotlight-item):not(.accordion-title) {
  color: #3B3B3B;
}
.u-bg-transparent-grey-10 a:visited:not(.btn):not(button):not(.event-item):not(.spotlight-item):not(.accordion-title) {
  color: light-dark(#4A4A4A, #A6A6A6);
}
.u-bg-transparent-grey-20 a:visited:not(.btn):not(button):not(.event-item):not(.spotlight-item):not(.accordion-title) {
  color: light-dark(#424242, #C2C2C2);
}
.u-bg-transparent-grey-30 a:visited:not(.btn):not(button):not(.event-item):not(.spotlight-item):not(.accordion-title) {
  color: light-dark(#3B3B3B, #B0B0B0);
}

.make-links-current-color a[href] {
  color: currentColor;
}
.make-links-current-color a[href]:is(:hover, :focus) {
  color: currentColor;
}

a u {
  text-decoration: none !important;
}

.status-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.coloured-tag {
  border-radius: 0.375rem;
  border-style: solid;
  display: inline-flex;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  text-transform: unset !important;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  white-space: normal;
  text-wrap: pretty;
  padding: 0.5625rem 1rem;
  font-size: 0.875rem;
  color: var(--body-color);
  border-color: color-mix(in srgb, currentColor 25%, transparent);
  background-color: transparent !important;
  border-width: 0.0625rem;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin-top: 0;
  margin-bottom: 1rem;
}

h1,
h2,
h3,
h4,
h5,
.h1,
.h2,
.h3,
.h4,
.h5 {
  line-height: 1.25;
  font-family: elza, sans-serif;
  font-weight: 700;
  font-feature-settings: initial;
}

blockquote {
  margin-block: 1rem;
  border-left: 0.5rem solid var(--primary);
  padding-left: calc(1em + 1vw);
  font-size: calc(1em + 0.6vw);
  line-height: 1.333;
  font-family: elza, sans-serif;
  font-weight: 700;
  text-wrap: balance;
}
@media (width >= 80rem) {
  blockquote {
    padding-left: 1.5rem;
    font-size: 1.5rem;
  }
}
.page-section.u-bg-mmu-blue blockquote {
  border-left-color: white;
}
.rt-has-background blockquote {
  border-left-color: var(--accent-1);
}

.hr,
hr {
  opacity: 0.2;
  border-width: 1px 0 0;
  border-color: currentColor;
  margin-top: 16px;
  margin-bottom: 16px;
}

::-moz-selection {
  background-color: Rgb(190 190 190/50%);
}

::selection {
  background-color: Rgb(190 190 190/50%);
}

.text-long .caps {
  font-variant-caps: all-small-caps;
}
.text-long blockquote p {
  font-weight: 700;
  font-family: Georgia, serif;
  line-height: 1;
  font-size: 1.5rem;
  font-stretch: condensed;
}
@media (min-width: 64rem) {
  .text-long blockquote p {
    font-size: 1.875rem;
  }
}
.text-long blockquote p:before, .text-long blockquote p:after {
  opacity: 0.25;
}
.text-long blockquote p:before {
  content: open-quote;
  margin-left: -0.4em;
}
.text-long blockquote p:after {
  content: close-quote;
}
.text-long ul:last-child {
  margin-bottom: 0;
}
.text-long :is(h3, .h3, h4, .h4, h5, .h5, h6, .h6, blockquote):not(:first-child) {
  margin-top: 2em;
}
.text-long .table-responsive {
  margin-top: 2em;
  margin-bottom: 2em;
}

:is(.text-long, .webform) li {
  line-height: 1.5;
  margin-top: 0.333em;
}

.page-section ul, .page-section ol {
  padding-left: 1.5rem;
  margin-block: 1.5rem;
}
.page-section ul li, .page-section ol li {
  margin-block: 0.5rem;
}
.page-section ul li::marker, .page-section ol li::marker {
  color: color-mix(in srgb, currentColor 66.666%, transparent);
}
.page-section ul {
  list-style-type: disc;
}
.page-section ol {
  list-style-type: decimal;
}

ul.list-unset,
ol.list-unset {
  padding-left: unset;
  margin-block: unset;
  list-style-type: none;
}
ul.list-unset li,
ol.list-unset li {
  margin-block: unset;
}

.course-listing-by-subject .list-single {
  display: grid;
}
.course-listing-by-subject .list-double {
  -moz-columns: 2;
       columns: 2;
}
.course-listing-by-subject :is(.list-single, .list-double) li {
  display: block;
}
.course-listing-by-subject :is(.list-single, .list-double) a {
  display: list-item;
  text-wrap: balance;
}

img,
picture {
  display: block;
  max-width: 100%;
  height: auto;
}

figure {
  margin: 0;
}

.news-content img {
  min-width: 100%;
}
.news-content .image-component__caption {
  margin-right: unset;
  position: static;
  bottom: unset;
  z-index: unset;
  color: inherit;
}
.news-content .image-component__caption:before {
  display: none;
}
.news-content figcaption {
  background-color: rgba(128, 128, 128, 0.2);
  padding: 1rem;
}

img.lazyload, img.lazyloading, img.lazyloaded {
  transition: opacity 0.15s linear;
  will-change: opacity;
  opacity: 0;
}
img.lazyloaded {
  opacity: 1;
}

.caption {
  width: -moz-fit-content;
  width: fit-content;
  background-image: linear-gradient(225deg, transparent 7%, #fff 0%);
}

.icon {
  display: inline-flex;
  overflow: visible;
  flex-shrink: 0;
  width: 1em;
  height: 1em;
  fill: currentColor;
  align-self: center;
}
.icon .contextual-region {
  width: 100%;
}

.treat-child-svgs-as-icons :is(svg, img) {
  display: flex;
  overflow: visible;
  flex-shrink: 0;
  width: 1em;
  height: 1em;
  min-width: 1em;
  min-height: 1em;
  fill: currentColor;
  aspect-ratio: 1/1;
}

.ui-autocomplete .ui-menu-item-wrapper {
  padding: 0;
}
.ui-autocomplete .ui-menu-item + .ui-menu-item {
  border-top-width: 1px;
  border-color: #e0e0e0;
}

:root {
  --form-control-color: #00afff;
  --input-border: #8b8a8b;
  --input-ui-size: 1.25rem ;
}

::-moz-placeholder {
  color: #969696;
  opacity: 1;
  font-weight: 400;
}

::placeholder {
  color: #969696;
  opacity: 1;
  font-weight: 400;
}

.form-control {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.1;
  display: grid;
  grid-template-columns: calc(var(--input-ui-size) + 0.125rem) auto;
  gap: 0.75rem;
}

input,
textarea,
select {
  font-size: 1.125rem;
  font-size: max(1.125rem, 1em);
  font-family: inherit;
  font-weight: 700;
  padding: 0.25em 0.5em;
  background-color: light-dark(white, black);
  color: light-dark(black, white);
  border: 2px solid var(--input-border);
  border-radius: 0.375rem;
  transition: 180ms box-shadow ease-in-out;
  max-width: 100%;
}
input:focus,
textarea:focus,
select:focus {
  border-color: light-dark(black, white);
  outline-color: #00afff;
  outline-style: auto;
  outline-width: 0.3em;
  outline-offset: 0.3em;
}

select,
input:not(textarea):not([type=submit]):not([type=checkbox]):not([type=radio]) {
  line-height: 1;
  height: 3.625rem;
}
.search.container select,
.search.container input:not(textarea):not([type=submit]):not([type=checkbox]):not([type=radio]) {
  width: 100%;
}

input[type=search]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  background-color: currentColor;
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23777'><path d='M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z'/></svg>");
  background-size: 1.25rem 1.25rem;
  height: 1.25rem;
  width: 1.25rem;
}

input[type=file] {
  font-size: 0.9em;
  padding-top: 0.35rem;
}

textarea {
  resize: vertical;
}

input[readonly] {
  border-style: dotted;
  cursor: not-allowed;
  color: #777;
}

input[disabled] {
  --input-border: #ccc;
  background-color: #eee;
  cursor: not-allowed;
}

input[size] {
  width: 100%;
}

label {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1;
}

input[type=checkbox] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  margin: 0;
  font: inherit;
  font-size: var(--input-ui-size);
  color: currentColor;
  width: 1em;
  height: 1em;
  padding: 0;
  border: 0.125rem solid var(--input-border);
  border-radius: 0.15em;
  transform: translateY(-0.075em);
  display: grid;
  place-content: center;
}

input[type=checkbox]::before {
  content: "";
  width: 0.5em;
  height: 0.5em;
  transform: scale(0);
  transform-origin: bottom left;
  transition: 120ms transform ease-in-out;
  background-color: CanvasText;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='square' stroke-miterlimit='10' stroke-width='4' d='m3 8.7 2.8 2.9L13 4.4'/%3E%3C/svg%3E");
  background-size: 0.5em 0.5em;
}

input[type=checkbox]:checked::before {
  transform: scale(1);
}

input[type=checkbox]:focus {
  outline: max(2px, 0.15em) solid #00afff;
  outline-offset: max(2px, 0.15em);
}

input[type=checkbox]:disabled {
  --form-control-color: var(--form-control-disabled);
  color: var(--form-control-disabled);
  cursor: not-allowed;
}

input[type=radio] {
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  margin: 0;
  font: inherit;
  font-size: var(--input-ui-size);
  color: currentColor;
  width: 1em;
  height: 1em;
  border: 0.125rem solid var(--input-border);
  border-radius: 50%;
  transform: translateY(-0.075em);
  display: grid;
  place-content: center;
}

input[type=radio]::before {
  content: "";
  width: 0.5em;
  height: 0.5em;
  border-radius: 50%;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1em 1em var(--form-control-color);
  background-color: CanvasText;
}

input[type=radio]:checked::before {
  transform: scale(1);
}

input[type=radio]:focus {
  outline: max(2px, 0.15em) solid #00afff;
  outline-offset: max(2px, 0.15em);
}

select {
  position: relative;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.5;
  background-position: calc(100% - 1rem) center;
  background-repeat: no-repeat;
  background-size: 1em;
  padding-right: 2.625rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='square' stroke-miterlimit='10' stroke-width='2' d='m2 7 10 10L22 7' class='nc-icon-wrapper'/%3E%3C/svg%3E");
}
select option {
  background-color: white;
  color: black;
}

html.light-mode select,
.form-element-has-light-bg select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='square' stroke-miterlimit='10' stroke-width='2' d='m2 7 10 10L22 7' class='nc-icon-wrapper'/%3E%3C/svg%3E");
}
html.light-mode select option,
.form-element-has-light-bg select option {
  background-color: white;
  color: black;
}

@media (prefers-color-scheme: light) {
  select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-linecap='square' stroke-miterlimit='10' stroke-width='2' d='m2 7 10 10L22 7' class='nc-icon-wrapper'/%3E%3C/svg%3E");
  }
  select option {
    background-color: white;
    color: black;
  }
}
@media (prefers-color-scheme: dark) {
  select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='white' stroke-linecap='square' stroke-miterlimit='10' stroke-width='2' d='m2 7 10 10L22 7' class='nc-icon-wrapper'/%3E%3C/svg%3E");
  }
  select option {
    background-color: black;
    color: white;
  }
}
html.dark-mode select,
.form-element-has-dark-bg select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='white' stroke-linecap='square' stroke-miterlimit='10' stroke-width='2' d='m2 7 10 10L22 7' class='nc-icon-wrapper'/%3E%3C/svg%3E");
}
html.dark-mode select option,
.form-element-has-dark-bg select option {
  background-color: black;
  color: white;
}

.form-range .form-range.custom-range + .input-group-append input::-webkit-outer-spin-button, .form-range .form-range.custom-range + .input-group-append input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.webform-options-display-side-by-side > div {
  display: grid;
  margin-right: 0;
}

input[type=submit] {
  min-height: 3.625rem;
  padding: 1.0625rem 1.5rem !important;
  padding: 0.875rem 1rem;
  background-color: var(--primary);
  border-color: var(--primary);
  border-radius: 0.375rem;
  border-style: solid;
  border-width: 0.125rem;
  color: var(--primary-contrast);
  display: inline-flex;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  text-transform: unset !important;
  transition: color 0.15s ease-out, background-color 0.15s ease-out;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  white-space: normal;
  text-wrap: pretty;
}
input[type=submit]:is(:hover, :focus) {
  color: var(--primary-contrast-interact);
  background-color: var(--primary-interact);
}
input[type=submit]:is(:disabled, .disabled) {
  cursor: not-allowed;
  filter: grayscale(1);
}

.input-min-height {
  min-height: 3.625rem;
}

.webform input[size][type=text],
.webform textarea[cols],
.webform select {
  width: 100%;
  max-width: 100%;
}

.address-picklist-container {
  box-shadow: 0 1rem 2rem rgba(132, 132, 132, 0.1);
}

.address-picklist {
  color: inherit;
  background-color: light-dark(rgba(255, 255, 255, 0.66), rgba(255, 255, 255, 0.1));
  max-height: 194px;
  overflow: auto;
  overflow-x: hidden;
}
.address-picklist div {
  padding: 8px 16px;
  line-height: 1.4;
}
.address-picklist div:hover {
  cursor: pointer;
  background-color: light-dark(rgba(219, 219, 219, 0.66), rgba(255, 255, 255, 0.1));
}

.use-address-entered {
  cursor: pointer;
  padding: 12px 16px;
  line-height: 1.4;
  background-color: var(--primary);
  color: var(--primary-contrast);
}
.use-address-entered:hover {
  background-color: var(--primary-interact);
  color: var(--primary-contrast-interact);
}
.use-address-entered em {
  font-style: normal;
}

fieldset#edit-formatted-address > span:first-of-type,
fieldset#edit-formatted-address legend {
  display: none !important;
}
html.js fieldset#edit-formatted-address {
  position: absolute !important;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  border: 0 !important;
}
html.js fieldset#edit-formatted-address.show-fieldset, html.js fieldset#edit-formatted-address:is(:active, :focus, :focus-within) {
  position: static !important;
  overflow: visible !important;
  clip: auto !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  white-space: inherit !important;
}

.search-again-link {
  margin-block: 0.5rem;
}

#postcode-lookup-form {
  display: grid;
  grid-template-columns: 1fr auto;
  max-width: 25.3125rem;
  width: 100%;
  grid-template-rows: auto;
  grid-template-areas: "label  button" "input  button" "message message";
  -moz-column-gap: 0;
       column-gap: 0;
  row-gap: 0.5rem;
  align-items: end;
}
#postcode-lookup-form .form-item-postcode {
  display: contents;
}
#postcode-lookup-form label {
  grid-area: label;
}
#postcode-lookup-form input[name=postcode] {
  grid-area: input;
  width: 100%;
  max-width: 18.75rem;
  border-radius: 0.375rem 0 0 0.375rem;
}
#postcode-lookup-form input[name=submit] {
  width: 6.5625rem;
  grid-area: button;
  align-self: end;
  border-radius: 0 0.375rem 0.375rem 0;
}
#postcode-lookup-form #result-message {
  grid-area: message;
  margin-top: 0.5rem;
  max-width: 100%;
}

.icon-input {
  color: #495057;
  border-color: #80bdff;
  outline: 0;
  background-color: #f1f5f8;
  box-shadow: 0 0 0 0.2rem #80e0ea;
}
.icon-input .form-control {
  height: inherit;
  border-radius: inherit;
}
.icon-input .form-control:focus {
  outline: none;
  box-shadow: none;
}

.webform-flex--container {
  margin: initial !important;
}
.webform-flex--container[style*="display: none;"] {
  display: none !important;
}

.webform fieldset {
  line-height: 1.5;
}

.form-item-radios,
.form-checkbox {
  margin-bottom: 1rem;
}

.webform-submission-form .js-form-wrapper:not(.form-actions),
.js-webform-states-hidden[style="display: block;"],
form:has([data-drupal-ajax-container]) .js-form-wrapper {
  display: grid !important;
  gap: 2rem;
}
.webform-submission-form .js-form-wrapper:not(.form-actions)[style*="display: none;"],
.js-webform-states-hidden[style="display: block;"][style*="display: none;"],
form:has([data-drupal-ajax-container]) .js-form-wrapper[style*="display: none;"] {
  display: none !important;
}

a[class*=btn],
button {
  padding: 0.875rem 1rem;
  background-color: var(--primary);
  border-color: var(--primary);
  border-radius: 0.375rem;
  border-style: solid;
  border-width: 0.125rem;
  color: var(--primary-contrast);
  display: inline-flex;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  text-transform: unset !important;
  transition: color 0.15s ease-out, background-color 0.15s ease-out;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  white-space: normal;
  text-wrap: pretty;
}
a[class*=btn]:is(:hover, :focus),
button:is(:hover, :focus) {
  color: var(--primary-contrast-interact);
  background-color: var(--primary-interact);
}
a[class*=btn]:is(:disabled, .disabled),
button:is(:disabled, .disabled) {
  cursor: not-allowed;
  filter: grayscale(1);
}

a[class].btn-sm,
button.btn-sm {
  padding: 0.5625rem 1rem;
  font-size: 0.875rem;
}

a[class].btn-lg,
button.btn-lg {
  padding: 1.0625rem 1.5rem;
  font-size: 1.125rem;
}

a[class].btn-black-or-white {
  color: light-dark(white, black);
  background-color: light-dark(black, white);
  border-color: light-dark(black, white);
}
a[class].btn-black-or-white:is(:hover, :focus) {
  color: light-dark(white, black);
  background-color: light-dark(rgba(0, 0, 0, 0.5), rgba(255, 255, 255, 0.5));
}

a[class].btn-white-or-black {
  color: light-dark(black, white);
  background-color: light-dark(white, black);
  border-color: light-dark(white, black);
}
a[class].btn-white-or-black:is(:hover, :focus) {
  color: light-dark(black, white);
  background-color: light-dark(rgba(255, 255, 255, 0.5), rgba(0, 0, 0, 0.5));
}

.btn-outline:is(a[href], button) {
  color: var(--body-color);
  border-color: var(--body-color);
  background-color: transparent !important;
  border-width: 0.125rem;
}
.btn-outline:is(a[href], button):is(:hover, :focus) {
  background-color: color-mix(in srgb, var(--body-color) 10%, transparent) !important;
}
.btn-outline:is(a[href], button).btn-black-or-white {
  color: currentColor;
  border-color: currentColor;
}
.btn-outline:is(a[href], button).btn-black-or-white:is(:hover, :focus) {
  color: color-mix(in srgb, currentColor 90%, transparent) !important;
  border-color: color-mix(in srgb, currentColor 90%, transparent) !important;
}

.btn-black {
  color: #fff;
  background-color: #000;
}
.btn-black:is(:hover, :focus) {
  color: #f3f3f3;
  background-color: rgb(25.5, 25.5, 25.5);
}

.btn-white {
  color: #000;
  background-color: #fff;
}
.btn-white:is(:hover, :focus) {
  color: rgb(25.5, 25.5, 25.5);
  background-color: #f3f3f3;
}

.btn-border-opaque-light {
  color: black;
  background-color: rgba(255, 255, 255, 0.05);
  border: 0.0625rem solid rgba(0, 0, 0, 0.25);
}
.btn-border-opaque-light:is(:hover, :focus) {
  color: black;
  background-color: rgba(255, 255, 255, 0.1);
  border: 0.0625rem solid rgba(0, 0, 0, 0.33);
}

.btn-grey {
  color: #fff;
  background-color: #505759;
}
.btn-grey:is(:hover, :focus) {
  color: #f3f3f3;
  background-color: #454b4d;
}

.btn.btn-success {
  color: #fff;
  background-color: #3a863a;
}
.btn.btn-success:is(:hover, :focus) {
  background-color: rgb(42.59375, 98.40625, 42.59375);
}

.btn-light {
  color: #000;
}

.site-header a[class].btn {
  border-color: var(--tw-color-gray-700);
}

.table {
  width: 100%;
  margin-block: 2rem;
}
.table th,
.table td {
  padding: 0.75rem;
  vertical-align: top;
  border: 1px solid color-mix(in srgb, currentColor 10%, transparent);
}
.table thead th {
  vertical-align: bottom;
}
.table caption {
  padding-top: 1rem;
  padding-bottom: 0;
}

.table-striped thead tr,
.table-striped tbody tr:nth-of-type(even) {
  background-color: rgba(255, 255, 255, 0.1);
}

.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(127, 127, 127, 0.1);
}

.video-embed {
  background-color: black;
  position: relative;
  width: 100%;
  height: 100%;
  padding-bottom: 56.25%;
}
.video-embed [data-video-video-container] {
  width: inherit;
  height: inherit;
  position: absolute;
  inset: 0;
}
.video-embed [data-video-video-container] iframe {
  width: 100%;
  height: 100%;
}
.video-embed button[data-video-overlay] {
  pointer-events: none;
  width: inherit;
  height: inherit;
  position: absolute;
  inset: 0;
  padding: 0;
  background-color: unset;
  border-color: unset;
  border-radius: unset;
  color: inherit;
  border-width: 0;
}
.video-embed:is(:hover, :focus) .btn {
  color: var(--primary-contrast-interact);
  background-color: var(--primary-interact);
}

.video-ui,
.video-thumbnail,
.video-thumbnail picture,
.video-thumbnail picture img {
  position: absolute;
  inset: 0;
  display: flex;
  width: 100%;
  height: 100%;
}

.video-thumbnail picture img {
  -o-object-fit: cover;
     object-fit: cover;
}

.video-ui .btn {
  padding: 0.875rem 1rem;
  background-color: var(--primary);
  border-color: var(--primary);
  border-radius: 0.375rem;
  border-style: solid;
  border-width: 0.125rem;
  color: var(--primary-contrast);
  display: inline-flex;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  text-transform: unset !important;
  transition: color 0.15s ease-out, background-color 0.15s ease-out;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  white-space: normal;
  text-wrap: pretty;
}
.video-ui .btn:is(:hover, :focus) {
  color: var(--primary-contrast-interact);
  background-color: var(--primary-interact);
}
.video-ui .btn:is(:disabled, .disabled) {
  cursor: not-allowed;
  filter: grayscale(1);
}
.video-ui .btn {
  margin: auto;
  padding: 0;
  font-size: 4.5rem;
  height: 1em;
  width: 1em;
}

.tabs.tabbed-content .tabs-title {
  position: relative;
  z-index: 1;
}
.tabs.tabbed-content .tabs-title a {
  display: block;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.tabs.tabbed-content .tabs-title.is-active a {
  color: var(--primary-contrast);
  background-color: var(--primary);
  border-color: var(--primary);
}
.tabs.tabbed-content .tabs-title.is-active a:is(:active, :focus, :hover) {
  color: var(--primary-contrast-interact);
  background-color: var(--primary-interact);
}

#nprogress#nprogress .bar {
  height: 3px;
  background: #fe7086;
}
#nprogress#nprogress .peg {
  box-shadow: 0 0 10px #fe7086, 0 0 5px #fe7086;
}
#nprogress#nprogress .spinner-icon {
  border-top-color: #fe7086;
  border-left-color: #fe7086;
}

.contextual {
  z-index: 400;
}

.ui-widget {
  font-family: realist, Helvetica Neue, sans-serif;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) {
  z-index: 1251;
  padding: 0;
  border-width: 6px;
  border-color: #fff;
  border-radius: 0.25rem;
  overflow: hidden;
  box-shadow: 0 15px 30px 0 Rgb(0 0 0/11%), 0 5px 15px 0 Rgb(0 0 0/8%);
  line-height: 1.5;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-titlebar,
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-content,
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-buttonpane {
  z-index: 501;
  padding-left: 16px;
  padding-right: 16px;
}
@media (min-width: 48rem) {
  .ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-titlebar,
  .ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-content,
  .ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-buttonpane {
    padding-left: 32px;
    padding-right: 32px;
  }
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-titlebar,
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-titlebar-close {
  background-color: #fff;
  border-width: 0;
  border-radius: 0;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-titlebar {
  padding-top: 24px;
  padding-bottom: 0;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-title {
  font-size: 1.25rem;
  margin-bottom: 24px;
  margin-top: 0;
  line-height: 1.5;
  white-space: normal;
  overflow: visible;
  width: 100%;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-content {
  padding-top: 0;
  padding-bottom: 0;
  aspect-ratio: 16/9;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-buttonpane {
  border-width: 0;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 24px;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-buttonset {
  float: none;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-titlebar-close {
  border-bottom-left-radius: 0.25rem;
  border-top-right-radius: 0.25rem;
  width: 36px;
  height: 36px;
  transform: translate(6px, -6px);
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .ui-dialog-titlebar-close .ui-icon-closethick {
  background-position: center;
  background-repeat: no-repeat;
  width: 28px;
  height: 28px;
  margin-top: -14px;
  margin-left: -14px;
  background-image: url("../images/jquery-ui/x.svg");
  background-size: 100% auto;
}
.ui-widget.ui-dialog:not(.ui-dialog-off-canvas) .status-message .u-breakout {
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
}

.ui-widget-overlay {
  background-color: #000;
  opacity: 0.9;
}

.ui-widget.ui-dialog:not(.ui-dialog-off-canvas).cti-media-modal-video-dialog {
  max-width: calc(100vw - 32px);
}

.a-to-z {
  min-height: 100dvh;
}

.this-is-a-spinner,
#a-to-z-placeholder {
  min-height: 100vh;
  position: absolute;
  inset: 0;
  margin: 0;
  height: 100%;
  pointer-events: none;
}

.a-to-z-spinner-bg {
  backdrop-filter: blur(3px);
  height: inherit;
  opacity: 0;
  animation: spinnerFadeIn 0.5s ease-in-out forwards;
}

.a-to-z-spinner-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  inset: 0;
}
.a-to-z-spinner-icon svg {
  max-width: 4rem;
}

@keyframes spinnerFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.a-to-z-buttons {
  gap: 1rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
@Media ( width >= 40rem ) {
  .a-to-z-buttons {
    grid-template-columns: repeat(6, 1fr);
  }
}
@Media ( width >= 48rem ) {
  .a-to-z-buttons {
    grid-template-columns: repeat(9, 1fr);
  }
}
@Media ( width >= 64rem ) {
  .a-to-z-buttons {
    grid-template-columns: repeat(11, 1fr);
  }
}
@Media ( width >= 80rem ) {
  .a-to-z-buttons {
    grid-template-columns: repeat(14, 1fr);
  }
}
@Media ( width >= 96rem ) {
  .a-to-z-buttons {
    grid-template-columns: repeat(17, 1fr);
  }
}
.a-to-z-buttons .a-to-z-button,
.a-to-z-buttons button {
  display: flex;
  align-items: stretch;
  min-width: 3.875rem;
  height: 1.75rem;
  line-height: 1.5625rem;
  border-radius: 0;
  padding: 0;
  color: black;
  background-color: white;
  text-align: center;
  border-bottom: 3px solid var(--primary);
  transition: background-color 0.3s ease, border-color 0.2s ease;
  text-decoration: none;
  border-top: 0;
  border-left: 0;
  border-right: 0;
}
.a-to-z-buttons .a-to-z-button:hover,
.a-to-z-buttons button:hover {
  text-decoration: none;
  background-color: rgba(255, 255, 255, 0.5);
  border-bottom-color: var(--primary-interact);
}
.a-to-z-buttons .a-to-z-button.a-to-z-button-is-active,
.a-to-z-buttons button.a-to-z-button-is-active {
  border-bottom-color: var(--accent-1);
}
.a-to-z-buttons .a-to-z-button.a-to-z-button-is-active:hover,
.a-to-z-buttons button.a-to-z-button-is-active:hover {
  border-bottom-color: var(--accent-1-interact);
}
.a-to-z-buttons .a-to-z-button[data-count="0"],
.a-to-z-buttons button[data-count="0"] {
  pointer-events: none;
  border-bottom-color: #cfcfcf;
}

.a-to-z-button-value {
  padding: 0.0625rem 0.5rem 0;
  font-weight: 700;
}

.a-to-z-button-count {
  font-weight: 400;
  padding-left: 0.3125rem;
  padding-right: 0.3125rem;
  font-size: 0.8em;
  background-color: rgba(232, 232, 232, 0.5);
  min-width: 4ch;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
}

.a-to-z-feature-icon {
  position: absolute;
  width: 2rem;
  height: 2rem;
  padding: 0.5rem;
  top: 0;
  right: 0;
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .a-to-z-feature-icon {
    right: auto;
    left: 0.25rem;
    top: 0.25rem;
  }
}

.a-to-z-listing-featured .a-to-z-title {
  width: 100%;
  text-wrap: balance;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .a-to-z-listing-featured .a-to-z-title {
    justify-content: flex-start;
    flex-direction: row;
  }
}
.a-to-z-listing-featured .a-to-z-title:before {
  content: "";
  display: block;
  min-width: 1rem;
}

.a-to-z-title {
  text-transform: unset;
  font-size: 1.25rem;
}

article.a-to-z-listing-item {
  position: relative;
  padding: 1rem;
  border-left-width: 0.5rem;
  border-left-style: solid;
  border-left-color: var(--primary);
  isolation: isolate;
}
@Media ( width >= 48rem ) {
  article.a-to-z-listing-item {
    padding: 1.5rem;
  }
}
article.a-to-z-listing-item:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.page-section[class*=u-bg-mmu-] article.a-to-z-listing-item:before {
  background-color: rgba(255, 255, 255, 0.25);
  mix-blend-mode: overlay;
}
article.a-to-z-listing-item ul {
  margin-block: initial;
}
article.a-to-z-listing-item h2 {
  font-size: 1.125rem;
}
article.a-to-z-listing-item h3 {
  font-size: 1.0625rem;
}
article.a-to-z-listing-item h4 {
  font-size: 1rem;
}
article.a-to-z-listing-item.study-funding-a-to-z-listing-item .a-to-z-item-buttons {
  display: grid;
  gap: 1rem;
  justify-items: start;
  align-self: flex-end;
  width: 100%;
}
@Media ( width >= 48rem ) {
  article.a-to-z-listing-item.study-funding-a-to-z-listing-item .a-to-z-item-buttons {
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    align-items: flex-end;
    max-width: 10.1875rem;
    align-self: stretch;
  }
  article.a-to-z-listing-item.study-funding-a-to-z-listing-item .a-to-z-item-buttons.status-is-exclusive {
    flex-direction: column;
  }
}

.al-features .icon,
.al-features img,
.al-features svg {
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
}

ul.accordion {
  padding-left: unset;
  margin-block: unset;
  list-style-type: none;
}
ul.accordion li {
  margin-block: unset;
}

.accordion-content {
  display: none;
}

.accordion-item:not(:last-child) {
  margin-bottom: 0.1875rem;
}
.accordion-item > a.accordion-title {
  border-style: solid;
  border-width: 0 0 0 0.375rem;
  display: grid;
  gap: 1rem;
  grid-template-columns: auto 1em;
  padding: 1.0625rem 1.5rem;
  text-decoration: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  border-color: var(--primary);
  transition: 0.25s ease-out box-shadow, 0.25s ease-out border-color, 0.25s ease-out background-color;
}
.accordion-item > a.accordion-title:is(:hover) {
  box-shadow: 0 0 10px rgba(128, 128, 128, 0.1098039216);
  border-color: var(--primary-interact);
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}
.accordion-item > a.accordion-title svg {
  color: var(--primary);
  animation: arrow-180-to-0 0.8s forwards;
}
.page-section[class*=u-bg-mmu-] .accordion-item > a.accordion-title {
  background-color: rgba(255, 255, 255, 0.25);
  mix-blend-mode: overlay;
}
.accordion-item.is-active > a.accordion-title svg {
  animation: arrow-0-to-180 0.8s forwards;
}

@keyframes arrow-180-to-0 {
  0% {
    transform: rotateX(180deg);
  }
  100% {
    transform: rotateX(0deg);
  }
}
@keyframes arrow-0-to-180 {
  0% {
    transform: rotateX(0deg);
  }
  100% {
    transform: rotateX(180deg);
  }
}
.rt-accordion-item,
.welcome-induction .accordion-content-spacer,
.staff-profile-publications-accordion .accordion-content-spacer {
  padding-inline: 2rem;
}

.accordion-component .accordion-content-spacer {
  display: grid;
  gap: 2rem;
}

.card.course a {
  height: 100%;
  text-wrap: balance;
  border-left-width: 0.5rem;
  border-left-style: solid;
  border-left-color: var(--primary);
  text-decoration: none;
  position: relative;
  isolation: isolate;
}
.card.course a svg {
  transition: transform 0.25s ease-out;
}
.card.course a:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.card.course a:is(:hover, :focus) svg {
  transform: translateX(0.5rem);
}
.card.course a:is(:hover, :focus):before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}
.card {
  /* stylelint-disable-line */
}
@Media ( width < 48rem ) {
  .card.news .card-body {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }
  .card.news .card__image {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }
}
.card {
  /* stylelint-disable-line */
}
@Media ( width < 64rem ) {
  .card.news.wide .card-body {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }
  .card.news.wide .card__image {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }
}

.card-scrim {
  height: 80px;
  opacity: 0.85;
}
.card-scrim::after {
  position: absolute;
  right: 0;
  left: 0;
  background-color: #000;
  top: 80px;
  height: 100vh;
  content: "";
}

.card-ui-bg {
  position: relative;
  padding: 1rem;
}
@Media ( width >= 48rem ) {
  .card-ui-bg {
    padding: 1.5rem;
  }
}
.card-ui-bg:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.card-ui-bg:is(:hover, :focus):before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}
.card-ui-bg > * {
  position: relative;
  z-index: 1;
}

.swiper-slide.swiper-slide {
  width: inherit !important;
}

.carousel :is(picture, img) {
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 16/9;
}
@Media ( width >= 48rem ) {
  .carousel :is(picture, img) {
    aspect-ratio: 1410/550;
  }
}

.carousel :is(.testimonial-profile-image, .embed-responsive-1by1) :is(picture, img) {
  aspect-ratio: 1/1;
}

.carousel .slider-arrow__right {
  margin-left: 1px;
}
.carousel .swiper-slide {
  overflow: hidden;
}

.carousel-height {
  height: 480px;
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .carousel-height {
    height: 550px;
  }
}

.container p.info-box {
  border-style: solid;
  border-width: 0 0 0 0.375rem;
  border-color: var(--mmu-yellow);
  background: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  padding: 1rem 2.5rem;
}

.container p.info-box:has(+ p.info-box) {
  margin-bottom: 0;
}

p.info-box ~ p.info-box {
  padding-top: 0;
}

/* 1) FIRST .info-box in a consecutive run (requires 2+ in a row) */
.container p.info-box:not(p.info-box + p.info-box):has(+ p.info-box) {
  padding-top: 2rem;
  margin-top: 2rem;
}

/* 2) LAST .info-box in a consecutive run (requires 2+ in a row) */
.container p.info-box + p.info-box:not(:has(+ p.info-box)) {
  padding-bottom: 2rem;
  margin-bottom: 2rem;
}

/* 3) SINGLE .info-box (no .info-box before or after) */
.container p.info-box:not(p.info-box + p.info-box):not(:has(+ p.info-box)) {
  padding-top: 2rem;
  padding-bottom: 2rem;
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.rt-multi-column {
  display: grid;
}
@Media ( width >= 48rem ) {
  .rt-multi-column {
    gap: 2rem;
  }
  .rt-multi-column.rt-multi-column-2 {
    grid-template-columns: repeat(2, 1fr);
  }
}
@Media ( width >= 48rem ) and (width < 64rem) {
  .rt-multi-column.rt-multi-column-3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .rt-multi-column.rt-multi-column-3 > div:nth-child(3) {
    grid-column: span 2;
  }
}
@Media ( width >= 64rem ) {
  .rt-multi-column.rt-multi-column-3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

.rt-has-background {
  background-color: var(--primary);
  color: var(--primary-contrast);
  padding-block: 1rem;
}
@Media (width >= 64rem) {
  .rt-has-background {
    padding-block: 2rem;
  }
}

.rtwf-image {
  display: grid;
  gap: 2rem;
}
@Media ( width >= 48rem ) {
  .rtwf-image {
    grid-template-columns: repeat(2, 50%);
  }
}

.rtwf-feature-left,
.rtwf-feature-right {
  display: grid;
  gap: 2rem;
}

@Media ( width >= 48rem ) {
  .rtwf-feature-left {
    grid-template-columns: 1fr 2fr;
  }
  .rtwf-feature-right {
    grid-template-columns: 2fr 1fr;
  }
}

.rtwf-image-composition-landscape img {
  aspect-ratio: 16/9;
}
.rtwf-image-composition-portrait img {
  aspect-ratio: 3/4;
  max-height: 80vh;
}
.rtwf-image-composition-square img {
  aspect-ratio: 1/1;
}
.rtwf-image-composition-original img {
  aspect-ratio: unset;
}

.rtwf-image img {
  -o-object-fit: cover;
     object-fit: cover;
}

.page-section {
  padding-block: 2rem;
}

.page-section-spacer {
  margin-bottom: 2rem;
}
@Media (width >= 48rem) {
  .page-section-spacer {
    margin-bottom: 3rem;
  }
}

.narrow-layout {
  width: 100%;
  margin-inline: auto;
}
@Media (width >= 48rem) {
  .narrow-layout {
    max-width: calc(0.8 * 48rem);
  }
}
@Media (width >= 64rem) {
  .narrow-layout {
    max-width: calc(0.7 * 64rem);
  }
}
@Media (width >= 80rem) {
  .narrow-layout {
    max-width: calc(0.6 * 80rem);
  }
}
@Media (width >= 96rem) {
  .narrow-layout {
    max-width: calc(0.5 * 96rem);
  }
}

.page-section > .container:has(> div:nth-child(2) > div:first-child.narrow-layout:not(.\!u-ml-0)) > div:not(.narrow-layout) h2 {
  width: 100%;
  margin-inline: auto;
}
@Media (width >= 48rem) {
  .page-section > .container:has(> div:nth-child(2) > div:first-child.narrow-layout:not(.\!u-ml-0)) > div:not(.narrow-layout) h2 {
    max-width: calc(0.8 * 48rem);
  }
}
@Media (width >= 64rem) {
  .page-section > .container:has(> div:nth-child(2) > div:first-child.narrow-layout:not(.\!u-ml-0)) > div:not(.narrow-layout) h2 {
    max-width: calc(0.7 * 64rem);
  }
}
@Media (width >= 80rem) {
  .page-section > .container:has(> div:nth-child(2) > div:first-child.narrow-layout:not(.\!u-ml-0)) > div:not(.narrow-layout) h2 {
    max-width: calc(0.6 * 80rem);
  }
}
@Media (width >= 96rem) {
  .page-section > .container:has(> div:nth-child(2) > div:first-child.narrow-layout:not(.\!u-ml-0)) > div:not(.narrow-layout) h2 {
    max-width: calc(0.5 * 96rem);
  }
}

.page-section > .container:has(> div:nth-child(2) > ul:first-child.accordion.narrow-layout) > div:not(.narrow-layout) h2 {
  width: 100%;
  margin-inline: auto;
}
@Media (width >= 48rem) {
  .page-section > .container:has(> div:nth-child(2) > ul:first-child.accordion.narrow-layout) > div:not(.narrow-layout) h2 {
    max-width: calc(0.8 * 48rem);
  }
}
@Media (width >= 64rem) {
  .page-section > .container:has(> div:nth-child(2) > ul:first-child.accordion.narrow-layout) > div:not(.narrow-layout) h2 {
    max-width: calc(0.7 * 64rem);
  }
}
@Media (width >= 80rem) {
  .page-section > .container:has(> div:nth-child(2) > ul:first-child.accordion.narrow-layout) > div:not(.narrow-layout) h2 {
    max-width: calc(0.6 * 80rem);
  }
}
@Media (width >= 96rem) {
  .page-section > .container:has(> div:nth-child(2) > ul:first-child.accordion.narrow-layout) > div:not(.narrow-layout) h2 {
    max-width: calc(0.5 * 96rem);
  }
}

/* TODO Check all the below once the components are updated
@Media (width >= 64rem) {

  !* Target a page section heading when
    a Contact Info component (same selectors),
    or a Rich Text component is;
    - the first component,
    - is not inside an accordion,
    - is not a 2 or 3 col and not left aligned,
    - and section heading layout is not set as narrow.
  *!
  article
  > div
  > .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > *:not(ul.accordion)
      .text-long.u-m-auto:not(.u-ml-0):not(.col-xl-4):not(.col-xl-6))
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    an Accordion component is;
    - the first component,
    - it's a .narrow-layout,
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .accordion.narrow-layout)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a Webform component is;
    - the first component,
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section > div > div:nth-of-type(1) > .webform)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a In-page Navigation component is;
    - the first component,
    - it's width is narrow
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .in-page-navigation
      .ipn-narrow)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a Rich text with features component is;
    - the first component,
    - it's width is narrow
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .rich-text-with-features
      .narrow-layout)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a Blockquote component is;
    - the first component,
    - it's width is narrow
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .narrow-layout
      > .blockquote)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    an Image component is;
    - the first component,
    - it's width is narrow
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .narrow-layout
      > .image-component)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a Statistic component is;
    - the first component,
    - it's width is narrow
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .statistic
      .statistic-layout-stacked
      .narrow-layout)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a Video Embed component is;
    - the first component,
    - it's width is narrow
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .video-embed
      .narrow-layout)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a Document Downloads component is;
    - the first component,
    - it's width is narrow
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .document-downloads
      .narrow-layout)
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }

  !* Target a page section heading when
    a CTA Banner component is;
    - the first component,
    - it's width is narrow
    - is either .basic-cta-banner or  .featured-cta-banner
    - and section heading layout is not set as narrow.
  *!
  .page-section
  > .container:has(.page-section
      > div
      > div:nth-of-type(1)
      > .narrow-layout
      div:is(.basic-cta-banner, .featured-cta-banner))
  div:not(.narrow-layout)
  h2 {
    max-width: 66%;
    margin-inline: auto;
  }
}
*/
.page-header.text-only-page-header ~ .page-section.u-bg-transparent:nth-of-type(2) {
  padding-top: 1rem !important;
}

.page-section.u-bg-grey-50 .accordion-item:not(.is-active) .accordion-title.u-bg-grey-50:not(:hover) {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .pagination .u-bg-grey-50:not(:hover),
.page-section.u-bg-grey-50 .card.course.u-bg-grey-50:not(:hover) {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .document-download.u-bg-grey-50 {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .document-download.u-bg-grey-50 .btn-document-download {
  background-color: #e8e8e8 !important;
}
.page-section.u-bg-grey-50 .document-download.u-bg-grey-50 .btn-document-download:is(:hover, :focus) {
  background-color: #e0e0e0 !important;
}
.page-section.u-bg-grey-50 .featured-in-page-navigation .md\:u-bg-grey-50 {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .featured-in-page-navigation .md\:u-bg-grey-50 .slant-separator__basic-cta-banner.u-bg-grey-50 {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .information-accordion .information-accordion-item:not(.is-active) .accordion-title.u-bg-grey-50:not(:hover) {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .staff-profile.u-text-grey-50:not(:hover):not(.staff-profile--text_only) {
  color: #e0e0e0 !important;
}
.page-section.u-bg-grey-50 .has-profile-url:not(:hover):not(:focus):not(:focus-within) .profile-image {
  border-color: #e0e0e0;
}
.page-section.u-bg-grey-50 .staff-profile.hover\:u-bg-grey-50:hover,
.page-section.u-bg-grey-50 .has-profile-url:is(:hover, :focus, :focus-within) {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .tabs.tabbed-content .tabs-title.is-active a,
.page-section.u-bg-grey-50 .tabs-content .lg\:u-bg-grey-50 {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .event-item-basic,
.page-section.u-bg-grey-50 .event-item .calendar-date {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .event-item .btn.btn-white:not(:hover),
.page-section.u-bg-grey-50 .event-item.event-item-featured .event-icon.u-bg-white {
  background-color: #e8e8e8 !important;
}
.page-section.u-bg-grey-50 .event-item-basic,
.page-section.u-bg-grey-50 .event-item-featured {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .event-item-basic .event-corner-tr svg,
.page-section.u-bg-grey-50 .event-item-featured .event-corner-tr svg {
  opacity: 0.04;
}
.page-section.u-bg-grey-50 .event-item-basic .btn,
.page-section.u-bg-grey-50 .event-item-featured .btn {
  background-color: #e8e8e8 !important;
}
.page-section.u-bg-grey-50 .event-item-basic .btn:is(:hover, :focus),
.page-section.u-bg-grey-50 .event-item-featured .btn:is(:hover, :focus) {
  background-color: #e0e0e0 !important;
}
.page-section.u-bg-grey-50 .event-item:is(:hover, :focus):not(.event-item-basic, .event-item-featured):before {
  background-color: #e0e0e0 !important;
}
.page-section.u-bg-grey-50 .vacancy-item.u-bg-grey-50 {
  background-color: white !important;
}
.page-section.u-bg-grey-50 .vacancy-item.u-bg-grey-50 .slant-separator__vacancy.u-bg-grey-50 {
  background-color: white !important;
}

html.dark-mode .page-section.u-bg-white {
  color: white;
  background-color: rgba(255, 255, 255, 0.075);
}

.page-section.u-bg-white {
  background-color: rgba(255, 255, 255, 0.66666);
}

.cta-banner-content {
  padding: 1rem;
  gap: 1rem;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
  justify-items: start;
  text-wrap: balance;
}
@Media (width >= 40rem) {
  .cta-banner-content {
    padding: 2rem;
  }
}

.cta-banner-image {
  position: relative;
  container-type: size;
  overflow: hidden;
  background-color: light-dark(white, black);
}
.cta-banner-image picture {
  height: 100cqh;
}
.cta-banner-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.cta-banner-image[onclick]:before {
  content: "";
  position: absolute;
  z-index: 2;
  height: 50cqh;
  aspect-ratio: 1/1;
  bottom: 0;
  right: 0;
  transition: opacity 0.25s ease-out;
  background-image: linear-gradient(315deg, light-dark(black, white), transparent);
  opacity: 0.5;
}
.cta-banner-image[onclick]:hover:before {
  opacity: 1;
}

svg.arrow-right {
  color: light-dark(white, black);
  display: flex;
  position: absolute;
  z-index: 3;
  bottom: 0;
  right: 0;
  padding: 1rem;
  font-size: 50cqh;
}
svg.arrow-right use {
  transition: transform 0.25s ease-out;
}
[onclick]:hover svg.arrow-right use {
  transform: translateX(1rem);
}

.basic-cta-banner {
  display: grid;
  justify-items: stretch;
  grid-template-columns: auto 4rem;
}
@Media (width < 40rem) {
  .basic-cta-banner svg.arrow-right {
    font-size: 4rem;
  }
}
@Media ( width >= 40rem ) {
  .basic-cta-banner {
    grid-template-columns: 3fr 1fr;
  }
}
@Media ( width >= 64rem ) {
  .basic-cta-banner:not(.narrow-layout) .cta-banner-content {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .basic-cta-banner:not(.narrow-layout) .cta-banner-content h3 {
    grid-row: 1/3;
  }
}

.cta-banner-graphic {
  position: relative;
  container-type: size;
  transition: background-color 0.25s ease-out;
  background-color: light-dark(#333333, #cccccc);
}
.cta-banner-graphic[onclick]:hover {
  background-color: light-dark(rgb(25.5, 25.5, 25.5), rgb(229.5, 229.5, 229.5));
}

.featured-cta-banner:not(.full-width-featured-cta-banner) {
  display: grid;
  grid-template-columns: 1fr;
  min-height: 20cqw;
}
@Media ( width >= 40rem ) {
  .featured-cta-banner:not(.full-width-featured-cta-banner) {
    grid-template-columns: repeat(2, 1fr);
  }
}
@Media (width < 40rem) {
  .featured-cta-banner:not(.full-width-featured-cta-banner) .cta-banner-image {
    order: -1;
    aspect-ratio: 2/1;
  }
}

:root {
  --wrapper-max-width: 0;
}
@Media ( width >= 40rem ) {
  :root {
    --wrapper-max-width: calc( 40rem - 1.5rem);
  }
}
@Media ( width >= 48rem ) {
  :root {
    --wrapper-max-width: calc( 48rem - 1.5rem);
  }
}
@Media ( width >= 64rem ) {
  :root {
    --wrapper-max-width: calc( 64rem - 1.5rem);
  }
}
@Media ( width >= 80rem ) {
  :root {
    --wrapper-max-width: calc( 80rem - 1.5rem);
  }
}
@Media ( width >= 96rem ) {
  :root {
    --wrapper-max-width: calc( 96rem - 1.5rem);
  }
}

.full-width-featured-cta-banner {
  min-height: 27cqw;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, calc(var(--wrapper-max-width) / 2)) minmax(0, calc(var(--wrapper-max-width) / 2)) minmax(0, 1fr);
}
@Media ( width < 40rem ) {
  .full-width-featured-cta-banner {
    grid-template-columns: 1fr;
  }
  .full-width-featured-cta-banner .cta-banner-content {
    padding-inline: 1rem;
  }
  .full-width-featured-cta-banner .cta-banner-image {
    order: -1;
    aspect-ratio: 2/1;
  }
}
@Media ( width >= 40rem ) {
  .full-width-featured-cta-banner .cta-banner-content {
    grid-column: 2/3;
  }
  .full-width-featured-cta-banner .cta-banner-image {
    grid-column: 3/-1;
  }
}

.cta-blocks-component {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@Media (width >= 48rem) {
  .cta-blocks-component {
    grid-template-columns: repeat(2, 1fr);
  }
}
.cta-blocks-component.ctab-with-img .cta-block-item {
  display: grid;
  grid-template-columns: 1fr;
}
@Media (width < 64rem) {
  .cta-blocks-component.ctab-with-img .cta-block-item .image {
    order: -1;
  }
}
@Media (width >= 64rem) {
  .cta-blocks-component.ctab-with-img .cta-block-item {
    grid-template-columns: repeat(2, 1fr);
  }
}

.cta-block-item {
  background-color: light-dark(white, rgb(31.875, 31.875, 31.875));
  color: var(--body-color);
  position: relative;
}
.cta-block-item .image,
.cta-block-item .image img {
  width: 100%;
  height: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
@Media (width >= 64rem) {
  .cta-block-item .image,
  .cta-block-item .image img {
    aspect-ratio: unset;
  }
}

.cta-block-content.cta-block-content {
  padding: 1rem;
  display: grid;
  align-items: start;
  align-content: start;
  justify-items: start;
  gap: 0.5rem;
}
@Media (width >= 64rem) {
  .cta-block-content.cta-block-content {
    max-width: 50cqw;
  }
  .cta-block-content.cta-block-content ~ * {
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    width: 50%;
  }
}

.btn-document-download {
  margin-bottom: 0;
  text-align: left;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  width: -moz-fit-content;
  width: fit-content;
}
.btn-document-download.btn {
  background-color: white;
  border-color: white;
  color: black;
}
.btn-document-download.btn:is(:focus, :hover) {
  background-color: rgba(255, 255, 255, 0.5);
  color: black;
}

.download-button__title {
  display: inline;
  vertical-align: baseline;
  padding-right: 8px;
  line-height: 1.5;
  font-weight: 700;
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  [data-style=callout] .download-button__title {
    font-size: 1.125rem;
  }
}
.download-button__file-size {
  font-weight: 300;
  display: inline;
  vertical-align: baseline;
  white-space: nowrap;
  font-size: 0.875rem;
}
.download-button__title, .download-button__file-size {
  position: relative;
  bottom: -0.1rem;
}
.download-button__type {
  border-radius: 9999px;
  font-family: realist, Helvetica Neue, sans-serif;
  position: relative;
  text-transform: uppercase;
  bottom: -2px;
  padding: 0.3125rem 0.4375rem 0.1875rem;
  font-size: 0.625rem;
  background-color: #000;
  color: #fff;
}
.download-button__type:is([data-extension=pdf]) {
  color: #fff;
  background-color: #b30b00;
}
.download-button__type:is([data-extension=doc], [data-extension=docx]) {
  color: #fff;
  background-color: #0078d4;
}
.download-button__type:is([data-extension=xlsx], [data-extension=xlsm], [data-extension=xlsb], [data-extension=xltx], [data-extension=xltm], [data-extension=xls], [data-extension=xlt], [data-extension=xls], [data-extension=xml], [data-extension=xml], [data-extension=xlam], [data-extension=xla], [data-extension=xlw], [data-extension=xlr]) {
  color: #fff;
  background-color: #107c41;
}
.download-button__type:is([data-extension=pptx], [data-extension=pptm], [data-extension=ppt], [data-extension=potx], [data-extension=potm], [data-extension=pot], [data-extension=ppsx], [data-extension=ppsm], [data-extension=pps], [data-extension=ppam], [data-extension=ppa]) {
  color: #fff;
  background-color: #d04423;
}

[data-style=simple] .btn-document-download {
  border: 0 !important;
  border-radius: 0 !important;
  background-color: transparent !important;
  padding: 0 !important;
  text-decoration: none !important;
  color: inherit;
  font-weight: bold;
}
[data-style=simple] .btn-document-download:is(:hover, :focus) {
  color: inherit;
  background-color: transparent;
}
[data-style=simple] .btn-document-download:is(:hover, :focus) .download-button__title {
  text-decoration-thickness: 0.2em;
  text-underline-offset: 0.3em;
}
[data-style=simple] .btn-document-download .download-button__title {
  font-size: 1.125rem;
  text-decoration: underline;
  text-decoration-color: #00afff;
  text-decoration-thickness: 0.1em;
  text-underline-offset: 0.2em;
  will-change: text-underline-offset, text-decoration-thickness;
  transition: ease-out 0.33s text-decoration-thickness, ease-out 0.33s text-underline-offset;
}
[data-style=simple] .btn-document-download .download-button__file-size {
  font-weight: 400;
}
[data-style=simple] .btn-document-download .download-button__title, [data-style=simple] .btn-document-download .download-button__file-size {
  bottom: 0;
}

.full-screen-ajax-indicator {
  animation: fadeInBlur 0.5s ease-out forwards;
}
.full-screen-ajax-indicator__container {
  width: 70px;
  height: 70px;
}

@keyframes fadeInBlur {
  0% {
    background: rgba(255, 255, 255, 0);
    backdrop-filter: blur(0px);
  }
  100% {
    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(2px);
  }
}
.gallery {
  background-color: rgba(128, 128, 128, 0.1019607843);
  container-type: inline-size;
}
.gallery img {
  max-width: 100cqw;
}
.gallery .gallery__button {
  margin-left: 1px;
}
.gallery .swiper-slide {
  overflow: hidden;
}
.gallery .swiper-slide picture {
  aspect-ratio: 16/9;
  -o-object-fit: contain;
     object-fit: contain;
}
.gallery .swiper-slide picture img {
  -o-object-position: 50% 50% !important;
     object-position: 50% 50% !important;
  aspect-ratio: inherit;
  -o-object-fit: inherit;
     object-fit: inherit;
}
.gallery[data-mmu-gallery-autoplay=false] .gallery__button--pause {
  display: none;
}
.gallery[data-mmu-gallery-autoplay=false] .progress {
  transform: translateY(-100%);
}
.gallery[data-mmu-gallery-autoplay=true] .gallery__button--play {
  display: none;
}
.gallery[data-mmu-gallery-autoplay=true] .progress {
  transform: translateY(0%);
}
.gallery[data-mmu-gallery-autoplay=true] .progress-bar {
  transition: none;
}

.swiper-container:not(.gallery-thumbs) .swiper-slide {
  overflow: hidden;
  opacity: 0 !important;
  transition: opacity 0.2s ease-in-out;
}
.swiper-container:not(.gallery-thumbs) .swiper-slide.swiper-slide-active {
  opacity: 1 !important;
}

.gallery-thumbs .swiper-slide {
  opacity: 0.25;
  transition: opacity 0.2s ease-in-out;
  width: 20%;
  filter: saturate(0.6);
  will-change: opacity;
}
.gallery-thumbs .swiper-slide:is(:hover, focus-within) {
  opacity: 0.5;
  filter: none;
}
.gallery-thumbs .swiper-slide.swiper-slide-thumb-active {
  opacity: 1;
  filter: none;
}
.gallery-thumbs .swiper-slide picture {
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
}

.image-component {
  display: flex;
  flex-direction: column;
  position: relative;
}
.image-component img {
  width: 100%;
}
.image-component__item {
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  overflow: hidden;
  inset: -1px;
}
@Media ( width < 48rem ) {
  .image-component__two-of-two {
    margin-top: 1rem;
  }
}
.image-component__caption {
  background-color: rgba(0, 0, 0, 0.8);
  color: white;
  padding: 1rem;
  height: auto !important;
  position: relative;
  backdrop-filter: blur(3px);
}
.image-component img {
  -o-object-fit: cover;
     object-fit: cover;
}
.image-component a {
  display: block;
  position: relative;
}
.image-component a .image-component__caption {
  color: white;
}
.image-component a .image-hover-effect-fade {
  will-change: opacity;
  transition: opacity ease 0.2s;
  opacity: 1;
  position: relative;
  z-index: 1;
}
.image-component a .image-multiply {
  background-color: var(--primary);
  width: 100%;
  height: auto;
  position: absolute;
  top: 0;
  left: 0;
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .image-component a .image-multiply {
    height: 100%;
  }
}
.image-component a .image-multiply * {
  width: inherit;
  height: inherit;
}
.image-component a .image-multiply img {
  mix-blend-mode: overlay;
}
.image-component a:is(:hover, :focus) .image-hover-effect-fade {
  opacity: 0;
}
.image-component a .image-hover {
  position: relative;
  z-index: 1;
}
.image-component a .image-hover:before {
  position: absolute;
  z-index: 1;
  inset: 0;
  content: "";
  background-color: var(--primary);
  mix-blend-mode: hard-light;
  opacity: 0;
  will-change: opacity;
  transition: opacity ease 0.2s;
}
.image-component a:is(:hover, :focus) .image-hover:before {
  opacity: 1;
}
.image-component {
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .image-component__caption {
    position: absolute;
    bottom: 0;
    z-index: 2;
  }
  .image-component:is(.image-layout__narrow,
  .image-layout__wide,
  .image-layout__full-canvas) {
    flex-direction: row;
    gap: 2rem;
    aspect-ratio: 3.1/1;
  }
  .image-component:is(.image-layout__narrow,
  .image-layout__wide,
  .image-layout__full-canvas) .image-component__item {
    position: relative;
  }
  .image-component:is(.image-layout__narrow,
  .image-layout__wide,
  .image-layout__full-canvas) .image-component__item * {
    height: 100%;
  }
  .image-component:is(.image-layout__narrow,
  .image-layout__wide,
  .image-layout__full-canvas) .image-component__one-of-two {
    width: 66.666%;
  }
  .image-component:is(.image-layout__narrow,
  .image-layout__wide,
  .image-layout__full-canvas) .image-component__two-of-two {
    width: 33.333%;
  }
}

.image-layout__news .u-max-h-70svh * {
  height: 100% !important;
  width: auto !important;
}
.image-layout__news picture {
  position: relative;
}
.image-layout__news img {
  margin-inline: auto;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: 50% 50% !important;
     object-position: 50% 50% !important;
}

.iii__icon-wrapper :is(svg, img) {
  width: 1.5em;
  height: 1.5em;
  min-width: 1.5em;
  min-height: 1.5em;
}
html.dark-mode .iii__icon-wrapper img[src$=".svg"] {
  filter: invert(1);
}

.logos-component {
  display: grid;
  -moz-column-gap: 4rem;
       column-gap: 4rem;
  row-gap: 1rem;
}
@Media ( width >= 64rem ) {
  .logos-component.lc-with-teaser {
    grid-template-columns: 1fr 2fr;
  }
  .logos-component.lc-with-teaser[data-lc-items="1"] {
    grid-template-columns: 1fr 1fr;
  }
}

.lc-logos {
  display: grid;
  grid-auto-flow: dense;
  grid-auto-rows: 8.75rem auto;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 15.625rem), 1fr));
  -moz-column-gap: 4rem;
       column-gap: 4rem;
  row-gap: 1rem;
}
.lc-logos:not(:has(.lc-item .lc-item-content)) {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
}
.lc-logos:not(:has(.lc-item .lc-item-content)) .lc-media {
  max-height: 15.625rem;
}
.lc-logos:not(:has(.lc-item .lc-item-content)):has(.lc-item:nth-child(n+6)) .lc-media {
  max-height: 9.375rem;
}
@Media ( width >= 48rem ) {
  .lc-logos {
    row-gap: 2rem;
  }
  [data-lc-items="5"] .lc-logos {
    grid-template-columns: repeat(6, 1fr);
  }
  [data-lc-items="5"] .lc-logos .lc-item {
    grid-column: span 2;
  }
  [data-lc-items="5"] .lc-logos .lc-item:nth-child(n+4) {
    grid-column: span 3;
    margin-inline: auto;
  }
}

.lc-item {
  display: grid;
  align-items: baseline;
  justify-self: start;
  max-width: 31.25rem;
  grid-row: span 2;
}
@Media ( width >= 48rem ) {
  .lc-item {
    grid-template-rows: subgrid;
  }
}
.lc-item:has(.lc-item-content) {
  gap: 1rem;
}
.lc-item:not(:has(.lc-item-content)) {
  grid-row: span 1;
  grid-row: span 2;
}

.lc-item-content {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.lc-item-content h4 {
  text-wrap: balance;
}
.lc-item-content p {
  text-wrap: pretty;
}

.lc-media {
  display: flex;
  margin-right: auto;
  max-height: 9.375rem;
  max-width: 100%;
  justify-content: flex-start;
  align-items: flex-end;
}
.lc-media[href] {
  border-radius: 0.375rem;
  transition: box-shadow 0.3s ease-out;
}
.lc-media[href]:hover {
  box-shadow: 0 0 2rem rgba(128, 128, 128, 0.4);
  animation: increasedBrightness 0.8s forwards;
}
.lc-media :is(.contextual-region,
picture,
svg,
img) {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: flex-end;
  max-width: 100%;
  max-height: inherit;
}
.lc-media :is(svg,
img) {
  max-width: 75%;
  padding: 1rem;
  background-color: white;
  color: black;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: left bottom !important;
     object-position: left bottom !important;
  border-radius: 0.375rem;
}

@keyframes increasedBrightness {
  0% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.5);
  }
  100% {
    filter: brightness(1);
  }
}
.media-banner {
  display: grid;
  align-items: center;
}
@Media ( width >= 48rem ) {
  .media-banner {
    grid-template-columns: repeat(2, 50%);
  }
}
.media-banner.mb-content-align-top {
  align-items: start;
}

.mb-content {
  padding: 1rem;
}
@media (min-width: 48rem) {
  .mb-content {
    padding: 2rem;
  }
}

.mb-white {
  background-color: light-dark(white, rgba(255, 255, 255, 0.1));
  color: light-dark(black, white);
}

.mb-black {
  background-color: black;
  color: white;
}

.mb-media {
  height: 100%;
}
.mb-media picture,
.mb-media img {
  aspect-ratio: 2/1;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@Media ( width >= 48rem ) {
  .mb-content {
    order: -1;
  }
  .mb-media-align-left .mb-content {
    order: unset;
  }
}
@Media ( width < 48rem ) {
  .mb-media-below-mobile .mb-content {
    order: -1;
  }
}
.mb-content .testimonial {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
}
.mb-content .testimonial + .btn {
  margin-top: 1rem;
}
.mb-content blockquote,
.mb-content figcaption {
  font-family: elza, sans-serif;
}
.mb-content blockquote {
  margin-block: 0;
  border-left: 0.5rem solid var(--primary);
  padding-inline: 1rem;
  font-size: 1.5rem;
}
@Media (width >= 48rem) {
  .mb-content blockquote {
    padding-inline: 1.5rem;
  }
}
@Media (min-width: 80rem) {
  .mb-content blockquote {
    font-size: 1.625rem;
  }
}
@Media (min-width: 96rem) {
  .mb-content blockquote {
    font-size: 1.75rem;
  }
}
.mb-content figcaption {
  font-size: 1.25rem;
}
@Media (min-width: 80rem) {
  .mb-content figcaption {
    font-size: 1.375rem;
  }
}
@Media (min-width: 96rem) {
  .mb-content figcaption {
    font-size: 1.5rem;
  }
}

#breadcrumbs {
  position: relative;
  background-color: rgba(0, 0, 0, 0.8);
  color: white;
  font-size: 1rem;
  padding-top: 0.125rem;
  padding-bottom: 1rem;
  padding-inline: 1rem;
}
@Media ( width >= 48rem ) {
  #breadcrumbs {
    padding-inline: 1.5rem;
  }
}
@Media ( width >= 64rem ) {
  #breadcrumbs {
    padding-inline: 2rem;
  }
}
#breadcrumbs ol {
  display: flex;
  flex-direction: row;
  align-items: center;
}
#breadcrumbs li {
  flex-direction: row;
  display: flex;
}
#breadcrumbs li:not(:first-child) {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  display: block;
}
#breadcrumbs li:last-child {
  color: color-mix(in srgb, currentColor 66.666%, transparent);
}
#breadcrumbs a {
  font-weight: 400;
  text-underline-offset: 0.125rem;
  width: -moz-max-content;
  width: max-content;
}
#breadcrumbs a[href="/"]:is(:hover, :focus) {
  color: #00afff;
}
.make-site-header-black #breadcrumbs {
  background-color: rgb(0, 0, 0);
}

[id=sub-menu-nav] .sub-menu {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 16px;
}
[id=sub-menu-nav] [id=mobileToggleSubMenu],
[id=sub-menu-nav] a,
[id=sub-menu-nav] .sub-menu-mobile-dropdown {
  font-size: 1rem;
  display: flex;
  justify-content: flex-start;
  color: black;
  text-decoration: none;
  text-wrap: pretty;
  border-width: 1px;
  border-style: solid;
  border-radius: 0.375rem;
  border-color: rgba(0, 0, 0, 0.25);
  background-color: transparent;
  transition: background-color 0.25s ease-out, border-color 0.25s ease-out;
  padding: 0.875rem 1rem;
}
[id=sub-menu-nav] [id=mobileToggleSubMenu]:is(:hover, :focus),
[id=sub-menu-nav] a:is(:hover, :focus),
[id=sub-menu-nav] .sub-menu-mobile-dropdown:is(:hover, :focus) {
  border-color: white;
  position: relative;
  z-index: 2;
}
[id=sub-menu-nav] [id=mobileToggleSubMenu]:is(:active),
[id=sub-menu-nav] a:is(:active),
[id=sub-menu-nav] .sub-menu-mobile-dropdown:is(:active) {
  border-color: #00afff;
}
@Media ( width >= 48rem ) {
  [id=sub-menu-nav] [id=mobileToggleSubMenu],
  [id=sub-menu-nav] a,
  [id=sub-menu-nav] .sub-menu-mobile-dropdown {
    padding: 0.5rem 0.625rem;
    font-size: 0.875rem;
  }
}
@Media ( width >= 64rem ) {
  [id=sub-menu-nav] [id=mobileToggleSubMenu],
  [id=sub-menu-nav] a,
  [id=sub-menu-nav] .sub-menu-mobile-dropdown {
    padding: 0.75rem 0.875rem;
    font-size: 1rem;
  }
}
@Media ( width >= 80rem ) {
  [id=sub-menu-nav] [id=mobileToggleSubMenu],
  [id=sub-menu-nav] a,
  [id=sub-menu-nav] .sub-menu-mobile-dropdown {
    padding: 0.875rem 1rem;
    font-size: 1.125rem;
  }
}
[id=sub-menu-nav] .sub-menu li.parent {
  position: relative;
}
@Media ( width >= 48rem ) {
  [id=sub-menu-nav] .sub-menu li.parent:is(:focus-within, :hover) > ul {
    display: flex;
    padding: 1rem;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub > div a {
    position: relative;
    align-items: center;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub > div a:after {
    position: absolute;
    right: 1rem;
    content: "";
    display: flex;
    width: 1em;
    font-size: 0.875rem;
    aspect-ratio: 1/1;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='square' stroke-miterlimit='10' stroke-width='2' d='m2 7 10 10L22 7'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub:is(:focus-within, :hover) > div a:after {
    filter: invert(1);
  }
  [id=sub-menu-nav] .sub-menu li.with-sub:is(:focus-within, :hover) a {
    color: inherit;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub div > a {
    padding-right: 2.5rem !important;
  }
}
[id=sub-menu-nav] .sub-menu li.sub a:after {
  transform: rotate(270deg);
}
[id=sub-menu-nav] .sub-menu ul {
  position: absolute;
  left: -1.125rem;
  width: 100%;
  padding: 0;
  z-index: 1;
  min-width: 300px;
}
[id=sub-menu-nav] .sub-menu ul li {
  display: block;
  width: 100%;
}
[id=sub-menu-nav] .sub-menu ul ul {
  left: 100%;
}
@Media ( width >= 48rem ) {
  [id=sub-menu-nav] .sub-menu ul ul {
    top: -1rem;
  }
}
[id=sub-menu-nav] .sub-menu ul.child {
  display: none;
}
[id=sub-menu-nav] .sub-menu ul.child li {
  display: grid;
  width: 100%;
  text-align: left;
}
[id=sub-menu-nav] .sub-menu ul.child li a {
  padding: 14px;
}

[id=sub-menu-nav]:focus-within {
  position: relative;
  z-index: 2;
}
[id=sub-menu-nav]:focus-within ~ * {
  position: relative;
  z-index: 1;
}

#sub-menu-nav {
  background-color: #00afff;
  color: black;
}
#sub-menu-nav > div {
  z-index: 2;
  position: relative;
}
#sub-menu-nav .sub-menu,
#sub-menu-nav .sub-menu li,
#sub-menu-nav .sub-menu li ul li {
  background-color: transparent;
}
#sub-menu-nav .sub-menu ul {
  background-color: #00afff;
}
@Media ( width >= 48rem ) {
  #sub-menu-nav .sub-menu ul {
    box-shadow: 0 32px 32px rgba(0, 0, 0, 0.3490196078);
  }
}

@Media ( width < 48rem ) {
  [id=sub-menu-nav] .sub-menu {
    display: none;
  }
  [id=sub-menu-nav].show-mobile-nav .sub-menu.level-0 {
    display: flex;
    flex-direction: column;
    padding-top: 1rem;
  }
  [id=sub-menu-nav] .with-sub.parent > div {
    display: grid;
    gap: 0.5rem;
    grid-template-columns: auto 2.875rem;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub > div {
    position: relative;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub > div:after {
    position: absolute;
    top: 0;
    right: 0;
    margin: 1.25rem 1rem;
    content: "";
    display: flex;
    width: 1em;
    font-size: 0.875rem;
    aspect-ratio: 1/1;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='currentColor' stroke-linecap='square' stroke-miterlimit='10' stroke-width='2' d='m2 7 10 10L22 7'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub.show-sub-level > div:after {
    filter: invert(1);
  }
  [id=sub-menu-nav] .parent.show-sub-level > .sub-menu {
    display: flex;
    flex-direction: column;
    padding-top: 1rem;
  }
  [id=sub-menu-nav] .sub-menu ul,
  [id=sub-menu-nav] .sub-menu ul ul {
    position: relative;
    left: 0;
  }
  [id=sub-menu-nav] .sub-menu li.with-sub div > a {
    padding-right: 1rem;
  }
}
@Media ( width >= 48rem ) {
  [id=sub-menu-nav] .sub-menu-mobile-dropdown {
    display: none;
  }
}
.message-banner {
  display: none;
}

.news-block.three-story > .card,
.news-block.three-story > .card .card__image {
  height: 100%;
}
@Media ( width >= 64rem ) {
  .news-block.three-story {
    grid-template-columns: 60% auto;
  }
}
@Media ( width >= 80rem ) {
  .news-block.three-story {
    grid-template-columns: 66.666% auto;
  }
}
@Media (width >= 48rem) {
  .news-block.five-story {
    grid-template-columns: repeat(2, [col] 1fr);
  }
  .news-block.five-story > div {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .news-block.five-story > div:nth-child(1) {
    grid-column: col/span 2;
  }
}
@Media (width >= 64rem) {
  .news-block.five-story {
    grid-template-columns: repeat(6, [col] 1fr);
  }
  .news-block.five-story > div:nth-child(1) {
    grid-column: col/span 3;
  }
  .news-block.five-story > div:nth-child(2) {
    grid-column: col 4/span 3;
  }
  .news-block.five-story > div:nth-child(3) {
    grid-column: col/span 2;
  }
  .news-block.five-story > div:nth-child(4) {
    grid-column: col 3/span 2;
  }
  .news-block.five-story > div:nth-child(5) {
    grid-column: col 5/span 2;
  }
}

.post-type {
  position: absolute;
  z-index: 10;
  left: -1px;
  top: -1px;
  background-color: var(--body-background-color);
  color: var(--body-color);
  padding: 0 0.5rem 0.25rem 0;
  border-radius: 0 0 4px;
}

.news-card {
  position: relative;
  display: flex;
  justify-content: space-between;
  flex-direction: column-reverse;
  width: 100%;
  gap: 1rem;
  overflow: hidden;
}
.news-card-title {
  text-transform: unset;
  margin-bottom: 0;
  text-wrap: balance;
  font-size: 1.25rem;
}
.news-card-title a {
  display: inline-flex;
}
.make-links-color-light .news-card a:is(:link, :visited, :hover, :active, :focus) {
  color: #fff !important;
}
.news-card .news-teaser {
  display: none;
}
.news-card-image {
  aspect-ratio: 16/9;
  margin-top: -0.0625rem;
  width: calc(100% + 0.0625rem);
}
.news-card-image img {
  width: 100%;
}
.news-card-meta {
  display: flex;
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  row-gap: 0.25rem;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 0.5rem;
}
.news-card-meta a:is(:hover, :focus) {
  text-decoration: none;
}

.news-block-featured-rows {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 1.25rem;
  align-items: stretch;
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) {
  display: flex;
  height: 100%;
  position: relative;
  padding-top: 0;
  border: 0;
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card {
  color: #fff;
  background-color: #000;
  container-type: inline-size;
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card a:is(:link, :visited, :hover, :active, :focus) {
  color: #fff !important;
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card-body {
  z-index: 1;
  position: relative;
  bottom: 0;
  width: 100%;
  padding: 1.25rem;
  margin-top: -23cqw;
  isolation: isolate;
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card-body:before, .news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card-body:after {
  display: block;
  content: "";
  position: absolute;
  width: calc(100% + 40px);
  left: -20px;
  height: calc(100% + 40px);
  top: -20px;
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card-body:before {
  z-index: -1;
  background-image: linear-gradient(0deg, black 0%, Rgb(0 0 0/33.333%));
  filter: blur(10px);
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card-body:after {
  z-index: -2;
  backdrop-filter: blur(2px);
  -webkit-mask-image: linear-gradient(180deg, Rgb(0 0 0/0%) 0%, black 30%);
}
.news-block-featured-rows .news-card-wrap:nth-child(n+1):nth-child(-n+5) .news-card-image {
  -webkit-mask-image: linear-gradient(0deg, Rgb(0 0 0/0%) 0%, black 30%);
}
.news-block-featured-rows .news-card-wrap:nth-child(n+6) :is(.post-type, .news-card-image) {
  display: none;
}
@Media ( width >= 64rem ) {
  .news-block-featured-rows .news-card-wrap:nth-child(6) {
    display: flex;
    height: 100%;
    position: relative;
    padding-top: 0;
    border: 0;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card {
    color: #fff;
    background-color: #000;
    container-type: inline-size;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card a:is(:link, :visited, :hover, :active, :focus) {
    color: #fff !important;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card-body {
    z-index: 1;
    position: relative;
    bottom: 0;
    width: 100%;
    padding: 1.25rem;
    margin-top: -23cqw;
    isolation: isolate;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card-body:before, .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card-body:after {
    display: block;
    content: "";
    position: absolute;
    width: calc(100% + 40px);
    left: -20px;
    height: calc(100% + 40px);
    top: -20px;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card-body:before {
    z-index: -1;
    background-image: linear-gradient(0deg, black 0%, Rgb(0 0 0/33.333%));
    filter: blur(10px);
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card-body:after {
    z-index: -2;
    backdrop-filter: blur(2px);
    -webkit-mask-image: linear-gradient(180deg, Rgb(0 0 0/0%) 0%, black 30%);
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) .news-card-image {
    -webkit-mask-image: linear-gradient(0deg, Rgb(0 0 0/0%) 0%, black 30%);
  }
  .news-block-featured-rows .news-card-wrap:nth-child(6) :is(.post-type, .news-card-image) {
    display: block;
  }
}
.news-block-featured-rows .news-card-wrap:nth-child(1) a:is(:hover, :focus) {
  text-decoration-thickness: 5px;
  text-underline-offset: 9px;
}
@Media ( width >= 48rem ) {
  .news-block-featured-rows {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .news-block-featured-rows .news-card-wrap:nth-child(1) {
    grid-column: span 2;
    grid-row: span 2;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(1) .news-card-title {
    font-size: 2.375rem;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(1) .news-teaser {
    display: block;
  }
}
@Media ( width >= 64rem ) {
  .news-block-featured-rows {
    grid-template-columns: repeat(12, 1fr);
  }
  .news-block-featured-rows .news-card-wrap:nth-child(1) {
    grid-column: span 7;
    grid-row: span 2;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(2) {
    grid-column: 8/span 5;
    grid-row: 1;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(3) {
    grid-column: 8/span 5;
    grid-row: 2;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(n+4):nth-child(-n+6) {
    grid-column: span 4;
    grid-row: 3;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(n+7) {
    grid-column: span 4;
  }
}
@Media ( width >= 80rem ) {
  .news-block-featured-rows .news-card-wrap:nth-child(1) {
    grid-column: span 8;
    grid-row: span 2;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(2) {
    grid-column: 9/span 4;
    grid-row: 1;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(3) {
    grid-column: 9/span 4;
    grid-row: 2;
  }
  .news-block-featured-rows .news-card-wrap:nth-child(n+7) {
    grid-column: span 3;
  }
}
.news-block-featured-rows .news-card-wrap {
  padding-top: 1.25rem;
  padding-bottom: 0.625rem;
  border-bottom-width: 2px;
  border-bottom-style: solid;
  -o-border-image: linear-gradient(to right, rgba(162, 162, 162, 0.33333), transparent) 1;
     border-image: linear-gradient(to right, rgba(162, 162, 162, 0.33333), transparent) 1;
  border-image-slice: 0 0 1 0;
}

.news-block-basic-rows {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 1.25rem;
  align-items: stretch;
}
@Media ( width >= 48rem ) {
  .news-block-basic-rows {
    display: grid;
    grid-template-columns: repeat(2, calc(50% - 0.625rem));
  }
}
@Media ( width >= 64rem ) {
  .news-block-basic-rows {
    grid-template-columns: repeat(3, calc(33.333% - 0.625rem));
  }
}
@Media ( width >= 80rem ) {
  .news-block-basic-rows {
    grid-template-columns: repeat(4, calc(25% - 0.625rem));
  }
}

.news-post-top-stories .news-card-wrap {
  border-bottom-width: 2px;
  border-bottom-style: solid;
  -o-border-image: linear-gradient(to right, rgba(162, 162, 162, 0.33333), transparent) 1;
     border-image: linear-gradient(to right, rgba(162, 162, 162, 0.33333), transparent) 1;
  border-image-slice: 0 0 1 0;
  padding: 1rem 0rem;
}
.news-post-top-stories .news-card-wrap .news-teaser {
  display: block;
}
.news-post-top-stories .news-card-wrap:last-child {
  border: 0;
}

.news-card-wrap picture,
.news-card-wrap img {
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}

.oembed > div > * {
  width: 100% !important;
  margin: 0 !important;
}

.pagination {
  display: flex;
  padding-left: 0;
  list-style: none;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}

.page-link {
  display: block;
  text-align: center;
}
.page-link:is(:hover, :focus) {
  background-color: rgba(128, 128, 128, 0.1019607843);
}

span.page-link:hover {
  border-color: transparent;
  background-color: transparent;
}

.page-item.active .page-link {
  z-index: 3;
  color: var(--primary-contrast);
  background-color: var(--primary);
}
.page-item.disabled .page-link {
  color: #6c757d;
  pointer-events: none;
  cursor: auto;
  background-color: #fff;
}

.promo-box-cta-desktop {
  display: none;
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .promo-box-cta-desktop {
    display: grid;
    grid-template-columns: auto auto;
    grid-template-rows: minmax(1.25em, 125%);
  }
  .promo-box-cta-desktop .icon {
    font-size: 1.5rem;
    margin-left: 0.5rem;
  }
}

[data-content-expander] [data-hidden=true] {
  display: none;
}

.spotlight-basic-items ul:not(.contextual-links) {
  display: grid;
  gap: 1.5rem;
}
@Media ( width >= 48rem ) {
  .spotlight-basic-items ul:not(.contextual-links) {
    grid-template-columns: repeat(2, 1fr);
  }
}
@Media ( width >= 80rem ) {
  .spotlight-basic-items ul:not(.contextual-links) {
    grid-template-columns: repeat(3, 1fr);
  }
}

.spotlight-featured-items ul:not(.contextual-links) {
  display: grid;
  gap: 2rem;
}
@Media ( width >= 64rem ) {
  .spotlight-featured-items ul:not(.contextual-links) {
    grid-template-columns: repeat(2, 1fr);
  }
}

@Media ( width >= 48rem ) {
  .spotlight-featured-fipn-items {
    grid-template-columns: repeat(2, 1fr);
  }
}

.spotlight-items:is(.spotlight-list-full-items,
.spotlight-list-half-items,
.spotlight-list-third-items) ul:not(.contextual-links) {
  display: grid;
  gap: 2rem;
}

@Media ( width >= 64rem ) {
  .spotlight-list-half-items ul:not(.contextual-links),
  .spotlight-list-third-items ul:not(.contextual-links) {
    grid-template-columns: repeat(2, 1fr);
  }
}
@Media ( width >= 80rem ) {
  .spotlight-list-third-items ul:not(.contextual-links) {
    grid-template-columns: repeat(3, 1fr);
  }
}
.spotlight-item {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.spotlight-content-container {
  position: relative;
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  gap: 0.5rem;
}

.spotlight-title {
  text-wrap: balance;
  margin: 0;
}

.spotlight-teaser {
  text-wrap: pretty;
  margin: 0;
}
@Media ( width > 64rem ) {
  .spotlight-teaser {
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -Webkit-box-orient: vertical;
    -Webkit-line-clamp: 2;
  }
}
@Media (80rem <= width <= 96rem) {
  .spotlight-teaser {
    -Webkit-line-clamp: 3;
  }
}
@Media ( width > 96rem ) {
  .spotlight-teaser {
    -Webkit-line-clamp: 6;
  }
}

a[href].spotlight-basic,
.spotlight-featured {
  background-color: black;
  color: white;
}

[class].spotlight-featured-fipn [class].spotlight-content-container {
  background-color: color-mix(in srgb, var(--primary) 80%, transparent);
  color: var(--primary-contrast);
}

.spotlight-item:not(.spotlight-list) {
  position: relative;
  overflow: hidden;
  justify-content: flex-end;
}
.spotlight-item:not(.spotlight-list) picture {
  width: 100%;
  height: 100%;
}
.spotlight-item:not(.spotlight-list) .spotlight-content-container {
  bottom: -1px;
  z-index: 1;
  width: 100%;
  padding: 1rem;
  background-color: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(5px);
}
@Media ( width >= 48rem ) {
  .spotlight-item:not(.spotlight-list) .spotlight-content-container {
    padding: 1.5rem;
  }
}

.spotlight-item:is(.spotlight-featured, .spotlight-featured-fipn) .spotlight-content-container {
  height: 100%;
  top: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 100%;
}
@Media ( width >= 40rem ) {
  .spotlight-item:is(.spotlight-featured, .spotlight-featured-fipn) .spotlight-content-container {
    width: 50%;
  }
}
@Media ( width >= 48rem ) {
  .spotlight-item:is(.spotlight-featured, .spotlight-featured-fipn) .spotlight-content-container {
    width: 40%;
  }
}
@Media ( width >= 64rem ) {
  .spotlight-item:is(.spotlight-featured, .spotlight-featured-fipn) .spotlight-content-container {
    width: 50%;
  }
}
@Media ( width >= 80rem ) {
  .spotlight-item:is(.spotlight-featured, .spotlight-featured-fipn) .spotlight-content-container {
    width: 40%;
  }
}

.spotlight-item:is(.spotlight-basic,
.spotlight-featured,
.spotlight-featured-fipn) :is(picture, img, .contextual-region) {
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
@Media (width >= 40rem) {
  .spotlight-item:is(.spotlight-basic,
  .spotlight-featured,
  .spotlight-featured-fipn) :is(picture, img, .contextual-region) {
    width: 100%;
    height: 100%;
    inset: 0;
    position: absolute;
  }
  .spotlight-item:is(.spotlight-basic,
  .spotlight-featured,
  .spotlight-featured-fipn) {
    aspect-ratio: 16/9;
  }
}

.spotlight-item:is(.spotlight-featured,
.spotlight-featured-fipn) :is(picture, img) {
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
.spotlight-item:is(.spotlight-featured,
.spotlight-featured-fipn) .btn {
  margin-top: 0.5rem;
}
@Media ( width < 40rem ) {
  .spotlight-item:is(.spotlight-featured,
  .spotlight-featured-fipn) .btn {
    padding: 0.5625rem 1rem;
    font-size: 0.875rem;
  }
}

.spotlight-item.spotlight-list {
  display: grid;
  gap: 0.5rem;
}
@Media ( width >= 40rem ) {
  .spotlight-item.spotlight-list {
    gap: 1rem;
    grid-template-columns: repeat(2, 1fr);
  }
}
.spotlight-item.spotlight-list :is(picture,
.contextual-region) {
  width: 100%;
  height: 100%;
  min-height: 100%;
}
.spotlight-item.spotlight-list img {
  aspect-ratio: 16/9;
  width: inherit;
  height: inherit;
  min-height: inherit;
  -o-object-fit: cover;
     object-fit: cover;
}
@Media ( width >= 40rem ) {
  .spotlight-list-full-items .spotlight-item.spotlight-list {
    grid-template-columns: minmax(0, 11.25rem) 2fr;
  }
}
@Media ( width >= 64rem ) {
  .spotlight-item.spotlight-list:is(.spotlight-list-third) {
    grid-template-columns: 1fr;
  }
}

@Media ( 48rem <= width <= 64rem ) {
  .spotlight-item:is(.spotlight-featured-fipn) {
    aspect-ratio: auto;
    min-height: 20.625rem;
  }
  .spotlight-featured-fipn {
    grid-column: span 2;
  }
}
@Media ( width >= 64rem ) {
  .spotlight-item:is(.spotlight-featured-fipn) {
    aspect-ratio: auto;
  }
  .spotlight-fipn-items:has(> :nth-child(3)) .spotlight-featured-fipn {
    grid-row: span 2;
  }
}
.spotlight-fipn-items {
  display: grid;
  gap: 1rem;
}
@Media (width >= 48rem) {
  .spotlight-fipn-items {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@Media (width >= 64rem) {
  .spotlight-fipn-items {
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  }
}

.spotlight-fipn-item {
  text-wrap: balance;
  padding: 1rem;
  background-color: light-dark(white, rgb(31.875, 31.875, 31.875));
}

.spotlight-item:is(.spotlight-basic,
.spotlight-featured,
.spotlight-featured-fipn) {
  position: relative;
}
.spotlight-item:is(.spotlight-basic,
.spotlight-featured,
.spotlight-featured-fipn) .contextual-region {
  width: 100%;
  height: 100%;
  inset: 0;
  position: absolute;
}

.statistic__big-figure {
  line-height: 1;
}

/* stylelint-disable-line */
@Media ( width < 40rem ) {
  .statistic__media img {
    max-width: 66.666%;
    margin-right: auto;
    margin-left: auto;
  }
}
/* stylelint-disable-line */
@Media ( width >= 64rem ) {
  .statistic .statistic-layout-stacked .statistic__media {
    width: 50%;
  }
}
.statistic-layout-horizontal .statistic__media img {
  max-height: 16.25rem;
}

.statistic__media img {
  -o-object-fit: contain;
     object-fit: contain;
}
.statistic__media .contextual-region,
.statistic__media svg {
  width: 100%;
}

.messages--core {
  display: none;
}

.ui-dialog-off-canvas .messages--core {
  display: block;
}
.ui-dialog-off-canvas .messages--rutherford {
  display: none;
}

.alert {
  display: block;
  border-radius: 0;
}
.alert a {
  color: #fff;
  font-weight: 700;
}
.alert-success {
  background-color: #3a863a;
  color: #fff;
}
.alert-warning {
  background-color: #da611e;
  color: #fff;
}
.alert-danger {
  background-color: #d64040;
  color: #fff;
}

.testimonial.staff-profile div blockquote {
  width: 100% !important;
}

.testimonial--full_width {
  min-height: 400px;
  position: relative;
  overflow: hidden;
}
.testimonial--full_width:before {
  position: absolute;
  display: block;
  content: "";
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.8);
}
.testimonial--full_width.testimonial--full_width--without-profile-pic {
  overflow: hidden;
}
.testimonial--full_width.testimonial--full_width--without-profile-pic:before {
  backdrop-filter: blur(10px);
  aspect-ratio: 1/1;
  width: 200vw;
  transform: translate(-33.333%, -50%);
  left: 50%;
  top: 50%;
}
@media (width >= 64rem) {
  .testimonial--full_width.testimonial--full_width--without-profile-pic:before {
    -webkit-mask-image: radial-gradient(at 10% 10%, transparent 0%, black 100%);
            mask-image: radial-gradient(at 10% 10%, transparent 0%, black 100%);
  }
}
.testimonial--full_width.testimonial--full_width--with-profile-pic:before {
  backdrop-filter: blur(10px);
  inset: 0;
}
@media (width < 64rem) {
  .testimonial--full_width.testimonial--full_width--with-profile-pic figcaption {
    display: grid;
    grid-template-columns: 100px auto;
    -moz-column-gap: 24px;
         column-gap: 24px;
    row-gap: 5px;
    align-items: center;
  }
  .testimonial--full_width.testimonial--full_width--with-profile-pic figcaption .testimonial-profile-image {
    grid-row: span 2;
  }
}

.testimonial-bg .contextual-region,
.testimonial-bg picture {
  position: absolute;
  inset: 0;
  z-index: 0;
  -o-object-fit: cover;
     object-fit: cover;
  height: 100%;
}
.testimonial-bg img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.testimonial--full_width-image {
  position: absolute;
  z-index: 2;
  inset: 0;
  background-size: cover;
  -webkit-mask-image: linear-gradient(90deg, transparent 75%, black 85%);
          mask-image: linear-gradient(90deg, transparent 75%, black 85%);
}

.testimonial--5050 {
  min-height: 550px;
}

.testimonial--5050 .contextual-region,
.testimonial--5050 picture,
.testimonial--5050-light .contextual-region,
.testimonial--5050-light picture {
  height: 100%;
  width: 100%;
}
.testimonial--5050 .contextual-region img,
.testimonial--5050 picture img,
.testimonial--5050-light .contextual-region img,
.testimonial--5050-light picture img {
  aspect-ratio: 16/9;
  height: inherit;
  width: inherit;
  -o-object-fit: cover;
     object-fit: cover;
}

@media (width >= 64rem) {
  .testimonial-profile-image {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 25%;
    right: 0;
  }
}
.testimonial-profile-image > div {
  align-content: center;
  z-index: 3;
  position: relative;
  display: grid;
  width: -moz-fit-content;
  width: fit-content;
  grid-template-areas: "profile-image";
  justify-items: center;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 100px rgba(0, 0, 0, 0.2705882353);
  border-radius: 50%;
}
.testimonial-profile-image > div:after {
  position: absolute;
  content: "";
  display: block;
  box-shadow: inset 0 0 0 1px white, inset 0 0 0.75rem white;
  border-radius: 100%;
  aspect-ratio: 1/1;
  width: calc(100% - 0.625rem);
  grid-area: profile-image;
  scale: 1.05;
}
.testimonial-profile-image picture {
  aspect-ratio: 1/1;
}
.testimonial-profile-image img {
  aspect-ratio: inherit;
  grid-area: profile-image;
  width: auto;
  min-height: 100%;
  margin-inline: auto;
  border-radius: 50%;
  overflow: hidden;
  -o-object-fit: cover;
     object-fit: cover;
  border: 0.375rem solid white;
  scale: 1.05;
}

.carousel .testimonial.testimonial--full_width.u-breakout {
  width: 100%;
  margin-inline: auto;
  left: unset;
  right: unset;
}

.testimonial--profile .contextual-region,
.testimonial--profile picture,
.testimonial--profile img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.timeline__item {
  text-align: left;
  clear: both;
}
.timeline__item:before {
  position: absolute;
  background-color: #002f6c;
  top: 24px;
  left: 16px;
  width: 10px;
  height: 10px;
  content: "";
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(0, 47, 108, 0.2);
}
.timeline__item {
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .timeline__item:nth-child(odd) {
    text-align: right;
    float: left;
  }
  .timeline__item:nth-child(odd):before {
    right: -6px;
    left: auto;
  }
  .timeline__item:nth-child(even) {
    text-align: left;
    float: right;
  }
  .timeline__item:nth-child(even):before {
    right: auto;
    left: -4px;
  }
  .timeline__item:before {
    top: 40px;
  }
}

.slant-separator__vacancy {
  top: -200px !important;
  width: 100%;
  height: 250px;
  transform: skewY(-15deg) !important;
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .slant-separator__vacancy {
    top: 0 !important;
    width: 120%;
    transform: skewX(200deg) skewY(0deg) !important;
  }
}

.vacancy picture img {
  background-color: white;
  padding: 1rem;
  -o-object-fit: contain;
     object-fit: contain;
}

.accommodation-teaser {
  border-bottom-width: 0.5rem;
  border-bottom-style: solid;
  border-bottom-color: var(--primary);
  position: relative;
  isolation: isolate;
}
.accommodation-teaser:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.accommodation-teaser:is(:hover, :focus-within):before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}

article.accommodation-listing {
  border-top-width: 0.5rem;
  border-top-style: solid;
  border-top-color: var(--primary);
  position: relative;
  isolation: isolate;
}
article.accommodation-listing:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
article.accommodation-listing:is(:hover, :focus-within):before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}

.accommodation-listing__tabs .btn-accommodation-listing-tab {
  border-width: 0.125rem;
  color: var(--primary-contrast);
  background-color: var(--primary);
  border-color: var(--primary);
}
.accommodation-listing__tabs .btn-accommodation-listing-tab:is(:active, :focus, :hover) {
  color: var(--primary-contrast-interact);
  background-color: var(--primary-interact);
  border-color: var(--primary-interact);
}
.accommodation-listing__tabs {
  /* purgecss start ignore */
}
.accommodation-listing__tabs .is-active .btn-accommodation-listing-tab {
  color: currentColor;
  border-color: currentColor;
  background-color: transparent !important;
}
.accommodation-listing__tabs .is-active .btn-accommodation-listing-tab:is(:active, :focus, :hover) {
  background-color: color-mix(in srgb, currentColor 10%, transparent) !important;
}
.accommodation-listing__tabs {
  /* purgecss end ignore */
}

.accommodation-listing__map-wrapper {
  height: 100dvh;
}

.dark-mode .al-features img {
  filter: invert(1);
}
.dark-mode .al-features svg {
  fill: white !important;
}

.gallery-component {
  position: relative;
  z-index: 2;
}

.swiper-slide {
  width: auto !important;
}

.gallery-component .swiper-slide {
  width: 100% !important;
  max-width: 100%;
}

.gallery-thumbs .swiper-slide {
  width: 120px !important;
}

.swiper-slide img {
  width: 100%;
  max-width: 100%;
}

.accommodation-room {
  border-top-width: 0.5rem;
  border-top-style: solid;
  border-top-color: var(--primary);
  position: relative;
  isolation: isolate;
}
.accommodation-room:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.accommodation-room:is(:hover, :focus-within):before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}

/* purgecss start ignore */
.campus {
  margin-bottom: 0;
  display: grid;
  gap: 1rem;
  container-type: inline-size;
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .campus {
    grid-template-columns: repeat(2, calc((100% - 1rem) / 2));
  }
}
.campus {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .campus {
    grid-template-columns: repeat(3, calc((100% - 2rem) / 3));
  }
}
.campus {
  /* stylelint-disable-line */
}
@Media ( width >= 96rem ) {
  .campus {
    grid-template-columns: repeat(4, calc((100% - 6rem) / 4));
    gap: 2rem;
  }
}

.campus-item {
  background-color: rgba(0, 0, 0, 0.09);
  container-type: inline-size;
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .campus-item--double-width {
    grid-column: span 2;
  }
  .campus-item--double-width .campus-item__wrapper {
    min-height: calc(50cqw - 0.5rem);
  }
  .campus-item--double-height {
    grid-row-end: span 2;
  }
}
.campus-item {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .campus-item--double-height-if-largest {
    grid-row-end: span 2;
  }
}

.campus-item__wrapper {
  min-height: 100cqw;
}

.campus__image {
  position: absolute;
  inset: 0;
}
.campus__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.campus__slanted-teaser {
  max-width: calc(100% - 2.8125rem);
  background-color: #fff;
  color: black;
}
.page-section.u-bg-grey-50 .campus__slanted-teaser {
  background-color: #e8e8e8;
}
.page-section.u-bg-grey-100 .campus__slanted-teaser {
  background-color: #e0e0e0;
}
.page-section.u-bg-black .campus__slanted-teaser {
  background-color: #000;
  color: white;
}
.page-section.u-bg-grey-500 .campus__slanted-teaser {
  background-color: #505759;
  color: white;
}
.page-section.u-bg-aqua .campus__slanted-teaser {
  background-color: #00afff;
}
.page-section.u-bg-blue .campus__slanted-teaser {
  background-color: #002f6c;
  color: white;
}
.page-section.u-bg-yellow .campus__slanted-teaser {
  background-color: #ffd74a;
}

li:is(.campus-item--staff-profile, .campus-item--profiles) .campus-item__wrapper,
li:is(.campus-item--staff-profile, .campus-item--profiles) .field,
li:is(.campus-item--staff-profile, .campus-item--profiles) .field > div,
li:is(.campus-item--staff-profile, .campus-item--profiles) .field__item,
li:is(.campus-item--staff-profile, .campus-item--profiles) .gallery,
li:is(.campus-item--staff-profile, .campus-item--profiles) .gallery > div,
li:is(.campus-item--staff-profile, .campus-item--profiles) .swiper-container,
li:is(.campus-item--staff-profile, .campus-item--profiles) .swiper-wrapper,
li:is(.campus-item--staff-profile, .campus-item--profiles) .swiper-slide {
  height: 100% !important;
}

.profiles--gallery-item {
  background-color: inherit;
  display: flex;
  justify-content: flex-start;
  flex-direction: column !important;
  align-items: center;
  height: inherit;
}
.profiles--gallery-item__media {
  width: 100%;
  max-width: 16.25rem;
}
.profiles--gallery-item__media img {
  position: relative;
  width: 100%;
}

.campus .statistic__big-figure {
  white-space: normal !important;
}

.campus-object {
  background-color: #505759;
  position: relative;
  overflow: hidden;
  display: flex;
  height: 100%;
  text-decoration: none;
}
.campus-item--double-width .campus-object {
  min-height: auto;
}

.flair-ui {
  position: absolute;
  z-index: 10;
  left: -1px;
  top: -1px;
  background-color: var(--body-background-color);
  color: var(--body-color);
  padding: 0 0.5rem 0.25rem 0;
  border-radius: 0 0 4px;
}

.page-section.u-bg-aqua .flair-ui {
  background: #00afff;
  color: black;
}
.page-section.u-bg-black .flair-ui {
  background: #000;
  color: white;
}
.page-section.u-bg-blue .flair-ui {
  background: #002f6c;
  color: white;
}
.page-section.u-bg-grey-50 .flair-ui {
  background: #e8e8e8;
  color: black;
}
.page-section.u-bg-grey-500 .flair-ui {
  background: #505759;
  color: white;
}
.page-section.u-bg-dark-pink .flair-ui {
  background: #fe7086;
  color: black;
}
.page-section.u-bg-orange .flair-ui {
  background: #f68300;
  color: black;
}
.page-section.u-bg-yellow .flair-ui {
  background: #ffd74a;
  color: black;
}

.image-hover-effect-fade,
.image-multiply {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.image-hover-effect-fade *,
.image-multiply * {
  width: inherit;
  height: inherit;
}

.hover\:image-effect-multiply {
  display: block;
  position: relative;
}
.hover\:image-effect-multiply .image-hover-effect-fade {
  z-index: 2;
  will-change: opacity;
  transition: opacity ease 0.2s;
  opacity: 1;
}
.hover\:image-effect-multiply .image-multiply {
  z-index: 1;
  background-color: var(--primary);
}
.hover\:image-effect-multiply .image-multiply img {
  mix-blend-mode: overlay;
}
.hover\:image-effect-multiply:is(:hover, :focus) .image-hover-effect-fade {
  opacity: 0;
}

.cc-item-content {
  background-color: color-mix(in srgb, var(--body-background-color) 80%, transparent);
  color: var(--body-color);
  backdrop-filter: blur(5px);
  position: absolute;
  display: flex;
  bottom: -1px;
  z-index: 30;
  padding: 1rem;
  width: calc(100% + 2px);
  left: -1px;
}
.cc-item-content p {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -Webkit-box-orient: vertical;
  -Webkit-line-clamp: 2;
}

:is(.campus-item--staff-profile, .campus-item--profiles) .swiper-wrapper {
  justify-content: center;
  display: grid;
  grid-template-areas: "campus-item--profiles";
}
:is(.campus-item--staff-profile, .campus-item--profiles) .swiper-wrapper .swiper-slide {
  grid-area: campus-item--profiles;
  opacity: 0 !important;
  transition: opacity 0.25s ease-out;
  transform: unset !important;
}
:is(.campus-item--staff-profile, .campus-item--profiles) .swiper-wrapper .swiper-slide.swiper-slide-active {
  opacity: 1 !important;
}
:is(.campus-item--staff-profile, .campus-item--profiles) .swiper-wrapper .swiper-slide picture {
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}

a.campus-object,
.campus-ii a[data-fancybox] {
  position: relative;
}
a.campus-object:before,
.campus-ii a[data-fancybox]:before {
  position: absolute;
  z-index: 1;
  inset: 0;
  content: "";
  background-color: var(--primary);
  mix-blend-mode: hard-light;
  opacity: 0;
  will-change: opacity;
  transition: opacity ease 0.2s;
}
a.campus-object:is(:hover, :focus):before,
.campus-ii a[data-fancybox]:is(:hover, :focus):before {
  opacity: 1;
}

.campus-object :is(.contextual-region, picture, img),
.campus-ii :is(.contextual-region, picture, img) {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* purgecss end ignore */
.country-selection {
  background: light-dark(black, rgb(31.875, 31.875, 31.875));
  color: white;
}
.country-selection .page-header-img-wrapper {
  background: light-dark(white, rgb(38.25, 38.25, 38.25));
  color: black;
  stroke: light-dark(black, white);
}
.country-selection input[name=countries] {
  width: 100%;
}
.country-selection input[name=countries]::-moz-placeholder {
  color: light-dark(#a6a6a6, #4b4b4b);
  opacity: 1;
}
.country-selection input[name=countries]::placeholder {
  color: light-dark(#a6a6a6, #4b4b4b);
  opacity: 1;
}

.form-entity-autocomplete {
  position: relative;
}
.form-entity-autocomplete:after {
  z-index: 1;
  position: absolute;
  display: block;
  aspect-ratio: 1/1;
  width: 24px;
  bottom: 0;
  right: 0;
  margin-right: 16px;
  margin-bottom: 10px;
  content: "";
}
.form-entity-autocomplete:has(input.form-autocomplete):after {
  content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><circle cx="12" cy="12" opacity=".4" r="11" fill="none" stroke="grey" stroke-width="2"></circle></svg>');
}
.form-entity-autocomplete:has(input.form-autocomplete.ui-autocomplete-loading):after {
  content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><g  fill="none" stroke="grey" class="nc-icon-wrapper"><g class="nc-loop-circle-24-icon-o"><circle cx="12" cy="12" opacity=".4" r="11" stroke-width="2"></circle><path d="M12 1a11 11 0 0 1 11 11" stroke-linecap="butt" stroke-width="2"></path></g>\3c style>.nc-loop-circle-24-icon-o{--animation-duration:0.5s;transform-origin:12px 12px;animation:nc-loop-circle-anim var(--animation-duration) infinite linear}@keyframes nc-loop-circle-anim{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}\3c /style></g></svg>');
}

.js input.form-autocomplete,
.js input.form-autocomplete.ui-autocomplete-loading {
  background-image: none !important;
}

.country-selection__map {
  height: auto !important;
  max-width: 100%;
  aspect-ratio: 1200/760;
  max-height: 25rem;
  margin-inline: auto;
  opacity: 0.333;
  padding: 1rem;
}
@Media (64rem <= width <= 80rem) {
  .country-selection__map {
    width: 100% !important;
  }
}
@media (width >= 80rem) {
  .country-selection__map {
    width: auto !important;
    height: 100% !important;
  }
}
.country-selection__map > .mapplic-container,
.country-selection__map .mapplic-map {
  width: inherit !important;
  height: inherit !important;
}
.country-selection__map .mapplic-map {
  transform: none !important;
}

.ui-widget.ui-widget-content,
.autocomplete-result {
  color: black;
  background-color: white;
}

.ui-widget.ui-widget-content,
.ui-widget.ui-widget-content .ui-menu-item {
  list-style: none;
}

.ui-menu .ui-state-focus,
.ui-menu .ui-state-active {
  margin: 0;
}

.ui-menu-item-wrapper,
.ui-state-active {
  display: block;
  border: 0 !important;
}

.ui-widget-content a {
  color: inherit;
  text-decoration: underline;
  text-decoration-color: #00afff;
  text-decoration-thickness: 0.1em;
  text-underline-offset: 0.2em;
  will-change: text-underline-offset, text-decoration-thickness;
  transition: ease-out 0.33s text-decoration-thickness, ease-out 0.33s text-underline-offset;
}
.ui-widget-content a:is(:hover, :focus, .ui-state-active) {
  text-decoration-thickness: 0.2em;
  text-underline-offset: 0.3em;
}

.document-downloads .field__item ~ .field__item .document-download[data-style=callout] {
  padding-top: 0 !important;
}
.document-downloads .field__item ~ .field__item .document-download[data-style=simple] {
  padding-top: 1rem !important;
}

.document-download__thumb picture {
  max-height: 16.25rem;
}
.document-download__thumb picture img {
  margin-inline: auto;
  max-height: 16.25rem;
  -o-object-fit: contain;
     object-fit: contain;
}

.education-advisers__select option {
  color: black;
}

.education-advisers__select + .ajax-progress-throbber {
  display: none;
}

.event-timeline-date .event-timeline-date__inner {
  padding-bottom: 2rem;
  bottom: 0;
}
.event-timeline-date .event-timeline-date__inner:before {
  position: absolute;
  bottom: 0.75rem;
  display: block;
  content: "";
  height: 0.75rem;
  width: 0.375rem;
  background-color: #00afff;
  transition: bottom 0.2s ease-in-out, height 0.2s ease-in-out;
}
.event-timeline-date.is-active .event-timeline-date__inner:before {
  bottom: 0.375rem;
  height: 1.125rem;
}

@media (width >= 48rem) {
  .event-timeline-event .event-timeline-event__media {
    flex: 0 0 50%;
  }
}
@media (width >= 64rem) {
  .event-timeline-event .event-timeline-event__media {
    flex: 0 0 33.333%;
  }
}
.event-timeline-event .event-timeline-event__media img {
  width: 100%;
}

.event-timeline--vertical .event-timeline-event {
  position: relative;
  margin-left: 2.625rem;
}
.event-timeline--vertical .event-timeline-event--has-timeline-decoration:before {
  position: absolute;
  top: -1rem;
  bottom: 0;
  left: -2rem;
  display: block;
  width: 5px;
  content: "";
  background-color: #00afff;
}
.event-timeline--vertical .event-timeline-event--has-timeline-decoration:after {
  position: absolute;
  top: 6px;
  left: -1.25rem;
  display: block;
  content: "";
  height: 0.375rem;
  width: 0.75rem;
  background-color: #00afff;
}

.event-timeline--horizontal .swiper-container {
  overflow: visible;
}
.event-timeline--horizontal .swiper-slide {
  overflow: visible;
  position: relative;
  isolation: isolate;
  padding: 1rem;
}
@Media ( width >= 48rem ) {
  .event-timeline--horizontal .swiper-slide {
    padding: 1.5rem;
  }
}
.event-timeline--horizontal .swiper-slide:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
}

.event-timeline--horizontal .event-timeline-timeline {
  position: relative;
  height: 0.375rem;
  width: calc(100% - 1.5rem);
  left: 1.5rem;
}
.event-timeline--horizontal .event-timeline-timeline:before {
  position: absolute;
  content: "";
  display: block;
  background-color: #00afff;
  height: inherit;
  width: 1.5rem;
  left: -1.5rem;
}
.event-timeline--horizontal .event-timeline-timeline:after {
  position: static;
  content: "";
  display: block;
}
.event-timeline--horizontal .swiper-slide {
  opacity: 0 !important;
}
.event-timeline--horizontal .swiper-slide.swiper-slide-active {
  opacity: 1 !important;
}
.event-timeline--horizontal .gallery__controls {
  top: auto;
  bottom: 0;
}

.events-list {
  margin-top: 1rem;
  display: grid;
  gap: 1rem;
  align-items: start;
}
@media (width >= 48rem) {
  .events-list {
    gap: 2rem;
  }
}
.events-list.events-list-basic {
  display: flex;
  flex-wrap: wrap;
  justify-content: left;
  align-items: stretch;
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .events-list.events-list-basic {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
}
.events-list.events-list-basic {
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .events-list.events-list-basic {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }
}
.events-list.events-list-basic {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .events-list.events-list-basic {
    grid-template-columns: repeat(6, 1fr);
  }
}
.events-list.events-list-basic {
  /* stylelint-disable-line */
}
@Media ( width >= 80rem ) {
  .events-list.events-list-basic {
    grid-template-columns: repeat(7, 1fr);
  }
}
.events-list.events-list-featured {
  display: flex;
  flex-wrap: wrap;
  justify-content: start;
  row-gap: 0;
}
.events-list.events-list-featured > .event-item {
  width: 100%;
}
@media (width >= 48rem) {
  .events-list.events-list-featured > .event-item {
    max-width: calc((100% - 2rem) / 2);
  }
}
@media (width >= 64rem) {
  .events-list.events-list-featured > .event-item {
    max-width: calc((100% - 2 * 2rem) / 3);
  }
}
.events-list.events-list-columns_basic, .events-list.events-list-columns_featured {
  gap: 2rem;
  grid-template-columns: 100%;
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .events-list.events-list-columns_basic, .events-list.events-list-columns_featured {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.events-list.events-list-columns_basic, .events-list.events-list-columns_featured {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .events-list.events-list-columns_basic, .events-list.events-list-columns_featured {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.events-list.events-list-lines_featured {
  gap: 2rem;
  grid-template-columns: 100%;
}

.event-item-basic {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  width: max(50% - 0.5rem, 10.1875rem);
  position: relative;
  border-top-width: 0.5rem;
  border-top-style: solid;
  border-top-color: var(--primary);
  isolation: isolate;
}
.event-item-basic:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.page-section[class*=u-bg-mmu-] .event-item-basic:before {
  background-color: rgba(255, 255, 255, 0.25);
  mix-blend-mode: overlay;
}
.event-item-basic:is(:hover, :focus):before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}
.event-item-basic .corner-fold {
  position: absolute;
  width: 2rem;
  height: 2rem;
  bottom: 0;
  right: 0;
  transform-origin: bottom right;
  overflow: hidden;
}
.event-item-basic .corner-fold svg {
  position: absolute;
  bottom: 0;
  right: 0;
  fill: black;
}
.event-item-basic .corner-fold:before {
  background-color: #00afff;
  content: "";
  position: absolute;
  bottom: -1px;
  right: -1px;
  width: 2rem;
  height: 2rem;
  transform-origin: bottom right;
  scale: 0.7;
  transition: all 0.25s ease-in-out;
}
.event-item-basic .corner-fold:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 2rem;
  height: 2rem;
  clip-path: polygon(0 0, 0% 100%, 100% 0);
  scale: 0.7;
  transform-origin: bottom right;
  transition: all 0.25s ease-in-out;
}
html.light-mode .event-item-basic .corner-fold:after {
  background-color: rgb(232, 232, 232);
}
html.dark-mode .event-item-basic .corner-fold:after {
  filter: brightness(1.5);
  background-image: linear-gradient(135deg, rgb(45, 45, 45) 0%, rgb(20, 20, 20) 50%);
}
.event-item-basic:is(:hover, :focus) .corner-fold:before, .event-item-basic:is(:hover, :focus) .corner-fold:after {
  scale: 1;
}
.event-item-basic:is(:hover, :focus) .corner-fold:after {
  filter: brightness(1);
}
.event-item-basic {
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .event-item-basic {
    width: 100%;
  }
}
.event-item-basic .event-label {
  color: var(--primary-contrast);
  background-color: var(--primary);
}
.event-item-basic .event-corner-tr {
  width: 1.875rem;
}
.event-item-basic .event-date {
  line-height: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding: 1.5rem 0.5rem 1rem;
}
.event-item-basic .event-date-day {
  font-size: 4rem;
  line-height: 0.8;
  font-weight: 700;
}
.event-item-basic .event-date-multi-day {
  font-size: 3.125rem;
  font-weight: 700;
}
.event-item-basic .event-date-month {
  font-size: 1.875rem;
  font-weight: 700;
  text-transform: uppercase;
}
.event-item-basic .event-date-multi-month {
  font-size: 2rem;
  font-weight: 700;
  text-transform: uppercase;
}

.event-item-featured {
  margin-bottom: 2rem;
  padding: 1rem;
  border-top-width: 0.5rem;
  border-top-style: solid;
  border-top-color: var(--primary);
  position: relative;
  isolation: isolate;
}
@Media ( width >= 48rem ) {
  .event-item-featured {
    padding: 1.5rem;
  }
}
.event-item-featured:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.page-section[class*=u-bg-mmu-] .event-item-featured:before {
  background-color: rgba(255, 255, 255, 0.25);
  mix-blend-mode: overlay;
}
.event-item-featured:is(:hover, :focus):before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}
.event-item-featured .event-title {
  font-size: 1.5rem;
}
.event-item-featured .event-label {
  font-size: 1.25rem;
}

.event-title {
  font-size: 1.375rem;
  line-height: 1.2;
  margin-bottom: 0.5rem;
  position: relative;
}

.event-info {
  font-weight: 400;
  display: inline-grid;
  grid-template-columns: auto auto;
  align-items: start;
  -moz-column-gap: 0.75rem;
       column-gap: 0.75rem;
  row-gap: 0.5rem;
  font-size: 1.125rem;
}
.event-info > div:nth-child(odd) {
  align-self: start;
}
.event-info > div:nth-child(even) {
  align-self: center;
  line-height: 1.2;
}

.event-icon {
  display: inline-flex;
  padding: 0.375rem;
  border-radius: 0.25rem;
}

.calendar-date {
  min-width: 4.8125rem;
  min-height: 4.8125rem;
  border-top-width: 0.5rem;
  border-top-style: solid;
  border-top-color: var(--primary);
  position: relative;
  padding: 1.5rem 1rem 0.5rem;
  isolation: isolate;
}
.calendar-date:after {
  content: "";
  position: absolute;
  width: 0.5rem;
  height: 0.5rem;
  background-color: var(--primary);
  top: 0.5rem;
  left: 0.5rem;
}
html.light-mode .calendar-date:after {
  box-shadow: 0px 16px rgba(0, 0, 0, 0.06), 0px 32px rgba(0, 0, 0, 0.04), 0px 48px rgba(0, 0, 0, 0.02), 16px 0 rgba(0, 0, 0, 0.06), 32px 0 rgba(0, 0, 0, 0.04), 48px 0 rgba(0, 0, 0, 0.02), 16px 16px rgba(0, 0, 0, 0.06), 16px 32px rgba(0, 0, 0, 0.04), 16px 48px rgba(0, 0, 0, 0.02), 32px 16px rgba(0, 0, 0, 0.04), 32px 32px rgba(0, 0, 0, 0.04), 32px 48px rgba(0, 0, 0, 0.02), 48px 16px rgba(0, 0, 0, 0.02), 48px 32px rgba(0, 0, 0, 0.02), 48px 48px rgba(0, 0, 0, 0.02);
}
html.dark-mode .calendar-date:after {
  box-shadow: 0px 16px rgba(255, 255, 255, 0.06), 0px 32px rgba(255, 255, 255, 0.04), 0px 48px rgba(255, 255, 255, 0.02), 16px 0 rgba(255, 255, 255, 0.06), 32px 0 rgba(255, 255, 255, 0.04), 48px 0 rgba(255, 255, 255, 0.02), 16px 16px rgba(255, 255, 255, 0.06), 16px 32px rgba(255, 255, 255, 0.04), 16px 48px rgba(255, 255, 255, 0.02), 32px 16px rgba(255, 255, 255, 0.04), 32px 32px rgba(255, 255, 255, 0.04), 32px 48px rgba(255, 255, 255, 0.02), 48px 16px rgba(255, 255, 255, 0.02), 48px 32px rgba(255, 255, 255, 0.02), 48px 48px rgba(255, 255, 255, 0.02);
}
html.light-mode .calendar-date.calendar-date-multi-day:after {
  box-shadow: 0px 16px rgba(0, 0, 0, 0.06), 0px 32px rgba(0, 0, 0, 0.04), 0px 48px rgba(0, 0, 0, 0.02), 16px 0 color-mix(in srgb, var(--primary) 50%, transparent), 32px 0 color-mix(in srgb, var(--primary) 25%, transparent), 48px 0 rgba(0, 0, 0, 0.02), 16px 16px rgba(0, 0, 0, 0.06), 16px 32px rgba(0, 0, 0, 0.04), 16px 48px rgba(0, 0, 0, 0.02), 32px 16px rgba(0, 0, 0, 0.04), 32px 32px rgba(0, 0, 0, 0.04), 32px 48px rgba(0, 0, 0, 0.02), 48px 16px rgba(0, 0, 0, 0.02), 48px 32px rgba(0, 0, 0, 0.02), 48px 48px rgba(0, 0, 0, 0.02);
}
html.dark-mode .calendar-date.calendar-date-multi-day:after {
  box-shadow: 0px 16px rgba(255, 255, 255, 0.06), 0px 32px rgba(255, 255, 255, 0.04), 0px 48px rgba(255, 255, 255, 0.02), 16px 0 color-mix(in srgb, var(--primary) 50%, transparent), 32px 0 color-mix(in srgb, var(--primary) 25%, transparent), 48px 0 rgba(255, 255, 255, 0.02), 16px 16px rgba(255, 255, 255, 0.06), 16px 32px rgba(255, 255, 255, 0.04), 16px 48px rgba(255, 255, 255, 0.02), 32px 16px rgba(255, 255, 255, 0.04), 32px 32px rgba(255, 255, 255, 0.04), 32px 48px rgba(255, 255, 255, 0.02), 48px 16px rgba(255, 255, 255, 0.02), 48px 32px rgba(255, 255, 255, 0.02), 48px 48px rgba(255, 255, 255, 0.02);
}
.calendar-date:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.page-section[class*=u-bg-mmu-] .calendar-date:before {
  background-color: rgba(255, 255, 255, 0.25);
  mix-blend-mode: overlay;
}

.event-item:is(:hover, :focus) .calendar-date:before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}

/*
Target a no-event message and event heading
when a page section heading width is narrow
*/
.page-section > .container:has(> .narrow-layout) .no-events .events-heading,
.page-section > .container:has(> .narrow-layout) .no-events-message {
  width: 100%;
  margin-inline: auto;
}
@Media (width >= 48rem) {
  .page-section > .container:has(> .narrow-layout) .no-events .events-heading,
  .page-section > .container:has(> .narrow-layout) .no-events-message {
    max-width: calc(0.8 * 48rem);
  }
}
@Media (width >= 64rem) {
  .page-section > .container:has(> .narrow-layout) .no-events .events-heading,
  .page-section > .container:has(> .narrow-layout) .no-events-message {
    max-width: calc(0.7 * 64rem);
  }
}
@Media (width >= 80rem) {
  .page-section > .container:has(> .narrow-layout) .no-events .events-heading,
  .page-section > .container:has(> .narrow-layout) .no-events-message {
    max-width: calc(0.6 * 80rem);
  }
}
@Media (width >= 96rem) {
  .page-section > .container:has(> .narrow-layout) .no-events .events-heading,
  .page-section > .container:has(> .narrow-layout) .no-events-message {
    max-width: calc(0.5 * 96rem);
  }
}

.events-carousel .slider-arrow__right {
  margin-left: 1px;
}
.events-carousel .swiper-slide {
  overflow: hidden;
}
.events-carousel .swiper-pagination-bullet {
  margin: 8px;
  border-radius: 0;
  width: 40px;
}
.events-carousel .swiper-pagination-bullet-active {
  background-color: #00afff;
}

.events-carousel-height {
  height: 480px;
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .events-carousel-height {
    height: 550px;
  }
}

#homepage-header {
  background-color: black;
  color: white;
  overflow: hidden;
}
@Media ( width >= 48rem ) {
  #homepage-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-direction: column;
  }
}
#homepage-header:before {
  content: "";
  width: 100%;
  min-height: 45vh;
  position: relative;
  z-index: 1;
}

#hh-feature-img-container,
#hh-feature-img-container * {
  position: absolute;
  z-index: 0;
  inset: 0;
  height: 100%;
  width: 100%;
}

#hh-feature-img-container img {
  -o-object-fit: cover;
     object-fit: cover;
  transition-property: opacity filter;
  transition-duration: 0.5s;
  transition-timing-function: ease;
}
@Media ( width < 48rem ) {
  #hh-feature-img-container img {
    opacity: 0.2 !important;
    filter: blur(5px);
  }
}
@Media ( width >= 48rem ) {
  #hh-feature-img-container img {
    filter: blur(0px);
    opacity: 1;
  }
}
body.preload #hh-feature-img-container img {
  filter: blur(5px);
  opacity: 0.666;
}

#hh-feature-mobile-img-container img {
  position: relative;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  aspect-ratio: 8/9;
  -webkit-mask-image: linear-gradient(0deg, rgba(255, 255, 255, 0) 0vw, rgba(255, 255, 255, 0.15) 28vw, rgb(255, 255, 255) 50vw);
          mask-image: linear-gradient(0deg, rgba(255, 255, 255, 0) 0vw, rgba(255, 255, 255, 0.15) 28vw, rgb(255, 255, 255) 50vw);
}
@Media ( width >= 48rem ) {
  #hh-feature-mobile-img-container img {
    display: none;
  }
}

#hh-content {
  position: relative;
  width: 100%;
  z-index: 1;
  padding-block: 2rem;
  isolation: isolate;
}
@Media ( width < 48rem ) {
  #hh-content {
    margin-top: -33vw;
  }
}
@Media ( width >= 48rem ) {
  #hh-content:before {
    pointer-events: none;
    background-color: rgba(0, 0, 0, 0.8);
    content: "";
    position: absolute;
    z-index: -1;
    inset: 0;
    bottom: 0;
    top: auto;
    width: 102%;
    left: -1%;
    height: 100%;
    -webkit-mask-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 20vw);
            mask-image: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 20vw);
    backdrop-filter: blur(2px);
  }
}

#hh-list {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr;
  grid-auto-rows: auto;
}
@Media ( width >= 48rem ) {
  #hh-list {
    grid-template-columns: 1fr 1fr;
    row-gap: 3rem;
  }
  #hh-list li:nth-child(1) {
    grid-column: span 2;
  }
}
@Media ( width >= 64rem ) {
  #hh-list {
    grid-template-columns: 2fr 1fr;
    row-gap: 2rem;
  }
  #hh-list li:nth-child(1) {
    grid-row: span 2;
    grid-column: 1;
  }
  #hh-list li:nth-child(2) {
    grid-row: 1;
    grid-column: 2;
    align-self: end;
  }
  #hh-list li:nth-child(3) {
    grid-row: 2;
    grid-column: 2;
    align-self: start;
  }
}
#hh-list li:first-child {
  text-wrap: balance;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 0.5rem;
}
@Media ( width >= 48rem ) {
  #hh-list li:first-child {
    gap: 1rem;
    max-width: 75vw;
  }
}
@Media ( width >= 64rem ) {
  #hh-list li:first-child {
    max-width: 50vw;
  }
}
@Media ( width >= 96rem ) {
  #hh-list li:first-child {
    max-width: 51.875rem;
  }
}
#hh-list li:first-child h2 {
  margin-bottom: 0;
  text-wrap: balance;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.2), 0 0 20px rgba(0, 0, 0, 0.2), 0 0 40px rgba(0, 0, 0, 0.2), 0 0 80px rgba(0, 0, 0, 0.2), 0 0 160px rgba(0, 0, 0, 0.2), 0 0 320px rgba(0, 0, 0, 0.2);
  font-size: 2.5rem;
}
@Media ( width >= 48rem ) {
  #hh-list li:first-child h2 {
    font-size: 4.8vw;
  }
}
@Media ( width >= 96rem ) {
  #hh-list li:first-child h2 {
    font-size: 4.625rem;
  }
}
#hh-list li:first-child p {
  font-size: 1.375rem;
  margin-bottom: 0;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.2), 0 0 20px rgba(0, 0, 0, 0.2), 0 0 40px rgba(0, 0, 0, 0.2), 0 0 80px rgba(0, 0, 0, 0.2), 0 0 160px rgba(0, 0, 0, 0.2), 0 0 320px rgba(0, 0, 0, 0.2);
}
#hh-list li:not(:first-child) a {
  gap: 16px;
  overflow: hidden;
  display: grid;
  height: 100%;
  width: 100%;
  grid-template-columns: min(7.5rem) 2fr;
  border-width: 1px;
  border-style: solid;
  border-color: rgba(255, 255, 255, 0.25);
  border-radius: 0.375rem;
  background-color: rgba(0, 0, 0, 0.5);
  text-decoration: none;
  transition: background-color 0.25s ease-out, border-color 0.25s ease-out;
  backdrop-filter: blur(3px);
}
@Media ( width >= 64rem ) {
  #hh-list li:not(:first-child) a {
    max-width: 25rem;
    margin-left: auto;
    margin-right: 0;
  }
}
#hh-list li:not(:first-child) a:is(:hover, :focus) {
  background-color: rgba(0, 0, 0, 0.75);
}
#hh-list li:not(:first-child) a .hh-not-1st-post-image {
  background-size: cover;
  background-position: center;
  min-width: 7.5rem;
  min-height: 7.5rem;
  position: relative;
}
#hh-list li:not(:first-child) a .hh-not-1st-post-image:before {
  inset: 0;
  position: absolute;
  content: "";
  display: block;
  backdrop-filter: blur(5px);
}
#hh-list li:not(:first-child) a .hh-not-1st-post-image * {
  position: absolute;
  width: 100%;
  height: 100%;
}
#hh-list li:not(:first-child) a img {
  -o-object-fit: contain;
     object-fit: contain;
  position: relative;
  z-index: 1;
  width: auto;
}
#hh-list li:not(:first-child) h2 {
  margin-block: 0;
  align-self: center;
  font-size: 1.1875rem;
  padding: 1rem 1rem 1rem 0;
}
#hh-list h2 {
  text-wrap: pretty;
}

.information-accordion .information-accordion-item {
  margin-bottom: 32px;
}
.information-accordion .information-accordion-item .accordion-title {
  background-color: light-dark(white, rgba(128, 128, 128, 0.1019607843));
  position: relative;
}
.information-accordion .information-accordion-item.is-active .accordion-title {
  background-color: #00afff;
  text-decoration-color: light-dark(white, black);
}
.information-accordion .information-accordion-item.is-active .accordion-title:after {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 1rem;
  content: "";
  border-top-width: 0;
  border-color: transparent transparent rgba(128, 128, 128, 0.2);
  position: absolute;
  left: 47%;
  top: 100%;
}
.information-accordion .accordion-content {
  display: none;
}
.information-accordion .accordion-title {
  width: 100%;
  justify-content: center;
  display: grid;
  align-content: space-evenly;
  text-align: center;
  min-height: 15.875rem;
}
.information-accordion .accordion-title h3 {
  min-height: 6ch;
}
@media (width >= 48rem) {
  .information-accordion .accordion-title {
    min-height: 19.5rem;
  }
}
@media (width >= 64rem) {
  .information-accordion .accordion-title {
    min-height: 20rem;
  }
}
.information-accordion .accordion-title svg {
  fill: black !important;
}
.information-accordion .accordion-title svg[stroke],
.information-accordion .accordion-title svg *[stroke] {
  stroke: black !important;
}
.information-accordion .accordion-title img,
.information-accordion .accordion-title svg {
  aspect-ratio: 1/1;
  width: 100%;
  max-height: 7em;
  max-width: 7em;
  margin-inline: auto;
}
html.dark-mode .information-accordion .accordion-title img,
html.dark-mode .information-accordion .accordion-title svg {
  filter: invert(1);
}
.information-accordion .accordion-title .accordion-title--contract,
.information-accordion .accordion-title .accordion-title--expand {
  transition: opacity 0.15s linear;
}
.information-accordion .accordion-title .accordion-title--contract {
  opacity: 0;
}
.information-accordion .accordion-title[aria-expanded=true] .accordion-title--contract {
  opacity: 1;
}
.information-accordion .accordion-title[aria-expanded=true] .accordion-title--expand {
  opacity: 0;
}

.in-page-navigation .btn {
  display: inline-grid;
  grid-template-columns: auto 1em;
  gap: 1rem;
  align-items: center;
}
.in-page-navigation ul {
  gap: 1rem;
}
.in-page-navigation.ipn-grid-list ul, .in-page-navigation.ipn-list ul {
  display: grid;
}
.in-page-navigation.ipn-inline-list ul {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
@media (width >= 40rem) {
  .in-page-navigation.ipn-grid-list ul {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (width >= 64rem) {
  .in-page-navigation.ipn-grid-list ul {
    grid-template-columns: repeat(3, 1fr);
  }
  .in-page-navigation.ipn-grid-list ul[data-items="2"], .in-page-navigation.ipn-grid-list ul[data-items="4"] {
    grid-template-columns: repeat(2, 1fr);
  }
}
.in-page-navigation.ipn-grid-list ul .btn {
  width: 100%;
  height: 100%;
}

.ui-dialog-off-canvas #drupal-off-canvas-wrapper .moderation-sidebar-container input.button {
  width: 100%;
  margin-bottom: 10px;
}
.ui-dialog-off-canvas #drupal-off-canvas-wrapper .moderation-sidebar-container ul {
  margin-left: 1em;
}
.ui-dialog-off-canvas #drupal-off-canvas-wrapper .moderation-sidebar-container li {
  display: list-item;
  font-size: 0.875rem;
}

.ot-display {
  display: inline-flex;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
  gap: 0.0625rem;
}

.ot-item {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: 0.75rem;
  background-color: rgba(128, 128, 128, 0.1019607843);
}
.ot-item:nth-child(even) {
  background-color: rgba(128, 128, 128, 0.2);
}

.default-h1 {
  margin-top: 2rem;
}

.page-header {
  z-index: 1;
  position: relative;
}
.page-header:not(.page-header-no-image):before {
  pointer-events: none;
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  --page-header-bg: rgba(0, 0, 0, 0.5);
  background-color: var(--page-header-bg);
  -webkit-mask-image: linear-gradient(180deg, white 0%, rgba(255, 255, 255, 0) 66.666%);
          mask-image: linear-gradient(180deg, white 0%, rgba(255, 255, 255, 0) 66.666%);
}
body.remove-page-bg-img .page-header:not(.page-header-no-image):before {
  background-color: transparent;
  -webkit-mask-image: none;
          mask-image: none;
}
.page-header.page-header-blue {
  color: black;
  --page-header-bg: #00afff;
  background-color: var(--page-header-bg);
}
.page-header.page-header-blue:before {
  display: none;
}
.page-header.page-header-blue .btn {
  background-color: white;
  color: black;
}
@Media ( width >= 80rem ) {
  .page-header h1 {
    font-size: 2.9375rem;
  }
}
@Media ( width >= 48rem ) {
  .page-header h1 {
    font-size: 3.375rem;
  }
}
.page-header .credentials {
  display: block;
  font-size: 0.55em;
  line-height: 1.3;
}

.page-header-text-wrapper {
  width: 100%;
  text-wrap: balance;
  margin-inline: auto;
  padding-inline: 1rem;
}
@Media ( width >= 40rem ) {
  .page-header-text-wrapper {
    max-width: calc(40rem - 1.5rem);
  }
}
@Media ( width >= 48rem ) {
  .page-header-text-wrapper {
    padding-inline: 1.5rem;
    max-width: calc(48rem - 1.5rem);
  }
}
@Media ( width >= 64rem ) {
  .page-header-text-wrapper {
    padding-inline: 2rem;
    max-width: calc(64rem - 1.5rem);
  }
  .lg\:header-min-height {
    min-height: 26.6875rem;
  }
  .page-header-image-text-wrapper {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, calc(var(--wrapper-max-width) / 2)) minmax(0, calc(var(--wrapper-max-width) / 2)) minmax(0, 1fr);
  }
  .page-header-text-wrapper {
    grid-column: 2/3;
    display: flex;
    align-items: center;
  }
  .page-header-no-image .page-header-text-wrapper, .page-header-title-indent .page-header-text-wrapper {
    grid-column: 2/4;
    max-width: none;
  }
  .page-header-img-wrapper {
    grid-column: 3/-1;
  }
}
.page-header-img-wrapper {
  position: relative;
  background-color: rgba(0, 0, 0, 0.15);
  order: 2;
  max-height: 26.6875rem;
}
.page-header-img-wrapper > .contextual-region,
.page-header-img-wrapper picture,
.page-header-img-wrapper img {
  max-height: inherit;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 960/427;
}
@Media ( width >= 64rem ) {
  .page-header-img-wrapper > .contextual-region,
  .page-header-img-wrapper picture,
  .page-header-img-wrapper img {
    aspect-ratio: unset;
  }
}

.add-graphic-devices .page-header-graphic {
  width: 300px;
  aspect-ratio: 4/3;
  position: absolute;
  overflow: hidden;
}
.add-graphic-devices .page-header-graphic:after {
  content: "";
  display: block;
  position: absolute;
  inset: -100%;
  background-image: url("/themes/custom/mmu/images/bg-repeat.svg");
  background-size: calc(60px/3) calc(200px/3);
  transform: rotate(315deg);
}

@Media ( width >= 64rem ) {
  .page-header-overlay {
    width: 100%;
    height: 100%;
    isolation: isolate;
    position: absolute;
    z-index: 1;
  }
}
.page-header-mask {
  left: -1px;
  top: -1px;
  right: -1px;
  bottom: -1px;
}

@Media ( width >= 64rem ) {
  .page-header-right-image .page-header-img-wrapper,
  .page-header-right-image .page-header-text-wrapper {
    position: relative;
  }
  .page-header-full-image .page-header-img-wrapper {
    grid-column: 1/5;
    grid-row: 1;
  }
  .page-header-full-image .page-header-img-wrapper img {
    aspect-ratio: 4/1;
  }
  .page-header-full-image .page-header-text-wrapper {
    grid-column: 1/5;
    grid-row: 2;
    width: 100%;
  }
  @Media ( width >= 40rem ) {
    .page-header-full-image .page-header-text-wrapper {
      max-width: calc(40rem - 1.5rem);
    }
  }
  @Media ( width >= 48rem ) {
    .page-header-full-image .page-header-text-wrapper {
      padding-inline: 1.5rem;
      max-width: calc(48rem - 1.5rem);
    }
  }
  @Media ( width >= 64rem ) {
    .page-header-full-image .page-header-text-wrapper {
      padding-inline: 2rem;
      max-width: calc(64rem - 1.5rem);
    }
  }
  @Media ( width >= 80rem ) {
    .page-header-full-image .page-header-text-wrapper {
      max-width: calc(80rem - 1.5rem);
    }
  }
  @Media ( width >= 96rem ) {
    .page-header-full-image .page-header-text-wrapper {
      max-width: calc(96rem - 1.5rem);
    }
  }
}
.page-header-title-indent .page-header-text-wrapper,
.page-header-title-indent .page-header-img-wrapper {
  position: static;
  grid-column: 1/5;
  order: unset;
}
.page-header-title-indent .page-header-text-wrapper {
  position: relative;
  width: 100%;
  margin-inline: auto;
}
@Media (width >= 48rem) {
  .page-header-title-indent .page-header-text-wrapper {
    max-width: calc(0.8 * 48rem);
  }
}
@Media (width >= 64rem) {
  .page-header-title-indent .page-header-text-wrapper {
    max-width: calc(0.7 * 64rem);
  }
}
@Media (width >= 80rem) {
  .page-header-title-indent .page-header-text-wrapper {
    max-width: calc(0.6 * 80rem);
  }
}
@Media (width >= 96rem) {
  .page-header-title-indent .page-header-text-wrapper {
    max-width: calc(0.5 * 96rem);
  }
}
.page-header-title-indent .page-header-text-wrapper > div {
  position: relative;
  padding-inline: 2rem;
  margin-inline: -2rem;
}
@Media ( width >= 40rem ) {
  .page-header-title-indent .page-header-text-wrapper > div {
    margin-top: -4rem;
  }
}
@Media ( width >= 48rem ) {
  .page-header-title-indent .page-header-text-wrapper > div {
    margin-inline: -3.375rem;
  }
}
@Media ( width >= 64rem ) {
  .page-header-title-indent .page-header-text-wrapper > div {
    margin-inline: -4rem;
  }
}
.page-header-title-indent .page-header-text-wrapper > div:before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  background-color: var(--body-background-color);
  -webkit-mask-image: linear-gradient(180deg, white 50%, rgba(255, 255, 255, 0) 100%);
          mask-image: linear-gradient(180deg, white 50%, rgba(255, 255, 255, 0) 100%);
}
.page-header-title-indent .page-header-text-wrapper > div > * {
  position: relative;
  z-index: 1;
}
.page-header-title-indent .page-header-img-wrapper {
  max-height: 26.6875rem;
}

.in-page-menu-mobile-dropdown {
  cursor: pointer;
}

.icon-dropdown:after {
  position: absolute;
  top: calc(50% - 5px);
  right: 20px;
  display: block;
  width: 10px;
  height: 10px;
  content: "";
  transform: rotate(135deg);
  transform-origin: center center;
  border-width: 2px 2px 0 0;
  border-style: solid;
  border-color: inherit;
}

[id=in-page-menu-section-links] li:last-of-type .u-border-r {
  display: none !important;
}

.node-type--staff-profile .page-header-img-wrapper {
  background-color: transparent;
}

.page-header-image-profile {
  height: 100%;
  position: relative;
  align-content: center;
  background-position: -1000vw center;
  background-repeat: no-repeat;
}
.page-header-image-profile > .contextual-region,
.page-header-image-profile > picture {
  position: absolute;
  inset: 0;
  z-index: 2;
  -webkit-mask-image: linear-gradient(180deg, white 0%, rgba(255, 255, 255, 0) 66.666%);
          mask-image: linear-gradient(180deg, white 0%, rgba(255, 255, 255, 0) 66.666%);
  opacity: 0.8;
}
.page-header-image-profile > .contextual-region img,
.page-header-image-profile > picture img {
  -o-object-fit: cover;
     object-fit: cover;
}
@Media ( width >= 40rem ) {
  .page-header-image-profile {
    min-height: 26.6875rem;
  }
}
.page-header-image-profile:after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  z-index: 3;
  backdrop-filter: blur(5px);
}
.page-header-image-profile > .page-header-image-profile-inner {
  align-content: center;
  inset: 0;
  z-index: 4;
  margin-inline: auto;
  min-height: inherit;
  position: relative;
  max-height: 26.6875rem;
  aspect-ratio: 1/1;
  height: 100%;
  width: auto;
  display: grid;
  grid-template-areas: "profile-image";
  justify-items: center;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 100px rgba(0, 0, 0, 0.2705882353);
  border-radius: 50%;
  scale: 1.05;
  transform-origin: 50% 33%;
}
@Media ( width < 40rem ) {
  .page-header-image-profile > .page-header-image-profile-inner {
    height: 80vw;
  }
}
.page-header-image-profile > .page-header-image-profile-inner:before, .page-header-image-profile > .page-header-image-profile-inner:after {
  position: absolute;
  content: "";
  display: block;
  border-radius: 100%;
  aspect-ratio: 1/1;
  width: 100%;
  grid-area: profile-image;
}
.page-header-image-profile > .page-header-image-profile-inner:before {
  z-index: 2;
  width: calc(100% - 0.1875rem);
  box-shadow: 0 0 0 0.375rem white;
}
.page-header-image-profile > .page-header-image-profile-inner:after {
  z-index: 3;
  box-shadow: inset 0 0 0.75rem white;
}
.page-header-image-profile .page-header-image-profile-inner picture,
.page-header-image-profile .page-header-image-profile-inner img {
  grid-area: profile-image;
  aspect-ratio: 1/1;
  overflow: hidden;
  width: 100%;
  height: 100%;
  max-height: inherit;
  min-height: inherit;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  margin-inline: auto;
  border-radius: 50%;
  position: relative;
  z-index: 1;
}

.profiles .tabs {
  margin-left: -0.75rem;
  padding-inline: 0.75rem;
  -webkit-mask-image: linear-gradient(90deg, Rgb(255 255 255/0%) 0px, white 12px, white calc(100% - 12px), Rgb(255 255 255/0%) 100%);
          mask-image: linear-gradient(90deg, Rgb(255 255 255/0%) 0px, white 12px, white calc(100% - 12px), Rgb(255 255 255/0%) 100%);
}
.profiles .tabs-title {
  padding: 0.75rem 0.5rem 0rem;
  width: 8.25rem;
  isolation: isolate;
}
.profiles .tabs-title:after {
  content: "";
  display: none;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 1rem;
  border-top-width: 0;
  border-color: transparent transparent var(--primary);
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: calc(50% - 1rem);
}
.profiles .tabs-title {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .profiles .tabs-title {
    width: 10.25rem;
  }
}
.profiles .tabs-title.is-active:after {
  display: block;
}

.profile-listing {
  position: relative;
  isolation: isolate;
}
.profile-listing:before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-color: light-dark(rgba(255, 255, 255, 0.66666), rgba(255, 255, 255, 0.05));
  mix-blend-mode: color-burn;
}
.page-section[class*=u-bg-mmu-] .profile-listing:before {
  background-color: rgba(255, 255, 255, 0.25);
  mix-blend-mode: overlay;
}

.profile-layout--RTwF {
  padding: 1rem;
  display: flex;
  gap: 1rem;
  width: -moz-fit-content;
  width: fit-content;
}
@Media (width >= 48rem) {
  .profile-layout--RTwF {
    padding: 2rem;
    min-width: 12.5rem;
    max-width: 17.1875rem;
    flex-direction: column;
    margin-inline: auto;
    text-align: center;
  }
  .rtwf-feature-left .profile-layout--RTwF {
    margin-right: 0;
  }
  .rtwf-feature-right .profile-layout--RTwF {
    margin-left: 0;
  }
}

.profile-image a {
  border-radius: 100%;
  display: grid;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  grid-template-areas: "profile-image";
  justify-items: center;
  align-items: center;
  justify-content: center;
}
.profile-image a :is(.contextual-region, picture, img) {
  grid-area: profile-image;
  transition: 0.25s ease-out border-color, 0.25s ease-out box-shadow;
}
.profile-image a:after {
  position: relative;
  content: "";
  display: block;
  box-shadow: inset 0 0 0.75rem rgba(255, 255, 255, 0);
  transition: 0.25s ease-out box-shadow;
  border-radius: 100%;
  aspect-ratio: 1/1;
  width: calc(100% - 0.75rem);
  grid-area: profile-image;
}
.profile-image a:is(:hover, :focus) img {
  border-color: white;
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(128, 128, 128, 0.5));
}
.profile-image a:is(:hover, :focus):after {
  box-shadow: inset 0 0 0.75rem white;
}
.profile-image img {
  display: flex;
  margin-inline: auto;
  width: 100%;
  max-width: 6.25rem;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 100%;
  border: 0.375rem solid color-mix(in srgb, currentColor 10%, transparent);
  overflow: hidden;
}
@Media (width >= 48rem) {
  .profile-image img {
    min-width: 10rem;
    max-width: 13.375rem;
  }
}

.quote-profile-item {
  padding-top: 0.5rem;
  padding-bottom: 1.5rem;
  margin-inline: auto;
  display: grid;
  gap: 0.5rem;
  text-align: center;
  align-items: center;
}
.quote-profile-item img {
  display: flex;
  margin-inline: auto;
  width: 100%;
  max-width: 8.5rem;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 100%;
  border: 0.375rem solid color-mix(in srgb, currentColor 10%, transparent);
  transition: 0.25s ease-out border-color, 0.25s ease-out box-shadow;
}
.quote-profile-item:is(:hover, :focus) img {
  border-color: white;
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
}

.profile-item-no-testimonial img {
  max-height: 34.375rem;
}

.profile-listing.profile-layout--featured {
  display: grid;
  grid-template-columns: 6.25rem auto;
  padding: 1rem;
  gap: 1rem;
  align-items: center;
}
@Media (width >= 48rem) {
  .profile-listing.profile-layout--featured {
    gap: 2rem;
    grid-template-columns: 13.75rem auto;
  }
}
.profile-listing.profile-layout--featured .profile-image {
  align-self: start;
}

.profile-layout--basic {
  padding: 1rem;
  display: grid;
  gap: 1rem;
  height: 100%;
  grid-template-columns: 6.25rem auto;
  align-items: center;
}
@Media (width >= 40rem) {
  .profile-layout--basic {
    grid-template-columns: auto;
    align-items: start;
  }
}

@Media ( width >= 64rem ) {
  .profiles-list.component--staff-profile-groupings {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}

.staff-profile {
  margin-left: auto;
  margin-right: auto;
  padding: 1rem;
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .staff-profile {
    padding: 1.5rem;
  }
}

.staff-profile-layout--event {
  margin-left: -1.5rem;
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .staff-profile-layout--event {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.staff-profile-layout--event {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .staff-profile-layout--event {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
.staff-profile-layout--featured {
  width: -moz-fit-content;
  width: fit-content;
}
.staff-profile-layout--featured .staff-profile__content-wrapper {
  text-align: center;
  margin-top: 1rem;
}
.staff-profile-layout--featured {
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .staff-profile-layout--featured {
    margin-left: 0;
    display: grid;
    grid-template-columns: minmax(15.625rem, 0.6fr) auto;
    gap: 1rem;
    align-items: start;
  }
  .staff-profile-layout--featured .staff-profile__content-wrapper {
    text-align: left;
    margin-top: 0;
  }
}
.staff-profile-layout--featured {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .staff-profile-layout--featured {
    grid-template-columns: 12.8125rem auto;
  }
}
.staff-profile-layout--RTwF {
  width: -moz-fit-content;
  width: fit-content;
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .staff-profile-layout--RTwF {
    width: 100%;
  }
}
.staff-profile-layout--RTwF .staff-profile__image-wrapper {
  min-width: 15.625rem;
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .staff-profile-layout--RTwF .staff-profile__image-wrapper {
    min-width: 0;
  }
}
.staff-profile-layout--text_only a {
  display: grid;
  height: 100%;
  align-content: center;
  text-wrap: balance;
  padding-block: 1rem;
  padding-inline: 1rem;
  border-left-width: 0.5rem;
  border-left-style: solid;
  border-left-color: var(--primary);
  text-decoration: none;
}
@Media ( width >= 48rem ) {
  .staff-profile-layout--text_only a {
    padding-inline: 1.5rem;
  }
}
.staff-profile-layout--text_only a.profile-listing:before {
  box-shadow: 0 0 0 rgba(128, 128, 128, 0);
  transition: 0.25s ease-out background-color, 0.25s ease-out box-shadow;
}
.staff-profile-layout--text_only a:is(:hover, :focus).profile-listing:before {
  box-shadow: 0 0 2rem light-dark(rgba(128, 128, 128, 0.1), rgba(0, 0, 0, 0.2));
  background-color: light-dark(rgb(255, 255, 255), rgba(255, 255, 255, 0.1));
}

.staff-profile-header .title,
.staff-profile-header .given,
.staff-profile-header .family,
.staff-profile-header .credentials,
.name-title,
.name-given,
.name-family,
.name-credentials {
  word-break: break-word;
}
.staff-profile-header .title:empty,
.staff-profile-header .given:empty,
.staff-profile-header .family:empty,
.staff-profile-header .credentials:empty,
.name-title:empty,
.name-given:empty,
.name-family:empty,
.name-credentials:empty {
  display: none;
}

.what-i-do > * {
  width: 100%;
  max-width: 9.375rem;
}
.what-i-do a img {
  will-change: opacity;
  transition: opacity 0.2s ease;
}
.what-i-do a:hover img {
  opacity: 0.5;
}

/* stylelint-disable-line */
.node-type--staff-profile .profiles {
  margin-top: 3rem;
}
@Media ( width >= 64rem ) {
  .node-type--staff-profile .tabs.tabbed-content {
    gap: 0.5rem;
    flex-wrap: wrap;
  }
}
.node-type--staff-profile .lg\:u-w-2\/3 > picture {
  margin-block: 3rem;
}
.node-type--staff-profile .tabs-control:has(select[data-tabs-target] option:only-child),
.node-type--staff-profile .tabs-control:has(.tabs li:only-child) {
  display: none !important;
}

.node-type--staff-profile .video-embed {
  height: auto;
}

.tabs-panel.is-active {
  display: block;
}

.tabs-panel {
  display: none;
}

.tabs.tabbed-content {
  position: relative;
  list-style: none;
  padding: 0;
  margin-bottom: 0;
}
.tabs.tabbed-content.tabs--vertical .tabs-title:not(:first-child) {
  margin-top: 1px;
}
.tabs.tabbed-content.tabs--horizontal .tabs-title:not(:first-child) {
  margin-left: 1px;
}
.tabs.tabbed-content {
  /* stylelint-disable-line */
}
@Media ( width >= 40rem ) {
  .tabs.tabbed-content {
    display: flex;
  }
}
.tabs.tabbed-content {
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .tabs.tabbed-content {
    font-size: 1.25rem;
  }
}
.tabs.tabbed-content {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .tabs.tabbed-content {
    font-size: 1.25rem;
  }
}

.tabs.tabbed-content.tabs--horizontal {
  text-align: center;
}

.tabs-wrapper {
  /* Staff profiles specific styling for sidebar news articles */
}
.tabs-wrapper .main-sidebar .row {
  margin: 0;
}
.tabs-wrapper .main-sidebar .row > * + * {
  margin-top: 24px;
}

/* stylelint-disable-line */
@Media ( width >= 64rem ) {
  .lg\:u-bg-grey-50-transparent {
    background-color: Rgb(0 0 0/9%);
  }
}
.taxonomy-select {
  --primary: #000;
  --primary-contrast: #fff;
}
.taxonomy-select .u-o-1 > * + .custom-select-wrapper {
  margin-top: 0rem !important;
}

.timeline:before {
  position: absolute;
  height: 100%;
  background-color: #002f6c;
  left: 20px;
  width: 2px;
  content: "";
}
.timeline {
  /* stylelint-disable-line */
}
@Media ( width >= 48rem ) {
  .timeline:before {
    left: 50%;
  }
}

.has-dark-bg .triptych-button {
  background-color: white;
  color: #002f6c !important;
}

.welcome-login-form {
  align-items: flex-end;
}
.welcome-login-form input[name=student_id] {
  border-radius: 0.375rem 0 0 0.375rem;
  padding-right: 0;
  background-color: black;
  border-color: black;
  color: white;
}
.welcome-login-form input[name=student_id]:focus {
  box-shadow: inset 0 0 6.25rem black;
}
.welcome-login-form .form-item--error ~ input.form-submit {
  align-self: flex-start;
  margin-top: 22px;
}
.welcome-login-form .form-item--error-text {
  color: #9e1500;
}
.welcome-login-form input.form-submit {
  border-radius: 0 0.375rem 0.375rem 0;
  color: black;
  text-decoration: none;
  border-width: 2px;
  border-style: solid;
  border-color: rgb(0, 0, 0);
  background-color: white;
  transition: background-color 0.25s ease-out;
}
.welcome-login-form input.form-submit:is(:hover, :focus) {
  background-color: #c7cdcc;
}

.welcome-course-daterange {
  /* Markup structure -> @atoms/_field.twig */
}
.welcome-course-daterange > div:first-child {
  font-weight: 700;
}
.welcome-course-daterange time {
  display: inline-block;
}

.stylised-items ol li {
  list-style: none;
  position: relative;
  margin-top: 0.666em;
}
.stylised-items ol li:before {
  content: "";
  display: inline-flex;
  width: 1.125rem;
  aspect-ratio: 1/1;
  position: absolute;
  top: 0.25rem;
  right: calc(100% + 0.625rem);
  background-color: var(--primary);
  border-radius: 100%;
  z-index: 1;
}
.stylised-items ol li:not(:last-child):after {
  content: "";
  display: block;
  position: absolute;
  background-color: var(--primary);
  right: calc(100% + 1.125rem);
  width: 0.125rem;
  height: 100%;
  top: 1.25rem;
}

.whats-new {
  container-type: inline-size;
}

.whats-new-tabs a {
  font-size: var(--input-ui-size);
  color: currentColor;
  text-decoration: none;
  display: flex;
  align-items: center;
  padding: 0.125rem;
  border-radius: 0.375rem;
}
.whats-new-tabs a span {
  align-content: center;
  position: relative;
  width: 1em;
  height: 1em;
  border-radius: 50%;
  background-color: light-dark(white, black);
}
.whats-new-tabs a span:before,
.whats-new-tabs a span:after {
  content: "";
  width: inherit;
  height: inherit;
  position: absolute;
  border-radius: inherit;
  top: 0;
  left: 0;
}
.whats-new-tabs a span:before {
  color: currentColor;
  border: 0.125rem solid var(--input-border);
}
.whats-new-tabs a span:after {
  scale: 0;
  box-shadow: inset 1em 1em var(--form-control-color);
  background-color: CanvasText;
  will-change: scale;
  transition: ease-out 0.33s scale;
}
.whats-new-tabs .is-active a span:after {
  scale: 0.5;
}

.whats-new-grid {
  display: grid;
  gap: 2rem;
}
@Media ( width >= 64rem ) {
  .whats-new-grid {
    grid-template-columns: repeat(2, calc(50% - 1rem));
  }
}

a[href].whats-new-object {
  display: grid;
  align-content: stretch;
  height: 100%;
  align-items: flex-start;
  text-decoration: none;
  background-color: light-dark(white, rgb(31.875, 31.875, 31.875));
  transition: ease-out 0.2s background-color, ease-out 0.2s box-shadow, ease-out 0.1s transform;
  box-shadow: 0 0 2rem light-dark(rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.333));
}
a[href].whats-new-object:is(:hover, :focus) {
  transform: scale(1.02);
  background-color: light-dark(white, rgb(63.75, 63.75, 63.75));
  box-shadow: 0 0 0.5rem light-dark(rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.166));
}
a[href].whats-new-object:is(:hover, :focus) .wn-image-container {
  animation: increasedBrightness 0.8s forwards;
}
@Media ( width >= 64rem ) {
  a[href].whats-new-object {
    grid-template-columns: repeat(2, 50%);
  }
}

.whats-new-item:is(:nth-child(1), :nth-child(2)) .wn-image-container {
  width: 100%;
  max-width: 100cqw;
}
.whats-new-item:is(:nth-child(1), :nth-child(2)) .wn-image-container :is(img, picture) {
  aspect-ratio: 1/1;
  max-width: 100cqw;
  width: 100%;
  height: 100%;
}
@media (width >= 48rem) {
  .whats-new-item:is(:nth-child(1), :nth-child(2)) .wn-image-container :is(img, picture) {
    aspect-ratio: 2/1;
  }
  .whats-new-item:is(:nth-child(1), :nth-child(2)) a[href].whats-new-object {
    grid-template-columns: 1fr;
  }
}

@media (width >= 40rem) {
  .whats-new-item:not(:nth-child(1), :nth-child(2)) a[href].whats-new-object {
    flex-direction: row;
    min-height: calc(25cqw - 8px);
  }
  .whats-new-item:not(:nth-child(1), :nth-child(2)) a[href].whats-new-object > * {
    flex: 1 1 50%;
  }
  .whats-new-item:not(:nth-child(1), :nth-child(2)) a[href].whats-new-object .wn-image-container {
    width: 100%;
    height: 100%;
  }
  .whats-new-item:not(:nth-child(1), :nth-child(2)) a[href].whats-new-object .wn-image-container * {
    width: inherit;
    height: inherit;
  }
}
@media (width >= 80rem) {
  .whats-new-item:not(:nth-child(1), :nth-child(2)) {
    min-height: calc(20cqw - 8px);
  }
}

@keyframes increasedBrightness {
  0% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.5);
  }
  100% {
    filter: brightness(1);
  }
}
.wn-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 1rem;
  gap: 0.5rem;
  height: 100%;
}
@media (width >= 40rem) and (width < 64rem) {
  .whats-new-item:nth-child(even):not(:nth-child(2)) .wn-content {
    order: -1;
  }
}
@media (width >= 64rem) {
  .whats-new-item:nth-child(4n+3) .wn-content, .whats-new-item:nth-child(4n+4) .wn-content {
    order: -1;
  }
}
.wn-content .wn-post-date,
.wn-content p,
.wn-content time {
  font-weight: 400;
  text-wrap: balance;
}
.wn-content h3 {
  font-size: 1.5rem;
  margin-bottom: 0;
  text-wrap: balance;
}
.wn-content h3, .wn-content p {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -Webkit-box-orient: vertical;
  -Webkit-line-clamp: 8;
}

.wn-news-tag-and-date {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  margin-top: auto;
}

.wn-smartdate {
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: 0.5rem;
       column-gap: 0.5rem;
}

.wn-tag {
  border-radius: 0.375rem;
  border: 0.0625rem solid color-mix(in srgb, currentColor 50%, transparent);
  padding: 0.25rem 0.5rem;
  font-size: 1rem;
  font-weight: 400;
  display: flex;
  gap: 0.5rem;
  margin-top: auto;
}
.wn-tag img {
  opacity: 0.75;
}
.wn-tag svg {
  color: color-mix(in srgb, currentColor 75%, transparent);
}

:is(.whats-new__image, .image__whats-new) {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}
:is(.whats-new__image, .image__whats-new) img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.whats-new__image--standard :is(img, picture) {
  aspect-ratio: 3/2;
}

.wn-item-featured .wn-image-container {
  background-color: inherit;
  position: relative;
  overflow: hidden;
}
.wn-item-featured .wn-image-container:before {
  position: absolute;
  z-index: 1;
  content: "Featured";
  display: block;
  top: -0.0625rem;
  left: -0.0625rem;
  background-color: inherit;
  padding: 0.25rem 0.75rem;
  border-radius: 0 0 4px 0;
}

#location .inline-flex-divider {
  overflow: hidden;
  -moz-column-gap: 3.0625rem;
       column-gap: 3.0625rem;
  row-gap: 1.0625rem;
}
#location .inline-flex-divider > div {
  position: relative;
  margin: 0.5rem;
}
#location .inline-flex-divider > div:before, #location .inline-flex-divider > div:after {
  content: "";
  display: block;
  position: absolute;
  opacity: 0.25;
}
#location .inline-flex-divider > div:before {
  left: -2rem;
  height: 100%;
  border-left: 1px solid;
}
#location .inline-flex-divider > div:after {
  top: -0.9375rem;
  width: 100%;
  border-top: 1px solid;
}

.event-detail-sidebar {
  /* stylelint-disable-line */
}
@Media ( width >= 64rem ) {
  .event-detail-sidebar {
    border-left: 0.0625rem solid #e0e0e0;
    padding-left: 2rem;
  }
}

.body-background-color {
  background-color: var(--body-background-color);
}

.body-color {
  color: var(--body-color);
}

.map-border {
  border: 1px solid color-mix(in srgb, currentColor 25%, transparent);
}

.node-type--event a[data-fancybox] :is(picture, img) {
  margin-inline: auto;
  width: auto;
  max-height: inherit;
}

.news-content {
  display: grid;
  gap: 2.625rem;
}
@media (width >= 64rem) {
  .news-content {
    grid-template-columns: 2fr 1fr;
  }
}

.news-sidebar {
  display: grid;
  gap: 2rem;
  align-content: space-between;
}

@media (width >= 64rem) {
  #top-stories {
    order: 1;
  }
  #related-info {
    order: 2;
  }
  #news-cta-block {
    order: 3;
  }
  #related-stories {
    grid-column: 1/-1;
    grid-row: 2;
  }
}
#top-stories .news-card-wrap {
  padding-top: 1.25rem;
  padding-bottom: 0.625rem;
  border-bottom-width: 2px;
  border-bottom-style: solid;
  -o-border-image: linear-gradient(to right, rgba(162, 162, 162, 0.33333), transparent) 1;
     border-image: linear-gradient(to right, rgba(162, 162, 162, 0.33333), transparent) 1;
  border-image-slice: 0 0 1 0;
}

#related-info {
  display: grid;
  gap: 1.625rem;
}

#related-stories .post-type {
  background-color: light-dark(#dcdada, #242626);
}

.cs-bg-primary {
  background-color: var(--primary);
}

.cs-bg-primary-contrast {
  background-color: var(--primary-contrast);
}

.cs-bg-primary-interact {
  background-color: var(--primary-interact);
}

.cs-bg-accent-1 {
  background-color: var(--accent-1);
}

.cs-bg-accent-1-contrast {
  background-color: var(--accent-1-contrast);
}

.cs-bg-accent-1-interact {
  background-color: var(--accent-1-interact);
}

.cs-bg-accent-2 {
  background-color: var(--accent-2);
}

.cs-bg-accent-2-contrast {
  background-color: var(--accent-2-contrast);
}

.cs-bg-accent-2-interact {
  background-color: var(--accent-2-interact);
}

@media (min-width: 48rem) {
  .md\:cs-bg-primary {
    background-color: var(--primary);
  }
  .md\:cs-bg-accent-1 {
    background-color: var(--accent-1);
  }
  .md\:cs-bg-accent-2 {
    background-color: var(--accent-2);
  }
}
/*
.hocus\:cs-bg-primary {
  &:hover,
  &:focus {
    background-color: var(--primary);
  }
}
.hocus\:cs-bg-primary-interact {
  &:hover,
  &:focus {
    background-color: var(--primary-interact);
  }
}
.hocus\:cs-bg-accent-1 {
  &:hover,
  &:focus {
    background-color: var(--accent-1);
  }
}
.hocus\:cs-bg-accent-1-interact {
  &:hover,
  &:focus {
    background-color: var(--accent-1-interact);
  }
}
.hocus\:cs-bg-accent-2 {
  &:hover,
  &:focus {
    background-color: var(--accent-2);
  }
}
.hocus\:cs-bg-accent-2-interact {
  &:hover,
  &:focus {
    background-color: var(--accent-2-interact);
  }
}
*/
.cs-text-primary {
  color: var(--primary);
}

.cs-text-primary-contrast {
  color: var(--primary-contrast);
}

.cs-text-accent-1 {
  color: var(--accent-1);
}

.cs-text-accent-1-contrast {
  color: var(--accent-1-contrast);
}

.cs-text-accent-2 {
  color: var(--accent-2);
}

.cs-text-accent-2-contrast {
  color: var(--accent-2-contrast);
}

/*
.group {
  &:hover,
  &:focus {
    .group-hocus\: {
      // Text Primary
      &cs-text-primary {
        color: var(--primary);
      }

      // BG Primary
      &cs-bg-primary {
        background-color: var(--primary);
      }

      // BG Primary Interact
      &cs-bg-primary-interact {
        background-color: var(--primary-interact);
      }
    }
  }
}
*/
/*

.hocus\:cs-text-primary {
  &:hover,
  &:focus {
    color: var(--primary);
  }
}
.hocus\:cs-text-primary-interact {
  &:hover,
  &:focus {
    color: var(--primary-interact);
  }
}
.hocus\:cs-text-accent-1-interact {
  &:hover,
  &:focus {
    color: var(--accent-1-interact);
  }
}
.hocus\:cs-text-accent-2-interact {
  &:hover,
  &:focus {
    color: var(--accent-2-interact);
  }
}
*/
.cs-fill-primary {
  fill: var(--primary);
}

.cs-fill-primary-contrast {
  fill: var(--primary-contrast);
}

.cs-fill-accent-1 {
  fill: var(--accent-1);
}

.cs-fill-accent-1-contrast {
  fill: var(--accent-1-contrast);
}

.cs-border-color-primary {
  border-color: var(--primary);
}

.cs-border-color-primary-contrast {
  border-color: var(--primary-contrast);
}

.cs-border-color-accent-1 {
  border-color: var(--accent-1);
}

.cs-border-color-accent-1-contrast {
  border-color: var(--accent-1-contrast);
}

.cs-border-color-accent-2 {
  border-color: var(--accent-2);
}

.cs-border-color-accent-2-contrast {
  border-color: var(--accent-2-contrast);
}

/*
.group {
  &:hover,
  &:focus {
    .group-hocus\: {
      // Fill Primary Interact
      &cs-fill-primary-interact {
        fill: var(--primary-interact);
      }
    }
  }
}
*/
a[class].btn-cs-primary {
  color: var(--primary-contrast);
  background-color: var(--primary);
}
a[class].btn-cs-primary:is(:active, :focus, :hover) {
  color: var(--primary-contrast-interact);
  background-color: var(--primary-interact);
}

a[class].btn-cs-accent-1 {
  color: var(--accent-1-contrast);
  background-color: var(--accent-1);
  border-color: var(--accent-1);
}
a[class].btn-cs-accent-1:is(:active, :focus, :hover) {
  color: var(--accent-1-contrast-interact);
  background-color: var(--accent-1-interact);
}

a[class].btn-cs-accent-2 {
  color: var(--accent-2-contrast);
  background-color: var(--accent-2);
  border-color: var(--accent-2);
}
a[class].btn-cs-accent-2:is(:active, :focus, :hover) {
  color: var(--accent-2-contrast-interact);
  background-color: var(--accent-2-interact);
}

/*
.group.is-active {
  // When the group.is-active

  .group-is-active\:cs-bg-accent-1 {
    background-color: var(--accent-1);
  }

  .group-is-active\:cs-text-accent-1-contrast {
    color: var(--accent-1-contrast);
  }

  .group-is-active\:hocus\:cs-bg-accent-1-interact {
    &:hover,
    &:focus {
      background-color: var(--accent-1-interact);
    }
  }

  .group-is-active\:hocus\:cs-text-accent-1-contrast-interact {
    &:hover,
    &:focus {
      color: var(--accent-1-contrast-interact);
    }
  }
}
*/
.foundation-mq {
  font-family: "small=0em&xs=0em&sm=40em&md=48em&medium=48em&lg=64em&xl=80em&xxl=96em";
}

:root {
  --mmu-blue: #00afff;
  --mmu-blue-light: #c9ddff;
  --mmu-cream: #f2f0f0;
  --mmu-silver-light: #c7cdcc;
  --mmu-silver: #8799a8;
  --mmu-rose: #fe7086;
  --mmu-green: #a6eaa8;
  --mmu-yellow: #ffd74a;
  --mmu-orange: #f68300;
  --mmu-red: #af1700;
  --accent-1: #fff;
  --accent-1-interact: #e6e6e6;
  --accent-1-contrast: #000;
  --accent-1-contrast-interact: #131313;
  --accent-2: #000;
  --accent-2-interact: #131313;
  --accent-2-contrast: #fff;
  --accent-2-contrast-interact: #e6e6e6;
  --primary: #00afff;
  --primary-interact: rgb(0, 157.85, 230.01);
  --primary-contrast: #000;
  --primary-contrast-interact: #131313;
}

#toolbar-administration :is([id=responsive-preview-toolbar-tab],
.contextual-toolbar-tab.toolbar-tab,
.toolbar-tab:nth-child(4):has(a[href*=shortcut]),
[id=admin-toolbar-search-tab] ~ .toolbar-tab) {
  display: none;
}
#toolbar-administration .toolbar-tray.toolbar-tray-horizontal > nav > .toolbar-menu-administration > .toolbar-menu {
  display: flex;
}
#toolbar-administration .toolbar-bar {
  position: fixed;
}
#toolbar-administration .toolbar-tray a {
  color: black;
  text-decoration-color: #00afff;
}

body.toolbar-icon-10 {
  padding-top: 39px !important;
}
body.toolbar-icon-10:has(h1:not(.default-h1)) .default-h1 {
  display: none;
}

.node-preview-container {
  z-index: 901;
}

html.dark-mode .episode .podcast_name,
html.dark-mode .episode .episode_name,
html.dark-mode .episode .meta p,
html.dark-mode .episode .description {
  color: #fff !important;
}

.gm-ui-hover-effect > span {
  background: black !important;
}

/*# sourceMappingURL=style.css.map */