/* Theme base styles */

/* Tools
Any animations, or functions used throughout the project.
Note: _macros.css needs to be imported into each stylesheet where macros are used and not included here
*/

/* Generic
This is where reset, normalize & box-sizing styles go.
*/

/* @import url('http://example.com/example_style.css'); */

/***********************************************/
/* CSS @imports must be at the top of the file */
/* Add them above this section                 */
/***********************************************/

/*****************************************/
/* Start your style declarations here    */
/*****************************************/
* {
    box-sizing: border-box;
}
html, body, div, span, applet, object, iframe,
p, blockquote, pre,
abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd,ul, ol, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
ul, ol {
	padding-left: 20px;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
/* ol, ul {
	list-style: none;
} */
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
i{
    font-style: italic;
}
/*! 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.5; /* 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;
}



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

/* The overflow-wrap is meant to prevent long/large words from breaking the mobile responsiveness of a page (e.g. horizontal scrolling). It is preferred to reduce font sizes on mobile to address this, with this CSS specifically helping with extreme scenarios where a reduction in font size is not possible. */

body {
  line-height: 1.5;
  overflow-wrap: break-word;
}

/* Handles word breaking for a few specific languages which handle breaks in words differently. If your content is not translated into these languages, you can safely remove this.  */

html[lang^="ja"] body,
html[lang^="zh"] body,
html[lang^="ko"] body {
  line-break: strict;
  overflow-wrap: normal;
  word-break: break-all;
}
/* Text Selection Color */
::-moz-selection{
  color: var(--text-light);
  background-color: var(--gray);
}
::selection {
  color: var(--text-light);
  background-color: var(--gray);
}
mark {
  color: var(--text-light);
  background-color: var(--primary);
}
/* Paragraphs */

p {
  margin: 0;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0;
}
.text-xsmall {
  font-size: 14px;
}
.text-small {
  font-size: 16px;
}
.text-medium {
  font-size: 18px;
}
.text-large {
  font-size: 24px;
}
.text-xlarge {
  font-size: 32px;
}
@media (max-width: 1023px){
  .text-xsmall {
    font-size: 12px;
  }
  .text-small {
    font-size: 14px;
  }
  .text-medium {
    font-size: 16px;
  }
  .text-large {
    font-size: 20px;
  }
  .text-xlarge {
    font-size: 24px;
  }
}

/* Extras */

.text-tagline,
.tagline {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 1.28px;
  text-transform: uppercase;
  font-weight: 600;
}
@media (max-width: 1023px){
  .text-tagline,
  .tagline {
    font-size: 14px;
  }
}

/* Link Text*/
.link-text,
.text-link {
  display: block;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: .8px;
  text-decoration: none;
  font-weight: 500;
  padding: 4px 16px;
  border-radius: 4px;
  transition: background .3s ease;
}    
.link-text:hover,
.text-link:hover {
  background: var(--off-white);
}

.link-text.link-text--dust:hover,
.text-link.text-link--dust:hover {
  background: var(--dust);
}
@media (max-width: 1023px){
  .link-text,
  .text-link {
    font-size: 14px;
  }
}
/* Anchors */

a {
  cursor: pointer;
}

/* Headings */

h1,
h2,
h3,
h4,
h5,
h6 {
  /* margin: 0 0 1.4rem; */
  margin: 0;
  font-weight: 500;
  letter-spacing: -.32px;
}

h1, .h1 {
  font-size: 64px;
  line-height: 1.2;
  
}
h2, .h2 {
  font-size: 56px;
  line-height: 1.2;
}
h3, .h3 {
  font-size: 48px;
  line-height: 1.2;
}
h4, .h4 {
  font-size: 32px;
  line-height: 1.3;
  letter-spacing: 0;
}
h5, .h5 {
  font-size: 24px;
  line-height: 1.3;
  letter-spacing: 0;
}
h6,.h6 {
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: 0;
}
@media (max-width: 1023px){
  h1, h2, h3, h4, h5, h6 {
    font-weight: 500;
    letter-spacing: -.32px;
  }

  h1, .h1 {
    font-size: 56px;
    
  }
  h2, .h2 {
    font-size: 48px;
  }
  h3, .h3 {
    font-size: 40px;
  }
  h4, .h4 {
    font-size: 24px;
    line-height: 1.3;
    letter-spacing: 0;
  }
  h5, .h5 {
    font-size: 20px;
  }
  h6,.h6 {
    font-size: 18px;
    line-height: 1.2;
    letter-spacing: 0;
  }
}
@media (max-width: 420px){
    h1 {
        font-size: clamp(48px,12.5vw,56px)
    }
}
/* Lists */

ul,
ol {
  /* margin: 0 0 1.4rem; */
}

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

ul.no-list {
  list-style: none;
  margin: 0;
  padding-left: 0;
}

/* Code blocks */

pre {
  overflow: auto;
}

code {
  vertical-align: bottom;
}

/* Blockquotes */

blockquote {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: 0;
}
@media (max-width:1023px){
  blockquote {
    font-size: 24px;
    line-height: 1.5;
    letter-spacing: 0;
  }
}

/* Horizontal rules */

hr {
  border: none;
  border-bottom: 1px solid #CCC;
}

/* Image alt text */

img {
  /* font-size: 0.583rem; */
  /* word-break: normal; */
}

/*
* HELPERS
*/
.no-underline {
  text-decoration: none;
}
.text-left {
  text-align: left;
}
.text-right{
  text-align: right;
}
.text-center {
  text-align: center;
}
@media (max-width: 1023px){
  .m-text-left {
    text-align: left;
  }
  .m-text-right{
    text-align: right;
  }
  .m-text-center {
    text-align: center;
  }
}

/* CAPITALIZATION  */
.text-uppercase {
  text-transform: uppercase;
}
.text-lowercase {
  text-transform: lowercase;
}
@media (max-width: 1023px){
  .m-text-uppercase {
    text-transform: uppercase;
  }
  .m-text-lowercase {
    text-transform: lowercase;
  }
}
/* FONT WEIGHT */
.text-300 {
  font-weight: 300;
}
.text-400 {
  font-weight: 400;
}
.text-500 {
  font-weight: 500;
}
.text-600 {
  font-weight: 600;
}
.text-700 {
  font-weight: 700;
}
.text-800 {
  font-weight: 800;
}
.text-900 {
  font-weight: 900;
}

/* 
* Anchor Links 
*/
body {
  color: var(--off-black);
}
a {
  color: inherit;
  text-underline-offset: 3px;
}
button {
    border: unset;
    outline: unset;
    display: block;
    background-color: unset;
    color: inherit;
}
/* button,
.button,
.hs-button {
  cursor: pointer;
  display: inline-block;
  text-align: center;
  transition: all 0.15s linear;
  white-space: normal;
}

button:disabled,
.button:disabled,
.hs-button:disabled {
  background-color: #D0D0D0;
  border-color: #D0D0D0;
  color: #E6E6E6;
} */

/* No button */

.no-button,
.no-button:hover,
.no-button:focus,
.no-button:active {
  background: none;
  border: none;
  border-radius: 0;
  color: initial;
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  margin-bottom: 0;
  padding: 0;
  text-align: left;
  text-decoration: none;
  transition: none;
}


/*
* T_LAKE CUSTOM BUTTONS 
*/
:root {
    --btn--ease: 1.1s cubic-bezier(0.45, 0, 0.15, 1);
}
.btn {
    display: flex;
    flex-direction: row;
    align-items: center;
    font-size: 14px;
    position: relative;
    font-weight: 500;
    line-height: 1.5;
    text-decoration: none!important;
}

/* 
* Arrow Buttons
*/
.btn.btn__arrow {
    font-size: 16px;
    gap: 8px;
    justify-content: flex-start;
    width: fit-content;
    padding-right: 2px;
    padding-bottom: 2px;
    color: var(--off-black);
}
@media (max-width: 1023px){
    .btn.btn__arrow {
        font-size: 14px;
    }
}
.btn.btn__arrow.btn__arrow--light {
    color: var(--off-white);
}
.btn.btn__arrow::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    background: currentColor;
    height: 1px ;
    width: 100%;
    left: 0;
    transition: transform .3s ease;
    transform-origin: center;
    transform: scaleX(0);
}
.btn.btn__arrow:hover::before {
    transform: scaleX(1);
}
/*
 * OVAL BUTTONS 
 * In order to update the button color you must check the inverted color of what you want
*/
:root {
  --inverted-primary-green: #d4c0e3;
  --inverted-off-white: #040404;
  --inverted-beige: #0f1115;
  --inverted-gray: #b0b1b3;

  --inverted-primary-green-1: #d8c4e7;
  --inverted-primary-green-2: #e3d1f8;
}
.btn--oval {
    overflow: hidden;
    position: relative;
    padding: 0 1em;
    filter: invert(1);
    gap: 24px;
    padding: 12px 20px;
    transition: border-color var(--btn--ease), box-shadow var(--btn--ease),background-color .25s ease .45s;
    border-radius: 100px;
    box-shadow: inset 0 0 0px 1px #555556;
    width: fit-content;
}
.btn.btn--oval:hover {
    box-shadow: inset 0 0 0px 1px transparent;
}
.btn.btn--oval.btn--primary {
    background: var(--inverted-off-white);
    color: var(--inverted-primary-green);
}
.btn.btn--oval.btn--secondary {
    background: var(--inverted-beige);
    color: var(--inverted-primary-green);
    border-color: var(--inverted-primary-green);
}
.btn.btn--oval.btn--tertiary {
    background: var(--inverted-off-white);
    color: var(--inverted-primary-green);
    border-color: var(--inverted-primary-green);
}

.btn.btn--oval::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 100%;
    mix-blend-mode: difference;
    transition: top var(--btn--ease);
}
.btn.btn--oval.btn--primary::after {
    background: var(--inverted-primary-green-1);
}
.btn.btn--oval.btn--secondary::after {
    background: var(--inverted-primary-green-1);
}
.btn.btn--oval.btn--tertiary::after {
    background: var(--inverted-beige);
}

.btn.btn--oval:hover::after {
    top: 0;
}
.btn.btn--oval * {
    position: relative;
    transition: left var(--btn--ease);
    left: 0;
}
.btn.btn--oval:hover * {
    left: 36px;
}
.btn .btn--oval__first--arrow {
    position: absolute;
    left: -48px;
}
.btn.btn--oval:hover .btn--oval__first--arrow {
    left: 30px;
}

.btn--oval svg {
    stroke: currentColor;
    height: 24px;
}
.btn .btn--oval__last--arrow {
    transition: stroke 0.6s ease 0.4s, left var(--btn--ease);
}
.btn--oval:hover .btn--oval__last--arrow {
    stroke: var(--inverted-off-white);
}

/* UPDATE BACKGROUND FOR PRIMARY BUTTON */
a.btn.btn--oval{
    transition-delay: 0s;
}
a.btn.btn--oval:not(.btn--tertiary):hover{
    background: rgba(255,255,255,0.028);
    transition: border-color var(--btn--ease), box-shadow var(--btn--ease),background-color .25s ease .65s;
}
.btn.btn--oval.btn--tertiary:hover{
    background: rgba(255,255,255,0);
    transition: border-color var(--btn--ease), box-shadow var(--btn--ease),background-color .25s ease .65s;
}
/* Fields */

.hs-form-field {
  margin-bottom: 1.4rem;
}

/* Labels */

form label {
  display: block;
  font-size: 0.875rem;
  margin-bottom: 0.35rem;
}

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

/* Help text */

form legend {
  font-size: 0.875rem;
}

/* Inputs */

form input[type=text],
form input[type=search],
form input[type=email],
form input[type=password],
form input[type=tel],
form input[type=number],
form input[type=file],
form select,
form textarea {
  display: inline-block;
  padding: 12px;
  border: 1px solid var(--border--30);
  width: 100%;
  border-radius: 8px;
  font-size: 16px;
  background: transparent;
  outline: unset!important;
}
form input::placeholder,
form textarea::placeholder {
  color: #1C1B19B2;
}
form textarea {
  resize: vertical;
}

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

/* Inputs - checkbox/radio */

form .inputs-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

form .inputs-list > li {
  display: block;
  margin: 0.7rem 0;
}

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

form input[type=checkbox],
form input[type=radio] {
  cursor: pointer;
  margin-right: 0.35rem;
}

/* 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 {
  border-radius: 0 !important;
  color: #FFF;
}

/* Inputs - file picker */

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

/* 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 > span,
.legal-consent-container .hs-form-booleancheckbox-display > span p {
  margin-left: 1rem !important;
}

/* Validation */

.hs-form-required {
  color: #EF6B51;
}

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

.hs-error-msg {
  color: #EF6B51;
  margin-top: 0.35rem;
}

/* Submit button */

form input[type=submit],
form .hs-button {
  cursor: pointer;
  display: inline-block;
  text-align: center;
  transition: all 0.15s linear;
  white-space: normal;
}

/* Captcha */

.grecaptcha-badge {
  margin: 0 auto;
}


  /* Search button input field and suggestions */
  .body-container-wrapper .hs-search-field__button {
    padding: 15px;
  }

  .body-container-wrapper .hs-search-field__bar--button-inline .hs-search-field__button {
    margin-left: 6px;
    margin-bottom: 0;
  }

  .body-container-wrapper .hs-search-field__button svg {
    height: 15px;
    fill: #fff;
  }

  .body-container-wrapper .hs-search-field__bar > form > .hs-search-field__input {
    padding: 10px;
  }

  .body-container-wrapper .hs-search-field__suggestions li a {
    color: #494A52;
    padding: 0.35rem 0.7rem;
    text-decoration: none;
    transition: background-color 0.3s;
  }


/* LAYOUT */
.hs-form fieldset.form-columns-1 .input {
  margin-right: unset!important;
}
.hs-form fieldset.form-columns-1 .input .hs-input {
  width: 100%;
}

.hs-form fieldset.form-columns-2 {
  display: flex;
  gap: 24px;
}
.hs-form fieldset.form-columns-2 .hs-form-field {
  float: unset;
}
.hs-form fieldset.form-columns-2 .input {
  margin-right: unset!important;
}
@media (min-width: 1024px){
  .hs-form fieldset.form-columns-2 {
    flex-direction: row;
  }
}

/*
* CHECKBOX INPUT 
*/

.hs-form .form-columns-2 .hs-form-booleancheckbox label {
  justify-content: flex-start;
}
.hs-form .hs-form-booleancheckbox label {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 8px;
}
.hs-form .hs-form-booleancheckbox label input[type=checkbox] {
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  margin: 0;
  border: 1px solid var(--off-black);
  border-radius: 50%;
  width: 18px !important;  
  aspect-ratio: 1;
  position: relative;
  transition: background 0.1s ease;
}
.hs-form .hs-form-booleancheckbox label input[type=checkbox]:checked {
  background: var(--off-black);
}
.hs-form .hs-form-booleancheckbox label input[type=checkbox]::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  width: 30%;
  height: 50%;
  border-bottom: 2px solid var(--off-white);
  border-right: 2px solid var(--off-white);
  top: 43%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(37deg);
  opacity: 0;
  transition: opacity 0.1s ease;
}
.hs-form .hs-form-booleancheckbox label input[type=checkbox]:checked::before {
  opacity: 1;
}
/* 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;
}

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

html {
    scroll-behavior: smooth;
}

section {
    padding: 80px 0;
    display: flex;
    flex-direction: column;
    width: 100%;
}
.wrapper {
    max-width: 1440px;
    margin: auto;
    padding: 0 64px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: 100%;
}
@media (max-width: 1023px) {
    .wrapper {
        padding: 0 18px;
    }
}
/* 
* WIDTH 
*/
.w-fitcontent {
    width: fit-content;
}
.w-max {
    width: 100%;
}
@media (max-width: 1023px){
    .m-w-max {
        width: 100%;
    }
}
/*
* POSITION 
*/
.absolute {
    position: absolute;
}
.relative {
    position: relative;
}
.fixed {
    position: fixed;
}
.sticky {
    position: sticky;
}
@media (max-width: 1023px) {
    .m-absolute {
        position: absolute;
    }
    .m-relative {
        position: relative;
    }
    .m-fixed {
        position: fixed;
    }
    .m-sticky {
        position: sticky;
    }
}
@media (max-width: 767px) {
    .sm-absolute {
        position: absolute;
    }
    .sm-relative {
        position: relative;
    }
    .sm-fixed {
        position: fixed;
    }
    .sm-sticky {
        position: sticky;
    }
}

.display-none {
    display: none;
}
.shrink-0 {
    flex-shrink: 0;
}
/*
* FLEX 
*/
.flex {
    display: flex;
}
.flex-row {
    flex-direction: row;
}
.flex-col,
.flex-column {
    flex-direction: column;
}
.flex-col-reverse{
    flex-direction: column-reverse;
}
.flex-row-reverse {
    flex-direction: row-reverse;
}
.flex-wrap {
    flex-wrap: wrap;
}
.flex-nowrap {
    flex-wrap: nowrap;
}
.justify-start {
    justify-content: flex-start;
}
.justify-end {
    justify-content: flex-end;
}
.justify-center {
    justify-content: center;
}
.justify-around {
    justify-content: space-around;
}
.justify-between {
    justify-content: space-between;
}
.justify-evenly {
    justify-content: space-evenly;
}

.align-start {
    align-items: start;
}
.align-center {
    align-items: center;
}
.align-end {
    align-items: end;
}
.align-stretch {
    align-items: stretch;
}
@media (max-width: 1023px) {
    .m-flex,
    .display-none.m-flex {
        display: flex;
    }

    .m-flex-row {
        flex-direction: row;
    }
    .m-flex-wrap {
        flex-wrap: wrap;
    }
    .m-flex-nowrap {
        flex-wrap: nowrap;
    }
    .m-flex-col,
    .m-flex-column {
        flex-direction: column;
    }
    .m-flex-col-reverse{
        flex-direction: column-reverse;
    }
    .m-flex-row-reverse {
        flex-direction: row-reverse;
    }
    .m-justify-start {
        justify-content: flex-start;
    }
    .m-justify-end {
        justify-content: flex-end;
    }
    .m-justify-center {
        justify-content: center;
    }
    .m-justify-around {
        justify-content: space-around;
    }
    .m-justify-between {
        justify-content: space-between;
    }
    .m-justify-evenly {
        justify-content: space-evenly;
    }

    .m-align-start {
        align-items: start;
    }
    .m-align-center {
        align-items: center;
    }
    .m-align-end {
        align-items: end;
    }
    .m-align-stretch {
        align-items: stretch;
    }
}
@media (max-width: 767px) {
    .sm-flex,
    .display-none.sm-flex {
        display: flex;
    }

    .sm-flex-row {
        flex-direction: row;
    }
    .sm-flex-wrap {
        flex-wrap: wrap;
    }
    .sm-flex-nowrap {
        flex-wrap: nowrap;
    }
    .sm-flex-col,
    .sm-flex-column {
        flex-direction: column;
    }
    .sm-flex-col-reverse{
        flex-direction: column-reverse;
    }
    .sm-flex-row-reverse {
        flex-direction: row-reverse;
    }
    .sm-justify-start {
        justify-content: flex-start;
    }
    .sm-justify-end {
        justify-content: flex-end;
    }
    .sm-justify-center {
        justify-content: center;
    }
    .sm-justify-around {
        justify-content: space-around;
    }
    .sm-justify-between {
        justify-content: space-between;
    }
    .sm-justify-evenly {
        justify-content: space-evenly;
    }

    .sm-align-start {
        align-items: start;
    }
    .sm-align-center {
        align-items: center;
    }
    .sm-align-end {
        align-items: end;
    }
    .sm-align-stretch {
        align-items: stretch;
    }
}
@media (max-width: 430px) {
    .xsm-flex-col {
        flex-direction: column;
    }
}

/*
* GAPs 
*/
.g-unset,
.g-0 {
    gap: unset;
}
.g-4 {
    gap: 4px;
}
.g-8 {
    gap: 8px;
}
.g-12 {
    gap: 12px;
}
.g-16 {
    gap: 16px;
}
.g-20 {
    gap: 20px;
}
.g-24 {
    gap: 24px;
}
.g-32 {
    gap: 32px;
}
.g-40 {
    gap: 40px;
}
.g-48 {
    gap: 48px;
}
.g-56 {
    gap: 56px;
}
.g-64 {
    gap: 64px;
}
.g-80 {
    gap: 80px;
}
.g-96 {
    gap: 96px;
}
.g-130 {
    gap: 130px;
}
@media (max-width: 1023px) {
    .m-g-unset,
    .m-g-0 {
        gap: unset;
    }
    .m-g-4 {
        gap: 4px;
    }
    .m-g-8 {
        gap: 8px;
    }
    .m-g-12 {
        gap: 12px;
    }
    .m-g-16 {
        gap: 16px;
    }
    .m-g-20 {
        gap: 20px;
    }
    .m-g-24 {
        gap: 24px;
    }
    .m-g-32 {
        gap: 32px;
    }
    .m-g-40 {
        gap: 40px;
    }
    .m-g-48 {
        gap: 48px;
    }
    .m-g-56 {
        gap: 56px;
    }
    .m-g-64 {
        gap: 64px;
    }
    .m-g-80 {
        gap: 80px;
    }
    .m-g-96 {
        gap: 96px;
    }
    .m-g-130 {
        gap: 130px;
    }
}
@media (max-width: 767px) {
    .sm-g-unset,
    .sm-g-0 {
        gap: unset;
    }
    .sm-g-4 {
        gap: 4px;
    }
    .sm-g-8 {
        gap: 8px;
    }
    .sm-g-12 {
        gap: 12px;
    }
    .sm-g-16 {
        gap: 16px;
    }
    .sm-g-20 {
        gap: 20px;
    }
    .sm-g-24 {
        gap: 24px;
    }
    .sm-g-32 {
        gap: 32px;
    }
    .sm-g-40 {
        gap: 40px;
    }
    .sm-g-48 {
        gap: 48px;
    }
    .sm-g-56 {
        gap: 56px;
    }
    .sm-g-64 {
        gap: 64px;
    }
    .sm-g-80 {
        gap: 80px;
    }
    .sm-g-96 {
        gap: 96px;
    }
    .sm-g-130 {
        gap: 130px;
    }
}

/*
* MARGINS 
*/
.m-unset {
    margin: unset;
}
.m-4 {
    margin: 4px;
}
.m-8 {
    margin: 8px;
}
.m-12 {
    margin: 12px;
}
.m-16 {
    margin: 16px;
}
.m-20 {
    margin: 20px;
}
.m-32 {
    margin: 32px;
}
.m-48 {
    margin: 48px;
}
.m-64 {
    margin: 64px;
}
.m-80 {
    margin: 80px;
}
.mt-unset {
    margin-top: unset;
}
.mt-4 {
    margin-top: 4px;
}
.mt-8 {
    margin-top: 8px;
}
.mt-12 {
    margin-top: 12px;
}
.mt-16 {
    margin-top: 16px;
}
.mt-20 {
    margin-top: 20px;
}
.mt-32 {
    margin-top: 32px;
}
.mt-48 {
    margin-top: 48px;
}
.mt-64 {
    margin-top: 64px;
}
.mt-80 {
    margin-top: 80px;
}
.mb-unset {
    margin-bottom: unset;
}
.mb-4 {
    margin-bottom: 4px;
}
.mb-8 {
    margin-bottom: 8px;
}
.mb-12 {
    margin-bottom: 12px;
}
.mb-16 {
    margin-bottom: 16px;
}
.mb-20 {
    margin-bottom: 20px;
}
.mb-32 {
    margin-bottom: 32px;
}
.mb-48 {
    margin-bottom: 48px;
}
.mb-64 {
    margin-bottom: 64px;
}
.mb-80 {
    margin-bottom: 80px;
}

.ml-unset {
    margin-left: unset;
}
.ml-4 {
    margin-left: 4px;
}
.ml-8 {
    margin-left: 8px;
}
.ml-12 {
    margin-left: 12px;
}
.ml-16 {
    margin-left: 16px;
}
.ml-20 {
    margin-left: 20px;
}
.ml-32 {
    margin-left: 32px;
}
.ml-48 {
    margin-left: 48px;
}
.ml-64 {
    margin-left: 64px;
}
.ml-80 {
    margin-left: 80px;
}

.mr-unset {
    margin-right: unset;
}
.mr-4 {
    margin-right: 4px;
}
.mr-8 {
    margin-right: 8px;
}
.mr-12 {
    margin-right: 12px;
}
.mr-16 {
    margin-right: 16px;
}
.mr-20 {
    margin-right: 20px;
}
.mr-32 {
    margin-right: 32px;
}
.mr-48 {
    margin-right: 48px;
}
.mr-64 {
    margin-right: 64px;
}
.mr-80 {
    margin-right: 80px;
}

.my-unset {
    margin-top: unset;
    margin-bottom: unset;
}
.my-4 {
    margin-top: 4px;
    margin-bottom: 4px;
}
.my-8 {
    margin-top: 8px;
    margin-bottom: 8px;
}
.my-12 {
    margin-top: 12px;
    margin-bottom: 12px;
}
.my-16 {
    margin-top: 16px;
    margin-bottom: 16px;
}
.my-20 {
    margin-top: 20px;
    margin-bottom: 20px;
}
.my-32 {
    margin-top: 32px;
    margin-bottom: 32px;
}
.my-48 {
    margin-top: 48px;
    margin-bottom: 48px;
}
.my-64 {
    margin-top: 64px;
    margin-bottom: 64px;
}
.my-80 {
    margin-top: 80px;
    margin-bottom: 80px;
}
.mx-unset {
    margin-left: unset;
    margin-right: unset;
}
.mx-4 {
    margin-left: 4px;
    margin-right: 4px;
}
.mx-8 {
    margin-left: 8px;
    margin-right: 8px;
}
.mx-12 {
    margin-left: 12px;
    margin-right: 12px;
}
.mx-16 {
    margin-left: 16px;
    margin-right: 16px;
}
.mx-20 {
    margin-left: 20px;
    margin-right: 20px;
}
.mx-32 {
    margin-left: 32px;
    margin-right: 32px;
}
.mx-48 {
    margin-left: 48px;
    margin-right: 48px;
}
.mx-64 {
    margin-left: 64px;
    margin-right: 64px;
}
.mx-80 {
    margin-left: 80px;
    margin-right: 80px;
}

.mt-auto {
    margin-top: auto;
}
.mb-auto {
    margin-bottom: auto;
}
.ml-auto {
    margin-left: auto;
}
.mr-auto {
    margin-right: auto;
}
.mx-auto {
    margin-left: auto;
    margin-right: auto;
}
.my-auto {
    margin-top: auto;
    margin-bottom: auto;
}
@media (max-width: 1023px) {
    .m-m-unset {
        margin: unset;
    }
    .m-m-4 {
        margin: 4px;
    }
    .m-m-8 {
        margin: 8px;
    }
    .m-m-12 {
        margin: 12px;
    }
    .m-m-16 {
        margin: 16px;
    }
    .m-m-20 {
        margin: 20px;
    }
    .m-m-32 {
        margin: 32px;
    }
    .m-m-48 {
        margin: 48px;
    }
    .m-m-64 {
        margin: 64px;
    }
    .m-m-80 {
        margin: 80px;
    }
    .m-mt-unset {
        margin-top: unset;
    }
    .m-mt-4 {
        margin-top: 4px;
    }
    .m-mt-8 {
        margin-top: 8px;
    }
    .m-mt-12 {
        margin-top: 12px;
    }
    .m-mt-16 {
        margin-top: 16px;
    }
    .m-mt-20 {
        margin-top: 20px;
    }
    .m-mt-32 {
        margin-top: 32px;
    }
    .m-mt-48 {
        margin-top: 48px;
    }
    .m-mt-64 {
        margin-top: 64px;
    }
    .m-mt-80 {
        margin-top: 80px;
    }
    .m-mb-unset {
        margin-bottom: unset;
    }
    .m-mb-4 {
        margin-bottom: 4px;
    }
    .m-mb-8 {
        margin-bottom: 8px;
    }
    .m-mb-12 {
        margin-bottom: 12px;
    }
    .m-mb-16 {
        margin-bottom: 16px;
    }
    .m-mb-20 {
        margin-bottom: 20px;
    }
    .m-mb-32 {
        margin-bottom: 32px;
    }
    .m-mb-48 {
        margin-bottom: 48px;
    }
    .m-mb-64 {
        margin-bottom: 64px;
    }
    .m-mb-80 {
        margin-bottom: 80px;
    }

    .m-ml-unset {
        margin-left: unset;
    }
    .m-ml-4 {
        margin-left: 4px;
    }
    .m-ml-8 {
        margin-left: 8px;
    }
    .m-ml-12 {
        margin-left: 12px;
    }
    .m-ml-16 {
        margin-left: 16px;
    }
    .m-ml-20 {
        margin-left: 20px;
    }
    .m-ml-32 {
        margin-left: 32px;
    }
    .m-ml-48 {
        margin-left: 48px;
    }
    .m-ml-64 {
        margin-left: 64px;
    }
    .m-ml-80 {
        margin-left: 80px;
    }

    .m-mr-unset {
        margin-right: unset;
    }
    .m-mr-4 {
        margin-right: 4px;
    }
    .m-mr-8 {
        margin-right: 8px;
    }
    .m-mr-12 {
        margin-right: 12px;
    }
    .m-mr-16 {
        margin-right: 16px;
    }
    .m-mr-20 {
        margin-right: 20px;
    }
    .m-mr-32 {
        margin-right: 32px;
    }
    .m-mr-48 {
        margin-right: 48px;
    }
    .m-mr-64 {
        margin-right: 64px;
    }
    .m-mr-80 {
        margin-right: 80px;
    }

    .m-my-unset {
        margin-top: unset;
        margin-bottom: unset;
    }
    .m-my-4 {
        margin-top: 4px;
        margin-bottom: 4px;
    }
    .m-my-8 {
        margin-top: 8px;
        margin-bottom: 8px;
    }
    .m-my-12 {
        margin-top: 12px;
        margin-bottom: 12px;
    }
    .m-my-16 {
        margin-top: 16px;
        margin-bottom: 16px;
    }
    .m-my-20 {
        margin-top: 20px;
        margin-bottom: 20px;
    }
    .m-my-32 {
        margin-top: 32px;
        margin-bottom: 32px;
    }
    .m-my-48 {
        margin-top: 48px;
        margin-bottom: 48px;
    }
    .m-my-64 {
        margin-top: 64px;
        margin-bottom: 64px;
    }
    .m-my-80 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .m-mx-unset {
        margin-left: unset;
        margin-right: unset;
    }
    .m-mx-4 {
        margin-left: 4px;
        margin-right: 4px;
    }
    .m-mx-8 {
        margin-left: 8px;
        margin-right: 8px;
    }
    .m-mx-12 {
        margin-left: 12px;
        margin-right: 12px;
    }
    .m-mx-16 {
        margin-left: 16px;
        margin-right: 16px;
    }
    .m-mx-20 {
        margin-left: 20px;
        margin-right: 20px;
    }
    .m-mx-32 {
        margin-left: 32px;
        margin-right: 32px;
    }
    .m-mx-48 {
        margin-left: 48px;
        margin-right: 48px;
    }
    .m-mx-64 {
        margin-left: 64px;
        margin-right: 64px;
    }
    .m-mx-80 {
        margin-left: 80px;
        margin-right: 80px;
    }
}
@media (max-width: 767px) {
    .sm-m-unset {
        margin: unset;
    }
    .sm-m-4 {
        margin: 4px;
    }
    .sm-m-8 {
        margin: 8px;
    }
    .sm-m-12 {
        margin: 12px;
    }
    .sm-m-16 {
        margin: 16px;
    }
    .sm-m-20 {
        margin: 20px;
    }
    .sm-m-32 {
        margin: 32px;
    }
    .sm-m-48 {
        margin: 48px;
    }
    .sm-m-64 {
        margin: 64px;
    }
    .sm-m-80 {
        margin: 80px;
    }
    .sm-mt-unset {
        margin-top: unset;
    }
    .sm-mt-4 {
        margin-top: 4px;
    }
    .sm-mt-8 {
        margin-top: 8px;
    }
    .sm-mt-12 {
        margin-top: 12px;
    }
    .sm-mt-16 {
        margin-top: 16px;
    }
    .sm-mt-20 {
        margin-top: 20px;
    }
    .sm-mt-32 {
        margin-top: 32px;
    }
    .sm-mt-48 {
        margin-top: 48px;
    }
    .sm-mt-64 {
        margin-top: 64px;
    }
    .sm-mt-80 {
        margin-top: 80px;
    }
    .sm-mb-unset {
        margin-bottom: unset;
    }
    .sm-mb-4 {
        margin-bottom: 4px;
    }
    .sm-mb-8 {
        margin-bottom: 8px;
    }
    .sm-mb-12 {
        margin-bottom: 12px;
    }
    .sm-mb-16 {
        margin-bottom: 16px;
    }
    .sm-mb-20 {
        margin-bottom: 20px;
    }
    .sm-mb-32 {
        margin-bottom: 32px;
    }
    .sm-mb-48 {
        margin-bottom: 48px;
    }
    .sm-mb-64 {
        margin-bottom: 64px;
    }
    .sm-mb-80 {
        margin-bottom: 80px;
    }

    .sm-ml-unset {
        margin-left: unset;
    }
    .sm-ml-4 {
        margin-left: 4px;
    }
    .sm-ml-8 {
        margin-left: 8px;
    }
    .sm-ml-12 {
        margin-left: 12px;
    }
    .sm-ml-16 {
        margin-left: 16px;
    }
    .sm-ml-20 {
        margin-left: 20px;
    }
    .sm-ml-32 {
        margin-left: 32px;
    }
    .sm-ml-48 {
        margin-left: 48px;
    }
    .sm-ml-64 {
        margin-left: 64px;
    }
    .sm-ml-80 {
        margin-left: 80px;
    }

    .sm-mr-unset {
        margin-right: unset;
    }
    .sm-mr-4 {
        margin-right: 4px;
    }
    .sm-mr-8 {
        margin-right: 8px;
    }
    .sm-mr-12 {
        margin-right: 12px;
    }
    .sm-mr-16 {
        margin-right: 16px;
    }
    .sm-mr-20 {
        margin-right: 20px;
    }
    .sm-mr-32 {
        margin-right: 32px;
    }
    .sm-mr-48 {
        margin-right: 48px;
    }
    .sm-mr-64 {
        margin-right: 64px;
    }
    .sm-mr-80 {
        margin-right: 80px;
    }

    .sm-my-unset {
        margin-top: unset;
        margin-bottom: unset;
    }
    .sm-my-4 {
        margin-top: 4px;
        margin-bottom: 4px;
    }
    .sm-my-8 {
        margin-top: 8px;
        margin-bottom: 8px;
    }
    .sm-my-12 {
        margin-top: 12px;
        margin-bottom: 12px;
    }
    .sm-my-16 {
        margin-top: 16px;
        margin-bottom: 16px;
    }
    .sm-my-20 {
        margin-top: 20px;
        margin-bottom: 20px;
    }
    .sm-my-32 {
        margin-top: 32px;
        margin-bottom: 32px;
    }
    .sm-my-48 {
        margin-top: 48px;
        margin-bottom: 48px;
    }
    .sm-my-64 {
        margin-top: 64px;
        margin-bottom: 64px;
    }
    .sm-my-80 {
        margin-top: 80px;
        margin-bottom: 80px;
    }
    .sm-mx-unset {
        margin-left: unset;
        margin-right: unset;
    }
    .sm-mx-4 {
        margin-left: 4px;
        margin-right: 4px;
    }
    .sm-mx-8 {
        margin-left: 8px;
        margin-right: 8px;
    }
    .sm-mx-12 {
        margin-left: 12px;
        margin-right: 12px;
    }
    .sm-mx-16 {
        margin-left: 16px;
        margin-right: 16px;
    }
    .sm-mx-20 {
        margin-left: 20px;
        margin-right: 20px;
    }
    .sm-mx-32 {
        margin-left: 32px;
        margin-right: 32px;
    }
    .sm-mx-48 {
        margin-left: 48px;
        margin-right: 48px;
    }
    .sm-mx-64 {
        margin-left: 64px;
        margin-right: 64px;
    }
    .sm-mx-80 {
        margin-left: 80px;
        margin-right: 80px;
    }
}
/*
* PADDINGS 
*/

.p-4 {
    padding: 4px;
}
.p-6 {
    padding: 6px;
}
.p-8 {
    padding: 8px;
}
.p-12 {
    padding: 12px;
}
.p-16 {
    padding: 16px;
}
.p-20 {
    padding: 20px;
}
.p-24 {
    padding: 24px;
}
.p-32 {
    padding: 32px;
}
.p-48 {
    padding: 48px;
}
.p-58 {
    padding: 58px;
}
.p-64 {
    padding: 64px;
}
.p-80 {
    padding: 80px;
}
.p-96 {
    padding: 96px;
}
.p-112 {
    padding: 112px;
}
.p-132 {
    padding: 132px;
}

.p-unset {
    padding: unset;
}

.pt-4 {
    padding-top: 4px;
}
.pt-6 {
    padding-top: 6px;
}
.pt-8 {
    padding-top: 8px;
}
.pt-12 {
    padding-top: 12px;
}
.pt-16 {
    padding-top: 16px;
}
.pt-20 {
    padding-top: 20px;
}
.pt-24 {
    padding-top: 24px;
}
.pt-32 {
    padding-top: 32px;
}
.pt-48 {
    padding-top: 48px;
}
.pt-58 {
    padding-top: 58px;
}
.pt-64 {
    padding-top: 64px;
}
.pt-80 {
    padding-top: 80px;
}
.pt-96 {
    padding-top: 96px;
}
.pt-112 {
    padding-top: 112px;
}
.pt-132 {
    padding-top: 132px;
}
.pt-160 {
    padding-top: 160px;
}

.pb-4 {
    padding-bottom: 4px;
}
.pb-6 {
    padding-bottom: 6px;
}
.pb-8 {
    padding-bottom: 8px;
}
.pb-12 {
    padding-bottom: 12px;
}
.pb-16 {
    padding-bottom: 16px;
}
.pb-20 {
    padding-bottom: 20px;
}
.pb-24 {
    padding-bottom: 24px;
}
.pb-32 {
    padding-bottom: 32px;
}
.pb-48 {
    padding-bottom: 48px;
}
.pb-58 {
    padding-bottom: 58px;
}
.pb-64 {
    padding-bottom: 64px;
}
.pb-80 {
    padding-bottom: 80px;
}
.pb-96 {
    padding-bottom: 96px;
}
.pb-112 {
    padding-bottom: 112px;
}
.pb-132 {
    padding-bottom: 132px;
}
.pb-unset {
    padding-bottom: unset;
}

.pl-4 {
    padding-left: 4px;
}
.pl-6 {
    padding-left: 6px;
}
.pl-8 {
    padding-left: 8px;
}
.pl-12 {
    padding-left: 12px;
}
.pl-16 {
    padding-left: 16px;
}
.pl-20 {
    padding-left: 20px;
}
.pl-24 {
    padding-left: 24px;
}
.pl-32 {
    padding-left: 32px;
}
.pl-48 {
    padding-left: 48px;
}
.pl-58 {
    padding-left: 58px;
}
.pl-64 {
    padding-left: 64px;
}
.pl-80 {
    padding-left: 80px;
}
.pl-96 {
    padding-left: 96px;
}
.pl-112 {
    padding-left: 112px;
}
.pl-132 {
    padding-left: 132px;
}
.pl-unset {
    padding-left: unset;
}

.pr-4 {
    padding-right: 4px;
}
.pr-6 {
    padding-right: 6px;
}
.pr-8 {
    padding-right: 8px;
}
.pr-12 {
    padding-right: 12px;
}
.pr-16 {
    padding-right: 16px;
}
.pr-20 {
    padding-right: 20px;
}
.pr-24 {
    padding-right: 24px;
}
.pr-32 {
    padding-right: 32px;
}
.pr-48 {
    padding-right: 48px;
}
.pr-58 {
    padding-right: 58px;
}
.pr-64 {
    padding-right: 64px;
}
.pr-80 {
    padding-right: 80px;
}
.pr-96 {
    padding-right: 96px;
}
.pr-112 {
    padding-right: 112px;
}
.pr-132 {
    padding-right: 132px;
}
.pr-unset {
    padding-right: unset;
}

.py-4 {
    padding-top: 4px;
    padding-bottom: 4px;
}
.py-6 {
    padding-top: 6px;
    padding-bottom: 6px;
}
.py-8 {
    padding-top: 8px;
    padding-bottom: 8px;
}
.py-12 {
    padding-top: 12px;
    padding-bottom: 12px;
}
.py-16 {
    padding-top: 16px;
    padding-bottom: 16px;
}
.py-20 {
    padding-top: 20px;
    padding-bottom: 20px;
}
.py-24 {
    padding-top: 24px;
    padding-bottom: 24px;
}
.py-32 {
    padding-top: 32px;
    padding-bottom: 32px;
}
.py-48 {
    padding-top: 48px;
    padding-bottom: 48px;
}
.py-58 {
    padding-top: 58px;
    padding-bottom: 58px;
}
.py-64 {
    padding-top: 64px;
    padding-bottom: 64px;
}
.py-80 {
    padding-top: 80px;
    padding-bottom: 80px;
}
.py-96 {
    padding-top: 96px;
    padding-bottom: 96px;
}
.py-112 {
    padding-top: 112px;
    padding-bottom: 112px;
}
.py-132 {
    padding-top: 132px;
    padding-bottom: 132px;
}
.py-unset {
    padding-top: unset;
    padding-bottom: unset;
}

.px-4 {
    padding-left: 4px;
    padding-right: 4px;
}
.px-6 {
    padding-left: 6px;
    padding-right: 6px;
}
.px-8 {
    padding-left: 8px;
    padding-right: 8px;
}
.px-12 {
    padding-left: 12px;
    padding-right: 12px;
}
.px-16 {
    padding-left: 16px;
    padding-right: 16px;
}
.px-20 {
    padding-left: 20px;
    padding-right: 20px;
}
.px-24 {
    padding-left: 24px;
    padding-right: 24px;
}
.px-32 {
    padding-left: 32px;
    padding-right: 32px;
}
.px-48 {
    padding-left: 48px;
    padding-right: 48px;
}
.px-58 {
    padding-left: 58px;
    padding-right: 58px;
}
.px-64 {
    padding-left: 64px;
    padding-right: 64px;
}
.px-80 {
    padding-left: 80px;
    padding-right: 80px;
}
.px-96 {
    padding-left: 96px;
    padding-right: 96px;
}
.px-112 {
    padding-left: 112px;
    padding-right: 112px;
}
.px-132 {
    padding-left: 132px;
    padding-right: 132px;
}

.px-unset {
    padding-left: unset;
    padding-right: unset;
}
.pt-unset {
    padding-top: unset;
}
@media (max-width: 1023px) {
    .m-p-4 {
        padding: 4px;
    }
    .m-p-6 {
        padding: 6px;
    }
    .m-p-8 {
        padding: 8px;
    }
    .m-p-12 {
        padding: 12px;
    }
    .m-p-16 {
        padding: 16px;
    }
    .m-p-20 {
        padding: 20px;
    }
    .m-p-24 {
        padding: 24px;
    }
    .m-p-32 {
        padding: 32px;
    }
    .m-p-48 {
        padding: 48px;
    }
    .m-p-58 {
        padding: 58px;
    }
    .m-p-64 {
        padding: 64px;
    }
    .m-p-80 {
        padding: 80px;
    }
    .m-p-96 {
        padding: 96px;
    }
    .m-p-112 {
        padding: 112px;
    }
    .m-p-132 {
        padding: 132px;
    }
    .m-p-unset {
        padding: unset;
    }
    .m-py-4 {
        padding-top: 4px;
        padding-bottom: 4px;
    }
    .m-py-6 {
        padding-top: 6px;
        padding-bottom: 6px;
    }
    .m-py-8 {
        padding-top: 8px;
        padding-bottom: 8px;
    }
    .m-py-12 {
        padding-top: 12px;
        padding-bottom: 12px;
    }
    .m-py-16 {
        padding-top: 16px;
        padding-bottom: 16px;
    }
    .m-py-20 {
        padding-top: 20px;
        padding-bottom: 20px;
    }
    .m-py-24 {
        padding-top: 24px;
        padding-bottom: 24px;
    }
    .m-py-32 {
        padding-top: 32px;
        padding-bottom: 32px;
    }
    .m-py-58 {
        padding-top: 58px;
        padding-bottom: 58px;
    }
    .m-py-64 {
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .m-py-80 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .m-py-96 {
        padding-top: 96px;
        padding-bottom: 96px;
    }
    .m-py-112 {
        padding-top: 112px;
        padding-bottom: 112px;
    }
    .m-py-132 {
        padding-top: 132px;
        padding-bottom: 132px;
    }
    .m-py-unset {
        padding-top: unset;
        padding-bottom: unset;
    }
    .m-px-4 {
        padding-left: 4px;
        padding-right: 4px;
    }
    .m-px-6 {
        padding-left: 6px;
        padding-right: 6px;
    }
    .m-px-8 {
        padding-left: 8px;
        padding-right: 8px;
    }
    .m-px-12 {
        padding-left: 12px;
        padding-right: 12px;
    }
    .m-px-16 {
        padding-left: 16px;
        padding-right: 16px;
    }
    .m-px-20 {
        padding-left: 20px;
        padding-right: 20px;
    }
    .m-px-24 {
        padding-left: 24px;
        padding-right: 24px;
    }
    .m-px-32 {
        padding-left: 32px;
        padding-right: 32px;
    }
    .m-px-58 {
        padding-left: 58px;
        padding-right: 58px;
    }
    .m-px-64 {
        padding-left: 64px;
        padding-right: 64px;
    }
    .m-px-80 {
        padding-left: 80px;
        padding-right: 80px;
    }
    .m-px-96 {
        padding-left: 96px;
        padding-right: 96px;
    }
    .m-px-112 {
        padding-left: 112px;
        padding-right: 112px;
    }
    .m-px-132 {
        padding-left: 132px;
        padding-right: 132px;
    }
    .m-px-unset {
        padding-left: unset;
        padding-right: unset;
    }
    .m-pt-4 {
        padding-top: 4px;
    }
    .m-pt-6 {
        padding-top: 6px;
    }
    .m-pt-8 {
        padding-top: 8px;
    }
    .m-pt-12 {
        padding-top: 12px;
    }
    .m-pt-16 {
        padding-top: 16px;
    }
    .m-pt-20 {
        padding-top: 20px;
    }
    .m-pt-24 {
        padding-top: 24px;
    }
    .m-pt-32 {
        padding-top: 32px;
    }
    .m-pt-58 {
        padding-top: 58px;
    }
    .m-pt-64 {
        padding-top: 64px;
    }
    .m-pt-80 {
        padding-top: 80px;
    }
    .m-pt-96 {
        padding-top: 96px;
    }
    .m-pt-112 {
        padding-top: 112px;
    }
    .m-pt-132 {
        padding-top: 132px;
    }

    .m-pb-4 {
        padding-bottom: 4px;
    }
    .m-pb-6 {
        padding-bottom: 6px;
    }
    .m-pb-8 {
        padding-bottom: 8px;
    }
    .m-pb-12 {
        padding-bottom: 12px;
    }
    .m-pb-16 {
        padding-bottom: 16px;
    }
    .m-pb-20 {
        padding-bottom: 20px;
    }
    .m-pb-24 {
        padding-bottom: 24px;
    }
    .m-pb-32 {
        padding-bottom: 32px;
    }
    .m-pb-58 {
        padding-bottom: 58px;
    }
    .m-pb-64 {
        padding-bottom: 64px;
    }
    .m-pb-80 {
        padding-bottom: 80px;
    }
    .m-pb-96 {
        padding-bottom: 96px;
    }
    .m-pb-112 {
        padding-bottom: 112px;
    }
    .m-pb-132 {
        padding-bottom: 132px;
    }
    .m-pb-unset {
        padding-bottom: unset;
    }
    .m-pl-4 {
        padding-left: 4px;
    }
    .m-pl-6 {
        padding-left: 6px;
    }
    .m-pl-8 {
        padding-left: 8px;
    }
    .m-pl-12 {
        padding-left: 12px;
    }
    .m-pl-16 {
        padding-left: 16px;
    }
    .m-pl-20 {
        padding-left: 20px;
    }
    .m-pl-24 {
        padding-left: 24px;
    }
    .m-pl-32 {
        padding-left: 32px;
    }
    .m-pl-58 {
        padding-left: 58px;
    }
    .m-pl-64 {
        padding-left: 64px;
    }
    .m-pl-80 {
        padding-left: 80px;
    }
    .m-pl-96 {
        padding-left: 96px;
    }
    .m-pl-112 {
        padding-left: 112px;
    }
    .m-pl-132 {
        padding-left: 132px;
    }
    .m-pl-unset {
        padding-left: unset;
    }
    .m-pr-4 {
        padding-right: 4px;
    }
    .m-pr-6 {
        padding-right: 6px;
    }
    .m-pr-8 {
        padding-right: 8px;
    }
    .m-pr-12 {
        padding-right: 12px;
    }
    .m-pr-16 {
        padding-right: 16px;
    }
    .m-pr-20 {
        padding-right: 20px;
    }
    .m-pr-24 {
        padding-right: 24px;
    }
    .m-pr-32 {
        padding-right: 32px;
    }
    .m-pr-58 {
        padding-right: 58px;
    }
    .m-pr-64 {
        padding-right: 64px;
    }
    .m-pr-80 {
        padding-right: 80px;
    }
    .m-pr-96 {
        padding-right: 96px;
    }
    .m-pr-112 {
        padding-right: 112px;
    }
    .m-pr-132 {
        padding-right: 132px;
    }
    .m-pr-unset {
        padding-right: unset;
    }

    .m-pt-unset {
        padding-top: unset;
    }
}
@media (max-width: 767px) {
    .sm-p-4 {
        padding: 4px;
    }
    .sm-p-6 {
        padding: 6px;
    }
    .sm-p-8 {
        padding: 8px;
    }
    .sm-p-12 {
        padding: 12px;
    }
    .sm-p-16 {
        padding: 16px;
    }
    .sm-p-20 {
        padding: 20px;
    }
    .sm-p-24 {
        padding: 24px;
    }
    .sm-p-32 {
        padding: 32px;
    }
    .sm-p-58 {
        padding: 58px;
    }
    .sm-p-64 {
        padding: 64px;
    }
    .sm-p-80 {
        padding: 80px;
    }
    .sm-p-96 {
        padding: 96px;
    }
    .sm-p-112 {
        padding: 112px;
    }
    .sm-p-132 {
        padding: 132px;
    }
    .sm-p-unset {
        padding: unset;
    }
    .sm-py-4 {
        padding-top: 4px;
        padding-bottom: 4px;
    }
    .sm-py-6 {
        padding-top: 6px;
        padding-bottom: 6px;
    }
    .sm-py-8 {
        padding-top: 8px;
        padding-bottom: 8px;
    }
    .sm-py-12 {
        padding-top: 12px;
        padding-bottom: 12px;
    }
    .sm-py-16 {
        padding-top: 16px;
        padding-bottom: 16px;
    }
    .sm-py-20 {
        padding-top: 20px;
        padding-bottom: 20px;
    }
    .sm-py-24 {
        padding-top: 24px;
        padding-bottom: 24px;
    }
    .sm-py-32 {
        padding-top: 32px;
        padding-bottom: 32px;
    }
    .sm-py-58 {
        padding-top: 58px;
        padding-bottom: 58px;
    }
    .sm-py-64 {
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .sm-py-80 {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .sm-py-96 {
        padding-top: 96px;
        padding-bottom: 96px;
    }
    .sm-py-112 {
        padding-top: 112px;
        padding-bottom: 112px;
    }
    .sm-py-132 {
        padding-top: 132px;
        padding-bottom: 132px;
    }
    .sm-py-unset {
        padding-top: unset;
        padding-bottom: unset;
    }
    .sm-px-4 {
        padding-left: 4px;
        padding-right: 4px;
    }
    .sm-px-6 {
        padding-left: 6px;
        padding-right: 6px;
    }
    .sm-px-8 {
        padding-left: 8px;
        padding-right: 8px;
    }
    .sm-px-12 {
        padding-left: 12px;
        padding-right: 12px;
    }
    .sm-px-16 {
        padding-left: 16px;
        padding-right: 16px;
    }
    .sm-px-20 {
        padding-left: 20px;
        padding-right: 20px;
    }
    .sm-px-24 {
        padding-left: 24px;
        padding-right: 24px;
    }
    .sm-px-32 {
        padding-left: 32px;
        padding-right: 32px;
    }
    .sm-px-58 {
        padding-left: 58px;
        padding-right: 58px;
    }
    .sm-px-64 {
        padding-left: 64px;
        padding-right: 64px;
    }
    .sm-px-80 {
        padding-left: 80px;
        padding-right: 80px;
    }
    .sm-px-96 {
        padding-left: 96px;
        padding-right: 96px;
    }
    .sm-px-112 {
        padding-left: 112px;
        padding-right: 112px;
    }
    .sm-px-132 {
        padding-left: 132px;
        padding-right: 132px;
    }
    .sm-px-unset {
        padding-left: unset;
        padding-right: unset;
    }
    .sm-pt-4 {
        padding-top: 4px;
    }
    .sm-pt-6 {
        padding-top: 6px;
    }
    .sm-pt-8 {
        padding-top: 8px;
    }
    .sm-pt-12 {
        padding-top: 12px;
    }
    .sm-pt-16 {
        padding-top: 16px;
    }
    .sm-pt-20 {
        padding-top: 20px;
    }
    .sm-pt-24 {
        padding-top: 24px;
    }
    .sm-pt-32 {
        padding-top: 32px;
    }
    .sm-pt-58 {
        padding-top: 58px;
    }
    .sm-pt-64 {
        padding-top: 64px;
    }
    .sm-pt-80 {
        padding-top: 80px;
    }
    .sm-pt-96 {
        padding-top: 96px;
    }
    .sm-pt-112 {
        padding-top: 112px;
    }
    .sm-pt-132 {
        padding-top: 132px;
    }

    .sm-pb-4 {
        padding-bottom: 4px;
    }
    .sm-pb-6 {
        padding-bottom: 6px;
    }
    .sm-pb-8 {
        padding-bottom: 8px;
    }
    .sm-pb-12 {
        padding-bottom: 12px;
    }
    .sm-pb-16 {
        padding-bottom: 16px;
    }
    .sm-pb-20 {
        padding-bottom: 20px;
    }
    .sm-pb-24 {
        padding-bottom: 24px;
    }
    .sm-pb-32 {
        padding-bottom: 32px;
    }
    .sm-pb-58 {
        padding-bottom: 58px;
    }
    .sm-pb-64 {
        padding-bottom: 64px;
    }
    .sm-pb-80 {
        padding-bottom: 80px;
    }
    .sm-pb-96 {
        padding-bottom: 96px;
    }
    .sm-pb-112 {
        padding-bottom: 112px;
    }
    .sm-pb-132 {
        padding-bottom: 132px;
    }
    .sm-pb-unset {
        padding-bottom: unset;
    }
    .sm-pl-4 {
        padding-left: 4px;
    }
    .sm-pl-6 {
        padding-left: 6px;
    }
    .sm-pl-8 {
        padding-left: 8px;
    }
    .sm-pl-12 {
        padding-left: 12px;
    }
    .sm-pl-16 {
        padding-left: 16px;
    }
    .sm-pl-20 {
        padding-left: 20px;
    }
    .sm-pl-24 {
        padding-left: 24px;
    }
    .sm-pl-32 {
        padding-left: 32px;
    }
    .sm-pl-58 {
        padding-left: 58px;
    }
    .sm-pl-64 {
        padding-left: 64px;
    }
    .sm-pl-80 {
        padding-left: 80px;
    }
    .sm-pl-96 {
        padding-left: 96px;
    }
    .sm-pl-112 {
        padding-left: 112px;
    }
    .sm-pl-132 {
        padding-left: 132px;
    }
    .sm-pl-unset {
        padding-left: unset;
    }
    .sm-pr-4 {
        padding-right: 4px;
    }
    .sm-pr-6 {
        padding-right: 6px;
    }
    .sm-pr-8 {
        padding-right: 8px;
    }
    .sm-pr-12 {
        padding-right: 12px;
    }
    .sm-pr-16 {
        padding-right: 16px;
    }
    .sm-pr-20 {
        padding-right: 20px;
    }
    .sm-pr-24 {
        padding-right: 24px;
    }
    .sm-pr-32 {
        padding-right: 32px;
    }
    .sm-pr-58 {
        padding-right: 58px;
    }
    .sm-pr-64 {
        padding-right: 64px;
    }
    .sm-pr-80 {
        padding-right: 80px;
    }
    .sm-pr-96 {
        padding-right: 96px;
    }
    .sm-pr-112 {
        padding-right: 112px;
    }
    .sm-pr-132 {
        padding-right: 132px;
    }
    .sm-pr-unset {
        padding-right: unset;
    }

    .sm-pt-unset {
        padding-top: unset;
    }
}
/* .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;
  }
} */

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

/* Header DND sections */

.header .dnd-section {
  padding: 0;
}

/* Header container */

.header__container {
  display: flex;
  justify-content: space-between;
}

.header__row-1 {
  padding-top: 1rem;
}

.header__row-1,
.header__row-2 {
  align-items: center;
  display: flex;
  justify-content: flex-end;
  width: 100%;
}

@media (max-width: 1150px) and (min-width: 767px) {
  .header__column {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .header__container {
    flex-direction: column;
    padding: 1rem 0 0;
  }

  .header__column {
    position: relative;
  }

  .header__row-1 {
    padding-top: 0;
  }

  .header__row-2 {
    justify-content: center;
    padding: 1.05rem;
  }
}

/* Navigation skipper */

.header__skip {
  height: 1px;
  left: -1000px;
  overflow: hidden;
  position: absolute;
  text-align: left;
  top: -1000px;
  width: 1px;
}

.header__skip:hover,
.header__skip:focus,
.header__skip:active {
  height: auto;
  left: 0;
  overflow: visible;
  top: 0;
  width: auto;
}

/* Logo */

.header__logo {
  align-items: center;
  display: flex;
  height: auto;
  margin-right: auto;
  max-width: 200px;
  overflow: hidden;
}

@media (max-width: 767px) {
  .header__logo {
    margin: 0 auto;
    width: 100%;
  }
}

.header__logo img {
  max-width: 100%;
}

.header__logo .logo-company-name {
  font-size: 1.167rem;
  margin-top: 0.7rem;
}

.header__logo--main {
  padding-top: 1rem;
}

/* Search bar */

.header__search {
  padding: 0 1rem;
  width: auto;
}



  .hs-search-field__form {
    position: relative;
  }

  .header__search .hs-search-field__label {
    flex-basis: auto;
  }



.header__search .hs-search-field__input {
  
  height: 45px;
  padding: 0 0.7rem;
}



  .header__search .hs-search-field__button {
    padding: 0;
    fill: #000;
    background-color: transparent;
    border: none;
    padding: 10px;
    position: absolute;
    top: 0;
    right: 0;
  }

  .header__search .hs-search-field__button svg {
    height: 25px;
  }


.header__search .hs-search-field--open .hs-search-field__input {
  border-bottom: none;
  border-radius: 6px 6px 0 0;
  max-width: 100%;
}

.header__search .hs-search-field--open .hs-search-field__suggestions {
  background-color: #FFF;
  border: 2px solid #D1D6DC;
  border-radius: 0 0 6px 6px;
  border-top-width: 1px;
  position: absolute;
  width: 100%;
  z-index: 10;
}

.header__search .hs-search-field__suggestions li {
  border-top: 1px solid #D1D6DC;
  font-size: 0.875rem;
}

.header__search .hs-search-field__suggestions li a {
  color: #494A52;
  padding: 0.35rem 0.7rem;
  text-decoration: none;
  transition: background-color 0.3s;
}

.header__search .hs-search-field__suggestions #results-for {
  display: none;
}

@media (min-width: 767px) {
  .header__search form {
    align-items: center;
    display: flex;
    flex-direction: row;
  }

  .header__search label {
    margin: 0 1rem 0 0;
  }

  .header__search .hs-search-field__input {
    width: auto;
  }
}

@media (max-width: 767px) {
  .header__search {
    border-top: 2px solid #CED4DB;
    order: 1;
    padding: 1.05rem;
  }
}

/* Language switcher */

.header__language-switcher {
  cursor: pointer;
  padding-right: 1.4rem;
}

.header__language-switcher .lang_switcher_class {
  position: static;
}

.header__language-switcher .lang_list_class {
  border: 2px solid;
  border-radius: 3px;
  box-shadow: 0 2px 9px 0 rgba(0, 0, 0, 0.2);
  display: block;
  left: calc(100% - 24px);
  opacity: 0;
  min-width: 100px;
  padding-top: 0;
  text-align: left;
  top: 100%;
  transition: opacity 0.3s;
  visibility: hidden;
}

.header__language-switcher:hover .lang_list_class,
.header__language-switcher:focus .lang_list_class {
  opacity: 1;
  transition: opacity 0.3s;
  visibility: visible;
}

.header__language-switcher .lang_list_class:before {
  left: 70%;
  top: -25px;
}

.header__language-switcher .lang_list_class:after {
  left: 70%;
  top: -22px;
}

.header__language-switcher .lang_list_class.first-active::after {
  top: -22px;
  transition: 0.3s;
}

.header__language-switcher .lang_list_class li {
  border: none;
  font-size: 18px;
  padding: 0.35rem 0.7rem;
}

.header__language-switcher .lang_list_class li:first-child {
  border-radius: 6px 6px 0 0;
  border-top: none;
}

.header__language-switcher .lang_list_class li:last-child {
  border-bottom: none;
  border-radius: 0 0 6px 6px;
}

.header__language-switcher .lang_list_class li:hover {
  transition: background-color 0.3s;
}

.header__language-switcher--label {
  display: flex;
  position: relative;
}

.header__language-switcher--label-current {
  align-items: center;
  display: flex;
  font-size: 0.75rem;
  margin-bottom: 0.175rem;
  margin-left: 0.7rem;
}

.header__language-switcher--label-current:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 6px solid #494A52;
  content: "";
  display: block;
  height: 0px;
  margin-left: 0.7rem;
  margin-top: 0.175rem;
  width: 0px;
}

@media (max-width: 767px) {
  .header__language-switcher {
    border-top: 2px solid #CED4DB;
    padding-left: 1.05rem;
    padding-right: 0;
  }

  .header__language-switcher .lang_list_class {
    border: none;
    box-shadow: unset;
    display: block;
    left: 30px;
    opacity: 1;
    padding: 0 1.05rem;
    top: 0;
    visibility: visible;
  }

  .header__language-switcher .lang_list_class li {
    background-color: inherit;
    font-size: 0.917rem;
  }

  .header__language-switcher--label-current {
    display: none;
  }

  .header__language-switcher .globe_class {
    background-image: none;
  }

  .header__language-switcher .lang_list_class li:hover{
    background-color: inherit;
  }

  .header__language-switcher .lang_list_class:before,
  .header__language-switcher .lang_list_class:after {
    content: none;
  }}

/* Navigation */

#nav-toggle {
  display: none;
}

/* Mobile toggles */

@media (max-width: 767px) {
  .header__navigation,
  .header__search,
  .header__language-switcher {
    display: none;
    width: 100%;
  }

  .header__navigation.open,
  .header__search.open,
  .header__language-switcher.open {
    background-color: #F8FAFC;
    display: block;
    left: 0;
    min-height: calc(100vh - 115px);
    position: absolute;
    right: 0;
    top: 75px;
    z-index: 2;
  }

  .header__navigation--toggle,
  .header__search--toggle,
  .header__language-switcher--toggle,
  .header__close--toggle {
    cursor: pointer;
    margin: 0 5vw;
    position: relative;
  }

  .header__navigation--toggle.hide,
  .header__search--toggle.hide,
  .header__language-switcher--toggle.hide {
    display: none;
  }

  .header__navigation--toggle.open,
  .header__search--toggle.open,
  .header__language-switcher--toggle.open {
    display: block;
    margin-left: 0;
    margin-right: auto;
  }

  .header__navigation--toggle:after,
  .header__search--toggle:after,
  .header__language-switcher--toggle:after {
    display: none;
    font-size: 1.083rem;
    font-weight: 600;
    position: absolute;
    left: 40px;
    text-transform: uppercase;
    top: -10px;
  }

  .header__navigation--toggle.open:after,
  .header__search--toggle.open:after,
  .header__language-switcher--toggle.open:after {
    display: block;
    word-break: normal;
  }

  .header__navigation--toggle {
    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAxOSIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4gICAgICAgIDx0aXRsZT5oYW1idXJnZXI8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGcgaWQ9ImhhbWJ1cmdlciIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCI+ICAgICAgICA8ZyBpZD0iR3JvdXAiIHN0cm9rZT0iIzQ5NEE1MiIgc3Ryb2tlLXdpZHRoPSIzIj4gICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlIiB4PSIxLjUiIHk9IjEuNSIgd2lkdGg9IjIxIiBoZWlnaHQ9IjEiIHJ4PSIwLjUiPjwvcmVjdD4gICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLUNvcHktNCIgeD0iMS41IiB5PSI5LjUiIHdpZHRoPSIyMSIgaGVpZ2h0PSIxIiByeD0iMC41Ij48L3JlY3Q+ICAgICAgICAgICAgPHJlY3QgaWQ9IlJlY3RhbmdsZS1Db3B5LTUiIHg9IjEuNSIgeT0iMTcuNSIgd2lkdGg9IjIxIiBoZWlnaHQ9IjEiIHJ4PSIwLjUiPjwvcmVjdD4gICAgICAgIDwvZz4gICAgPC9nPjwvc3ZnPg==);
    background-size: cover;
    height: 25px;
    width: 25px;
  }

  .header__navigation--toggle:after {
    content: "Menu";
  }

  .header__language-switcher--toggle {
    background-image: url(//static.hsappstatic.net/cos-LanguageSwitcher/static-1.1/img/globe.png);
    background-size: cover;
    height: 25px;
    width: 25px;
  }

  .header__language-switcher--toggle:after {
    content: "Language";
  }

  .header__search--toggle {
    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjI0cHgiIHZpZXdCb3g9IjAgMCAyNCAyNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4gICAgICAgIDx0aXRsZT5TZWFyY2g8L3RpdGxlPiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4gICAgPGRlZnM+ICAgICAgICA8cGF0aCBkPSJNOS4xMzg2MTUzNCwxNS44OTI1Njg1IEM1LjQxMzk1NzQyLDE1Ljg5MjU2ODUgMi4zODM4ODUyNywxMi44NjM0NDc1IDIuMzgzODg1MjcsOS4xMzkwMDM3NiBDMi4zODM4ODUyNyw1LjQxNDU2MDA1IDUuNDEzOTU3NDIsMi4zODM4ODUyNyA5LjEzODYxNTM0LDIuMzgzODg1MjcgQzEyLjg2MzI3MzMsMi4zODM4ODUyNyAxNS44OTI1Njg1LDUuNDE0NTYwMDUgMTUuODkyNTY4NSw5LjEzOTAwMzc2IEMxNS44OTI1Njg1LDEyLjg2MzQ0NzUgMTIuODYzMjczMywxNS44OTI1Njg1IDkuMTM4NjE1MzQsMTUuODkyNTY4NSBNOS4xMzg3NTI0NSwyLjQzMzYwODg3ZS0xMyBDMTQuMTc3OTk1NSwyLjQzMzYwODg3ZS0xMyAxOC4yNzY0NTM3LDQuMTAwMzI0NzEgMTguMjc2NDUzNyw5LjEzOTI3Nzk2IEMxOC4yNzY0NTM3LDExLjIyOTgyMTEgMTcuNTcxMDE2OSwxMy4xNTg0NDM0IDE2LjM4NTYzMTMsMTQuNjk5NjY5NiBMMjMuNjUwODg4MSwyMS45NjUyMjY2IEMyNC4xMTYzNzA2LDIyLjQzMDcwOTIgMjQuMTE2MzcwNiwyMy4xODU0MDU1IDIzLjY1MDg4ODEsMjMuNjUwODg4MSBDMjMuMTg1NDA1NSwyNC4xMTYzNzA2IDIyLjQzMDcwOTIsMjQuMTE2MzcwNiAyMS45NjUyMjY2LDIzLjY1MDg4ODEgTDE0LjY5OTgxMzMsMTYuMzg1NDcxMyBDMTMuMTU4NDQwNSwxNy41NzA5NTA5IDExLjIyOTU3MzgsMTguMjc2NDUzNyA5LjEzODc1MjQ1LDE4LjI3NjQ1MzcgQzQuMDk5NTA5MzgsMTguMjc2NDUzNyAtMy43MzAzNDkzNmUtMTQsMTQuMTc4MjMxMiAtMy43MzAzNDkzNmUtMTQsOS4xMzkyNzc5NiBDLTMuNzMwMzQ5MzZlLTE0LDQuMTAwMzI0NzEgNC4wOTk1MDkzOCwyLjQzMzYwODg3ZS0xMyA5LjEzODc1MjQ1LDIuNDMzNjA4ODdlLTEzIFoiIGlkPSJwYXRoLTEiPjwvcGF0aD4gICAgPC9kZWZzPiAgICA8ZyBpZD0iU2VhcmNoIiBzdHJva2U9Im5vbmUiIHN0cm9rZS13aWR0aD0iMSIgZmlsbD0ibm9uZSIgZmlsbC1ydWxlPSJldmVub2RkIj4gICAgICAgIDxtYXNrIGlkPSJtYXNrLTIiIGZpbGw9IndoaXRlIj4gICAgICAgICAgICA8dXNlIHhsaW5rOmhyZWY9IiNwYXRoLTEiPjwvdXNlPiAgICAgICAgPC9tYXNrPiAgICAgICAgPHVzZSBpZD0iSWNvbnMvQWN0aW9ucy9TZWFyY2giIGZpbGw9IiM0OTRBNTIiIHhsaW5rOmhyZWY9IiNwYXRoLTEiPjwvdXNlPiAgICA8L2c+PC9zdmc+);
    background-size: cover;
    height: 25px;
    width: 25px;
  }

  .header__search--toggle:after {
    content: "Search";
  }

  .header__close--toggle {
    background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz48c3ZnIHdpZHRoPSIyNHB4IiBoZWlnaHQ9IjE5cHgiIHZpZXdCb3g9IjAgMCAyNCAxOSIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIj4gICAgICAgIDx0aXRsZT5jbG9zZTwvdGl0bGU+ICAgIDxkZXNjPkNyZWF0ZWQgd2l0aCBTa2V0Y2guPC9kZXNjPiAgICA8ZyBpZD0iY2xvc2UiIHN0cm9rZT0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIxIiBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiPiAgICAgICAgPGcgaWQ9Ikdyb3VwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgyLjAwMDAwMCwgLTEuMDAwMDAwKSIgc3Ryb2tlPSIjNDk0QTUyIiBzdHJva2Utd2lkdGg9IjMiPiAgICAgICAgICAgIDxyZWN0IGlkPSJSZWN0YW5nbGUiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEwLjAwMDAwMCwgMTAuNTAwMDAwKSByb3RhdGUoLTQ1LjAwMDAwMCkgdHJhbnNsYXRlKC0xMC4wMDAwMDAsIC0xMC41MDAwMDApICIgeD0iLTAuNSIgeT0iMTAuNSIgd2lkdGg9IjIxIiBoZWlnaHQ9IjEiIHJ4PSIwLjUiPjwvcmVjdD4gICAgICAgICAgICA8cmVjdCBpZD0iUmVjdGFuZ2xlLUNvcHktNSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMTAuMDAwMDAwLCAxMC41MDAwMDApIHJvdGF0ZSg0NS4wMDAwMDApIHRyYW5zbGF0ZSgtMTAuMDAwMDAwLCAtMTAuNTAwMDAwKSAiIHg9Ii0wLjUiIHk9IjEwLjUiIHdpZHRoPSIyMSIgaGVpZ2h0PSIxIiByeD0iMC41Ij48L3JlY3Q+ICAgICAgICA8L2c+ICAgIDwvZz48L3N2Zz4=);
    background-repeat: no-repeat;
    background-size: 110%;
    display: none;
    height: 25px;
    margin-right: 0;
    width: 25px;
  }

  .header__close--toggle.show {
    display: block;
  }
}
/* Menu and simple menu */

.hs-menu-wrapper ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding-left: 0;
}

/* Horizontal menu */

.hs-menu-wrapper.hs-menu-flow-horizontal .hs-menu-children-wrapper {
  flex-direction: column;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.hs-menu-flow-horizontal ul {
    flex-direction: column;
  }
}

/* Vertical menu */

.hs-menu-wrapper.hs-menu-flow-vertical ul {
  flex-direction: column;
}

/* Flyouts */

.hs-menu-wrapper.hs-menu-flow-vertical.flyouts ul {
  display: inline-flex;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.hs-menu-flow-vertical ul {
    display: flex;
  }
}

.hs-menu-wrapper.flyouts .hs-item-has-children {
  position: relative;
}

.hs-menu-wrapper.flyouts .hs-menu-children-wrapper {
  left: -9999px;
  opacity: 0;
  position: absolute;
}

.hs-menu-wrapper.flyouts .hs-menu-children-wrapper a {
  display: block;
  white-space: nowrap;
}

.hs-menu-wrapper.hs-menu-flow-horizontal.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper {
  left: 0;
  opacity: 1;
  top: 100%;
}

.hs-menu-wrapper.hs-menu-flow-vertical.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper {
  left: 100%;
  opacity: 1;
  top: 0;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.flyouts .hs-menu-children-wrapper,
  .hs-menu-wrapper.hs-menu-flow-horizontal.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper,
  .hs-menu-wrapper.hs-menu-flow-vertical.flyouts .hs-item-has-children:hover > .hs-menu-children-wrapper {
    left: 0;
    opacity: 1;
    position: relative;
    top: auto;
  }
}

/* CTA, logo, and rich text images */

.hs_cos_wrapper_type_cta img,
.hs_cos_wrapper_type_logo img,
.hs_cos_wrapper_type_rich_text img {
  height: auto;
  max-width: 100%;
}

/* Utilities
Helper classes with ability to override anything that comes before it
*/
:root {
    --primary: #2B3F1C;
    --off-black: #1C1B19;
    
    --off-white: #FBFBFB;
    --beige: #F0EEEA;
    --gray: #4f4e4c;

    --dust: var(--beige);
    --text-dark: var(--off-black);
    --text-light: var(--off-white);
    --text-grey: var(--gray);
    --border--30: #1C1B194D;
}

/* Text Color */
.text-dark {
    color: var(--text-dark);
}
.text-light {
    color: var(--text-light);
}
.text-dust {
    color: var(--beige);
}
.text-green {
    color: var(--primary);
}
.text-gray {
  color: var(--text-grey);
}
/* Background Color */
.bg-off-white {
    background-color: var(--off-white);
}
.bg-dust {
    background-color: var(--dust);
}
.bg-gray {
    background-color: var(--gray);
}
.bg-green {
    background-color: var(--primary);
}
.display-none {
  display: none;
}
.display-block {
  display: block;
}
@media (max-width: 1023px){
  .m-display-none {
    display: none;
  }
  .m-display-block {
    display: block;
  }
}
.radius-4 {
  border-radius: 4px;
}
.radius-8 {
  border-radius: 8px;
}
.radius-12 {
  border-radius: 12px;
}
.radius-16 {
  border-radius: 16px;
}
.radius-20 {
  border-radius: 20px;
}
.radius-24 {
  border-radius: 24px;
}
@media (max-width: 1023px){
  .m-radius-4 {
    border-radius: 4px;
  }
  .m-radius-8 {
    border-radius: 8px;
  }
  .m-radius-12 {
    border-radius: 12px;
  }
  .m-radius-16 {
    border-radius: 16px;
  }
  .m-radius-20 {
    border-radius: 20px;
  }
  .m-radius-24 {
    border-radius: 24px;
  }
}

@media (max-width: 1023px){
  .m-radius-4 {
    border-radius: 4px;
  }
  .m-radius-8 {
    border-radius: 8px;
  }
  .m-radius-12 {
    border-radius: 12px;
  }
  .m-radius-16 {
    border-radius: 16px;
  }
  .m-radius-20 {
    border-radius: 20px;
  } 
}

.overflow-hidden {
  overflow: hidden;
}


/* HUBSPOT CTA'S */
/* .hs-cta-embed__loaded {
  width: 100%!important;
  height: 75vw!important;
  max-width: 784px!important;
  min-height: 729px;
  
} */
/* For content that needs to be visually hidden but stay visible for screenreaders */

.show-for-sr {
  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;
}

@media (max-width: 767px) {
  .show-for-sr--mobile {
    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;
  }
}

/**
* CATEGORY PILL
*/

.category-pill {
  border: 1px solid var(--off-white);
  color: var(--off-white);
  background: rgba(0, 0,0, 0.35);
  box-shadow: 0 0 8px 0 rgba(255, 255, 255, 0.20) inset, 0 2px 8px 0 rgba(0, 0, 0, 0.10);
  backdrop-filter: blur(12.5px);
  padding: 6px 10px;
  text-align: center;
  border-radius: 100px;
  font-size: 14px;
}

/**
* AOS 
*/
[data-aos="cta-footer"] {
  transform: scale(1)
}
[data-aos="cta-footer"].aos-animate {
  transform: scale(1.1)
}

/*
* HELPERS 
*/

.cursor-pointer {
  cursor: pointer;
}