.site-footer{
  position: relative;
  overflow: clip;
  min-height: 100svh;
  color: #fff;
  background:
    radial-gradient(900px 520px at 54% 44%, rgba(0,191,255,.075), transparent 70%),
    radial-gradient(620px 360px at 20% 72%, rgba(80,220,255,.045), transparent 74%),
    linear-gradient(180deg, #000 0%, #020814 46%, #000 100%);
  padding: 72px 48px 42px;
}

.site-footer::before{
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(circle at 52% 48%, rgba(0,191,255,.045), transparent 34%),
    linear-gradient(180deg, rgba(0,0,0,.18), transparent 30%, rgba(0,0,0,.60));
  mix-blend-mode: screen;
}

.site-footer::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 220px;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      #000 0%,
      rgba(0,0,0,.86) 24%,
      rgba(0,0,0,.42) 62%,
      transparent 100%
    );
}

.site-footer__video{
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .24;
  filter: grayscale(.18) contrast(1.12) brightness(.58) saturate(.75);
  transform: scale(1.04);
  pointer-events: none;

  -webkit-mask-image:
    linear-gradient(
      180deg,
      transparent 0%,
      rgba(0,0,0,.08) 10%,
      rgba(0,0,0,.42) 22%,
      rgba(0,0,0,.82) 36%,
      #000 48%,
      #000 100%
    );
  mask-image:
    linear-gradient(
      180deg,
      transparent 0%,
      rgba(0,0,0,.08) 10%,
      rgba(0,0,0,.42) 22%,
      rgba(0,0,0,.82) 36%,
      #000 48%,
      #000 100%
    );
}

.site-footer__video-filter{
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(900px 520px at 56% 42%, rgba(0,191,255,.08), transparent 70%),
    linear-gradient(
      180deg,
      rgba(0,0,0,.82) 0%,
      rgba(0,0,0,.62) 18%,
      rgba(0,0,0,.38) 44%,
      rgba(0,0,0,.86) 100%
    );
}

.site-footer__inner{
  position: relative;
  z-index: 3;
  max-width: 1760px;
  min-height: calc(100svh - 114px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.02fr 1.18fr;
  grid-template-rows: 1fr auto;
  column-gap: clamp(70px, 8vw, 160px);
}

.site-footer__hero{
  align-self: start;
  padding-top: clamp(150px, 24vh, 285px);
}

.site-footer__eyebrow{
  margin: 0 0 42px;
  font-size: 12px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255,255,255,.42);
}

.site-footer__title{
  margin: 0;
  font-size: clamp(92px, 8.8vw, 174px);
  line-height: .84;
  letter-spacing: -.078em;
}

.site-footer__title span{
  display: block;
  white-space: nowrap;
}

.site-footer__social-area{
  align-self: start;
  justify-self: stretch;
  padding-top: clamp(150px, 24vh, 285px);
  display: grid;
  grid-template-columns: repeat(2, minmax(300px, 1fr));
  gap: clamp(76px, 7vw, 140px);
}

.site-footer__group{
  min-width: 0;
}

.site-footer__group h3{
  margin: 0 0 34px;
  max-width: none;
  font-size: clamp(34px, 2.35vw, 48px);
  line-height: .92;
  letter-spacing: -.055em;
  white-space: nowrap;
}

.site-footer__socials{
  display: grid;
  gap: 18px;
}

.site-footer__socials a{
  display: grid;
  grid-template-columns: 38px minmax(0, auto);
  align-items: center;
  column-gap: 18px;
  width: fit-content;
  min-height: 38px;
  color: rgba(255,255,255,.70);
  text-decoration: none;
  font-size: 20px;
  line-height: 1.15;
  transition:
    color .25s ease,
    transform .25s ease,
    opacity .25s ease;
}

.site-footer__socials a:hover{
  color: rgb(180,245,255);
  transform: translateX(6px);
}

.site-footer__socials img{
  width: 38px;
  height: 38px;
  display: block;
  object-fit: contain;
  opacity: .72;
  filter: invert(1) grayscale(1) brightness(.82);
  transition: opacity .25s ease, filter .25s ease;
}

.site-footer__socials a:hover img{
  opacity: 1;
  filter: invert(1) grayscale(1) brightness(1.18);
}

.site-footer__socials span{
  display: block;
  white-space: nowrap;
}

.site-footer__divider{
  display: block;
  width: 100%;
  height: 1px;
  margin: 10px 0 6px;
  background: linear-gradient(
    90deg,
    rgba(180,245,255,.24),
    rgba(180,245,255,.055),
    transparent
  );
}

.site-footer__subgroup{
  display: block;
  margin: 0 0 4px;
  font-size: 10px;
  line-height: 1;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(180,245,255,.46);
}

.site-footer__notice{
  grid-column: 2 / 4;
  max-width: 720px;
  margin: 22px 0 0;
  color: rgba(255,255,255,.34);
  font-size: 11px;
  line-height: 1.45;
}

.site-footer__bottom{
  grid-column: 1 / -1;
  align-self: end;
  display: grid;
  grid-template-columns: minmax(360px, 1fr) minmax(420px, auto) minmax(360px, 1fr);
  align-items: end;
  gap: 32px;
  padding-top: 72px;
}

.site-footer__contact{
  justify-self: start;
  display: grid;
  gap: 8px;
}

.site-footer__contact span{
  font-size: 14px;
  font-style: italic;
  color: rgba(255,255,255,.62);
}

.site-footer__contact a{
  width: fit-content;
  color: rgba(255,255,255,.92);
  font-size: clamp(24px, 2vw, 36px);
  line-height: 1.08;
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,.42);
  transition: color .25s ease, border-color .25s ease;
}

.site-footer__contact a:hover{
  color: rgb(180,245,255);
  border-color: rgba(0,191,255,.65);
}

.site-footer__legal{
  justify-self: center;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 24px;
  white-space: nowrap;
}

.site-footer__legal a{
  color: rgba(255,255,255,.50);
  text-decoration: none;
  font-size: 14px;
  line-height: 1.25;
  transition: color .25s ease;
}

.site-footer__legal a:hover{
  color: rgba(180,245,255,.92);
}

.site-footer__copy{
  justify-self: end;
  margin: 0;
  color: rgba(255,255,255,.46);
  font-size: 14px;
  line-height: 1.25;
  text-align: right;
  white-space: nowrap;
}

@media (max-width: 1180px){
  .site-footer{
    padding: 76px 24px 36px;
  }

  .site-footer__inner{
    min-height: auto;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    row-gap: 64px;
  }

  .site-footer__hero{
    padding-top: 0;
  }

  .site-footer__social-area{
    padding-top: 0;
    grid-template-columns: repeat(2, minmax(250px, 1fr));
    gap: 56px;
  }

  .site-footer__notice{
    grid-column: 1;
    max-width: 100%;
    margin-top: -24px;
  }

  .site-footer__bottom{
    grid-template-columns: 1fr;
    gap: 30px;
    padding-top: 24px;
  }

  .site-footer__contact,
  .site-footer__legal,
  .site-footer__copy{
    justify-self: start;
    text-align: left;
  }

  .site-footer__legal{
    justify-content: flex-start;
    flex-wrap: wrap;
    white-space: normal;
  }

  .site-footer__copy{
    white-space: normal;
  }
}

@media (max-width: 760px){
  .site-footer__video{
    display: block;
    opacity: .14;
    filter: grayscale(.22) contrast(1.05) brightness(.46) saturate(.68);
    transform: scale(1.08);
  }

  .site-footer__video-filter{
    display: block;
    background:
      linear-gradient(
        180deg,
        rgba(0,0,0,.90) 0%,
        rgba(0,0,0,.64) 42%,
        rgba(0,0,0,.94) 100%
      );
  }
}

@media (max-width: 680px){
  .site-footer{
    min-height: auto;
    padding: 72px 18px 34px;
  }

  .site-footer::after{
    display: none;
  }

  .site-footer__inner{
    row-gap: 52px;
  }

  .site-footer__title{
    font-size: clamp(58px, 17vw, 94px);
  }

  .site-footer__social-area{
    grid-template-columns: 1fr;
    gap: 46px;
  }

  .site-footer__group h3{
    font-size: 34px;
    margin-bottom: 24px;
    white-space: normal;
  }

  .site-footer__socials{
    gap: 16px;
  }

  .site-footer__socials a{
    grid-template-columns: 34px minmax(0, auto);
    min-height: 34px;
    column-gap: 15px;
    font-size: 18px;
  }

  .site-footer__socials img{
    width: 34px;
    height: 34px;
  }

  .site-footer__contact a{
    font-size: 22px;
    word-break: break-word;
  }

  .site-footer__legal{
    gap: 12px 18px;
  }
}