/* 1. Use a more-intuitive box-sizing model */
*, *::before, *::after {
  box-sizing: border-box;
}

/* 2. Remove default margin */
* {
  margin: 0;
}

/* 3. Enable keyword animations */
@media (prefers-reduced-motion: no-preference) {
  html {
    interpolate-size: allow-keywords;
  }
}
body {
  /* 4. Add accessible line-height */
  line-height: 1.5;
  /* 5. Improve text rendering */
  -webkit-font-smoothing: antialiased;
}

/* 6. Improve media defaults */
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

/* 7. Inherit fonts for form controls */
input, button, textarea, select {
  font: inherit;
}

/* 8. Avoid text overflows */
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

/* 9. Improve line wrapping */
p {
  text-wrap: pretty;
}

h1, h2, h3, h4, h5, h6 {
  text-wrap: balance;
}

/*
  10. Create a root stacking context
*/
#root, #__next {
  isolation: isolate;
}

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

html {
  scroll-behavior: smooth;
}

.footer .description p, .stats .items .item .description p, .hero .description, .header .link span {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
}

.stats .items .item .cta-title h3, .stats .section-title h2, .hero__form-wrapper .link span, .hero .description ol li::before, .hero__text-wrapper .page-title h1, .header .link span a {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
}

/* --------------------------
Mixins
-------------------------- */
/* --------------------------
Components
-------------------------- */
.header {
  box-shadow: 0 3px 6px rgba(9, 7, 5, 0.19), 0 3px 6px rgba(9, 7, 5, 0.23);
}
.header__outer-wrapper {
  margin: 0 auto;
  max-width: 1290px;
}
.header__inner-wrapper {
  padding-top: 0.625rem;
  padding-right: 1.25rem;
  padding-bottom: 0.625rem;
  padding-left: 1.25rem;
  align-items: center;
  display: flex;
  justify-content: space-between;
}
@media screen and (min-width: 768px) {
  .header__inner-wrapper {
    padding-top: 1.25rem;
    padding-right: 2rem;
    padding-bottom: 1.25rem;
    padding-left: 2rem;
  }
}
.header .image {
  flex: 0 0 2.5rem;
}
@media screen and (min-width: 768px) {
  .header .image {
    flex: 0 0 3.125rem;
  }
}
.header .image img {
  height: 2.5rem;
  object-fit: cover;
  object-position: center;
  width: 2.5rem;
}
@media screen and (min-width: 768px) {
  .header .image img {
    height: 3.125rem;
    width: 3.125rem;
  }
}
.header .link {
  align-items: center;
  column-gap: 0.625rem;
  display: flex;
  justify-content: space-between;
}
.header .link__icon {
  padding-top: 0.3125rem;
  padding-right: 0.3125rem;
  padding-bottom: 0.3125rem;
  padding-left: 0.3125rem;
  background-color: #0B3266;
  border-radius: 50%;
}
.header .link__icon svg {
  height: 1.25rem;
  width: 1.25rem;
}
.header .link span {
  font-size: 0.625rem;
  line-height: 1.2;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .header .link span {
    font-size: 0.875rem;
    line-height: 1.1429;
  }
}
.header .link span a {
  font-size: 0.75rem;
  line-height: 1.3334;
  color: #0B3266;
  text-decoration: none;
}
html[data-whatintent=mouse] .header .link span a {
  transition: all 0.3s ease-in-out;
}
html[data-whatintent=mouse] .header .link span a:hover {
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .header .link span a {
    font-size: 1.125rem;
    line-height: 1.3334;
  }
}

.hero {
  margin: 0 auto;
  max-width: 1290px;
}
.hero__inner-wrapper {
  padding-top: 3.75rem;
  padding-right: 1.25rem;
  padding-bottom: 3.75rem;
  padding-left: 1.25rem;
}
@media screen and (min-width: 1025px) {
  .hero__inner-wrapper {
    padding-right: 2rem;
    padding-left: 2rem;
    align-items: center;
    column-gap: 3.125rem;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
  }
}
@media screen and (min-width: 1025px) {
  .hero__text-wrapper {
    flex: 0 0 calc(50% - 1.5625rem);
  }
}
.hero__text-wrapper .page-title {
  margin-bottom: 0.625rem;
}
.hero__text-wrapper .page-title h1 {
  font-size: 2.25rem;
  line-height: 1.3334;
  color: #0B3266;
}
@media screen and (min-width: 768px) {
  .hero__text-wrapper .page-title h1 {
    font-size: 3.25rem;
    line-height: 1.2308;
  }
}
.hero .description {
  font-size: 1rem;
  line-height: 1.625;
}
.hero .description p:not(:last-child) {
  margin-bottom: 0.625rem;
}
.hero .description ol {
  padding-left: 0;
  counter-reset: counter1;
  list-style: none;
}
.hero .description ol li {
  padding-left: 0;
  counter-increment: counter1;
  position: relative;
}
.hero .description ol li:not(:last-child) {
  margin-bottom: 0.625rem;
}
.hero .description ol li::before {
  font-size: 1rem;
  line-height: 1.625;
  margin-right: 0.3125rem;
  align-items: center;
  background-color: #0B3266;
  border-radius: 50%;
  color: #FFFFFF;
  content: counter(counter1) "";
  display: inline-flex;
  height: 1.5rem;
  justify-content: center;
  width: 1.5rem;
}
.hero .description--is-desktop {
  display: none;
}
@media screen and (min-width: 1025px) {
  .hero .description--is-desktop {
    display: block;
  }
}
.hero .description--is-mobile {
  margin-top: 1.25rem;
}
@media screen and (min-width: 1025px) {
  .hero .description--is-mobile {
    display: none;
  }
}
.hero__form-wrapper {
  margin-top: 1.25rem;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .hero__form-wrapper {
    flex: 0 0 calc(50% - 1.5625rem);
  }
}
@media screen and (min-width: 1025px) {
  .hero__form-wrapper::before {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    background-image: url("../assets/images/favicon.png");
    background-position: center;
    background-size: cover;
    content: "";
    height: 100%;
    opacity: 0.25;
    width: 100%;
    z-index: -1;
  }
}
@media screen and (min-width: 1025px) {
  .hero__form-wrapper-inner {
    margin: 0 auto;
    max-width: 22.5rem;
  }
}
.hero__form-wrapper .link {
  margin-top: 1.25rem;
  padding-top: 0.625rem;
  padding-right: 1.25rem;
  padding-bottom: 0.625rem;
  padding-left: 1.25rem;
  align-items: center;
  background-color: #FFFFFF;
  border: 0.125rem solid #0B3266;
  border-radius: 2rem;
  column-gap: 0.625rem;
  display: flex;
  justify-content: center;
}
.hero__form-wrapper .link__icon {
  padding-top: 0.3125rem;
  padding-right: 0.3125rem;
  padding-bottom: 0.3125rem;
  padding-left: 0.3125rem;
  background-color: #0B3266;
  border-radius: 50%;
}
.hero__form-wrapper .link__icon svg {
  height: 1.25rem;
  width: 1.25rem;
}
.hero__form-wrapper .link span {
  font-size: 1rem;
  line-height: 1.625;
  color: #0B3266;
  text-align: center;
}
.hero__form-wrapper .link span a {
  color: #0B3266;
  text-decoration: none;
}
html[data-whatintent=mouse] .hero__form-wrapper .link span a {
  transition: all 0.3s ease-in-out;
}
html[data-whatintent=mouse] .hero__form-wrapper .link span a:hover {
  text-decoration: underline;
}
@media screen and (min-width: 768px) {
  .hero__form-wrapper .link span a {
    font-size: 1.125rem;
    line-height: 1.3334;
  }
}

.stats {
  margin: 0 auto;
  max-width: 56.25rem;
}
.stats__inner-wrapper {
  padding-right: 1.25rem;
  padding-bottom: 3.75rem;
  padding-left: 1.25rem;
}
@media screen and (min-width: 1025px) {
  .stats__inner-wrapper {
    padding-right: 2rem;
    padding-bottom: 6.25rem;
    padding-left: 2rem;
  }
}
.stats .section-title {
  margin-bottom: 2.5rem;
  text-align: center;
}
.stats .section-title h2 {
  font-size: 1.75rem;
  line-height: 1.3572;
  color: #0B3266;
}
@media screen and (min-width: 1025px) {
  .stats .section-title h2 {
    font-size: 2.5rem;
    line-height: 1.25;
  }
}
.stats .items {
  display: flex;
  flex-direction: column;
  row-gap: 1.25rem;
}
@media screen and (min-width: 1025px) {
  .stats .items {
    flex-direction: row;
    justify-content: space-between;
  }
}
.stats .items .item {
  text-align: center;
}
.stats .items .item .cta-title {
  margin-bottom: 0.3125rem;
}
.stats .items .item .cta-title h3 {
  font-size: 1.25rem;
  line-height: 1.4;
  color: #0B3266;
}
@media screen and (min-width: 768px) {
  .stats .items .item .cta-title h3 {
    font-size: 2.5rem;
    line-height: 1.25;
  }
}
.stats .items .item .description {
  margin: 0 auto;
  max-width: 12.5rem;
  margin-bottom: 0.625rem;
}
@media screen and (min-width: 1025px) {
  .stats .items .item .description {
    margin: 0 auto;
    max-width: 15.625rem;
  }
}
.stats .items .item .description p {
  font-size: 1rem;
  line-height: 1.25;
}

.footer {
  background-color: #0B3266;
}
.footer__outer-wrapper {
  margin: 0 auto;
  max-width: 1290px;
}
.footer__inner-wrapper {
  padding-top: 3.75rem;
  padding-right: 1.25rem;
  padding-bottom: 3.75rem;
  padding-left: 1.25rem;
}
@media screen and (min-width: 1025px) {
  .footer__inner-wrapper {
    padding-top: 6.25rem;
    padding-right: 2rem;
    padding-bottom: 6.25rem;
    padding-left: 2rem;
  }
}
.footer .description p {
  font-size: 1rem;
  line-height: 1.5;
  color: #FFFFFF;
}
.footer .description p:not(:last-child) {
  margin-bottom: 0.625rem;
}