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

.fv {
  position: relative;
  background-color: #091023;
  height: max(100vh - 580px, 310px);
  max-height: 462px;
}
@media screen and (max-width: 1024px) {
  .fv {
    height: 310px;
  }
}
@media screen and (max-width: 768px) {
  .fv {
    height: auto;
    max-height: inherit;
  }
}
.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: 768px) {
  .fv__news-wrapper {
    width: calc(100vw - 112px);
    right: 56px;
    bottom: -60px;
    transform: inherit;
  }
}
@media screen and (max-width: 550px) {
  .fv__news-wrapper {
    width: calc(100vw - 56px);
    right: 28px;
  }
}
.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__top, .fv__img {
  width: calc(100% - 132px);
  height: max(100vh - 172px, 718px);
  max-height: 870px;
  position: absolute;
  right: 0;
  top: -408px;
  padding-left: 10.0694444444vw;
  padding-top: 20vh;
  z-index: 2;
}
@media screen and (max-width: 1024px) {
  .fv__top, .fv__img {
    width: calc(100% - 95px);
    height: 718px;
    padding-top: 14vh;
  }
}
@media screen and (max-width: 950px) {
  .fv__top, .fv__img {
    top: -440px;
    padding-top: 20vh;
    height: 750px;
  }
}
@media screen and (max-width: 768px) {
  .fv__top {
    width: 100%;
    position: relative;
    top: 0;
    margin-top: 60px;
    height: 65vh;
    padding-top: 20vh;
    padding-left: 56px;
  }
}
@media screen and (max-width: 550px) {
  .fv__top {
    padding-left: 28px;
    min-height: 530px;
  }
}
.fv__img {
  padding: 0;
}
.fv__img img, .fv__img source {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 768px) {
  .fv__img {
    width: 100%;
    top: 0;
    height: 65vh;
  }
}
@media screen and (max-width: 550px) {
  .fv__img {
    min-height: 530px;
  }
}
.fv__title {
  display: inline-block;
  color: #fff;
  font-size: 53px;
  line-height: 1.749905696;
  letter-spacing: 0.02em;
  margin-bottom: 80px;
  font-weight: bold;
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .fv__title {
    margin-bottom: 2.5390625vw;
    font-size: max(4.39453125vw, 32px);
  }
}
@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__text {
  color: #fff;
  font-size: 17px;
  line-height: 2;
  letter-spacing: 0.02em;
  font-weight: normal !important;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 1024px) {
  .fv__text {
    font-size: max(1.85546875vw, 16px);
    width: 530px;
  }
}
@media screen and (max-width: 768px) {
  .fv__text {
    display: none;
  }
}
.fv__text .annotation {
  font-size: 11px;
  margin: 0 3px;
}
.fv__text .new-window-link {
  color: #fff;
}
.fv__text .new-window-link img {
  width: 14px;
  margin: 0 8px 0 6px;
}
.fv__text .new-window-link:hover {
  color: #0f8fef;
}
.fv__text .new-window-link:hover img {
  filter: invert(58%) sepia(57%) saturate(6425%) hue-rotate(184deg) brightness(99%) contrast(90%);
}
.fv__text-note {
  font-size: 11px;
  margin-top: 12px;
}
.fv__text-note a {
  color: #fff;
  text-decoration: underline;
}
.fv__text-sp {
  display: none;
  background: #091023;
  padding: 94px 56px 56px;
  color: #fff;
  font-size: 16px;
  line-height: 1.8;
  text-align: justify;
}
@media screen and (max-width: 550px) {
  .fv__text-sp {
    padding: 94px 28px 40px;
    font-size: 15px;
  }
}
.fv__text-sp .annotation {
  font-size: 11px;
  margin: 0 3px;
}
.fv__text-sp .new-window-link {
  color: #fff;
}
.fv__text-sp .new-window-link img {
  width: 14px;
  margin: 0 8px 0 6px;
}
.fv__text-sp .fv__text-note {
  display: block;
  width: 100%;
  text-align: right;
  font-size: 12px;
  margin-top: 12px;
}
.fv__text-sp .fv__text-note a {
  color: #fff;
  text-decoration: underline;
}
@media screen and (max-width: 768px) {
  .fv__text-sp {
    display: block;
  }
}
.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: 768px) {
  .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: 200px;
  padding-bottom: 100px;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .service {
    padding-top: 19.53125vw;
    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: auto;
    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;
    padding-bottom: 5.46875vw;
  }
}
@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;
    min-width: 360px;
  }
}
@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;
    min-width: inherit;
  }
}
.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: max(2.34375vw, 18px);
    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: max(1.5625vw, 15px);
    margin-bottom: 16px;
    line-height: 1.8;
  }
}
@media screen and (max-width: 500px) {
  .service__explain {
    font-size: 4vw;
    margin: 0;
  }
}
.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: max(1.5625vw, 15px);
  }
}
@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: 152px;
  left: 0px;
  color: #111b36;
  z-index: 1;
}
@media screen and (max-width: 1024px) {
  .service__bg-text {
    font-size: 15.52734375vw;
    top: 14.84375vw;
  }
}
@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 */