/* Theme base styles */
:root {
    --color-ui-black: #333333;
    --color-ui-grey: #DFDFDF;
    --color-ui-dark-grey: #6E6E6E;
    --color-ui-light-grey: #F0F0F0;

    --color-brand-green: hsl(146, 100%, 35%);  /* #00b34d */
    --color-brand-green-darker: hsl(146, 100%, 27%);

    --color-brand-yellow: hsl(46, 85%, 57%); /* #efc334 */
    --color-brand-dark-blue: hsl(220, 71%, 12%);
    --color-brand-light-blue: hsl(195, 40%, 96%);  /* #F2F8F9 */
    --color-light-green: hsl(160, 37%, 97%); /* #F4FAF8 */

    --color-brand-green-hover: hsl(146, 100%, 40%);
    --color-brand-yellow-hover: hsl(46, 85%, 62%);
    --color-brand-dark-blue-hover: hsl(220, 71%, 17%);
}

* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

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

img {
  display: block;
  width: 100%;
}
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body {
  margin: 0;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

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

/* Grouping content
   ========================================================================== */

/**
 * Add the correct box sizing in Firefox.
 */

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

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

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

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

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

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

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

/**
 * Remove the inheritance of text transform in Edge and Firefox.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

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

/**
 * Remove the inner border and padding in Firefox.
 */

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

/**
 * Restore the focus styles unset by the previous rule.
 */

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

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * Remove the padding so developers are not caught out when they zero out `fieldset` elements in all browsers.
 */

legend {
  padding: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  vertical-align: baseline;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

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

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

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

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

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

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge and Firefox.
 */

details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Objects
Non-cosmetic design patterns including grid and layout classes)
*/



/* CSS variables */

:root {
  --column-gap: 2.13%;
  --column-width-multiplier: 8.333;
}

.body-container {
  overflow: hidden;
}

/* Mobile layout */

.row-fluid {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}


  .row-fluid .span1,
  .row-fluid .span2,
  .row-fluid .span3,
  .row-fluid .span4,
  .row-fluid .span5,
  .row-fluid .span6,
  .row-fluid .span7,
  .row-fluid .span8,
  .row-fluid .span9,
  .row-fluid .span10,
  .row-fluid .span11,
  .row-fluid .span12{
  min-height: 1px;
  width: 100%;
}

/* Desktop layout */

@media (min-width: 768px) {
  .row-fluid {
    flex-wrap: nowrap;
    justify-content: space-between;
  }

  
    .row-fluid .span1 {
      width: calc(var(--column-width-multiplier) * 1% * 1 - var(--column-gap) * (11 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span2 {
      width: calc(var(--column-width-multiplier) * 1% * 2 - var(--column-gap) * (10 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span3 {
      width: calc(var(--column-width-multiplier) * 1% * 3 - var(--column-gap) * (9 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span4 {
      width: calc(var(--column-width-multiplier) * 1% * 4 - var(--column-gap) * (8 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span5 {
      width: calc(var(--column-width-multiplier) * 1% * 5 - var(--column-gap) * (7 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span6 {
      width: calc(var(--column-width-multiplier) * 1% * 6 - var(--column-gap) * (6 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span7 {
      width: calc(var(--column-width-multiplier) * 1% * 7 - var(--column-gap) * (5 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span8 {
      width: calc(var(--column-width-multiplier) * 1% * 8 - var(--column-gap) * (4 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span9 {
      width: calc(var(--column-width-multiplier) * 1% * 9 - var(--column-gap) * (3 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span10 {
      width: calc(var(--column-width-multiplier) * 1% * 10 - var(--column-gap) * (2 * var(--column-width-multiplier) / 100));
    }
  
    .row-fluid .span11 {
      width: calc(var(--column-width-multiplier) * 1% * 11 - var(--column-gap) * (1 * var(--column-width-multiplier) / 100));
    }
  
}


.fs-container {
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  width: 100%;
  max-width: 1440px;
}

.fs-container--narrow {
  max-width: 1024px;
}

@media (min-width: 768px) {
  .fs-container {
    padding-left: 40px;
    padding-right: 40px;
  }
}
.content-wrapper {
  margin: 0 auto;
  padding: 0 1rem;
}

@media screen and (min-width: 1380px) {
  .content-wrapper {
    padding: 0;
  }
}

.dnd-section > .row-fluid {
  margin: 0 auto;
}

.dnd-section .dnd-column {
  padding: 0 1rem;
}

@media (max-width: 767px) {
  .dnd-section .dnd-column {
    padding: 0;
  }
}

/* Elements
Base HMTL elements are styled in this section (<body>, <h1>, <a>, <p>, <button> etc.)
*/

:root {
  --text-size-body: 20px;
  --text-size-sm: 14px;
  --text-size-xs: 12px;
  --text-size-lg: 22px;
  --text-size-h1: 56px;
  --text-size-h2: 40px;
  --text-size-h3: 32px;
  --text-size-h4: 18px;
  --text-size-h5: 16px;
  --text-size-h6: 14px;

  --text-line-height-body: 1.5;
  --text-line-height-sm: 1.25;
  --text-line-height-xs: 1;
  --text-line-height-lg: 1.3;
  --text-line-height-h1: 1.3;
  --text-line-height-h2: 1.3;
  --text-line-height-h3: 1.3;
  --text-line-height-h4: 1.5;
  --text-line-height-h5: 1.25;
  --text-line-height-h6: 1.25;
}

@media screen and (max-width: 1023px) {
  :root {
      --text-size-h1: 28px;
      --text-size-h2: 24px;
      --text-size-h3: 20px;
  }
}

html, body {
  font-family: "Nunito", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 16px;
}


/************** Text Elements **************/
/* Headings */

h1, .h1 {
  font-size: var(--text-size-h1);
  line-height: var(--text-line-height-h1);
  margin-top: 0;
  margin-bottom: 0.3em;
}

h2, .h2 {
  font-size: var(--text-size-h2);
  line-height: var(--text-line-height-h2);
  margin-top: 0;
  margin-bottom: 0.3em;
}

h3, .h3 {
  font-size: var(--text-size-h3);
  line-height: var(--text-line-height-h3);
  margin-top: 0;
  margin-bottom: 0.8em;
}

h4, .h4 {
  font-size: var(--text-size-h4);
  line-height: var(--text-line-height-h4);
  margin-top: 0;
  margin-bottom: 0.8em;
}

h5, .h5 {
  font-size: var(--text-size-h5);
  line-height: var(--text-line-height-h5);
  margin-top: 0;
  margin-bottom: 0.8em;
}

h6, .h6, .fs-subheader {
  font-size: var(--text-size-h6);
  line-height: var(--text-line-height-h6);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  margin: 0 0 1em;
}

blockquote, p {
  font-size: var(--text-size-body);
  line-height: var(--text-line-height-body);
  margin-top: 0;
  margin-bottom: 0.8em;
}




/************** Lists **************/
ul li,
ol li {
  font-size: var(--text-size-body);
  line-height: var(--text-line-height-body);
}

ul ul,
ol ul,
ul ol,
ol ol {
  margin: 0;
}

/************** Links and Media **************/
a {
  color: var(--color-brand-green);
  text-decoration: underline;
}

a:hover,
a:focus
{
  color: var(--color-brand-green-hover);
}

a:hover {
  text-decoration: none;
}

img {}

figure {}

figcaption {}

video {}

iframe {}
/* General Button Styles */
.btn {
  text-transform: uppercase;
  position: relative;
  font-weight: 600;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  letter-spacing: 0.06em;
  font-size: 15px;
  line-height: 1;
  padding: 15px 30px;
  cursor: pointer;
  justify-content: center;
  text-align: center;
  min-width: 64px;
  z-index: 10;
  text-decoration: none;

  /* Arrow and animation */
  span {
    display: inline-block;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease-out;
    margin-bottom: -1px;
  }
}

@media (min-width: 768px) {
  .btn {
    transition: color 0.2s ease-out, background-color 0.2s ease-out, background-position 0.4s ease-out;
    will-change: color, background-color, background-position;
    background-size: 400% 100%;
    background-position: 0 0;

    &::after {
      margin-top: 1px;
      opacity: 0;
      position: absolute;
      right: 22px;
      transition: opacity 0.2s ease-out, right 0.2s ease-out;
      height: 100%;
      display: flex;
      align-items: center;
    }

    &.btn--arrow {
      span {
        transform: translateX(-10px);
      }

      &::after {
        opacity: 1;
        right: 20px;
      }
    }
    
    &:hover {
      background-position: 100% 0;

      span {
        transform: translateX(-10px);
      }

      &::after {
        opacity: 1;
        right: 20px;
      }
    }
  }
}


/* CTA Button Style Overrides */
a.cta_button.btn {
  box-sizing: border-box !important;
}


/* Default Button Variants */

.btn--green,
.btn--green:hover {
  background-color: var(--color-brand-green);
  color: #FFFFFF;
}

@media (min-width: 768px) {
  .btn--green {
    background-image: linear-gradient(90deg, var(--color-brand-green) 0% 25%, var(--color-brand-green-hover) 75% 100%);

    &::after {
      content: url('data:image/svg+xml,<svg width="14" height="14" viewBox="0 0 17 14" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill="%23ffffff" fill-rule="evenodd" clip-rule="evenodd" d="M10.3603 0.489047L16.1621 6.32224C16.5506 6.71449 16.5478 7.3474 16.1557 7.7361L10.357 13.5048C9.96461 13.8935 9.33145 13.8905 8.94277 13.4982C8.55421 13.1059 8.55708 12.473 8.94911 12.0843L13.037 8.01462L1.5147 7.90012C0.962423 7.89751 0.516826 7.44769 0.519433 6.89541C0.522039 6.34313 0.971863 5.89753 1.52414 5.90014L13.0381 6.0146L8.94027 1.89741L8.93943 1.89657C8.55076 1.50421 8.55375 0.871051 8.94611 0.482374C9.33844 0.0937285 9.97162 0.0967773 10.3603 0.489047Z"/></svg>');
    }

    &:hover {
      background-color: var(--color-brand-green-hover);
      color: #FFFFFF;
    }
  }
}

.btn--yellow,
.btn--yellow:hover {
  background-color: var(--color-brand-yellow);
  color: var(--color-ui-black);
}

@media (min-width: 768px) {
  .btn--yellow {
    background-image: linear-gradient(90deg, var(--color-brand-yellow) 0% 25%, var(--color-brand-yellow-hover) 75% 100%);

    &::after {
      content: url('data:image/svg+xml,<svg width="14" height="14" viewBox="0 0 17 14" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill="%23333333" fill-rule="evenodd" clip-rule="evenodd" d="M10.3603 0.489047L16.1621 6.32224C16.5506 6.71449 16.5478 7.3474 16.1557 7.7361L10.357 13.5048C9.96461 13.8935 9.33145 13.8905 8.94277 13.4982C8.55421 13.1059 8.55708 12.473 8.94911 12.0843L13.037 8.01462L1.5147 7.90012C0.962423 7.89751 0.516826 7.44769 0.519433 6.89541C0.522039 6.34313 0.971863 5.89753 1.52414 5.90014L13.0381 6.0146L8.94027 1.89741L8.93943 1.89657C8.55076 1.50421 8.55375 0.871051 8.94611 0.482374C9.33844 0.0937285 9.97162 0.0967773 10.3603 0.489047Z"/></svg>');
    }

    &:hover {
      background-color: var(--color-brand-yellow-hover);
      color: var(--color-ui-black);
    }
  }
}


.btn--white,
.btn--white:hover {
  background-color: #FFFFFF;
  color: var(--color-ui-black);
}

@media (min-width: 768px) {
  .btn--white {
    background-image: linear-gradient(90deg, var(--color-brand-white) 0% 25%, var(--color-brand-white-hover) 75% 100%);

    &::after {
      content: url('data:image/svg+xml,<svg width="14" height="14" viewBox="0 0 17 14" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill="%23333333" fill-rule="evenodd" clip-rule="evenodd" d="M10.3603 0.489047L16.1621 6.32224C16.5506 6.71449 16.5478 7.3474 16.1557 7.7361L10.357 13.5048C9.96461 13.8935 9.33145 13.8905 8.94277 13.4982C8.55421 13.1059 8.55708 12.473 8.94911 12.0843L13.037 8.01462L1.5147 7.90012C0.962423 7.89751 0.516826 7.44769 0.519433 6.89541C0.522039 6.34313 0.971863 5.89753 1.52414 5.90014L13.0381 6.0146L8.94027 1.89741L8.93943 1.89657C8.55076 1.50421 8.55375 0.871051 8.94611 0.482374C9.33844 0.0937285 9.97162 0.0967773 10.3603 0.489047Z"/></svg>');
    }

    &:hover {
      background-color: var(--color-ui-black);
      color: #FFFFFF;
    }
  }
}



.btn--transparent-black,
.btn--transparent-black:hover {
  border: 1px solid var(--color-ui-black);
  margin: -1px;
  background-color: transparent;
  color: var(--color-ui-black);
}

@media (min-width: 768px) {
  .btn--transparent-black {
    background-image: linear-gradient(90deg, transparent 0% 25%, #3333331a 75% 100%);

    &::after {
      content: url('data:image/svg+xml,<svg width="14" height="14" viewBox="0 0 17 14" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill="%23333333" fill-rule="evenodd" clip-rule="evenodd" d="M10.3603 0.489047L16.1621 6.32224C16.5506 6.71449 16.5478 7.3474 16.1557 7.7361L10.357 13.5048C9.96461 13.8935 9.33145 13.8905 8.94277 13.4982C8.55421 13.1059 8.55708 12.473 8.94911 12.0843L13.037 8.01462L1.5147 7.90012C0.962423 7.89751 0.516826 7.44769 0.519433 6.89541C0.522039 6.34313 0.971863 5.89753 1.52414 5.90014L13.0381 6.0146L8.94027 1.89741L8.93943 1.89657C8.55076 1.50421 8.55375 0.871051 8.94611 0.482374C9.33844 0.0937285 9.97162 0.0967773 10.3603 0.489047Z"/></svg>');
    }

    &:hover {
      background-color: transparent;
      color: var(--color-ui-black);
    }
  }
}


.btn--transparent-white,
.btn--transparent-white:hover {
  border: 1px solid #FFFFFF;
  margin: -1px;
  background-color: transparent;
  color: #FFFFFF;
}

@media (min-width: 768px) {
  .btn--transparent-white {
    background-image: linear-gradient(90deg, transparent 0% 25%, #FFFFFF0D 75% 100%);

    &::after {
      content: url('data:image/svg+xml,<svg width="14" height="14" viewBox="0 0 17 14" fill="none" xmlns="http://www.w3.org/2000/svg"><path fill="%23ffffff" fill-rule="evenodd" clip-rule="evenodd" d="M10.3603 0.489047L16.1621 6.32224C16.5506 6.71449 16.5478 7.3474 16.1557 7.7361L10.357 13.5048C9.96461 13.8935 9.33145 13.8905 8.94277 13.4982C8.55421 13.1059 8.55708 12.473 8.94911 12.0843L13.037 8.01462L1.5147 7.90012C0.962423 7.89751 0.516826 7.44769 0.519433 6.89541C0.522039 6.34313 0.971863 5.89753 1.52414 5.90014L13.0381 6.0146L8.94027 1.89741L8.93943 1.89657C8.55076 1.50421 8.55375 0.871051 8.94611 0.482374C9.33844 0.0937285 9.97162 0.0967773 10.3603 0.489047Z"/></svg>');
    }

    &:hover {
      background-color: transparent;
      color: #FFFFFF;
    }
  }
}

/* Small Button Variant */
.btn--small {
  padding: 8px 22px;
  min-width: 0;
  font-size: 13px;

  span {
    margin-bottom: -1px;
  }

  &::after {
    right: 16px;
    transform: scale(0.85);
  }
  &:hover:after {
    right: 14px;
  }
  
}

.btn--icon-only {
  padding: 0;
  min-width: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  color: var(--color-ui-black);
  font-size: 20px;
  line-height: 1;

  span {
    margin-bottom: -1px;
    transform: translateX(0);
    transition: transform 0.2s ease-out;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: inherit;
    height: inherit;
    border-radius: inherit;
  }

  &::after {
    content: none;
  }
}

/* Responsive Small Button for Mobile */
@media (max-width: 767px) {
  .btn--small {
    height: 38px;
    min-height: 38px;
    padding: 11px 22px;
    min-width: 0;
    font-size: 13px;
  }


}

/* Button input style */
.btn:is(input) {
  background-color: var(--color-ui-black);
}


.fs-buttons__group {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 20px;
}

.fs-buttons__group--center  {
    justify-content: center;
}
form {
    --color-form: #333333;
    --color-form-focus: #00b34d;
    --color-form-description: #888;
    --color-form-placeholder: #888;
    --color-form-label: #333333;
}

.form--white form {
    --color-form: #ffffff;
    --color-form-focus: #fff;
    --color-form-description: #ffffff;
    --color-form-placeholder: #ffffff;
    --color-form-label: #ffffff;
}

/* Form Title */
.form-title {
    margin-bottom: 0;
}

/* Inputs - file picker */
form input[type=file] {
    background-color: transparent;
    border: initial;
    padding: initial;
}


/* Fields */
.hs-form-field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin-bottom: 1.4rem;
}

/* Put help text last */
.hs-field-desc {
    color: var(--color-form-description);
    margin: 0;
    order: 10;
}

.hs-error-msgs {
    order: 11;
}

/* Labels */
form label {
    display: block;
    font-family: "Nunito", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.25rem;
    margin: 0;
    color: var(--color-form-label);
}

/* Help text */

form legend {
    font-size: 0.875rem;
}

/* Inputs */

form input[type='text'],
form input[type='email'],
form input[type='password'],
form input[type='tel'],
form input[type='number'],
form input[type='file'],
form select,
form textarea {
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--color-form);
    border-radius: 0;
    display: inline-block;
    font-size: 1rem;
    padding: 0.75rem 1rem;
    width: 100% !important;
    color: var(--color-form);

}

form select {
    padding: 0.6rem 1rem;
}

::placeholder {
    color: var(--color-form-placeholder);
    opacity: 1; /* Override default opacity */
}

form textarea {
    resize: vertical;
}

form fieldset {
    max-width: 100% !important;
}

/* Inputs - checkbox/radio */
form .inputs-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

form .inputs-list>li {
    display: block;
    line-height: 1;
    margin: 0;
}

form .inputs-list input,
form .inputs-list span {
    vertical-align: middle;
}

.hs-form-radio-display,
.hs-form-checkbox-display {
    cursor: pointer;
    font-size: 14px;
    margin: 0;
    color: var(--color-form);
}

.hs-fieldtype-radio label {
    color: var(--color-form);
}

form input[type='checkbox'] {
    border-radius: .25rem;
}

form input[type='checkbox'],
form input[type='radio'] {
    border-color: var(--color-ui-black);
    color: #00b34d;
    accent-color: #00b34d;
    cursor: pointer;
    height: 1rem !important;
    margin-right: 0.35rem;
    width: 1rem !important;
}

[multiple]:focus,
[type=date]:focus,
[type=datetime-local]:focus,
[type=email]:focus,
[type=month]:focus,
[type=number]:focus,
[type=password]:focus,
[type=search]:focus,
[type=tel]:focus,
[type=text]:focus,
[type=time]:focus,
[type=url]:focus,
[type=week]:focus,
select:focus,
textarea:focus,
form input[type='checkbox']:focus,
form input[type='radio']:focus {
    outline: none;
    border-color: var(--color-form-focus);
}

.hs-fieldtype-intl-phone.hs-input select {
    max-height: 43px;
}

/* Inputs - date picker */

.hs-dateinput {
    position: relative;
}

.hs-dateinput:before {
    content: '\01F4C5';
    position: absolute;
    right: 10%;
    top: 50%;
    transform: translateY(-50%);
}

.fn-date-picker .pika-table thead th {
    color: #fff;
}

.fn-date-picker td.is-selected .pika-button {
    border-radius: 0;
    box-shadow: none;
}

.fn-date-picker td .pika-button:hover,
.fn-date-picker td .pika-button:focus,
.fn-date-picker .is-selected .pika-button {
    border-radius: 0 !important;
    color: #fff;
    background-color: #00b34d !important;
}

.fn-date-picker .is-today .pika-button {
    color: #00b34d !important;
}

.fn-date-picker.pika-single {
    border-radius: .375rem
}

/* Inputs - file picker */
form input[type='file'] {
    background-color: transparent;
    border: initial;
    padding: initial;
    border-radius: 0;
}

/* Headings and text */

form .hs-richtext,
form .hs-richtext p {
    font-size: 0.875rem;
    margin: 0 0 1.4rem;
}

form .hs-richtext img {
    max-width: 100% !important;
}

/* GDPR */
.legal-consent-container .hs-form-booleancheckbox-display {
    display: flex;
    align-items: center;
}

.legal-consent-container .hs-form-booleancheckbox-display>span,
.legal-consent-container .hs-form-booleancheckbox-display>span p {
    margin-left: 0 !important;
    font-size: 1rem;
    cursor: pointer;
    user-select: none;
}

/* Validation */
.hs-form-required {
    color: #ef6b51;
}

.hs-input.invalid.error {
    border-color: #ef6b51;
}

.hs-error-msg {
    color: #ef6b51;
    margin: 0;
}

/* Submit button */
form input[type='submit'],
form .hs-button {
    text-transform: uppercase;
    position: relative;
    font-weight: 600;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    border-radius: 9999px;
    border: 0;
    letter-spacing: 0.06em;
    font-size: 15px;
    line-height: 1;
    padding: 15px 30px;
    cursor: pointer;
    justify-content: center;
    text-align: center;
    min-width: 64px;
    z-index: 10;
    text-decoration: none;
    background-color: var(--color-brand-yellow);
    margin-top: 16px;

}

@media (min-width: 768px) {

    form input[type='submit'],
    form .hs-button {
        font-size: 1.125rem;
        line-height: 1;
    }
}

form input[type='submit']:hover,
form .hs-button:hover {}



/* Captcha */

.grecaptcha-badge {
    margin: 0 auto;
}
/* Table */

table {
  border-collapse: collapse;
  margin-bottom: 1.4rem;
  overflow-wrap: break-word;
}

/* Table cells */

td,
th {
  vertical-align: top;
}

/* Table header */

thead th {
  vertical-align: bottom;
}

/* Components
Specific pieces of UI that are stylized. Typically used for global partial styling
*/



/* Utilities
Helper classes with ability to override anything that comes before it
*/

/* For content that needs to be visually hidden but stay visible for screenreaders */
.relative {
  position: relative;
}

.pointer-none {
  pointer-events: none;
}

.sr-only {
  border: 0 !important;
  clip: rect(0, 0, 0, 0) !important;
  height: 1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  white-space: nowrap !important;
  width: 1px !important;
}

.hidden {
  display: none !important;
}

.padding-top--large { padding-top: 52px; --current-padding-top: 52px; }
.padding-top--small { padding-top: 24px; --current-padding-top: 24px; }
.padding-top--none { padding-top: 0px; --current-padding-top: 0px; }

.padding-bottom--large { padding-bottom: 52px; --current-padding-bottom: 52px; }
.padding-bottom--small { padding-bottom: 24px; --current-padding-bottom: 24px; }
.padding-bottom--none { padding-bottom: 0px; --current-padding-bottom: 0px; }

@media screen and (min-width: 768px) {
  .padding-top--large { padding-top: 100px; --current-padding-top: 100px; }
  .padding-top--small { padding-top: 50px; --current-padding-top: 50px; }
  .padding-top--none { padding-top: 0px; --current-padding-top: 0px; }

  .padding-bottom--large { padding-bottom: 100px; --current-padding-bottom: 100px; }
  .padding-bottom--small { padding-bottom: 50px; --current-padding-bottom: 50px; }
  .padding-bottom--none { padding-bottom: 0px; --current-padding-bottom: 0px; }
}

.bg-white { background-color: #fff; --current-bg-color: #fff; }
.bg-light-grey { background-color: var(--color-ui-light-grey); --current-bg-color: var(--color-ui-light-grey); }
.bg-dark-blue { background-color: var(--color-brand-dark-blue); --current-bg-color: var(--color-brand-dark-blue); }
.bg-dark-green { background-color: var(--color-brand-green-darker); --current-bg-color: var(--color-brand-green-darker); }
.bg-light-blue { background-color: var(--color-brand-light-blue); --current-bg-color: var(--color-brand-light-blue); }
.bg-light-green { background-color: var(--color-brand-light-green); --current-bg-color: var(--color-brand-light-green); }
.bg-green { background-color: var(--color-brand-green); --current-bg-color: var(--color-brand-green); }

.bg-gradient--top-to-bottom { background-color: transparent; background-image: linear-gradient(to bottom, var(--current-bg-color), transparent); }
.bg-gradient--bottom-to-top { background-color: transparent; background-image: linear-gradient(to top, var(--current-bg-color), transparent); }



.fs-background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  opacity: 0.3;
  background-image: url('https://19534803.fs1.hubspotusercontent-na1.net/hubfs/19534803/flourish-software-theme-assets/images/backgrounds/bg-1-right.png'),
    url('https://19534803.fs1.hubspotusercontent-na1.net/hubfs/19534803/flourish-software-theme-assets/images/backgrounds/bg-1-left.png');
  background-repeat: no-repeat, no-repeat;
  background-size: min(100%, 1440px), min(100%, 1440px);
  background-position: center bottom;
}

.bg-image {
  background-size: cover;
  background-position: center;
  position: relative;

  & > div {
    position: relative;
    z-index: 1;
  }

  &:after {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    background: rgba(238,247,245,0.6);
    z-index: 0;
    display: block;
    top: 0;
    left: 0;
  }
}
/* Theme base styles */

.fs-blog-post {
  background-color: var(--color-brand-light-blue);
}


.fs-blog-post-banner {
  text-align: center;
  background-image: linear-gradient(to bottom, rgb(0 26 11 / 50%), rgb(0 97 42 / 50%)), url("https://19534803.fs1.hubspotusercontent-na1.net/hubfs/19534803/flourish-software-theme-assets/images/backgrounds/blog-post-bg.jpg");
  background-size: cover;
  background-position: center;
}

.fs-blog-post-banner .fs-container {
  position: relative;
  z-index: 1;
}


.blog-post__subheader {
  color: var(--color-brand-yellow)
}

.blog-post__title {
  color: #fff
}

.fs-grid {
  display: grid;
  grid-template-columns: minmax(200px, 8fr) minmax(150px, 4fr);
  gap: 30px;

  @media (max-width: 768px) {
    grid-template-columns: 1fr;
  }
}

.blog-post__content,
.landing-page__content {
  background: white;
  border: 1px solid var(--color-brand-green);
  border-radius: 16px;
  padding: 24px;
}

.blog-post__image--placeholder {
  filter: blur(10px);
}

.blog-post__image--non-placeholder {
  position: absolute;
  left: 0;
  top: 0;
}

.blog-post__image {
  border-radius: 16px;
  margin-bottom: 16px;
}

.blog-post__image-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  margin-bottom: 16px;
}



/************ Blog Post Sidebar ************/

.blog-post__sidebar .sticky,
.landing-page__sidebar .sticky {
  position: sticky;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: 160px;
}

.blog-post__subscribe {
  background-image: linear-gradient(180deg, rgb(32 131 36 / 62%), #4CAF50), url(https://19534803.fs1.hubspotusercontent-na1.net/hubfs/19534803/flourish-software-theme-assets/images/backgrounds/blog-post-bg.jpg);
  background-size: cover;
  background-position: center;
  color: white;
  padding: 16px;
  border-radius: 16px;
}
.landing-page__subscribe {
  /* background-color: var(--color-brand-green-darker); */
  /* color: white; */
    background-color: var(--color-light-green);
  padding: 16px;
  border-radius: 16px;
  border: 1px solid var(--color-brand-green);
  border-radius: 16px;
}

.blog-post__subscribe .submitted-message,
.landing-pagee__subscribe .submitted-message {
  background: rgba(255, 255, 255, 0.8);
  padding: 16px;
  border-radius: 16px;
  color: var(--color-brand-green);
  margin-top: 20px;

}

.blog-post__sidebar h3,
.landing-page__sidebar h3 {
  font-size: 1.5rem;
}

.blog-post__subscribe form label,
.landing-pagee__subscribe form label {
  color: white;
}

.blog-post__subscribe form .hs-error-msg,
.landing-pagee__subscribe form .hs-error-msg {
  color: #ef6b51;
}

.blog-post__subscribe form,
.landing-pagee__subscribe form {
  margin-top: 16px;
}

.blog-post__subscribe form input[type=email],
.landing-pagee__subscribe form input[type=email] {
  border: 0
}

.blog-post__subscribe .hs-form-field,
.landing-pagee__subscribe .hs-form-field {
  margin-bottom: 0;
}

.blog-post__subscribe .input,
.landing-pagee__subscribe .input {
  background: white;
  border-radius: 8px;
  padding: 8px;
  border: none;
  width: 100%;
}

.blog-post__subscribe input:focus,
.landing-pagee__subscribe input:focus {
  outline: none;
}

.blog-post__subscribe input::placeholder,
.landing-pagee__subscribe input::placeholder {
  color: var(--color-brand-green);
}

.blog-post__subscribe input:focus::placeholder,
.landing-pagee__subscribe input:focus::placeholder {
  color: var(--color-brand-green);
}

.blog-post__subscribe .hs-error-msg,
.landing-pagee__subscribe .hs-error-msg {
  background: rgba(255, 255, 255, 1);
  padding: .2rem 1.2rem;
  border-radius: 4px;
}

.blog-post__social-share h3 {
  margin-bottom: 0;
}

.blog-post__social-share {
  padding: 16px;
  border-radius: 16px;
  background: white;
  border: 1px solid var(--color-brand-green);
  display: flex;
  gap: 16px;
  flex-direction: column;
}

.blog-post__social-share-icons {
  display: flex;
  gap: 16px;
}

.blog-post__social-share-icons a {
  color: var(--color-brand-green);
  font-size: 24px;
}

.blog-post__social-share-icons svg {
  width: 34px;
  height: auto;
  background: var(--color-brand-green);
  border-radius: 3px;
  padding: 4px;
  color: white;
}

.blog-post__social-share .copy_icon input {
  position: absolute;
  pointer-events: none;
  opacity: 0;
  z-index: -50;
}

.blog-post__social-share .copy_icon span {
  position: relative;
  height: 34px;
  display: block;
  background: var(--color-brand-green);
  cursor: pointer;
}

.blog-post__social-share .copy_icon .copy-toast {
  /* absolute hidden top-full text-neutral-black-5 font-medium */
  position: absolute;
  top: 100%;
}

.blog-post__social-share-icons a:hover svg,
.blog-post__social-share-icons a:hover span {
  background-color: var(--color-brand-green-hover);
}


.blog-post__tags {
  padding: 16px;
  border-radius: 16px;
  background: white;
  border: 1px solid var(--color-brand-green);
  display: flex;
  gap: 16px;
  flex-direction: column;
}

.blog-post__tags h3 {
  margin-bottom: 0;
}

.blog-post__tags ul {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0 0 0 16px;
  list-style: none;
}

.blog-post__tags ul li {
  padding: 0;
  padding-left: 12px;
  position: relative;
  list-style: none;
}

.blog-post__tags ul li::before {
  content: '';
  position: absolute;
  top: 50%;
  left: -12px;
  width: 6px;
  height: 6px;
  background-color: var(--color-brand-green);
  border-radius: 50%;
  transform: translateY(-50%);
}

.blog-post__tags ul li a {
  color: var(--color-ui-black);
  font-size: 1.2rem;
  text-decoration: none;
  font-weight: bold;
  transition: color 0.3s ease;
}

.blog-post__tags ul li a:hover {
  color: var(--color-brand-green);
}



.blob-svg {
    pointer-events: none;
    display: inline-block;
    position: relative;
    width: 800px;
    height: 800px;
    top: 50%;
    left: 50%;
    margin-left: -400px;
    margin-top: -400px;
}

rect {
    -webkit-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
}

.blobs {
    -webkit-filter: url("#goo");
    filter: url("#goo");


}

.blob {
    transform-origin: 50% 50%;
    animation: blob-rotate 4s linear infinite;
    fill: white;
}



@keyframes blob-rotate {
    0% {
        transform: rotate(0deg) translate(6px, 0.1px) rotate(0deg);
    }

    100% {
        transform: rotate(360deg) translate(6px, 0.1px) rotate(-360deg);
    }
}


.blobs .blob:nth-child(1) {
    animation-delay: 0s;
}

.blobs .blob:nth-child(2) {
    animation-delay: -1s;
}

.blobs .blob:nth-child(3) {
    animation-delay: -2s;
}

.blobs .blob:nth-child(4) {
    animation-delay: -3s;
}

.blobs .blob:nth-child(5) {
    animation-delay: -4s;
}