*, :before, :after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  color: #333;
  background-color: #e6edf2;
  margin: 0;
  font-family: Lato, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
}

a {
  color: #1c3d5e;
  text-decoration: underline;
}

a:hover, a:focus {
  color: #00103d;
}

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

.material-icons {
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  vertical-align: middle;
  font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  direction: ltr;
  font-family: Material Icons;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  display: inline-block;
}

.container-xl {
  width: 100%;
  max-width: 1320px;
  margin-inline: auto;
  padding-inline: 1rem;
}

.gov-banner {
  color: #1b1b1b;
  background-color: #f0f0f0;
  border-bottom: 1px solid #dfe1e2;
  font-size: .85rem;
}

.gov-banner__top {
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem;
  padding-block: .4rem;
  display: flex;
}

.gov-banner__flag {
  flex-shrink: 0;
  width: 16px;
  height: auto;
}

.gov-banner__label {
  flex: 0 auto;
}

.gov-banner__toggle {
  color: #005ea2;
  cursor: pointer;
  font: inherit;
  background: none;
  border: 0;
  align-items: center;
  gap: .25rem;
  padding: .1rem .3rem;
  text-decoration: none;
  display: inline-flex;
}

.gov-banner__toggle:hover, .gov-banner__toggle:focus-visible {
  color: #1a4480;
}

.gov-banner__toggle:focus-visible {
  outline-offset: 2px;
  outline: 2px solid #2491ff;
}

.gov-banner__toggle-text {
  text-decoration: underline;
}

.gov-banner__chevron:after {
  content: "▾";
  font-size: 1em;
}

.gov-banner .js-gov-banner-toggle[aria-expanded="true"] .gov-banner__chevron:after {
  content: "▴";
  font-size: 1em;
}

.gov-banner__content {
  background-color: #f0f0f0;
  border-top: 1px solid #dfe1e2;
  padding-block: 1rem;
}

.gov-banner__content[aria-hidden="true"] {
  display: none;
}

.gov-banner__col {
  align-items: flex-start;
  gap: .75rem;
  padding-block: .5rem;
  display: flex;
}

.gov-banner__col p {
  margin: 0 0 .25rem;
  line-height: 1.4;
}

.gov-banner__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
}

.gov-banner__lock {
  display: inline-block;
}

.site-header {
  color: #fff;
  position: relative;
}

.site-hero {
  background-color: #00103d;
  background-image: url("header-home.981d39ed.png");
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
  min-height: 380px;
  position: relative;
}

.site-hero:before {
  content: "";
  pointer-events: none;
  background: #0000002e;
  position: absolute;
  inset: 0;
}

.site-hero > .container-xl {
  z-index: 1;
  padding-block: 1.25rem 2.5rem;
  position: relative;
}

.page-spanish .site-hero {
  background-image: url("header-spanish.b44eea02.png");
}

.page-home .site-hero, .page-about .site-hero, .page-disclaimer .site-hero, .page-404 .site-hero, .page-contactus .site-hero, .page-default .site-hero {
  background-image: url("header-home.981d39ed.png");
}

.page-cornerstone .site-hero, .page-hicp .site-hero, .page-landscape .site-hero {
  background-image: url("header-cornerstone.1bbd67d0.png");
}

.page-kod .site-hero, .page-kod-five-threats .site-hero, .page-kod-detail .site-hero, .page-kod-quick-shots .site-hero {
  background-image: url("header-education.6f53869f.png");
}

.page-resources .site-hero {
  background-image: url("header-resources.ecb828a1.png");
}

.page-post .site-hero, .page-post-detail .site-hero {
  background-image: url("header-post.3b606a01.png");
}

.site-header__bar {
  align-items: flex-start;
  gap: 1rem;
  padding-top: .5rem;
  display: flex;
}

.site-header__logo {
  flex: auto;
  text-decoration: none;
}

.site-header__logo img {
  width: auto;
  height: 86px;
  display: block;
}

.site-header__top-links {
  align-items: center;
  gap: .6rem;
  margin-top: .75rem;
  display: flex;
}

.site-header__top-links a {
  color: #fff;
  font-size: .95rem;
  text-decoration: none;
}

.site-header__top-links a:hover, .site-header__top-links a:focus-visible {
  color: #fdba35;
}

@media (width <= 575.98px) {
  .site-header__top-links {
    display: none;
  }
}

.site-header__divider {
  color: #ffffff80;
}

.site-header__hamburger {
  color: #fff;
  cursor: pointer;
  background: none;
  border: 0;
  padding: .5rem;
  display: none;
}

.site-header__hamburger .material-icons {
  font-size: 28px;
}

@media (width <= 575.98px) {
  .site-header__hamburger {
    align-items: center;
    display: inline-flex;
  }
}

.site-header__tabs {
  background-color: #0003;
  border-top: 1px solid #c8c8c880;
  border-bottom: 1px solid #c8c8c880;
  flex-wrap: wrap;
  margin-top: 1rem;
  display: flex;
}

.site-header__tab {
  text-align: center;
  color: #fff;
  border-bottom: 3px solid #0000;
  flex: auto;
  padding: .85rem .75rem;
  font-size: 1rem;
  font-weight: 500;
  text-decoration: none;
  transition: border-color .15s, color .15s;
}

.site-header__tab:hover, .site-header__tab:focus-visible {
  color: #fdba35;
  border-bottom-color: #f1b643;
}

@media (width <= 767.98px) {
  .site-header__tab {
    flex-basis: 50%;
    font-size: .85rem;
  }
}

.site-header__tab--disabled {
  color: #ffffff8c;
  cursor: not-allowed;
}

.site-header__tab--disabled:hover, .site-header__tab--disabled:focus-visible {
  color: #ffffff8c;
  border-bottom-color: #0000;
}

.site-header__top-link--disabled {
  color: #ffffff8c;
  cursor: not-allowed;
  font-size: .95rem;
}

.site-hero__tagline {
  color: #fdba35;
  text-shadow: 0 1px 4px #0006;
  padding: 2rem 1rem 1rem;
}

@media (width >= 768px) {
  .site-hero__tagline {
    padding-inline: 5rem;
  }
}

.site-hero__tagline-line, .site-hero__tagline-emphasis {
  margin: 0;
  font-family: Lato, sans-serif;
  font-weight: 700;
  line-height: 1.1;
}

.site-hero__tagline-line {
  font-size: 1.75rem;
}

@media (width >= 768px) {
  .site-hero__tagline-line {
    font-size: 2.25rem;
  }
}

.site-hero__tagline-emphasis {
  font-size: 2.5rem;
  font-style: italic;
}

@media (width >= 768px) {
  .site-hero__tagline-emphasis {
    font-size: 3.5rem;
  }
}

.site-footer {
  color: #fff;
  background-color: #003668;
  margin-top: 4rem;
  padding-block: 2rem;
}

.site-footer a {
  color: #fff;
  text-decoration: none;
}

.site-footer a:hover, .site-footer a:focus-visible {
  color: #fdba35;
  text-decoration: underline;
}

.site-footer__logos {
  flex-direction: column;
  gap: .5rem;
  margin-bottom: 1rem;
  display: flex;
}

.site-footer__logos img {
  max-width: 200px;
  height: auto;
}

.site-footer__heading {
  margin: .5rem 0;
  font-size: 1.25rem;
  font-weight: 500;
}

.site-footer__socials {
  gap: .75rem;
  display: flex;
}

.site-footer__socials a {
  color: #fff;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  font-size: 1.5rem;
  transition: color .15s, transform .15s;
  display: inline-flex;
}

.site-footer__socials a:hover, .site-footer__socials a:focus-visible {
  color: #fdba35;
  transform: translateY(-2px);
}

.site-footer__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-footer__group {
  margin-bottom: 1rem;
}

.site-footer__item--lead {
  margin-block: .25rem;
  font-size: 1.2rem;
  font-weight: 500;
  display: block;
}

.site-footer__sublist {
  margin: .25rem 0 0;
  padding-left: .75rem;
  list-style: none;
}

.site-footer__sublist li {
  margin-block: .2rem;
  font-size: .85rem;
}

.site-footer__item--disabled {
  color: #ffffff8c;
  cursor: not-allowed;
}

.site-footer__version {
  text-align: right;
  color: #bbb;
  margin-top: 1.5rem;
  font-size: .7rem;
  font-style: italic;
}

[data-animate] {
  opacity: 0;
  filter: blur(8px);
  will-change: opacity, transform, filter;
  transition: opacity 1.5s ease-in-out, filter 1.5s ease-in-out, transform 1.5s ease-in-out;
  transform: translateY(6em);
}

[data-animate].is-visible {
  opacity: 1;
  filter: none;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  [data-animate] {
    opacity: 1;
    filter: none;
    transition: none;
    transform: none;
  }
}

.brand-carousel {
  background-color: #cfdbe6;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px #00000014;
}

.brand-carousel .carousel-inner {
  background-color: #fff;
}

.brand-carousel .carousel-item {
  padding: 2rem 3rem;
}

.brand-carousel__slide-grid {
  grid-template-columns: 1fr;
  align-items: center;
  gap: 1.5rem;
  display: grid;
}

@media (width >= 768px) {
  .brand-carousel__slide-grid {
    grid-template-columns: 280px 1fr;
  }
}

.brand-carousel__media img {
  border-radius: 4px;
  width: 100%;
  max-width: 280px;
  height: auto;
  margin-inline: auto;
  transition: transform .15s cubic-bezier(.34, 1.56, .64, 1);
  display: block;
}

.brand-carousel__media img:hover, .brand-carousel__media img:focus-visible {
  transform: scale(1.025) rotate(2deg);
}

@media (prefers-reduced-motion: reduce) {
  .brand-carousel__media img {
    transition: none;
  }

  .brand-carousel__media img:hover, .brand-carousel__media img:focus-visible {
    transform: none;
  }
}

.brand-carousel__title {
  color: #00103d;
  margin: 0 0 .5rem;
  font-size: 1.5rem;
  font-weight: 700;
}

.brand-carousel__body {
  color: #333;
  margin-bottom: 1rem;
  line-height: 1.55;
}

.brand-carousel__cta {
  color: #00103d;
  background-color: #fdba35;
  border-radius: 999px;
  align-items: center;
  gap: .4rem;
  margin-right: .5rem;
  padding: .55rem 1.1rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
}

.brand-carousel__cta:hover, .brand-carousel__cta:focus-visible {
  color: #00103d;
  background-color: #fdad0f;
  text-decoration: none;
}

.brand-carousel__cta--secondary {
  color: #fff;
  background-color: #003668;
}

.brand-carousel__cta--secondary:hover, .brand-carousel__cta--secondary:focus-visible {
  color: #fff;
  background-color: #00103d;
}

.brand-carousel__coming-soon {
  color: #00103d;
  background-color: #0000001a;
  border-radius: 999px;
  padding: .35rem .85rem;
  font-size: .85rem;
  font-weight: 700;
  display: inline-block;
}

.brand-carousel .carousel-control-prev-icon, .brand-carousel .carousel-control-next-icon {
  filter: invert() drop-shadow(0 0 2px #0009);
}

.brand-carousel .carousel-indicators [data-bs-target] {
  background-color: #003668;
}

.cybersecurity-roadmap {
  width: 100%;
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: 1rem;
}

.cybersecurity-roadmap__svg {
  width: 100%;
  height: auto;
  display: block;
}

.cybersecurity-roadmap__hotspot {
  fill: #fff6;
  stroke: #fdba35;
  stroke-width: 2px;
  cursor: pointer;
  transition: fill .2s, stroke-width .2s;
}

.cybersecurity-roadmap__hotspot:hover, .cybersecurity-roadmap__hotspot:focus-visible {
  fill: #fdba35b3;
  stroke-width: 4px;
  outline: none;
}

.hicp-threats {
  margin-block: 2.5rem;
  scroll-margin-top: 1rem;
}

.hicp-threats__heading {
  color: #003668;
  text-align: center;
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
  font-weight: 700;
}

@media (width >= 768px) {
  .hicp-threats__heading {
    font-size: 1.85rem;
  }
}

.hicp-threats .nav-tabs {
  border-bottom: 2px solid #003668;
  flex-wrap: wrap;
  gap: .25rem;
}

.hicp-threats .nav-tabs .nav-link {
  color: #003668;
  background-color: #cfdbe6;
  border: 1px solid #0000;
  border-radius: 6px 6px 0 0;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  min-width: 110px;
  padding: .65rem 1rem;
  font-weight: 600;
  display: flex;
}

.hicp-threats .nav-tabs .nav-link img {
  width: auto;
  max-height: 48px;
}

.hicp-threats .nav-tabs .nav-link:hover {
  color: #00103d;
  background-color: #dce5ed;
}

.hicp-threats .nav-tabs .nav-link.active {
  color: #fff;
  background-color: #003668;
  border-color: #003668 #003668 #fdba35;
  border-bottom-width: 4px;
}

.hicp-threats__pane {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-top: none;
  border-radius: 0 0 6px 6px;
  padding: 1.5rem;
}

.hicp-threats__title {
  color: #003668;
  margin: 0 0 .5rem;
  font-size: 1.4rem;
  font-weight: 700;
}

.hicp-threats__scenario-label {
  color: #00103d;
  margin-top: 1rem;
  margin-bottom: .25rem;
  font-weight: 700;
  display: block;
}

.hicp-threats__video {
  margin-block: 1rem;
}

.hicp-threats__video video {
  background-color: #000;
  width: 100%;
  max-width: 700px;
  height: auto;
  margin-inline: auto;
  display: block;
}

.hicp-threats__transcript {
  color: #1c3d5e;
  margin-top: .5rem;
  display: inline-block;
}

.hicp-threats__buttons {
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: 1rem;
  display: flex;
}

.hicp-threats__button {
  color: #fff;
  background-color: #003668;
  border-radius: 4px;
  align-items: center;
  gap: .35rem;
  padding: .55rem 1rem;
  font-size: .9rem;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.hicp-threats__button:hover, .hicp-threats__button:focus-visible {
  color: #fff;
  background-color: #00103d;
  text-decoration: none;
}

.hicp-threats__button--accent {
  color: #00103d;
  background-color: #fdba35;
}

.hicp-threats__button--accent:hover, .hicp-threats__button--accent:focus-visible {
  color: #00103d;
  background-color: #fdad0f;
}

.hicp-practices {
  margin-block: 2.5rem;
  scroll-margin-top: 1rem;
}

.hicp-practices__heading {
  color: #003668;
  text-align: center;
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
  font-weight: 700;
}

@media (width >= 768px) {
  .hicp-practices__heading {
    font-size: 1.85rem;
  }
}

.hicp-practices__grid {
  grid-template-columns: repeat(2, 1fr);
  gap: .5rem;
  display: grid;
}

@media (width >= 576px) {
  .hicp-practices__grid {
    grid-template-columns: repeat(5, 1fr);
  }
}

.hicp-practices__button {
  color: #00103d;
  text-align: center;
  cursor: pointer;
  background-color: #cfdbe6;
  border: 2px solid #0000;
  border-radius: 6px;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  width: 100%;
  min-height: 110px;
  padding: .85rem .5rem;
  font-size: .85rem;
  font-weight: 600;
  transition: background-color .15s, border-color .15s;
  display: flex;
}

.hicp-practices__button img {
  width: auto;
  max-height: 56px;
}

.hicp-practices__button:hover {
  background-color: #dce5ed;
}

.hicp-practices__button[aria-expanded="true"] {
  color: #fff;
  background-color: #003668;
  border-color: #fdba35;
}

.hicp-practices__panel {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 6px;
  margin-top: .75rem;
  padding: 1.25rem 1.5rem;
}

.hicp-practices__panel-title {
  color: #003668;
  margin: 0 0 .5rem;
  font-size: 1.3rem;
  font-weight: 700;
}

.hicp-practices__panel-buttons {
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: 1rem;
  display: flex;
}

.hicp-document-list {
  flex-wrap: wrap;
  gap: .75rem;
  margin-block: 1rem;
  display: flex;
}

.hicp-document-list__button {
  color: #fff;
  background-color: #3375a0;
  border-radius: 4px;
  align-items: center;
  gap: .4rem;
  padding: .6rem 1.1rem;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.hicp-document-list__button:hover, .hicp-document-list__button:focus-visible {
  color: #fff;
  background-color: #275979;
  text-decoration: none;
}

.landscape-page {
  padding-block: 1.5rem;
}

.landscape-page__intro {
  text-align: center;
  margin-bottom: 2rem;
}

.landscape-page__intro h1 {
  color: #003668;
  margin: 0;
  font-size: 1.85rem;
}

.landscape-page__intro h2 {
  color: #003668;
  margin: 0 0 1rem;
  font-size: 1.5rem;
}

.landscape-page__intro p {
  max-width: 56rem;
  margin-inline: auto;
  line-height: 1.55;
}

.landscape-page__intro .landscape-page__cta {
  color: #00103d;
  background-color: #fdba35;
  border-radius: 999px;
  align-items: center;
  gap: .4rem;
  margin-top: 1rem;
  padding: .65rem 1.25rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
}

.landscape-page__intro .landscape-page__cta:hover, .landscape-page__intro .landscape-page__cta:focus-visible {
  color: #00103d;
  background-color: #fdad0f;
}

.landscape-page__pair {
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-block: 1.5rem;
  display: grid;
}

@media (width >= 768px) {
  .landscape-page__pair {
    grid-template-columns: 1fr 1fr;
  }
}

.landscape-page__pair--panel {
  background-color: #cfdbe6;
  border-radius: 6px;
  padding: 1.25rem;
}

.landscape-page__panel {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 6px;
  padding: 1.25rem;
}

.landscape-page__panel h3, .landscape-page__panel h4, .landscape-page__panel h5, .landscape-page__panel h6 {
  color: #003668;
  margin-top: 0;
}

.landscape-page__panel ul, .landscape-page__panel ol {
  padding-left: 1.25rem;
  line-height: 1.55;
}

.landscape-page__panel li {
  margin-block: .3rem;
}

.landscape-page__table {
  border-collapse: collapse;
  background-color: #fff;
  width: 100%;
  margin-block: 1rem;
  box-shadow: 0 1px 3px #0000000d;
}

.landscape-page__table th {
  color: #fff;
  text-align: left;
  vertical-align: top;
  background-color: #003668;
  padding: .65rem .85rem;
  font-weight: 600;
}

.landscape-page__table td {
  vertical-align: top;
  border-bottom: 1px solid #e0e6ee;
  padding: .65rem .85rem;
}

.landscape-page__table tr:nth-child(2n) td {
  background-color: #f5f8fb;
}

.landscape-page__table ul {
  margin: 0;
  padding-left: 1.1rem;
}

.landscape-page__table li {
  margin-block: .2rem;
  font-size: .9rem;
}

.landscape-page__graphs {
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1rem;
  display: grid;
}

@media (width >= 768px) {
  .landscape-page__graphs {
    grid-template-columns: repeat(3, 1fr);
  }
}

.landscape-page__graphs img {
  border: 1px solid #d0d8e2;
  border-radius: 4px;
  width: 100%;
  height: auto;
}

.landscape-page__thumbs {
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1rem;
  display: flex;
}

.landscape-page__thumbs a {
  width: 140px;
  transition: transform .15s;
  display: block;
}

.landscape-page__thumbs a:hover, .landscape-page__thumbs a:focus-visible {
  transform: translateY(-3px);
}

.landscape-page__thumbs a img {
  border: 1px solid #d0d8e2;
  border-radius: 4px;
  width: 100%;
  height: auto;
}

.kod-icon {
  color: #00103d;
  text-align: center;
  background-color: #fff;
  border-radius: 8px;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  padding: 1rem;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  display: flex;
  position: relative;
  box-shadow: 0 2px 6px #00000014;
}

.kod-icon img {
  max-width: 120px;
  height: auto;
}

.kod-icon__title {
  margin: 0;
  font-size: .95rem;
  font-weight: 600;
}

.kod-icon:hover, .kod-icon:focus-visible {
  color: #00103d;
  text-decoration: none;
  transform: scale(1.025) rotate(2deg);
  box-shadow: 0 6px 16px #00000026;
}

.kod-icon--coming-soon {
  opacity: .65;
  cursor: not-allowed;
}

.kod-icon--coming-soon:hover, .kod-icon--coming-soon:focus-visible {
  transform: none;
  box-shadow: 0 2px 6px #00000014;
}

.kod-icon__ribbon {
  color: #00103d;
  text-transform: uppercase;
  background-color: #fdba35;
  border-radius: 999px;
  padding: .15rem .55rem;
  font-size: .7rem;
  font-weight: 700;
  position: absolute;
  top: .5rem;
  right: .5rem;
}

.kod-icon__ribbon--soon {
  color: #fff;
  background-color: #003668;
}

.kod-five-threats__intro {
  text-align: center;
  max-width: 56rem;
  margin: 0 auto 2rem;
}

.kod-five-threats__intro h1 {
  color: #003668;
}

.kod-five-threats__contains {
  background-color: #cfdbe6;
  border-radius: 8px;
  margin-block: 2rem;
  padding: 1.5rem;
}

.kod-five-threats__contains h2 {
  color: #003668;
  text-align: center;
  margin: 0 0 1rem;
  font-size: 1.5rem;
}

.kod-five-threats__contains-grid {
  grid-template-columns: 1fr;
  gap: 1rem;
  display: grid;
}

@media (width >= 768px) {
  .kod-five-threats__contains-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.kod-five-threats__contains-card {
  text-align: center;
  background-color: #fff;
  border-radius: 6px;
  padding: 1rem;
}

.kod-five-threats__contains-card h3 {
  color: #003668;
  margin: 0 0 .4rem;
  font-size: 1.05rem;
}

.kod-five-threats__contains-card p {
  margin: 0;
  font-size: .85rem;
  line-height: 1.4;
}

.kod-five-threats__threats-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  display: grid;
}

@media (width >= 768px) {
  .kod-five-threats__threats-grid {
    grid-template-columns: repeat(5, 1fr);
  }
}

.kod-detail__intro {
  text-align: center;
  margin-bottom: 1.5rem;
}

.kod-detail__intro h1 {
  color: #003668;
}

.kod-detail__launch {
  text-align: center;
  margin-block: 1.5rem;
}

.kod-detail__launch a {
  transition: transform .2s;
  display: inline-block;
}

.kod-detail__launch a:hover, .kod-detail__launch a:focus-visible {
  transform: scale(1.025);
}

.kod-detail__launch a img {
  width: 100%;
  max-width: 360px;
  height: auto;
}

.kod-detail__body {
  max-width: 56rem;
  margin-inline: auto;
  padding-inline: 1rem;
}

.kod-detail__body p {
  line-height: 1.6;
}

.kod-detail__buttons {
  flex-wrap: wrap;
  justify-content: center;
  gap: .75rem;
  margin-block: 1.5rem;
  display: flex;
}

.kod-detail__button {
  color: #fff;
  background-color: #3375a0;
  border-radius: 4px;
  align-items: center;
  gap: .4rem;
  padding: .6rem 1.1rem;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.kod-detail__button:hover, .kod-detail__button:focus-visible {
  color: #fff;
  background-color: #275979;
  text-decoration: none;
}

.kod-detail__feedback {
  text-align: center;
  margin-block: 1rem;
  font-size: .95rem;
}

.kod-detail__others {
  margin-top: 3rem;
}

.kod-detail__others h3 {
  text-align: center;
  color: #003668;
  margin-bottom: 1rem;
}

.kod-detail__others-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  display: grid;
}

@media (width >= 768px) {
  .kod-detail__others-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.kod-quick-shots__intro {
  text-align: center;
  max-width: 56rem;
  margin: 0 auto 2rem;
}

.kod-quick-shots__intro h1 {
  color: #003668;
}

.kod-quick-shots__grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  display: grid;
}

@media (width >= 768px) {
  .kod-quick-shots__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.kod-quick-shots__tile {
  cursor: pointer;
  text-align: inherit;
  background: none;
  border: 0;
  width: 100%;
  padding: 0;
}

.kod-quick-shots__tile[disabled] {
  cursor: not-allowed;
}

.kod-video-modal .modal-dialog {
  max-width: 900px;
}

.kod-video-modal .modal-content {
  background-color: #000;
  border: 0;
  border-radius: 8px;
}

.kod-video-modal .modal-header {
  color: #fff;
  background-color: #003668;
  border-bottom: 1px solid #3f5f96;
}

.kod-video-modal .modal-header .btn-close {
  filter: invert();
}

.kod-video-modal video {
  width: 100%;
  height: auto;
  display: block;
}

.kod-landing__intro {
  text-align: center;
  max-width: 56rem;
  margin: 0 auto 2rem;
}

.kod-landing__intro h1 {
  color: #003668;
}

.resources-page__intro {
  text-align: center;
  max-width: 60rem;
  margin: 0 auto 2rem;
}

.resources-page__intro h1 {
  color: #003668;
  margin-top: 0;
}

.resources-page__intro p {
  line-height: 1.55;
}

.resources-page__layout {
  grid-template-columns: 1fr;
  gap: 2rem;
  display: grid;
}

@media (width >= 992px) {
  .resources-page__layout {
    grid-template-columns: 260px 1fr;
  }

  .resources-page__sidebar {
    align-self: start;
    position: sticky;
    top: 1rem;
  }
}

.resources-page__main {
  min-width: 0;
}

.tag-cloud {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 8px;
  padding: 1rem;
}

.tag-cloud__heading {
  color: #003668;
  margin: 0 0 .75rem;
  font-size: 1.1rem;
  font-weight: 700;
}

.tag-cloud__list {
  flex-wrap: wrap;
  gap: .4rem .6rem;
  line-height: 1.4;
  display: flex;
}

.tag-cloud__tag {
  color: #1c3d5e;
  border-radius: 3px;
  padding: .1rem .3rem;
  line-height: 1.2;
  text-decoration: none;
  transition: color .15s, background-color .15s;
  display: inline-block;
}

.tag-cloud__tag:hover, .tag-cloud__tag:focus-visible {
  color: #00103d;
  background-color: #cfdbe6;
}

.tag-cloud__tag.is-active {
  color: #00103d;
  background-color: #fdba35;
  font-weight: 700;
}

.resources-search {
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1rem;
  display: flex;
}

.resources-search__input {
  font: inherit;
  background-color: #fff;
  border: 1px solid #b8c2d0;
  border-radius: 4px;
  flex: 14rem;
  padding: .55rem .85rem;
}

.resources-search__input:focus-visible {
  outline-offset: 1px;
  border-color: #003668;
  outline: 2px solid #fdba35;
}

.resources-search__button {
  color: #fff;
  cursor: pointer;
  background-color: #003668;
  border: 0;
  border-radius: 4px;
  padding: .55rem 1rem;
  font-weight: 600;
}

.resources-search__button:hover, .resources-search__button:focus-visible {
  background-color: #00103d;
}

.resources-controls {
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  display: flex;
}

.resources-controls__count {
  color: #555;
  flex: auto;
  font-size: .9rem;
}

.resources-controls__sort label {
  color: #555;
  margin-right: .4rem;
  font-size: .85rem;
}

.resources-controls__sort select {
  font: inherit;
  background-color: #fff;
  border: 1px solid #b8c2d0;
  border-radius: 4px;
  padding: .35rem .5rem;
}

.resources-controls__reset {
  color: #555;
  cursor: pointer;
  background-color: #0000;
  border: 1px solid #b8c2d0;
  border-radius: 4px;
  padding: .4rem .85rem;
  font-size: .85rem;
}

.resources-controls__reset:hover:not(:disabled), .resources-controls__reset:focus-visible:not(:disabled) {
  color: #00103d;
  background-color: #cfdbe6;
}

.resources-controls__reset:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.resources-chips {
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: 1rem;
  display: flex;
}

.resources-chips__chip {
  color: #00103d;
  cursor: pointer;
  background-color: #fff;
  border: 1px solid #b8c2d0;
  border-radius: 999px;
  align-items: center;
  gap: .3rem;
  padding: .4rem .85rem;
  font-size: .85rem;
  font-weight: 600;
  transition: background-color .15s, border-color .15s;
  display: inline-flex;
}

.resources-chips__chip:hover {
  background-color: #cfdbe6;
}

.resources-chips__chip[aria-pressed="true"] {
  color: #fff;
  background-color: #003668;
  border-color: #003668;
}

.resources-chips__chip:before {
  content: "";
  border: 1px solid;
  border-radius: 50%;
  width: 14px;
  height: 14px;
  display: inline-block;
}

.resources-chips__chip[aria-pressed="true"]:before {
  background-color: #fdba35;
  border-color: #fdba35;
}

.resource-grid {
  gap: 1rem;
  display: grid;
}

.resource-card {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 6px;
  grid-template-columns: 100px 1fr;
  align-items: start;
  gap: 1rem;
  padding: 1rem;
  transition: box-shadow .15s, transform .15s;
  display: grid;
}

.resource-card.is-hidden {
  display: none;
}

.resource-card:hover {
  box-shadow: 0 4px 12px #00000014;
}

@media (width >= 576px) {
  .resource-card {
    grid-template-columns: 120px 1fr;
  }
}

.resource-card__media img {
  background-color: #cfdbe6;
  border-radius: 4px;
  width: 100%;
  max-width: 120px;
  height: auto;
  display: block;
}

.resource-card__title {
  margin: 0 0 .4rem;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1.3;
}

.resource-card__title a {
  color: #003668;
  text-decoration: none;
}

.resource-card__title a:hover, .resource-card__title a:focus-visible {
  color: #00103d;
  text-decoration: underline;
}

.resource-card__meta {
  color: #555;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: .4rem;
  font-size: .8rem;
  display: flex;
}

.resource-card__category {
  color: #00103d;
  background-color: #cfdbe6;
  border-radius: 3px;
  padding: .05rem .5rem;
  font-weight: 600;
  display: inline-block;
}

.resource-card__descr {
  color: #333;
  margin: 0;
  font-size: .9rem;
  line-height: 1.5;
}

.pagination-bar {
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: .4rem;
  margin-block: 1.25rem;
  display: flex;
}

.pagination-bar__button {
  color: #003668;
  cursor: pointer;
  min-width: 2.4rem;
  font: inherit;
  background-color: #fff;
  border: 1px solid #b8c2d0;
  border-radius: 4px;
  padding: .4rem .8rem;
  font-weight: 600;
}

.pagination-bar__button:hover:not(:disabled), .pagination-bar__button:focus-visible:not(:disabled) {
  background-color: #cfdbe6;
}

.pagination-bar__button.is-current {
  color: #fff;
  background-color: #003668;
  border-color: #003668;
}

.pagination-bar__button:disabled {
  opacity: .4;
  cursor: not-allowed;
}

.pagination-bar__info {
  color: #555;
  margin-inline: .5rem;
  font-size: .85rem;
}

.resources-empty {
  text-align: center;
  color: #666;
  padding: 3rem 1rem;
  font-style: italic;
}

.resources-empty.is-hidden {
  display: none;
}

.archive-list {
  gap: .5rem;
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
}

.archive-list__item {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 4px;
}

.archive-list__item a {
  color: #003668;
  justify-content: space-between;
  align-items: center;
  padding: .75rem 1rem;
  font-weight: 600;
  text-decoration: none;
  display: flex;
}

.archive-list__item a:hover, .archive-list__item a:focus-visible {
  color: #00103d;
  background-color: #cfdbe6;
}

.archive-list__item a .material-icons {
  color: #3f5f96;
}

.post-list__intro {
  text-align: center;
  max-width: 60rem;
  margin: 0 auto 2rem;
}

.post-list__intro h1 {
  color: #003668;
  margin-top: 0;
}

.post-list__intro p {
  line-height: 1.55;
}

.post-list__chips {
  flex-wrap: wrap;
  justify-content: center;
  gap: .4rem;
  margin-bottom: 1.5rem;
  display: flex;
}

.post-card {
  grid-template-columns: 1fr;
  gap: 1rem;
  display: grid;
}

.post-card.is-hidden {
  display: none;
}

.post-card__media img {
  background-color: #cfdbe6;
  border-radius: 4px;
  width: 100%;
  height: auto;
}

.post-card__title {
  color: #003668;
  margin: 0 0 .5rem;
  line-height: 1.25;
}

.post-card__title a {
  color: #003668;
  text-decoration: none;
}

.post-card__title a:hover, .post-card__title a:focus-visible {
  color: #00103d;
  text-decoration: underline;
}

.post-card__meta {
  color: #555;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: .5rem;
  font-size: .85rem;
  display: flex;
}

.post-card__category {
  color: #00103d;
  background-color: #cfdbe6;
  border-radius: 3px;
  padding: .05rem .5rem;
  font-weight: 600;
  display: inline-block;
}

.post-card__descr {
  color: #333;
  margin: 0;
  line-height: 1.55;
}

.post-card--primary {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 8px;
  padding: 1.5rem;
  box-shadow: 0 2px 8px #0000000d;
}

.post-card--primary .post-card__title {
  font-size: 1.6rem;
}

@media (width >= 768px) {
  .post-card--primary {
    grid-template-columns: 320px 1fr;
    align-items: center;
  }
}

.post-card--secondary {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 6px;
  padding: 1.25rem;
}

.post-card--secondary .post-card__title {
  font-size: 1.2rem;
}

.post-card--list {
  background-color: #fff;
  border: 1px solid #d0d8e2;
  border-radius: 6px;
  padding: 1rem;
}

@media (width >= 576px) {
  .post-card--list {
    grid-template-columns: 100px 1fr;
    align-items: start;
  }
}

.post-card--list .post-card__title {
  font-size: 1rem;
}

.post-list__featured {
  margin-bottom: 1.5rem;
}

.post-list__secondaries {
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-bottom: 1.5rem;
  display: grid;
}

@media (width >= 768px) {
  .post-list__secondaries {
    grid-template-columns: 1fr 1fr;
  }
}

.post-list__remaining {
  gap: .75rem;
  display: grid;
}

.post-detail {
  max-width: 56rem;
  margin: 0 auto;
  padding-block: 1.5rem;
  padding-inline: 1rem;
}

.post-detail__back {
  color: #1c3d5e;
  align-items: center;
  gap: .3rem;
  margin-bottom: 1rem;
  text-decoration: none;
  display: inline-flex;
}

.post-detail__back:hover, .post-detail__back:focus-visible {
  color: #00103d;
  text-decoration: underline;
}

.post-detail__header-image {
  object-fit: cover;
  background-color: #cfdbe6;
  border-radius: 6px;
  width: 100%;
  max-height: 360px;
  margin-bottom: 1rem;
}

.post-detail__header-image[hidden], .post-detail__header-image:not([src]) {
  display: none;
}

.post-detail__title {
  color: #003668;
  margin: 0 0 .5rem;
  line-height: 1.2;
}

.post-detail__meta {
  color: #555;
  flex-wrap: wrap;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1rem;
  font-size: .9rem;
  display: flex;
}

.post-detail__category {
  color: #00103d;
  background-color: #cfdbe6;
  border-radius: 3px;
  padding: .1rem .6rem;
  font-weight: 600;
  display: inline-block;
}

.post-detail__author {
  color: #00103d;
  font-weight: 600;
}

.post-detail__author:empty {
  display: none;
}

.post-detail__download {
  color: #00103d;
  background-color: #fdba35;
  border-radius: 4px;
  align-items: center;
  gap: .4rem;
  margin-bottom: 1.5rem;
  padding: .55rem 1.1rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
}

.post-detail__download[hidden] {
  display: none !important;
}

.post-detail__download:hover, .post-detail__download:focus-visible {
  color: #00103d;
  background-color: #fdad0f;
}

.post-detail__body {
  color: #222;
  line-height: 1.7;
}

.post-detail__body h1, .post-detail__body h2, .post-detail__body h3, .post-detail__body h4, .post-detail__body h5, .post-detail__body h6 {
  color: #003668;
  margin-top: 1.75rem;
  margin-bottom: .5rem;
}

.post-detail__body h2 {
  font-size: 1.5rem;
}

.post-detail__body h3 {
  font-size: 1.25rem;
}

.post-detail__body p {
  margin-block: .75rem;
}

.post-detail__body a {
  color: #1c3d5e;
  text-decoration: underline;
}

.post-detail__body a:hover, .post-detail__body a:focus-visible {
  color: #00103d;
}

.post-detail__body img {
  border-radius: 4px;
  max-width: 100%;
  height: auto;
  margin-block: 1rem;
  display: block;
}

.post-detail__body img[src$="#left"] {
  float: left;
  max-width: 50%;
  margin-right: 1rem;
}

.post-detail__body img[src$="#none"] {
  float: none;
  margin-inline: auto;
}

.post-detail__body ul, .post-detail__body ol {
  margin-block: .75rem;
  padding-left: 1.5rem;
}

.post-detail__body li {
  margin-block: .3rem;
}

.post-detail__body blockquote {
  color: #555;
  border-left: 4px solid #cfdbe6;
  margin-block: 1rem;
  padding-left: 1rem;
  font-style: italic;
}

.post-detail__body table {
  border-collapse: collapse;
  width: 100%;
  margin-block: 1rem;
}

.post-detail__body table th, .post-detail__body table td {
  text-align: left;
  border: 1px solid #d0d8e2;
  padding: .5rem .75rem;
}

.post-detail__body table th {
  color: #00103d;
  background-color: #cfdbe6;
}

.post-detail__body code {
  background-color: #cfdbe6;
  border-radius: 3px;
  padding: .1rem .3rem;
  font-size: .9em;
}

.post-detail__body pre {
  color: #fff;
  background-color: #00103d;
  border-radius: 6px;
  padding: 1rem;
  overflow-x: auto;
}

.post-detail__body pre code {
  color: inherit;
  background: none;
}

.post-detail__body .footnotes {
  color: #555;
  border-top: 1px solid #d0d8e2;
  margin-top: 2rem;
  padding-top: 1rem;
  font-size: .85rem;
}

.post-detail__body .footnotes-sep {
  display: none;
}

.post-detail__body .footnote-ref a, .post-detail__body .footnote-backref {
  color: #1c3d5e;
  text-decoration: none;
}

.post-detail__body .footnote-ref a:hover, .post-detail__body .footnote-backref:hover {
  text-decoration: underline;
}

.post-detail__not-found {
  text-align: center;
  color: #666;
  padding: 3rem 1rem;
}

.post-detail__not-found h2 {
  color: #003668;
}

.home-notices:empty, .home-notices > .container-xl > #notices-banner:empty {
  display: none;
}

.home-notices {
  padding-block: 1rem 0;
}

#notices-banner {
  flex-direction: column;
  gap: .75rem;
  display: flex;
}

#notices-banner:empty {
  display: none;
}

.notice-card {
  background-color: #cfdbe6;
  border-left: 4px solid #3375a0;
  border-radius: 6px;
  padding: 1rem 1.25rem;
  box-shadow: 0 1px 3px #0000000f;
}

.notice-card--resource {
  border-left-color: #fdba35;
}

.notice-card--event {
  border-left-color: #3375a0;
}

.notice-card__header {
  color: #00103d;
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: .25rem;
  font-size: .85rem;
  font-weight: 700;
  display: block;
}

.notice-card__title {
  color: #003668;
  margin: 0 0 .5rem;
  font-size: 1.2rem;
}

.notice-card__body {
  color: #333;
  margin: 0;
  line-height: 1.5;
}

.notice-card__link {
  color: #fff;
  background-color: #003668;
  border-radius: 4px;
  margin-top: .6rem;
  padding: .4rem 1rem;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
}

.notice-card__link:hover, .notice-card__link:focus-visible {
  color: #fff;
  background-color: #00103d;
}

.home-main-links {
  padding-block: 1rem 2.5rem;
}

.main-links-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: .5rem;
  display: grid;
}

@media (width >= 768px) {
  .main-links-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
  }
}

.main-links__button {
  text-align: center;
  color: #fff;
  cursor: pointer;
  background-color: #003668;
  border: 3px solid #0000;
  border-radius: 8px;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  width: 100%;
  height: 100%;
  min-height: 180px;
  padding: 1.25rem 1rem;
  transition: background-color .2s, border-color .2s, transform .2s;
  display: flex;
}

.main-links__button:hover {
  background-color: #3375a0;
  transform: translateY(-2px);
}

.main-links__button[aria-expanded="true"] {
  background-color: #3375a0;
  border-color: #fdba35;
}

.main-links__icon {
  object-fit: contain;
  width: 50px;
  height: 50px;
}

.main-links__icon--dark, .main-links__button:hover .main-links__icon--light, .main-links__button[aria-expanded="true"] .main-links__icon--light {
  display: none;
}

.main-links__button:hover .main-links__icon--dark, .main-links__button[aria-expanded="true"] .main-links__icon--dark {
  display: block;
}

.main-links__title {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
}

@media (width >= 768px) {
  .main-links__title {
    font-size: 1.25rem;
  }
}

.main-links__descr {
  color: #ffffffe6;
  margin: 0;
  font-size: .85rem;
  line-height: 1.4;
}

.main-links-panels {
  margin-top: 1rem;
}

.main-links__panel {
  background-color: #3375a0;
  border: 3px solid #fdba35;
  border-radius: 8px;
}

.main-links__panel-inner {
  padding: 1.5rem;
}

.main-links__sublink {
  color: #fff;
  background-color: #0000;
  border-radius: 4px;
  align-items: center;
  gap: .5rem;
  margin-bottom: .5rem;
  padding: .6rem .85rem;
  font-weight: 500;
  text-decoration: none;
  transition: transform .15s cubic-bezier(.34, 1.56, .64, 1), background-color .15s;
  display: flex;
  position: relative;
}

.main-links__sublink:before {
  content: "›";
  color: #fdba35;
  flex-shrink: 0;
  font-size: 1.4rem;
  line-height: 1;
}

.main-links__sublink:hover, .main-links__sublink:focus-visible {
  color: #fdba35;
  background-color: #ffffff2e;
  text-decoration: none;
  transform: translateX(8px);
}

.main-links__sublink--new {
  background-color: #fdba352e;
  font-weight: 700;
}

.main-links__sublink-title {
  flex: auto;
  font-size: .95rem;
  line-height: 1.3;
}

.main-links__sublink-badge {
  color: #00103d;
  text-transform: uppercase;
  letter-spacing: .3px;
  background-color: #fdba35;
  border-radius: 999px;
  flex-shrink: 0;
  padding: .15rem .5rem;
  font-size: .65rem;
  font-weight: 700;
  display: inline-block;
}

.home-stats {
  background-color: #cfdbe6;
  border-radius: 8px;
  margin-block: 2rem;
  padding-block: 3rem;
}

.home-stats__heading {
  text-align: center;
  color: #003668;
  margin: 0 0 2rem;
  font-size: 1.5rem;
  font-weight: 700;
}

@media (width >= 768px) {
  .home-stats__heading {
    font-size: 1.85rem;
  }
}

.home-stats__grid {
  grid-template-columns: 1fr;
  gap: 1.5rem;
  max-width: 1100px;
  margin-inline: auto;
  padding-inline: 1rem;
  display: grid;
}

@media (width >= 768px) {
  .home-stats__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.stat-counter {
  text-align: center;
  background-color: #fff;
  border-radius: 8px;
  padding: 1.5rem;
  box-shadow: 0 2px 8px #0000000f;
}

.stat-counter__title {
  color: #003668;
  margin: .75rem 0 0;
  font-size: 1.1rem;
  font-weight: 700;
}

.stat-counter__value {
  margin-block: 0 .5rem;
  font-family: Lato, sans-serif;
  font-size: 2.5rem;
  font-weight: 900;
  line-height: 1;
}

@media (width >= 768px) {
  .stat-counter__value {
    font-size: 3rem;
  }
}

.stat-counter__descr {
  color: #555;
  margin: .5rem 0 0;
  font-size: .85rem;
}

.stat-counter__link {
  color: #1c3d5e;
  align-items: center;
  gap: .3rem;
  margin-top: .75rem;
  font-size: .85rem;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.stat-counter__link:hover, .stat-counter__link:focus-visible {
  color: #00103d;
  text-decoration: underline;
}

.stat-counter__link .material-icons {
  font-size: .9rem;
}

@media (prefers-reduced-motion: reduce) {
  .main-links__sublink {
    transition: none;
  }

  .main-links__sublink:hover, .main-links__sublink:focus-visible, .main-links__button:hover {
    transform: none;
  }
}

.mobile-drawer.offcanvas {
  color: #fff;
  background-color: #081627;
  width: 280px;
}

.mobile-drawer.offcanvas .offcanvas-header {
  background-color: #00103d;
  border-bottom: 1px solid #ffffff1a;
  padding: 1rem 1.25rem;
}

.mobile-drawer.offcanvas .offcanvas-title {
  color: #fff;
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
}

.mobile-drawer.offcanvas .btn-close {
  filter: invert();
  opacity: .8;
}

.mobile-drawer.offcanvas .btn-close:focus-visible {
  box-shadow: 0 0 0 2px #fdba35;
}

.mobile-drawer.offcanvas .offcanvas-body {
  padding: 0;
}

.mobile-drawer__list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.mobile-drawer__list > li {
  border-bottom: 1px solid #ffffff0f;
}

.mobile-drawer__item {
  color: #fff;
  padding: .85rem 1.25rem;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  transition: background-color .15s, color .15s;
  display: block;
}

.mobile-drawer__item:hover, .mobile-drawer__item:focus-visible {
  color: #fdba35;
  background-color: #ffffff14;
}

.mobile-drawer__sublist {
  background-color: #0000002e;
  margin: 0;
  padding: 0 0 .5rem;
  list-style: none;
}

.mobile-drawer__sublist li a {
  color: #ffffffd9;
  padding: .55rem 1.25rem .55rem 2.5rem;
  font-size: .9rem;
  text-decoration: none;
  transition: background-color .15s, color .15s;
  display: block;
}

.mobile-drawer__sublist li a:hover, .mobile-drawer__sublist li a:focus-visible {
  color: #fdba35;
  background-color: #ffffff14;
}

main section {
  padding-block: 2.5rem;
}

main > section:first-child {
  z-index: 1;
  margin-top: -50px;
  padding-top: 0;
  position: relative;
}

.page-intro-box {
  background-color: #fff;
  border-radius: 8px;
  margin-top: 1.25rem;
  padding: 1.5rem 1.25rem;
  box-shadow: 0 2px 8px #00000014;
}

.intro-card {
  background-color: #fff;
  border-radius: 8px;
  height: 100%;
  padding: 1.5rem 1.25rem;
  box-shadow: 0 2px 8px #00000014;
}

.intro-card__title {
  margin: 0 0 .75rem;
  font-size: 1.5rem;
  font-weight: 700;
}

.intro-card__body {
  margin: 0;
  font-size: 1rem;
  line-height: 1.55;
}

.intro-card--blue {
  color: #00103d;
  background-color: #cfdbe6;
}

.intro-card--navy {
  color: #fff;
  background-color: #003668;
}

.intro-card--navy a {
  color: #fdba35;
}

.intro-card--grey {
  color: #00103d;
  background-color: #eee;
}

.intro-card--bg-panel {
  color: #00103d;
  background-color: #cfdbe6;
}

.home-newsletter .newsletter-panel {
  color: #fff;
  text-align: center;
  background-color: #3375a0;
  border-radius: 8px;
  padding: 2rem 1.5rem;
}

.home-newsletter .newsletter-panel__title {
  margin: 0 0 .5rem;
  font-size: 1.75rem;
  font-weight: 700;
}

.home-newsletter .newsletter-panel__body {
  max-width: 56rem;
  margin: 0 auto 1.25rem;
  line-height: 1.55;
}

.home-newsletter .newsletter-panel__cta {
  color: #00103d;
  background-color: #fdba35;
  border-radius: 999px;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.5rem;
  font-weight: 700;
  text-decoration: none;
  transition: background-color .15s, transform .15s;
  display: inline-flex;
  box-shadow: 0 2px 6px #0003;
}

.home-newsletter .newsletter-panel__cta:hover, .home-newsletter .newsletter-panel__cta:focus-visible {
  color: #00103d;
  background-color: #fdad0f;
  text-decoration: none;
  transform: translateY(-2px);
}

.about-partners__heading {
  text-align: center;
  color: #003668;
  margin: 0 0 1.5rem;
  font-size: 1.75rem;
  font-weight: 700;
}

.about-partners__grid {
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  place-items: center;
  gap: 1.5rem;
  display: grid;
}

.about-partners__logo {
  background-color: #fff;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  min-height: 100px;
  padding: 1rem;
  transition: transform .15s, box-shadow .15s;
  display: flex;
  box-shadow: 0 1px 4px #0000000f;
}

.about-partners__logo:hover, .about-partners__logo:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 4px 12px #0000001f;
}

.about-partners__logo img {
  object-fit: contain;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 70px;
}

.disclaimer-page {
  max-width: 56rem;
  margin: 0 auto;
  padding-inline: 1rem;
}

.disclaimer-page h1, .disclaimer-page h2, .disclaimer-page h3, .disclaimer-page h4 {
  color: #003668;
}

.disclaimer-page h3 {
  margin-top: 0;
  font-size: 1.75rem;
}

.disclaimer-page h4 {
  margin-top: 1.5rem;
  font-size: 1.25rem;
}

.disclaimer-page hr {
  border: 0;
  border-top: 1px solid #c9d3df;
  margin-block: 1.5rem;
}

.disclaimer-page p {
  line-height: 1.6;
}

.disclaimer-page__updated {
  text-align: right;
  color: #555;
  margin-top: 2rem;
  font-size: .85rem;
  font-style: italic;
}

.spanish-intro .container-xl {
  max-width: 56rem;
}

.spanish-intro h1 {
  color: #003668;
  margin-top: 0;
}

.spanish-intro p {
  font-size: 1.05rem;
  line-height: 1.6;
}

.spanish-box {
  padding-block: 2.5rem;
  scroll-margin-top: 1rem;
}

.spanish-box__media img {
  width: 100%;
  max-width: 280px;
  height: auto;
  margin-inline: auto;
  display: block;
}

.spanish-box__title {
  color: #00103d;
  margin: 0 0 .75rem;
  font-size: 1.6rem;
  font-weight: 700;
}

.spanish-box__body {
  line-height: 1.6;
}

.spanish-box__links {
  margin: 1rem 0 0;
  padding-left: 1.25rem;
  list-style: outside;
}

.spanish-box__links li {
  margin-block: .4rem;
}

.spanish-box__links a {
  color: #1c3d5e;
  text-decoration: underline;
}

.spanish-box__links a:hover, .spanish-box__links a:focus-visible {
  color: #00103d;
}

.contactus__intro {
  text-align: center;
  max-width: 56rem;
  margin-inline: auto;
  padding-inline: 1rem;
}

.contactus__title {
  color: #003668;
  margin-top: 0;
}

.contactus__subtitle {
  color: #00103d;
  margin-top: 0;
  font-weight: 500;
}

.contactus__body {
  text-align: left;
  line-height: 1.6;
}

.contactus__newsletter-cta {
  color: #00103d;
  background-color: #fdba35;
  border-radius: 999px;
  align-items: center;
  gap: .5rem;
  margin-top: 1rem;
  padding: .75rem 1.5rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  box-shadow: 0 2px 6px #0003;
}

.contactus__newsletter-cta:hover, .contactus__newsletter-cta:focus-visible {
  color: #00103d;
  background-color: #fdad0f;
  text-decoration: none;
}

.contactus-member {
  background-color: #cfdbe6;
  border-top-left-radius: 1em;
  border-top-right-radius: 1em;
}

.contactus-member__panel {
  text-align: center;
  max-width: 56rem;
  margin-inline: auto;
  padding: 2rem 1rem;
}

.contactus-member__title {
  color: #003668;
  margin-top: 0;
}

.contactus-member__body {
  text-align: left;
  line-height: 1.6;
}

.contactus-member__cta {
  color: #fff;
  background-color: #003668;
  border-radius: 4px;
  margin-top: .5rem;
  padding: .6rem 1.4rem;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
}

.contactus-member__cta:hover, .contactus-member__cta:focus-visible {
  color: #fff;
  background-color: #00103d;
  text-decoration: none;
}

.contactus-channels {
  background-color: #cfdbe6;
  padding-block: 2rem 3rem;
}

.contactus-channels__grid {
  flex-wrap: wrap;
  justify-content: center;
  gap: 3rem;
  display: flex;
}

.contactus-channels__group {
  text-align: center;
}

.contactus-channels__group h3 {
  color: #003668;
  margin: 0 0 .5rem;
  font-size: 1.5rem;
}

.contactus-channels__icons {
  justify-content: center;
  gap: 1rem;
  display: flex;
}

.contactus-channels__icons a {
  color: #003668;
  font-size: 3.5rem;
  line-height: 1;
  transition: color .15s, transform .15s;
}

.contactus-channels__icons a:hover, .contactus-channels__icons a:focus-visible {
  color: #fdad0f;
  transform: translateY(-3px);
}

.contactus-channels__email {
  color: #003668;
  align-items: center;
  gap: .6rem;
  font-size: 1.2rem;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
}

.contactus-channels__email i {
  font-size: 2rem;
}

.contactus-channels__email:hover, .contactus-channels__email:focus-visible {
  color: #00103d;
  text-decoration: underline;
}

.cornerstone-intro {
  padding-top: 2.5rem;
}

.cornerstone-intro h1 {
  color: #003668;
  margin-top: 0;
}

.cornerstone-intro__body {
  max-width: 60rem;
  margin: 1rem auto 0;
  line-height: 1.6;
}

.error-container {
  text-align: center;
  padding: 4rem 1rem;
}

.error-container h1 {
  color: #003668;
  margin: 0;
  font-size: 6rem;
  font-weight: 900;
}

.error-container h2 {
  color: #00103d;
  margin: .5rem 0 1.5rem;
  font-size: 1.5rem;
}

.error-container a {
  color: #00103d;
  background-color: #fdba35;
  border-radius: 999px;
  padding: .6rem 1.5rem;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
}

.error-container a:hover, .error-container a:focus-visible {
  background-color: #fdad0f;
}
/*# sourceMappingURL=404.8c1c22dc.css.map */
