#bodymovin {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: -1;
  width: 100%;
  transform: translateX(-50%);
}

.mainvisual_copy {
  height: 50vw;
  position: relative;
  display: flex;
  align-items: flex-end;
  width: 100%;
  margin-bottom: 7vw;
}

.homettl01 {
  position: sticky;
  bottom: 50px;
  left: 0;
  max-width: 1568px;
  width: 100%;
  margin: 0 auto;
  padding: 0 40px;
  color: #1D2157;
  font-weight: 900;
  font-size: 2.875rem;
  line-height: 1.28;
  font-feature-settings: "palt";
}

.homettl01 .sub {
  font-size: 1.313rem;
  display: block;
  margin-bottom: 5px;
}

@media (max-width: 1099px) {

  #bodymovin {
    width: 127.8%;
  }

  .mainvisual_copy {
    height: auto;
    display: block;
    margin-bottom: 0;
  }

  .homettl01 {
    position: static;
    max-width: 100%;
    padding: 46.8% 40px 33.8%;
    font-size: 2rem;
    transform: translateX(0);
  }

  .homettl01 .sub {
    font-size: .938rem;
  }

}

@media (max-width: 767px) {

  #bodymovin {
    width: 149%;
  }

  .homettl01 {
    padding: 114.6% 24px 10.6%;
  ]
}