@font-face {
  font-family: Neue Haas Display;
  src: url('../fonts/NeueHaasDisplayBlack.ttf') format("truetype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Neue Haas Display;
  src: url('../fonts/NeueHaasDisplayMediu.ttf') format("truetype"), url('../fonts/NeueHaasDisplayRoman.ttf') format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Neue Haas Display;
  src: url('../fonts/NeueHaasDisplayBold.ttf') format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Neue Haas Display;
  src: url('../fonts/NeueHaasDisplayThin.ttf') format("truetype");
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Neue Haas Display;
  src: url('../fonts/NeueHaasDisplayLight.ttf') format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

:root {
  --grey: #bbb;
  --brand-color-01: #00fff0;
  --light-yellow: #fcff7c;
  --white: white;
  --yellow: #faff00;
  --black: black;
  --nav-bar: #424242ab;
  --nav-bar-expanded: #555555e8;
}

.w-layout-layout {
  grid-row-gap: 20px;
  grid-column-gap: 20px;
  grid-auto-columns: 1fr;
  justify-content: center;
  padding: 20px;
}

.w-layout-cell {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

body {
  color: #fff;
  background-color: #000;
  font-family: neue-haas-grotesk-text, sans-serif;
  font-size: .8vw;
  font-weight: 600;
  line-height: 1.5;
}

h2 {
  text-transform: uppercase;
  margin-top: 20px;
  margin-bottom: 10px;
  font-size: 32px;
  font-weight: 700;
  line-height: 36px;
}

h3 {
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.4vw;
  font-weight: 700;
  line-height: 1;
}

h4 {
  color: var(--grey);
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2vw;
  font-weight: 600;
  line-height: 1;
}

p {
  margin-bottom: 1.5vw;
}

a {
  color: #000;
  text-decoration: none;
}

.header-section {
  z-index: -1;
  justify-content: center;
  align-items: center;
  height: 100svh;
}

.container {
  max-width: none;
  margin-left: auto;
  margin-right: auto;
  padding-left: 30px;
  padding-right: 30px;
}

.container.footer {
  background-color: #00fff0;
  border-top: 1.5px solid #fff;
}

.navbar-section {
  z-index: 1000;
  position: fixed;
  inset: 0% 0% auto;
}

.nav-wrapper {
  justify-content: space-between;
  align-items: center;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 20px;
  padding-bottom: 18px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.nav-wrapper.footer {
  padding-top: 2vw;
  padding-bottom: 0;
}

.nav-link {
  color: #fff;
  text-transform: uppercase;
  justify-content: center;
  align-items: center;
  padding-left: 10px;
  padding-right: 10px;
  font-size: 12px;
  font-weight: 400;
  text-decoration: none;
  transition: color .2s;
  display: flex;
}

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

.nav-link:active {
  color: var(--light-yellow);
}

.nav-link.w--current {
  opacity: .5;
}

.nav-link.sign-up-nav {
  margin-left: 0;
  margin-right: -10px;
}

.nav-link.sign-up-nav:hover {
  color: var(--brand-color-01);
}

.nav-link.sign-up-nav.back-to-top {
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
  padding-right: 0;
  font-size: 1vw;
}

.nav-link.sign-up-nav.footer {
  justify-content: flex-end;
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
  padding-right: 0;
  font-size: 12px;
}

.nav-link.footer:active, .nav-link.footer.w--current {
  color: var(--yellow);
}

.nav-link.jp {
  padding-left: 3px;
}

.nav-link.jp.w--current:hover {
  color: var(--white);
}

.nav-link.en {
  padding-right: 4px;
}

.nav-link.en.w--current:hover {
  color: var(--white);
}

.footer-nav {
  flex-flow: column;
  display: flex;
}

.main-logo {
  width: 2.7vw;
  display: block;
}

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

.ruler {
  background-color: #fff;
  min-height: 2px;
}

.ruler.no-rule {
  display: none;
}

.lower-footer-wrapper {
  justify-content: space-between;
  padding-bottom: 15px;
  display: flex;
}

.standard-text {
  text-transform: uppercase;
  font-size: 1vw;
  font-weight: 600;
}

.standard-text.footer {
  padding-top: 10px;
  padding-bottom: 10px;
}

.button-link {
  z-index: 10000;
  cursor: pointer;
  margin-right: 0;
  text-decoration: none;
}

.footer-branding {
  color: #000;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 400;
}

.footer-branding.lower-content {
  font-size: 10px;
}

.navbar-mobile, .mobile-menu-link, .mobile-overlay {
  display: none;
}

.logo {
  z-index: auto;
  text-align: center;
  text-transform: uppercase;
  width: 15vw;
  font-size: 12px;
  font-weight: 400;
  display: block;
  position: absolute;
  inset: auto 0% auto 50%;
  transform: translate(-50%);
}

.hello {
  z-index: 2000;
}

.konnichiwa {
  -webkit-text-stroke-width: .7px;
  -webkit-text-stroke-color: var(--white);
  display: none;
}

.kia-ora, .hola {
  display: none;
}

.ni-hao, .marhaban, .namaste {
  -webkit-text-stroke-width: .5px;
  display: none;
}

.ola {
  display: none;
}

.annyeong-haseyo {
  -webkit-text-stroke-width: .5px;
  display: none;
}

.hallo, .merhaba, .xin-chao, .ciao, .czesc, .hej, .hei, .zdravstvuyte {
  display: none;
}

.hyalo {
  -webkit-text-stroke-width: .5px;
  display: none;
}

.bonjour {
  display: none;
}

.link-block-2 {
  position: relative;
}

.link-block-2.w--current {
  z-index: 3000;
}

.sticky-header {
  z-index: 0;
  position: fixed;
  inset: 0% auto auto 0%;
}

.div-block-22 {
  z-index: -500;
  filter: none;
  background-image: url('../images/047A6872-v2.jpg');
  background-position: 0 0;
  background-size: 100vw;
  width: 105vw;
  height: 6vw;
  display: none;
  position: absolute;
  inset: 0% 0% auto;
  overflow: hidden;
}

.nav-blur {
  z-index: -1;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  position: absolute;
  inset: 0%;
  overflow: hidden;
}

.nav-bg-color {
  z-index: -1;
  position: absolute;
  inset: 0%;
}

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

.ethos-full-wrapper {
  background-color: #00fff0;
  border-top: 2px solid #fff;
  flex-flow: column;
  justify-content: space-between;
  width: 100vw;
  height: 100vh;
  display: flex;
}

.titles-wrapper {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 75vw;
  margin-top: 37svh;
  padding-left: 30px;
  padding-right: 30px;
  display: flex;
  position: absolute;
}

.main-title {
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: .8vw;
  font-size: 4.9vw;
  line-height: 1;
}

.main-title.shadow {
  text-shadow: 2px 2px 11px #00000094;
}

.main-sub-title {
  color: var(--white);
  width: 47vw;
  font-size: 1.5vw;
  font-weight: 400;
  line-height: 1.2;
}

.main-sub-title.shadow {
  text-shadow: 2px 2px 9px #00000080;
  margin-top: 0;
  margin-bottom: 0;
}

.ethos-write-up-holder {
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  display: flex;
}

.paragraph-wrapper {
  flex-flow: column;
  flex: 1;
  justify-content: center;
  align-items: stretch;
  width: 34vw;
  display: flex;
}

.heading-6 {
  color: #000;
  margin-top: 0;
  margin-bottom: .8vw;
  font-size: 2.2vw;
}

.heading-6.breakdown-heading {
  color: #fff;
  text-align: center;
  margin-bottom: .4vw;
  line-height: 1.2;
}

.ethos {
  color: #000;
  text-transform: uppercase;
  margin-bottom: 0;
  font-size: 1vw;
  font-weight: 400;
  line-height: 1.2;
}

.ethos.breakdown {
  color: #fff;
  text-align: center;
}

.ethos.header-paragraph {
  color: #fff;
  text-align: right;
  padding-right: 10px;
}

.ethos.cta-paragraph {
  color: #fff;
  text-transform: none;
}

.ethos.sticky {
  position: sticky;
  top: 15vh;
}

.ethos-text-holders {
  justify-content: space-between;
  width: 100%;
  display: flex;
}

.ethos-text-holders.top {
  margin-top: 3vw;
  display: none;
}

.ethos-text-holders.bottom {
  margin-bottom: 3vw;
}

.ethos-content-wrapper {
  z-index: 1;
  flex-flow: column;
  flex: 1;
  justify-content: space-between;
  align-items: stretch;
  margin-left: 30px;
  margin-right: 30px;
  display: flex;
  position: relative;
}

.nav-bar-text {
  font-weight: 400;
}

.nav-bar-text.slash {
  font-size: 12px;
}

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

.breakdown-content-wrapper {
  background-image: linear-gradient(#777, #505050);
  border-top: 1.5px solid #fff;
  border-bottom: 1.5px solid #fff;
  padding-top: 3vw;
  padding-bottom: 4vw;
}

.stack-split {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  outline-offset: 0px;
  outline: 1.7px solid #fff;
  width: 46vw;
  height: 23vw;
  padding: 0;
}

.quick-stack-breakdown {
  grid-column-gap: 4vw;
  grid-row-gap: 4vw;
  margin-top: 3vw;
  padding: 0;
}

.left-cell-split {
  border-right: .85px solid #fff;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.right-cell-split {
  border-left: .85px solid #fff;
  width: 100%;
  height: 100%;
}

.breakdown-title-holder {
  border-bottom: 1.7px solid #fff;
  justify-content: flex-start;
  align-items: center;
  height: 22%;
  padding-left: 1.2vw;
  display: flex;
}

.breakdown-paragraph-holder {
  flex-flow: column;
  justify-content: space-around;
  width: 100%;
  height: 78%;
  padding-left: 1.2vw;
  padding-right: 1.2vw;
  display: flex;
}

.paragraph {
  margin-bottom: .7vw;
  font-size: 1.03vw;
  font-weight: 400;
  line-height: 1.25;
}

.paragraph.jp-tracking-adjust {
  letter-spacing: -.07vw;
}

.slogan {
  justify-content: flex-end;
  height: 6.3vw;
  margin-bottom: 2vw;
  padding-right: 27px;
  display: flex;
  position: absolute;
  inset: auto 0% 0% auto;
  overflow: hidden;
}

.breakdown-image {
  width: 100%;
  overflow: visible;
}

.breakdown-main-cell {
  transition: transform .35s cubic-bezier(.455, .03, .515, .955), box-shadow .2s cubic-bezier(.455, .03, .515, .955);
}

.breakdown-main-cell:hover {
  transform: translate(-.3vw, -.3vw);
  box-shadow: 9px 9px 7px #0000005e;
}

.bg-image-wrapper {
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 120vh;
  display: flex;
  position: absolute;
  overflow: hidden;
}

.ethos-bg-image-01 {
  aspect-ratio: auto;
  opacity: .06;
  mix-blend-mode: multiply;
  object-fit: fill;
  max-width: none;
  height: 120%;
  overflow: visible;
}

.footer-logo {
  flex-flow: column;
  align-items: flex-start;
  display: flex;
}

.text-block-4 {
  color: #000;
}

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

.cta-full-wrapper {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  position: relative;
}

.cta-content-wrapper {
  z-index: 10000;
  outline-offset: 0px;
  background-color: #515151e6;
  outline: 1.5px solid #fff;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 40vw;
  padding: 3vw 4vw;
  transition: box-shadow .2s cubic-bezier(.455, .03, .515, .955), transform .35s cubic-bezier(.455, .03, .515, .955);
  display: flex;
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
}

.cta-content-wrapper:hover {
  transform: translate(-51.5%, -51.5%);
  box-shadow: 9px 9px 7px #0000005e;
}

.heading-7 {
  margin-top: 0;
  margin-bottom: 1.2vw;
  font-size: 2.2vw;
  line-height: 1.2;
}

.cta-button-wrapper {
  grid-column-gap: 1vw;
  grid-row-gap: 1vw;
  display: flex;
}

.pl-wrapper {
  z-index: 5000;
  background-color: #5e5e5e;
  width: 100vw;
  min-height: 100svh;
  display: none;
  position: fixed;
  inset: 0% auto auto 0%;
}

.pl-bg-holder {
  z-index: -5;
  width: 100vw;
  min-height: 100svh;
  display: block;
  position: absolute;
  inset: 0%;
}

.pl-top-wrapper {
  justify-content: space-between;
  align-items: flex-start;
  margin-top: 20px;
  display: flex;
}

.pl-texts {
  color: #fff;
  text-transform: uppercase;
  margin-bottom: 0;
  font-size: 1.2vw;
  font-weight: 400;
  line-height: 1.3;
}

.pl-logo-mark {
  width: 5vw;
}

.pl-mid-wrapper {
  z-index: -5;
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
  inset: 0%;
}

.pl-bottom-wrapper {
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 20px;
  display: flex;
}

.pl-content-wrapper {
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  min-height: 100svh;
  display: flex;
}

.loading-percentage {
  color: #fff;
  text-transform: uppercase;
  margin-bottom: 0;
  font-size: 3vw;
  font-weight: 400;
  line-height: 1.3;
}

.pl-white-logo {
  width: 100%;
  min-width: 100%;
  position: absolute;
}

.pl-white-logo-wrapper {
  align-items: flex-start;
  width: 55vw;
  height: 9vh;
  display: flex;
  position: absolute;
}

.pl-number-wrapper {
  display: flex;
}

.percentage-sign {
  color: #fff;
  text-transform: uppercase;
  margin-bottom: 0;
  font-size: 3vw;
  font-weight: 400;
  line-height: 1.3;
}

.pl-white-logo-mask {
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
}

.pl-color-logo-wrapper {
  z-index: 1;
  align-items: flex-start;
  width: 55vw;
  height: 9vh;
  display: flex;
  position: absolute;
}

.pl-color-logo-mask {
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
}

.pl-color-logo {
  width: 100%;
  min-width: 55vw;
  position: absolute;
}

.div-hide {
  overflow: hidden;
}

.button-wrapper {
  -webkit-backdrop-filter: brightness(85%) blur(3px);
  backdrop-filter: brightness(85%) blur(3px);
  margin-top: 1.5vw;
  margin-bottom: 10px;
  margin-right: 10px;
  box-shadow: 2px 2px 6px #0000005c;
}

.nav-bar {
  background-color: var(--nav-bar);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
}

.button-01 {
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  vertical-align: middle;
  margin-bottom: 0;
  padding: 7px 22px;
  font-size: 1.2vw;
  font-weight: 400;
  display: inline-block;
}

.button-01.hover {
  color: #000;
  font-weight: 400;
}

.button-01.shadow {
  text-shadow: 0 1px #0000003d;
}

.button-01.cta {
  font-size: 1vw;
}

.button-01-interaction {
  border: 2px solid #fff;
  position: relative;
}

.button-01-interaction.cta {
  border-width: 1px;
}

.button-div-hide {
  display: none;
  position: absolute;
  inset: 0% auto auto 0%;
  overflow: hidden;
}

.button-hover-bg {
  z-index: -1;
  background-color: var(--brand-color-01);
  position: absolute;
  inset: 0%;
}

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

.language-link-wrapper {
  margin-right: 15px;
  display: flex;
}

.ethos-logo {
  z-index: auto;
  text-align: center;
  font-size: 12px;
  font-weight: 400;
}

.ethos-logo.ethos {
  text-align: left;
  margin-bottom: .2vw;
  font-size: 1vw;
  font-weight: 500;
}

.div-block-37 {
  justify-content: space-between;
  padding-bottom: 2vw;
  display: flex;
}

.div-block-38 {
  background-color: var(--black);
  height: 1px;
  margin-top: 1.4vw;
  margin-bottom: 1.4vw;
}

.ethos-sticky-holder {
  position: absolute;
  inset: 6vh auto 0;
}

.header-video-background-section-copy-me {
  z-index: -100;
  filter: brightness(90%);
  justify-content: center;
  align-items: center;
  width: 100vw;
  min-height: 100svh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.video-wrapper {
  z-index: -999;
  width: 1000%;
  height: 100%;
  padding-bottom: 56.25%;
  display: block;
  position: absolute;
}

.video-embed {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.ethos-bg-image-mobile-01 {
  aspect-ratio: auto;
  opacity: .06;
  mix-blend-mode: multiply;
  object-fit: fill;
  max-width: none;
  display: none;
  overflow: visible;
}

.header-back-up-bg-image-low-power-ios {
  z-index: -1000;
  max-width: none;
  height: 100%;
  display: block;
  position: absolute;
  overflow: visible;
}

.cta-video-background-section-copy-me-copy {
  z-index: -1;
  justify-content: center;
  align-items: flex-start;
  width: 100vw;
  min-height: 75svh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.cta-back-up-bg-image-low-power-ios {
  z-index: -1000;
  max-width: none;
  height: 100%;
  display: block;
  position: absolute;
  overflow: visible;
}

.home-top-link {
  display: block;
}

.drop-down-nav---mobile {
  display: none;
}

.nav-link-wrapper---mobile {
  display: flex;
}

.gradient-wrapper {
  z-index: -1;
  opacity: .75;
  filter: blur(160px);
  min-height: 90vh;
  position: absolute;
  inset: 0%;
}

.circle {
  background-color: #fe3218;
  border-radius: 50%;
  width: 50vw;
  height: 80vh;
  position: absolute;
  inset: 0% 0% auto auto;
}

.circle._1 {
  background-color: #85bec9b8;
  top: -25%;
  left: 1%;
}

.circle._2 {
  background-color: #252525;
  inset: -25% -10% auto auto;
}

.circle._4 {
  background-color: #6b6b6b;
  inset: auto -10% -25% auto;
}

.circle._3 {
  background-color: #303030;
  inset: auto auto -39% -4%;
}

.pl-mid-wrapper---mobile {
  display: none;
}

.pl-color-logo-wrapper---mobile {
  z-index: 1;
  align-items: flex-start;
  width: 55vw;
  height: 9vh;
  display: flex;
  position: absolute;
}

.pl-color-logo-mask--mobile {
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
}

.pl-color-logo--mobile {
  width: 100%;
  min-width: 55vw;
  position: absolute;
}

.pl-white-logo-wrapper---mobile {
  z-index: 1;
  align-items: flex-start;
  width: 55vw;
  height: 9vh;
  display: flex;
  position: absolute;
}

.pl-white-logo-mask--mobile {
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
}

.pl-white-logo--mobile {
  width: 100%;
  min-width: 55vw;
  position: absolute;
}

.utility-page-wrap {
  background-color: #414141;
  background-image: linear-gradient(#646464, #505050);
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 20vw;
  display: flex;
}

.utility-page-form {
  flex-direction: column;
  align-items: center;
  display: flex;
}

.image {
  display: none;
}

.text-field {
  text-align: center;
  background-color: #fff0;
  border: .2vw solid #fff;
  margin-bottom: 1.5vw;
  padding: .5vw 1.2vw;
  font-size: 1.2vw;
  font-weight: 400;
}

.submit-button {
  color: #000;
  text-transform: uppercase;
  background-color: #fff;
  padding: .7vw 3vw;
  font-size: 1.2vw;
  font-weight: 400;
}

.field-label {
  display: none;
}

.heading-8 {
  margin-top: 0;
  margin-bottom: 1.5vw;
  font-size: 2.65vw;
  line-height: 1.2;
}

.heading-9 {
  margin-top: 1.5vw;
  margin-bottom: .4vw;
  font-size: 2.2vw;
  line-height: 1.2;
}

.text-block-5 {
  font-size: 1vw;
  font-weight: 400;
  line-height: 1.2;
}

.krk-link {
  cursor: pointer;
}

.krk-link:hover {
  font-style: italic;
}

.drone-link {
  color: var(--brand-color-01);
}

@media screen and (min-width: 1440px) {
  .main-sub-title.shadow {
    text-shadow: 1px 1px 6px #0003;
  }

  .pl-white-logo-wrapper, .pl-color-logo-wrapper, .pl-color-logo-wrapper---mobile, .pl-white-logo-wrapper---mobile {
    height: 10vh;
  }
}

@media screen and (max-width: 991px) {
  .header-section {
    min-height: 600px;
  }

  .navbar-section {
    display: block;
  }

  .nav-wrapper {
    padding-top: 20px;
    padding-bottom: 15px;
  }

  .nav-link {
    font-size: 1.5vw;
  }

  .nav-link.sign-up-nav.back-to-top:hover {
    color: var(--white);
  }

  .nav-link.sign-up-nav.back-to-top:active {
    color: var(--light-yellow);
  }

  .nav-link.sign-up-nav.footer {
    font-size: 1.3vw;
  }

  .nav-link.footer {
    color: var(--grey);
    font-size: 1.8vw;
  }

  .nav-link.mobile {
    border-bottom: 2px solid var(--white);
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
    font-size: 5vw;
  }

  .nav-link.mobile:hover {
    color: var(--white);
  }

  .nav-link.mobile:active {
    color: var(--yellow);
  }

  .nav-link.mobile.w--current {
    border-bottom-color: var(--yellow);
  }

  .main-logo {
    width: 4vw;
  }

  .main-logo.header {
    width: 95px;
  }

  .lower-footer-wrapper {
    padding-bottom: 25px;
  }

  .standard-text {
    font-size: 1.3vw;
  }

  .logo-link-header-mobile {
    z-index: 2000;
    position: relative;
  }

  .logo-link-header-mobile.footer.w--current {
    z-index: 0;
    position: static;
  }

  .footer-branding {
    font-size: 1.3vw;
  }

  .footer-branding.lower-content {
    font-size: 1vw;
  }

  .navbar-mobile {
    display: none;
  }

  .hamburger-top, .hamburger-middle {
    background-color: var(--white);
    width: 85px;
    height: 3.5px;
    margin-bottom: 10px;
    padding-bottom: 0;
    padding-right: 0;
  }

  .hamburger-bottom {
    background-color: #fff;
    width: 85px;
    height: 3.5px;
    padding-bottom: 0;
    padding-right: 0;
  }

  .mobile-menu-link {
    z-index: 2000;
    flex-direction: column;
    justify-content: center;
    margin-left: 15px;
    display: none;
    position: relative;
  }

  .mobile-overlay {
    z-index: 1000;
    background-color: var(--black);
    display: none;
    position: absolute;
    inset: 0% 0% -50%;
  }

  .nav-wrapper-mobile {
    margin-top: 90px;
    display: block;
  }

  .nav-text-mobile {
    margin-top: 5px;
    margin-bottom: 5px;
    font-weight: 700;
  }

  .nav-feature-text {
    margin-top: 15px;
  }

  .body-2 {
    background-color: var(--black);
  }

  .logo {
    font-size: 1.5vw;
  }

  .ethos-full-wrapper {
    height: 100svh;
    min-height: 600px;
  }

  .titles-wrapper {
    width: 100vw;
  }

  .main-title.shadow {
    margin-bottom: 1vw;
    font-size: 7vw;
  }

  .main-title.shadow.jp {
    font-size: 6.6vw;
  }

  .main-sub-title.shadow {
    width: 68vw;
    font-size: 2.2vw;
  }

  .paragraph-wrapper {
    width: 51vw;
  }

  .heading-6.ethos-heading {
    font-size: 3.3vw;
  }

  .heading-6.breakdown-heading {
    font-size: 3.2vw;
  }

  .ethos {
    font-size: 1.5vw;
  }

  .ethos.sticky {
    top: 8vh;
  }

  .ethos-text-holders.bottom {
    margin-bottom: 5vw;
  }

  .nav-bar-text.slash {
    font-size: 1.5vw;
  }

  .breakdown-content-wrapper {
    padding-top: 5vw;
    padding-bottom: 4vw;
  }

  .stack-split {
    width: 70vw;
    height: 35vw;
  }

  .quick-stack-breakdown {
    margin-top: 4vw;
  }

  .quick-stack-breakdown.bottom {
    padding-bottom: 5vw;
  }

  .breakdown-title-holder {
    padding-left: 2vw;
  }

  .breakdown-title {
    font-size: 2.1vw;
  }

  .breakdown-paragraph-holder {
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .paragraph {
    font-size: 1.5vw;
  }

  .breakdown-main-cell {
    align-items: center;
  }

  .breakdown-main-cell:hover {
    box-shadow: none;
    transform: none;
  }

  .bg-image-wrapper {
    height: 100svh;
    min-height: 600px;
  }

  .ethos-bg-image-01 {
    display: none;
  }

  .cta-content-wrapper {
    width: 58vw;
    padding: 4vw 5vw;
  }

  .cta-content-wrapper:hover {
    box-shadow: none;
    transform: translate(-50%, -50%);
  }

  .heading-7 {
    margin-bottom: 1.4vw;
    font-size: 3.3vw;
  }

  .pl-wrapper {
    z-index: 10000;
    display: none;
  }

  .pl-top-wrapper {
    margin-top: 40px;
  }

  .pl-texts {
    font-size: 1.3vw;
  }

  .pl-logo-mark {
    width: 6vw;
  }

  .pl-bottom-wrapper {
    margin-bottom: 40px;
  }

  .loading-percentage {
    font-size: 2.5vw;
  }

  .pl-white-logo-wrapper {
    height: 10vh;
  }

  .percentage-sign {
    font-size: 2.5vw;
  }

  .pl-color-logo-wrapper {
    height: 10vh;
  }

  .button-wrapper {
    margin-top: 2.4vw;
  }

  .button-01.hover, .button-01.shadow {
    font-size: 1.8vw;
  }

  .button-01.cta {
    font-size: 1.5vw;
  }

  .ethos-logo {
    font-size: 2vw;
  }

  .ethos-logo.ethos {
    font-size: 1.5vw;
  }

  .header-video-background-section-copy-me {
    height: 100svh;
    min-height: 600px;
  }

  .video-embed {
    z-index: 1;
  }

  .ethos-bg-image-mobile-01 {
    display: block;
  }

  .cta-video-background-section-copy-me-copy {
    height: 55svh;
    min-height: 400px;
  }

  .gradient-wrapper {
    filter: blur(180px);
  }

  .circle {
    width: 80vw;
    height: 80vw;
  }

  .pl-color-logo-wrapper---mobile, .pl-white-logo-wrapper---mobile {
    height: 10vh;
  }

  .text-field {
    font-size: 1.5vw;
  }
}

@media screen and (max-width: 767px) {
  .nav-wrapper {
    margin-bottom: 0;
  }

  .nav-link.footer {
    margin-left: 15px;
    margin-right: 15px;
    font-size: 2.6vw;
  }

  .nav-link.footer.w--current {
    color: var(--yellow);
  }

  .standard-text {
    font-size: 2vw;
  }

  .footer-branding {
    font-size: 1.5vw;
  }

  .mobile-overlay {
    display: none;
  }

  .nav-text-mobile {
    font-size: 6vw;
  }

  .main-title.shadow.jp {
    font-size: 6.2vw;
  }

  .ethos-logo {
    font-size: 2.5vw;
  }

  .circle {
    height: 80vh;
  }

  .utility-page-content {
    width: 38vw;
  }

  .text-field {
    margin-bottom: 2.5vw;
    font-size: 2vw;
  }

  .submit-button {
    padding: 1.2vw 4vw;
    font-size: 2vw;
  }

  .heading-8 {
    margin-bottom: 2vw;
    font-size: 4.05vw;
  }
}

@media screen and (max-width: 479px) {
  .container {
    padding-left: 10px;
    padding-right: 10px;
    overflow: hidden;
  }

  .navbar-section {
    z-index: 1;
  }

  .nav-wrapper {
    padding-top: 17px;
    padding-bottom: 17px;
  }

  .nav-wrapper.footer {
    padding-top: 3vw;
  }

  .nav-link:hover, .nav-link:active {
    color: var(--brand-color-01);
  }

  .nav-link.footer {
    margin-left: 0;
    margin-right: 0;
    font-size: 3.3vw;
  }

  .footer-nav {
    grid-column-gap: 19px;
    grid-row-gap: 19px;
    flex-flow: row;
    justify-content: space-between;
    align-items: center;
  }

  .main-logo {
    width: 15vw;
  }

  .main-logo.footer {
    width: 100px;
  }

  .main-logo.header {
    width: 100px;
    max-width: none;
  }

  .standard-text {
    font-size: 2.3vw;
  }

  .logo-link-header-mobile.w--current {
    width: 20%;
  }

  .footer-branding {
    font-size: 2.6vw;
  }

  .footer-branding.lower-content {
    font-size: 1.8vw;
  }

  .footer-branding.sub-text, .navbar-mobile {
    display: none;
  }

  .hamburger-top, .hamburger-middle {
    width: 40px;
    height: 1.5px;
    margin-bottom: 6px;
  }

  .hamburger-bottom {
    width: 40px;
    height: 1.5px;
  }

  .mobile-menu-link {
    display: block;
  }

  .nav-text-mobile {
    font-size: 9.5vw;
  }

  .nav-feature-text {
    margin-top: 12px;
  }

  .logo {
    width: auto;
    font-size: 4vw;
    display: none;
    position: static;
    transform: none;
  }

  .header-content-wrapper {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .ethos-section {
    z-index: 0;
  }

  .titles-wrapper {
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
    padding-left: 10px;
    padding-right: 10px;
  }

  .main-title.shadow {
    margin-bottom: 2vw;
    font-size: 11.3vw;
  }

  .main-title.shadow.jp {
    font-size: 11.3vw;
  }

  .main-sub-title.shadow {
    width: auto;
    font-size: 3vw;
  }

  .paragraph-wrapper {
    width: 72vw;
  }

  .heading-6.ethos-heading {
    font-size: 4.7vw;
    line-height: 1.5;
  }

  .heading-6.breakdown-heading {
    margin-bottom: 1.3vw;
    font-size: 4.7vw;
  }

  .ethos {
    font-size: 2.3vw;
  }

  .ethos.breakdown {
    font-size: 2.2vw;
  }

  .ethos.header-paragraph.shadow {
    padding-right: 8px;
  }

  .ethos.sticky {
    position: sticky;
    top: 10vh;
  }

  .ethos-content-wrapper {
    margin-left: 10px;
    margin-right: 10px;
  }

  .nav-bar-text {
    text-transform: uppercase;
    font-size: 2.6vw;
  }

  .nav-bar-text.slash {
    font-size: 2.6vw;
  }

  .breakdown-section {
    z-index: 0;
  }

  .breakdown-content-wrapper {
    padding-top: 7vw;
    padding-bottom: 5vw;
  }

  .stack-split {
    width: 94vw;
    height: 47vw;
  }

  .quick-stack-breakdown {
    grid-column-gap: 6vw;
    grid-row-gap: 6vw;
    margin-top: 6vw;
  }

  .breakdown-title {
    font-size: 2.8vw;
  }

  .paragraph {
    font-size: 2.1vw;
  }

  .slogan {
    margin-bottom: 4vw;
    padding-right: 9px;
  }

  .text-block-4 {
    font-size: 2.6vw;
  }

  .cta-section {
    z-index: 0;
  }

  .cta-content-wrapper {
    width: 79vw;
  }

  .heading-7 {
    font-size: 4.5vw;
  }

  .pl-top-wrapper {
    justify-content: center;
    margin-top: 6vw;
    margin-left: 4vw;
    display: flex;
    position: absolute;
    inset: 0% 0% auto;
  }

  .pl-texts {
    font-size: 3vw;
    display: block;
  }

  .pl-logo-mark, .pl-mid-wrapper {
    display: none;
  }

  .pl-bottom-wrapper {
    margin-bottom: 0;
  }

  .pl-content-wrapper {
    justify-content: center;
    align-items: center;
  }

  .loading-percentage {
    font-size: 6vw;
  }

  .pl-number-wrapper {
    margin-top: 20vw;
  }

  .percentage-sign {
    font-size: 6vw;
  }

  .button-wrapper {
    margin-top: 3.5vw;
  }

  .slogan-arrow {
    width: 1.5vw;
  }

  .button-01.hover, .button-01.shadow {
    font-size: 2.6vw;
  }

  .button-01.cta {
    font-size: 2.3vw;
  }

  .button-01-interaction {
    border-width: 1px;
  }

  .nav-link-wrapper {
    display: none;
  }

  .ethos-logo {
    font-size: 4vw;
  }

  .ethos-logo.ethos {
    font-size: 2.3vw;
  }

  .div-block-37 {
    padding-bottom: 7vw;
  }

  .div-block-38 {
    margin-top: 2.5vw;
    margin-bottom: 2.5vw;
  }

  .ethos-sticky-holder {
    top: 3vh;
  }

  .cta-video-background-section-copy-me-copy {
    height: 70svh;
  }

  .home-top-link {
    display: block;
  }

  .drop-down-nav---mobile {
    z-index: auto;
    width: 100%;
    display: block;
  }

  .drop-down-content-wrapper {
    justify-content: space-between;
    align-items: center;
    height: 40px;
    display: flex;
  }

  .nav-bar-drop-down-ruler {
    background-color: #fff;
    height: 1.5px;
    padding-bottom: 0;
    padding-right: 0;
  }

  .nav-link-wrapper---mobile {
    display: flex;
  }

  .gradient-wrapper {
    opacity: .8;
    inset: 0% auto auto 0%;
  }

  .pl-mid-wrapper---mobile {
    align-items: flex-start;
    width: 50vw;
    height: 28vw;
    margin-bottom: 15vw;
    display: block;
    position: absolute;
    overflow: hidden;
  }

  .pl-color-logo-wrapper---mobile {
    z-index: 2;
    width: 50vw;
    height: 28vw;
  }

  .pl-color-logo--mobile {
    min-width: 50vw;
  }

  .pl-white-logo-wrapper---mobile {
    width: 50vw;
    height: 28vw;
  }

  .pl-white-logo--mobile {
    min-width: 50vw;
  }

  .pl-bottom-text-holder {
    justify-content: center;
    margin-bottom: 6vw;
    margin-left: 4vw;
    display: flex;
    position: absolute;
    inset: auto 0% 0%;
  }

  .utility-page-content {
    width: 55vw;
  }

  .text-field {
    margin-bottom: 3.5vw;
    font-size: 3vw;
  }

  .submit-button {
    font-size: 3vw;
  }

  .heading-8 {
    margin-bottom: 3vw;
    font-size: 5.9vw;
  }
}

#w-node-_412c1867-44fa-d226-7b04-8f79c79e8673-c9cb02b2, #w-node-bafb0070-bc30-c349-06e9-e1f53f2ab2c0-c9cb02b2, #w-node-dc56b50c-a747-de4b-e47a-274b07e51739-c9cb02b2, #w-node-_84133400-b817-c241-6282-7a4d3c368de1-c9cb02b2, #w-node-b66e3e39-42a1-5184-031b-f48827d8a848-c9cb02b2, #w-node-_0a5b1e16-dfb8-4705-7239-ae926a08841c-c9cb02b2, #w-node-_412c1867-44fa-d226-7b04-8f79c79e8673-19c7c6fb, #w-node-bafb0070-bc30-c349-06e9-e1f53f2ab2c0-19c7c6fb, #w-node-dc56b50c-a747-de4b-e47a-274b07e51739-19c7c6fb, #w-node-_84133400-b817-c241-6282-7a4d3c368de1-19c7c6fb, #w-node-b66e3e39-42a1-5184-031b-f48827d8a848-19c7c6fb, #w-node-_0a5b1e16-dfb8-4705-7239-ae926a08841c-19c7c6fb {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
}

@media screen and (max-width: 991px) {
  #w-node-_412c1867-44fa-d226-7b04-8f79c79e8673-c9cb02b2, #w-node-_84133400-b817-c241-6282-7a4d3c368de1-c9cb02b2, #w-node-_412c1867-44fa-d226-7b04-8f79c79e8673-19c7c6fb, #w-node-_84133400-b817-c241-6282-7a4d3c368de1-19c7c6fb {
    grid-template-rows: auto;
    grid-template-columns: 1fr;
  }
}


@font-face {
  font-family: 'Neue Haas Display';
  src: url('../fonts/NeueHaasDisplayBlack.ttf') format('truetype');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Neue Haas Display';
  src: url('../fonts/NeueHaasDisplayMediu.ttf') format('truetype'), url('../fonts/NeueHaasDisplayRoman.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Neue Haas Display';
  src: url('../fonts/NeueHaasDisplayBold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Neue Haas Display';
  src: url('../fonts/NeueHaasDisplayThin.ttf') format('truetype');
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Neue Haas Display';
  src: url('../fonts/NeueHaasDisplayLight.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}