@font-face {
  font-family: "FTSterling-Book";
  src: url(../fonts/ft-sterling-book.eot?bbc9d9c3e455251353805618efa133ee);
  src: url(../fonts/ft-sterling-book.eot?bbc9d9c3e455251353805618efa133ee?#iefix) format("embedded-opentype"), url(../fonts/ft-sterling-book.woff2?f3da660dec51eba006335541e171593d) format("woff2"), url(../fonts/ft-sterling-book.woff?6101826e30495fc2903b7c8fed1fcdcc) format("woff"), url(../fonts/ft-sterling-book.ttf?46d94bbb838bc07e5263c7104ba42efa) format("truetype"), url(../fonts/ft-sterling-book.svg?0ef719b9203232c59ec3b8b2e82b1e1c#youworkforthem) format("svg");
  font-weight: normal;
  font-style: normal;
}
:root {
  --flux-white: #f4f4ef;
  --flux-black: #0e0e0e;
  --flux-green: #525b43;
  --flux-spacer: clamp(16px, 2.4vw + 6.4px, 64px);
  --font-size-base: clamp(16px, 0.2vw + 15.2px, 20px);
}

html, body {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  font-size: var(--font-size-base);
  border: none;
  cursor: none !important;
}

body {
  font-family: "FTSterling-Book", sans-serif;
  line-height: 1.25;
  color: var(--flux-white);
  background: var(--flux-black);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

* {
  box-sizing: border-box;
  cursor: none !important;
}

::-moz-selection {
  color: var(--flux-white);
  background: rgba(14, 14, 14, 0.99);
}

::selection {
  color: var(--flux-white);
  background: rgba(14, 14, 14, 0.99);
}

a, button {
  cursor: pointer;
  text-decoration: none;
}

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

.main {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: calc(var(--flux-spacer) * 2);
  min-height: 100%;
  overflow: hidden;
  padding: calc(var(--flux-spacer) * 0.75) var(--flux-spacer);
  opacity: 0;
  visibility: hidden;
}
.main > * {
  position: relative;
  z-index: 3;
}

.bg {
  position: absolute;
  z-index: 1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  opacity: 0.5;
}
.bg img,
.bg video {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.showreel {
  position: fixed;
  z-index: 10;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: var(--flux-black);
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  pointer-events: none;
}
.showreel video {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}
.showreel iframe {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.showreel__close {
  position: fixed;
  z-index: 10;
  right: var(--flux-spacer);
  top: calc(var(--flux-spacer) * 0.75);
  display: flex;
  justify-content: center;
  align-items: center;
  width: clamp(32px, 1.2vw + 27.2px, 56px);
  height: clamp(32px, 1.2vw + 27.2px, 56px);
  cursor: pointer;
  padding: 0;
  color: var(--flux-black);
  border: none;
  border-radius: 50%;
  background: var(--flux-white);
  box-shadow: none;
  outline: none;
}
.showreel__trigger-touch {
  display: none;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 3rem;
  margin-top: calc(var(--flux-spacer) * 0.75);
  padding: 0 1.5rem;
  font-size: 1rem;
  text-align: center;
  color: var(--flux-black);
  border: none;
  border-radius: 0.25rem;
  background: var(--flux-white);
  box-shadow: none;
  outline: none;
  pointer-events: auto;
}
@media (hover: none) and (pointer: coarse) {
  .showreel__trigger-touch {
    display: flex !important;
  }
}
.showreel__trigger-click {
  position: absolute;
  z-index: 2;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
}
@media (hover: none) and (pointer: coarse) {
  .showreel__trigger-click {
    display: none !important;
    pointer-events: none !important;
  }
}
.showreel__cursor {
  position: absolute;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 7.5rem;
  height: 7.5rem;
  font-size: 0.875rem;
  text-align: center;
  color: var(--flux-black);
  border-radius: 50%;
  background: var(--flux-green);
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
  pointer-events: none;
  transition: transform 0.3s ease;
}
@media (hover: none) and (pointer: coarse) {
  .showreel__cursor {
    display: none !important;
  }
}
.showreel__cursor > span {
  transition: opacity 0.3s ease;
}
.showreel__cursor-link {
  transform: translate(-50%, -50%) scale(0.25);
}
.showreel__cursor-link > span {
  opacity: 0;
}
.showreel__active {
  -webkit-clip-path: inset(0 0 0 0);
          clip-path: inset(0 0 0 0);
  pointer-events: auto;
  transition: -webkit-clip-path 1s cubic-bezier(0.76, 0, 0.24, 1);
  transition: clip-path 1s cubic-bezier(0.76, 0, 0.24, 1);
  transition: clip-path 1s cubic-bezier(0.76, 0, 0.24, 1), -webkit-clip-path 1s cubic-bezier(0.76, 0, 0.24, 1);
}
.showreel__closing {
  -webkit-clip-path: inset(0 0 0 100%);
          clip-path: inset(0 0 0 100%);
  transition: -webkit-clip-path 1s cubic-bezier(0.76, 0, 0.24, 1);
  transition: clip-path 1s cubic-bezier(0.76, 0, 0.24, 1);
  transition: clip-path 1s cubic-bezier(0.76, 0, 0.24, 1), -webkit-clip-path 1s cubic-bezier(0.76, 0, 0.24, 1);
}

.header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 3rem calc(var(--flux-spacer) * 2);
  pointer-events: none;
}
.header a, .header button {
  pointer-events: auto;
}
.header__title {
  align-self: center;
  margin: 0;
  font-size: 1rem;
  font-weight: normal;
  pointer-events: auto;
}
.header__intro {
  width: 100%;
}
.header__body {
  max-width: 30em;
  pointer-events: auto;
}
.header__socials {
  align-self: center;
  display: flex;
  gap: 1rem;
}
.header__socials a {
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  color: var(--flux-white);
}
@media only screen and (min-width: 768px) {
  .header__socials a {
    width: auto;
    height: auto;
  }
}
.header__socials-label {
  display: none;
}
@media only screen and (min-width: 768px) {
  .header__socials-label {
    display: inline-block;
  }
}
.header__socials-icon {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 1.25rem;
  height: 1.25rem;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .header__socials-icon {
    display: none;
  }
}
.header__socials-icon svg {
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
}
.header__btn {
  display: inline-flex;
  align-items: center;
  color: var(--flux-white);
}
.header__btn-label {
  position: relative;
  padding: 0.125em 0;
}
.header__btn-label::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 0.05em;
  background: currentColor;
}
@keyframes arrowMove {
  0% {
    opacity: 1;
    transform: translate(0, 0);
  }
  49% {
    opacity: 0;
    transform: translate(35%, -35%);
  }
  50% {
    opacity: 0;
    transform: translate(-35%, 35%);
  }
  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}
.header__btn-arrow {
  margin-left: 0.25em;
}
.header__btn-arrow svg {
  width: 0.75rem;
  height: 0.75rem;
}
.header__btn:hover .header__btn-arrow {
  animation: arrowMove 0.4s cubic-bezier(0.76, 0, 0.24, 1) forwards;
}
.header__btn-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
  margin-top: 1rem;
}

.footer {
  pointer-events: none;
}

.logo {
  position: relative;
  overflow: hidden;
}
.logo-letter:not(:first-child) {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.logo svg {
  width: 100%;
  height: auto;
}
