@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-LightItalic.ttf') format("truetype");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-Medium.ttf') format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-BlackItalic.ttf') format("truetype");
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-ExtraBoldItalic.ttf') format("truetype"), url('../fonts/OpenSauceTwo-BoldItalic.ttf') format("truetype");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-Italic.ttf') format("truetype");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-Bold.ttf') format("truetype"), url('../fonts/OpenSauceTwo-ExtraBold.ttf') format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-MediumItalic.ttf') format("truetype");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-Regular.ttf') format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-Black.ttf') format("truetype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-SemiBold.ttf') format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-Light.ttf') format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Opensaucetwo;
  src: url('../fonts/OpenSauceTwo-SemiBoldItalic.ttf') format("truetype");
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

:root {
  --text-color--text-primary: var(--brand-color--heading);
  --brand-color--body: #252a37;
  --link-color--link-primary: var(--brand-color--primary-blue);
  --neutral--primary-blue-50: #4957a180;
  --border-color--border-alternate: var(--neutral--lavender-mist);
  --background-color--bg-primary: var(--brand-color--primary-blue);
  --text-color--text-alternate: var(--neutral--white);
  --text-color--text-secondary: var(--brand-color--body);
  --border-color--border-primary: var(--neutral--victoria);
  --background-color--bg-alternate: var(--neutral--white);
  --background-color--bg-secondary: var(--brand-color--secondary-yellow);
  --link-color--link-secondary: var(--brand-color--heading);
  --background-color--background-error\<deleted\|variable-89aecd3e-2fe8-312c-65a2-e3e7c57d326c\>: var(--base-color-system--error-red\<deleted\|variable-ad7a5e8d-bd95-fba4-5110-cbccfa2520c4\>);
  --text-color--text-error\<deleted\|variable-4a51c5d2-820c-a0d9-b49e-0e5d273c964f\>: var(--base-color-system--error-red-dark\<deleted\|variable-f7a8b234-8033-a5d6-4d85-0326277c2bf8\>);
  --border-color--border-secondary: var(--brand-color--secondary-yellow);
  --brand-color--secondary-yellow: #ffbc00;
  --brand-color--heading: #0f172a;
  --neutral--white: #fff;
  --neutral--transparent: #0000;
  --brand-color--primary-blue: #4957a1;
  --background-color--background-warning\<deleted\|variable-0aa1a7ce-e851-b6b5-66db-1a1a96e8e04b\>: var(--base-color-system--warning-yellow\<deleted\|variable-b0ee00e7-091a-a3f5-1619-b09d07f4475a\>);
  --text-color--text-warning\<deleted\|variable-825aa1d8-b093-0b89-37c5-87d980df10f5\>: var(--base-color-system--warning-yellow-dark\<deleted\|variable-296491a7-483e-1229-36b5-e13808cc9004\>);
  --background-color--bg-tertiary: var(--neutral--ebbony-clay);
  --neutral--alabaster-50: #f8fafc80;
  --neutral--lavender-mist-10: #e2e8f01a;
  --neutral--lavender-mist-5: #e2e8f00d;
  --neutral--lavender-mist: #e2e8f0;
  --neutral--green: #0ab983;
  --neutral--aqua-spring: #effaf3;
  --text-color--text-light-grey: var(--neutral--light-grey);
  --text-color--text-river-bed: var(--neutral--river-bed);
  --text-color--text-storm-grey: var(--neutral--storm-grey);
  --neutral--alabaster: #f8fafc;
  --text-color--text-primary-blue: var(--brand-color--primary-blue);
  --neutral--light-grey: #d9d9d9;
  --neutral--red: #eb0e0e;
  --neutral--river-bed: #485466;
  --text-color--text-lavender-mist: var(--neutral--lavender-mist);
  --border-color--border-white: var(--neutral--white);
  --neutral--white-5: #ffffff0d;
  --link-color--link-alternate: var(--neutral--white);
  --neutral--black: #000;
  --neutral--victoria: #4b55a1;
  --neutral--ebbony-clay: #1b2542;
  --netural--red: #f87171;
  --neutral--lavender-mist-20: #e2e8f033;
  --neutral--storm-grey: #64748b;
  --neutral--water: #eff1fb;
  --neutral--light-grey-20: #d9d9d933;
  --neutral--cadet-grey: #93a1b5;
  --border-color--border-green: var(--neutral--green);
  --border-color--border-primary-blue-50: var(--neutral--primary-blue-50);
  --border-color--border-storm-grey: var(--neutral--storm-grey);
  --border-color--border-light-grey: var(--neutral--light-grey);
  --text-color--text-cadet-grey: var(--neutral--cadet-grey);
  --base-color-system--error-red\<deleted\|variable-ad7a5e8d-bd95-fba4-5110-cbccfa2520c4\>: #f8e4e4;
  --base-color-system--error-red-dark\<deleted\|variable-f7a8b234-8033-a5d6-4d85-0326277c2bf8\>: #3b0b0b;
  --base-color-system--warning-yellow\<deleted\|variable-b0ee00e7-091a-a3f5-1619-b09d07f4475a\>: #fcf8d8;
  --base-color-system--warning-yellow-dark\<deleted\|variable-296491a7-483e-1229-36b5-e13808cc9004\>: #5e5515;
}

.w-checkbox {
  margin-bottom: 5px;
  padding-left: 20px;
  display: block;
}

.w-checkbox:before {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox:after {
  content: " ";
  clear: both;
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox-input {
  float: left;
  margin: 4px 0 0 -20px;
  line-height: normal;
}

.w-checkbox-input--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 2px;
  width: 12px;
  height: 12px;
}

.w-checkbox-input--inputType-custom.w--redirected-checked {
  background-color: #3898ec;
  background-image: url('https://d3e54v103j8qbb.cloudfront.net/static/custom-checkbox-checkmark.589d534424.svg');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  border-color: #3898ec;
}

.w-checkbox-input--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-form-formradioinput--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 50%;
  width: 12px;
  height: 12px;
}

.w-form-formradioinput--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-form-formradioinput--inputType-custom.w--redirected-checked {
  border-width: 4px;
  border-color: #3898ec;
}

body {
  color: var(--text-color--text-primary);
  font-family: Opensaucetwo, Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
}

h1 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3.25rem;
  font-weight: 700;
  line-height: 1.15;
}

h2 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.2;
}

h3 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.2;
}

h4 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.75rem;
  font-weight: 600;
  line-height: 1.4;
}

h5 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.5;
}

h6 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}

p {
  color: var(--brand-color--body);
  margin-bottom: 0;
  line-height: 1.6;
}

a {
  color: var(--link-color--link-primary);
}

ul, ol {
  margin-top: 0;
  margin-bottom: 0;
  padding-left: 1.5rem;
}

li {
  margin-bottom: .25rem;
}

img {
  max-width: 100%;
  display: inline-block;
}

label {
  margin-bottom: .25rem;
  font-weight: 500;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

blockquote {
  border-left: .25rem solid #e2e2e2;
  margin-bottom: 0;
  padding: 0 1.25rem;
  font-size: 1.25rem;
  line-height: 1.5;
}

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

figcaption {
  text-align: center;
  margin-top: .25rem;
}

.utility-page_component {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  display: flex;
}

.utility-page_wrapper {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  text-align: center;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  max-width: 20rem;
  display: flex;
}

.utility-page_form {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  display: flex;
}

.utility-page_image {
  margin-left: auto;
  margin-right: auto;
}

.global-styles {
  display: block;
  position: fixed;
  inset: 0% auto auto 0%;
}

.margin-custom2 {
  margin: 2.5rem;
}

.padding-xlarge {
  padding: 4rem;
}

.margin-xlarge {
  margin: 4rem;
}

.margin-xsmall {
  margin: .5rem;
}

.padding-xhuge {
  padding: 8rem;
}

.margin-custom1 {
  margin: 1.5rem;
}

.padding-0 {
  padding: 0;
}

.padding-xxhuge {
  padding: 12rem;
}

.padding-huge {
  padding: 6rem;
}

.margin-large {
  margin: 3rem;
}

.padding-xxlarge {
  padding: 5rem;
}

.margin-xxsmall {
  margin: .25rem;
}

.padding-custom3 {
  padding: 3.5rem;
}

.padding-large {
  padding: 3rem;
}

.margin-tiny {
  margin: .125rem;
}

.padding-small {
  padding: 1rem;
}

.padding-custom2 {
  padding: 2.5rem;
}

.margin-custom3 {
  margin: 3.5rem;
}

.padding-custom1 {
  padding: 1.5rem;
}

.margin-huge {
  margin: 6rem;
}

.padding-medium {
  padding: 2rem;
}

.padding-xsmall {
  padding: .5rem;
}

.margin-xxlarge {
  margin: 5rem;
}

.padding-xxsmall {
  padding: .25rem;
}

.margin-xhuge {
  margin: 8rem;
}

.padding-tiny {
  padding: .125rem;
}

.margin-small {
  margin: 1rem;
}

.margin-medium {
  margin: 2rem;
}

.margin-xxhuge {
  margin: 12rem;
}

.margin-0 {
  margin: 0;
}

.margin-horizontal {
  margin-top: 0;
  margin-bottom: 0;
}

.padding-top {
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
}

.margin-vertical {
  margin-left: 0;
  margin-right: 0;
}

.margin-bottom {
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
}

.padding-left {
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
}

.padding-vertical {
  padding-left: 0;
  padding-right: 0;
}

.padding-horizontal {
  padding-top: 0;
  padding-bottom: 0;
}

.margin-right {
  margin-top: 0;
  margin-bottom: 0;
  margin-left: 0;
}

.margin-top {
  margin-bottom: 0;
  margin-left: 0;
  margin-right: 0;
}

.margin-left {
  margin-top: 0;
  margin-bottom: 0;
  margin-right: 0;
}

.padding-right {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
}

.padding-bottom {
  padding-top: 0;
  padding-left: 0;
  padding-right: 0;
}

.form_checkbox {
  flex-direction: row;
  align-items: center;
  margin-bottom: .5rem;
  padding-left: 0;
  display: flex;
}

.form_checkbox-icon {
  border-radius: .125rem;
  width: .875rem;
  height: .875rem;
  margin: 0 .5rem 0 0;
}

.form_checkbox-icon.w--redirected-checked {
  background-size: 90%;
  border-radius: .125rem;
  width: .875rem;
  height: .875rem;
  margin: 0 .5rem 0 0;
}

.form_checkbox-icon.w--redirected-focus {
  border-radius: .125rem;
  width: .875rem;
  height: .875rem;
  margin: 0 .5rem 0 0;
  box-shadow: 0 0 .25rem 0 #3898ec;
}

.fs-styleguide_background {
  border: 1px solid #0000001a;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  display: flex;
}

.fs-styleguide_spacing {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  background-image: linear-gradient(0deg, var(--neutral--primary-blue-50), #fff0);
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-content: start;
  place-items: start stretch;
  display: grid;
  position: relative;
}

.icon-1x1-small {
  flex-flow: row;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 1rem;
  height: 1rem;
  display: flex;
}

.overflow-auto {
  overflow: auto;
}

.spacing-clean {
  margin: 0;
  padding: 0;
}

.icon-1x1-large {
  justify-content: center;
  align-items: center;
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
}

.form-form {
  grid-column-gap: 1.25rem;
  grid-row-gap: 1.25rem;
  flex-flow: column;
  display: flex;
}

.z-index-2 {
  z-index: 2;
  position: relative;
}

.fs-styleguide_background-space {
  width: 1px;
  height: 1px;
  margin: 5rem;
}

.text-weight-semibold {
  font-weight: 600;
}

.text-style-strikethrough {
  text-decoration: line-through;
}

.fs-styleguide_item {
  grid-column-gap: 1.125rem;
  grid-row-gap: 1.125rem;
  border-bottom: 1px solid #0000001a;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-content: start;
  place-items: start;
  padding-bottom: 3rem;
  display: grid;
  position: relative;
}

.fs-styleguide_item.is-stretch {
  justify-items: stretch;
}

.max-width-full {
  width: 100%;
  max-width: none;
}

.fs-styleguide_item-header {
  border-bottom: 1px solid var(--border-color--border-alternate);
  width: 100%;
  padding-bottom: 2rem;
}

.background-color-primary {
  background-color: var(--background-color--bg-primary);
  color: var(--text-color--text-alternate);
}

.z-index-1 {
  z-index: 1;
  position: relative;
}

.text-color-primary {
  color: var(--text-color--text-primary);
}

.text-color-secondary {
  color: var(--text-color--text-secondary);
}

.fs-styleguide_2-col {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.fs-styleguide_2-col.is-align-start {
  align-items: start;
}

.fs-styleguide_row {
  grid-column-gap: .75rem;
  grid-row-gap: .75rem;
  flex-direction: row;
  grid-template-rows: auto;
  grid-template-columns: auto;
  grid-auto-columns: auto;
  grid-auto-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.heading-style-h3 {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.2;
}

.text-rich-text h1, .text-rich-text h2, .text-rich-text h3, .text-rich-text h4 {
  margin-top: 1.5rem;
  margin-bottom: 1rem;
}

.text-rich-text h5, .text-rich-text h6 {
  margin-top: 1.25rem;
  margin-bottom: 1rem;
}

.text-rich-text p {
  margin-bottom: 1rem;
}

.text-rich-text ul, .text-rich-text ol {
  margin-bottom: 1.5rem;
}

.text-rich-text blockquote {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

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

.container-small {
  width: 100%;
  max-width: 48rem;
  margin-left: auto;
  margin-right: auto;
}

.icon-height-small {
  height: 1rem;
}

.icon-1x1-medium {
  justify-content: center;
  align-items: center;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
}

.heading-style-h1 {
  font-size: 3.25rem;
  font-weight: 700;
  line-height: 1.15;
}

.padding-global {
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}

.text-weight-normal {
  font-weight: 400;
}

.padding-section-small {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.padding-section-small.is-home-hero {
  padding-top: 5rem;
}

.padding-section-small.is-footer {
  padding-bottom: 1.5rem;
}

.padding-section-small.is-proj-hero {
  padding-bottom: 5rem;
}

.padding-section-small.is-branch-hero {
  padding-top: 5rem;
}

.max-width-small {
  width: 100%;
  max-width: 20rem;
}

.text-color-alternate {
  color: var(--text-color--text-alternate);
}

.text-style-italic {
  font-style: italic;
}

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

.text-weight-medium {
  font-weight: 500;
}

.overflow-hidden {
  overflow: hidden;
}

.fs-styleguide_section-header {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  border-bottom: 1px solid var(--border-color--border-alternate);
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  padding-bottom: 3rem;
  line-height: 1.4;
  display: grid;
}

.text-size-tiny {
  font-size: .75rem;
}

.max-width-xxlarge {
  width: 100%;
  max-width: 80rem;
}

.fs-styleguide_1-col {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.overflow-visible {
  overflow: visible;
}

.fs-styleguide_empty-box {
  z-index: -1;
  border-style: dashed;
  border-width: 1px;
  border-color: #2d40ea #2d40ea var(--border-color--border-primary);
  background-color: var(--neutral--primary-blue-50);
  min-width: 3rem;
  height: 3rem;
  position: relative;
}

.text-weight-light {
  font-weight: 300;
}

.fs-styleguide_heading-medium {
  font-size: 4rem;
}

.max-width-xsmall {
  width: 100%;
  max-width: 16rem;
}

.fs-styleguide_4-col {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.text-size-regular {
  font-size: 1rem;
}

.text-weight-xbold {
  font-weight: 800;
}

.text-align-right {
  text-align: right;
}

.text-weight-bold {
  font-weight: 700;
}

.max-width-medium {
  width: 100%;
  max-width: 32rem;
}

.fs-styleguide_item-wrapper {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.max-width-large {
  width: 100%;
  max-width: 48rem;
}

.fs-styleguide_header-block {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-items: center start;
  display: grid;
}

.background-color-alternate {
  background-color: var(--background-color--bg-alternate);
}

.text-style-muted {
  opacity: .6;
}

.text-size-small {
  font-size: .875rem;
}

.text-size-small.text-color-river-bed {
  margin-top: -.06rem;
}

.heading-style-h4 {
  font-size: 1.75rem;
  font-weight: 600;
  line-height: 1.4;
}

.max-width-xlarge {
  width: 100%;
  max-width: 64rem;
}

.form_radio-icon {
  width: .875rem;
  height: .875rem;
  margin-top: 0;
  margin-left: 0;
  margin-right: .5rem;
}

.form_radio-icon.w--redirected-checked {
  border-width: .25rem;
  width: .875rem;
  height: .875rem;
}

.form_radio-icon.w--redirected-focus {
  width: .875rem;
  height: .875rem;
  box-shadow: 0 0 .25rem 0 #3898ec;
}

.text-style-nowrap {
  white-space: nowrap;
}

.text-align-left {
  text-align: left;
}

.background-color-secondary {
  background-color: var(--background-color--bg-secondary);
}

.form_input {
  border: 1px solid var(--border-color--border-alternate);
  background-color: #0000;
  min-height: 3rem;
  margin-bottom: .75rem;
  padding: .5rem 1rem;
  font-size: 1rem;
}

.form_input::placeholder {
  color: var(--text-color--text-secondary);
}

.heading-style-h6 {
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}

.heading-style-h6.is-large {
  font-size: 1.3rem;
}

.padding-section-large {
  padding-top: 7.5rem;
  padding-bottom: 7.5rem;
}

.padding-section-large.is-proj-detail {
  padding-top: 5rem;
}

.fs-styleguide_3-col {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: stretch;
  width: 100%;
  display: grid;
}

.fs-styleguide_3-col.is-align-start {
  align-items: start;
}

.text-style-link {
  color: var(--link-color--link-secondary);
  text-decoration: underline;
}

.text-size-large {
  font-size: 1.25rem;
}

.fs-styleguide_header {
  background-color: var(--background-color--bg-primary);
  color: var(--text-color--text-alternate);
  background-image: radial-gradient(circle at 100% 100%, #dd23bb40, #0000 40%), radial-gradient(circle at 0 100%, #2d62ff4d, #0000 60%);
}

.heading-style-h2 {
  font-size: 2.5rem;
  font-weight: 600;
  line-height: 1.2;
}

.fs-styleguide_label {
  background-color: var(--background-color--bg-primary);
  color: var(--text-color--text-alternate);
  border-radius: .25rem;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  padding: .25rem .75rem .3rem;
  font-weight: 600;
  display: flex;
}

.fs-styleguide_label.is-tag {
  background-color: var(--background-color--bg-secondary);
}

.heading-style-h5 {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.3;
}

.container-large {
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
}

.container-large.is-large {
  max-width: 90rem;
}

.icon-height-medium {
  height: 2rem;
}

.text-style-allcaps {
  text-transform: uppercase;
}

.overflow-scroll {
  overflow: scroll;
}

.form_message-error {
  background-color: var(--background-color--background-error\<deleted\|variable-89aecd3e-2fe8-312c-65a2-e3e7c57d326c\>);
  color: var(--text-color--text-error\<deleted\|variable-4a51c5d2-820c-a0d9-b49e-0e5d273c964f\>);
  margin-top: .75rem;
  padding: .75rem;
}

.icon-height-large {
  height: 3rem;
}

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

.form-component {
  margin-bottom: 0;
}

.max-width-xxsmall {
  width: 100%;
  max-width: 12rem;
}

.layer {
  justify-content: center;
  align-items: center;
  position: absolute;
  inset: 0%;
}

.text-style-quote {
  border-left: .25rem solid #e2e2e2;
  margin-bottom: 0;
  padding: 0 1.25rem;
  font-size: 1.25rem;
  line-height: 1.5;
}

.align-center {
  margin-left: auto;
  margin-right: auto;
}

.button {
  border: 1px solid var(--border-color--border-secondary);
  background-color: var(--brand-color--secondary-yellow);
  color: var(--brand-color--heading);
  text-align: center;
  border-radius: .5rem;
  padding: .75rem 1.5rem;
  font-weight: 600;
  line-height: 1.5;
  text-decoration: none;
  transition: all .3s;
}

.button:hover {
  background-color: var(--neutral--white);
}

.button.is-text {
  color: var(--link-color--link-primary);
  background-color: #0000;
  border: 2px solid #0000;
}

.button.is-small {
  padding: .5rem 1.25rem;
}

.button.is-large {
  padding: 1rem 2rem;
}

.button.is-secondary {
  border: 1px solid var(--border-color--border-primary);
  background-color: var(--neutral--transparent);
  color: var(--link-color--link-primary);
}

.button.is-secondary:hover {
  background-color: var(--brand-color--primary-blue);
  color: var(--background-color--bg-alternate);
}

.button.is-icon {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  border: 1px solid var(--border-color--border-secondary);
  flex-direction: row;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  display: flex;
}

.button.is-icon:hover {
  background-color: #ff9500;
  border-color: #ff9500;
}

.fs-styleguide_classes {
  grid-column-gap: 1px;
  grid-row-gap: 1px;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.text-size-medium {
  font-size: 1.13rem;
}

.fs-styleguide_section {
  grid-column-gap: 6rem;
  grid-row-gap: 6rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-items: start;
  display: grid;
}

.fs-styleguide_section.is-vertical {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-columns: 1fr;
}

.button-group {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: wrap;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.hide {
  display: none;
}

.padding-section-medium {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.container-medium {
  width: 100%;
  max-width: 64rem;
  margin-left: auto;
  margin-right: auto;
}

.form_radio {
  flex-direction: row;
  align-items: center;
  margin-bottom: .5rem;
  padding-left: 0;
  display: flex;
}

.fs-styleguide_spacing-all {
  display: none;
}

.spacer-huge {
  width: 100%;
  padding-top: 6rem;
}

.spacer-medium {
  width: 100%;
  padding-top: 2rem;
}

.fs-styleguide_spacer-box {
  background-color: #2d40ea1a;
  border: 1px dashed #2d40ea;
  width: 100%;
  position: relative;
}

.spacer-xsmall {
  width: 100%;
  padding-top: .5rem;
}

.spacer-small {
  width: 100%;
  padding-top: 1rem;
}

.spacer-xhuge {
  width: 100%;
  padding-top: 8rem;
}

.spacer-tiny {
  width: 100%;
  padding-top: .125rem;
}

.spacer-xxsmall {
  width: 100%;
  padding-top: .25rem;
}

.spacer-xxhuge {
  width: 100%;
  padding-top: 12rem;
}

.spacer-xlarge {
  width: 100%;
  padding-top: 4rem;
}

.spacer-large {
  padding-top: 3rem;
}

.spacer-xxlarge {
  width: 100%;
  padding-top: 5rem;
}

.fs-styleguide_message {
  background-color: var(--background-color--background-warning\<deleted\|variable-0aa1a7ce-e851-b6b5-66db-1a1a96e8e04b\>);
  color: var(--text-color--text-warning\<deleted\|variable-825aa1d8-b093-0b89-37c5-87d980df10f5\>);
  border-radius: .25rem;
  padding: .25rem .5rem;
  font-size: .875rem;
}

.aspect-ratio-square {
  aspect-ratio: 1;
  object-fit: cover;
}

.aspect-ratio-portrait {
  aspect-ratio: 2 / 3;
  object-fit: cover;
}

.aspect-ratio-landscape {
  aspect-ratio: 3 / 2;
  object-fit: cover;
}

.aspect-ratio-widescreen {
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.background-color-tertiary {
  background-color: var(--background-color--bg-tertiary);
}

.fs-styleguide_hero-label {
  color: var(--text-color--text-primary);
  text-transform: uppercase;
  background-color: #eee;
  border-radius: .25rem;
  padding: .25rem .375rem;
  font-size: .75rem;
  font-weight: 500;
  text-decoration: none;
}

.fs-styleguide_heading-header {
  font-size: 6rem;
}

.navabar {
  z-index: 1000;
  border-bottom: 1px solid var(--border-color--border-alternate);
  background-color: var(--neutral--white);
  position: sticky;
  top: 0;
}

.nav-content-flex {
  justify-content: space-between;
  align-items: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
  display: flex;
}

.nav-logo {
  width: 100%;
  max-width: 14rem;
}

.section-header {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
}

.section-tag {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  border: 1px solid var(--border-color--border-alternate);
  background-color: var(--neutral--alabaster-50);
  text-align: center;
  border-radius: 10rem;
  justify-content: center;
  align-items: center;
  padding: .25rem .75rem;
  display: flex;
}

.section-tag.for-dark {
  border-color: var(--neutral--lavender-mist-10);
  background-color: var(--neutral--lavender-mist-5);
  color: var(--neutral--lavender-mist);
}

.section-tag-circle {
  background-color: var(--brand-color--secondary-yellow);
  border-radius: 1rem;
  width: .5rem;
  height: .5rem;
}

.section-heading {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  text-align: center;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-heading.is-home-hero {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  text-align: left;
  justify-content: flex-start;
  align-items: flex-start;
}

.section-heading.is-contact {
  text-align: left;
  justify-content: flex-start;
  align-items: flex-start;
}

.section-heading.is-proj-hero {
  max-width: 58rem;
}

.section-heading.is-recent-proj {
  max-width: 45rem;
}

.section-heading.is-info {
  text-align: left;
  justify-content: flex-start;
  align-items: flex-start;
}

.section-heading.is-branch-hero {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  text-align: left;
  justify-content: flex-start;
  align-items: flex-start;
}

.section-tag-large {
  grid-column-gap: .625rem;
  grid-row-gap: .625rem;
  border: 1px solid var(--neutral--green);
  background-color: var(--neutral--aqua-spring);
  color: var(--brand-color--body);
  text-align: center;
  border-radius: 3rem;
  justify-content: center;
  align-items: center;
  padding: .7rem 1.3rem;
  display: flex;
}

.section-tag-large.is-left-aligned {
  text-align: left;
}

.section-tag-large.is-left-aligned.is-empty {
  border-color: var(--neutral--transparent);
  background-color: var(--neutral--transparent);
  padding: 0;
}

.button-link {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  color: var(--brand-color--secondary-yellow);
  justify-content: flex-start;
  align-items: center;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s;
  display: flex;
}

.button-link:hover {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
}

.button-link.is-blue {
  color: var(--brand-color--primary-blue);
  flex: none;
  margin-top: auto;
}

.section-button {
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  display: flex;
}

.testimonials-item-author {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.testimonials-item-author-avatar {
  border-radius: 100%;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 3rem;
  height: 3rem;
  display: flex;
  overflow: hidden;
}

.testimonials-item-author-name {
  grid-row-gap: 0px;
  flex-flow: column;
  display: flex;
}

.section_footer {
  border-top: 1px solid var(--border-color--border-alternate);
  background-color: var(--background-color--bg-tertiary);
}

.footer-top {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  flex-flow: column;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  display: grid;
}

.footer-link {
  color: var(--neutral--lavender-mist);
  text-decoration: none;
  transition: all .3s;
}

.footer-link:hover {
  color: var(--brand-color--secondary-yellow);
}

.footer-left {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.footer-logo-link {
  width: 100%;
  max-width: 14rem;
}

.footer-address {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  max-width: 21rem;
  display: flex;
}

.footer-bottom {
  text-align: center;
  border-top: 1px solid #ffffff1a;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding-top: 1.5rem;
  display: flex;
}

.section_home-hero {
  background-image: url('../images/Home-Hero-BG.svg');
  background-position: 50%;
  background-size: cover;
}

.home-hero-content-grid {
  grid-column-gap: 7.5rem;
  grid-row-gap: 7.5rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.home-hero-content {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
  position: relative;
}

.home-challenges_dropdown {
  display: block;
}

.software-faqs_tab-link {
  border-bottom: 1px solid var(--neutral--lavender-mist);
  background-color: #ddd0;
  padding: 1rem 0;
}

.software-faqs_tab-link.w--current {
  background-color: #ddd0;
}

.text-color-light-grey {
  color: var(--text-color--text-light-grey);
}

.text-color-river-bed {
  color: var(--text-color--text-river-bed);
}

.text-color-storm-grey {
  color: var(--text-color--text-storm-grey);
}

.icon-box-1x1-small {
  border: 1px solid var(--border-color--border-alternate);
  border-radius: .3rem;
  flex-flow: column;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
}

.icon-box-1x1-medium {
  border: 1px solid var(--border-color--border-alternate);
  background-color: var(--neutral--alabaster);
  width: 2.5rem;
  height: 2.5rem;
  color: var(--brand-color--primary-blue);
  border-radius: .5rem;
  flex-flow: column;
  flex: none;
  justify-content: center;
  align-items: center;
  display: flex;
}

.icon-box-1x1-large {
  border: 1px solid var(--border-color--border-alternate);
  background-color: var(--neutral--alabaster);
  width: 3rem;
  height: 3rem;
  color: var(--brand-color--primary-blue);
  border-radius: .5rem;
  flex-flow: column;
  flex: none;
  justify-content: center;
  align-items: center;
  display: flex;
}

.section-content-wrapper {
  width: 100%;
}

.section-content-wrapper.is-home-hero {
  grid-column-gap: 7rem;
  grid-row-gap: 7rem;
  flex-flow: column;
  display: flex;
}

.section-content-wrapper.is-testimonials {
  grid-column-gap: 3.75rem;
  grid-row-gap: 3.75rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-content-wrapper.is-footer {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-content-wrapper.is-contact {
  grid-column-gap: 3.75rem;
  grid-row-gap: 3.75rem;
  color: var(--text-color--text-alternate);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-content-wrapper.is-proj-hero {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-content-wrapper.is-proj-detail {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-content-wrapper.is-info {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-content-wrapper.is-recent-proj {
  grid-column-gap: 3.75rem;
  grid-row-gap: 3.75rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.section-content-wrapper.is-recent-proj.is-teritairy {
  color: var(--text-color--text-alternate);
}

.section-content-wrapper.is-branch-hero {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  flex-flow: column;
  display: flex;
}

.image {
  width: 100%;
}

.image.is-full {
  object-fit: cover;
  height: 100%;
}

.text-color-primary-blue {
  color: var(--text-color--text-primary-blue);
}

.nav-right-wrapper {
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.nav-button-wrapper {
  flex-flow: column;
  display: flex;
}

.footer-top-inner {
  justify-content: space-between;
  width: 100%;
  display: flex;
}

.section-tag-large-icon-wrapper {
  color: var(--neutral--green);
}

.cases-list {
  grid-column-gap: 2.5rem;
  grid-row-gap: 2.5rem;
  flex-flow: column;
  grid-template-rows: 1fr;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.cases-list.is-grid {
  grid-template-columns: 1fr 1fr 1fr;
}

.cases-list-item {
  border: 1px solid var(--border-color--border-alternate);
  background-color: var(--neutral--white);
  width: 100%;
  height: 100%;
  color: var(--brand-color--body);
  border-radius: .5rem;
  flex-flow: column;
  grid-template-rows: auto;
  grid-template-columns: 1fr .75fr;
  grid-auto-columns: 1fr;
  text-decoration: none;
  transition: box-shadow .25s;
  display: grid;
  position: relative;
  overflow: hidden;
  box-shadow: 2px 6px 20px #1111110a;
}

.cases-list-item.is-flex-vertical {
  padding: .3125rem;
  display: flex;
}

.cases-list-item-content {
  grid-column-gap: 2.38rem;
  grid-row-gap: 2.38rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding: 2.5rem;
  display: flex;
}

.cases-list-item-content.for-vertical-item {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex: 1;
  padding: 1.5rem;
}

.cases-list-item-image {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.cases-list-item-image.for-vertical-item {
  border-top-left-radius: .5rem;
  border-top-right-radius: .5rem;
  height: 17.5rem;
  position: relative;
}

.cases-list-item-heading {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  display: flex;
}

.cases-list-item-button-wrapper {
  justify-content: flex-start;
  align-items: flex-start;
  margin-top: auto;
  display: flex;
  overflow: hidden;
}

.section_contact {
  background-color: var(--background-color--bg-tertiary);
}

.contact-content-grid {
  grid-column-gap: 6rem;
  grid-row-gap: 6rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr .9fr;
  grid-auto-columns: 1fr;
  align-items: start;
  width: 100%;
  display: grid;
}

.contact-content-grid.is-less-gaped {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  grid-template-columns: .8fr 1fr;
}

.contact-content {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.contact-content-separator {
  background-color: var(--border-color--border-alternate);
  width: 100%;
  height: 1px;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.contact-form-box {
  width: 100%;
}

.contact-form-block {
  margin-bottom: 0;
}

.contact-form {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.contact-form-fields {
  grid-column-gap: 1.25rem;
  grid-row-gap: 1.25rem;
  flex-flow: column;
  width: 100%;
  display: flex;
}

.form-field-flex {
  grid-column-gap: .31rem;
  grid-row-gap: .31rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.form-input {
  border: 1px solid var(--neutral--light-grey);
  background-color: var(--neutral--alabaster);
  width: 100%;
  height: auto;
  color: var(--brand-color--body);
  border-radius: .5rem;
  margin-bottom: 0;
  padding: 1rem;
  font-size: 1rem;
}

.form-input:focus {
  border-color: var(--brand-color--primary-blue);
}

.form-input::placeholder {
  color: #252a3799;
}

.form-input.is-area {
  min-height: 8.75rem;
}

.span-text-red {
  color: var(--neutral--red);
}

.contact-form-fields-grid {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.contact-form-privacy-text {
  width: 100%;
  max-width: 32.94rem;
  color: var(--neutral--river-bed);
}

.form-success {
  background-color: var(--neutral--aqua-spring);
  color: var(--neutral--green);
  border-radius: .5rem;
  padding: 1.25rem;
}

.form-error {
  background-color: var(--neutral--transparent);
  color: var(--neutral--red);
  margin-top: .75rem;
  padding: 0;
}

.proj-hero-image {
  border: .31rem solid var(--neutral--white);
  border-radius: .5rem;
  width: 100%;
  height: 35rem;
  overflow: hidden;
  box-shadow: 2px 6px 20px #1111110a;
}

.section_proj-hero {
  background-image: url('../images/Project-Hero-Bg.svg');
  background-position: 50%;
  background-size: cover;
}

.proj-detail-grid {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr .45fr;
  grid-auto-columns: 1fr;
  align-items: start;
  width: 100%;
  display: grid;
  position: relative;
}

.proj-detail-info-box {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  border: 1px solid var(--border-color--border-alternate);
  border-radius: .5rem;
  flex-flow: column;
  padding: 1.5rem;
  display: flex;
  position: sticky;
  top: 6rem;
  box-shadow: 2px 6px 20px #1111110a;
}

.proj-detail-info-box-top {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  width: 100%;
  display: flex;
}

.proj-detail-info-box-item {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.proj-detail-content {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-flow: column;
  width: 100%;
  display: flex;
}

.section_recent-proj {
  background-image: url('../images/Saas-BG-.svg');
  background-position: 50%;
  background-size: cover;
}

.section_recent-proj.is-teritairy {
  background-color: var(--background-color--bg-tertiary);
  background-image: none;
}

.proj-detail-content-richtext {
  width: 100%;
}

.proj-detail-content-richtext h1 {
  margin-bottom: 1rem;
  font-size: 2.2rem;
  font-weight: 600;
}

.proj-detail-content-richtext h2 {
  margin-bottom: .38rem;
  font-size: 1.7rem;
}

.proj-detail-content-richtext h3 {
  margin-bottom: .38rem;
  font-size: 1.5rem;
}

.proj-detail-content-richtext h4 {
  margin-bottom: 1rem;
  font-size: 1.3rem;
}

.proj-detail-content-richtext h5 {
  margin-bottom: 1rem;
  font-size: 1.19rem;
}

.proj-detail-content-richtext h6 {
  margin-bottom: 1rem;
  font-size: 1rem;
}

.proj-detail-content-richtext p {
  margin-bottom: 1rem;
}

.proj-detail-content-richtext blockquote {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.proj-detail-content-richtext li {
  margin-bottom: 0;
}

.proj-detail-content-richtext ol {
  margin-top: 1rem;
  margin-bottom: 1rem;
  padding-left: 2rem;
}

.proj-detail-content-richtext ul {
  margin-bottom: 1rem;
  padding-left: 2rem;
}

.proj-detail-content-richtext a {
  text-decoration: none;
}

.proj-detail-content-richtext figure {
  flex-flow: column;
  width: 100%;
  margin-top: 1.5rem;
  margin-bottom: 0;
  display: flex;
}

.proj-detail-content-richtext img {
  border-radius: .5rem;
}

.proj-detail-content-richtext figcaption {
  margin-top: 1rem;
  font-style: italic;
  font-weight: 500;
}

.proj-detail-author-box {
  grid-column-gap: 2.5rem;
  grid-row-gap: 2.5rem;
  border: 1px solid var(--border-color--border-alternate);
  background-color: var(--neutral--alabaster-50);
  border-radius: .5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  padding: 2rem;
  display: flex;
}

.proj-detail-author-box-top {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.proj-detail-author-box-bottom {
  grid-column-gap: 2.38rem;
  grid-row-gap: 2.38rem;
  grid-template-rows: auto;
  grid-template-columns: .6fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  display: grid;
}

.proj-detail-author-rating-stars {
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 9.88rem;
  display: flex;
}

.proj-detail-author {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.proj-detail-author-avatar {
  border-radius: 100%;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 3rem;
  height: 3rem;
  display: flex;
  overflow: hidden;
}

.proj-detail-author-name {
  grid-row-gap: 0px;
  flex-flow: column;
  display: flex;
}

.proj-detail-info-box-divider {
  background-color: var(--border-color--border-alternate);
  width: 100%;
  height: 1px;
}

.blog-list-item {
  border: 1px solid var(--border-color--border-alternate);
  background-color: var(--neutral--white);
  color: var(--brand-color--body);
  border-radius: .5rem;
  flex-flow: column;
  grid-template-rows: auto;
  grid-template-columns: 1fr .75fr;
  grid-auto-columns: 1fr;
  padding: .3125rem;
  text-decoration: none;
  transition: box-shadow .25s;
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 1px 4px 15px #11111103;
}

.info-content-grid {
  grid-column-gap: 6.25rem;
  grid-row-gap: 6.25rem;
  grid-template-rows: auto;
  grid-template-columns: .85fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.info-content {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.info-image {
  object-fit: cover;
  border-radius: .5rem;
  width: 100%;
  max-width: 35.63rem;
  height: 100%;
  overflow: hidden;
}

.testimonials-block {
  grid-column-gap: 2.5rem;
  grid-row-gap: 2.5rem;
  width: 100%;
  max-width: 62.5rem;
  color: var(--background-color--bg-alternate);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.testimonials-block.is-left-aligned {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  color: var(--text-color--text-primary);
  justify-content: flex-end;
  align-items: flex-start;
}

.testimonials-block-stars {
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 6.875rem;
  display: flex;
}

.testimonials-block-content {
  text-align: center;
}

.testimonials-block-content.is-left-aligned {
  text-align: left;
}

.text-color-lavender-mist {
  color: var(--text-color--text-lavender-mist);
}

.prod-hero-tags {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.home-hero-image {
  border: 5px solid var(--border-color--border-white);
  object-fit: cover;
  border-radius: .5rem;
  width: 100%;
  height: 100%;
  overflow: hidden;
  box-shadow: 2px 6px 20px #0000000a;
}

.home-hero-logos-wrapper {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.home-hero-logos-grid {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  place-items: end center;
  display: grid;
}

.home-hero-logo {
  width: 100%;
  max-width: 5em;
}

.contact-links-grid {
  grid-column-gap: .88em;
  grid-row-gap: .88em;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.contact-link {
  color: #fff;
  border-bottom: 1px solid #0000;
  text-decoration: none;
}

.contact-link:hover {
  border-bottom: 1px solid #fff;
}

.contact-link.is-not-link:hover {
  border-bottom-color: #0000;
}

.contact-link-flex {
  grid-column-gap: .5em;
  grid-row-gap: .5em;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.contact-link-flex.top-align {
  justify-content: flex-start;
  align-items: flex-start;
}

.testimonials-item-author-wrapper {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  justify-content: center;
  align-items: stretch;
  display: flex;
}

.testimonials-item-author-logo {
  border-left: 1px solid var(--border-color--border-primary);
  justify-content: flex-start;
  align-items: center;
  padding-left: 2rem;
  display: flex;
}

.testimonials-item-author-logo-image {
  width: 6em;
}

.contact-form-button {
  flex-flow: column;
  min-width: 12rem;
  display: flex;
}

.section_branch-hero {
  background-image: url('../images/Software-Development-Hero-Bg.svg');
  background-position: 50%;
  background-size: cover;
}

.is-branch-hero-grid {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  grid-template-rows: auto;
  grid-template-columns: .9fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.is-branch-hero-content {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.is-branch-hero-image {
  border: 5px solid var(--border-color--border-white);
  object-fit: cover;
  border-radius: .5rem;
  width: 100%;
  height: 100%;
  min-height: 35em;
  overflow: hidden;
  box-shadow: 2px 6px 20px #0000000a;
}

@media screen and (max-width: 991px) {
  .padding-xlarge {
    padding: 3rem;
  }

  .margin-xlarge {
    margin: 3rem;
  }

  .padding-xhuge {
    padding: 6rem;
  }

  .padding-xxhuge {
    padding: 8rem;
  }

  .padding-huge {
    padding: 5rem;
  }

  .margin-large {
    margin: 2.5rem;
  }

  .padding-xxlarge {
    padding: 4rem;
  }

  .padding-large {
    padding: 2.5rem;
  }

  .margin-huge {
    margin: 5rem;
  }

  .padding-medium {
    padding: 1.5rem;
  }

  .margin-xxlarge {
    margin: 4rem;
  }

  .margin-xhuge {
    margin: 6rem;
  }

  .margin-medium {
    margin: 1.5rem;
  }

  .margin-xxhuge {
    margin: 8rem;
  }

  .margin-horizontal {
    margin-top: 0;
    margin-bottom: 0;
  }

  .padding-top {
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .margin-vertical {
    margin-left: 0;
    margin-right: 0;
  }

  .margin-bottom {
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .padding-left {
    padding-top: 0;
    padding-bottom: 0;
    padding-right: 0;
  }

  .padding-vertical {
    padding-left: 0;
    padding-right: 0;
  }

  .padding-horizontal {
    padding-top: 0;
    padding-bottom: 0;
  }

  .margin-right {
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 0;
  }

  .margin-top {
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .margin-left {
    margin-top: 0;
    margin-bottom: 0;
    margin-right: 0;
  }

  .padding-right {
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 0;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .hide-tablet {
    display: none;
  }

  .fs-styleguide_2-col {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    grid-template-columns: 1fr;
  }

  .max-width-full-tablet {
    width: 100%;
    max-width: none;
  }

  .padding-global {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .fs-styleguide_1-col {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .fs-styleguide_heading-medium {
    font-size: 3rem;
  }

  .fs-styleguide_4-col {
    grid-template-columns: 1fr;
  }

  .padding-section-large {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .fs-styleguide_3-col {
    grid-template-columns: 1fr;
  }

  .fs-styleguide_section {
    grid-column-gap: 2.5rem;
    grid-template-columns: 1fr;
  }

  .padding-section-medium {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .spacer-huge {
    padding-top: 5rem;
  }

  .spacer-medium {
    padding-top: 1.5rem;
  }

  .spacer-xhuge {
    padding-top: 6rem;
  }

  .spacer-xxhuge {
    padding-top: 8rem;
  }

  .spacer-xlarge {
    padding-top: 3rem;
  }

  .spacer-large {
    padding-top: 2.5rem;
  }

  .spacer-xxlarge {
    padding-top: 4rem;
  }

  .fs-styleguide_heading-header {
    font-size: 4rem;
  }

  .nav-content-flex {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }

  .nav-logo {
    max-width: 13rem;
    padding-left: 0;
  }

  .section-heading.is-branch-hero {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .footer-top {
    flex-flow: column;
  }

  .footer-logo-link {
    max-width: 13rem;
  }

  .footer-bottom {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    text-align: center;
    flex-flow: column;
    padding-top: 1.5rem;
  }

  .nav-menu-button {
    background-color: var(--background-color--bg-primary);
    width: 3rem;
    height: 3rem;
    color: var(--neutral--white);
    border-radius: .4rem;
    justify-content: center;
    align-items: center;
    padding: 0;
    font-size: 2.5rem;
    display: none;
  }

  .nav-menu-button.w--open {
    background-color: var(--background-color--bg-primary);
  }

  .home-hero-content-grid {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    flex-flow: column;
    display: flex;
  }

  .home-challenges_dropdown {
    width: 100%;
  }

  .section-content-wrapper.is-testimonials, .section-content-wrapper.is-footer, .section-content-wrapper.is-recent-proj, .section-content-wrapper.is-branch-hero {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
  }

  .nav-right-wrapper {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .nav-menu-button-icon-wrapper {
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    display: flex;
  }

  .nav-menu-button-icon {
    filter: invert();
    justify-content: center;
    align-items: center;
    width: 2rem;
    height: 2rem;
    display: flex;
  }

  .nav-button-wrapper {
    display: flex;
  }

  .footer-top-inner {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    flex-flow: column;
  }

  .cases-list {
    flex-flow: column;
    display: flex;
  }

  .cases-list.is-grid {
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    display: grid;
  }

  .cases-list-item {
    flex-flow: column-reverse;
    display: flex;
  }

  .cases-list-item.is-flex-vertical {
    flex-flow: column;
  }

  .cases-list-item-content {
    padding: 1.5rem;
  }

  .cases-list-item-image {
    height: 60vw;
  }

  .cases-list-item-image.for-vertical-item {
    height: 40vw;
  }

  .contact-content-grid {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
    flex-flow: column;
    display: flex;
  }

  .contact-content-grid.is-less-gaped {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
  }

  .proj-hero-image {
    height: 55vw;
  }

  .proj-detail-grid {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
    flex-flow: column;
    align-items: stretch;
    display: flex;
  }

  .proj-detail-info-box {
    position: static;
    top: 0;
  }

  .proj-detail-author-box-bottom {
    grid-template-columns: .7fr 1fr;
  }

  .info-content-grid {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
    flex-flow: column;
    display: flex;
  }

  .info-image {
    max-width: none;
  }

  .is-branch-hero-grid {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
    flex-flow: column;
    display: flex;
  }

  .is-branch-hero-image {
    min-height: auto;
  }
}

@media screen and (max-width: 767px) {
  h1 {
    font-size: 2.3rem;
  }

  h2 {
    font-size: 2rem;
  }

  h3 {
    font-size: 1.5rem;
  }

  h4 {
    font-size: 1.25rem;
  }

  h5 {
    font-size: 1.1rem;
  }

  h6 {
    font-size: 1rem;
  }

  .padding-xlarge {
    padding: 2rem;
  }

  .margin-xlarge {
    margin: 2rem;
  }

  .padding-xhuge {
    padding: 4rem;
  }

  .padding-xxhuge {
    padding: 4.5rem;
  }

  .padding-huge {
    padding: 3.5rem;
  }

  .margin-large {
    margin: 1.5rem;
  }

  .padding-xxlarge {
    padding: 3rem;
  }

  .padding-large {
    padding: 1.5rem;
  }

  .margin-huge {
    margin: 3.5rem;
  }

  .padding-medium {
    padding: 1.25rem;
  }

  .margin-xxlarge {
    margin: 3rem;
  }

  .margin-xhuge {
    margin: 4rem;
  }

  .margin-medium {
    margin: 1.25rem;
  }

  .margin-xxhuge {
    margin: 4.5rem;
  }

  .margin-horizontal {
    margin-top: 0;
    margin-bottom: 0;
  }

  .padding-top {
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .margin-vertical {
    margin-left: 0;
    margin-right: 0;
  }

  .margin-bottom {
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .padding-left {
    padding-top: 0;
    padding-bottom: 0;
    padding-right: 0;
  }

  .padding-vertical {
    padding-left: 0;
    padding-right: 0;
  }

  .padding-horizontal {
    padding-top: 0;
    padding-bottom: 0;
  }

  .margin-right {
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 0;
  }

  .margin-top {
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .margin-left {
    margin-top: 0;
    margin-bottom: 0;
    margin-right: 0;
  }

  .padding-right {
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 0;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .hide-mobile-landscape {
    display: none;
  }

  .heading-style-h3 {
    font-size: 1.5rem;
  }

  .heading-style-h1 {
    font-size: 2.3rem;
  }

  .padding-global {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .padding-section-small {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .padding-section-small.is-home-hero {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .padding-section-small.is-footer {
    padding-top: 4rem;
  }

  .padding-section-small.is-proj-hero, .padding-section-small.is-branch-hero {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .fs-styleguide_section-header {
    font-size: .875rem;
  }

  .fs-styleguide_heading-medium {
    font-size: 2rem;
  }

  .max-width-full-mobile-landscape {
    width: 100%;
    max-width: none;
  }

  .heading-style-h4 {
    font-size: 1.25rem;
  }

  .text-style-nowrap {
    white-space: normal;
  }

  .heading-style-h6 {
    font-size: 1rem;
  }

  .heading-style-h6.is-large {
    font-size: 1.1rem;
  }

  .padding-section-large {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .padding-section-large.is-proj-detail {
    padding-top: 4rem;
  }

  .text-size-large {
    font-size: 1rem;
  }

  .heading-style-h2 {
    font-size: 2rem;
  }

  .heading-style-h5, .text-size-medium {
    font-size: 1.1rem;
  }

  .padding-section-medium {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .spacer-huge {
    padding-top: 3.5rem;
  }

  .spacer-medium {
    padding-top: 1.25rem;
  }

  .spacer-xhuge {
    padding-top: 4rem;
  }

  .spacer-xxhuge {
    padding-top: 4.5rem;
  }

  .spacer-xlarge {
    padding-top: 2rem;
  }

  .spacer-large {
    padding-top: 1.5rem;
  }

  .spacer-xxlarge {
    padding-top: 3rem;
  }

  .nav-content-flex {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }

  .section-header {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .footer-top {
    grid-template-columns: 1fr;
    place-items: start;
  }

  .section-content-wrapper.is-home-hero {
    grid-column-gap: 6rem;
    grid-row-gap: 6rem;
  }

  .section-content-wrapper.is-testimonials, .section-content-wrapper.is-footer {
    grid-column-gap: 2.5rem;
    grid-row-gap: 2.5rem;
  }

  .section-content-wrapper.is-contact, .section-content-wrapper.is-proj-detail, .section-content-wrapper.is-info {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
  }

  .section-content-wrapper.is-recent-proj, .section-content-wrapper.is-branch-hero {
    grid-column-gap: 2.5rem;
    grid-row-gap: 2.5rem;
  }

  .footer-top-inner {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .cases-list {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .cases-list.is-grid {
    grid-template-columns: 1fr;
  }

  .cases-list-item {
    flex-flow: column-reverse;
  }

  .cases-list-item-image.for-vertical-item {
    height: 60vw;
  }

  .contact-content-grid {
    grid-column-gap: 2.5rem;
    grid-row-gap: 2.5rem;
    justify-content: flex-start;
    align-items: center;
  }

  .contact-content-grid.is-less-gaped {
    grid-column-gap: 2.5rem;
    grid-row-gap: 2.5rem;
  }

  .contact-content-separator {
    margin-top: 0;
    margin-bottom: 0;
  }

  .contact-form-fields-grid {
    grid-column-gap: 1.25rem;
    grid-row-gap: 1.25rem;
    grid-template-columns: 1fr;
  }

  .proj-hero-image {
    height: 60vw;
  }

  .proj-detail-grid, .proj-detail-content {
    grid-column-gap: 2.5rem;
    grid-row-gap: 2.5rem;
  }

  .proj-detail-content-richtext h1 {
    margin-bottom: .63rem;
    font-size: 2rem;
  }

  .proj-detail-content-richtext h2 {
    margin-bottom: .63rem;
    font-size: 1.5rem;
  }

  .proj-detail-content-richtext h3 {
    margin-bottom: .63rem;
    font-size: 1.3rem;
  }

  .proj-detail-content-richtext h4 {
    margin-bottom: .63rem;
    font-size: 1.1rem;
  }

  .proj-detail-content-richtext h5 {
    margin-bottom: .63rem;
    font-size: 1rem;
  }

  .proj-detail-content-richtext h6 {
    margin-bottom: .63rem;
    font-size: .88rem;
  }

  .proj-detail-content-richtext p {
    margin-bottom: .63rem;
  }

  .proj-detail-content-richtext blockquote, .proj-detail-content-richtext ol, .proj-detail-content-richtext ul {
    margin-top: .63rem;
    margin-bottom: .63rem;
  }

  .proj-detail-content-richtext figcaption {
    margin-top: .63rem;
  }

  .proj-detail-author-box {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    padding: 1.5rem;
  }

  .proj-detail-author-box-top {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .proj-detail-author-box-bottom {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    grid-template-columns: 1fr;
  }

  .proj-detail-author-rating-stars {
    max-width: 8rem;
  }

  .info-content-grid {
    grid-column-gap: 2.5rem;
    grid-row-gap: 2.5rem;
  }

  .info-content {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .testimonials-block {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .is-branch-hero-grid {
    grid-column-gap: 2.5rem;
    grid-row-gap: 2.5rem;
  }
}

@media screen and (max-width: 479px) {
  h1 {
    font-size: 2rem;
  }

  h2 {
    font-size: 1.7rem;
  }

  .margin-horizontal {
    margin-top: 0;
    margin-bottom: 0;
  }

  .padding-top {
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .margin-vertical {
    margin-left: 0;
    margin-right: 0;
  }

  .margin-bottom {
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .padding-left {
    padding-top: 0;
    padding-bottom: 0;
    padding-right: 0;
  }

  .padding-vertical {
    padding-left: 0;
    padding-right: 0;
  }

  .padding-horizontal {
    padding-top: 0;
    padding-bottom: 0;
  }

  .margin-right {
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 0;
  }

  .margin-top {
    margin-bottom: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .margin-left {
    margin-top: 0;
    margin-bottom: 0;
    margin-right: 0;
  }

  .padding-right {
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 0;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .fs-styleguide_row {
    flex-wrap: wrap;
  }

  .max-width-full-mobile-portrait {
    width: 100%;
    max-width: none;
  }

  .icon-1x1-medium {
    width: 1.2rem;
    height: 1.2rem;
  }

  .heading-style-h1 {
    font-size: 2rem;
  }

  .padding-global {
    padding-left: 1.13rem;
    padding-right: 1.13rem;
  }

  .padding-section-small.is-home-hero {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .padding-section-small.is-footer {
    padding-top: 3rem;
    padding-bottom: 1rem;
  }

  .padding-section-small.is-proj-hero, .padding-section-small.is-branch-hero {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .text-size-tiny {
    font-size: .69rem;
  }

  .hide-mobile-portrait {
    display: none;
  }

  .text-size-regular {
    font-size: .88rem;
  }

  .text-size-small {
    font-size: .75rem;
  }

  .padding-section-large {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .padding-section-large.is-proj-detail {
    padding-top: 3rem;
  }

  .heading-style-h2 {
    font-size: 1.7rem;
  }

  .heading-style-h5 {
    font-size: 1.1rem;
  }

  .button {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
    font-size: .94rem;
  }

  .text-size-medium {
    font-size: 1rem;
  }

  .button-group {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
    flex-flow: column;
    align-items: stretch;
    width: 100%;
  }

  .padding-section-medium {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }

  .nav-content-flex {
    padding-top: .88rem;
    padding-bottom: .88rem;
  }

  .nav-logo {
    max-width: 12rem;
  }

  .section-header {
    grid-row-gap: 1rem;
  }

  .section-heading, .section-heading.is-home-hero, .section-heading.is-branch-hero {
    grid-column-gap: .75rem;
    grid-row-gap: .75rem;
  }

  .section-tag-large {
    border-radius: .5rem;
    padding: .7rem;
  }

  .button-link {
    font-size: .88rem;
  }

  .testimonials-item-author {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .footer-top {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .footer-left {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    width: 100%;
  }

  .footer-logo-link {
    max-width: 12rem;
  }

  .footer-address {
    max-width: 100%;
  }

  .footer-bottom {
    padding-top: 1rem;
  }

  .nav-menu-button {
    width: 2.8rem;
    height: 2.8rem;
  }

  .home-hero-content-grid, .home-hero-content {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .icon-box-1x1-medium {
    width: 2rem;
    height: 2rem;
  }

  .icon-box-1x1-large {
    width: 2.5rem;
    height: 2.5rem;
  }

  .section-content-wrapper.is-home-hero {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .section-content-wrapper.is-testimonials {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .section-content-wrapper.is-footer, .section-content-wrapper.is-contact {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .section-content-wrapper.is-proj-hero, .section-content-wrapper.is-proj-detail {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .section-content-wrapper.is-info {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .section-content-wrapper.is-recent-proj {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .section-content-wrapper.is-branch-hero {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .cases-list {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .cases-list-item-content {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    padding: 1rem;
  }

  .cases-list-item-content.for-vertical-item {
    padding: 1rem;
  }

  .cases-list-item-heading {
    grid-column-gap: .75rem;
    grid-row-gap: .75rem;
  }

  .contact-content-grid, .contact-content-grid.is-less-gaped {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .contact-content, .contact-form {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .contact-form-fields {
    grid-column-gap: .88rem;
    grid-row-gap: .88rem;
  }

  .form-input {
    padding: .75rem;
    font-size: .88rem;
  }

  .contact-form-fields-grid {
    grid-column-gap: .88rem;
    grid-row-gap: .88rem;
  }

  .proj-hero-image {
    height: 70vw;
  }

  .proj-detail-grid {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .proj-detail-info-box {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    padding: 1rem;
  }

  .proj-detail-info-box-top {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .proj-detail-info-box-item {
    grid-column-gap: .31rem;
    grid-row-gap: .31rem;
  }

  .proj-detail-content {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .proj-detail-content-richtext p {
    margin-bottom: .5rem;
    font-size: .88rem;
  }

  .proj-detail-content-richtext li {
    font-size: .88rem;
  }

  .proj-detail-content-richtext img {
    border-radius: .31rem;
  }

  .proj-detail-content-richtext figcaption {
    margin-top: .5rem;
    font-size: .88rem;
  }

  .proj-detail-author-box {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    padding: 1rem;
  }

  .proj-detail-author-box-bottom {
    grid-column-gap: .88rem;
    grid-row-gap: .88rem;
  }

  .proj-detail-author-rating-stars {
    max-width: 7rem;
  }

  .proj-detail-author {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .info-content-grid {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .info-content, .testimonials-block {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .testimonials-block.is-left-aligned {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    text-align: center;
  }

  .prod-hero-tags {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .contact-links-grid {
    grid-column-gap: .5em;
    grid-row-gap: .5em;
  }

  .testimonials-item-author-wrapper {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .testimonials-item-author-logo {
    padding-left: 1rem;
  }

  .testimonials-item-author-logo-image {
    width: 5em;
  }

  .is-branch-hero-grid {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
  }

  .is-branch-hero-content {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }
}

#w-node-_12075a14-d61a-e1ab-f297-fd1b9fb092c1-f4ec537e, #w-node-a0444c45-390c-3a9e-f336-4fb0f61b6f6f-f4ec537e, #w-node-_1b31facc-0a3a-a992-e515-b57e8d35a0c9-f4ec537e {
  justify-self: end;
}

#w-node-_6591b5aa-949b-7880-93aa-29372f2541aa-f4ec537e, #w-node-e57a2bd3-da10-ab04-e4fe-755668d6365d-53b7b273 {
  grid-area: span 1 / span 2 / span 1 / span 2;
}

#w-node-b224ec27-30fa-be84-48bf-7ed471542af3-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627ca17-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ca1c-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ca21-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ca26-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ca2c-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ca32-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ca38-f4ec5381 {
  justify-self: start;
}

#w-node-_5d224905-8a1e-1460-7532-d38cb7ec37c1-f4ec5381, #w-node-_40538c8c-870b-b365-34c4-2a06f0f8567d-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cb45-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cb5e-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cb61-f4ec5381 {
  justify-self: start;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cb63-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cb66-f4ec5381 {
  justify-self: start;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cbb8-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cbc2-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cbc3-f4ec5381, #w-node-_79e0fcc6-2af2-f271-87bd-73e2bb839ff8-f4ec5381, #w-node-_79e0fcc6-2af2-f271-87bd-73e2bb839ff9-f4ec5381, #w-node-_7a93fd76-8090-7503-250a-a6caf48c31d2-f4ec5381, #w-node-_7a93fd76-8090-7503-250a-a6caf48c31d3-f4ec5381, #w-node-_631ba54b-f44e-220f-6d3c-9f0d9fa376ac-f4ec5381, #w-node-c23d7e04-233d-9e11-6dfa-01f4729431c1-f4ec5381, #w-node-_4a4da16e-34af-1c75-31c9-692c1974d9cb-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cc31-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc36-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc3b-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc40-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc45-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc4a-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc54-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc59-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc5e-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc63-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc68-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc6d-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc72-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc77-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc7c-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc81-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc86-f4ec5381 {
  justify-self: start;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cc8a-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cc8b-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc90-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc95-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cc9a-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccaf-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccb4-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccb9-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccbe-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccc3-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccc8-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccd2-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccd7-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccdc-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cce1-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cce6-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cceb-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccf0-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccf5-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccfa-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627ccff-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cd04-f4ec5381 {
  justify-self: start;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cd08-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cd09-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cd0e-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cd13-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cd18-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef3e5-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef3ea-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef3ef-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef3f4-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef3f9-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef3fe-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef403-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef408-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef40d-f4ec5381, #w-node-_30684373-af34-3818-02a4-e58b3ffef412-f4ec5381 {
  justify-self: start;
}

#w-node-_30684373-af34-3818-02a4-e58b3ffef416-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_30684373-af34-3818-02a4-e58b3ffef417-f4ec5381 {
  justify-self: start;
}

#w-node-_30684373-af34-3818-02a4-e58b3ffef41a-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cd6b-f4ec5381, #w-node-_32eadc24-e391-a089-abe0-fb5b6627cd98-f4ec5381 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_32eadc24-e391-a089-abe0-fb5b6627cdc7-f4ec5381 {
  justify-self: start;
}


@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-LightItalic.ttf') format('truetype');
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-BlackItalic.ttf') format('truetype');
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-ExtraBoldItalic.ttf') format('truetype'), url('../fonts/OpenSauceTwo-BoldItalic.ttf') format('truetype');
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-Italic.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-Bold.ttf') format('truetype'), url('../fonts/OpenSauceTwo-ExtraBold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-MediumItalic.ttf') format('truetype');
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-Black.ttf') format('truetype');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-SemiBold.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-Light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Opensaucetwo';
  src: url('../fonts/OpenSauceTwo-SemiBoldItalic.ttf') format('truetype');
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
/* Focus state style for keyboard navigation for the focusable elements */
*[tabindex]:focus-visible,
input[type="file"]:focus-visible {
  outline: 0.125rem solid #4d65ff;
  outline-offset: 0.125rem;
}
/* Set color style to inherit */
.inherit-color * {
  color: inherit;
}
/* Get rid of top margin on first element in any rich text element */
.w-richtext > :not(div):first-child, .w-richtext > div:first-child > :first-child {
  margin-top: 0 !important;
}
/* Get rid of bottom margin on last element in any rich text element */
.w-richtext>:last-child, .w-richtext ol li:last-child, .w-richtext ul li:last-child {
  margin-bottom: 0 !important;
}
/* Make sure containers never lose their center alignment */
.container-medium,.container-small, .container-large {
  margin-right: auto !important;
  margin-left: auto !important;
}
/*
Make the following elements inherit typography styles from the parent and not have hardcoded values.
Important: You will not be able to style for example "All Links" in Designer with this CSS applied.
Uncomment this CSS to use it in the project. Leave this message for future hand-off.
*/
/*
a,
.w-input,
.w-select,
.w-tab-link,
.w-nav-link,
.w-dropdown-btn,
.w-dropdown-toggle,
.w-dropdown-link {
  color: inherit;
  text-decoration: inherit;
  font-size: inherit;
}
*/
/* Apply "..." after 3 lines of text */
.text-style-3lines {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
/* Apply "..." after 2 lines of text */
.text-style-2lines {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
/* These classes are never overwritten */
.hide {
  display: none !important;
}
@media screen and (max-width: 991px) {
  .hide, .hide-tablet {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .hide-mobile-landscape{
    display: none !important;
  }
}
@media screen and (max-width: 479px) {
  .hide-mobile{
    display: none !important;
  }
}
.margin-0 {
  margin: 0rem !important;
}
.padding-0 {
  padding: 0rem !important;
}
.spacing-clean {
  padding: 0rem !important;
  margin: 0rem !important;
}
.margin-top {
  margin-right: 0rem !important;
  margin-bottom: 0rem !important;
  margin-left: 0rem !important;
}
.padding-top {
  padding-right: 0rem !important;
  padding-bottom: 0rem !important;
  padding-left: 0rem !important;
}
.margin-right {
  margin-top: 0rem !important;
  margin-bottom: 0rem !important;
  margin-left: 0rem !important;
}
.padding-right {
  padding-top: 0rem !important;
  padding-bottom: 0rem !important;
  padding-left: 0rem !important;
}
.margin-bottom {
  margin-top: 0rem !important;
  margin-right: 0rem !important;
  margin-left: 0rem !important;
}
.padding-bottom {
  padding-top: 0rem !important;
  padding-right: 0rem !important;
  padding-left: 0rem !important;
}
.margin-left {
  margin-top: 0rem !important;
  margin-right: 0rem !important;
  margin-bottom: 0rem !important;
}
.padding-left {
  padding-top: 0rem !important;
  padding-right: 0rem !important;
  padding-bottom: 0rem !important;
}
.margin-horizontal {
  margin-top: 0rem !important;
  margin-bottom: 0rem !important;
}
.padding-horizontal {
  padding-top: 0rem !important;
  padding-bottom: 0rem !important;
}
.margin-vertical {
  margin-right: 0rem !important;
  margin-left: 0rem !important;
}
.padding-vertical {
  padding-right: 0rem !important;
  padding-left: 0rem !important;
}
