body {
  padding-top: 500px;
}
@media screen and (max-width: 500px) {
  body {
    padding-top: 318px;
  }
}

.fv {
  position: relative;
  background-color: #091023;
}
.fv__news {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  background-color: #fff;
  padding-top: 24px;
  padding-bottom: 24px;
  padding-left: 20px;
  padding-right: 60px;
  -moz-column-gap: 20px;
       column-gap: 20px;
  row-gap: 17px;
  transform: translateX(17%);
  opacity: 0;
}
.fv__news.js-slide-in {
  transform: transLateX(0);
  transition: 0.6s;
  transition-timing-function: ease;
  opacity: 1;
}
@media screen and (max-width: 500px) {
  .fv__news {
    opacity: 0;
    transform: translateX(0);
    padding-right: 50px;
    padding-left: 20px;
  }
  .fv__news.js-slide-in {
    opacity: 1;
    transform: transLateX(0);
    transition: 0.6s;
  }
}
.fv__news-wrapper {
  width: 846px;
  max-width: 100%;
  position: absolute;
  bottom: 0;
  right: 0;
  height: -moz-fit-content;
  height: fit-content;
  z-index: 2;
  overflow: hidden;
  transform: translateY(50%);
}
@media screen and (max-width: 500px) {
  .fv__news-wrapper {
    width: 100%;
    left: 0;
    right: auto;
    transform: translateY(50%) translateX(-27.5px);
  }
}
.fv__news-date {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 15px;
  color: #111B36;
  line-height: 1;
  font-family: "termina", sans-serif;
  font-weight: 500;
  font-style: normal;
}
.fv__news-cat {
  width: 121px;
  height: 29px;
  line-height: 29px;
  color: #fff;
  font-size: 14px;
  text-align: center;
  font-weight: normal;
  background-color: #576885;
}
.fv__news-link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.fv__news-name {
  width: calc(100% - 293px);
  font-size: 15px;
  line-height: 1.8;
  color: #111B36;
}
@media screen and (max-width: 768px) {
  .fv__news-name {
    width: 100%;
  }
}
@media screen and (max-width: 500px) {
  .fv__news-name {
    min-width: auto;
  }
}
.fv__news::after {
  content: "";
  width: 20px;
  height: 17px;
  background-image: url(../image/arrow-blue.svg);
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media screen and (max-width: 768px) {
  .fv__news::after {
    right: 10px;
  }
}
.fv__news:hover::after {
  right: 12px;
  transition: 0.3s;
}
@media screen and (max-width: 768px) {
  .fv__news:hover::after {
    right: 0px;
  }
}
.fv__wrapper {
  width: 1160px;
  margin: 0 auto;
  padding-top: 549px;
  padding-bottom: 100px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 1200px) {
  .fv__wrapper {
    width: 80.5555555556vw;
    padding-bottom: 6.9444444444vw;
  }
}
@media screen and (max-width: 1024px) {
  .fv__wrapper {
    padding-top: max(300px, 37.79296875vw);
    padding-top: max(400px, 37.79296875vw);
    width: 91.9921875vw;
    padding-bottom: 9.765625vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__wrapper {
    padding-top: 328px;
    padding-top: 400px;
    width: 92vw;
    padding-bottom: 16.5333333333vw;
    flex-direction: column-reverse;
    row-gap: 30px;
  }
}
.fv__imgs {
  width: 468px;
  height: 413px;
  display: flex;
  position: relative;
}
@media screen and (max-width: 1200px) {
  .fv__imgs {
    width: 32.5vw;
    height: 28.6805555556vw;
  }
}
@media screen and (max-width: 1024px) {
  .fv__imgs {
    width: 38.671875vw;
    height: 33.69140625vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__imgs {
    width: 100%;
    height: 79.4666666667vw;
  }
}
.fv__textarea {
  width: 608px;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 1200px) {
  .fv__textarea {
    width: 42.2222222222vw;
  }
}
@media screen and (max-width: 1024px) {
  .fv__textarea {
    width: 48.828125vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__textarea {
    width: 100%;
  }
}
.fv__catch {
  color: #fff;
  font-size: 36px;
  line-height: 1.75;
  margin-bottom: 50px;
  font-weight: bold;
  z-index: 2;
}
@media screen and (max-width: 1200px) {
  .fv__catch {
    margin-bottom: 3.4722222222vw;
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 1024px) {
  .fv__catch {
    margin-bottom: 2.5390625vw;
    font-size: 3.515625vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__catch {
    font-size: 6.4vw;
    margin-bottom: 6.9333333333vw;
  }
}
.fv__explain {
  color: #Fff;
  font-size: 16px;
  line-height: 2;
  font-weight: normal;
  text-align: justify;
}
@media screen and (max-width: 1200px) {
  .fv__explain {
    font-size: 1.1111111111vw;
  }
}
@media screen and (max-width: 1024px) {
  .fv__explain {
    font-size: 1.46484375vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__explain {
    font-size: 4vw;
  }
}
.fv__top, .fv__img {
  width: calc(100% - 132px);
  height: 810px;
  position: absolute;
  right: 0;
  top: -408px;
  padding-left: 265px;
  padding-top: 260px;
  z-index: 2;
}
@media screen and (min-width: 1932px) {
  .fv__top, .fv__img {
    padding-left: 15%;
  }
}
@media screen and (min-width: 2200px) {
  .fv__top, .fv__img {
    padding-left: 18%;
  }
}
@media screen and (min-width: 2400px) {
  .fv__top, .fv__img {
    padding-left: 21%;
  }
}
@media screen and (min-width: 2600px) {
  .fv__top, .fv__img {
    padding-left: 24%;
  }
}
@media screen and (min-width: 2800px) {
  .fv__top, .fv__img {
    padding-left: 27%;
  }
}
@media screen and (max-width: 1440px) {
  .fv__top, .fv__img {
    padding-left: 18.4027777778vw;
  }
}
@media screen and (max-width: 1024px) {
  .fv__top, .fv__img {
    height: 676px;
    width: calc(100% - 95px);
    padding-left: 13.671875vw;
    padding-top: 250px;
  }
}
@media screen and (max-width: 950px) {
  .fv__top, .fv__img {
    top: -440px;
  }
}
@media screen and (max-width: 500px) {
  .fv__top, .fv__img {
    width: calc(100% - 55px);
    height: 533px;
    top: -258px;
    padding-left: 14.1333333333vw;
    padding-top: 170px;
  }
}
.fv__img {
  padding: 0;
}
.fv__img img, .fv__img source {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.fv__title {
  display: inline-block;
  color: #fff;
  font-size: 53px;
  line-height: 1.749905696;
  letter-spacing: 0.02em;
  margin-bottom: 26px;
  font-weight: bold;
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .fv__title {
    margin-bottom: 2.5390625vw;
    font-size: 4.39453125vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__title {
    font-size: 30px;
    margin-bottom: 26px;
  }
}
@media screen and (max-width: 375px) {
  .fv__title {
    font-size: 8vw;
  }
}
.fv__en {
  color: #fff;
  font-size: 19px;
  line-height: 1;
  letter-spacing: 0.02em;
  font-weight: normal !important;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 1024px) {
  .fv__en {
    font-size: 1.85546875vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__en {
    font-size: 7px;
  }
}
.fv__outline-wrapper {
  width: 50%;
  height: auto;
  background-color: transparent;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
}
.fv__outline-wrapper img {
  width: 100%;
}
.fv__img-wrapper {
  width: 156px;
  height: 312px;
  z-index: 2;
}
@media screen and (max-width: 1200px) {
  .fv__img-wrapper {
    width: 10.8333333333vw;
    height: 21.6666666667vw;
  }
}
@media screen and (max-width: 1024px) {
  .fv__img-wrapper {
    height: 25.87890625vw;
    width: 13.0859375vw;
  }
}
@media screen and (max-width: 500px) {
  .fv__img-wrapper {
    height: 61.3333333333vw;
    width: 30.9333333333vw;
  }
}
.fv__img-wrapper img {
  width: 100%;
}
.fv__img-wrapper-1 {
  transform: translateY(100px);
  opacity: 0;
}
.fv__img-wrapper-1.appeared {
  transform: translateY(41px);
  opacity: 1;
  transition: 0.5s;
}
@media screen and (max-width: 1200px) {
  .fv__img-wrapper-1.appeared {
    transform: translateY(2.8472222222vw);
  }
}
@media screen and (max-width: 1024px) {
  .fv__img-wrapper-1.appeared {
    transform: translateY(3.41796875vw);
  }
}
@media screen and (max-width: 500px) {
  .fv__img-wrapper-1.appeared {
    transform: translateY(8vw);
  }
}
.fv__img-wrapper-2 {
  transform: translateY(152px);
  opacity: 0;
}
.fv__img-wrapper-2.appeared {
  transform: translateY(93px);
  opacity: 1;
  transition: 0.5s;
  transition-delay: 0.2s;
}
@media screen and (max-width: 1200px) {
  .fv__img-wrapper-2.appeared {
    transform: translateY(6.4583333333vw);
  }
}
@media screen and (max-width: 1024px) {
  .fv__img-wrapper-2.appeared {
    transform: translateY(7.8125vw);
  }
}
@media screen and (max-width: 500px) {
  .fv__img-wrapper-2.appeared {
    transform: translateY(18.4vw);
  }
}
.fv__img-wrapper-3 {
  transform: translateY(59px);
  opacity: 0;
}
.fv__img-wrapper-3.appeared {
  transform: translateY(0);
  opacity: 1;
  transition: 0.5s;
  transition-delay: 0.4s;
}
.fv::before {
  content: "scroll";
  font-family: termina, sans-serif;
  font-weight: normal;
  color: #0f8fef;
  font-size: 14px;
  writing-mode: vertical-lr;
  position: absolute;
  top: -125px;
  left: 66px;
  transform: translateX(-50%);
}
@media screen and (max-width: 1024px) {
  .fv::before {
    left: 49px;
  }
}
@media screen and (max-width: 500px) {
  .fv::before {
    left: 29px;
  }
}
.fv::after {
  content: "";
  width: 1px;
  position: absolute;
  top: -68px;
  left: 65px;
  height: 136px;
  animation: backwards 2s 0.5s infinite heightChange;
  border-left: #0f8fef 2px solid;
}
@media screen and (max-width: 1024px) {
  .fv::after {
    left: 47px;
  }
}
@media screen and (max-width: 500px) {
  .fv::after {
    left: 27px;
  }
}
.fv__sm-br {
  display: none;
}
@media screen and (max-width: 500px) {
  .fv__sm-br {
    display: block;
  }
}

@keyframes heightChange {
  0% {
    transform-origin: top;
    transform: scaleY(0);
  }
  50% {
    transform: scaleY(1);
    transform-origin: top;
  }
  51% {
    transform-origin: bottom;
    transform: scaleY(1);
  }
  100% {
    transform: scaleY(0);
    transform-origin: bottom;
  }
}
.service {
  background-color: #182445;
  padding-top: 92px;
  padding-bottom: 100px;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .service {
    padding-top: 8.984375vw;
    padding-bottom: 9.765625vw;
  }
}
@media screen and (max-width: 500px) {
  .service {
    padding-top: 16vw;
    padding-bottom: 16vw;
  }
}
.service__title {
  line-height: 1;
  font-size: 48px;
  letter-spacing: 0.02em;
  margin-bottom: 104px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .service__title {
    font-size: 4.6875vw;
    margin-bottom: 10.15625vw;
  }
}
@media screen and (max-width: 500px) {
  .service__title {
    font-size: 6.4vw;
    margin-bottom: 16.8vw;
  }
}
.service__block {
  width: 100%;
  margin: 0 auto;
  height: 556px;
  margin-bottom: 100px;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .service__block {
    height: 54.296875vw;
    margin-bottom: 9.765625vw;
  }
}
@media screen and (max-width: 500px) {
  .service__block {
    height: auto;
    margin-bottom: 16vw;
  }
}
.service__block.reverse .service__block-wrapper {
  padding-right: 140px;
  padding-left: 0;
}
@media screen and (max-width: 1440px) {
  .service__block.reverse .service__block-wrapper {
    padding-right: 9.7222222222vw;
  }
}
@media screen and (max-width: 1024px) {
  .service__block.reverse .service__block-wrapper {
    padding-right: 3.90625vw;
  }
}
@media screen and (max-width: 500px) {
  .service__block.reverse .service__block-wrapper {
    padding-right: 0;
  }
}
.service__block.reverse .service__textarea {
  margin-left: auto;
}
@media screen and (max-width: 500px) {
  .service__block.reverse .service__textarea {
    margin: 0 auto;
  }
}
.service__block.reverse .service__img-wrapper {
  left: 0;
}
.service__block-wrapper {
  width: 1440px;
  margin: 0 auto;
  padding-top: 96px;
  padding-left: 140px;
}
@media screen and (max-width: 1440px) {
  .service__block-wrapper {
    width: 100%;
    padding-left: 9.7222222222vw;
  }
}
@media screen and (max-width: 1024px) {
  .service__block-wrapper {
    width: 100%;
    padding-left: 3.90625vw;
    padding-top: 9.375vw;
  }
}
@media screen and (max-width: 500px) {
  .service__block-wrapper {
    padding-top: 47.2vw;
    padding-left: 0;
    height: auto;
  }
}
.service__textarea {
  width: 610px;
  background-color: #Fff;
  padding-top: 55px;
  padding-left: 80px;
  padding-right: 80px;
  padding-bottom: 41px;
  text-align: right;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1024px) {
  .service__textarea {
    padding-top: 5.37109375vw;
    padding-left: 7.8125vw;
    padding-right: 7.8125vw;
    padding-bottom: 4.00390625vw;
    width: 59.5703125vw;
  }
}
@media screen and (max-width: 500px) {
  .service__textarea {
    padding-top: 8vw;
    padding-left: 10.6666666667vw;
    padding-right: 10.6666666667vw;
    padding-bottom: 9.3333333333vw;
    width: 91.7333333333vw;
    margin: 0 auto;
  }
}
.service__logo-wrapper {
  width: 313px;
  height: 40px;
  margin-bottom: 28px;
}
@media screen and (max-width: 1024px) {
  .service__logo-wrapper {
    width: 30.56640625vw;
    margin-bottom: 2.734375vw;
    height: 3.90625vw;
  }
}
@media screen and (max-width: 500px) {
  .service__logo-wrapper {
    width: 56.2666666667vw;
    margin-bottom: 9.0666666667vw;
    height: 5.3333333333vw;
  }
}
.service__logo-wrapper img {
  width: 100%;
}
.service__block-title {
  font-size: 24px;
  line-height: 1.8;
  font-weight: bold;
  margin-bottom: 32px;
  text-align: left;
  color: #091023;
}
@media screen and (max-width: 1024px) {
  .service__block-title {
    font-size: 2.34375vw;
    margin-bottom: 3.125vw;
  }
}
@media screen and (max-width: 500px) {
  .service__block-title {
    font-size: 4.8vw;
    margin-bottom: 6.1333333333vw;
  }
}
.service__explain {
  font-size: 16px;
  line-height: 2;
  font-weight: normal;
  text-align: justify;
  color: #182445;
}
@media screen and (max-width: 1024px) {
  .service__explain {
    font-size: 1.5625vw;
  }
}
@media screen and (max-width: 500px) {
  .service__explain {
    line-height: 1.8;
    font-size: 4vw;
  }
}
.service__btn {
  display: inline-block;
  padding-left: 14px;
  padding-right: 36px;
  padding-top: 20px;
  padding-bottom: 20px;
  border-bottom: 2px solid #e4ecf9;
  position: relative;
  font-size: 16px;
}
@media screen and (max-width: 1024px) {
  .service__btn {
    padding-left: 1.3671875vw;
    padding-right: 3.515625vw;
    padding-top: 1.953125vw;
    padding-bottom: 1.953125vw;
    font-size: 1.5625vw;
  }
}
@media screen and (max-width: 500px) {
  .service__btn {
    padding-left: 3.7333333333vw;
    padding-right: 9.6vw;
    padding-top: 5.3333333333vw;
    padding-bottom: 5.3333333333vw;
    font-size: 4.2666666667vw;
  }
}
.service__btn:hover {
  color: #0f8fef;
}
.service__btn:hover::before {
  width: 100%;
  transition: 0.3s;
}
.service__btn:hover::after {
  background-image: url("../image/newtab-right-blue.svg");
}
.service__btn::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background-image: url("../image/newtab-darkblue.svg");
  position: absolute;
  background-size: contain;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
@media screen and (max-width: 1024px) {
  .service__btn::after {
    width: 1.953125vw;
    height: 1.953125vw;
  }
}
@media screen and (max-width: 500px) {
  .service__btn::after {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
  }
}
.service__btn::before {
  content: "";
  height: 2px;
  width: 42px;
  background-color: #0f8fef;
  position: absolute;
  bottom: -2px;
  left: 0;
  transition: 0.3s;
}
@media screen and (max-width: 1024px) {
  .service__btn::before {
    width: 4.1015625vw;
  }
}
@media screen and (max-width: 500px) {
  .service__btn::before {
    width: 11.2vw;
  }
}
.service__img-wrapper {
  width: 70%;
  height: 100%;
  background-size: contain;
  background-position-x: 50%;
  background-position-y: -100px;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  overflow: hidden;
}
.service__img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transform: scale(1.3) translateY(-30px);
}
@media screen and (max-width: 1440px) {
  .service__img-wrapper {
    width: 75.9027777778vw;
  }
}
@media screen and (max-width: 1024px) {
  .service__img-wrapper {
    width: 77.1484375vw;
  }
}
@media screen and (max-width: 500px) {
  .service__img-wrapper {
    width: 100%;
    height: 66.6666666667vw;
  }
}
.service__bg-text {
  line-height: 1;
  font-weight: bold;
  font-size: 159px;
  letter-spacing: 0.02em;
  position: absolute;
  top: 60px;
  left: 0px;
  color: #111b36;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .service__bg-text {
    font-size: 15.52734375vw;
    top: 5.859375vw;
  }
}
@media screen and (max-width: 500px) {
  .service__bg-text {
    font-size: 14.9333333333vw;
    top: 13.8666666667vw;
  }
}

.news {
  background-color: #091023;
  padding-top: 92px;
  padding-bottom: 100px;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .news {
    padding-bottom: 9.765625vw;
    padding-top: 8.984375vw;
  }
}
@media screen and (max-width: 500px) {
  .news {
    padding-top: 16vw;
    padding-bottom: 16vw;
  }
}
.news__title {
  color: #fff;
  font-size: 48px;
  line-height: 1;
  font-weight: bold;
  margin-bottom: 100px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1024px) {
  .news__title {
    font-size: 4.6875vw;
    margin-bottom: 10.15625vw;
  }
}
@media screen and (max-width: 500px) {
  .news__title {
    font-size: 6.4vw;
    margin-bottom: 16.8vw;
  }
}
.news__items {
  margin-bottom: 100px;
}
@media screen and (max-width: 768px) {
  .news__items {
    margin-bottom: 60px;
  }
}
.news__item {
  width: 1160px;
  padding-top: 30px;
  padding-bottom: 30px;
  padding-left: 20px;
  padding-right: 60px;
  background-color: #182445;
  margin: 0 auto;
  align-items: center;
  display: flex;
  margin-bottom: 20px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1200px) {
  .news__item {
    width: 92.08984375vw;
  }
}
@media screen and (max-width: 768px) {
  .news__item {
    flex-wrap: wrap;
    row-gap: 15px;
    padding-right: 20px;
  }
}
.news__item:last-of-type {
  margin-bottom: 0;
}
.news__item::after {
  content: "";
  width: 20px;
  height: 17px;
  background-image: url(../image/arrow-blue.svg);
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media screen and (max-width: 768px) {
  .news__item::after {
    right: 10px;
  }
}
.news__item:hover .news__link {
  background-size: 100% 2px;
}
.news__item:hover::after {
  right: 12px;
  transition: 0.3s;
}
@media screen and (max-width: 768px) {
  .news__item:hover::after {
    right: 0px;
  }
}
.news__date {
  color: #fff;
  font-size: 15px;
  font-weight: normal !important;
  width: 72px;
  margin-right: 58px;
}
@media screen and (max-width: 375px) {
  .news__date {
    margin-right: 15.4666666667vw;
  }
}
.news__cat {
  width: 123px;
  text-align: center;
  height: 30px;
  line-height: 30px;
  color: #Fff;
  background-color: #576885;
  margin-right: 28px;
  font-size: 14px;
  font-weight: normal;
}
@media screen and (max-width: 768px) {
  .news__cat {
    margin-right: 0;
  }
}
@media screen and (max-width: 375px) {
  .news__cat {
    width: 32.8vw;
  }
}
.news__name {
  color: #fff;
  line-height: 1.8;
  font-size: 15px;
  font-weight: normal;
  width: calc(100% - 280px);
  display: inline !important;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  .news__name {
    width: 100%;
    padding-right: 15px;
  }
}
.news__link {
  background: linear-gradient(transparent, #fff) 0px 100%/0px 2px no-repeat;
  transition: background 0.4s;
  text-decoration: none;
  color: #fff;
}
.news__bg-text {
  color: #111b36;
  font-size: 158px;
  line-height: 1;
  letter-spacing: 0.02em;
  font-weight: bold;
  position: absolute;
  top: 60px;
  right: 0;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .news__bg-text {
    font-size: 15.52734375vw;
    top: 5.859375vw;
  }
}
@media screen and (max-width: 500px) {
  .news__bg-text {
    font-size: 14.9333333333vw;
    top: 13.8666666667vw;
  }
}
.news__link-wide {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.contact {
  background-image: url("../image/contact.webp");
  background-size: cover;
  background-position: top center;
  padding-top: 120px;
  padding-bottom: 110px;
  text-align: center;
}
@media screen and (max-width: 500px) {
  .contact {
    padding-top: 132px;
    padding-bottom: 110px;
  }
}
.contact__title {
  margin: 0 auto;
  text-align: center;
  color: #fff;
  font-size: 60px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1;
  margin-bottom: 62px;
}
@media screen and (max-width: 500px) {
  .contact__title {
    font-size: 41px;
  }
}
.contact__btn {
  display: inline-block;
  text-align: center;
  width: 325px;
  padding-top: 25px;
  padding-bottom: 25px;
  line-height: 1;
  color: #fff;
  border-radius: 200px;
  background-color: #0f8fef;
  border: 3px solid #0f8fef;
  font-size: 16px;
  font-weight: normal;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 500px) {
  .contact__btn {
    width: 262px;
  }
}
.contact__btn::before {
  content: "";
  width: 0%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #fff;
  transition: 0.5s;
}
.contact__btn::after {
  content: "";
  width: 20px;
  height: 17px;
  background-image: url(../image/arrow.svg);
  background-size: cover;
  position: absolute;
  top: 50%;
  right: 28px;
  transform: translateY(-50%);
}
.contact__btn:hover {
  color: #0f8fef;
}
.contact__btn:hover::before {
  width: 100%;
  transition: 0.5s;
}
.contact__btn:hover::after {
  background-image: url("../image/arrow-blue.svg");
}
.contact__btn span {
  position: relative;
  z-index: 2;
}

.bgextend {
  animation-name: bgextendAnimeBase;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  position: relative;
  overflow: hidden;
  opacity: 0;
}
@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.bgappear {
  animation-name: bgextendAnimeSecond;
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-fill-mode: forwards;
  opacity: 0;
}

.bgappear-w {
  animation-name: bgextendAnimeSecond;
  animation-duration: 1s;
  animation-delay: 0.6s;
  animation-fill-mode: forwards;
  opacity: 0;
}
@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.bgLRextend::before {
  animation-name: bgLRextendAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #fff;
}
@keyframes bgLRextendAnime {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  50% {
    transform-origin: left;
    transform: scaleX(1);
  }
  51% {
    transform-origin: right;
    transform: scaleX(1);
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
.bgextendTrigger,
.bgLRextendTrigger {
  opacity: 0;
}/*# sourceMappingURL=top.css.map */