:root {
  --black-01: #0d0d0d;
  --white-01: white;
  --black-02: #121212;
  --brand--pink: #e082b7;
  --accent-01: #d42121;
  --grey-01: #999;
  --black-03: #1c1c1c;
  --grey-02: #3d3d3d;
}

.w-layout-vflex {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

body {
  background-color: var(--black-01);
  color: var(--white-01);
  font-family: Red hat display, sans-serif;
  font-size: 1vw;
}

h1 {
  letter-spacing: -.03em;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 9em;
  font-weight: 700;
  line-height: .9;
}

h2 {
  letter-spacing: -.03em;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 6em;
  font-weight: 700;
  line-height: .9;
}

h3 {
  letter-spacing: -.03em;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 4em;
  font-weight: 700;
  line-height: .9;
}

h4 {
  letter-spacing: -.03em;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3.5em;
  font-weight: 700;
  line-height: .9;
}

h5 {
  letter-spacing: -.03em;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2.5em;
  font-weight: 700;
  line-height: .9;
}

h6 {
  letter-spacing: -.03em;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2em;
  font-weight: 700;
  line-height: .9;
}

p {
  margin-bottom: 0;
  font-size: 1.25em;
  line-height: 1.6;
}

a {
  color: var(--white-01);
  text-decoration: none;
}

ul, ol {
  margin-bottom: 0;
  padding-left: 20px;
}

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

strong {
  font-weight: bold;
}

blockquote {
  border-left: 5px #e2e2e2;
  margin-bottom: 0;
  padding: 0;
  font-size: 4em;
  font-weight: 300;
  line-height: 1;
}

figure {
  margin-bottom: 10px;
}

figcaption {
  text-align: center;
  margin-top: 5px;
}

.section {
  padding-top: 9em;
  padding-bottom: 9em;
}

.section.padding-bottom-0.hidden {
  display: none;
}

.section.story {
  background-color: var(--black-02);
  padding-top: 0;
  padding-bottom: 2.8em;
}

.section.footer {
  padding-top: 3.5em;
  padding-bottom: 3.5em;
}

.section.hero {
  padding-top: 4em;
  padding-bottom: 0;
}

.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 2em;
  padding-right: 2em;
}

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

.column-xsmall {
  width: 100%;
  max-width: 290px;
}

.column-2xlarge {
  width: 100%;
  max-width: 1060px;
}

.divider {
  background-color: #31313199;
  width: 100%;
  height: 1px;
  line-height: 1.4px;
}

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

.grid.about {
  grid-column-gap: 1em;
  grid-row-gap: 1em;
  grid-template-columns: 1fr 1fr 1fr;
}

.grid.blog, .grid.licenses {
  grid-column-gap: 1.5em;
  grid-row-gap: 1.5em;
  grid-template-columns: 1fr 1fr 1fr;
}

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

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

.text-display-1 {
  font-size: 8em;
}

.text-display-1.line-1 {
  text-align: left;
  font-size: 3.5em;
  font-weight: 700;
  display: block;
}

.text-display-1.line-2 {
  text-align: right;
  font-size: 5.5em;
}

.text-display-1.line-2.brand {
  color: var(--brand--pink);
}

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

.button {
  background-color: var(--accent-01);
  text-transform: uppercase;
  border-radius: 200px;
  justify-content: center;
  align-items: center;
  margin-top: 3em;
  padding: 1.125em 3em;
  font-size: 14px;
  font-weight: 500;
}

.rich-text {
  max-width: 40em;
  margin-left: auto;
  margin-right: auto;
  font-size: 18px;
}

.rich-text h1 {
  margin-bottom: 32px;
  font-size: 2.5em;
}

.rich-text h2 {
  margin-bottom: 32px;
  font-size: 2em;
}

.rich-text h3 {
  margin-bottom: 24px;
  font-size: 1.75em;
}

.rich-text h4 {
  margin-bottom: 24px;
  font-size: 1.5em;
}

.rich-text h5 {
  margin-bottom: 20px;
  font-size: 1.25em;
}

.rich-text h6 {
  margin-bottom: 20px;
  font-size: 1em;
}

.rich-text p {
  color: var(--grey-01);
  margin-bottom: 32px;
  font-size: 1.125em;
  line-height: 1.5;
}

.rich-text li {
  margin-bottom: 12px;
}

.rich-text ul {
  color: var(--grey-01);
  margin-bottom: 32px;
  padding-left: 20px;
}

.rich-text ol {
  color: var(--grey-01);
  overflow: visible;
}

.rich-text figcaption {
  color: var(--grey-01);
  text-transform: uppercase;
  margin-top: 12px;
  font-size: 14px;
  font-weight: 700;
}

.rich-text blockquote {
  margin-bottom: 32px;
  font-size: 2em;
}

.rich-text figure {
  margin-top: 56px;
  margin-bottom: 56px;
}

.style-guide-color {
  height: 150px;
  margin-bottom: 12px;
}

.style-guide-color.accent-01 {
  background-color: var(--accent-01);
}

.style-guide-color.black-01 {
  border: 1px solid var(--black-03);
  background-color: var(--black-01);
}

.style-guide-color.black-02 {
  background-color: var(--black-02);
}

.style-guide-color.black-03 {
  background-color: var(--black-03);
}

.style-guide-color.grey-01 {
  background-color: var(--grey-01);
}

.style-guide-color.white-01 {
  background-color: var(--white-01);
}

.style-guide-color.grey-02 {
  background-color: var(--grey-02);
}

.nav-link {
  letter-spacing: -.01em;
  text-transform: uppercase;
  margin-left: 1.5em;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  transition: color .4s cubic-bezier(.23, 1, .32, 1);
}

.nav-link:hover, .nav-link.w--current:hover {
  color: var(--brand--pink);
}

.text-display-2 {
  font-size: 6em;
  transition: color .2s;
}

.text-display-2:hover {
  color: var(--brand--pink);
}

.text-display-3 {
  font-size: 4em;
}

.text-display-4 {
  color: var(--white-01);
  font-size: 3.5em;
}

.text-display-5 {
  font-size: 2.5em;
}

.text-display-6 {
  font-size: 2em;
}

.text-display-7 {
  text-transform: uppercase;
  font-size: 1.5em;
  font-weight: 700;
}

.text-body-1 {
  letter-spacing: -.03em;
  font-size: 3.3em;
  font-weight: 300;
  line-height: 1;
}

.text-body-1.cc {
  text-align: center;
}

.text-body-2 {
  letter-spacing: -.01em;
  max-width: 70%;
  font-size: 1.125em;
  line-height: 1.6;
}

.paragraph {
  letter-spacing: -.01em;
}

.text-micro-1 {
  letter-spacing: .01em;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
}

.text-micro-1.spaced {
  letter-spacing: .7em;
}

.text-micro-2 {
  letter-spacing: .01em;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.5;
}

.text-micro-2.grey-01.cc {
  text-align: center;
  justify-content: center;
  align-items: flex-end;
  width: 340px;
  max-width: 340px;
  margin-left: -40px;
  display: block;
}

.nav-btn {
  display: none;
}

.logo-img {
  height: 1.125em;
}

.header-nav {
  flex-direction: row;
  flex: 1;
  justify-content: flex-end;
  align-items: center;
  margin-top: 0;
  margin-bottom: 0;
  padding: 0;
  list-style-type: none;
  display: flex;
}

.logo-link {
  margin-left: 0;
  margin-right: 0;
  padding: 0;
}

.nav-btn-lottie {
  width: 32px;
  height: 32px;
}

.header {
  z-index: 99;
  background-color: #0000;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 4em;
  display: flex;
  position: sticky;
  top: 0;
}

.header-inner {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
}

.reel-contain {
  border-radius: 1.5em;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.reel-contain.home-hero {
  text-align: center;
  height: 42em;
}

.reel-contain.cta {
  text-align: center;
  height: 38em;
}

.reel-contain.blog {
  text-align: center;
  height: 42em;
  margin-top: 5em;
}

.reel-contain.slide-wrap {
  text-align: center;
  height: 42em;
}

.reel {
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.reel.home-hero, .reel.work {
  background-image: linear-gradient(#0000004d, #0000004d);
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  padding-bottom: 2em;
  padding-left: 2em;
  padding-right: 2em;
  display: flex;
}

.reel.cta {
  background-image: linear-gradient(#0000004d, #0000004d);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding-bottom: 2em;
  padding-left: 2em;
  padding-right: 2em;
  display: flex;
}

.reel-title {
  perspective: 2000px;
  margin-bottom: 2em;
}

.spacer-wrap {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
}

.spacer-icon {
  background-color: var(--white-01);
  border-radius: 50%;
  flex: none;
  width: 1em;
  height: 1em;
}

.spacer-icon.rec {
  background-color: var(--accent-01);
}

.spacer-line {
  background-color: #ffffff4d;
  flex: 1;
  height: 1px;
  margin-left: 1em;
  margin-right: 1em;
}

.col {
  width: 100%;
}

.col._11-20 {
  max-width: 55%;
}

.col._10-20 {
  max-width: 50%;
}

.col._6-20 {
  max-width: 30%;
}

.col._8-20 {
  max-width: 40%;
}

.col._3-20 {
  max-width: 15%;
}

.col._9-20 {
  max-width: 45%;
}

.col._5-20 {
  max-width: 25%;
}

.col._2-20 {
  max-width: 10%;
}

.col._12-20 {
  max-width: 60%;
}

.col._7-20 {
  max-width: 35%;
}

.col._1-20 {
  max-width: 5%;
}

.col._4-20 {
  max-width: 20%;
}

.col._13-20 {
  max-width: 65%;
}

.col._14-20 {
  max-width: 70%;
}

.col._15-20 {
  max-width: 75%;
}

.col._16-20 {
  max-width: 80%;
}

.col._17-20 {
  max-width: 85%;
}

.col._18-20 {
  max-width: 90%;
}

.col._19-20 {
  max-width: 95%;
}

.col._20-20 {
  max-width: 100%;
}

.style-guide-block {
  background-color: var(--grey-01);
  height: 4em;
}

.o-grid {
  grid-column-gap: 1em;
  grid-row-gap: 1em;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.row {
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  padding-left: 8em;
  padding-right: 8em;
  display: flex;
}

.row.company {
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
}

.row.slider-wrap {
  flex-direction: column;
  position: relative;
}

.row.story-content {
  flex-direction: row;
  justify-content: space-between;
}

.row.story-title {
  margin-bottom: 5em;
}

.row.work {
  grid-column-gap: 1.5em;
  grid-row-gap: 1.5em;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  margin-top: 5em;
  display: grid;
}

.row.hero-title, .row.template {
  text-align: center;
  justify-content: center;
  align-items: center;
}

.company-title {
  margin-bottom: 2.5em;
}

.grey-01 {
  color: var(--grey-01);
}

.company-text {
  width: 100%;
  max-width: 240px;
}

.about-card {
  border-radius: 1.5em;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding-top: 100%;
  display: flex;
  position: relative;
  overflow: hidden;
}

.about-card.content {
  border: 1px solid var(--black-03);
  text-align: center;
  justify-content: center;
  padding-top: 0%;
  padding-left: 4em;
  padding-right: 4em;
}

.about-card-title {
  margin-bottom: 1.5em;
}

.track {
  border: 1px solid var(--black-03);
  border-radius: 1.5em;
  justify-content: flex-start;
  align-items: center;
  height: 6.25em;
  display: flex;
  overflow: hidden;
}

.track-holder {
  flex: none;
  justify-content: center;
  align-items: center;
  display: flex;
}

.track-icon {
  background-color: var(--accent-01);
  border-radius: 50%;
  width: .75em;
  height: .75em;
  margin-left: 1.5em;
  margin-right: 1.5em;
}

.slider {
  border-radius: 1.5em;
  height: 42em;
  margin-top: 5em;
  position: relative;
}

.slide {
  border-radius: 1.5em;
  overflow: hidden;
}

.story-text {
  width: 100%;
  max-width: 296px;
}

.work-title {
  text-align: center;
  max-width: 47.75em;
  margin-left: auto;
  margin-right: auto;
}

.work-item {
  border-radius: 1.5em;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
  padding-left: 2.5em;
  position: relative;
  overflow: hidden;
}

.work-text {
  width: 100%;
  max-width: 26.1em;
  overflow: hidden;
}

.clients-wrap {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  border: 1px solid var(--black-03);
  border-radius: 1.5em;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
  overflow: hidden;
}

.clients-item {
  border-right: 1px solid var(--black-03);
  border-bottom: 1px solid var(--black-03);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 11.25em;
  margin-top: -1px;
  margin-right: -1px;
  display: flex;
}

.clients-item.last {
  border-bottom-style: none;
}

.blog-card {
  background-color: var(--black-03);
  border-radius: 1.5em;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  height: 25em;
  padding: 3.5em 2em 2em;
  display: flex;
  position: relative;
  overflow: hidden;
}

.blog-card-bottom {
  z-index: 10;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
  position: relative;
}

.blog-card-icon {
  width: 2em;
  transform: rotate(180deg);
}

.blog-card-top {
  z-index: 10;
  position: relative;
}

.blog-card-bg {
  z-index: 5;
  opacity: .7;
  perspective-origin: 100% 100%;
  transform-origin: 100% 100%;
  width: 12.5em;
  height: 12.5em;
  position: absolute;
  inset: auto 0% 0% auto;
}

.cta-title {
  margin-top: 2.5em;
  margin-bottom: 2.5em;
}

.social-wrap {
  display: flex;
}

.social-icon {
  border: 2px solid #ffffff4d;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 3em;
  height: 3em;
  margin-left: .375em;
  margin-right: .375em;
  transition: background-color .8s cubic-bezier(.23, 1, .32, 1);
  display: flex;
}

.social-icon:hover {
  background-color: #ffffff4d;
}

.logo-footer {
  width: 100%;
}

.footer-wrap {
  border: 1px solid var(--black-03);
  border-radius: 1.5em;
  justify-content: space-between;
  align-items: center;
  height: 5em;
  margin-top: 3.5em;
  padding-left: 2em;
  padding-right: 2em;
  display: flex;
}

.text-link {
  letter-spacing: .01em;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
  transition: color .4s cubic-bezier(.23, 1, .32, 1);
}

.text-link:hover {
  color: var(--grey-01);
}

.footer-links {
  grid-column-gap: 1.5em;
  grid-row-gap: 1.5em;
  display: flex;
}

.slider-left-arrow {
  width: 2.5em;
  height: 2.5em;
  font-size: 1vw;
  inset: -8.1em 3.2em auto auto;
}

.slider-right-arrow {
  justify-content: center;
  align-items: center;
  width: 2.5em;
  height: 2.5em;
  font-size: 1vw;
  display: flex;
  inset: -8.1em 0% auto auto;
}

.slide-nav {
  display: none;
}

.slider-arrow-icon.right {
  width: 2.5em;
  height: 2.5em;
  transform: rotate(180deg);
}

.slider-arrow-icon.left {
  width: 2.5em;
  height: 2.5em;
}

.reel-title-mask {
  padding-left: 1em;
  padding-right: 1em;
  overflow: hidden;
}

.template-text {
  max-width: 37.5em;
  margin-bottom: 5em;
}

.top-bar {
  background-color: var(--accent-01);
  text-align: center;
  letter-spacing: 0;
  text-transform: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 20px 24px;
  font-size: 16px;
  font-weight: 400;
  display: flex;
}

.licenses-item {
  background-color: var(--black-03);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 56.25em;
  padding: 32px;
  display: flex;
}

.licenses-text {
  margin-top: .7em;
}

.heading {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  text-align: center;
  text-transform: none;
  mix-blend-mode: normal;
  margin-left: 0;
  padding-left: 0;
  font-style: normal;
  font-weight: 700;
  text-decoration: none;
  display: block;
  position: static;
}

.section-2 {
  min-height: 500px;
  padding-top: 1px;
  padding-left: 0;
}

.heading-2, .heading-3 {
  font-size: 2em;
}

.container-2 {
  min-width: 500px;
  min-height: 100px;
  display: flex;
}

.div-block {
  grid-column-gap: 80px;
  grid-row-gap: 80px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  padding-top: 6em;
  display: flex;
}

.image {
  display: inline-block;
}

.image.hidden {
  display: none;
}

.div-block-2 {
  padding-left: 0;
}

.grid-x6 {
  grid-column-gap: 16px;
  grid-row-gap: 57px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 63%;
  display: grid;
}

.gid-block {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  flex-flow: row;
  width: 100%;
  display: flex;
}

.image-2 {
  width: 120px;
}

.p-body {
  color: #858585;
  max-width: 25ch;
  font-size: 16px;
}

.p-body.no-max {
  color: #ddd;
  text-shadow: 0 1px 1px #0003;
  mix-blend-mode: normal;
  max-width: 61%;
}

.p-body.no-ch {
  max-width: none;
}

.small-title {
  font-size: 24px;
}

.block-wrapper {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  flex-flow: column;
  display: flex;
}

.cards-body {
  max-width: 0;
}

.heading-4 {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.text-span {
  color: #e082b7;
}

.text-span-2 {
  color: var(--white-01);
}

.text-span-3 {
  color: #e082b7;
}

.fn-container-grid {
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  max-width: 1310px;
  padding-left: 15px;
  padding-right: 15px;
  display: grid;
}

.fn-contain-logo {
  color: #df0;
  object-fit: contain;
  object-position: 0% 50%;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
}

.fn-links-wrapper {
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  flex-direction: column;
  padding-left: 40px;
  display: flex;
}

.fn-standard-white-link {
  color: #ecf0ef;
  font-size: 14px;
  line-height: 1.4em;
  transition: color .25s;
  display: block;
}

.fn-standard-white-link:hover {
  color: var(--brand--pink);
}

.fn-standard-white-link.w--current {
  color: #df0;
}

.fn-footer-first {
  color: #ecf0ef;
  background-color: #0f1213;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding-top: 60px;
  padding-bottom: 60px;
  font-family: Open Sans, sans-serif;
  display: flex;
}

.fn-social-share-wrapper {
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  display: flex;
}

.fn-social-link {
  color: #687373;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  transition: color .25s;
  display: flex;
}

.fn-social-link:hover {
  color: #df0;
}

.fn-social-link-icon {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  display: flex;
}

.fn-footer-line {
  background-color: #3e4545;
  width: 100%;
  height: 1px;
  margin-top: 36px;
  margin-bottom: 10px;
}

.fn-legal-links-wrapper {
  grid-column-gap: 22px;
  grid-row-gap: 22px;
  flex-wrap: wrap;
  display: flex;
}

.fn-footer-legal-link {
  color: #939b9b;
  font-size: 14px;
  transition: color .25s;
}

.fn-footer-legal-link:hover {
  color: var(--brand--pink);
}

.fn-footer-copyright {
  color: #687373;
  font-size: 14px;
}

.fn-brand-footer {
  object-fit: contain;
  object-position: 0% 50%;
  width: 168px;
  height: 21.55px;
  margin-right: 20px;
}

.div-block-3 {
  background-color: #4d4d4d;
  width: 100%;
  height: .5px;
}

.bold-text {
  font-size: 14px;
  line-height: 1;
}

.bold-text-2 {
  font-size: 16px;
}

.image-3 {
  width: 150px;
  margin-top: -3px;
}

.product_section {
  flex-flow: column;
  padding-top: 11vw;
  padding-bottom: 5vw;
  display: flex;
}

.product_heading {
  color: #c6e643;
}

.product_link {
  border-bottom-style: solid;
  border-bottom-width: 1px;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding-top: 1.875rem;
  padding-bottom: 1.875rem;
  display: flex;
  position: relative;
}

.product_list {
  width: 100%;
  padding-top: 5em;
  padding-left: 8em;
  padding-right: 8em;
}

.product_title {
  text-shadow: 0 1px 1px #0003;
  font-size: 32px;
  line-height: 1;
}

.product_content {
  z-index: 11;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding-right: 3vw;
  display: flex;
  position: relative;
}

.product_header {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

.product_video {
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  object-fit: cover;
  border-radius: 20px;
  width: 80%;
  height: 500px;
  margin-left: 26.3em;
  position: absolute;
  overflow: hidden;
}

.product_number {
  white-space: nowrap;
}

.what-we-dp-wrapper {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  flex-flow: column;
  height: 40px;
  display: flex;
  overflow: hidden;
}

.text-block {
  margin-top: -23px;
  padding-bottom: 0;
  font-size: 14px;
}

.body-all-sections.paddiong {
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  flex-flow: column;
  padding-top: 10em;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
}

.large-title {
  font-size: 42px;
  line-height: 1;
}

.hover-link {
  transition: color .2s;
}

.hover-link:hover {
  color: var(--brand--pink);
}

@media screen and (max-width: 991px) {
  body {
    font-size: 16px;
  }

  h1 {
    font-size: 4em;
  }

  h2 {
    font-size: 3.5em;
  }

  h3 {
    font-size: 3em;
  }

  h4 {
    font-size: 2.5em;
  }

  h5 {
    font-size: 2em;
  }

  h6 {
    font-size: 1.5em;
  }

  p {
    font-size: 1em;
  }

  blockquote {
    font-size: 2em;
  }

  .section {
    padding-top: 5em;
    padding-bottom: 5em;
  }

  .section.padding-bottom-0 {
    padding-bottom: 0;
  }

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

  .container {
    padding-left: 1.5em;
    padding-right: 1.5em;
  }

  .grid-quarters {
    grid-column-gap: 24px;
  }

  .grid-quarters.style-guide, .grid.about {
    grid-template-columns: 1fr;
  }

  .grid.blog {
    grid-template-columns: 1fr 1fr;
  }

  .text-display-1 {
    font-size: 4em;
  }

  .text-display-1.line-1 {
    font-size: 2em;
    display: flex;
  }

  .text-display-1.line-2 {
    flex-flow: row;
    font-size: 3em;
    display: flex;
  }

  .grid-thirds {
    grid-column-gap: 24px;
  }

  .nav-link {
    border-bottom: 1px solid var(--black-03);
    width: 100%;
    margin-left: 0;
    padding: 1.25em 1.5em;
  }

  .text-display-2 {
    font-size: 3.5em;
  }

  .text-display-3 {
    font-size: 3em;
  }

  .text-display-4 {
    font-size: 2.5em;
  }

  .text-display-5 {
    font-size: 2em;
  }

  .text-display-6 {
    font-size: 1.5em;
  }

  .text-display-7 {
    font-size: 1.25em;
  }

  .text-body-1 {
    font-size: 2em;
  }

  .nav-btn {
    cursor: pointer;
    display: flex;
  }

  .header-nav {
    z-index: -1;
    background-color: var(--black-01);
    flex-direction: column;
    justify-content: center;
    height: auto;
    display: none;
    position: fixed;
    inset: 4em 0% auto;
  }

  .nav-btn-lottie {
    width: 1.5em;
    height: 1.5em;
  }

  .header {
    z-index: 2000;
    border-bottom: 1px solid var(--black-03);
    background-color: var(--black-01);
    height: 4em;
  }

  .reel-contain.home-hero {
    height: 0;
    padding-top: 56.25%;
  }

  .reel-contain.blog {
    height: 0;
    margin-top: 3em;
    padding-top: 56.25%;
  }

  .reel-contain.slide-wrap {
    height: 28em;
  }

  .spacer-wrap {
    margin-top: -20px;
  }

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

  .row.story-title {
    margin-bottom: 3em;
  }

  .row.work {
    grid-template-columns: 1fr;
    margin-top: 3em;
  }

  .about-card.content {
    padding-top: 8em;
    padding-bottom: 8em;
  }

  .slider {
    height: 28em;
    margin-top: 3em;
    margin-bottom: 3em;
  }

  .slider-mask {
    height: 28em;
  }

  .clients-wrap {
    grid-template-columns: 1fr 1fr 1fr;
  }

  .blog-card-bg {
    width: 10em;
    height: 10em;
  }

  .footer-wrap {
    flex-direction: column;
    justify-content: space-between;
    height: auto;
    padding-top: 2em;
    padding-bottom: 2em;
  }

  .footer-links {
    margin-top: 1em;
    margin-bottom: 1em;
  }

  .slider-left-arrow {
    width: 40px;
    height: 40px;
    inset: auto auto -56px 0%;
  }

  .slider-right-arrow {
    width: 40px;
    height: 40px;
    inset: auto auto -56px 56px;
  }

  .slider-arrow-icon.right, .slider-arrow-icon.left {
    width: 40px;
    height: 40px;
  }

  .heading {
    margin-left: 20px;
  }

  .section-2 {
    padding-left: 20px;
    padding-right: 20px;
  }

  .grid-x6 {
    width: 100%;
  }

  .p-body.no-max {
    max-width: none;
  }

  .fn-container-grid {
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  }

  .fn-standard-white-link {
    transition: none;
  }

  .fn-standard-white-link:hover {
    color: #ecf0ef;
  }

  .fn-footer-first {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .fn-footer-legal-link {
    transition: none;
  }

  .fn-footer-legal-link:hover {
    color: #939b9b;
  }

  .fn-brand-footer {
    z-index: 2;
    margin-bottom: 11px;
  }

  .product_section {
    padding-top: 2rem;
  }

  .product_link {
    grid-column-gap: 1rem;
    grid-row-gap: 1.5rem;
    flex-flow: column;
    padding-left: 3vw;
    padding-right: 3vw;
  }

  .product_list {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
  }

  .product_content {
    flex-wrap: wrap;
    padding-right: 0;
  }

  .product_header {
    width: 100%;
  }

  .product_video {
    opacity: 1;
    flex: none;
    width: 100%;
    margin-left: 0;
    position: relative;
  }

  .what-we-dp-wrapper {
    height: auto;
  }
}

@media screen and (max-width: 767px) {
  .section {
    padding-top: 5em;
    padding-bottom: 5em;
  }

  .container {
    padding-left: 1.25em;
    padding-right: 1.25em;
  }

  .grid.blog {
    grid-template-columns: 1fr;
  }

  .text-display-1 {
    font-size: 3em;
  }

  .text-display-1.line-1 {
    flex-flow: column;
    font-size: 1.5em;
  }

  .text-display-1.line-2 {
    flex-flow: column;
    padding-top: 0;
  }

  .grid-thirds.style-guide {
    grid-template-columns: 1fr 1fr;
  }

  .nav-link {
    padding-left: 1.25em;
    padding-right: 1.25em;
  }

  .text-display-2 {
    font-size: 2.5em;
  }

  .text-display-3 {
    font-size: 2em;
  }

  .text-display-4 {
    font-size: 1.75em;
  }

  .text-display-5 {
    font-size: 1.5em;
  }

  .text-display-6 {
    font-size: 1.25em;
  }

  .text-display-7 {
    font-size: 1.125em;
  }

  .reel-contain.slide-wrap {
    height: 20em;
  }

  .reel.home-hero {
    padding-top: 0;
  }

  .reel.work {
    padding-bottom: 1.25em;
    padding-left: 1.25em;
    padding-right: 1.25em;
  }

  .spacer-wrap {
    margin-top: -23px;
    padding-top: 0;
  }

  .col._10-20 {
    max-width: 100%;
  }

  .row.story-content {
    flex-direction: column;
  }

  .row.story-title {
    margin-bottom: 3em;
  }

  .slider {
    height: 20em;
    margin-top: 3em;
  }

  .slider-mask {
    height: 20em;
  }

  .story-text {
    max-width: 100%;
    margin-bottom: 1em;
  }

  .clients-wrap {
    grid-template-columns: 1fr 1fr;
  }

  .blog-card {
    padding-top: 2em;
  }

  .text-span {
    flex-flow: column;
    flex: none;
    display: inline-flex;
  }

  .fn-container-grid {
    grid-column-gap: 12px;
    grid-row-gap: 12px;
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }

  .fn-footer-first {
    text-align: center;
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .fn-social-share-wrapper {
    flex-direction: row;
    margin-top: 12px;
  }

  .fn-footer-line {
    margin-top: 12px;
  }

  .fn-brand-footer {
    margin-right: 0;
    padding-left: 0;
  }

  .flex-block {
    justify-content: flex-start;
    align-items: center;
  }

  .product_section {
    padding-bottom: 5.4rem;
  }
}

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

  h2 {
    font-size: 2.25em;
  }

  h3 {
    font-size: 2em;
  }

  h4 {
    font-size: 1.75em;
  }

  h5 {
    font-size: 1.5em;
  }

  h6 {
    font-size: 1.25em;
  }

  .section {
    padding-top: 3.75em;
    padding-bottom: 3.75em;
  }

  .section.padding-bottom-0.hidden {
    display: none;
  }

  .section.story {
    padding-bottom: 0;
  }

  .grid-quarters {
    grid-template-columns: 1fr 1fr;
  }

  .text-display-1 {
    font-size: 2.5em;
  }

  .text-display-1.line-1 {
    font-size: .8em;
  }

  .text-display-1.line-2 {
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-end;
    font-size: 1.5em;
  }

  .grid-thirds, .grid-thirds.style-guide {
    grid-template-columns: 1fr;
  }

  .rich-text h1 {
    font-size: 2em;
  }

  .rich-text h2 {
    font-size: 1.75em;
  }

  .rich-text h3 {
    font-size: 1.5em;
  }

  .rich-text h4 {
    font-size: 1.25em;
  }

  .rich-text h5 {
    font-size: 1em;
  }

  .rich-text h6 {
    font-size: .75em;
  }

  .rich-text p, .rich-text ul {
    font-size: 1em;
  }

  .rich-text blockquote {
    font-size: 1.5em;
  }

  .text-display-2 {
    font-size: 2em;
  }

  .text-body-1 {
    font-size: 1.5em;
  }

  .text-body-2 {
    max-width: none;
  }

  .text-micro-1.spaced {
    letter-spacing: 0;
  }

  .logo-link {
    border-top: 1px #c4c4c4;
  }

  .logo-link.w--current {
    border-top-style: none;
  }

  .header {
    padding: 0;
  }

  .reel-contain.home-hero {
    padding-top: 100%;
  }

  .reel-contain.cta {
    height: 28em;
  }

  .reel-contain.slide-wrap {
    height: 14em;
  }

  .reel.home-hero {
    justify-content: flex-end;
    align-items: flex-start;
    padding-left: 1.25em;
    padding-right: 1.25em;
  }

  .spacer-wrap {
    justify-content: space-between;
    align-items: center;
    margin-top: 0;
    margin-bottom: -15px;
    padding-bottom: 0;
  }

  .col._11-20, .col._6-20, .col._8-20, .col._3-20, .col._9-20, .col._5-20, .col._2-20, .col._12-20, .col._7-20, .col._1-20, .col._4-20, .col._13-20, .col._14-20, .col._15-20, .col._16-20, .col._17-20, .col._18-20, .col._19-20 {
    max-width: 100%;
  }

  .about-card.content {
    padding: 6em 1.25em;
  }

  .slider, .slider-mask {
    height: 14em;
  }

  .clients-wrap {
    grid-template-columns: 1fr;
  }

  .clients-item {
    height: 8em;
  }

  .blog-card {
    height: 20em;
    padding-bottom: 1.25em;
    padding-left: 1.25em;
    padding-right: 1.25em;
  }

  .blog-card-bg {
    width: 8em;
    height: 8em;
  }

  .footer-wrap {
    padding-left: 1.25em;
    padding-right: 1.25em;
  }

  .footer-links {
    grid-column-gap: 1em;
    grid-row-gap: 0em;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
  }

  .reel-title-mask {
    padding-left: .4em;
    padding-right: .4em;
  }

  .top-bar {
    font-size: 14px;
    line-height: 1.2;
  }

  .licenses-item {
    padding: 24px;
  }

  .heading {
    margin-left: 17px;
  }

  .section-2 {
    padding-top: 0;
  }

  .div-block {
    grid-column-gap: 24px;
    grid-row-gap: 24px;
    padding-top: 40px;
  }

  .grid-x6 {
    grid-template-columns: 1fr 1fr;
  }

  .gid-block {
    flex-flow: column;
  }

  .p-body.no-max {
    max-width: none;
  }

  .text-span {
    flex: none;
    display: block;
  }

  .fn-container-grid {
    place-items: center;
  }

  .fn-links-wrapper {
    margin-bottom: 12px;
    padding-left: 0;
  }

  .fn-standard-white-link {
    max-width: 20ch;
  }

  .fn-legal-links-wrapper {
    grid-column-gap: 24px;
    grid-row-gap: 24px;
    flex-direction: column;
    margin-top: 12px;
    margin-bottom: 12px;
  }

  .product_section {
    padding-bottom: 2rem;
  }

  .product_link {
    border-bottom-style: solid;
    border-bottom-color: #4b4b4b;
    flex-direction: column;
    padding: 1.5rem 0;
  }

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

  .product_header {
    padding-left: 20px;
    padding-right: 20px;
  }

  .product_video {
    z-index: 12;
    width: 100%;
    height: 255px;
    margin-left: 0;
  }

  .what-we-dp-wrapper {
    height: auto;
  }
}

#w-node-e9b50993-8880-c1c1-9d5a-2d5cb08f22fe-2ada1172, #w-node-_9c4e3bfa-b8ef-d3cf-3f35-bb9bafa13ee1-2ada1172, #w-node-_7f90bf18-484e-6c77-b756-dff1f1e7149d-2ada1172 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-c5fb2864-ebab-b0f6-4547-3975dbce3caf-2ada1172 {
  grid-area: span 1 / span 3 / span 1 / span 3;
}

#w-node-d69096f6-1eb0-67ae-8433-042b2873d078-2ada1172, #w-node-_61c4657a-7774-78d2-f6b6-28387cda47d0-2ada1172, #w-node-_7fef2f1b-1a5a-f604-fbcf-5d2054191063-2ada1172, #w-node-d699604d-2e11-6f01-943d-887da7c45185-2ada1172, #w-node-_39fdca48-8a8c-ff02-a7f5-82506b0e6bdc-2ada1172, #w-node-fd56ca6e-7934-c775-6b0e-193297c1c6d4-2ada1172, #w-node-_5063f33e-c9cd-a2e4-bd1a-2fca4e8aeb27-2ada1172, #w-node-a0473834-6e6f-282f-b70c-15cec276a27a-2ada1172, #w-node-_058d3a3f-af44-42f8-0f75-d1f87eeaee6f-2ada1172, #w-node-abe71499-7bc6-7eea-94ae-fe8339ebd757-2ada1172, #w-node-c6ef8996-ba6e-090a-c305-238357b84588-2ada1172, #w-node-c9eefad4-8ef0-7c6b-bcc5-5a6b970bcead-2ada1172, #w-node-_4f98f72f-3339-ae79-c525-1bc93c68d17b-2ada1172, #w-node-_58823a00-6f71-d57b-d5ce-b3d9110bebd8-2ada1172, #w-node-_6090fd15-1795-1720-0e7b-af4c425e9266-2ada1172, #w-node-_84a13e05-fbd3-08c2-9a5f-3bc667065901-2ada1172 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-b3bc66d6-d5e7-c05c-823c-5538613310cd-b826b1cd {
  grid-area: span 1 / span 2 / span 1 / span 2;
}

#w-node-b3bc66d6-d5e7-c05c-823c-5538613310cf-b826b1cd, #w-node-edf0f699-376e-04c7-8d40-b80f5d10b34b-b826b1cd {
  grid-area: span 1 / span 3 / span 1 / span 3;
}

#w-node-b3bc66d6-d5e7-c05c-823c-5538613310e1-b826b1cd {
  grid-area: span 1 / span 4 / span 1 / span 4;
}

#w-node-b3bc66d6-d5e7-c05c-823c-5538613310f3-b826b1cd {
  grid-area: span 1 / span 12 / span 1 / span 12;
}

#w-node-b3bc66d6-d5e7-c05c-823c-5538613310f4-b826b1cd {
  grid-area: span 1 / span 6 / span 1 / span 6;
}

#w-node-b3bc66d6-d5e7-c05c-823c-5538613310fb-b826b1cd {
  grid-area: span 1 / span 6 / span 1 / span 6;
  justify-self: end;
}

@media screen and (max-width: 991px) {
  #w-node-c5fb2864-ebab-b0f6-4547-3975dbce3caf-2ada1172 {
    grid-area: span 1 / span 1 / span 1 / span 1;
  }

  #w-node-b3bc66d6-d5e7-c05c-823c-5538613310cd-b826b1cd, #w-node-b3bc66d6-d5e7-c05c-823c-5538613310f3-b826b1cd {
    grid-column: span 8 / span 8;
  }

  #w-node-b3bc66d6-d5e7-c05c-823c-5538613310f4-b826b1cd, #w-node-b3bc66d6-d5e7-c05c-823c-5538613310fb-b826b1cd {
    grid-column: span 4 / span 4;
  }
}

@media screen and (max-width: 767px) {
  #w-node-b3bc66d6-d5e7-c05c-823c-5538613310cd-b826b1cd {
    grid-column: span 4 / span 4;
    justify-self: center;
  }

  #w-node-b3bc66d6-d5e7-c05c-823c-5538613310cf-b826b1cd, #w-node-edf0f699-376e-04c7-8d40-b80f5d10b34b-b826b1cd, #w-node-b3bc66d6-d5e7-c05c-823c-5538613310e1-b826b1cd, #w-node-b3bc66d6-d5e7-c05c-823c-5538613310f3-b826b1cd {
    grid-column: span 4 / span 4;
  }

  #w-node-b3bc66d6-d5e7-c05c-823c-5538613310f4-b826b1cd, #w-node-b3bc66d6-d5e7-c05c-823c-5538613310fb-b826b1cd {
    justify-self: center;
  }
}


@font-face {
  font-family: 'Red hat display';
  src: url('../fonts/red-hat-display-bold.woff2') format('woff2');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Red hat display';
  src: url('../fonts/red-hat-display-bold.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Red hat display';
  src: url('../fonts/red-hat-display-bold.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Red hat display';
  src: url('../fonts/red-hat-display-bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}