.footer {
  overflow: hidden;
  position: relative;

  &::after {
    content: "";
    position: absolute;
    top: 0;

    max-width: 1440px;
    max-height: 1440px;
    width: 100vw;
    height: 100vw;
    left: 50%;
    transform: translateX(-50%);

    z-index: 1;
    background-color: var(--textLight);

    border-radius: 50%;
  }
}

.footer__box {
}

.footer__info {
}

.footer__content {
  position: relative;
  z-index: 10;
  padding: 170px 0 70px;
  grid-template-columns: 280px 1fr;
  align-items: end;
  gap: 0;
}

.footer__banner {
  width: 100%;

  img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
}

.footer__text {
}

.footer__title {
  color: var(--textDark);
}

.footer__desc {
  color: var(--textDark);
  margin: 30px 0 16px;
}

.footer__btn {
  background: var(--btn);
  color: var(--textLight);
}

.footer__copyright {
  color: var(--bg);
  font-size: 12px;
  margin-top: 30px;
}

.footer__copyright.hidden {
  opacity: 1;
}

.footer.bottom {
  transform: translateY(-60px);
}

.footer.place {
  transform: translateY(0);
}

@media screen and (max-width: 1000px) {
  .footer {
    &::after {
      border-radius: 50% 50% 0 0;
      width: 200vw;
      height: 200vw;
      left: 50%;
      transform: translateX(-50%);
      top: 0;
    }
  }

  .footer__content {
    padding: 60px 0;
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 20px;
  }

  .footer__banner {
    width: 50%;
  }

  .footer__text {
    text-align: center;
  }

  .footer__btn {
    margin: 0 auto;
  }
}

@media screen and (max-width: 800px) {
  .footer {
    &::after {
      width: 100%;
      border-top-left-radius: 50% 24%;
      border-top-right-radius: 50% 24%;
    }
  }
}

@media screen and (max-width: 520px) {
  .footer__content {
    padding: 70px 0 45px;
  }

  .footer__banner {
    width: 160px;
  }
}
