@font-face {
  font-family: Matter VF;
  src: url('../fonts/Matter-TRIAL-VF.woff2') format("woff2");
  font-weight: 100 1000;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Matter GX;
  src: url('../fonts/MatterGX.woff2') format("woff2");
  font-weight: 300 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Roobert;
  src: url('../fonts/Roobert-Medium.otf') format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

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

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

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

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

@font-face {
  font-family: Slussen Mono VF;
  src: url('../fonts/Slussen-Mono-Variable.ttf') format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Slussen VF;
  src: url('../fonts/Slussen-Variable.ttf') format("truetype");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --site-padding: 20px;
  --white: white;
  --black: black;
}

body {
  color: #333;
  --site-padding: 20px;
  --white: white;
  --black: black;
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 14px;
  line-height: 20px;
}

.body {
  background-color: #151515;
  line-height: 1em;
}

.list-left {
  flex: 0 auto;
  justify-content: flex-start;
  align-items: stretch;
  margin-bottom: 0;
  padding-left: 0;
  display: block;
}

.utility-page-wrap {
  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: 260px;
  display: flex;
}

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

.header-text {
  color: #fff;
  letter-spacing: .02em;
  font-family: Roobert, sans-serif;
  font-size: 22px;
  font-weight: 400;
  line-height: 1em;
}

.container {
  justify-content: space-between;
  max-width: 100vw;
  display: flex;
}

.list-right {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  justify-content: flex-start;
  margin-bottom: 0;
  padding-left: 0;
  display: flex;
}

.navbar {
  z-index: 4;
  padding-top: var(--site-padding);
  padding-right: var(--site-padding);
  padding-left: var(--site-padding);
  mix-blend-mode: exclusion;
  flex-direction: row;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-content: start;
  width: 100%;
  display: flex;
  position: fixed;
  inset: 0% 0% auto;
}

.link-nav {
  color: #fff;
  font-family: Roobert, sans-serif;
  font-size: 1.2em;
  font-weight: 400;
  line-height: 1em;
  text-decoration: none;
}

.superscript-2 {
  font-size: 10px;
  font-weight: 500;
}

.list-item-2 {
  display: block;
}

.list-item-3 {
  display: none;
}

.list-center {
  flex: 0 auto;
  justify-content: flex-start;
  align-items: stretch;
  margin-bottom: 0;
  padding-left: 0;
  display: block;
}

.preloader {
  z-index: 10;
  background-color: #000;
  justify-content: center;
  align-items: center;
  display: none;
  position: fixed;
  inset: 0%;
}

.icon-preloader {
  grid-column-gap: 3px;
  grid-row-gap: 3px;
  justify-content: flex-start;
  align-items: flex-start;
  padding-left: 5px;
  display: flex;
}

.gradient-mask {
  z-index: 2;
  pointer-events: none;
  background-image: linear-gradient(90deg, #000, #21212100 8% 92%, #000);
  position: absolute;
  inset: 0;
}

.div-block-5 {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: flex-end;
  align-items: flex-start;
  display: flex;
}

.icon-hot {
  color: #fff;
  padding-bottom: 2px;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-size: 1em;
  font-weight: 600;
  line-height: 1em;
  position: relative;
}

.text-banner-all {
  justify-content: space-around;
  align-items: center;
  min-width: 28em;
  max-width: 28em;
  display: flex;
}

.text-sub-logo-bold {
  color: #fff;
  font-variation-settings: "wght" 480;
  text-transform: uppercase;
  word-spacing: -2.5px;
  font-family: Slussen Mono VF, Arial, sans-serif;
  font-size: 1.1em;
  line-height: 1em;
}

.info-slide {
  z-index: 2;
  color: #fff;
  mix-blend-mode: exclusion;
  grid-template-rows: auto;
  grid-template-columns: 30% 65% 5%;
  justify-items: stretch;
  padding-left: 35px;
  padding-right: 35px;
  font-size: 18px;
  text-decoration: underline;
  position: absolute;
  inset: 0%;
}

.text-banner-scroll {
  justify-content: space-around;
  align-items: center;
  width: 56em;
  display: flex;
}

.front-logos {
  padding-right: var(--site-padding);
  padding-bottom: var(--site-padding);
  padding-left: var(--site-padding);
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  mix-blend-mode: exclusion;
  flex-flow: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-content: space-between flex-end;
  place-items: stretch end;
  width: 100%;
  display: flex;
  position: absolute;
  inset: auto 0% 0%;
}

.banner {
  justify-content: center;
  align-items: flex-start;
  width: 25%;
  padding-left: 5px;
  padding-right: 5px;
  display: none;
  position: relative;
}

.text-banner {
  color: #fff;
  white-space: nowrap;
  padding-bottom: 2px;
  font-family: Slussen VF, Arial, sans-serif;
  font-size: .9em;
  font-style: italic;
  font-weight: 400;
  line-height: 1em;
}

.background {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
}

.svg-22 {
  padding: 1px;
  display: flex;
}

.inici {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100vh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.vimeo-thumb-16-9 {
  aspect-ratio: 16 / 9;
  object-fit: cover;
  min-height: 101%;
  padding-bottom: 0;
  padding-right: 0;
  display: block;
}

.banner-container {
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  margin-left: -8px;
  margin-right: -8px;
  display: flex;
  position: relative;
  overflow: clip;
}

.text-icon-bcn {
  color: #fff;
  font-variation-settings: "wght" 550;
  text-align: right;
  border: .15em solid #fff;
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  padding-left: 4px;
  padding-right: 4px;
  font-family: Matter GX, Arial, sans-serif;
  font-size: .7em;
  line-height: 1.2em;
  display: flex;
}

.front-title-right {
  grid-column-gap: 6px;
  grid-row-gap: 6px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.image-slide {
  pointer-events: none;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.vimeo-thumb-9-16 {
  aspect-ratio: 9 / 16;
  object-fit: cover;
  flex-flow: column;
  justify-content: space-between;
  min-width: 101%;
  min-height: 101%;
  padding-bottom: 0;
  padding-right: 0;
  display: none;
  position: absolute;
}

.vimeo-thumb-9-16.mobile {
  display: block;
}

.subtitle-logo {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding-left: 4px;
  padding-right: 4px;
  display: flex;
}

.ramen-japanese {
  color: #fff;
  letter-spacing: -.02em;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif;
  font-size: 1em;
  font-weight: 900;
  line-height: 1em;
}

.contact-links {
  grid-column-gap: 24px;
  grid-row-gap: 24px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.link {
  color: #fff;
  font-variation-settings: "wght" 480;
  text-transform: uppercase;
  text-underline-offset: 1.5px;
  word-spacing: -2.5px;
  font-family: Slussen Mono VF, Arial, sans-serif;
  font-size: 1.2em;
  line-height: 1em;
  text-decoration: none;
}

.link:hover {
  text-decoration: underline;
}

.navbar-cont {
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.text-block {
  color: #fff;
  font-variation-settings: "wght" 480;
  text-transform: uppercase;
  word-spacing: -2.5px;
  font-family: Slussen Mono VF, Arial, sans-serif;
  font-size: 1.2em;
  line-height: 1em;
}

.svg-23 {
  display: block;
}

.text-sub-logo {
  color: #fff;
  font-variation-settings: "wght" 480;
  text-transform: uppercase;
  word-spacing: -2.5px;
  font-family: Slussen Mono VF, Arial, sans-serif;
  font-size: 1.1em;
  line-height: 1em;
}

.demo-section__title {
  padding-right: var(--site-padding);
  padding-bottom: var(--site-padding);
  padding-left: var(--site-padding);
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  mix-blend-mode: exclusion;
  flex-flow: column;
  display: flex;
  position: fixed;
  inset: auto 0% 0%;
}

.bunny-bg__btn {
  -webkit-backdrop-filter: blur(1em);
  backdrop-filter: blur(1em);
  cursor: pointer;
  background-color: #6464644d;
  border: 1px solid #ffffff1a;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 3em;
  height: 3em;
  padding: .8125em;
  display: flex;
  position: relative;
}

.bunny-bg__pause-svg {
  display: none;
}

.bunny-bg__playpause {
  pointer-events: auto;
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
  bottom: 4vw;
  right: 4vw;
}

.bunny-bg__video {
  object-fit: cover;
  width: 100%;
  height: 100%;
  padding-bottom: 0;
  padding-right: 0;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}

.demo-section__title-h1 {
  max-width: 9em;
  font-size: 8vw;
  font-weight: 500;
  line-height: 1;
}

.bunny-bg {
  pointer-events: none;
  color: #fff;
  isolation: isolate;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  transform: translateX(0);
}

.bunny-bg__loading {
  opacity: 0;
  visibility: hidden;
  background-color: #00000054;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
}

.bunny-bg__placeholder {
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
}

.demo-section {
  color: #efeeec;
  background-color: #000;
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
  min-height: 100svh;
  padding: 4vw;
  display: flex;
  position: relative;
  overflow: hidden;
}

.bunny-bg__loading-svg {
  width: 6em;
}

.demo-section__fade-left {
  pointer-events: none;
  background-image: linear-gradient(45deg, #000, #0000 50%);
  width: 90vw;
  height: 90vw;
  position: absolute;
  bottom: 0;
  left: 0;
}

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

  .navbar {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    flex-flow: column;
    align-items: center;
  }

  .icon-hot {
    width: auto;
    font-size: 16px;
  }

  .text-sub-logo-bold {
    font-size: 1em;
  }

  .front-logos {
    grid-column-gap: 12px;
    grid-row-gap: 12px;
  }

  .text-banner {
    font-size: 14px;
  }

  .vimeo-thumb-16-9 {
    min-height: 108%;
  }

  .vimeo-thumb-9-16 {
    display: none;
  }

  .subtitle-logo {
    padding-left: 0;
    padding-right: 0;
  }

  .text-sub-logo {
    font-size: 1em;
  }

  .bunny-bg__playpause {
    bottom: 1em;
    right: 1em;
  }

  .demo-section__title-h1 {
    font-size: 15vw;
  }

  .demo-section {
    padding-bottom: 25vw;
  }
}

@media screen and (max-width: 767px) {
  body {
    --site-padding: 12px;
  }

  .list-left {
    display: block;
  }

  .list-center {
    display: none;
  }

  .icon-hot {
    letter-spacing: -.01em;
  }

  .text-sub-logo-bold {
    font-size: .9em;
  }

  .front-logos {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .text-banner {
    letter-spacing: -.01em;
  }

  .svg-22 {
    display: block;
  }

  .vimeo-thumb-16-9 {
    min-height: 110%;
  }

  .vimeo-thumb-9-16 {
    min-width: 101%;
    min-height: 101%;
    display: none;
  }

  .subtitle-logo {
    padding-left: 0;
    padding-right: 0;
  }

  .ramen-japanese {
    font-size: .9em;
  }

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

  .contact-links {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-end;
  }

  .svg-23 {
    display: none;
  }

  .text-sub-logo {
    font-size: .9em;
  }
}

@media screen and (max-width: 479px) {
  body {
    --site-padding: 8px;
  }

  .list-left {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
    flex-wrap: wrap;
  }

  .header-text {
    text-align: right;
    font-size: 22px;
    line-height: 1.1em;
  }

  .list-right {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
    flex-wrap: wrap;
  }

  .navbar {
    padding-top: 14px;
    padding-left: 14px;
    padding-right: 14px;
  }

  .list-item-2 {
    display: flex;
  }

  .list-item-3 {
    display: block;
  }

  .list-center {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
    flex-wrap: wrap;
    display: flex;
  }

  .text-sub-logo-bold {
    font-size: .8em;
    display: none;
  }

  .front-logos {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
    position: fixed;
  }

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

  .text-icon-bcn {
    font-size: .65em;
    top: 3px;
  }

  .front-title-right {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .vimeo-thumb-9-16, .vimeo-thumb-9-16.mobile {
    display: none;
  }

  .subtitle-logo {
    justify-content: space-between;
    align-items: center;
    padding-left: 0;
    padding-right: 0;
  }

  .ramen-japanese {
    color: #fff;
    font-size: 1em;
  }

  .logo {
    flex-flow: column;
    justify-content: flex-end;
    align-items: stretch;
    padding-left: 0;
    padding-right: 0;
    display: flex;
  }

  .contact-links {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-end;
  }

  .link {
    font-size: 1.1em;
  }

  .navbar-cont {
    justify-content: space-between;
    align-items: flex-start;
  }

  .text-block {
    font-size: 1.1em;
  }

  .text-sub-logo {
    font-size: .9em;
  }

  .demo-section__title {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
  }
}


@font-face {
  font-family: 'Matter VF';
  src: url('../fonts/Matter-TRIAL-VF.woff2') format('woff2');
  font-weight: 100 1000;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Matter GX';
  src: url('../fonts/MatterGX.woff2') format('woff2');
  font-weight: 300 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Roobert';
  src: url('../fonts/Roobert-Medium.otf') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Helveticanowdisplay';
  src: url('../fonts/HelveticaNowDisplay-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Helveticanowdisplay';
  src: url('../fonts/HelveticaNowDisplay-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Helveticanowdisplay';
  src: url('../fonts/HelveticaNowDisplay-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Helveticanowdisplay';
  src: url('../fonts/HelveticaNowDisplay-Light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Slussen Mono VF';
  src: url('../fonts/Slussen-Mono-Variable.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Slussen VF';
  src: url('../fonts/Slussen-Variable.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}