/*!********************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/postcss-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./src/scss/index.scss ***!
  \********************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap);
/*!************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/postcss-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./src/scss/index.scss (1) ***!
  \************************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Titillium+Web:wght@400;600;700&display=swap);
/*!************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/postcss-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./src/scss/index.scss (2) ***!
  \************************************************************************************************************************************************************/
@charset "UTF-8";
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

* {
  margin: 0;
}

html {
  font-size: 10px;
}

body {
  font-size: 1.6rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body,
* {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings: "wdth" 100;
}

h1,
h2,
h3,
h4,
h5,
h6,
.title-wrapper {
  color: #001cb0;
  -webkit-margin-before: 1.75rem;
          margin-block-start: 1.75rem;
  -webkit-margin-after: 1.75rem;
          margin-block-end: 1.75rem;
}

p,
ol,
ul {
  margin-bottom: 1rem;
}

b,
strong {
  font-weight: 700;
}

h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child,
h6:first-child,
.title-wrapper:first-child,
ol:first-child,
ul:first-child,
p:first-child {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child,
.title-wrapper:last-child,
ol:last-child,
ul:last-child,
p:last-child {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}

h1 {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3rem;
  line-height: 1.25;
}

h2 {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 2.75rem;
  line-height: 1.25;
}

h3 {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2.25rem;
  line-height: 1.25;
}

h4 {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2rem;
  line-height: 1.25;
}

h5 {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2rem;
  line-height: 1.25;
}

h6 {
  color: #001cb0;
  font-size: 1.6rem;
}

.title-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}
.title-wrapper h1,
.title-wrapper h2,
.title-wrapper h3,
.title-wrapper h4,
.title-wrapper h5,
.title-wrapper h6 {
  margin: 0;
}
.title-wrapper .download-link {
  display: none;
}
@media (min-width: 992px) {
  .title-wrapper .download-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

table {
  -webkit-margin-before: 3rem;
          margin-block-start: 3rem;
  -webkit-margin-after: 3rem;
          margin-block-end: 3rem;
}
table:first-child {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
table:last-child {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}

title {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 2rem;
  line-height: 1.25;
  display: block;
  color: #001cb0;
  -webkit-margin-before: 3rem;
          margin-block-start: 3rem;
  -webkit-margin-after: 3rem;
          margin-block-end: 3rem;
}
title:has(+ table) {
  -webkit-margin-before: 3rem;
          margin-block-start: 3rem;
  -webkit-margin-after: 1.5rem;
          margin-block-end: 1.5rem;
}
title:first-child {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
title + table {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}

.download-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  padding: 0;
  color: #001cb0;
  font-weight: 600;
  text-decoration: underline;
  background-color: transparent;
  border: none;
}
.download-link svg {
  display: block;
  width: 24px;
  height: auto;
}

html {
  scroll-behavior: smooth;
}

body {
  --header-height: 65px;
  --breadcrumbs-height: 35px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 100dvh;
  overflow-x: hidden;
}
@media (min-width: 1200px) {
  body {
    --header-height: 110px;
  }
}
body:has(.header__search-popover--open), body:has(.header__mobile-menu-drawer--open) {
  overflow: hidden;
}
body:has(.search-results) .header .search__button:after {
  opacity: 1;
}
body > header {
  position: sticky;
  top: 0;
  z-index: 100;
}

main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  overflow: hidden;
}

.accordion {
  -webkit-border-before: solid 1.5px #001cb0;
          border-block-start: solid 1.5px #001cb0;
  -webkit-border-after: solid 1.5px #001cb0;
          border-block-end: solid 1.5px #001cb0;
  -webkit-margin-before: 3.5rem;
          margin-block-start: 3.5rem;
  -webkit-margin-after: 3.5rem;
          margin-block-end: 3.5rem;
}
.accordion__title {
  position: relative;
  color: #001cb0;
  font-weight: 600;
  padding-block: 10px;
  -webkit-padding-end: 24px;
          padding-inline-end: 24px;
  cursor: pointer;
}
.accordion__title:before, .accordion__title:after {
  content: "";
  width: 16px;
  height: 2px;
  position: absolute;
  top: 50%;
  right: 0;
  background-color: #001cb0;
  border-radius: 2px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: -webkit-transform 0.2s ease;
  transition: -webkit-transform 0.2s ease;
  transition: transform 0.2s ease;
  transition: transform 0.2s ease, -webkit-transform 0.2s ease;
}
.accordion__title:after {
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
}
.accordion__content {
  max-height: 0px;
  -webkit-transition: max-height 0.2s ease;
  transition: max-height 0.2s ease;
  overflow: hidden;
}
.accordion__content:before, .accordion__content:after {
  content: "";
  display: block;
  width: 100%;
  height: 24px;
}
@media (min-width: 1600px) {
  .accordion__content:before, .accordion__content:after {
    height: 40px;
  }
}
.accordion__content:before {
  height: 16px;
}
@media (min-width: 1600px) {
  .accordion__content:before {
    height: 32px;
  }
}
.accordion--open .accordion__title:before {
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}
.accordion--open .accordion__title:after {
  -webkit-transform: translateY(-50%) rotate(135deg);
          transform: translateY(-50%) rotate(135deg);
}
.accordion:has(+ .accordion) {
  -webkit-border-after: none;
          border-block-end: none;
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.accordion + .accordion {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}

.breadcrumbs {
  height: var(--breadcrumbs-height);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-inline: 30px;
  background-color: #f4f2f0;
  border-bottom: solid 1.5px #ccc;
  overflow: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.breadcrumbs:-webkit-scrollbar {
  display: none;
}
@media (min-width: 1200px) {
  .breadcrumbs {
    padding-inline: 100px;
  }
}
@media (min-width: 1600px) {
  .breadcrumbs {
    padding-inline: 160px;
  }
}
.breadcrumbs ul {
  list-style: none;
  list-style-type: none;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
}
.breadcrumbs ul li a {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #000;
  font-size: 12px;
  text-decoration: none;
  white-space: nowrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.breadcrumbs ul li a:after {
  content: "";
  position: relative;
  display: block;
  width: 10px;
  height: 10px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 192 512%27%3E%3Cpath d=%27M166.9 264.5l-117.8 116c-4.7 4.7-12.3 4.7-17 0l-7.1-7.1c-4.7-4.7-4.7-12.3 0-17L127.3 256 25.1 155.6c-4.7-4.7-4.7-12.3 0-17l7.1-7.1c4.7-4.7 12.3-4.7 17 0l117.8 116c4.6 4.7 4.6 12.3-.1 17z%27/%3E%3C/svg%3E");
  background-position: center;
  background-size: 50%;
  background-repeat: no-repeat;
  margin-left: 8px;
  pointer-events: none;
}
.breadcrumbs ul li:last-child a {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
.breadcrumbs ul li:last-child a:after {
  display: none;
}

.hero-banner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #001cb0;
  background-color: #fff;
}
.hero-banner__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px;
  padding: 30px;
  width: 280px;
}
@media (min-width: 992px) {
  .hero-banner__content {
    width: 300px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    gap: 16px;
    padding: 0;
    padding-block: 80px;
    -webkit-margin-start: 30px;
            margin-inline-start: 30px;
  }
}
@media (min-width: 1200px) {
  .hero-banner__content {
    width: 350px;
    -webkit-margin-start: 100px;
            margin-inline-start: 100px;
  }
}
@media (min-width: 1600px) {
  .hero-banner__content {
    -webkit-margin-start: 160px;
            margin-inline-start: 160px;
  }
}
.hero-banner__content:after {
  content: "";
  position: absolute;
  top: 0;
  left: calc(30px + var(--header-height) * 2 + var(--breadcrumbs-height));
  height: 100%;
  aspect-ratio: 1;
  background: linear-gradient(45deg, white 50%, transparent 50%);
  z-index: 1;
}
@media (min-width: 1200px) {
  .hero-banner__content:after {
    left: calc(100px + var(--header-height) * 2 + var(--breadcrumbs-height));
  }
}
@media (min-width: 1600px) {
  .hero-banner__content:after {
    left: calc(160px + var(--header-height) * 2 + var(--breadcrumbs-height));
  }
}
.hero-banner__icon, .hero-banner__title, .hero-banner__intro {
  position: relative;
  z-index: 2;
}
.hero-banner__icon {
  --icon-size: 40px;
  width: var(--icon-size);
  height: var(--icon-size);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-radius: var(--icon-size);
  background-color: var(--theme-color);
}
@media (min-width: 992px) {
  .hero-banner__icon {
    --icon-size: 60px;
  }
}
.hero-banner__icon svg {
  display: block;
  width: 50%;
  height: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.hero-banner__icon svg path {
  fill: #fff;
}
.hero-banner__icon:empty {
  display: none;
}
.hero-banner__title {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3rem;
  line-height: 1.25;
}
@media (min-width: 992px) {
  .hero-banner__title {
    width: 100%;
    -webkit-padding-after: 8px;
            padding-block-end: 8px;
    -webkit-border-after: solid 3px var(--theme-color);
            border-block-end: solid 3px var(--theme-color);
  }
}
.hero-banner__intro {
  width: 100%;
  -webkit-padding-before: 8px;
          padding-block-start: 8px;
  -webkit-border-before: solid 3px var(--theme-color);
          border-block-start: solid 3px var(--theme-color);
}
@media (min-width: 992px) {
  .hero-banner__intro {
    font-size: 1.8rem;
    -webkit-padding-before: 0;
            padding-block-start: 0;
    -webkit-border-before: none;
            border-block-start: none;
  }
}
@media (min-width: 1200px) {
  .hero-banner__intro {
    font-size: 2rem;
  }
}
.hero-banner__intro:empty {
  display: none;
}
.hero-banner__image {
  position: absolute;
  top: 0;
  left: calc(30px + var(--header-height) * 2 + var(--breadcrumbs-height));
  right: 0;
  width: calc(100% - (30px + var(--header-height) * 2 + var(--breadcrumbs-height)));
  height: 100%;
}
@media (min-width: 1200px) {
  .hero-banner__image {
    left: calc(100px + var(--header-height) * 2 + var(--breadcrumbs-height));
    width: calc(100% - (100px + var(--header-height) * 2 + var(--breadcrumbs-height)));
  }
}
@media (min-width: 1600px) {
  .hero-banner__image {
    left: calc(160px + var(--header-height) * 2 + var(--breadcrumbs-height));
    width: calc(100% - (160px + var(--header-height) * 2 + var(--breadcrumbs-height)));
  }
}
.hero-banner__image img {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

table {
  width: 100%;
  overflow: scroll;
  font-size: 12px;
}
table[format=standard] {
  display: block;
  border-collapse: collapse;
  border-bottom: solid 3px #000;
  overflow: scroll;
}
@media (min-width: 992px) {
  table[format=standard] {
    display: table;
  }
}
table[format=standard] tbody {
  width: 100%;
}
table[format=standard] th,
table[format=standard] td {
  padding: 0;
  min-width: 30vw;
}
@media (min-width: 576px) {
  table[format=standard] th,
  table[format=standard] td {
    min-width: 20vw;
  }
}
@media (min-width: 992px) {
  table[format=standard] th,
  table[format=standard] td {
    min-width: unset;
  }
}
table[format=standard] tr.thin-border td, table[format=standard] tr[format=thin-border] td {
  -webkit-padding-after: 10px;
          padding-block-end: 10px;
  border-bottom: solid 1px #000;
}
table[format=standard] tr:last-child td {
  -webkit-padding-after: 10px;
          padding-block-end: 10px;
}
table[format=standard] tr:has(th) + tr td {
  -webkit-padding-before: 10px;
          padding-block-start: 10px;
}
table[format=standard] tr:has(td):hover {
  position: relative;
}
table[format=standard] tr:has(td):hover td {
  background-color: #f4f2f0;
}
table[format=standard] th {
  padding-inline: 10px;
  -webkit-padding-after: 8px;
          padding-block-end: 8px;
  border-bottom: solid 3px #001cb0;
}
table[format=standard] th.shaded {
  background-color: transparent;
  padding-inline: 10px;
}
table[format=standard] th p {
  color: #001cb0;
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
}
table[format=standard] th p b,
table[format=standard] th p strong {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
table[format=standard] td {
  padding-inline: 10px;
  padding-block: 5px;
  background-clip: padding-box;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
}
table[format=standard] td.shaded {
  padding-inline: 10px;
}
table[format=standard] td h1 {
  color: #001cb0;
  font-size: 14px;
  margin-block: 8px;
}
table[format=notes], table[format=gri-reference] {
  border-collapse: collapse;
}
table[format=notes] tr th,
table[format=notes] tr td, table[format=gri-reference] tr th,
table[format=gri-reference] tr td {
  padding: 0;
  -webkit-padding-after: 8px;
          padding-block-end: 8px;
}
table[format=notes] tr:last-child th,
table[format=notes] tr:last-child td, table[format=gri-reference] tr:last-child th,
table[format=gri-reference] tr:last-child td {
  -webkit-padding-after: 0;
          padding-block-end: 0;
}
table[format=notes] p, table[format=gri-reference] p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
}
table[format=notes] p:before, table[format=gri-reference] p:before {
  content: "•";
}
table[format=notes] p {
  font-size: 12px;
  line-height: 16px;
}
table[format=bordered] {
  border-collapse: collapse;
}
table[format=bordered] th,
table[format=bordered] td {
  padding: 8px 16px;
}
table[format=bordered] th {
  display: table-cell;
  vertical-align: bottom;
  -webkit-padding-after: 8px;
          padding-block-end: 8px;
  border-bottom: solid 3px #001cb0;
}
table[format=bordered] th p {
  color: #001cb0;
  text-align: left;
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
table[format=bordered] th p b,
table[format=bordered] th p strong {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
table[format=bordered] td {
  border: solid 1px #000;
  vertical-align: top;
}
table th p {
  line-height: 14px;
}
table a {
  color: #001cb0;
  text-decoration: underline;
}
table .left p {
  text-align: left;
}
table .right p {
  text-align: right;
}
table .top {
  display: table-cell;
  vertical-align: top;
}
table .shaded,
table .highlight {
  background-color: #f4f2f0;
}

header .header__navbar {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  max-width: 100%;
  height: var(--header-height);
  padding-inline: 30px;
  color: #fff;
  border-bottom: solid 1.5px #ccc;
  overflow: hidden;
  z-index: 1;
}
@media (min-width: 1200px) {
  header .header__navbar {
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: end;
    padding-inline: 100px;
  }
}
@media (min-width: 1600px) {
  header .header__navbar {
    padding-inline: 160px;
  }
}
header .header__logo {
  height: 100%;
  aspect-ratio: 1;
  background-color: #fff;
}
header .header__logo img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
header .header__angle {
  position: relative;
  height: 100%;
  aspect-ratio: 1;
  background: linear-gradient(45deg, white 50%, #001cb0 50%);
}
header .header__angle::before {
  content: "";
  position: absolute;
  top: 0;
  right: 50%;
  width: 100vw;
  height: 100%;
  background-color: #fff;
  z-index: -1;
}
header .header__angle:after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 100vw;
  height: 100%;
  background-color: #001cb0;
  z-index: -1;
}
header .header__body {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
}
@media (min-width: 1200px) {
  header .header__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 8px;
  }
}
header .header__title {
  color: #fff;
  text-decoration: none;
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
@media (min-width: 1200px) {
  header .header__title {
    font-size: 24px;
  }
}
header .header__title span {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
}
header .header__links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
header .header__links * {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.4rem;
}
header .header__main-menu {
  display: none;
}
@media (min-width: 1200px) {
  header .header__main-menu {
    display: block;
  }
}
header .header__main-menu ul {
  list-style: none;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 36px;
}
header .header__main-menu ul li a {
  position: relative;
  display: block;
  color: #fff;
  font-size: 14px;
  text-decoration: none;
  padding-bottom: 16px;
}
header .header__main-menu ul li a:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 6px;
  background-color: var(--theme-color);
  opacity: 0;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
}
header .header__main-menu ul li a:hover:after, header .header__main-menu ul li a.current-page:after {
  opacity: 1;
}
header .header__main-menu ul li a.current-page {
  font-weight: 700;
}
header .header__toggles {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}
header .header__toggles button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  padding: 0;
  background-color: transparent;
  border: none;
}
header .header__toggles .search__button {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  cursor: pointer;
}
@media (min-width: 1200px) {
  header .header__toggles .search__button {
    padding-bottom: 16px;
  }
  header .header__toggles .search__button:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 6px;
    background-color: #ffe344;
    opacity: 0;
    -webkit-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
  }
  header .header__toggles .search__button:hover:after, header .header__toggles .search__button--open:after {
    opacity: 1;
  }
}
header .header__toggles .search__text {
  display: none;
  font-size: 14px;
}
@media (min-width: 1200px) {
  header .header__toggles .search__text {
    display: block;
  }
}
header .header__toggles .search__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .header__toggles .search__icon svg {
  width: 16px;
  height: auto;
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
}
header .header__toggles .search__icon svg path {
  fill: #fff;
}
header .header__toggles .mobile-menu__button {
  --button-size: 18px;
  --button-height: 18px;
  --button-line-width: 1.5px;
  grid-column-start: 2;
  grid-column-end: 3;
  grid-row-start: 1;
  grid-row-end: 2;
  display: inline-block;
  overflow: visible;
  margin: 0;
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
  -webkit-transition-duration: 0.15s;
          transition-duration: 0.15s;
  -webkit-transition-property: opacity, -webkit-filter;
  transition-property: opacity, -webkit-filter;
  transition-property: opacity, filter;
  transition-property: opacity, filter, -webkit-filter;
  text-transform: none;
  color: inherit;
  border: 0;
  background-color: transparent;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  cursor: pointer;
}
@media (min-width: 1200px) {
  header .header__toggles .mobile-menu__button {
    display: none;
  }
}
header .header__toggles .mobile-menu__button .hamburger-box {
  position: relative;
  display: inline-block;
  width: var(--button-size);
  height: var(--button-height);
}
header .header__toggles .mobile-menu__button .hamburger-box .hamburger-inner {
  position: absolute;
  top: 50%;
  display: block;
  width: var(--button-size);
  height: var(--button-line-width);
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
  -webkit-transition-duration: 0.15s;
          transition-duration: 0.15s;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  border-radius: var(--button-line-width);
  background-color: #fff;
  margin-top: -2px;
  -webkit-transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
          transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  -webkit-transition-duration: 75ms;
          transition-duration: 75ms;
}
header .header__toggles .mobile-menu__button .hamburger-box .hamburger-inner:before, header .header__toggles .mobile-menu__button .hamburger-box .hamburger-inner:after {
  content: "";
  position: absolute;
  display: block;
  width: var(--button-size);
  height: var(--button-line-width);
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
  -webkit-transition-duration: 0.15s;
          transition-duration: 0.15s;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  border-radius: var(--button-line-width);
  background-color: #fff;
}
header .header__toggles .mobile-menu__button .hamburger-box .hamburger-inner:before {
  top: calc(var(--button-height) / -3);
  -webkit-transition: top 75ms ease 0.12s, opacity 75ms ease;
  transition: top 75ms ease 0.12s, opacity 75ms ease;
}
header .header__toggles .mobile-menu__button .hamburger-box .hamburger-inner:after {
  bottom: calc(var(--button-height) / -3);
  right: 0px;
  -webkit-transition: bottom 75ms ease 0.12s, -webkit-transform 75ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
  transition: bottom 75ms ease 0.12s, -webkit-transform 75ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
  transition: bottom 75ms ease 0.12s, transform 75ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
  transition: bottom 75ms ease 0.12s, transform 75ms cubic-bezier(0.55, 0.055, 0.675, 0.19), -webkit-transform 75ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
header .header__toggles .mobile-menu__button--open .hamburger-box .hamburger-inner {
  -webkit-transition-delay: 0.12s;
          transition-delay: 0.12s;
  -webkit-transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  background-color: #fff;
}
header .header__toggles .mobile-menu__button--open .hamburger-box .hamburger-inner:before {
  top: 0;
  -webkit-transition: top 75ms ease, opacity 75ms ease 0.12s;
  transition: top 75ms ease, opacity 75ms ease 0.12s;
  opacity: 0;
}
header .header__toggles .mobile-menu__button--open .hamburger-box .hamburger-inner:after {
  width: var(--button-size);
  bottom: 0;
  -webkit-transition: bottom 75ms ease, -webkit-transform 75ms cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
  transition: bottom 75ms ease, -webkit-transform 75ms cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
  transition: bottom 75ms ease, transform 75ms cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
  transition: bottom 75ms ease, transform 75ms cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s, -webkit-transform 75ms cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
  left: 0;
  background-color: #fff;
}
header .header__search-popover {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  max-height: 0px;
  padding-inline: 30px;
  color: #001cb0;
  background-color: #f4f2f0;
  -webkit-transition: max-height 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  transition: max-height 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  overflow: hidden;
  -webkit-box-shadow: rgba(100, 100, 111, 0.5) 0px 7px 29px 0px;
          box-shadow: rgba(100, 100, 111, 0.5) 0px 7px 29px 0px;
}
@media (min-width: 1200px) {
  header .header__search-popover {
    padding-inline: 100px;
  }
}
header .header__search-popover--open {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
header .header__search-popover .search__inner {
  position: relative;
  width: 100%;
  padding-block: 64px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}
header .header__search-popover .search__close {
  position: absolute;
  top: 48px;
  right: 0;
  width: 15px;
  height: 15px;
  cursor: pointer;
}
header .header__search-popover .search__close svg {
  width: 100%;
  height: auto;
}
header .header__search-popover .search__close svg path {
  fill: #001cb0;
}
header .header__search-popover .search__title {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 24px;
  -webkit-user-select: none;
  -ms-user-select: none;
  -moz-user-select: none;
       user-select: none;
}
header .header__search-popover .search__field {
  width: 40vw;
  border-bottom: solid 1.5px #001cb0;
}
header .header__search-popover .search__field form {
  display: grid;
  grid-template-columns: auto 30px;
  gap: 16px;
}
@media (min-width: 1200px) {
  header .header__search-popover .search__field form {
    grid-template-columns: 30px auto 30px;
  }
}
header .header__search-popover .search__field form input {
  background-color: transparent;
  border: none;
}
header .header__search-popover .search__field form input[type=text] {
  width: 100%;
  height: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0;
  margin: 0;
  border: none;
  outline: none;
}
@media (min-width: 1200px) {
  header .header__search-popover .search__field form input[type=text] {
    grid-column: 2/3;
    text-align: center;
  }
}
header .header__search-popover .search__field form input[type=submit] {
  width: auto;
  background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 x=%270px%27 y=%270px%27 viewBox=%270 0 16.7 16.7%27 style=%27enable-background: new 0 0 16.7 16.7%27 xml:space=%27preserve%27 %3E%3Cpath d=%27M1.5,6.6c0-2.8,2.3-5.1,5.1-5.1c2.8,0,5.1,2.3,5.1,5.1c0,2.8-2.3,5.1-5.1,5.1C3.8,11.8,1.5,9.5,1.5,6.6z M6.6,0 C3,0,0,3,0,6.6c0,3.7,3,6.6,6.6,6.6c1.6,0,3-0.5,4.1-1.4l4.6,4.6c0.3,0.3,0.8,0.3,1.1,0c0.3-0.3,0.3-0.8,0-1.1l-4.6-4.6 c0.9-1.1,1.4-2.6,1.4-4.1C13.3,3,10.3,0,6.6,0z%27 %3E%3C/path%3E%3C/svg%3E");
  background-size: 17px;
  background-position: center;
  background-repeat: no-repeat;
  padding: 0;
  margin: 0;
  cursor: pointer;
}
@media (min-width: 1200px) {
  header .header__search-popover .search__field form input[type=submit] {
    grid-column: 3/4;
  }
}
header .header__search-popover .search__field form ::-webkit-input-placeholder {
  color: #000;
  opacity: 1;
}
header .header__search-popover .search__field form ::-moz-placeholder {
  color: #000;
  opacity: 1;
}
header .header__search-popover .search__field form :-ms-input-placeholder {
  color: #000;
  opacity: 1;
}
header .header__search-popover .search__field form ::-ms-input-placeholder {
  color: #000;
  opacity: 1;
}
header .header__search-popover .search__field form ::placeholder {
  color: #000;
  opacity: 1;
}
header .header__mobile-menu-drawer {
  position: absolute;
  top: 100%;
  left: 0;
  width: clamp(300px, 100vw, 600px);
  height: calc(100dvh - var(--header-height));
  padding: 30px;
  background-color: #fff;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86), -webkit-box-shadow 0.2s ease;
  transition: -webkit-transform 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86), -webkit-box-shadow 0.2s ease;
  transition: transform 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86), box-shadow 0.2s ease;
  transition: transform 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86), box-shadow 0.2s ease, -webkit-transform 0.4s cubic-bezier(0.785, 0.135, 0.15, 0.86), -webkit-box-shadow 0.2s ease;
  -webkit-box-shadow: rgba(100, 100, 111, 0) 0px 7px 29px 0px;
          box-shadow: rgba(100, 100, 111, 0) 0px 7px 29px 0px;
  overflow: scroll;
}
header .header__mobile-menu-drawer--open {
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-box-shadow: rgba(100, 100, 111, 0.5) 0px 7px 29px 0px;
          box-shadow: rgba(100, 100, 111, 0.5) 0px 7px 29px 0px;
}
@media (min-width: 1200px) {
  header .header__mobile-menu-drawer {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
header .header__mobile-menu-drawer > ul {
  list-style: none;
  padding: 0;
}
header .header__mobile-menu-drawer > ul > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: solid 1.5px #001cb0;
}
header .header__mobile-menu-drawer > ul > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-inline: 8px;
  padding-block: 8px;
  color: #001cb0;
  font-size: 1.8rem;
  text-decoration: none;
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
header .header__mobile-menu-drawer > ul > li > button {
  position: relative;
  width: 16px;
  height: 16px;
  padding: 0;
  background-color: transparent;
  border: none;
  margin: 0;
  -webkit-margin-end: 4px;
          margin-inline-end: 4px;
  cursor: pointer;
}
header .header__mobile-menu-drawer > ul > li > button:before, header .header__mobile-menu-drawer > ul > li > button:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: block;
  width: 1.5px;
  height: 100%;
  background-color: #001cb0;
}
header .header__mobile-menu-drawer > ul > li > button:after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}
header .header__mobile-menu-drawer > ul > li > button:has(+ .accordion-content[style]):before {
  display: none;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content {
  width: 100%;
  max-height: 0px;
  background-color: #f4f2f0;
  -webkit-transition: max-height 0.2s ease;
  transition: max-height 0.2s ease;
  overflow: hidden;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul {
  list-style: none;
  padding: 0;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: solid 1px #ccc;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li:last-child {
  border-bottom: none;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-inline: 8px;
  padding-block: 8px;
  color: #001cb0;
  font-size: 1.4rem;
  font-weight: 600;
  text-decoration: none;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > button {
  position: relative;
  width: 14px;
  height: 14px;
  padding: 0;
  background-color: transparent;
  border: none;
  margin: 0;
  -webkit-margin-end: 8px;
          margin-inline-end: 8px;
  cursor: pointer;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > button:before, header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > button:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  display: block;
  width: 1px;
  height: 100%;
  background-color: #001cb0;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > button:after {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > button:has(+ .accordion-content[style]):before {
  display: none;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > .accordion-content {
  width: 100%;
  max-height: 0px;
  -webkit-transition: max-height 0.2s ease;
  transition: max-height 0.2s ease;
  overflow: hidden;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > .accordion-content > ul {
  list-style: none;
  padding: 0;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > .accordion-content > ul > li {
  border-top: solid 1px #ccc;
}
header .header__mobile-menu-drawer > ul > li > .accordion-content > ul > li > .accordion-content > ul > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-inline: 8px;
  padding-block: 8px;
  color: #000;
  font-size: 1.4rem;
  text-decoration: none;
}
header .header__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.4);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  pointer-events: none;
  opacity: 0;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
  z-index: -2;
}
header .header__overlay--visible {
  opacity: 1;
  pointer-events: all;
}

footer {
  width: 100%;
  max-width: 100%;
  padding-inline: 30px;
  padding-block: 30px;
  color: #fff;
  background: linear-gradient(135deg, #043fbb 0%, #00b0e4 100%);
  background-size: 200%;
  overflow: hidden;
}
@media (min-width: 1200px) {
  footer {
    background: -webkit-gradient(linear, left top, right top, from(#0027c0), to(#00b0e4));
    background: linear-gradient(90deg, #0027c0 0%, #00b0e4 100%);
    padding-inline: 0;
    padding-block: 0;
  }
}
footer a {
  color: #fff;
  text-decoration: none;
}
@media (min-width: 1200px) {
  footer .footer__start, footer .footer__body, footer .footer__end {
    padding-inline: 100px;
  }
}
@media (min-width: 1600px) {
  footer .footer__start, footer .footer__body, footer .footer__end {
    padding-inline: 160px;
  }
}
footer .footer__start, footer .footer__body {
  border-bottom: solid 1px rgba(255, 255, 255, 0.5);
}
footer .footer__start {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
  -webkit-padding-after: 16px;
          padding-block-end: 16px;
}
@media (min-width: 1200px) {
  footer .footer__start {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-padding-before: 24px;
            padding-block-start: 24px;
  }
}
footer .footer__logo svg {
  display: block;
  width: 100%;
  max-width: 160px;
  height: auto;
}
@media (min-width: 1200px) {
  footer .footer__logo svg {
    max-width: 180px;
  }
}
footer .footer__title {
  font-size: 16px;
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
}
footer .footer__title span {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
footer .footer__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 24px;
  padding-block: 16px;
}
@media (min-width: 1200px) {
  footer .footer__body {
    gap: 16px;
  }
}
footer .footer__links {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
footer .footer__links * {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 1.2rem;
}
@media (min-width: 1200px) {
  footer .footer__links {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 48px;
  }
}
footer .footer__links .links__main-menu ul, footer .footer__links .links__sub-menu ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 8px;
  list-style: none;
  padding: 0;
}
@media (min-width: 1200px) {
  footer .footer__links .links__main-menu ul, footer .footer__links .links__sub-menu ul {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 24px;
  }
}
footer .footer__links .links__main-menu ul li, footer .footer__links .links__sub-menu ul li {
  width: auto;
}
footer .footer__links .links__main-menu ul li a:hover, footer .footer__links .links__sub-menu ul li a:hover {
  color: #ccd2ef;
  text-decoration: underline;
}
footer .footer__messaging {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 24px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media (min-width: 1200px) {
  footer .footer__messaging {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
footer .footer__message {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
@media (min-width: 1200px) {
  footer .footer__message {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    max-width: 35vw;
  }
}
footer .footer__socials {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
}
@media (min-width: 1200px) {
  footer .footer__socials {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
footer .footer__socials .social-icon {
  display: block;
  width: 30px;
  height: 30px;
  background-color: #fff;
  border-radius: 99px;
  padding: 8px;
}
footer .footer__socials .social-icon svg {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
footer .footer__socials .social-icon svg path {
  fill: #0075cc;
}
footer .footer__end {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-padding-before: 16px;
          padding-block-start: 16px;
}
@media (min-width: 1200px) {
  footer .footer__end {
    -webkit-padding-after: 48px;
            padding-block-end: 48px;
  }
}
footer .footer__end .end__links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
}
footer .footer__end .end__links * {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.2rem;
  text-decoration: underline;
}
footer .footer__end .end__links *:hover {
  color: #ccd2ef;
  text-decoration: none;
}
footer .footer__messaging, footer .footer__end {
  font-size: 1.1rem;
}

.contents-list {
  position: relative;
  display: grid;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  gap: 24px;
  background-color: #f4f2f0;
  padding: 30px;
}
@media (min-width: 1200px) {
  .contents-list {
    padding: 48px 100px;
  }
}
@media (min-width: 1600px) {
  .contents-list {
    padding: 64px 160px;
  }
}
.contents-list > ul {
  list-style: none;
  list-style-type: none;
  padding: 0;
}
@media (min-width: 992px) {
  .contents-list > ul {
    -webkit-column-count: 2;
       -moz-column-count: 2;
            column-count: 2;
    -webkit-column-fill: balance;
       -moz-column-fill: balance;
            column-fill: balance;
  }
}
.contents-list > ul > li {
  -webkit-column-break-inside: avoid;
     -moz-column-break-inside: avoid;
          break-inside: avoid-column;
}
.contents-list > ul > li > a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #001cb0;
  font-weight: 600;
  text-decoration: none;
  padding: 8px;
  -webkit-border-after: solid 1.5px #001cb0;
          border-block-end: solid 1.5px #001cb0;
}
.contents-list > ul > li > a:after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--theme-color);
  opacity: 0;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
  z-index: 0;
}
.contents-list > ul > li > a span {
  position: relative;
  color: #001cb0;
  font-weight: 600;
  text-decoration: none;
  z-index: 1;
}
.contents-list > ul > li > a:hover:after {
  opacity: 0.2;
}
.contents-list > ul > li > ul {
  list-style: none;
  list-style-type: none;
  padding: 0;
}
.contents-list > ul > li > ul > li > a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #000;
  text-decoration: none;
  padding: 8px;
  -webkit-border-after: solid 1.5px #ccc;
          border-block-end: solid 1.5px #ccc;
}
.contents-list > ul > li > ul > li > a span {
  position: relative;
  color: #000;
  text-decoration: none;
  z-index: 1;
}
.contents-list > ul > li > ul > li > a:after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--theme-color);
  opacity: 0;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
  z-index: 0;
}
.contents-list > ul > li > ul > li > a:hover:after {
  opacity: 0.2;
}
.contents-list > ul > li > ul > li:last-child > a {
  -webkit-border-after: solid 1.5px #001cb0;
          border-block-end: solid 1.5px #001cb0;
}
.contents-list button {
  -webkit-margin-start: auto;
          margin-inline-start: auto;
}

.homepage {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 30px;
  width: 100%;
  height: 100%;
  padding: 64px 30px;
}
@media (min-width: 1200px) {
  .homepage {
    padding: 100px;
  }
}
@media (min-width: 1600px) {
  .homepage {
    padding-inline: 160px;
  }
}
.homepage__title {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3rem;
  line-height: 1.25;
  color: #001cb0;
}
@media (min-width: 1200px) {
  .homepage__title .break--mobile-only {
    display: none;
  }
}
.homepage__title .break--desktop-only {
  display: none;
}
@media (min-width: 1200px) {
  .homepage__title .break--desktop-only {
    display: block;
  }
}
.homepage__links {
  display: grid;
  gap: 8px;
  width: 60vw;
  max-width: 300px;
  color: #001cb0;
}
@media (min-width: 1200px) {
  .homepage__links {
    width: 50%;
    max-width: 580px;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
  }
}
.homepage__links .link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
  text-decoration: none;
  -webkit-padding-after: 8px;
          padding-block-end: 8px;
  -webkit-border-after: solid 3px var(--theme-color);
          border-block-end: solid 3px var(--theme-color);
}
@media (min-width: 1200px) {
  .homepage__links .link {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 8px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    -webkit-padding-after: 0;
            padding-block-end: 0;
    -webkit-border-after: none;
            border-block-end: none;
  }
}
.homepage__links .link__icon {
  --icon-size: 40px;
  width: var(--icon-size);
  height: var(--icon-size);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-radius: var(--icon-size);
  background-color: var(--theme-color);
}
@media (min-width: 1200px) {
  .homepage__links .link__icon {
    --icon-size: 60px;
  }
}
.homepage__links .link__icon svg {
  display: block;
  width: 50%;
  height: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.homepage__links .link__icon svg path {
  fill: #fff;
}
.homepage__links .link__title {
  font-size: 18px;
  color: #001cb0;
  text-decoration: none;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
}
@media (min-width: 1200px) {
  .homepage__links .link__title {
    width: 100%;
    font-size: 20px;
    -webkit-padding-before: 4px;
            padding-block-start: 4px;
    -webkit-border-before: solid 3px var(--theme-color);
            border-block-start: solid 3px var(--theme-color);
  }
}
.homepage__links .link:hover .link__title {
  color: var(--theme-color);
}
.homepage__feature-image {
  pointer-events: none;
}
.homepage__feature-image--mobile {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: calc(100vw - 30px - var(--header-height) * 2 + 2px);
  height: auto;
}
@media (min-width: 1200px) {
  .homepage__feature-image--mobile {
    display: none;
  }
}
.homepage__feature-image--desktop {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  left: calc(100px + var(--header-height) * 2 - 2px);
  width: calc(100vw - (100px + var(--header-height) * 2) + 2px);
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: left top;
     object-position: left top;
}
@media (min-width: 1200px) {
  .homepage__feature-image--desktop {
    display: block;
  }
}
@media (min-width: 1600px) {
  .homepage__feature-image--desktop {
    left: calc(160px + var(--header-height) * 2 - 2px);
    width: calc(100vw - (160px + var(--header-height) * 2) + 2px);
    height: 100%;
  }
}

.page-content {
  display: grid;
  gap: 16px;
  padding-inline: 30px;
  padding-block: 30px;
}
@media (min-width: 992px) {
  .page-content {
    height: 100%;
    grid-template-columns: 260px 1fr;
    grid-template-rows: auto 1fr;
    row-gap: 0;
    -webkit-column-gap: 30px;
       -moz-column-gap: 30px;
            column-gap: 30px;
    -webkit-padding-before: 16px;
            padding-block-start: 16px;
    -webkit-padding-after: 0;
            padding-block-end: 0;
  }
}
@media (min-width: 1200px) {
  .page-content {
    -webkit-column-gap: 100px;
       -moz-column-gap: 100px;
            column-gap: 100px;
    padding-inline: 100px;
  }
}
@media (min-width: 1600px) {
  .page-content {
    padding-inline: 160px;
  }
}
.page-content__header {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
  -webkit-padding-after: 8px;
          padding-block-end: 8px;
  -webkit-border-after: solid 3px var(--theme-color);
          border-block-end: solid 3px var(--theme-color);
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3rem;
  line-height: 1.25;
  color: #001cb0;
}
@media (min-width: 992px) {
  .page-content__header {
    grid-column: span 2;
  }
}
.page-content__header .header__icon {
  --icon-size: 40px;
  width: var(--icon-size);
  height: var(--icon-size);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-radius: var(--icon-size);
  background-color: var(--theme-color);
}
.page-content__header .header__icon:empty {
  display: none;
}
.page-content__header .header__icon svg {
  display: block;
  width: 50%;
  height: 50%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
.page-content__header .header__icon svg path {
  fill: #fff;
}
.page-content__sidebar {
  display: none;
  width: 260px;
  background-color: #f4f2f0;
}
@media (min-width: 992px) {
  .page-content__sidebar {
    display: block;
  }
}
.page-content__sidebar > ul {
  list-style: none;
  list-style-type: none;
  padding: 0;
  font-size: 1.2rem;
}
.page-content__sidebar > ul > li {
  -webkit-column-break-inside: avoid;
     -moz-column-break-inside: avoid;
          break-inside: avoid-column;
}
.page-content__sidebar > ul > li:first-child {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
.page-content__sidebar > ul > li:first-child a {
  -webkit-border-before: none;
          border-block-start: none;
}
.page-content__sidebar > ul > li > a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #001cb0;
  font-weight: 600;
  text-decoration: none;
  padding: 8px;
  -webkit-border-after: solid 1.5px #001cb0;
          border-block-end: solid 1.5px #001cb0;
}
.page-content__sidebar > ul > li > a:after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--theme-color);
  opacity: 0;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
  z-index: 0;
}
.page-content__sidebar > ul > li > a span {
  position: relative;
  color: #001cb0;
  font-weight: 600;
  text-decoration: none;
  z-index: 1;
}
.page-content__sidebar > ul > li > a:hover:after {
  opacity: 0.2;
}
.page-content__sidebar > ul > li > ul {
  list-style: none;
  list-style-type: none;
  padding: 0;
}
.page-content__sidebar > ul > li > ul > li > a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #000;
  text-decoration: none;
  padding: 8px;
  -webkit-border-before: solid 1.5px #ccc;
          border-block-start: solid 1.5px #ccc;
  -webkit-border-after: solid 1.5px #ccc;
          border-block-end: solid 1.5px #ccc;
}
.page-content__sidebar > ul > li > ul > li > a span {
  position: relative;
  color: #000;
  text-decoration: none;
  z-index: 1;
}
.page-content__sidebar > ul > li > ul > li > a:after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--theme-color);
  opacity: 0;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
  z-index: 0;
}
.page-content__sidebar > ul > li > ul > li > a:hover:after {
  opacity: 0.2;
}
.page-content__sidebar > ul > li > ul > li:last-child > a {
  -webkit-border-after: solid 1.5px #001cb0;
          border-block-end: solid 1.5px #001cb0;
}
.page-content__sidebar .current-page, .page-content__sidebar .current-page * {
  font-weight: 700 !important;
}
.page-content__sidebar .current-page:after, .page-content__sidebar .current-page *:after {
  opacity: 0.2;
}
@media (min-width: 992px) {
  .page-content__main {
    -webkit-padding-before: 30px;
            padding-block-start: 30px;
    -webkit-padding-after: 64px;
            padding-block-end: 64px;
  }
}
.page-content__mobile-nav {
  width: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 16px;
  background-color: #f4f2f0;
  padding: 16px 30px 30px;
  -webkit-border-before: solid 1.5px #001cb0;
          border-block-start: solid 1.5px #001cb0;
  -webkit-margin-start: -30px;
          margin-inline-start: -30px;
  -webkit-margin-end: -30px;
          margin-inline-end: -30px;
  -webkit-margin-after: -30px;
          margin-block-end: -30px;
  -webkit-margin-before: 14px;
          margin-block-start: 14px;
}
@media (min-width: 992px) {
  .page-content__mobile-nav {
    display: none;
  }
}
.page-content__mobile-nav .mobile-nav__prev, .page-content__mobile-nav .mobile-nav__next {
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 4px;
  text-decoration: none;
  max-width: 35vw;
}
.page-content__mobile-nav .mobile-nav__prev *, .page-content__mobile-nav .mobile-nav__next * {
  color: #001cb0;
  font-size: 14px;
  text-decoration: none;
}
.page-content__mobile-nav .mobile-nav__prev .link__icon, .page-content__mobile-nav .mobile-nav__next .link__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.page-content__mobile-nav .mobile-nav__prev .link__title, .page-content__mobile-nav .mobile-nav__next .link__title {
  font-weight: 600;
}
.page-content__mobile-nav .mobile-nav__prev {
  grid-template-columns: 30px auto;
}
.page-content__mobile-nav .mobile-nav__prev .link__icon, .page-content__mobile-nav .mobile-nav__prev .link__heading {
  grid-row: 1/2;
}
.page-content__mobile-nav .mobile-nav__prev .link__heading, .page-content__mobile-nav .mobile-nav__prev .link__title {
  grid-column: 2/3;
}
.page-content__mobile-nav .mobile-nav__next {
  grid-template-columns: auto 30px;
  text-align: end;
}
.page-content__mobile-nav .mobile-nav__next .link__icon, .page-content__mobile-nav .mobile-nav__next .link__heading {
  grid-row: 1/2;
}
.page-content__mobile-nav .mobile-nav__next .link__icon {
  grid-column: 2/3;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
}
.page-content__mobile-nav .mobile-nav__next .link__heading, .page-content__mobile-nav .mobile-nav__next .link__title {
  grid-column: 1/2;
}

.search-results {
  padding: 30px;
}
@media (min-width: 1200px) {
  .search-results {
    padding: 100px;
  }
}
.search-results__inner {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 992px) {
  .search-results__inner {
    max-width: 900px;
  }
}
@media (min-width: 1200px) {
  .search-results__inner {
    max-width: 1000px;
  }
}
@media (min-width: 1400px) {
  .search-results__inner {
    max-width: 1140px;
  }
}
@media (min-width: 1600px) {
  .search-results__inner {
    max-width: 1320px;
  }
}
.search-results__title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-bottom: 4px;
  color: #001cb0;
  border-bottom: solid 3px #ffe344;
  margin-bottom: 8px;
}
.search-results__title, .search-results__title * {
  font-family: "Titillium Web", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: 3rem;
  line-height: 1.25;
}
@media (min-width: 1200px) {
  .search-results__title {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
}
.search-results__search-term {
  font-family: "Titillium Web", sans-serif;
  font-weight: 400;
  font-style: normal;
}
@media (min-width: 1200px) {
  .search-results__search-term {
    font-size: 24px;
  }
}
.search-results__list {
  list-style-type: none;
  padding: 0;
}
.search-results__list li {
  border-bottom: solid 1px #001cb0;
}
.search-results__list li a {
  display: block;
  padding-block: 10px;
  color: #001cb0;
  text-decoration: none;
  font-weight: 600;
}
