/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
@import url(https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap);

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%
}

body {
  margin: 0
}

main {
  display: block
}

h1 {
  font-size: 2em;
  margin: .67em 0
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible
}

pre {
  font-family: monospace, monospace;
  font-size: 1em
}

a {
  background-color: transparent
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em
}

small {
  font-size: 80%
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

img {
  border-style: none
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0
}

button,
input {
  overflow: visible
}

button,
select {
  text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted ButtonText
}

fieldset {
  padding: .35em .75em .625em
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

details {
  display: block
}

summary {
  display: list-item
}

template {
  display: none
}

[hidden] {
  display: none
}

body,
html {
  font-family: Inter, sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #212121;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: #fff;
  scroll-behavior: smooth
}

#body-wrapper {
  margin: 0 auto
}

.nowrap {
  white-space: nowrap
}

.container-responsive {
  width: 100%;
  max-width: 1240px;
  margin-right: auto;
  margin-left: auto
}

h1 {
  margin-top: 0
}

#page-content section,
#page-footer {
  padding: 3.75rem
}

#page-content section .container-responsive,
#page-footer .container-responsive {
  max-width: 1000px
}

@media (max-width:992px) {

  #page-content section,
  #page-footer {
    padding: 2.75rem
  }
}

@media (max-width:768px) {

  #page-content section,
  #page-footer {
    padding: 2rem
  }
}

a {
  color: inherit;
  transition: color .2s
}

a:hover {
  text-decoration: none;
  color: #85ba39
}

p {
  font-size: inherit
}

p a {
  font-weight: bolder;
  color: #85ba39
}

p a:hover {
  text-decoration: underline
}

hr {
  margin-top: 2rem;
  margin-bottom: 2rem
}

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

.serif {
  font-family: Inter, sans-serif
}

.sans,
.sans-serif,
.sansserif {
  font-family: Inter, sans-serif
}

#body-wrapper .btn,
.hs-button.primary.large {
  font-size: 1rem;
  border-radius: 20rem;
  padding: 1.5em 2.5em;
  line-height: 1.25em;
  box-shadow: none;
  font-family: Inter, sans-serif;
  font-weight: 500;
  border: 0 solid transparent;
  background-clip: border-box;
  will-change: transform;
  background-color: #7dc242
}

#body-wrapper .btn,
#body-wrapper .btn *,
#body-wrapper .btn .fl-button-text,
#body-wrapper .btn span,
.hs-button.primary.large,
.hs-button.primary.large *,
.hs-button.primary.large .fl-button-text,
.hs-button.primary.large span {
  transition: all .5s cubic-bezier(.19, 1, .12, 1)
}

#body-wrapper .btn:hover,
.hs-button.primary.large:hover {
  transform: translatey(-.125rem);
  box-shadow: 0 .25rem .5rem rgba(0, 0, 0, .2)
}

#body-wrapper .btn,
#body-wrapper .btn *,
#body-wrapper .btn .fl-button-text,
#body-wrapper .btn span,
.hs-button.primary.large,
.hs-button.primary.large *,
.hs-button.primary.large .fl-button-text,
.hs-button.primary.large span {
  color: #fff
}

#body-wrapper .btn:hover,
.hs-button.primary.large:hover {
  background-color: #649e33
}

#body-wrapper .btn:hover,
#body-wrapper .btn:hover *,
#body-wrapper .btn:hover .fl-button-text,
#body-wrapper .btn:hover span,
.hs-button.primary.large:hover,
.hs-button.primary.large:hover *,
.hs-button.primary.large:hover .fl-button-text,
.hs-button.primary.large:hover span {
  color: #fff
}

#body-wrapper #page-content {
  overflow-x: clip
}

#body-wrapper #page-content .green {
  color: #7dc242
}

#body-wrapper #page-content .blue {
  color: #0063a6
}

#body-wrapper #page-content .teal {
  color: #00b09b
}

#body-wrapper #page-content .ib {
  display: inline-block
}

#body-wrapper #page-content h2 {
  color: #00345a;
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 1.13em;
  margin: 0
}

#body-wrapper #page-content h3 {
  color: #00345a;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.375em;
  letter-spacing: .01em;
  margin: 0
}

#body-wrapper #page-content p {
  margin-bottom: 0;
  letter-spacing: .01em;
  color: #333;
  font-size: 1rem;
  line-height: 1.375em
}

#body-wrapper #page-content .large-text {
  font-size: 1.375rem;
  line-height: 1.27em;
  letter-spacing: .01em
}

#body-wrapper #hero {
  padding-top: 2.5rem
}

#body-wrapper #hero .logos-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  margin-bottom: 2.5rem
}

#body-wrapper #hero .logo-link {
  padding-inline: 1.25rem
}

#body-wrapper #hero .logo-link:first-child {
  padding-left: 0;
  border-right: 1px solid #ccc
}

#body-wrapper #hero .logo-link:last-child {
  padding-right: 0
}

#body-wrapper #hero .container-responsive {
  max-width: 81.5625rem
}

#body-wrapper #hero .hero-card {
  display: grid;
  grid-template-columns: 69% 31%
}

#body-wrapper #hero .text-side {
  padding: 5rem 3.75rem;
  border-radius: 1.25rem 0 0 1.25rem;
  border: 1px solid #f2f2f2;
  background: linear-gradient(98deg, #f4feec 10.22%, #f2f9fe 93.82%)
}

#body-wrapper #hero .img-side {
  border-radius: 0 1.25rem 1.25rem 0;
  overflow: clip
}

#body-wrapper #hero .img-side .img-bg {
  width: auto;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover
}

#body-wrapper #hero h1 {
  color: #00345a;
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.15em
}

#body-wrapper #hero p {
  color: #404042;
  font-size: 1.375rem;
  font-weight: 500;
  line-height: 1.36em;
  margin-block: 1.875rem 2.5rem
}

#body-wrapper #hero .btn {
  max-width: 16.875rem;
  width: 100%
}

#body-wrapper #optimize h2 {
  margin-bottom: 1.875rem
}

#body-wrapper #support-services .container-responsive {
  border: 1px solid #ccc;
  border-radius: 1.25rem;
  padding: 2.5rem 3.75rem
}

#body-wrapper #support-services h2 {
  margin-bottom: 2.5rem
}

#body-wrapper #support-services .w-710 {
  max-width: 44.375rem;
  margin-inline: auto
}

#body-wrapper #support-services .info-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  justify-content: center;
  align-items: center;
  gap: 1.875rem
}

#body-wrapper #support-services .info-box {
  width: 100%;
  max-width: 13.125rem;
  display: grid;
  grid-template-columns: 1.875rem 1fr;
  gap: .9375rem
}

#body-wrapper #support-services h3 {
  text-wrap: balance
}

#body-wrapper #contributions h2 {
  text-align: center;
  margin-bottom: 2.5rem
}

#body-wrapper #contributions .y-gap {
  row-gap: 2.5rem
}

#body-wrapper #contributions .info-box {
  width: 100%;
  display: grid;
  grid-template-columns: 1.875rem 1fr;
  gap: .9375rem
}

#body-wrapper #contributions h3 {
  text-wrap: balance;
  font-weight: 700;
  margin-bottom: .3125rem
}

#body-wrapper #contributions p {
  margin-bottom: 0;
  color: #333;
  line-height: 1.375em;
  letter-spacing: .01em
}

#body-wrapper #contributions .gradient-card {
  margin-top: 2.5rem;
  display: grid;
  grid-template-columns: .65fr .35875fr;
  padding: 2.5rem 5rem;
  gap: 2.5rem;
  border-radius: 1.25rem;
  background: linear-gradient(275deg, #f4feec 3.89%, #f2f9fe 89.59%);
  justify-content: center;
  align-items: center
}

#body-wrapper #contributions .gradient-card h2 {
  text-align: start;
  margin: 0
}

#body-wrapper #process .container-responsive {
  border: 1px solid #ccc;
  border-radius: 1.25rem;
  padding: 3.75rem
}

#body-wrapper #process h2 {
  font-size: 2.5rem;
  margin: 0 auto
}

#body-wrapper #process hr {
  padding: 0;
  margin: 1.5rem auto;
  width: 100%;
  max-width: 5.25rem;
  border-top: 2px solid #7dc242;
  opacity: 1
}

#body-wrapper #process p {
  margin-bottom: 3.75rem
}

#body-wrapper #process .btn {
  margin-top: 3.75rem
}

#body-wrapper #process .desktop {
  display: block
}

#body-wrapper #process .mobile {
  display: none
}

#body-wrapper #how-it-works h3 {
  color: #1a1a1a;
  font-size: 1.375rem;
  line-height: 1.27em;
  letter-spacing: .01em;
  margin-block: 1.25rem 2.5rem
}

#body-wrapper #how-it-works ol {
  padding-left: 1.5em;
  margin-bottom: 0
}

#body-wrapper #how-it-works li {
  line-height: 1.25em;
  color: #1a1a1a;
  font-size: 1.375rem;
  line-height: 1.27em;
  letter-spacing: .01em
}

#body-wrapper #how-it-works li:nth-child(even) {
  margin-top: .625em;
  margin-bottom: .625em
}

#body-wrapper #how-it-works img {
  border-radius: 1.25rem
}

#body-wrapper #form-row .container-responsive {
  max-width: 81.5625rem;
  padding: 3.75rem;
  border-radius: 1.25rem;
  background: linear-gradient(98deg, #f4feec 10.22%, #f2f9fe 93.82%)
}

#body-wrapper #form-row h2 {
  font-size: 3.125rem;
  font-weight: 700;
  line-height: 115%
}

#body-wrapper #form-row h3 {
  margin-top: 2.25rem;
  color: #7dc242;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 115%;
  letter-spacing: .01em
}

#body-wrapper #form-row .hsfc-Step__Content {
  padding: 0
}

#body-wrapper #page-footer .container-responsive {
  max-width: 81.5625rem;
  padding-top: 1.75rem;
  border-top: 1px solid #e6e6e6
}

#body-wrapper #page-footer .footer-items {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.25rem
}

#body-wrapper #page-footer .footer-items .links-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem
}

#body-wrapper #page-footer .footer-items a {
  color: #000;
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.375em;
  text-decoration: none;
  display: block;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content
}

#body-wrapper #page-footer .footer-items a:hover {
  text-decoration: underline;
  color: #0063a6
}

@media (max-width:1200px) {
  #body-wrapper #form-row h2 {
    font-size: 2.25rem
  }

  #body-wrapper #form-row h3 {
    margin-top: 1.5rem;
    font-size: 1.875rem
  }
}

@media (max-width:992px) {
  #body-wrapper #hero h1 {
    font-size: 2.25rem
  }

  #body-wrapper #hero p {
    font-size: 1.125rem;
    line-height: 1.33em
  }

  #body-wrapper #hero .hero-card {
    display: flex;
    flex-direction: column-reverse;
    gap: 1.5rem
  }

  #body-wrapper #hero .text-side {
    padding: 2.5rem;
    border-radius: 1.25rem;
    text-align: center
  }

  #body-wrapper #hero .img-side {
    border-radius: 1.25rem;
    overflow: clip;
    width: 100%;
    max-width: 18rem;
    margin: 0 auto
  }

  #body-wrapper #hero .img-side .img-bg {
    width: 100%;
    height: auto;
    -o-object-fit: cover;
    object-fit: cover
  }

  #body-wrapper #contributions .gradient-card {
    display: flex;
    flex-direction: column;
    text-align: center;
    gap: 1.5rem;
    padding: 2.5rem 1.5rem
  }

  #body-wrapper #contributions .gradient-card h2 {
    text-align: center;
    text-wrap: balance
  }

  #body-wrapper #learn-more,
  #body-wrapper #process,
  #body-wrapper #support-services {
    padding-inline: 1.5rem
  }

  #body-wrapper #learn-more .container-responsive,
  #body-wrapper #process .container-responsive,
  #body-wrapper #support-services .container-responsive {
    padding: 2.5rem
  }

  #body-wrapper #process .desktop {
    display: none
  }

  #body-wrapper #process .mobile {
    display: block
  }
}

@media (max-width:768px) {

  #body-wrapper #form-row .container-responsive,
  #body-wrapper #process .container-responsive,
  #body-wrapper #support-services .container-responsive {
    padding: 1.5rem
  }

  #body-wrapper #support-services .info-row {
    grid-template-columns: 1fr 1fr
  }

  #body-wrapper #support-services .info-row .info-box {
    margin-inline: auto
  }
}

@media (max-width:576px) {
  #body-wrapper #page-content h2 {
    font-size: 1.5rem
  }

  #body-wrapper #hero h1 {
    font-size: 1.75rem
  }

  #body-wrapper #optimize h2 {
    font-size: 1.5rem
  }

  #body-wrapper #optimize p {
    font-size: 1.125rem !important;
    line-height: 1.33em
  }

  #body-wrapper #support-services .info-row {
    grid-template-columns: 1fr
  }

  #body-wrapper #support-services .info-row .info-box {
    margin-inline: auto
  }

  #body-wrapper #how-it-works h3 {
    font-size: 1.125rem;
    line-height: 1.33em
  }

  #body-wrapper #how-it-works li {
    font-size: 1.125rem;
    line-height: 1.33em
  }

  #body-wrapper #form-row h2 {
    font-size: 1.5rem
  }

  #body-wrapper #form-row h3 {
    margin-top: 1.5rem;
    font-size: 1.25rem
  }

  #body-wrapper #page-footer .footer-items {
    flex-direction: column;
    text-align: center
  }

  #body-wrapper #page-footer .footer-items .links-wrapper {
    justify-content: center
  }
}