@font-face {
    font-family: 'Synonym-Regular';
    src: url('../fonts/Synonym-Regular.woff2') format('woff2'),
        url('../fonts/Synonym-Regular.woff') format('woff'),
        url('../fonts/Synonym-Regular.ttf') format('truetype');
    font-weight: 400;
    font-display: swap;
    font-style: normal;
}

@font-face {
    font-family: 'CabinetGrotesk-Black';
    src: url('../fonts/CabinetGrotesk-Black.woff2') format('woff2'),
        url('../fonts/CabinetGrotesk-Black.woff') format('woff'),
        url('../fonts/CabinetGrotesk-Black.ttf') format('truetype');
    font-weight: 900;
    font-display: swap;
    font-style: normal;
}

.content-format ol {
    list-style: auto;
    padding: revert;
    margin: 1em 0;
}

.content-format ul {
    list-style: disc;
    padding: revert;
    margin: 1em 0;
}

.content-format ol li,
.content-format ul li {
    line-height: 1.3;
}

.content-format ol li+li,
.content-format ul li+li {
    margin-top: 20px;
}

.content-format .video-container {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    margin: 30px 0;
}

.content-format .video-container iFrame {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.navbar-nav .nav-item>.nav-link:hover {
    cursor: pointer;
}

.case-card .caption-grid {
    flex-wrap: wrap !important;
}

h1,
h2,
h3,
h4,
h5,
.featured-case .caption .title,
.joyful-customization-app .blurb .title {
    color: #00d275 !important;
}

.btn-green,
.btn-green:focus {
    background-color: #101010;
    color: #FFF !important;
}

.btn-white,
.btn-white:focus,
h6 {
    color: #FFF !important;
}

canvas {
    display: none !important;
}

.form-layout .form-sidebar .paragraph,
.product-parallax-section .parallax-background-section .paragraph {
    color: #FFF;
}

.testimonial .content p {
    line-height: initial !important;
}

@-ms-viewport {
    width: device-width;
}

a,
address,
article,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
dd,
del,
dfn,
div,
dl,
dt,
em,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
html,
i,
iframe,
img,
ins,
kbd,
label,
li,
main,
menu,
nav,
object,
ol,
p,
pre,
q,
s,
section,
small,
span,
strong,
sub,
sup,
td,
th,
time,
tr,
tt,
u,
ul,
var,
video {
    border: 0;
    font-size: 100%;
    font: inherit;
    margin: 0;
    padding: 0;
    vertical-align: baseline;
}

article,
footer,
header,
main,
menu,
nav,
section {
    display: block;
}

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

html {
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -ms-overflow-style: scrollbar;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    box-sizing: border-box;
    touch-action: manipulation;
}

body {
    font-family: sans-serif;
    line-height: 1;
    text-align: left;
}

[tabindex="-1"]:focus:not(:focus-visible) {
    outline: 0 !important;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:after,
blockquote:before,
q:after,
q:before {
    content: "";
    content: none;
}

caption {
    caption-side: bottom;
}

th {
    text-align: inherit;
    text-align: -webkit-match-parent;
}

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

kbd,
pre {
    font-family: monospace, monospace;
}

pre {
    -ms-overflow-style: scrollbar;
    overflow: auto;
}

a {
    -webkit-text-decoration-skip: objects;
    background-color: transparent;
}

address {
    font-style: normal;
    line-height: inherit;
}

b,
strong {
    font-weight: bolder;
}

small {
    font-size: 80%;
}

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

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

em {
    font-style: italic;
}

img {
    border-style: none;
}

svg:not(:root) {
    overflow: hidden;
}

button {
    border-radius: 0;
}

button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color;
}

button,
input,
select {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
}

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

input[type="date"],
input[type="time"] {
    -webkit-appearance: listbox;
}

button,
input {
    overflow: visible;
}

button,
select {
    text-transform: none;
}

select {
    word-wrap: normal;
}

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

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

[tabindex="-1"]:focus {
    outline: 0 !important;
}

progress {
    vertical-align: baseline;
}

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

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

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

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

[hidden] {
    display: none;
}

a {
    text-decoration: none;
}

a:-moz-focusring {
    outline: none;
}

a:focus {
    outline: none;
}

button,
input[type="button"],
input[type="submit"] {
    -webkit-appearance: button;
    appearance: button;
    background: none;
    border: 0;
    color: inherit;
    font: inherit;
    font-size: 100%;
    padding: 0;
    text-align: inherit;
    -ms-user-select: none;
    user-select: none;
}

[role="button"]:not(:disabled),
button:not(:disabled),
input[type="button"]:not(:disabled),
input[type="reset"]:not(:disabled),
input[type="submit"]:not(:disabled) {
    cursor: pointer;
}

[role="button"]:-moz-focusring,
button:-moz-focusring,
input[type="button"]:-moz-focusring,
input[type="reset"]:-moz-focusring,
input[type="submit"]:-moz-focusring {
    outline: none;
}

[role="button"]:focus,
button:focus,
input[type="button"]:focus,
input[type="reset"]:focus,
input[type="submit"]:focus {
    outline: none;
}

.bg-neon-green {
    background-color: #666;
}

.bg-teal {
    background-color: #5cfff1;
}

.bg-yellow {
    background-color: #ffe95c;
}

.bg-texas-rose {
    background-color: #ffaf5c;
}

.bg-bitter-sweet {
    background-color: #000;
}

.bg-watermelon {
    background-color: #ff5c7d;
}

.bg-violet {
    background-color: #00d275;
}

.text-neon-green {
    color: #666;
}

.text-teal {
    color: #5cfff1;
}

.text-violet {
    color: #00d275;
}

.d-block {
    display: block !important;
}

.d-flex {
    display: flex !important;
}

@media (min-width: 1280px) {
    .d-lg-none {
        display: none !important;
    }
}

.justify-content-center {
    justify-content: center !important;
}

.overflow-hidden {
    overflow: hidden !important;
}

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

.sr-only-focusable:active,
.sr-only-focusable:focus {
    clip: auto;
    height: auto;
    overflow: visible;
    position: static;
    white-space: normal;
    width: auto;
}

.m-0 {
    margin: 0 !important;
}

.m-1 {
    margin: 0.25rem !important;
}

.m-2 {
    margin: 0.5rem !important;
}

.m-3 {
    margin: 1rem !important;
}

.m-4 {
    margin: 1.5rem !important;
}

.mt-4 {
    margin-top: 1.5rem !important;
}

.ml-4 {
    margin-left: 1.5rem !important;
}

.m-5 {
    margin: 3rem !important;
}

.mr-5 {
    margin-right: 3rem !important;
}

.p-0 {
    padding: 0 !important;
}

.pt-0 {
    padding-top: 0 !important;
}

.pb-0 {
    padding-bottom: 0 !important;
}

.pl-0 {
    padding-left: 0 !important;
}

.p-1 {
    padding: 0.25rem !important;
}

.p-2 {
    padding: 0.5rem !important;
}

.p-3 {
    padding: 1rem !important;
}

.p-4 {
    padding: 1.5rem !important;
}

.p-5 {
    padding: 3rem !important;
}

.py-5 {
    padding-top: 3rem !important;
}

.py-5 {
    padding-bottom: 3rem !important;
}

.m-n4 {
    margin: -1.5rem !important;
}

.m-n5 {
    margin: -3rem !important;
}

.datepicker {
    display: none;
}

.datepicker.active {
    display: block;
}

.datepicker-dropdown {
    left: 0;
    padding-top: 4px;
    position: absolute;
    top: 0;
    z-index: 20;
}

.datepicker-dropdown.datepicker-orient-top {
    padding-bottom: 4px;
    padding-top: 0;
}

.datepicker-picker {
    background-color: #fff;
    border-radius: 4px;
    display: inline-block;
}

.datepicker-dropdown .datepicker-picker {
    box-shadow: 0 2px 3px hsla(0, 0%, 4%, 0.1), 0 0 0 1px hsla(0, 0%, 4%, 0.1);
}

.datepicker-picker span {
    -webkit-touch-callout: none;
    border: 0;
    border-radius: 4px;
    cursor: default;
    display: block;
    flex: 1;
    text-align: center;
    -ms-user-select: none;
    user-select: none;
}

.datepicker-main {
    padding: 2px;
}

.datepicker-footer {
    background-color: #f5f5f5;
    box-shadow: inset 0 1px 1px hsla(0, 0%, 4%, 0.1);
}

.datepicker-controls,
.datepicker-grid,
.datepicker-view,
.datepicker-view .days-of-week {
    display: flex;
}

.datepicker-grid {
    flex-wrap: wrap;
}

.datepicker-view .days .datepicker-cell,
.datepicker-view .dow {
    flex-basis: 14.2857142857%;
}

.datepicker-view.datepicker-grid .datepicker-cell {
    flex-basis: 25%;
}

.datepicker-cell,
.datepicker-view .week {
    height: 2.25rem;
    line-height: 2.25rem;
}

.datepicker-title {
    background-color: #f5f5f5;
    box-shadow: inset 0 -1px 1px hsla(0, 0%, 4%, 0.1);
    font-weight: 700;
    padding: 0.375rem 0.75rem;
    text-align: center;
}

.datepicker-header .datepicker-controls {
    padding: 2px 2px 0;
}

.datepicker-controls .button {
    align-items: center;
    background-color: #fff;
    border: 0;
    border-radius: 4px;
    box-shadow: none;
    color: #363636;
    cursor: pointer;
    display: inline-flex;
    font-size: 1rem;
    height: 2.25em;
    justify-content: center;
    line-height: 1.5;
    margin: 0;
    padding: calc(0.375em - 1px) 0.75em;
    position: relative;
    text-align: center;
    vertical-align: top;
    white-space: nowrap;
}

.datepicker-controls .button:active,
.datepicker-controls .button:focus {
    outline: none;
}

.datepicker-controls .button:hover {
    border-color: #b5b5b5;
    color: #363636;
}

.datepicker-controls .button:focus {
    border-color: #3273dc;
    color: #363636;
}

.datepicker-controls .button:focus:not(:active) {
    box-shadow: 0 0 0 0.125em rgba(50, 115, 220, 0.25);
}

.datepicker-controls .button:active {
    border-color: #4a4a4a;
    color: #363636;
}

.datepicker-controls .button[disabled] {
    cursor: not-allowed;
}

.datepicker-header .datepicker-controls .button {
    border-font-weight: 700;
}

.datepicker-header .datepicker-controls .button:hover {
    background-color: #f9f9f9;
}

.datepicker-header .datepicker-controls .button:focus:not(:active) {
    box-shadow: 0 0 0 0.125em hsla(0, 0%, 100%, 0.25);
}

.datepicker-header .datepicker-controls .button:active {
    background-color: #f2f2f2;
}

.datepicker-header .datepicker-controls .button[disabled] {
    box-shadow: none;
}

.datepicker-footer .datepicker-controls .button {
    border-radius: 2px;
    font-size: 0.75rem;
    margin: calc(0.375rem - 1px) 0.375rem;
    width: 100%;
}

.datepicker-controls .view-switch {
    flex: auto;
}

.datepicker-controls .next-btn,
.datepicker-controls .prev-btn {
    padding-left: 0.375rem;
    padding-right: 0.375rem;
    width: 2.25rem;
}

.datepicker-controls .next-btn.disabled,
.datepicker-controls .prev-btn.disabled {
    visibility: hidden;
}

.datepicker-view .dow {
    font-size: 0.875rem;
    font-weight: 700;
    height: 1.5rem;
    line-height: 1.5rem;
}

.datepicker-view .week {
    color: #b5b5b5;
    font-size: 0.75rem;
    width: 2.25rem;
}

@media (max-width: 22.5rem) {
    .datepicker-view .week {
        width: 1.96875rem;
    }
}

.datepicker-grid {
    width: 15.75rem;
}

@media (max-width: 22.5rem) {
    .calendar-weeks+.days .datepicker-grid {
        width: 13.78125rem;
    }
}

.datepicker-cell:not(.disabled):hover {
    background-color: #f9f9f9;
    cursor: pointer;
}

.datepicker-cell.focused:not(.selected) {
    background-color: #e8e8e8;
}

.datepicker-cell.selected,
.datepicker-cell.selected:hover {
    background-color: #3273dc;
    color: #fff;
    font-weight: 600;
}

.datepicker-cell.disabled {
    color: #dbdbdb;
}

.datepicker-cell.next:not(.disabled),
.datepicker-cell.prev:not(.disabled) {
    color: #7a7a7a;
}

.datepicker-cell.next.selected,
.datepicker-cell.prev.selected {
    color: #e6e6e6;
}

.datepicker-cell.highlighted:not(.selected):not(.range):not(.today) {
    background-color: #f5f5f5;
    border-radius: 0;
}

.datepicker-cell.highlighted:not(.selected):not(.range):not(.today):not(.disabled):hover {
    background-color: #eee;
}

.datepicker-cell.highlighted:not(.selected):not(.range):not(.today).focused {
    background-color: #e8e8e8;
}

.datepicker-cell.today:not(.selected) {
    background-color: #00d1b2;
}

.datepicker-cell.today:not(.selected):not(.disabled) {
    color: #fff;
}

.datepicker-cell.today.focused:not(.selected) {
    background-color: #00c4a7;
}

.datepicker-cell.range-end:not(.selected),
.datepicker-cell.range-start:not(.selected) {
    background-color: #b5b5b5;
    color: #fff;
}

.datepicker-cell.range-end.focused:not(.selected),
.datepicker-cell.range-start.focused:not(.selected) {
    background-color: #afafaf;
}

.datepicker-cell.range-start {
    border-radius: 4px 0 0 4px;
}

.datepicker-cell.range-end {
    border-radius: 0 4px 4px 0;
}

.datepicker-cell.range {
    background-color: #dbdbdb;
    border-radius: 0;
}

.datepicker-cell.range:not(.disabled):not(.focused):not(.today):hover {
    background-color: #d5d5d5;
}

.datepicker-cell.range.disabled {
    color: #c2c2c2;
}

.datepicker-cell.range.focused {
    background-color: #cfcfcf;
}

.datepicker-view.datepicker-grid .datepicker-cell {
    height: 4.5rem;
    line-height: 4.5rem;
}

.datepicker-input.in-edit {
    border-color: #2366d1;
}

.datepicker-input.in-edit:active,
.datepicker-input.in-edit:focus {
    box-shadow: 0 0 0.25em 0.25em rgba(35, 102, 209, 0.2);
}

:root {
    --dropdownXOffset: 0;
    --gutter: 20px;
    --navbarH: 80px;
    --sectionPaddingY: 80px;
}

@media (min-width: 768px) {
    :root {
        --gutter: 40px;
        --navbarH: 80px;
        --sectionPaddingY: 120px;
    }
}

@media (min-width: 1280px) {
    :root {
        --gutter: 100px;
    }
}

body {
    background: #0f0f0f;
    color: #0f0f0f;
    visibility: hidden;
}

body,
html {
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: none;
    -ms-scroll-chaining: none;
    font-family: "Synonym-Regular", sans-serif;
    font-size: 20px;
    min-height: 100%;
    overscroll-behavior: none;
    width: 100%;
}

h1 {
    font-size: 5rem;
}

h2 {
    font-size: 4rem;
}

h3 {
    font-size: 3.2rem;
}

h4 {
    font-size: 2.56rem;
}

h5 {
    font-size: 1.92rem;
}

h6 {
    font-size: 1.44rem;
}

h1,
h2,
h3,
h4,
h5,
h6,
.joyful-customization-app .heading {
    font-family: "CabinetGrotesk-Black", sans-serif !important;
    margin: 0;
}

p {
    line-height: 1.3;
    margin-bottom: 0;
}

a {
    color: inherit;
}

a:active,
a:hover {
    color: inherit;
    text-decoration: none;
}

a:focus {
    outline: 0;
    text-decoration: none;
}

.btn {
    --btnH: 56px;
    --paddingX: 24px;
    --paddingY: 16px;
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 1em;
    box-sizing: border-box;
    display: inline-flex;
    font-size: 1rem;
    font-weight: 500;
    gap: 16px;
    height: var(--btnH);
    justify-content: center;
    line-height: calc(var(--btnH) - var(--paddingY) - 2px);
    padding: var(--paddingY) var(--paddingX);
    position: relative;
    transition-delay: 0s;
    transition-duration: 0.2s;
    transition-property: background-color, color, border-color;
    transition-timing-function: cubic-bezier(0.38, 0.005, 0.215, 1);
}

/*
@media (min-width: 768px) {
    .btn {
        --btnH: 64px;
        --paddingX: 32px;
        border-radius: 1em;
        font-size: 20px;
    }
}*/

.btn:active:focus,
.btn:hover {
    transition-duration: 0.4s;
}

.btn-bg {
    border-radius: inherit;
    bottom: -1px;
    left: -1px;
    overflow: hidden;
    position: absolute;
    right: -1px;
    top: -1px;
    transform: translateZ(0);
}

.btn-bg:before {
    border-radius: 50%;
    content: "";
    height: calc(var(--btnH) * 8);
    left: 50%;
    margin-left: calc(var(--btnH) * 8 / -2);
    margin-top: calc(var(--btnH) * 8 / -2);
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: scale(0);
    transform-origin: center center;
    transition: transform 0.8s cubic-bezier(0.38, 0.005, 0.215, 1), opacity 0.2s cubic-bezier(0.38, 0.005, 0.215, 1);
    width: calc(var(--btnH) * 8);
}

.btn:hover .btn-bg:before {
    opacity: 1;
    transform: scale(1);
    transition: transform 0.8s cubic-bezier(0.38, 0.005, 0.215, 1), opacity 0s cubic-bezier(0.38, 0.005, 0.215, 1);
}

.btn-text {
    align-items: center;
    display: flex;
    gap: inherit;
    justify-content: center;
    position: relative;
    z-index: 3;
    font-family: "CabinetGrotesk-Black", sans-serif;
    font-size: 1rem;
    line-height: 1rem;
}

.btn-sm {
    --btnH: 56px;
    --paddingX: 24px;
    font-size: 1rem;
    gap: 12px;
}

.btn-sm svg {
    height: auto;
    width: 15px;
}

@media (min-width: 768px) {
    .btn-sm {
        --btnH: 56px;
    }
}

.btn-lg {
    --btnH: 56px;
    --paddingX: 24px;
    font-size: 1rem;
}

@media (min-width: 1280px) {
    .btn-lg {
        --btnH: 80px;
        --paddingX: 40px;
        font-size: 24px;
    }
}

.btn svg path {
    fill: currentColor;
}

.btn-white,
.btn-white:focus {
    background-color: #00d275;
    color: #101010 !important;
}

footer .btn-white,
footer .btn-white:focus {
    color: #fff !important;
}

.btn-white:active:focus,
.btn-white:hover {
    background-color: #efece6;
    color: #00d275 !important;
}

.btn-white .btn-bg:before,
.btn-white:focus .btn-bg:before {
    background-color: #FFF;
}

.btn-primary,
.btn-primary:focus {
    background-color: #0f0f0f;
    color: #efece6;
}

.btn-primary:active:focus,
.btn-primary:hover {
    background-color: #0f0f0f;
    color: #0f0f0f;
}

.btn-primary .btn-bg:before,
.btn-primary:focus .btn-bg:before {
    background-color: #dbd4c7;
}

.btn-neon-green,
.btn-neon-green:focus {
    background-color: #666;
    color: #fff;
}

.btn-neon-green:active:focus,
.btn-neon-green:hover {
    background-color: #666;
    color: #efece6;
}

.btn-neon-green .btn-bg:before,
.btn-neon-green:focus .btn-bg:before {
    background-color: #00d275;
}

.container {
    margin-left: auto;
    margin-right: auto;
    /*max-width: 1640px;
    padding-left: var(--gutter);
    padding-right: calc(var(--gutter)*2);*/
    width: 100%;
}

.navbar {
    align-items: center;
    flex-wrap: wrap;
    justify-content: space-between;
    position: relative;
}

.navbar,
.navbar .container {
    display: flex;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline: 0;
}

header {
    left: 0;
    pointer-events: none;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 2019;
}

.navbar {
    border-radius: 0;
    margin: 0;
    min-height: var(--navbarH);
    padding: 0;
    background: rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(5px);
}

@media (min-width: 768px) {
    .navbar {
        min-height: var(--navbarH);
    }
}

.navbar .container {
    justify-content: space-between;
    position: static;
}

@media (min-width: 1280px) {
    .navbar .container {
        justify-content: space-between;
        position: relative;
    }
}

.navbar-actions {
    display: none;
    flex: 1;
    text-align: right;
    padding-top: 0.5rem;
}

@media (min-width: 1280px) {
    .navbar-actions {
        display: block;
    }
}

.navbar-actions .navbar-nav {
    pointer-events: auto;
}

.navbar-actions .navbar-nav>.nav-item {
    margin: 0;
}

.navbar-actions .btn {
    white-space: nowrap;
}

.navbar-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    width: 100%;
    z-index: 1000;
}

@media (min-width: 1280px) {
    .navbar-header {
        display: flex;
        flex: 1;
        width: auto;
    }
}

.navbar-header .navbar-brand,
.navbar-header .navbar-menu-toggler {
    pointer-events: auto;
}

@media (min-width: 1280px) {

    .navbar-actions,
    .navbar-header {
        flex: 1;
    }
}

.navbar-nav {
    align-items: center;
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
}

@media (min-width: 1280px) {
    .navbar-nav {
        align-items: center;
        flex-direction: row;
        justify-content: flex-start;
        margin-left: 0;
        margin-right: 0;
    }
}

.navbar-nav .nav-item {
    margin: 16px 0;
    opacity: 0;
    transform: translateY(20px);
}

@media (min-width: 1280px) {
    .navbar-nav .nav-item {
        border: 0;
        margin: 0 24px;
        opacity: unset;
        padding: 0;
        transform: unset;
    }
}

.navbar-nav .nav-item>.nav-link {
    color: #FFF;
    display: flex;
    font-family: "CabinetGrotesk-Black", sans-serif;
    font-size: 0.9rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 1;
    position: relative;
}

.navbar-nav .nav-item>.nav-link:hover {
    color: #00d275;
}

.navbar-nav .nav-item>.nav-link::before {
    content: '';
    background-color: hsla(0, 0%, 0%, 0.75);
    position: absolute;
    left: 0;
    bottom: 3px;
    width: 100%;
    height: 0;
    z-index: -1;
    transition: all .3s ease-in-out;
}

.navbar-nav .nav-item>.nav-link:hover::before {
    bottom: 0;
    height: 100%;
}

@media (min-width: 1280px) {
    .navbar-nav .nav-item>.nav-link {
        border-bottom: 0;
        display: inline-block;
        font-family: "CabinetGrotesk-Black", sans-serif;
        font-weight: 500;
        padding: 0;
    }
}

@media (min-width: 1280px) {
    .navbar-nav .nav-item>.nav-link:focus {
        background-color: transparent;
    }
}

.navbar-menu-toggler {
    background: none;
    border: 0;
    color: #efece6;
    display: block;
    height: 32px;
    padding: 0 4px;
    width: 32px;
    z-index: 1000;
}

@media (min-width: 1280px) {
    .navbar-menu-toggler {
        display: none;
    }
}

.navbar-menu-toggler>span {
    background: currentColor;
    display: block;
    height: 2px;
    width: 24px;
}

.navbar-menu-toggler>span+span {
    margin-top: 4px;
}

.navbar-brand {
    color: currentColor;
    display: inline-block;
    height: 100%;
    margin: 0;
    padding: 0;
    width: auto;
    z-index: 1000;
    padding-top: 1rem;
}

/*
@media (min-width: 768px) {
    .navbar-brand {
        height: 64px;
    }
}*/

.navbar-brand img,
.navbar-brand svg {
    display: block;
    max-height: 100%;
    width: 50%;
}

.navbar-menu {
    -webkit-overflow-scrolling: touch;
    display: none;
    flex-direction: column;
    height: 100%;
    left: 0;
    overflow: auto;
    padding: var(--navbarH) 20px;
    pointer-events: auto;
    position: absolute;
    top: 0;
    width: 100%;
}

.navbar-menu img {
    max-width: 1.5rem;
    max-height: 1.5rem;
    margin-right: 1rem;
}

@media (min-width: 1280px) {
    .navbar-menu {
        align-items: center;
        background: transparent;
        display: flex;
        flex-direction: row;
        height: auto;
        justify-content: center;
        margin-left: 0;
        overflow: unset;
        padding: 0;
        position: static;
        width: auto;
    }

    .navbar-menu img.first {
        margin-left: 5rem;
    }
}

.menu-open {
    display: flex;
}

.menu-is-open {
    overflow: hidden;
}

.menu-is-open header {
    height: 100%;
}

.menu-is-open .navbar-header {
    min-height: var(--navbarH);
}

.menu-is-open .navbar {
    align-items: flex-start;
    border-bottom: 1px solid hsla(0, 0%, 6%, 0.1);
    color: #0f0f0f;
    height: 100%;
}

.menu-is-open .navbar .btn-primary {
    background: #0f0f0f;
    border-color: #0f0f0f;
    color: #efece6;
}

.menu-is-open .navbar-nav {
    flex-grow: 1;
}

.menu-is-open .navbar-nav .nav-link.js-toggle-navigation:after,
.menu-is-open .navbar-nav .nav-link[data-toggle="dropdown"]:after {
    -webkit-filter: none;
    filter: none;
}

.menu-is-open .navbar-menu-toggler>span {
    transition-delay: 0s;
}

.menu-is-open .navbar-menu-toggler>span:first-of-type {
    transform: rotate(45deg);
}

.menu-is-open .navbar-menu-toggler>span:nth-of-type(2) {
    margin-top: -2px;
    transform: rotate(-45deg);
}

.menu-is-open .navbar-menu-toggler>span:nth-of-type(3) {
    display: none;
}

.background-bubble {
    background: #0f0f0f;
    border-radius: 50%;
    display: none;
    height: 10px;
    position: fixed;
    right: 0;
    top: 0;
    width: 10px;
    z-index: 100;
}

body {
    overflow: hidden;
}

.intro {
    --size: 80;
    --relativeWidth: 860;
    --relativeHeight: 422;
    background: #0f0f0f;
    display: flex;
    inset: 0;
    position: fixed;
    z-index: 2030;
}

.intro .intro-logo {
    backface-visibility: hidden;
    display: inline-block;
    transform: translateZ(0);
    will-change: transform, filter;
}

.intro .intro-logo img,
.intro .intro-logo svg {
    display: block;
    width: auto;
}

.intro .intro-logo svg {
    height: 192px;
}

.intro .intro-logo .family-neon {
    -webkit-backface-visibility: hidden;
    position: relative;
    -webkit-transform-style: preserve-3d;
}

@media (min-width: 768px) {
    .intro {
        --size: 160;
    }
}

.intro .intro-logo .family-neon .text {
    height: calc(var(--size) * 1px);
}

.intro .intro-logo .family-neon .elephant {
    animation: flicker-1 4s linear forwards;
    height: calc(280 / var(--relativeHeight) * 100%);
    left: calc(524 / var(--relativeWidth) * 100%);
    position: absolute;
    top: calc(-70 / var(--relativeHeight) * 100%);
    width: auto;
    will-change: filter;
}

.intro .intro-logo .family-neon .live {
    animation: flicker-2 3s linear forwards;
    height: calc(216 / var(--relativeHeight) * 100%);
    left: calc(520 / var(--relativeWidth) * 100%);
    position: absolute;
    top: calc(294 / var(--relativeHeight) * 100%);
    width: auto;
    will-change: filter;
}

@keyframes flicker-1 {

    0%,
    19.999%,
    22%,
    62.999%,
    64%,
    64.999%,
    70% {
        -webkit-filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) opacity(0.99);
        filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) opacity(0.99);
    }

    20%,
    21.999%,
    63%,
    63.999%,
    65%,
    69.999% {
        -webkit-filter: drop-shadow(0 0 12px transparent) brightness(120%) grayscale(100%) opacity(0.4);
        filter: drop-shadow(0 0 12px transparent) brightness(120%) grayscale(100%) opacity(0.4);
    }

    85%,
    95% {
        -webkit-filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) grayscale(0) opacity(0.99);
        filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) grayscale(0) opacity(0.99);
    }

    80%,
    to {
        -webkit-filter: drop-shadow(0 0 12px #63cfe3) brightness(120%) saturate(240%) grayscale(0) opacity(0.99);
        filter: drop-shadow(0 0 12px #63cfe3) brightness(120%) saturate(240%) grayscale(0) opacity(0.99);
    }
}

@keyframes flicker-2 {

    0%,
    19.999%,
    22%,
    62.999%,
    64%,
    64.999%,
    70% {
        -webkit-filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) opacity(0.99);
        filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) opacity(0.99);
    }

    20%,
    21.999%,
    63%,
    63.999%,
    65%,
    69.999% {
        -webkit-filter: drop-shadow(0 0 12px transparent) brightness(120%) grayscale(100%) opacity(0.4);
        filter: drop-shadow(0 0 12px transparent) brightness(120%) grayscale(100%) opacity(0.4);
    }

    85%,
    95% {
        -webkit-filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) grayscale(0) opacity(0.99);
        filter: drop-shadow(0 0 12px transparent) brightness(120%) saturate(120%) grayscale(0) opacity(0.99);
    }

    80%,
    to {
        -webkit-filter: drop-shadow(0 0 12px #ec2180) brightness(120%) saturate(240%) grayscale(0) opacity(0.99);
        filter: drop-shadow(0 0 12px #ec2180) brightness(120%) saturate(240%) grayscale(0) opacity(0.99);
    }
}

.intro .intro-container {
    align-items: center;
    display: flex;
    flex: 1;
    justify-content: center;
}

.intro .intro-progress-bar {
    background: #00d275;
    height: 4px;
    left: 0;
    position: absolute;
    top: 0;
}

@keyframes fadeIn {
    0% {
        opacity: 0;
    }
}

.grid {
    display: grid;
}

.grid-3-desktop {
    gap: 40px 20px;
    grid-template: auto/repeat(1, 1fr);
}

@media (min-width: 768px) {
    .grid-3-desktop {
        gap: 40px;
        grid-template: auto/repeat(3, 1fr);
    }
}

@media (min-width: 1280px) {
    .grid-3-desktop {
        gap: 80px;
    }
}

@media (min-width: 768px) {
    .grid-uneven> :last-of-type {
        grid-area: auto/span 2;
    }
}

@media (min-width: 1280px) {
    .grid-uneven> :last-of-type {
        grid-area: auto;
    }
}

.section {
    background: #fff;
    padding: var(--sectionPaddingY) 0;
    position: relative;
}

.shared-heading,
.shared-heading .heading {
    margin-bottom: clamp(60px, 7.0052539405vw, 120px);
    margin-top: clamp(60px, 7.0052539405vw, 120px);
}

.shared-heading .heading {
    color: #00d275;
    font-size: 3rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 2.5rem;
    white-space: nowrap;
}

.shared-heading .stroke {
    --borderWidth: clamp(1px, 0.1167542323vw, 2px);
    color: currentColor;
    display: inline-block;
    text-shadow: calc(var(--borderWidth) * -1) calc(var(--borderWidth) * -1) 0 currentColor, var(--borderWidth) calc(var(--borderWidth) * -1) 0 currentColor, calc(var(--borderWidth) * -1) var(--borderWidth) 0 currentColor,
        var(--borderWidth) var(--borderWidth) 0 currentColor;
}

@supports (-webkit-text-stroke: var(--borderWidth) #efece6) {
    .shared-heading .stroke {
        -webkit-text-stroke: var(--borderWidth) #efece6;
        text-shadow: none;
    }
}

.hero-layout {
    display: flex;
    flex-flow: column nowrap;
}

@media (min-width: 768px) {
    .hero-layout {
        align-items: center;
        flex-flow: row nowrap;
        justify-content: space-between;
    }
}

.hero-content {
    margin-bottom: 40px;
    position: relative;
}

@media (min-width: 768px) {
    .hero-content {
        margin-bottom: 0;
        margin-right: 60px;
        max-width: 760px;
    }
}

@media (min-width: 1280px) {
    .hero-content {
        margin-right: 80px;
    }
}

.hero-content .heading {
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 1440px) {
    .hero-content .heading {
        font-size: 125px;
    }
}

.hero-content .heading {
    font-size: 96px;
}

@media screen and (min-width: 1440px) {
    .hero-content .heading {
        font-size: 102px;
    }
}

.hero-content .paragraph {
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 24px;
    max-width: 520px;
}

@media screen and (min-width: 768px) {
    .hero-content .paragraph {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .hero-content .paragraph {
        font-size: 24px;
    }
}

@media (min-width: 1280px) {
    .hero-content .paragraph {
        margin-top: 40px;
    }
}

.hero-content .buttons {
    display: flex;
    flex-flow: row wrap;
    gap: 8px 10px;
    margin-top: 30px;
}

@media (min-width: 1280px) {
    .hero-content .buttons {
        flex-flow: row nowrap;
        gap: 12px 24px;
        margin-top: 50px;
    }

    .hero-content .buttons .btn {
        white-space: nowrap;
    }
}

.shared-hero {
    padding: var(--sectionPaddingY) 0;
}

@media (min-width: 768px) {
    .shared-hero {
        padding: calc(var(--navbarH) + var(--sectionPaddingY) / 2) 0 var(--sectionPaddingY);
    }
}

.shared-hero-content {
    position: relative;
}

.shared-hero-content .heading {
    font-size: 96px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .shared-hero-content .heading {
        font-size: calc(-86.85714px + 23.80952vw);
    }
}

@media screen and (min-width: 1440px) {
    .shared-hero-content .heading {
        font-size: 125px;
    }
}

.shared-hero-content .heading span {
    --borderWidth: clamp(1px, 0.1167542323vw, 2px);
    color: #0f0f0f;
    text-shadow: calc(var(--borderWidth) * -1) calc(var(--borderWidth) * -1) 0 #efece6, var(--borderWidth) calc(var(--borderWidth) * -1) 0 #efece6, calc(var(--borderWidth) * -1) var(--borderWidth) 0 #efece6,
        var(--borderWidth) var(--borderWidth) 0 #efece6;
}

@supports (-webkit-text-stroke: var(--borderWidth) #efece6) {
    .shared-hero-content .heading span {
        -webkit-text-stroke: var(--borderWidth) #efece6;
        text-shadow: none;
    }
}

.shared-hero-content .paragraph {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 30px;
    max-width: 620px;
}

@media screen and (min-width: 768px) {
    .shared-hero-content .paragraph {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .shared-hero-content .paragraph {
        font-size: 24px;
    }
}

@media (min-width: 768px) {
    .shared-hero-content .paragraph {
        margin-top: 40px;
    }
}

.shared-hero-content .buttons {
    display: inline-flex;
    flex-flow: row wrap;
    gap: 8px 10px;
    margin-top: 40px;
}

@media (min-width: 768px) {
    .shared-hero-content .buttons {
        gap: 12px 24px;
        margin-top: 50px;
    }
}

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

.shared-hero-center .paragraph {
    margin-left: auto;
    margin-right: auto;
}

.hero-media {
    flex-shrink: 0;
}

.section-hero-home {
    overflow: hidden;
}

@media (max-width: 1279px) {
    .section-hero-home {
        padding-bottom: 0;
    }
}

.section-hero-home .hero-content {
    text-align: center;
}

@media (min-width: 768px) {
    .section-hero-home .hero-content {
        text-align: left;
    }
}

.section-hero-home .hero-content .paragraph {
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 768px) {
    .section-hero-home .hero-content .paragraph {
        margin-left: 0;
        margin-right: 0;
    }
}

.section-hero-home .hero-content .buttons {
    display: inline-flex;
    justify-content: center;
}

@media (min-width: 768px) {
    .section-hero-home .hero-content .buttons {
        justify-content: flex-start;
    }
}

.section-hero-home .hero-content .heading {
    background-clip: text;
    -webkit-background-clip: text;
    background-image: url(https://media2.giphy.com/media/HkEDr0jVekaZO/giphy.gif?cid=790b76115151ed408a9cae4539eb6351baba5d85998ab783&ct=g&rid=giphy.gif);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
}

.section-hero-home .hero-content .heading:before {
    background-color: #efece6;
    content: "";
    height: 100%;
    left: 0;
    mix-blend-mode: multiply;
    position: absolute;
    top: 0;
    transition: opacity 0.6s;
    width: 100%;
}

.section-hero-home .hero-content .heading.bg-gif:before {
    opacity: 0;
}

.home-intro-video {
    display: flex;
    justify-content: center;
    position: relative;
}

@media (min-width: 768px) {
    .home-intro-video {
        width: clamp(740px, 67.3003802281vw, 1010px);
    }
}

.home-intro-video video {
    display: block;
    height: 100%;
    width: 100%;
}

@media (min-width: 768px) {
    .home-intro-video video {
        height: 105%;
        margin: -2.5%;
        width: 105%;
    }
}

.intro-grid {
    display: grid;
    gap: 20px;
    grid-template: auto/1fr;
}

@media (min-width: 1280px) {
    .intro-grid {
        gap: 40px;
    }
}

.intro-grid .row {
    display: grid;
    gap: 20px;
    grid-template: auto/repeat(3, minmax(0, clamp(200px, 18.6vw, 280px)));
}

@media (min-width: 1280px) {
    .intro-grid .row {
        gap: 40px;
    }
}

@media (min-width: 768px) {

    .intro-grid .row:first-child,
    .intro-grid .row:nth-child(3) {
        margin-left: 90px;
    }
}

.intro-grid .image {
    border-radius: clamp(16px, 3.5vw, 48px);
    overflow: hidden;
    position: relative;
}

.intro-grid .image:before {
    content: "";
    display: block;
    padding-bottom: 68.75%;
}

.intro-grid .image img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.parallax-container {
    position: relative;
}

.parallax-background-section {
    color: #0f0f0f;
    overflow: hidden;
    position: relative;
    top: 0;
}

.pbe-1 {
    background: url(https://images.unsplash.com/photo-1640270914397-2103d0a16eeb?crop=entropy&cs=srgb&fm=jpg&ixid=MnwxNDU4OXwwfDF8cmFuZG9tfHx8fHx8fHx8MTY0MTcwNTk2MQ&ixlib=rb-1.2.1&q=85);
}

.pbe-2 {
    background: url(https://images.unsplash.com/photo-1641273272565-c779149efd6d?crop=entropy&cs=srgb&fm=jpg&ixid=MnwxNDU4OXwwfDF8cmFuZG9tfHx8fHx8fHx8MTY0MTcwNjAzMg&ixlib=rb-1.2.1&q=85);
}

.pbe-3 {
    background: url(https://images.unsplash.com/photo-1640270914397-2103d0a16eeb?crop=entropy&cs=srgb&fm=jpg&ixid=MnwxNDU4OXwwfDF8cmFuZG9tfHx8fHx8fHx8MTY0MTcwNTk2MQ&ixlib=rb-1.2.1&q=85);
}

.parallax-background-element {
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    height: 100vh;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -1;
}

.parallax-element {
    left: 0;
    position: absolute;
    top: 0;
    z-index: 2;
}

.why-us-section {
    text-align: center;
}

.why-us-section .content {
    display: inline-block;
    position: relative;
    text-align: center;
}

.why-us-section .content .heading {
    font-size: 72px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
    position: relative;
    z-index: 2;
    color: #00d275;
}

@media screen and (min-width: 768px) {
    .why-us-section .content .heading {
        font-size: calc(-28.57143px + 13.09524vw);
    }
}

@media screen and (min-width: 1440px) {
    .why-us-section .content .heading {
        font-size: 160px;
    }
}

.why-us-section .content .paragraph {
    font-size: 1rem;
    line-height: 1.3;
    margin: 40px auto 0;
    max-width: 100%;
    position: relative;
    z-index: 2;
}

@media screen and (min-width: 768px) {
    .why-us-section .content .paragraph {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .why-us-section .content .paragraph {
        font-size: 24px;
    }
}

@media (min-width: 500px) {
    .why-us-section .content .paragraph {
        width: clamp(440px, 42.0315236427vw, 720px);
    }
}

.why-us-section .content .btn {
    margin-top: 50px;
    position: relative;
    z-index: 2;
}

.why-us-section .tags {
    display: none;
    pointer-events: none;
}

@media (min-width: 768px) {
    .why-us-section .tags {
        display: block;
    }
}

.why-us-section .tag {
    color: #0f0f0f;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1;
    padding: clamp(12px, 1.4010507881vw, 24px) clamp(16px, 1.8680677175vw, 32px);
    position: absolute;
    text-transform: uppercase;
    white-space: nowrap;
}

@media screen and (min-width: 768px) {
    .why-us-section .tag {
        font-size: calc(-2.28571px + 2.38095vw);
    }
}

@media screen and (min-width: 1440px) {
    .why-us-section .tag {
        font-size: 32px;
    }
}

.why-us-section .avatars {
    display: none;
    pointer-events: none;
}

@media (min-width: 768px) {
    .why-us-section .avatars {
        display: block;
    }
}

.why-us-section .avatar {
    border-radius: 50%;
    height: clamp(40px, 9.3403385873vw, 160px);
    overflow: hidden;
    position: absolute;
    width: clamp(40px, 9.3403385873vw, 160px);
}

.why-us-section .avatar img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.why-us-section .yellow {
    background: #ffe95c;
    left: calc(50% - 36.19381vw);
    top: 9.3403385873vw;
}

@media (min-width: 1280px) {
    .why-us-section .yellow {
        left: calc(50% - 30.3561vw);
        top: 9.3403385873vw;
    }
}

.why-us-section .texas {
    background: #ffaf5c;
    left: calc(50% - 4.67017vw);
    top: -8.4063047285vw;
}

@media (min-width: 1280px) {
    .why-us-section .texas {
        left: calc(50% - 4.67017vw);
        top: -8.4063047285vw;
    }
}

.why-us-section .violet {
    background: #00d275;
    left: calc(50% + 26.85347vw);
    top: -0.9340338587vw;
}

@media (min-width: 1280px) {
    .why-us-section .violet {
        left: calc(50% + 23.35085vw);
        top: -0.9340338587vw;
    }
}

.why-us-section .watermelon {
    background: #ff5c7d;
    bottom: -0.9340338587vw;
    left: calc(50% + 16.34559vw);
}

@media (min-width: 1280px) {
    .why-us-section .watermelon {
        bottom: -0.9340338587vw;
        left: calc(50% + 11.67542vw);
    }
}

.logos {
    transform: scale(0.6) translateX(-50%);
}

@media (min-width: 768px) {
    .logos {
        transform: scale(1);
    }
}

.logos .loop-track {
    align-items: center;
}

.logos .item {
    padding: 0 40px;
}

.logos img {
    opacity: 0.6;
    width: auto;
}

.mini-cases {
    margin-top: clamp(20px, 4.6701692936vw, 80px);
}

.mini-cases-masks {
    height: 0;
    position: absolute;
    width: 0;
}

.mini-cases .clip-1 {
    clip-path: url(#clip-1);
}

@-moz-document url-prefix() {
    .mini-cases .clip-1 {
        clip-path: none;
    }
}

.mini-cases .clip-2 {
    clip-path: url(#clip-2);
}

@-moz-document url-prefix() {
    .mini-cases .clip-2 {
        clip-path: none;
    }
}

.mini-cases .clip-3 {
    clip-path: url(#clip-3);
}

@-moz-document url-prefix() {
    .mini-cases .clip-3 {
        clip-path: none;
    }
}

.mini-cases .clip-4 {
    clip-path: url(#clip-4);
}

@-moz-document url-prefix() {
    .mini-cases .clip-4 {
        clip-path: none;
    }
}

.mini-cases .mini-case {
    margin: 0 10px;
    overflow: hidden;
    position: relative;
    width: 120px;
}

@-moz-document url-prefix() {
    .mini-cases .mini-case {
        border-radius: 32px;
    }
}

@media (min-width: 768px) {
    .mini-cases .mini-case {
        margin: 0 20px;
        width: 300px;
    }
}

.mini-cases .mini-case.clip-2 {
    width: 96px;
}

@media (min-width: 768px) {
    .mini-cases .mini-case.clip-2 {
        width: 240px;
    }
}

.mini-cases .mini-case:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.mini-cases .mini-case.clip-2:before {
    padding-bottom: 125%;
}

.mini-cases .mini-case img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

img.lazyload:not([src]),
img.ls-blur-up-is-loading {
    visibility: hidden;
}

.ls-blur-up-img {
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
}

.ls-blur-up-img,
img.lazyload {
    font-family: "blur-up: auto", "object-fit: cover";
    -o-object-fit: cover;
    object-fit: cover;
}

.ls-blur-up-img {
    background: #1c1c1c;
    -webkit-filter: blur(16px);
    filter: blur(16px);
    opacity: 1;
    transform: scale(2);
    transition: opacity 0.2s, -webkit-filter 0.2s;
    transition: opacity 0.2s, filter 0.2s;
    transition: opacity 0.2s, filter 0.2s, -webkit-filter 0.2s;
}

.ls-blur-up-img.ls-inview.ls-original-loaded {
    -webkit-filter: blur(16px);
    filter: blur(16px);
    opacity: 0;
}

.the-experience-section .heading {
    font-size: 96px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
    margin-bottom: clamp(60px, 7.0052539405vw, 120px);
}

@media screen and (min-width: 768px) {
    .the-experience-section .heading {
        font-size: calc(-86.85714px + 23.80952vw);
    }
}

@media screen and (min-width: 1440px) {
    .the-experience-section .heading {
        font-size: 125px;
    }
}

.the-experience-section .heading span {
    --borderWidth: clamp(1px, 0.1167542323vw, 2px);
    color: #0f0f0f;
    text-shadow: calc(var(--borderWidth) * -1) calc(var(--borderWidth) * -1) 0 #efece6, var(--borderWidth) calc(var(--borderWidth) * -1) 0 #efece6, calc(var(--borderWidth) * -1) var(--borderWidth) 0 #efece6,
        var(--borderWidth) var(--borderWidth) 0 #efece6;
}

@supports (-webkit-text-stroke: var(--borderWidth) #efece6) {
    .the-experience-section .heading span {
        -webkit-text-stroke: var(--borderWidth) #efece6;
        text-shadow: none;
    }
}

.the-experience-horizontal-scroller {
    align-items: center;
    display: flex;
}

.the-experience-horizontal {
    display: flex;
    flex-direction: row;
    flex-shrink: 0;
    gap: clamp(120px, 9.3403385873vw, 160px);
}

.the-experience-horizontal .card {
    flex-shrink: 0;
    transform: rotate(-4deg);
    width: clamp(332px, 31.0566258027vw, 532px);
    will-change: transform;
}

.the-experience-horizontal .card:nth-child(2n) {
    transform: rotate(4deg);
}

.the-experience-horizontal .card .thumb {
    overflow: hidden;
    position: relative;
}

.the-experience-horizontal .card .thumb:before {
    content: "";
    display: block;
    padding-bottom: 135.3383458647%;
}

.the-experience-horizontal .card .thumb img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.the-experience-horizontal .card .text {
    position: relative;
    z-index: 2;
}

.the-experience-horizontal .card .heading {
    font-size: 48px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 90%;
    line-height: 80%;
    margin-top: -0.375em;
    text-align: center;
    white-space: nowrap;
}

@media screen and (min-width: 768px) {
    .the-experience-horizontal .card .heading {
        font-size: calc(-43.42857px + 11.90476vw);
    }
}

@media screen and (min-width: 1440px) {
    .the-experience-horizontal .card .heading {
        font-size: 128px;
    }
}

.swiper-home {
    --swiper-pagination-bullet-inactive-color: #efece6;
    --swiper-pagination-color: #efece6;
    --swiper-pagination-bullet-horizontal-gap: 10px;
    --swiper-pagination-bullet-width: 24px;
    --swiper-pagination-bullet-height: 3px;
    --swiper-pagination-bullet-size: 8px;
    margin: 0 calc(var(--gutter) * -1);
    position: relative;
}

@media (min-width: 500px) {
    .swiper-home {
        margin: 0;
    }
}

.swiper-home .swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets,
.swiper-home .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets {
    bottom: unset;
    display: flex;
    justify-content: center;
    left: unset;
    margin-top: clamp(40px, 4.6701692936vw, 80px);
    position: relative;
}

.swiper-home .swiper-pagination-bullet {
    border-radius: 3px;
}

.swiper-home .buttons {
    display: flex;
    justify-content: center;
    margin-top: clamp(40px, 4.6701692936vw, 80px);
}

.swiper-home .home-slide {
    display: grid;
    grid-template: auto/1fr;
    overflow: hidden;
    pointer-events: auto;
}

@media (min-width: 500px) {
    .swiper-home .home-slide {
        border-radius: 32px;
    }
}

@media (min-width: 768px) {
    .swiper-home .home-slide {
        grid-template: auto/repeat(2, 1fr);
    }
}

.swiper-home .home-slide .content {
    align-items: center;
    color: #0f0f0f;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(60px, 4.6701692936vw, 80px) clamp(40px, 4.6701692936vw, 80px);
    text-align: center;
}

@media (max-width: 767px) {
    .swiper-home .home-slide .content br {
        display: none;
    }
}

.swiper-home .media {
    overflow: hidden;
    position: relative;
}

.swiper-home .media:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.swiper-home .media img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.swiper-home .heading {
    font-size: 64px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
    margin-bottom: 30px;
}

@media screen and (min-width: 768px) {
    .swiper-home .heading {
        font-size: calc(27.42857px + 4.7619vw);
    }
}

@media screen and (min-width: 1440px) {
    .swiper-home .heading {
        font-size: 96px;
    }
}

.swiper-home .heading span {
    --borderWidth: clamp(1px, 0.1167542323vw, 2px);
    color: currentColor;
    display: block;
    text-shadow: calc(var(--borderWidth) * -1) calc(var(--borderWidth) * -1) 0 currentColor, var(--borderWidth) calc(var(--borderWidth) * -1) 0 currentColor, calc(var(--borderWidth) * -1) var(--borderWidth) 0 currentColor,
        var(--borderWidth) var(--borderWidth) 0 currentColor;
}

@supports (-webkit-text-stroke: var(--borderWidth) #0f0f0f) {
    .swiper-home .heading span {
        -webkit-text-stroke: var(--borderWidth) #0f0f0f;
        text-shadow: none;
    }
}

.swiper-home .paragraph {
    font-size: 1rem;
}

@media (min-width: 768px) {
    .swiper-home .paragraph {
        font-size: 18px;
    }
}

.swiper-home .paragraph+.paragraph {
    margin-top: 0.75em;
}

.loop,
.loop-track {
    display: flex;
    flex-wrap: nowrap;
}

.loop-track {
    will-change: transform;
}

.loop-content {
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
}

.the-bridge-section .text {
    color: #efece6;
    font-size: 96px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
    margin-bottom: clamp(40px, 4.6701692936vw, 80px);
    white-space: nowrap;
}

@media screen and (min-width: 768px) {
    .the-bridge-section .text {
        font-size: calc(-86.85714px + 23.80952vw);
    }
}

@media screen and (min-width: 1440px) {
    .the-bridge-section .text {
        font-size: 125px;
    }
}

.the-bridge-section .text span {
    --borderWidth: clamp(1px, 0.1167542323vw, 2px);
    color: currentColor;
    display: inline-block;
    text-shadow: calc(var(--borderWidth) * -1) calc(var(--borderWidth) * -1) 0 currentColor, var(--borderWidth) calc(var(--borderWidth) * -1) 0 currentColor, calc(var(--borderWidth) * -1) var(--borderWidth) 0 currentColor,
        var(--borderWidth) var(--borderWidth) 0 currentColor;
}

@supports (-webkit-text-stroke: var(--borderWidth) #efece6) {
    .the-bridge-section .text span {
        -webkit-text-stroke: var(--borderWidth) #efece6;
        text-shadow: none;
    }
}

@media screen and (min-width: 768px) {
    .the-bridge-section .paragraph {
        font-size: calc(-21.71429px + 5.95238vw);
    }
}

@media screen and (min-width: 1440px) {
    .the-bridge-section .paragraph {
        font-size: 64px;
    }
}

.the-bridge-section .the-bridge-fluid {
    margin-top: clamp(40px, 4.6701692936vw, 80px);
}

.the-bridge-section .bridge-layout {
    display: grid;
    gap: 50px;
    grid-template: auto/minmax(0, 1fr);
}

@media (min-width: 768px) {
    .the-bridge-section .bridge-layout {
        align-items: center;
        gap: 80px;
        grid-template: auto/repeat(2, minmax(0, 1fr));
    }
}

.the-bridge-section .bridge-layout .content .heading {
    font-size: 3rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 2.5rem;
}

.the-bridge-section .bridge-layout .content .heading span {
    display: block;
}

.the-bridge-section .bridge-layout .content .paragraph {
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 40px;
    max-width: 510px;
}

.the-bridge-section .bridge-layout .content .buttons {
    margin-top: 40px;
}

.the-bridge-section .bridge-layout .media .image,
.the-bridge-section .bridge-layout .media .video {
    border-radius: 8px;
    overflow: hidden;
    position: relative;
}

.the-bridge-section .bridge-layout .media .image img,
.the-bridge-section .bridge-layout .media .video video {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.the-bridge-section .bridge-layout .media .image:before,
.the-bridge-section .floating-grid .item .video:before {
    content: "";
    display: block;
    padding-bottom: 58.6206896552%;
}

.the-bridge-section .bridge-layout .media .image:before,
.the-bridge-section .bridge-layout .media .video:before {
    content: "";
    display: block;
    padding-bottom: 144.0909090909%;
}

.the-bridge-fluid {
    list-style: none;
    margin: 0;
    padding: 0;
}

.the-bridge-fluid li {
    border-top: 1px solid hsla(40, 22%, 92%, 0.1);
}

.the-bridge-fluid li .content {
    align-items: center;
    display: flex;
    font-size: 1rem;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 1640px;
    padding: 0.66em var(--gutter);
    width: 100%;
}

.the-bridge-fluid li .paragraph {
    color: #efece6;
    font-size: 1rem;
    font-weight: 400;
}

.the-bridge-fluid li img {
    height: 1em;
    width: 1em;
}

.customization-experiences-section .slide {
    display: flex;
    flex-flow: row wrap;
}

.customization-experiences-section .content {
    max-width: clamp(604px, 52.7729130181vw, 904px);
}

.customization-experiences-section .media {
    flex: 1;
    min-width: 300px;
}

.customization-experiences-section .heading {
    font-size: 72px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .customization-experiences-section .heading {
        font-size: calc(-28.57143px + 13.09524vw);
    }
}

@media screen and (min-width: 1440px) {
    .customization-experiences-section .heading {
        font-size: 160px;
    }
}

.customization-experiences-section .paragraph {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 40px;
    max-width: 560px;
}

@media screen and (min-width: 768px) {
    .customization-experiences-section .paragraph {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .customization-experiences-section .paragraph {
        font-size: 24px;
    }
}

.customization-experiences-section .buttons {
    margin-top: 50px;
}

.matter-pills {
    min-height: 100%;
    position: relative;
}

.matter-pills:before {
    content: "";
    display: block;
    padding-bottom: 50%;
}

@media (min-width: 1280px) {
    .matter-pills:before {
        padding-bottom: 100%;
    }
}

.matter-pills canvas {
    height: 100% !important;
    left: 0;
    position: absolute;
    top: 0;
    width: 100% !important;
}

.matter-pills .pill {
    display: none;
}

@media (max-width: 767px) {
    .featured-cases-section .shared-heading .heading {
        font-size: 50px;
    }

    .why-us-section .content .heading {
        font-size: 54px;
    }

    .hero-content .heading {
        font-size: 50px;
    }
}

@media screen and (max-width: 767px) and (min-width: 1440px) {
    .featured-cases-section .shared-heading .heading {
        font-size: 128px;
    }
}

.featured-cases-module {
    --padding-x: 20px;
    margin: 0 calc(var(--padding-x) / 2 * -1);
    padding: 0 var(--padding-x);
}

.featured-cases-module .featured-cases-track {
    display: flex;
    flex-direction: column;
    row-gap: 40px;
}

@media (min-width: 768px) {
    .featured-cases-module .featured-cases-track {
        flex-direction: row;
        row-gap: 0;
    }
}

.featured-case {
    --caption-h: 48px;
    --case-units: 5;
    --case-unit-scale: 10%;
    --case-unit-width: 100 / var(--case-units) * 0.1;
    --case-unit-height: 64.01766vh;
    padding-left: calc(var(--padding-x) / 2);
    padding-right: calc(var(--padding-x));
    position: relative;
}

@media (min-width: 768px) {
    .featured-case {
        padding-bottom: var(--caption-h);
        transition: width 0.6s cubic-bezier(0.38, 0.005, 0.215, 1), flex-shrink 0.6s cubic-bezier(0.38, 0.005, 0.215, 1);
        width: calc(var(--case-unit-width) * var(--case-unit-scale));
    }
}

.featured-case .thumb {
    border-radius: 16px;
    display: block;
    overflow: hidden;
    position: relative;
}

.featured-case .thumb img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.featured-case .thumb:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

@media (min-width: 768px) {
    .featured-case .thumb:before {
        padding-bottom: var(--case-unit-height);
    }
}

.featured-case .caption {
    padding-top: 20px;
}

@media (min-width: 768px) {
    .featured-case .caption {
        bottom: 0;
        height: var(--caption-h);
        position: absolute;
        width: calc(100% - var(--padding-x));
    }
}

.featured-case .caption .title {
    font-family: "CabinetGrotesk-Black", sans-serif;
    font-size: 24px;
    font-weight: 300;
    letter-spacing: 0.02em;
    line-height: 1;
}

@media (min-width: 768px) {
    .featured-case .caption .title {
        opacity: 0;
        transition: opacity 0.3s cubic-bezier(0.38, 0.005, 0.215, 1) 0.3s;
        white-space: nowrap;
    }
}

.featured-case .caption .location {
    color: #101010;
    font-size: 1rem;
    line-height: 1;
}

@media (min-width: 768px) {
    .featured-case .caption .location {
        opacity: 0;
        transition: opacity 0s cubic-bezier(0.38, 0.005, 0.215, 1) 0s;
        white-space: nowrap;
    }
}

.featured-case .caption-grid {
    align-items: baseline;
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    justify-content: space-between;
}

@media (min-width: 768px) {
    .featured-cases-track:hover .featured-case .caption .title {
        opacity: 0;
        transition-delay: 0s;
        transition-duration: 0s;
    }
}

@media (min-width: 768px) {
    .featured-cases-track:hover .featured-case:hover .caption .title {
        opacity: 1;
    }
}

@media (min-width: 768px) {
    .featured-case:hover {
        flex-shrink: 0;
        width: var(--case-unit-height);
    }
}

.featured-case:hover .caption .title {
    opacity: 1;
}

.featured-case:hover .caption .location {
    opacity: 1;
    transition-delay: 0.3s;
    transition-duration: 0.3s;
}

.blog-post .thumb {
    border-radius: 16px;
    display: block;
    overflow: hidden;
    position: relative;
}

@media (min-width: 768px) {
    .blog-post .thumb {
        border-radius: 32px;
    }
}

.blog-post .thumb img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    transition: transform 0.6s cubic-bezier(0.38, 0.005, 0.215, 1);
    width: 100%;
}

.blog-post:hover .thumb img {
    transform: scale(1.05);
}

.blog-post .thumb:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.blog-post .content {
    padding-top: 20px;
}

@media (min-width: 768px) {
    .blog-post .content {
        padding-top: 40px;
    }
}

.blog-post .content .category {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
}

.blog-post .content .title {
    font-family: "Synonym-Regular", sans-serif;
    font-size: 24px;
    line-height: 1.3;
    margin-top: 12px;
}

@media (min-width: 768px) {
    .blog-post .content .title {
        font-size: 32px;
        margin-top: 20px;
    }
}

.blog-post .content .date {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 12px;
}

@media (min-width: 768px) {
    .blog-post .content .date {
        margin-top: 20px;
    }
}

.blog-post .buttons {
    margin-top: 20px;
}

@media (min-width: 768px) {
    .blog-post .buttons {
        margin-top: 30px;
    }
}

.call-to-action {
    display: grid;
    grid-template: auto/1fr 1fr;
}

.call-to-action .block {
    align-items: center;
    display: flex;
    justify-content: center;
    overflow: hidden;
    position: relative;
}

.call-to-action .block:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.call-to-action .ribbon {
    color: #0f0f0f;
    overflow: hidden;
    padding: 6px 10px;
    position: relative;
    width: 100%;
    z-index: 2;
}

.call-to-action .ribbon svg {
    height: auto;
    width: clamp(12px, 2.3350846468vw, 40px);
}

.call-to-action .text {
    align-items: center;
    display: flex;
    font-size: clamp(16px, 1.8680677175vw, 32px);
    font-weight: 700;
    line-height: 1;
    text-transform: uppercase;
    white-space: nowrap;
}

.call-to-action .text>div {
    align-items: center;
    display: flex;
    padding: clamp(5px, 0.8756567426vw, 15px);
}

.call-to-action .thumb {
    overflow: hidden;
}

.call-to-action .thumb,
.call-to-action .thumb img {
    display: block;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
}

.call-to-action .thumb img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.call-to-action .thumb:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.call-to-action .block:hover .thumb img {
    transform: scale(1.025);
}

.block.join-us {
    margin-bottom: 7.0052539405vw;
    margin-top: 3.5026269702vw;
    transform: rotate(-10deg);
    z-index: 2;
}

.block.join-us .ribbon {
    background: #ffe95c;
}

.block.case-studies {
    margin-bottom: 3.5026269702vw;
    margin-top: 7.0052539405vw;
    transform: rotate(10deg);
}

.block.case-studies .ribbon {
    background: #5cfff1;
}

.interactive-cta {
    color: #efece6;
    display: flex;
    flex-direction: column;
    font-family: "CabinetGrotesk-Black", sans-serif;
    font-size: clamp(40px, 7.4722708698vw, 128px);
    font-weight: 900;
    gap: 10px;
    letter-spacing: 0.02em;
    line-height: 80%;
    padding: 0;
    transition: background 0.3s ease;
}

@media (min-width: 500px) {
    .interactive-cta {
        background: #1e1e1e;
        padding: clamp(40px, 7.0052539405vw, 120px);
    }
}

.interactive-cta:hover {
    background: #171717;
}

.interactive-cta .row {
    align-items: center;
    display: flex;
    gap: 10px;
}

@media (min-width: 500px) {
    .interactive-cta .row {
        gap: 20px;
    }
}

.interactive-cta .image {
    border-radius: 1em;
    flex: 1;
    height: 0.7em;
    overflow: hidden;
    position: relative;
}

.interactive-cta .image img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.interactive-cta .image:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.interactive-cta .action {
    align-items: center;
    border-radius: 1em;
    display: flex;
    flex-grow: 1;
    height: 0.7em;
    overflow: hidden;
    position: relative;
    transition: -webkit-filter 0.3s ease;
    transition: filter 0.3s ease;
    transition: filter 0.3s ease, -webkit-filter 0.3s ease;
    white-space: nowrap;
}

.interactive-cta:hover .action {
    -webkit-filter: hue-rotate(20deg);
    filter: hue-rotate(20deg);
}

.interactive-cta .action.bg-violet .inner,
.interactive-cta .action.bg-yellow .inner {
    width: 100vw;
}

.interactive-cta .action svg {
    height: auto;
    width: clamp(12px, 2.3350846468vw, 40px);
}

.interactive-cta .text {
    flex-shrink: 0;
}

.interactive-cta .content {
    align-items: center;
    color: #0f0f0f;
    display: flex;
    font-family: "Synonym-Regular", sans-serif;
    font-size: clamp(16px, 1.8680677175vw, 32px);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}

.interactive-cta .content>div {
    align-items: center;
    display: flex;
    padding: 0 5px;
}

@media (min-width: 500px) {
    .interactive-cta .content>div {
        padding: 0 15px;
    }
}

.interactive-cta .text span {
    --borderWidth: clamp(1px, 0.1167542323vw, 2px);
    color: currentColor;
    display: inline-block;
    text-shadow: calc(var(--borderWidth) * -1) calc(var(--borderWidth) * -1) 0 currentColor, var(--borderWidth) calc(var(--borderWidth) * -1) 0 currentColor, calc(var(--borderWidth) * -1) var(--borderWidth) 0 currentColor,
        var(--borderWidth) var(--borderWidth) 0 currentColor;
}

@supports (-webkit-text-stroke: var(--borderWidth) #efece6) {
    .interactive-cta .text span {
        -webkit-text-stroke: var(--borderWidth) #efece6;
        text-shadow: none;
    }
}

.blog-masonry {
    display: grid;
    gap: 40px var(--gutter);
    grid-template: auto/repeat(1, 1fr);
}

@media (min-width: 768px) {
    .blog-masonry {
        gap: var(--gutter);
        grid-template: auto/repeat(2, 1fr);
    }
}

.blog-masonry .blog-post:nth-child(3n + 2) .thumb:before {
    padding-bottom: 60%;
}

.blog-masonry .blog-post:nth-child(3n + 3) .thumb:before {
    padding-bottom: 120%;
}

@media (min-width: 768px) {
    .blog-masonry .blog-post:nth-child(6n + 6) {
        margin-top: -60%;
    }
}

@media (min-width: 768px) {
    .blog-masonry .blog-post:nth-child(6n + 4) {
        margin-top: -40%;
    }
}

.article-cover {
    align-items: flex-end;
    display: flex;
    min-height: 100vh;
    padding: var(--sectionPaddingY) 0;
    position: relative;
}

@media (min-width: 768px) {
    .article-cover {
        padding: var(--navbarH) 0 calc(var(--sectionPaddingY) / 2);
    }
}

.article-cover .content {
    position: relative;
    text-align: center;
    z-index: 3;
}

.article-cover .content .title {
    font-size: 72px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .article-cover .content .title {
        font-size: calc(-28.57143px + 13.09524vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-cover .content .title {
        font-size: 160px;
    }
}

.article-cover .content .meta {
    color: #fff;
    display: inline-flex;
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 30px;
}

@media (min-width: 768px) {
    .article-cover .content .meta {
        font-size: 20px;
        margin-top: 60px;
    }
}

.article-cover .content .date:before {
    content: "//";
    margin-left: 20px;
    padding-right: 20px;
}

.article-cover-background {
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
}

.article-cover-background:before {
    background: linear-gradient(0deg, #0f0f0f, hsla(0, 0%, 6%, 0)), linear-gradient(50.43deg, hsla(0, 0%, 6%, 0.8) 27.37%, hsla(0, 0%, 6%, 0));
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}

.article-cover-background img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.article-body {
    display: grid;
    gap: 40px 120px;
    grid-template: auto/repeat(1, minmax(0, 1fr));
    margin-left: auto;
    margin-right: auto;
    max-width: 1640px;
    padding: 0 var(--gutter) var(--sectionPaddingY);
    position: relative;
    width: 100%;
}

@media (min-width: 768px) {
    .article-body {
        grid-template: auto/920px;
        justify-content: center;
        padding: 80px var(--gutter) var(--sectionPaddingY);
    }
}

.article-body .sidebar {
    color: hsla(40, 22%, 92%, 0.4);
    font-size: 1rem;
    font-weight: 400;
    line-height: 1;
    text-transform: uppercase;
}

.article-body .sidebar .row {
    display: flex;
    flex-flow: row wrap;
}

.article-body .sidebar .row+.row {
    margin-top: 8px;
}

.article-body .sidebar .row span {
    color: #efece6;
    margin-left: 0.35em;
}

.article-body .sidebar .share {
    align-items: center;
    display: flex;
    flex-flow: row wrap;
    gap: 24px;
    margin-top: 40px;
}

.article-body .ul-social {
    display: flex;
    gap: 24px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.article-body .ul-social img {
    height: 16px;
    width: 16px;
}

.article-body .content {
    margin: 0 calc(var(--gutter) * -1);
    overflow: hidden;
    padding: 0 var(--gutter) 0;
    position: relative;
}

@media (min-width: 768px) {
    .article-body .content {
        padding: 0 var(--gutter) 0;
    }
}

.article-body .content-format p {
    font-size: 1rem;
    line-height: 1.3;
}

@media screen and (min-width: 768px) {
    .article-body .content-format p {
        font-size: calc(11.42857px + 0.59524vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-body .content-format p {
        font-size: 20px;
    }
}

.article-body .content-format p+p {
    margin-top: 30px;
}

.article-body .content-format h1 {
    font-family: "Synonym-Regular", sans-serif;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.2;
    margin-bottom: 30px;
    margin-top: 60px;
}

@media screen and (min-width: 768px) {
    .article-body .content-format h1 {
        font-size: calc(5.71429px + 2.38095vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-body .content-format h1 {
        font-size: 40px;
    }
}

.article-body .content-format h2 {
    font-family: "Synonym-Regular", sans-serif;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.2;
    margin-bottom: 30px;
    margin-top: 60px;
}

@media screen and (min-width: 768px) {
    .article-body .content-format h2 {
        font-size: calc(14.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-body .content-format h2 {
        font-size: 32px;
    }
}

.article-body .content-format h3 {
    font-size: 40px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 100%;
    line-height: 80%;
    margin-bottom: 30px;
    margin-top: 60px;
}

@media screen and (min-width: 768px) {
    .article-body .content-format h3 {
        font-size: calc(12.57143px + 3.57143vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-body .content-format h3 {
        font-size: 64px;
    }
}

.article-body .content-format h4 {
    font-size: 32px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 100%;
    line-height: 80%;
    margin-bottom: 30px;
    margin-top: 60px;
}

@media screen and (min-width: 768px) {
    .article-body .content-format h4 {
        font-size: calc(13.71429px + 2.38095vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-body .content-format h4 {
        font-size: 48px;
    }
}

.article-body .content-format a {
    text-decoration: underline;
}

.article-body .content-format .image {
    margin: 60px 0;
    position: relative;
}

.article-body .content-format .image-container {
    display: block;
    margin: 60px 0;
    overflow: hidden;
    position: relative;
}

.article-body .content-format .image-container img {
    height: auto;
    width: 100%;
}

.article-footer .content {
    margin: 0 auto;
    max-width: 920px;
}

.article-footer .content .heading {
    font-size: 72px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
    margin-bottom: 40px;
}

@media screen and (min-width: 768px) {
    .article-footer .content .heading {
        font-size: calc(-28.57143px + 13.09524vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-footer .content .heading {
        font-size: 160px;
    }
}

.article-footer .content p {
    font-size: 1rem;
    line-height: 1.3;
    margin-bottom: 20px;
}

@media screen and (min-width: 768px) {
    .article-footer .content p {
        font-size: calc(11.42857px + 0.59524vw);
    }
}

@media screen and (min-width: 1440px) {
    .article-footer .content p {
        font-size: 20px;
    }
}

.article-footer .meta-tags-container {
    margin-top: 60px;
}

.article-footer .meta-tags-container .label {
    font-size: 28px;
    margin-bottom: 16px;
}

@media (min-width: 768px) {
    .article-footer .meta-tags-container .label {
        font-size: 32px;
        margin-bottom: 20px;
    }
}

.article-footer .meta-tags {
    display: flex;
    flex-flow: row wrap;
    gap: 6px 4px;
}

@media (min-width: 768px) {
    .article-footer .meta-tags {
        gap: 8px 6px;
    }
}

.article-footer .meta-tags .family-tag:nth-child(1n + 1):before {
    background-color: #666;
}

.article-footer .meta-tags .family-tag:nth-child(2n + 2):before {
    background-color: #5cfff1;
}

.article-footer .meta-tags .family-tag:nth-child(3n + 3):before {
    background-color: #ffe95c;
}

.article-footer .meta-tags .family-tag:nth-child(4n + 4):before {
    background-color: #ffaf5c;
}

.article-footer .meta-tags .family-tag:nth-child(5n + 5):before {
    background-color: #ff795c;
}

.article-footer .meta-tags .family-tag:nth-child(6n + 6):before {
    background-color: #ff5c7d;
}

.article-footer .meta-tags .family-tag:nth-child(7n + 7):before {
    background-color: #00d275;
}

.spinning-badge {
    --size: clamp(100px, 8.1727962639vw, 140px);
    background-image: url(../img/badge.svg);
    background-position: 50%;
    background-size: contain;
    bottom: -20px;
    -webkit-filter: drop-shadow(30px -30px 140px #0f0f0f);
    filter: drop-shadow(30px -30px 140px #0f0f0f);
    height: var(--size);
    left: -20px;
    position: absolute;
    width: var(--size);
}

.spinning-badge-left {
    left: -20px;
}

.spinning-badge-right {
    left: unset;
    right: -20px;
}

.spinning-badge-text {
    animation: rotate 10s linear infinite;
    border-radius: 50%;
    color: #0f0f0f;
    font-size: clamp(8px, 0.700525394vw, 12px);
    font-weight: 900;
    height: 100%;
    left: 0;
    position: absolute;
    text-transform: uppercase;
    top: 0;
    width: 100%;
}

.spinning-badge-text .char {
    --units: 1;
    --charGutter: clamp(22px, 1.6345592528vw, 28px);
    --l: calc(var(--char-total) + 1);
    --rotationUnit: calc(1turn / var(--l) * var(--char-index, 1));
    display: block !important;
    height: calc(100% - var(--charGutter));
    left: calc(var(--charGutter) / 2);
    position: absolute !important;
    text-align: center;
    top: calc(var(--charGutter) / 2);
    transform: rotate(var(--rotationUnit));
    transform-origin: center;
    width: calc(100% - var(--charGutter));
}

@keyframes rotate {
    0% {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(1turn);
    }
}

.full-height-hero,
.full-height-hero1 {
    align-items: flex-end;
    display: flex;
    min-height: 620px;
    padding: var(--sectionPaddingY) 0;
    position: relative;
}

@media (min-width: 768px) {

    .full-height-hero,
    .full-height-hero1 {
        min-height: 100vh;
        padding: var(--navbarH) 0 calc(var(--sectionPaddingY) / 2);
    }
}

.full-height-hero .content,
.full-height-hero1 .content {
    position: relative;
    z-index: 3;
}

.full-height-hero .content .title,
.full-height-hero1 .content .title {
    font-size: 2rem !important;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 2rem !important;
}

.testimonial .content {
    color: #FFF;
}

.value {
    display: inline-block;
    font-weight: bold;
}

.full-height-hero .content .paragraph,
.full-height-hero1 .content .paragraph {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 20px;
    max-width: 420px;
}

.full-height-hero .content .buttons,
.full-height-hero1 .content .buttons {
    margin-top: 30px;
}

@media (min-width: 768px) {

    .full-height-hero .content .buttons,
    .full-height-hero1 .content .buttons {
        margin-top: 40px;
    }
}

.full-height-hero .background,
.full-height-hero1 .background {
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
}

.full-height-hero .background:before,
.full-height-hero1 .background:before {
    background: linear-gradient(0deg, #0f0f0f, hsla(0, 0%, 6%, 0)), linear-gradient(50.43deg, hsla(0, 0%, 6%, 0.8) 27.37%, hsla(0, 0%, 6%, 0));
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}

.full-height-hero .background img,
.full-height-hero1 .background img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.about-hero .content .title {
    font-size: 96px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .about-hero .content .title {
        font-size: calc(-86.85714px + 23.80952vw);
    }
}

@media screen and (min-width: 1440px) {
    .about-hero .content .title {
        font-size: 125px;
    }
}

.about-hero .content {
    text-align: center;
}

.leave-an-impression-section .heading {
    font-size: 3rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 2.5rem;
    margin-bottom: clamp(40px, 4.6701692936vw, 80px);
}

.leave-an-impression-section .grid-3-desktop {
    gap: 20px;
    grid-template: auto/repeat(1, 1fr);
}

@media (min-width: 768px) {
    .leave-an-impression-section .grid-3-desktop {
        gap: 40px;
        grid-template: auto/repeat(2, 1fr);
    }
}

@media (min-width: 1280px) {
    .leave-an-impression-section .grid-3-desktop {
        grid-template: auto/repeat(3, 1fr);
    }
}

@media (min-width: 768px) {
    .leave-an-impression-section .grid-3-desktop> :last-child {
        grid-area: auto/span 2;
    }
}

@media (min-width: 1280px) {
    .leave-an-impression-section .grid-3-desktop> :last-child {
        grid-area: auto;
    }
}

.leave-an-impression-section .blurb {
    background: #191919;
    border-radius: 24px;
    display: flex;
    flex-direction: column;
    padding: 30px;
}

@media (min-width: 768px) {
    .leave-an-impression-section .blurb {
        border-radius: 32px;
        padding: 40px;
    }
}

.leave-an-impression-section .blurb .icon {
    height: 60px;
}

@media (min-width: 768px) {
    .leave-an-impression-section .blurb .icon {
        height: 100px;
    }
}

.leave-an-impression-section .blurb .icon img {
    height: 100%;
    width: auto;
}

.leave-an-impression-section .blurb .content {
    margin-top: 30px;
}

.leave-an-impression-section .blurb h6 {
    font-family: "Synonym-Regular", sans-serif;
    font-size: 1rem;
    font-weight: 500;
}

.leave-an-impression-section .blurb p {
    color: #fff;
    font-size: 1rem;
    margin-top: 16px;
}

.leave-an-impression-section .blurb .buttons {
    padding-top: 30px;
}

.leave-an-impression-section .stroke-text {
    --color: #efece6;
}

.stroke-text {
    --borderWidth: clamp(1px, 0.1167542323vw, 2px);
    --color: #efece6;
    color: var(--color);
    text-shadow: calc(var(--borderWidth) * -1) calc(var(--borderWidth) * -1) 0 var(--color), var(--borderWidth) calc(var(--borderWidth) * -1) 0 var(--color), calc(var(--borderWidth) * -1) var(--borderWidth) 0 #efece6,
        var(--borderWidth) var(--borderWidth) 0 var(--color);
}

@supports (-webkit-text-stroke: var(--borderWidth) var(--color)) {
    .stroke-text {
        -webkit-text-stroke: var(--borderWidth) var(--color);
        text-shadow: none;
    }
}

.real-crowd-section .content-layout {
    display: grid;
    gap: var(--gutter);
    grid-template: auto/1fr;
}

@media (min-width: 768px) {
    .real-crowd-section .content-layout {
        grid-template: auto/auto clamp(420px, 32.6911850555vw, 560px);
    }
}

.real-crowd-section .heading {
    font-size: 72px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .real-crowd-section .heading {
        font-size: calc(-28.57143px + 13.09524vw);
    }
}

@media screen and (min-width: 1440px) {
    .real-crowd-section .heading {
        font-size: 160px;
    }
}

.real-crowd-section .paragraph {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
}

@media screen and (min-width: 768px) {
    .real-crowd-section .paragraph {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .real-crowd-section .paragraph {
        font-size: 24px;
    }
}

.real-crowd-section .paragraph span {
    color: #efece6;
}

.real-crowd-section .carousel {
    margin-bottom: var(--sectionPaddingY);
}

.real-crowd-section .carousel-item {
    margin: 0 10px;
    overflow: hidden;
    position: relative;
    width: 240px;
}

@media (min-width: 768px) {
    .real-crowd-section .carousel-item {
        width: 480px;
    }
}

.real-crowd-section .carousel-item:nth-child(odd) {
    border-top-left-radius: 16px;
}

@media (min-width: 768px) {
    .real-crowd-section .carousel-item:nth-child(odd) {
        border-top-left-radius: 32px;
    }
}

.real-crowd-section .carousel-item:nth-child(2n) {
    border-top-right-radius: 16px;
}

@media (min-width: 768px) {
    .real-crowd-section .carousel-item:nth-child(2n) {
        border-top-right-radius: 32px;
    }
}

.real-crowd-section .carousel-item:before {
    content: "";
    display: block;
    padding-bottom: 120%;
}

.real-crowd-section .carousel-item img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.real-crowd-section .stroke-text {
    --color: #efece6;
}

@media (min-width: 768px) {
    .product-parallax-section .parallax-background-section {
        background: #000;
    }
}

.product-parallax-section .slide {
    display: grid;
    grid-template: auto/repeat(1, minmax(0, 1fr));
    position: relative;
}

@media (min-width: 768px) {
    .product-parallax-section .slide {
        grid-template: auto/repeat(2, minmax(0, 1fr));
        min-height: 100vh;
    }
}

.product-parallax-section .image {
    overflow: hidden;
    position: relative;
}

.product-parallax-section .image img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.product-parallax-section .content {
    align-self: center;
    padding: 60px 20px;
    text-align: center;
}

.product-parallax-section .content .heading {
    font-size: 64px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .product-parallax-section .content .heading {
        font-size: calc(27.42857px + 4.7619vw);
    }
}

@media screen and (min-width: 1440px) {
    .product-parallax-section .content .heading {
        font-size: 96px;
    }
}

.product-parallax-section .content .paragraph {
    font-size: 1rem;
    line-height: 1.3;
    margin: 30px auto 0;
    max-width: 580px;
}

@media screen and (min-width: 768px) {
    .product-parallax-section .content .paragraph {
        font-size: calc(11.42857px + 0.59524vw);
    }
}

@media screen and (min-width: 1440px) {
    .product-parallax-section .content .paragraph {
        font-size: 20px;
    }
}

@media (min-width: 768px) {
    .product-parallax-section .content .paragraph {
        margin: 40px auto 0;
    }
}

.product-parallax-section .content .buttons {
    margin-top: 40px;
}

.experience-generator-section .content {
    margin-bottom: clamp(80px, 7.0052539405vw, 120px);
    text-align: center;
}

.experience-generator-section .content .heading {
    font-size: 72px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .experience-generator-section .content .heading {
        font-size: calc(-28.57143px + 13.09524vw);
    }
}

@media screen and (min-width: 1440px) {
    .experience-generator-section .content .heading {
        font-size: 160px;
    }
}

.experience-generator-section .content .paragraph {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
    margin: 40px auto 0;
    max-width: 720px;
}

@media screen and (min-width: 768px) {
    .experience-generator-section .content .paragraph {
        font-size: calc(11.42857px + 0.59524vw);
    }
}

@media screen and (min-width: 1440px) {
    .experience-generator-section .content .paragraph {
        font-size: 20px;
    }
}

.experience-generator-section .content .buttons {
    margin-top: 50px;
}

.what-people-are-saying-section .text {
    color: #efece6;
    font-size: 80px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
    margin-bottom: clamp(40px, 5.837711617vw, 100px);
    white-space: nowrap;
}

@media screen and (min-width: 768px) {
    .what-people-are-saying-section .text {
        font-size: calc(-48px + 16.66667vw);
    }
}

@media screen and (min-width: 1440px) {
    .what-people-are-saying-section .text {
        font-size: 192px;
    }
}

.testimonials-grid {
    display: grid;
    gap: 20px;
    grid-template: auto/repeat(1, 1fr);
}

@media (min-width: 768px) {
    .testimonials-grid {
        gap: 40px;
        grid-template: auto/repeat(4, 1fr);
    }
}

.testimonial {
    --padding: 40px;
    background: #191919;
    border-radius: 32px;
    padding: var(--padding);
}

@media (min-width: 768px) {
    .testimonial {
        --padding: 60px;
    }
}

.testimonial .content .logo {
    border-radius: 0 16px 16px 0;
    display: inline-block;
    margin-bottom: 30px;
    margin-left: calc(var(--padding) * -1);
    padding: 16px calc(var(--padding) / 2) 16px var(--padding);
}

@media (min-width: 768px) {
    .testimonial .content .logo {
        background: #101010;
    }
}

.testimonial {
    background: #00d275;
}

.testimonial .discovery {
    background: #1b6693;
}

.testimonial .content .logo-container {
    align-items: center;
    display: flex;
    height: 36px;
}

.testimonial .content .logo img {
    height: 100%;
    width: auto;
}

.testimonial .content p {
    color: #fff;
    font-size: 1rem;
    font-style: italic;
    line-height: 1.3;
}

@media screen and (min-width: 768px) {
    .testimonial .content p {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .testimonial .content p {
        font-size: 24px;
    }
}

.testimonial .content .author {
    color: #fff;
    display: inline-block;
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 30px;
}

@media (min-width: 768px) {
    .testimonial .content .author {
        margin-top: 40px;
    }
}

.about-quote-section blockquote {
    margin-left: auto;
    margin-right: auto;
    max-width: 1080px;
    text-align: center;
}

.about-quote-section blockquote .paragraph {
    font-size: 18px;
    margin-bottom: 60px;
}

@media screen and (min-width: 768px) {
    .about-quote-section blockquote .paragraph {
        font-size: calc(6.57143px + 1.4881vw);
    }
}

@media screen and (min-width: 1440px) {
    .about-quote-section blockquote .paragraph {
        font-size: 28px;
    }
}

.about-quote-section blockquote cite {
    font-size: 18px;
    font-weight: 700;
    position: relative;
}

@media screen and (min-width: 768px) {
    .about-quote-section blockquote cite {
        font-size: calc(6.57143px + 1.4881vw);
    }
}

@media screen and (min-width: 1440px) {
    .about-quote-section blockquote cite {
        font-size: 28px;
    }
}

.about-quote-section blockquote cite:before {
    background-image: url(../img/icons/quotes.svg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: clamp(70px, 8.1727962639vw, 140px);
    left: 50%;
    opacity: 0.1;
    pointer-events: none;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: clamp(81px, 9.4570928196vw, 162px);
}

.about-story-section {
    overflow: hidden;
    position: relative;
}

.about-story-section .background {
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
}

.about-story-section .mask-inner,
.about-story-section .mask-outer {
    height: 100%;
    left: 0;
    overflow: hidden;
    position: absolute;
    top: 0;
    width: 100%;
}

.about-story-section .mask-inner {
    align-items: flex-end;
    display: flex;
    padding: calc(var(--sectionPaddingY) / 2) 0;
}

.about-story-section .background:before {
    background: linear-gradient(0deg, hsla(0, 0%, 6%, 0.5), hsla(0, 0%, 6%, 0) 146.57%), linear-gradient(1turn, #0f0f0f, hsla(0, 0%, 6%, 0));
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.about-story-section .background img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.about-story-section .slide {
    align-items: flex-end;
    display: flex;
    position: relative;
    z-index: 1;
}

@media (min-width: 768px) {
    .about-story-section .slide {
        height: 100vh;
        left: 0;
        position: absolute;
        top: 0;
        width: 100%;
    }
}

.about-story-section .slide .container {
    position: relative;
    z-index: 2;
}

.about-story-section .content {
    margin-left: auto;
    max-width: 676px;
}

.about-story-section .content-title {
    display: flex;
    max-width: none;
}

.about-story-section .content .title {
    display: inline-block;
    font-size: 96px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
    margin-left: auto;
}

@media screen and (min-width: 768px) {
    .about-story-section .content .title {
        font-size: calc(-86.85714px + 23.80952vw);
    }
}

@media screen and (min-width: 1440px) {
    .about-story-section .content .title {
        font-size: 125px;
    }
}

.about-story-section .content .text {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.2;
}

@media screen and (min-width: 768px) {
    .about-story-section .content .text {
        font-size: calc(6.28571px + 1.78571vw);
    }
}

@media screen and (min-width: 1440px) {
    .about-story-section .content .text {
        font-size: 32px;
    }
}

.floating-gifs .events-gif {
    overflow: hidden;
    position: absolute;
    width: clamp(120px, 18.6806771745vw, 320px);
}

.floating-gifs .events-gif:first-child {
    left: 8%;
    top: 46%;
    transform: rotate(-18deg);
}

.floating-gifs .events-gif:nth-child(2) {
    left: 72%;
    top: 56%;
    transform: rotate(18deg);
}

.floating-gifs .events-gif:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.floating-gifs .events-gif img {
    height: 120%;
    left: 50%;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 120%;
}

.events-grid {
    display: grid;
    gap: 40px;
    grid-template: auto/repeat(1, 1fr);
}

@media (min-width: 768px) {
    .events-grid {
        gap: 60px;
        grid-template: auto/repeat(2, 1fr);
    }
}

@media (min-width: 1280px) {
    .events-grid {
        gap: 80px;
        grid-template: auto/repeat(3, 1fr);
    }
}

.section-cases-results {
    display: none;
    opacity: 0;
}

.cases-results .sidebar {
    position: relative;
}

@media (min-width: 768px) {
    .cases-results .sidebar {
        width: 180px;
    }
}

@media (min-width: 768px) {
    .cases-results .sidebar>.inner {
        position: sticky;
        top: 40px;
    }
}

.cases-results .sidebar>.inner>.title {
    color: #fff;
    font-family: "Synonym-Regular", sans-serif;
    font-size: 18px;
    font-weight: 400;
    line-height: 1;
    margin-bottom: 30px;
    position: relative;
}

@media (min-width: 768px) {
    .cases-results .sidebar>.inner>.title {
        font-size: 14px;
    }
}

.cases-results .sidebar>.inner>.title:before {
    background: hsla(40, 22%, 92%, 0.4);
    content: "";
    display: block;
    height: 0.75em;
    margin-top: 0.125em;
    position: absolute;
    right: 0.375em;
    top: 0;
    transition: transform 0.2s ease;
    width: 2px;
}

@media (min-width: 768px) {
    .cases-results .sidebar>.inner>.title:before {
        display: none;
    }
}

.cases-results .sidebar>.inner>.title:after {
    background: hsla(40, 22%, 92%, 0.4);
    content: "";
    display: block;
    height: 0.75em;
    margin-top: 0.125em;
    position: absolute;
    right: 0.375em;
    top: 0;
    transform: rotate(90deg);
    width: 2px;
}

@media (min-width: 768px) {
    .cases-results .sidebar>.inner>.title:after {
        display: none;
    }
}

.cases-results .sidebar>.inner>.title.is-active:before {
    transform: rotate(90deg);
}

@media (min-width: 768px) {
    .cases-results .filter-group .title:hover {
        cursor: pointer;
    }
}

.cases-results .filter-group .title:before {
    background: #efece6;
    content: "";
    height: 0.75em;
    margin-top: 0.125em;
    position: absolute;
    right: 0.375em;
    top: 0;
    transition: transform 0.2s ease;
    width: 2px;
}

.cases-results .filter-group .title:after {
    background: #efece6;
    content: "";
    height: 0.75em;
    margin-top: 0.125em;
    position: absolute;
    right: 0.375em;
    top: 0;
    transform: rotate(90deg);
    width: 2px;
}

.cases-results .filter-group .title.is-active:before {
    transform: rotate(90deg);
}

.cases-results-heading {
    margin-bottom: 30px;
}

@media (min-width: 768px) {
    .cases-results-heading {
        margin-bottom: 40px;
    }
}

.cases-results-heading .actions {
    margin-bottom: 20px;
}

@media (min-width: 768px) {
    .cases-results-heading .actions {
        margin-bottom: 40px;
    }
}

.cases-results-heading .action {
    align-items: center;
    color: #fff;
    display: inline-flex;
    font-size: 20px;
    font-weight: 500;
}

.cases-results-heading .action:hover {
    color: #efece6;
}

.cases-results-heading .action svg {
    height: auto;
    margin-right: 16px;
    transform: scaleX(-1);
    width: 16px;
}

.cases-results-heading .action svg path {
    fill: currentColor;
}

.cases-results-heading .heading {
    font-size: 48px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 90%;
    margin-bottom: 0.25em;
}

@media screen and (min-width: 768px) {
    .cases-results-heading .heading {
        font-size: calc(11.42857px + 4.7619vw);
    }
}

@media screen and (min-width: 1440px) {
    .cases-results-heading .heading {
        font-size: 80px;
    }
}

.cases-results-heading .filter {
    display: flex;
    flex-flow: row wrap;
    gap: 8px 4px;
}

.form-checkbox .checkbox-label:before {
    border: 1px solid hsla(40, 22%, 92%, 0.4);
    border-radius: 4px;
    content: "";
    height: 1.25em;
    left: 0;
    margin-top: -0.125em;
    position: absolute;
    top: 0;
    transition: border-color 0.2s ease;
    width: 1.25em;
}

.form-checkbox .checkbox-label:after {
    --offset: 4px;
    background: #efece6;
    border-radius: 2px;
    content: "";
    height: calc(1.25em - var(--offset) * 2);
    left: var(--offset);
    margin-top: -0.125em;
    opacity: 0;
    position: absolute;
    top: var(--offset);
    width: calc(1.25em - var(--offset) * 2);
}

.form-checkbox .checkbox:checked+.checkbox-label:after {
    opacity: 1;
}

.form-checkbox .checkbox-label:hover:before,
.form-checkbox .checkbox:checked+.checkbox-label:before {
    border-color: #efece6;
}

.form-checkbox .checkbox-label:hover,
.form-checkbox .checkbox:checked+.checkbox-label {
    color: #efece6;
}

.cases-grid {
    display: grid;
    gap: 40px;
    grid-template: auto/repeat(1, 1fr);
}

@media (min-width: 500px) {
    .cases-grid {
        gap: 40px 20px;
        grid-template: auto/repeat(2, 1fr);
    }
}

@media (min-width: 768px) {
    .cases-grid {
        gap: 40px;
        grid-template: auto/repeat(3, 1fr);
    }
}

@media (min-width: 1280px) {
    .cases-grid {
        gap: 60px;
    }
}

.case-card {
    position: relative;
}

.case-card .thumb {
    border-radius: 32px;
    display: block;
    overflow: hidden;
    position: relative;
}

.case-card .thumb img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.case-card .thumb:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.case-card .tags {
    display: inline-flex;
    gap: 10px;
    left: 20px;
    position: absolute;
    top: 20px;
}

.case-card .tags-bottom {
    bottom: 20px;
    top: auto;
}

.case-card .caption {
    padding-top: 20px;
}

.case-card .caption .title {
    font-family: "CabinetGrotesk-Black", sans-serif;
    font-size: 24px;
    font-weight: 300;
    letter-spacing: 0.02em;
    line-height: 1;
}

.case-card .caption .location {
    color: #fff;
    font-size: 1rem;
    line-height: 1;
    white-space: nowrap;
}

.case-card .caption-grid {
    align-items: baseline;
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    justify-content: space-between;
}

.shared-hero-generator {
    padding: calc(var(--navbarH) + var(--sectionPaddingY) / 2) 0 var(--sectionPaddingY);
}

.shared-hero-generator .heading {
    font-size: 72px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .shared-hero-generator .heading {
        font-size: calc(-28.57143px + 13.09524vw);
    }
}

@media screen and (min-width: 1440px) {
    .shared-hero-generator .heading {
        font-size: 160px;
    }
}

.shared-hero-generator .shared-hero-content {
    display: inline-flex;
    flex-direction: column;
}

.shared-hero-generator .heading-container {
    align-items: center;
    display: inline-flex;
    flex-direction: column;
    gap: 20px;
    position: relative;
}

.shared-hero-generator .spinning-badge {
    animation: beat 1.4s ease-in-out infinite;
    background-image: url(../img/badge-tap.svg);
    left: unset;
    order: 1;
    position: static;
    right: unset;
    top: unset;
    transform: unset;
    z-index: 10;
}

@media (min-width: 640px) {
    .shared-hero-generator .spinning-badge {
        margin-right: calc(var(--size) / -1.25);
        margin-top: calc(var(--size) / -2);
        position: absolute;
        right: 0;
        top: 100%;
    }
}

@media (min-width: 768px) {
    .shared-hero-generator .spinning-badge {
        cursor: pointer;
    }
}

@keyframes beat {
    0% {
        transform: scale(1.1);
    }

    50% {
        transform: scale(1);
    }

    to {
        transform: scale(1.1);
    }
}

.icon {
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    display: inline-block;
    height: 16px;
    width: 16px;
}

.icon-users {
    background-image: url(../img/icons/users.svg);
}

.get-started-hero .content {
    text-align: center;
}

.get-started-hero .content .title {
    font-size: 96px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .get-started-hero .content .title {
        font-size: calc(-86.85714px + 23.80952vw);
    }
}

@media screen and (min-width: 1440px) {
    .get-started-hero .content .title {
        font-size: 125px;
    }
}

.get-started-hero .content .paragraph {
    color: #efece6;
    font-size: 20px;
    line-height: 1.4;
    margin-top: 30px;
    max-width: none;
}

@media screen and (min-width: 768px) {
    .get-started-hero .content .paragraph {
        font-size: calc(-2.85714px + 2.97619vw);
    }
}

@media screen and (min-width: 1440px) {
    .get-started-hero .content .paragraph {
        font-size: 40px;
    }
}

@media (min-width: 768px) {
    .get-started-hero .content .paragraph {
        margin-top: 40px;
    }
}

.form-layout {
    padding-bottom: 100px;
    display: grid;
    gap: 60px;
    grid-template: auto/1fr;
    padding-top: var(--sectionPaddingY);
}

@media (min-width: 1280px) {
    .form-layout {
        gap: 100px;
        grid-template: auto/auto 1fr;
    }
}

.form-layout .heading {
    font-size: 48px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 1;
    margin-bottom: 30px;
}

@media screen and (min-width: 768px) {
    .form-layout .heading {
        font-size: calc(11.42857px + 4.7619vw);
    }
}

@media screen and (min-width: 1440px) {
    .form-layout .heading {
        font-size: 80px;
    }
}

.form-layout .paragraph {
    margin-top: 20px;
}

.form-layout .form-sidebar {
    order: 99;
}

@media (min-width: 1280px) {
    .form-layout .form-sidebar {
        order: -1;
        width: 440px;
    }

    .form-layout .form-sidebar .inner {
        position: sticky;
        top: var(--navbarH);
    }
}

.form-layout .social {
    align-items: center;
    display: inline-flex;
    flex-flow: row wrap;
    gap: 24px;
    margin-top: 30px;
}

.form-layout .social p {
    color: hsla(40, 22%, 92%, 0.4);
    font-size: 1rem;
    font-weight: 500;
    text-transform: uppercase;
}

.form-layout .social-ul {
    display: inline-flex;
    flex-flow: row wrap;
    gap: 24px;
}

.form-get-started label {
    color: hsla(40, 22%, 92%, 0.4);
    display: inline-block;
    font-size: 12px;
    font-weight: 500;
    margin-bottom: 20px;
    text-transform: uppercase;
}

@media (min-width: 768px) {
    .form-get-started label {
        font-size: 1rem;
    }
}

.form-get-started .form-group {
    margin-bottom: 40px;
}

@media (min-width: 768px) {
    .form-get-started .form-group {
        margin-bottom: 60px;
    }
}

.form-get-started .form-group-row {
    display: flex;
    flex-flow: row wrap;
    gap: 40px;
}

@media (min-width: 768px) {
    .form-get-started .form-group-row {
        gap: 40px;
    }
}

.form-get-started .form-group-col {
    flex: 0 0 100%;
}

@media (min-width: 768px) {
    .form-get-started .form-group-col {
        flex: 1;
    }
}

.form-get-started .form-control {
    background: none;
    border: none;
    border-bottom: 1px solid hsla(40, 22%, 92%, 0.1);
    color: #efece6;
    font-size: 1rem;
    height: 48px;
    width: 100%;
}

@media (min-width: 768px) {
    .form-get-started .form-control {
        font-size: 24px;
        height: 64px;
    }
}

.form-get-started .form-control:-ms-input-placeholder {
    color: hsla(40, 22%, 92%, 0.4);
}

.form-get-started .form-control::placeholder {
    color: hsla(40, 22%, 92%, 0.4);
}

.form-get-started .input-group {
    position: relative;
}

.form-get-started .input-group-addon {
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

.form-get-started .input-group-addon .action {
    opacity: 0.4;
}

.form-get-started .input-group-addon .action:hover {
    opacity: 1;
}

.form-get-started .checkboxes {
    display: flex;
    flex-flow: row wrap;
    gap: 12px 10px;
}

.form-get-started .form-buttons .btn {
    width: 100%;
}

.form-get-started .form-buttons .btn .btn-bg:before {
    height: calc(var(--btnH) * 16);
    margin-left: calc(var(--btnH) * 16 / -2);
    margin-top: calc(var(--btnH) * 16 / -2);
    width: calc(var(--btnH) * 16);
}

.experience-checkbox input {
    left: 0;
    position: absolute;
    top: 0;
    visibility: hidden;
}

.experience-checkbox label {
    align-items: center;
    background: hsla(40, 22%, 92%, 0.1);
    border-radius: 60px;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-size: 1rem;
    height: 48px;
    margin-bottom: 0;
    padding: 0 20px;
    text-transform: none;
    transition-duration: 0.15s;
    transition-property: background-color, color, border-color;
    transition-timing-function: ease;
}

@media (min-width: 768px) {
    .experience-checkbox label {
        font-size: 18px;
        height: 64px;
        padding: 0 32px;
    }
}

.experience-checkbox input:checked+label {
    color: #0f0f0f;
}

.experience-checkbox input:checked+.tag-live-screen-printing {
    background-color: #ffe95c;
}

.experience-checkbox input:checked+.tag-live-embroidery {
    background-color: #5cfff1;
}

.experience-checkbox input:checked+.tag-live-sublimination {
    background-color: #ff795c;
}

.experience-checkbox input:checked+.tag-live-heat-press {
    background-color: #ffaf5c;
}

.experience-checkbox input:checked+.tag-live-laser-engraving {
    background-color: #00d275;
}

.experience-checkbox input:checked+.tag-live-hand-jet-print-gun {
    background-color: #ff5c7d;
}

.experience-checkbox input:checked+.tag-virtual-event {
    background-color: #666;
}

.experience-checkbox input:checked+.tag-custom-experience {
    background-color: #efece6;
}

.event-type-checkbox input,
.form-radio input {
    left: 0;
    position: absolute;
    top: 0;
    visibility: hidden;
}

.event-type-checkbox label,
.form-radio label {
    --tagHeight: 40px;
    --paddingX: 16px;
    align-items: center;
    background-border: none;
    border-radius: 60px;
    box-sizing: border-box;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font-size: 1rem;
    font-weight: 500;
    height: var(--tagHeight);
    justify-content: center;
    line-height: calc(var(--tagHeight) - 1rem - 2px);
    margin-bottom: 0;
    padding: 0.5rem var(--paddingX);
    position: relative;
    text-transform: none;
    transition-duration: 0.15s;
    transition-property: background-color, color, border-color;
    transition-timing-function: ease;
    white-space: nowrap;
}

.event-type-checkbox label:active:focus:before,
.event-type-checkbox label:hover:before,
.form-radio label:active:focus:before,
.form-radio label:hover:before {
    transform: translate(-2px, 4px);
}

.event-type-checkbox label:active:focus .label-inner,
.event-type-checkbox label:hover .label-inner,
.form-radio label:active:focus .label-inner,
.form-radio label:hover .label-inner {
    transform: translate(-2px, 4px);
}

.event-type-checkbox label:after,
.event-type-checkbox label:before,
.form-radio label:after,
.form-radio label:before {
    border: 2px solid;
    border-color: inherit;
    border-radius: inherit;
    bottom: 0;
    content: "";
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    transition-duration: inherit;
    transition-property: transform, background-color;
    transition-timing-function: inherit;
}

.event-type-checkbox label:before,
.form-radio label:before {
    z-index: 2;
}

.event-type-checkbox label:after,
.form-radio label:after {
    transform: translate(-2px, 4px);
    z-index: 1;
}

.event-type-checkbox .label-inner,
.form-radio .label-inner {
    align-items: center;
    display: inline-flex;
    gap: 6px;
    position: relative;
    transition-duration: inherit;
    transition-property: transform;
    transition-timing-function: inherit;
    z-index: 3;
}

.event-type-checkbox label:after,
.event-type-checkbox label:before,
.event-type-checkbox label:focus:after,
.event-type-checkbox label:focus:before,
.form-radio label:after,
.form-radio label:before,
.form-radio label:focus:after,
.form-radio label:focus:before {
    background-color: #393938;
    border-color: #0f0f0f;
}

.event-type-checkbox input:checked+label:before,
.form-radio input:checked+label:before {
    transform: translate(-2px, 4px);
}

.event-type-checkbox input:checked+label:after,
.event-type-checkbox input:checked+label:before,
.form-radio input:checked+label:after,
.form-radio input:checked+label:before {
    background-color: #efece6;
    border-color: #0f0f0f;
}

.event-type-checkbox input:checked+label,
.form-radio input:checked+label {
    color: #0f0f0f;
}

.event-type-checkbox input:checked+label .label-inner,
.form-radio input:checked+label .label-inner {
    transform: translate(-2px, 4px);
}

.case-study-layout {
    display: grid;
    grid-template: auto/minmax(0, 1fr);
    margin-left: auto;
    margin-right: auto;
    max-width: 1640px;
    overflow: hidden;
    padding: calc(var(--navbarH) + var(--sectionPaddingY) / 2) 0 clamp(60px, 14.0105078809vw, 240px);
    padding-left: var(--gutter);
    padding-right: var(--gutter);
    row-gap: clamp(60px, 14.0105078809vw, 240px);
    width: 100%;
}

.case-study-layout p {
    font-size: 20px;
    line-height: 1.3;
}

@media (min-width: 768px) {
    .case-study-layout p {
        font-size: 28px;
    }
}

.case-study-layout p+p {
    margin-top: 20px;
}

.case-study-header .content {
    text-align: center;
}

.case-study-header .content .paragraph {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 30px;
    max-width: 620px;
}

@media screen and (min-width: 768px) {
    .case-study-header .content .paragraph {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .case-study-header .content .paragraph {
        font-size: 24px;
    }
}

@media (min-width: 768px) {
    .case-study-header .content .paragraph {
        margin-top: 40px;
    }
}

.case-study-header .family-tag-screen-printing:before {
    background-color: #ffe95c;
}

.case-study-header .family-tag-embroidery:before {
    background-color: #5cfff1;
}

.case-study-header .family-tag-sublimination:before {
    background-color: #ff795c;
}

.case-study-header .family-tag-heat-press:before {
    background-color: #ffaf5c;
}

.case-study-header .family-tag-laser-engraving:before {
    background-color: #00d275;
}

.case-study-header .family-tag-hand-jet-print-gun:before {
    background-color: #ff5c7d;
}

.case-study-header .family-tag-virtual-event:before {
    background-color: #666;
}

.case-study-header .family-tag-custom-experience:before {
    background-color: #efece6;
}

.case-study-header .content .heading {
    font-size: 96px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .case-study-header .content .heading {
        font-size: calc(-86.85714px + 23.80952vw);
    }
}

@media screen and (min-width: 1440px) {
    .case-study-header .content .heading {
        font-size: 125px;
    }
}

.case-study-header .content .categories {
    display: inline-flex;
    flex-flow: row wrap;
    gap: 20px;
    margin-bottom: 40px;
}

@media (min-width: 768px) {
    .case-study-header .content .categories {
        margin-bottom: 60px;
    }
}

.case-study-header .content .categories .tags {
    align-items: center;
    display: flex;
    flex-flow: row wrap;
    gap: 10px;
}

.case-study-header .content .categories .tags:first-child:after {
    background: hsla(40, 22%, 92%, 0.2);
    content: "";
    display: inline-block;
    height: 10px;
    margin-left: 10px;
    width: 1px;
}

.case-study-header .content .meta {
    display: inline-flex;
    font-size: 20px;
    line-height: 1.3;
    margin-top: 40px;
}

@media (min-width: 768px) {
    .case-study-header .content .meta {
        margin-top: 60px;
    }
}

.case-study-header .content .date,
.case-study-header .content .location {
    color: #fff;
}

.case-study-header .content .date:before {
    content: "//";
    padding-left: 20px;
    padding-right: 20px;
}

.case-study-cover {
    position: relative;
}

.case-study-cover .spinning-badge {
    background-image: url(../img/badge-white.svg);
    left: 50%;
    top: 0;
    transform: translate(-50%, -50%);
    z-index: 2;
}

.case-study-cover-image {
    overflow: hidden;
    position: relative;
}

.case-study-cover-image:before {
    content: "";
    display: block;
    padding-bottom: 50.1351351351%;
}

.case-study-cover-image img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.case-study-intro {
    margin: 0 auto;
    max-width: 900px;
    text-align: center;
}

.case-study-image-grid {
    display: grid;
    gap: 20px;
    grid-template: auto/1fr;
}

@media (min-width: 768px) {
    .case-study-image-grid {
        grid-template: auto/repeat(2, 1fr);
    }
}

.case-study-image-grid .item {
    overflow: hidden;
    position: relative;
}

.case-study-image-grid .item:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.case-study-image-grid .item img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

@media (min-width: 768px) {
    .case-study-image-grid .item:first-child {
        border-radius: 32px 0 0 0;
    }
}

@media (min-width: 768px) {
    .case-study-image-grid .item:nth-child(2n + 2) {
        border-radius: 0 32px 0 0;
    }
}

@media (min-width: 768px) {
    .case-study-image-grid .item:nth-child(3n + 3) {
        border-radius: 0 0 0 32px;
    }
}

@media (min-width: 768px) {
    .case-study-image-grid .item:last-child {
        border-radius: 0 0 32px 0;
    }
}

.case-study-text-section {
    display: grid;
    gap: 40px;
    grid-template: auto/minmax(0, 1fr);
}

@media (min-width: 1280px) {
    .case-study-text-section {
        gap: 60px;
        grid-template: auto/auto 1fr;
    }

    .case-study-text-section .title {
        width: 420px;
    }
}

.case-study-text-section .title p {
    color: #fff;
}

.case-study-video {
    position: relative;
}

.case-study-video .spinning-badge {
    background-image: url(../img/badge-play.svg);
    cursor: pointer;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
}

.case-study-video-poster:before {
    content: "";
    display: block;
    padding-bottom: 56.25%;
}

.datepicker-picker {
    background: #232323;
    border-radius: 0;
    box-shadow: none;
    color: #efece6;
    font-size: 14px;
}

.datepicker-input.in-edit:active,
.datepicker-input.in-edit:focus {
    box-shadow: none;
}

.datepicker-cell.next:not(.disabled),
.datepicker-cell.prev:not(.disabled) {
    color: #fff;
}

.datepicker-cell.disabled {
    color: hsla(40, 22%, 92%, 0.2);
}

.datepicker-controls .button {
    background: #232323;
    border-radius: 60px;
    color: hsla(40, 22%, 92%, 0.4);
    font-size: 1rem;
    height: 2.25rem;
}

.datepicker-controls .next-btn,
.datepicker-controls .prev-btn {
    padding: 0 0 2px;
}

.datepicker-view .days-of-week {
    margin-bottom: 10px;
}

.datepicker-view .dow {
    font-size: 14px;
}

.datepicker-picker span {
    align-items: center;
    border-radius: 60px;
    display: flex;
    font-weight: 500;
    justify-content: center;
    padding-top: 1px;
}

.datepicker-cell.focused:not(.selected),
.datepicker-cell.focused:not(.selected):hover,
.datepicker-header .datepicker-controls .button:hover {
    background: #efece6;
    color: #0f0f0f;
}

.datepicker-cell.range-end.focused:not(.selected),
.datepicker-cell.range-end:not(.selected),
.datepicker-cell.range-start.focused:not(.selected),
.datepicker-cell.range-start:not(.selected),
.datepicker-cell.selected,
.datepicker-cell.selected:hover {
    background: #666;
    color: #0f0f0f;
}

.datepicker-cell.range {
    background: hsla(40, 22%, 92%, 0.1);
    color: #efece6;
}

.datepicker-cell.range:not(.disabled):not(.focused):not(.today):hover {
    background: hsla(40, 22%, 92%, 0.2);
    color: #efece6;
}

.datepicker-cell.focused:not(.selected),
.datepicker-cell.focused:not(.selected):hover,
.datepicker-header .datepicker-controls .button:hover {
    background: hsla(40, 22%, 92%, 0.2);
    color: #efece6;
}

.datepicker-cell:not(.disabled):hover {
    background: hsla(40, 22%, 92%, 0.3);
    color: #efece6;
}

.datepicker-cell.range-start {
    border-radius: 60px 0 0 60px;
}

.datepicker-cell.range-end {
    border-radius: 0 60px 60px 0;
}

.section-hero-platform {
    overflow: hidden;
}

.section-hero-platform .shared-hero-content .heading {
    font-size: 80px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 80%;
}

@media screen and (min-width: 768px) {
    .section-hero-platform .shared-hero-content .heading {
        font-size: calc(-48px + 16.66667vw);
    }
}

@media screen and (min-width: 1440px) {
    .section-hero-platform .shared-hero-content .heading {
        font-size: 192px;
    }
}

.section-hero-platform .shared-hero-content .paragraph-lead {
    font-size: 20px;
    line-height: 1.5;
    margin-top: 1em;
}

@media screen and (min-width: 768px) {
    .section-hero-platform .shared-hero-content .paragraph-lead {
        font-size: calc(-2.85714px + 2.97619vw);
    }
}

@media screen and (min-width: 1440px) {
    .section-hero-platform .shared-hero-content .paragraph-lead {
        font-size: 40px;
    }
}

.section-hero-platform .platform-app-border-wrap {
    border-radius: 12px;
    margin: 80px auto 0;
    max-width: 1024px;
    padding: 1px;
    position: relative;
}

.section-hero-platform .platform-app-border-wrap:before {
    background: linear-gradient(180deg, hsla(40, 22%, 92%, 0.3) 0, hsla(40, 22%, 92%, 0));
    border-radius: inherit;
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.section-hero-platform .platform-app-border-wrap:after {
    background: #0f0f0f;
    border-radius: inherit;
    content: "";
    height: calc(100% - 4px);
    left: 0;
    margin: 1px;
    position: absolute;
    top: 0;
    width: calc(100% - 4px);
    z-index: 2;
}

.section-hero-platform .platform-app {
    backdrop-filter: blur(30px);
    background: linear-gradient(180deg, hsla(40, 22%, 92%, 0.1), hsla(40, 22%, 92%, 0));
    border-radius: 12px;
    padding: 10px;
    position: relative;
    z-index: 3;
}

.section-hero-platform .platform-app-image {
    border-radius: 8px;
    overflow: hidden;
    position: relative;
    z-index: 2;
}

.section-hero-platform .platform-app-image:before {
    content: "";
    display: block;
    padding-bottom: 58.59375%;
}

.section-hero-platform .platform-app-image img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.section-hero-platform .platform-app-shadow {
    -webkit-filter: blur(150px);
    filter: blur(150px);
    left: 50%;
    opacity: 0.8;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}

.section-hero-platform .platform-app-shadow:before {
    content: "";
    display: block;
    padding-bottom: 58.59375%;
}

.section-hero-platform .platform-app-shadow:after {
    background: linear-gradient(180deg, hsla(0, 0%, 6%, 0) 0, #0f0f0f 66.67%, #0f0f0f);
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}

.section-hero-platform .platform-app-shadow img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.more-than-just-an-app-section {
    --contentSize: min(-21.9497956801vw, -276px);
    --itemGap: clamp(60px, 4.6701692936vw, 80px);
    --itemLandscapeSize: clamp(320px, 28.0210157618vw, 480px);
    --itemPortraitSize: clamp(260px, 19.848219498vw, 340px);
    --itemLandscapeYOffset: var(--itemLandscapeSize) * (340/580);
    --itemPortraitYOffset: var(--itemPortraitSize) * (634/440);
    --gridOffsetLandscape: calc(var(--itemLandscapeSize) + var(--itemGap));
    --gridOffsetPortrait: calc(var(--itemPortraitSize) + var(--itemGap));
    padding-top: var(--itemGap);
}

@media (min-width: 768px) {
    .more-than-just-an-app-section .content {
        max-width: calc(var(--gridOffsetLandscape) - var(--itemGap));
    }
}

.more-than-just-an-app-section .content .heading {
    font-size: 64px;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 0.8;
}

@media screen and (min-width: 1280px) {
    .more-than-just-an-app-section .content .heading {
        font-size: calc(-64px + 10vw);
    }
}

@media screen and (min-width: 1440px) {
    .more-than-just-an-app-section .content .heading {
        font-size: 80px;
    }
}

.more-than-just-an-app-section .content .paragraph {
    color: #fff;
    font-size: 1rem;
    line-height: 1.3;
    margin-bottom: 2em;
    margin-top: 2em;
}

.more-than-just-an-app-section .floating-grid {
    display: none;
    margin-left: calc(var(--itemGap) * 0.5);
    margin-top: calc(var(--contentSize));
    position: relative;
}

@media (min-width: 768px) {
    .more-than-just-an-app-section .floating-grid {
        display: block;
    }
}

.more-than-just-an-app-section .floating-grid:before {
    content: "";
    display: block;
    padding-bottom: calc(var(--itemLandscapeYOffset) * 2 + var(--itemPortraitYOffset) + var(--itemGap) * 2);
}

.more-than-just-an-app-section .floating-grid .item {
    position: absolute;
    width: var(--itemLandscapeSize);
}

.more-than-just-an-app-section .floating-grid .item.portrait {
    width: var(--itemPortraitSize);
}

.more-than-just-an-app-section .floating-grid .item:first-child {
    left: var(--gridOffsetLandscape);
    top: 0;
}

.more-than-just-an-app-section .floating-grid .item:nth-child(2) {
    left: calc(var(--gridOffsetLandscape) + var(--itemGap) + var(--itemLandscapeSize));
    top: calc(var(--itemLandscapeYOffset) * 0.5);
}

.more-than-just-an-app-section .floating-grid .item:nth-child(3) {
    left: calc(var(--gridOffsetPortrait) - var(--itemGap) + var(--itemGap) * 0.5);
    top: calc(var(--itemLandscapeYOffset) * 1 + var(--itemGap));
}

.more-than-just-an-app-section .floating-grid .item:nth-child(4) {
    left: calc(var(--gridOffsetPortrait) - var(--itemGap) + var(--gridOffsetLandscape));
    top: calc(var(--itemLandscapeYOffset) * 1.5 + var(--itemGap));
}

.more-than-just-an-app-section .floating-grid .item:nth-child(5) {
    left: calc(var(--gridOffsetLandscape) - var(--itemGap) * 2 - var(--itemLandscapeSize));
    top: calc(var(--itemLandscapeYOffset) * 1.5 + var(--itemGap));
}

.more-than-just-an-app-section .floating-grid .item:nth-child(6) {
    left: calc(var(--gridOffsetPortrait) - var(--itemGap));
    top: calc(var(--itemPortraitYOffset) + var(--itemLandscapeYOffset) + var(--itemGap) * 2);
}

.more-than-just-an-app-section .floating-grid .item .image,
.more-than-just-an-app-section .floating-grid .item .video {
    border-radius: 8px;
    overflow: hidden;
    position: relative;
}

.more-than-just-an-app-section .floating-grid .item .image img,
.more-than-just-an-app-section .floating-grid .item .video video {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.more-than-just-an-app-section .floating-grid .item .image:before,
.more-than-just-an-app-section .floating-grid .item .video:before {
    content: "";
    display: block;
    padding-bottom: 58.6206896552%;
}

.more-than-just-an-app-section .floating-grid .item.portrait .image:before,
.more-than-just-an-app-section .floating-grid .item.portrait .video:before {
    content: "";
    display: block;
    padding-bottom: 144.0909090909%;
}

.joyful-customization-app .content {
    max-width: 1280px;
}

.joyful-customization-app .heading {
    font-family: "Synonym-Regular", sans-serif;
    font-size: 3rem;
    font-weight: 400;
    line-height: 2.5rem;
    text-transform: none;
}

/*
@media screen and (min-width: 768px) {
    .joyful-customization-app .heading {
        font-size: calc(11.42857px + 4.7619vw);
    }
}

@media screen and (min-width: 1440px) {
    .joyful-customization-app .heading {
        font-size: 80px;
    }
}*/

.joyful-customization-app .grid {
    display: grid;
    gap: 60px;
    grid-template: auto/repeat(auto-fit, minmax(310px, 1fr));
}

.joyful-customization-app .blurb .title {
    font-family: "Synonym-Regular", sans-serif;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
}

.joyful-customization-app .blurb .paragraph {
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 8px;
    margin: 0 auto;
    text-align: center;
}

.joyful-customization-app .blurb .icon {
    margin-bottom: 40px;
}

.joyful-customization-app .blurb .icon img {
    height: 32px;
    width: 32px;
}

.app-features {
    --padding: clamp(20px, 2.3350846468vw, 40px);
    --gradient: linear-gradient(225deg, #00d275, #333);
    margin-top: 80px;
}

@media (min-width: 768px) {
    .app-features {
        margin-top: 80px;
    }
}

.app-features .feature-layout {
    align-items: center;
    display: grid;
    gap: 60px;
    grid-template: auto/minmax(0, 1fr);
}

@media (min-width: 768px) {
    .app-features .feature-layout {
        gap: 80px;
        grid-template: auto/repeat(2, 1fr);
    }
}

.app-features .feature-layout+.feature-layout {
    margin-top: 80px;
}

@media (min-width: 768px) {
    .app-features .feature-layout+.feature-layout {
        margin-top: 120px;
    }
}

.app-features .feature-layout .content {
    padding: 0;
}

/*
@media (min-width: 1280px) {
    .app-features .feature-layout .content {
        padding: 0 clamp(20px, 5.837711617vw, 100px);
    }
}*/

.app-features .feature-layout .content .title {
    font-family: "CabinetGrotesk-Black", sans-serif;
    color: #00d275 !important;
    font-size: 32px;
    line-height: 1.2;
}

/*
@media screen and (min-width: 768px) {
    .app-features .feature-layout .content .title {
        font-size: calc(22.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .app-features .feature-layout .content .title {
        font-size: 40px;
    }
}
*/
.app-features .feature-layout .content .paragraph {
    font-size: 1rem;
    line-height: 1.3;
    margin-top: 20px;
}

.app-features .feature-layout .content .btn {
    margin-top: 20px;
}

.app-features .feature-layout .media {
    border-radius: clamp(16px, 1.8680677175vw, 32px);
    padding: var(--padding) 0 0 var(--padding);
}

.app-features .feature-layout:nth-child(2n) .media {
    padding: var(--padding) var(--padding) 0 0;
}

@media (min-width: 768px) {
    .app-features .feature-layout:nth-child(2n) .media {
        order: -1;
    }
}

.app-features .feature-layout .mockup {
    border-radius: 12px;
    margin: 0 -10px -10px 0;
    max-width: 1024px;
    padding: 1px;
    position: relative;
}

.app-features .feature-layout:nth-child(2n) .mockup {
    margin: 0 0 -10px -10px;
}

.app-features .feature-layout .mockup:before {
    /*background: linear-gradient(180deg, hsla(40, 22%, 92%, 0.3) 0, hsla(40, 22%, 92%, 0));
    border-radius: inherit;*/
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.app-features .feature-layout .mockup:after {
    background: #0f0f0f;
    border-radius: inherit;
    content: "";
    height: calc(100% - 4px);
    left: 0;
    margin: 1px;
    position: absolute;
    top: 0;
    width: calc(100% - 4px);
    z-index: 2;
}

.app-features .feature-layout .mockup-inner {
    /*backdrop-filter: blur(30px);
    background: linear-gradient(180deg, hsla(40, 22%, 92%, 0.1), hsla(40, 22%, 92%, 0));
    border-radius: 12px;
    padding: 10px;*/
    position: relative;
    z-index: 3;
}

.app-features .feature-layout .screen {
    border-radius: 8px;
    overflow: hidden;
    position: relative;
    z-index: 2;
}

.app-features .feature-layout .screen .image:before {
    content: "";
    display: block;
    padding-bottom: 58.7692307692%;
}

.app-features .feature-layout .screen .video {
    position: relative;
}

.app-features .feature-layout .screen .video:before {
    content: "";
    display: block;
    padding-bottom: 56.3694267516%;
}

.app-features .feature-layout .screen img,
.app-features .feature-layout .screen video {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: contain;
    object-fit: contain;
    position: absolute;
    top: 0;
    width: 100%;
}

.app-features .feature-layout .media,
.app-features .feature-layout .mockup:after {
    background: var(--gradient);
}

.app-features .feature-layout.no-bg .media,
.app-features .feature-layout.no-bg .mockup:after {
    background: none !important;
    padding: 0 !important;
}

.app-features-section .content-layout {
    display: grid;
    gap: var(--gutter);
    grid-template: auto/1fr;
}

@media (min-width: 768px) {
    .app-features-section .content-layout {
        grid-template: auto/1fr 1fr;
    }
}

.app-features-section .heading {
    font-size: 3rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    line-height: 2.5rem;
}

.app-features-section .paragraph {
    font-size: 1rem;
    line-height: 1.3;
}

@media screen and (min-width: 768px) {
    .app-features-section .paragraph {
        font-size: calc(6.85714px + 1.19048vw);
    }
}

@media screen and (min-width: 1440px) {
    .app-features-section .paragraph {
        font-size: 24px;
    }
}

.app-features-section .paragraph span {
    color: #efece6;
}

.app-features-section .carousel {
    margin-bottom: var(--sectionPaddingY);
}

.app-features-section .carousel-item {
    margin: 0 10px;
    overflow: hidden;
    position: relative;
    width: 240px;
}

@media (min-width: 768px) {
    .app-features-section .carousel-item {
        width: 480px;
    }
}

.app-features-section .carousel-item:nth-child(odd) {
    border-top-left-radius: 16px;
}

@media (min-width: 768px) {
    .app-features-section .carousel-item:nth-child(odd) {
        border-top-left-radius: 32px;
    }
}

.app-features-section .carousel-item:nth-child(2n) {
    border-top-right-radius: 16px;
}

@media (min-width: 768px) {
    .app-features-section .carousel-item:nth-child(2n) {
        border-top-right-radius: 32px;
    }
}

.app-features-section .carousel-item:before {
    content: "";
    display: block;
    padding-bottom: 120%;
}

.app-features-section .carousel-item img {
    display: block;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
}

.app-features-section .stroke-text {
    --color: #efece6;
}

.vimeo-player {
    position: relative;
}

.vimeo-player:before {
    content: "";
    display: block;
    padding-bottom: 56.25%;
}

.vimeo-player iframe {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
}

.form-experience-generator {
    align-items: center;
    display: flex;
    flex-direction: column;
    font-size: 1rem;
    gap: 1.25em 0;
    line-height: 1.3;
    margin-top: 1.25em;
}

@media screen and (min-width: 768px) {
    .form-experience-generator {
        font-size: calc(-2.28571px + 2.38095vw);
    }
}

@media screen and (min-width: 1440px) {
    .form-experience-generator {
        font-size: 32px;
    }
}

.form-experience-generator label {
    display: none;
}

.form-experience-generator select {
    -webkit-appearance: none;
    background: none;
    border: none;
    border-bottom: 2px solid #666;
    color: #666;
    line-height: 1.4;
}

@media (min-width: 768px) {
    .form-experience-generator select:hover {
        cursor: pointer;
    }
}

.f-modal {
    -webkit-overflow-scrolling: touch;
    align-items: center;
    backdrop-filter: blur(4px);
    background: hsla(0, 0%, 6%, 0.4);
    display: none;
    grid-template: auto/minmax(0, 1fr);
    height: 100%;
    justify-items: center;
    left: 0;
    opacity: 0;
    overflow-y: auto;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 2022;
}

.f-modal .f-modal-content {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    max-width: 100%;
    padding: var(--navbarH) var(--gutter);
    pointer-events: none;
}

.f-modal .f-modal-content>* {
    pointer-events: auto;
}

.f-modal .f-modal-close {
    cursor: pointer;
    height: 32px;
    position: absolute;
    right: 40px;
    top: 40px;
    width: 32px;
    z-index: 3;
}

.f-modal .f-modal-close:hover {
    opacity: 0.5;
}

.f-modal .f-modal-close:after,
.f-modal .f-modal-close:before {
    background-color: #efece6;
    border-radius: 6px;
    content: "";
    height: 100%;
    left: 16px;
    position: absolute;
    top: 0;
    width: 3px;
}

.f-modal .f-modal-close:before {
    transform: rotate(-45deg);
}

.f-modal .f-modal-close:after {
    transform: rotate(45deg);
}

.f-modal.open {
    display: grid;
}

.experience-generator-notes {
    background: #1c1c1c;
    border-radius: 24px;
    max-width: 100%;
    padding: 40px;
    width: 540px;
}

.experience-generator-notes .heading {
    font-family: "Synonym-Regular", sans-serif;
    font-size: 24px;
    font-weight: 900;
    margin-bottom: 20px;
}

.experience-generator-notes .list {
    font-size: 14px;
    line-height: 1.3;
    list-style: none;
    margin: 0;
    padding: 0;
}

.experience-generator-notes .list li {
    color: hsla(40, 22%, 92%, 0.7);
    margin-top: 16px;
}

.experience-generator-notes .list li strong {
    color: #efece6;
}

.experience-generator-notes .paragraph {
    color: hsla(40, 22%, 92%, 0.7);
    font-size: 14px;
    line-height: 1.3;
    margin-top: 16px;
}

.navbar-menu .navbar-nav {
    position: relative;
}

@media (min-width: 1280px) {
    .navbar-menu .navbar-nav {
        position: static;
    }
}

.navbar-menu .nav-link {
    transition: color 0.2s ease;
}

.navbar-menu .nav-link[data-toggle="dd"] {
    position: relative;
}

@media (min-width: 1280px) {
    .navbar-menu .nav-link[data-toggle="dd"] {
        padding-right: 1em;
    }
}

@media (min-width: 1280px) {
    .navbar-menu .nav-link[data-toggle="dd"]:before {
        background: rgba(169, 255, 92, 0.1);
        border-radius: 0.75em;
        content: "";
        inset: -0.75em -1em;
        opacity: 0;
        position: absolute;
        transition: opacity 0.2s ease;
    }
}

.navbar-menu .nav-link[data-toggle="dd"]:after {
    border-right: 3px solid;
    border-top: 3px solid;
    content: "";
    height: 0.15em;
    margin-right: -0.45em;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%) rotate(135deg);
    width: 0.15em;
}

@media (min-width: 1280px) {
    .navbar-menu .nav-link[data-toggle="dd"]:after {
        border-right: 2px solid;
        border-top: 2px solid;
        height: 0.35em;
        margin-right: 0;
        width: 0.35em;
    }
}

@media (min-width: 1280px) {
    .navbar-menu .nav-link[data-toggle="dd"]:hover:before {
        opacity: 1;
    }
}

.navbar-menu .nav-item.active .nav-link[data-toggle="dd"]:after {
    margin-top: 0.075em;
    transform: translateY(-50%) rotate(-45deg);
}

@media (min-width: 1280px) {
    .navbar-menu .nav-item.active .nav-link[data-toggle="dd"]:after {
        margin-top: 0.15em;
    }
}

.dd-nav {
    bottom: auto;
    height: 0;
    left: 0;
    overflow: hidden;
    right: 0;
    top: 50%;
    z-index: 2023;
}

@media (min-width: 1280px) {
    .dd-nav {
        box-shadow: 0 4px 8px hsla(0, 0%, 6%, 0.1), 0 8px 16px hsla(0, 0%, 6%, 0.12), 0 16px 32px hsla(0, 0%, 6%, 0.14), 0 32px 64px hsla(0, 0%, 6%, 0.16);
        display: none;
        height: auto;
        margin-top: calc(var(--navbarH) / 2);
        overflow: unset;
        position: absolute;
    }
}

.dd-nav.show {
    display: block;
}

.dd-content {
    position: relative;
}

@media (min-width: 1280px) {
    .dd-content {
        background: #1c1c1c;
        border-radius: 16px;
        left: 50%;
        max-width: calc(100% - var(--gutter) * 2);
        padding: 30px;
        position: absolute;
        transform: translateX(-50%);
        width: 1000px;
    }
}

.dd-content:before {
    background: inherit;
    border-radius: 0 4px 0 0;
    content: "";
    height: 16px;
    left: var(--dropdownXOffset);
    margin-left: -8px;
    margin-top: -8px;
    position: absolute;
    top: 0;
    transform: rotate(-45deg);
    width: 16px;
}

.dd-list {
    --gap: 32px;
    align-items: center;
    display: flex;
    flex-flow: column wrap;
    gap: var(--gap);
    list-style: none;
    margin: 32px 0 0;
    padding: 0;
}

@media (min-width: 1280px) {
    .dd-list {
        --gap: 24px;
        align-items: flex-start;
        flex-flow: row wrap;
        margin: 0;
    }

    .dd-list .dd-item {
        flex: 0 0 calc(33.33333% - var(--gap));
    }
}

.dd-list .dd-link {
    display: inline-flex;
    flex-direction: row;
    gap: 16px;
}

.dd-list .dd-text {
    padding-top: 2px;
}

.dd-list .dd-image {
    border-radius: 12px;
    display: none;
    flex-shrink: 0;
    height: 60px;
    overflow: hidden;
    position: relative;
    width: 60px;
}

@media (min-width: 1280px) {
    .dd-list .dd-image {
        display: block;
    }
}

.dd-list .dd-image:before {
    content: "";
    display: block;
    padding-bottom: 100%;
}

.dd-list .dd-image img {
    bottom: 0;
    height: 100%;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
}

.dd-list .dd-title {
    color: #efece6;
    font-family: "Synonym-Regular", sans-serif;
    font-size: 20px;
    font-weight: 500;
    transition: color 0.2s ease;
}

@media (min-width: 1280px) {
    .dd-list .dd-title {
        font-size: 1rem;
    }
}

@media (min-width: 768px) {
    .dd-list .dd-link:hover .dd-title {
        color: #666;
    }
}

.dd-list .dd-paragraph {
    color: #fff;
    display: none;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.4;
    margin-top: 10px;
}

@media (min-width: 1280px) {
    .dd-list .dd-paragraph {
        display: block;
    }
}

footer {
    background: #00d275;
    padding: var(--sectionPaddingY) 0;
    position: relative;
}

.footer-brand {
    display: block;
    height: 48px;
    margin-bottom: 30px;
    width: auto;
}

@media (min-width: 768px) {
    .footer-brand {
        height: 64px;
        margin-bottom: 40px;
    }
}

.footer-brand img,
.footer-brand svg {
    display: block;
    height: 100%;
    width: auto;
}

.footer-layout {
    display: grid;
    gap: 30px 0;
    grid-template: auto/1fr;
}

@media (min-width: 1280px) {
    .footer-layout {
        gap: clamp(60px, 7vw, 120px);
        grid-template: auto/clamp(340px, 25vw, 440px) auto;
    }
}

.columns {
    display: grid;
    gap: 20px;
    grid-template: auto/1fr;
}

@media (min-width: 768px) {
    .columns {
        grid-template: auto/repeat(3, 1fr);
    }
}

@media (max-width: 767px) {
    footer .column:last-child {
        order: -1;
    }
}

.copyright {
    margin-top: 30px;
}

@media (min-width: 768px) {
    .copyright {
        margin-bottom: 40px;
    }
}

.copyright p {
    color: #101010;
    font-size: 1rem;
    line-height: 1.3;
    margin-bottom: 0;
}

.footer-title {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 24px;
}

.footer-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.footer-links li {
    margin-top: 16px;
}

.footer-links li a {
    color: #101010;
    font-size: 0.75rem;
    line-height: 1;
}

.footer-links li a:hover {
    color: #efece6;
}

.footer-social {
    display: inline-flex;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.footer-social li a {
    align-items: center;
    display: flex;
    height: 50px;
    justify-content: center;
    position: relative;
}

.footer-social li a img {
    height: 30px;
    width: auto;
}

.footer-social li a .radar-border-mask {
    border-radius: 50%;
    content: "";
    inset: -1px;
    -webkit-mask: linear-gradient(#efece6 0 0) content-box, linear-gradient(#efece6 0 0);
    mask: linear-gradient(#efece6 0 0) content-box, linear-gradient(#efece6 0 0);
    mask-composite: xor;
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: 0;
    padding: 1px;
    pointer-events: none;
    position: absolute;
    transition: opacity 1s ease;
}

.footer-social li a:hover .radar-border-mask {
    opacity: 1;
}

.footer-social li a .radar-border {
    animation: radarTurn 2s linear infinite;
    background-image: conic-gradient(from 0 at 50% 50%, hsla(40, 22%, 92%, 0.75) 0deg, hsla(40, 22%, 92%, 0) 60deg, hsla(40, 22%, 92%, 0) 310deg, hsla(40, 22%, 92%, 0.75) 1turn);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}

.footer-social li a .radar-border:before {
    content: "";
    float: left;
    padding-top: 100%;
}

.footer-social li a .radar-border:after {
    clear: both;
    content: "";
    display: block;
}

@keyframes radarTurn {
    0% {
        transform: translate(-50%, -50%) rotate(0);
    }

    to {
        transform: translate(-50%, -50%) rotate(1turn);
    }
}

footer .buttons {
    display: flex;
    flex-flow: row wrap;
    gap: 24px;
}

footer .buttons .btn {
    flex: 1;
    white-space: nowrap;
}

footer .btn+.btn {
    margin-left: 0;
}

section ul {
    list-style-type: disc;

    font-size: 1rem;
    line-height: 1.3;
    margin-top: 20px;
}

.paragraph img {
    width: 150px;
    margin: 30px;
}

.bridge-layout .media img,
.app-features .media img {
    max-height: 500px;
    text-align: center;
    margin: 0 auto;
    max-width: 100%;
}

@media (min-width: 1024px) {

    .the-bridge-section .bridge-layout .content .heading,
    .full-height-hero .content .title {
        font-size: 7rem;
        line-height: 6rem;
    }

    .leave-an-impression-section .heading,
    .the-bridge-section .bridge-layout .content .heading,
    .app-features-section .heading,
    .shared-heading .heading {
        font-size: 5rem;
        line-height: 4rem;
    }

    .featured-case .caption-grid {
        display: block;
    }
}

.full-height-hero .background:before {
    background: linear-gradient(0deg, #0f0f0f, hsla(0, 0%, 6%, 0)), linear-gradient(50.43deg, hsla(0, 0%, 6%, 0.8) 27.37%, hsla(0, 0%, 6%, 0));
    content: "";
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}

header,
section.section,
section.full-height-hero,
footer {
    margin-left: auto;
    margin-right: auto;
    /*max-width: 1640px;*/
    padding-left: var(--gutter) !important;
    padding-right: calc(var(--gutter)* 2) !important;
    width: 100%;
}