.top-sp-hidden {
  display: none;
}

.top-pc-hidden {
  display: block;
}
@media screen and (min-width: 768px) {
  .top-sp-hidden {
    display: block;
  }

  .top-pc-hidden {
    display: none;
  }
}

.content article > .top-section {
  margin-bottom: 48px;
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .content article > .top-section {
    margin-bottom: 0;
    margin-top: 40px;
    padding-left: 0;
    padding-right: 0;
  }
}

.top-section > * {
  margin: 0;
  max-width: 100%;
}
@media screen and (min-width: 768px) {
  .top-section > * {
    margin-left: auto;
    margin-right: auto;
    max-width: 1242px;
  }
}

.top-keyvisual {
  margin-left: 0;
  margin-right: 0;
}

@media screen and (min-width: 1303px) {
  .top-keyvisual {
    max-width: calc(1242px + (30px * 2)) !important;
  }
}

.top-keyvisual__inner {
  margin-left: 0;
  margin-right: 0;
}
@media screen and (min-width: 768px) {
  .top-keyvisual__inner {
    margin-left: auto;
    margin-right: auto;
  }
}

.top-keyvisual-content__inner a {
  padding-bottom: 0;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-content__inner a {
    display: flex;
    justify-content: flex-start;
    padding-bottom: 0;
  }
}

.top-keyvisual-image {
  border-radius: 10px;
  box-shadow: 8px 4px 30px 0 rgb(0 0 0 / 0.16);
  overflow: hidden;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-image {
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
    width: 47.8%;
  }
}

.top-keyvisual-image img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-image img {
    border-radius: 10px;
    box-shadow: 8px 4px 30px 0 rgb(0 0 0 / 0.16);
  }
}

.top-keyvisual-info {
  margin-top: 16px;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-info {
    margin-left: 30px;
    margin-top: 40px;
    opacity: 1;
    width: 49%;
  }
}

.swiper-slide-active .top-keyvisual-info {
  animation: 1s ease-out 0.5s forwards top-keyvisual-info;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .swiper-slide-active .top-keyvisual-info {
    animation: none;
    opacity: 1;
  }
}

@media screen and (min-width: 768px) and (max-width: 1366px) {
  .top-keyvisual-info {
    margin-left: 3vw;
    margin-top: 3.62vw;
  }
}

.top-keyvisual__title {
  color: #08287f;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.4;
  max-width: 80vw;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .top-keyvisual__title {
    color: #08287f;
    font-size: 4.2rem;
    max-width: 530px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1366px) {
  .top-keyvisual__title {
    font-size: 3vw;
    width: 37vw;
  }
}

.top-keyvisual__title span {
  background-color: rgb(255 255 255 / 0.8);
  padding: 1.5px 0;
}
@media screen and (min-width: 768px) {
  .top-keyvisual__title span {
    padding: 2px 0;
  }
}

.top-keyvisual__lead {
  color: #333;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.6;
  margin-top: 4px;
  max-width: 75vw;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .top-keyvisual__lead {
    font-size: 1.6rem;
    max-width: 430px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1366px) {
  .top-keyvisual__lead {
    font-size: 1.2vw;
    width: 36vw;
  }
}

.top-keyvisual__lead span {
  background-color: rgb(255 255 255 / 0.8);
  padding: 2px 0;
}
@media screen and (min-width: 768px) {
  .top-keyvisual__lead span {
    padding: 1.95px 0;
  }
}

.top-keyvisual-carousel {
  position: relative;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-carousel {
    overflow: hidden;
    padding: 0 30px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1302px) {
  .top-keyvisual-carousel {
    padding: 0;
  }
}

/* .top-keyvisual-carousel__inner {
  transition: all 0.5s ease-out !important;
} */

.top-keyvisual-carousel__page {
  align-items: center;
  display: flex;
  transition: margin 0.5s ease-out;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-carousel__page {
    bottom: 16px;
    left: calc(50% - -10px);
    max-width: 540px;
    position: absolute;
    width: 100%;
  }
}

@media screen and (min-width: 768px) {
  .top-keyvisual-carousel__button-next {
    right: calc((100% - 570px) / 2);
  }
}

.top-keyvisual-carousel__button-prev,
.top-keyvisual-carousel__button-next {
  display: none;
  height: 40px;
  width: 40px;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-carousel__button-prev,
  .top-keyvisual-carousel__button-next {
    margin-top: -52px;
  }
}

.top-keyvisual-carousel__button-prev::after,
.top-keyvisual-carousel__button-next::after {
  background: url(/common2024/images/icon/icon_carousel_control.svg) no-repeat;
  background-size: contain;
  content: '';
  height: 100%;
  width: 100%;
}

.top-keyvisual-carousel__button-pouse {
  background: url(/common2024/images/icon/icon_pouse.svg) no-repeat;
  background-size: cover;
  border-radius: 100%;
  bottom: 0;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 0.2);
  cursor: pointer;
  display: inline-block;
  height: 30px;
  margin-left: 15px;
  position: relative;
  width: 30px;
  z-index: 11;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-carousel__button-pouse {
  }
}

.top-keyvisual-carousel__button-pouse.is-stop {
  background: url(/common2024/images/icon/icon_link_arrow.svg) no-repeat;
  background-size: cover;
}

.top-keyvisual-carousel__pagination {
  position: relative;
  text-align: left;
  vertical-align: sub;
  width: auto !important;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-carousel__pagination {
  }
}

.top-keyvisual-carousel > .top-keyvisual-carousel__pagination {
  width: auto;
}
@media screen and (min-width: 768px) {
  .top-keyvisual-carousel > .top-keyvisual-carousel__pagination {
  }
}

.top-keyvisual-carousel__pagination .swiper-pagination-bullet {
  background: #f3f3f3;
  height: 15px;
  margin: 0;
  width: 15px;
}

.top-keyvisual-carousel__pagination .swiper-pagination-bullet:nth-child(n + 2) {
  margin-left: 15px;
}

.top-keyvisual-carousel__pagination .swiper-pagination-bullet-active {
  background: #285ae1;
}

.top-pickupservice {
  margin-top: 40px;
}
@media screen and (min-width: 768px) {
  .top-pickupservice {
    margin-top: 48px;
  }
}

.top-pickupservice__inner {
  background-color: rgb(240 244 255 / 0.9);
  display: flex;
  justify-content: space-between;
  padding: 16px 4px;
}
@media screen and (min-width: 768px) {
  .top-pickupservice__inner {
    border-radius: 10px;
    margin-left: 0;
    margin-right: 0;
    padding: 24px 162px;
  }
}

.top-pickupservice-content {
  padding: 0 4px;
  width: 32.41%;
}

@media screen and (min-width: 768px) {
  .top-pickupservice-content {
    padding: 0;
    width: 29.41%;
  }

  .top-pickupservice-content:not(:first-child) {
    margin-left: 16px;
  }
}

.top-pickupservice-content__link {
}
@media screen and (min-width: 768px) {
  .top-pickupservice-content__link {
  }
}

.top-pickupservice-content__image {
  margin: 0 auto;
  max-width: 56px;
}
@media screen and (min-width: 768px) {
  .top-pickupservice-content__image {
    max-width: 96px;
    text-align: center;
  }
}

.top-pickupservice-content__image img {
  filter: drop-shadow(30px 4px 30px rgb(0 0 0 / 0.16));
  width: 100%;
}

.top-pickupservice-content__body {
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .top-pickupservice-content__body {
    margin-top: 16px;
  }
}

.top-pickupservice-content__title {
  color: #285ae1;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-pickupservice-content__title {
    font-size: 2rem;
  }
}

.top-pickupservice-content__text {
  display: none;
}
@media screen and (min-width: 768px) {
  .top-pickupservice-content__text {
    color: #333;
    display: block;
    font-size: 1.4rem;
    line-height: 1.6;
    margin-top: 4px;
    text-align: center;
  }
}

.top-service {
  margin-left: 4%;
  margin-right: 4%;
  margin-top: 48px;
  max-width: 92%;
}
@media screen and (min-width: 768px) {
  .top-service {
    margin-left: auto;
    margin-right: auto;
    max-width: 1242px;
  }
}

.top-service__inner {
}
@media screen and (min-width: 768px) {
  .top-service__inner {
    display: flex;
  }
}

.top-service-content {
  background-color: rgb(255 255 255 / 0.9);
  border: 1px solid #fff;
  border-radius: 10px;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 0.2);
  padding: 28px;
}

.top-service-content:not(:first-child) {
  margin-top: 15px;
}
@media screen and (min-width: 768px) {
  .top-service-content {
    padding: 32px 24px;
    width: 30.43%;
  }

  .top-service-content:not(:first-child) {
    margin-left: 54px;
    margin-top: 0;
  }
}

.top-service-content__title {
  color: #285ae1;
  font-size: 2rem;
  font-weight: bold;
  line-height: 2;
  padding-left: 55px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .top-service-content__title {
    line-height: 2.4;
    padding-left: 63px;
  }
}

.top-service-content__titile-icon {
  height: auto;
  left: 0;
  max-width: 40px;
  position: absolute;
  top: 0;
  width: auto;
}
@media screen and (min-width: 768px) {
  .top-service-content__titile-icon {
    max-width: 48px;
  }
}

.top-service-content-list.section__list {
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .top-service-content-list.section__list {
  }
}

.top-service-content-list__item {
}

.top-service-content-list__item:nth-child(n + 2) {
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .top-service-content-list__item:nth-child(n + 2) {
    margin-top: 5px;
  }
}

.top-service-content-list__link {
  color: #0000b3;
}
@media screen and (min-width: 768px) {
  .top-service-content-list__link {
  }
}

.top-service-content-list__link-text {
}
@media screen and (min-width: 768px) {
  .top-service-content-list__link-text {
  }
}

.top-otherservice {
  background-color: rgb(240 244 255 / 0.9);
  margin-top: 48px;
}
@media screen and (min-width: 768px) {
  .top-otherservice {
  }

  .top-seconditem > .top-otherservice {
    max-width: 100%;
  }
}

.top-otherservice__inner {
  padding: 32px 4%;
}
@media screen and (min-width: 768px) {
  .top-otherservice__inner {
    margin: 0 auto;
    max-width: 1324px;
    padding: 24px 42px;
  }
}

.top-otherservice__body {
}
@media screen and (min-width: 768px) {
  .top-otherservice__body {
  }
}

.top-otherservice-list {
}
@media screen and (min-width: 768px) {
  .top-otherservice-list {
    display: flex;
    flex-wrap: wrap;
  }
}

.top-otherservice-list__item {
  width: 100%;
}

.top-otherservice-list__item:not(:first-child) {
  margin-top: 4%;
}
@media screen and (min-width: 768px) {
  .top-otherservice-list__item {
    width: 21.73%;
  }

  .top-otherservice-list__item:not(:first-child) {
    margin-top: 0;
  }

  .top-otherservice-list__item:nth-child(n + 5) {
    margin-top: 16px;
  }

  .top-otherservice-list__item:not(:nth-child(4n + 1)) {
    margin-left: 4.34%;
  }
}

.top-otherservice-list__link {
  background-color: #fff;
  border: 1px solid #fff;
  border-radius: 10px;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 0.2);
  color: #285ae1;
  display: block;
  font-size: 1.8rem;
  font-weight: bold;
  height: 100%;
  line-height: 1.2;
  padding: 21px 44px 21px 16px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .top-otherservice-list__link {
    align-items: center;
    border: 1px solid #ccc;
    display: flex;
    padding: 21px 24px;
  }
}

.top-otherservice-list__link::after {
  background: url(/common2024/images/icon/icon_triangle.png) no-repeat;
  background-size: contain;
  content: '';
  display: block;
  height: 12px;
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
}
@media screen and (min-width: 768px) {
  .top-otherservice-list__link::after {
    right: 8px;
  }
}

.top-academy {
  background-color: rgb(226 234 255 / 0.9);
}
@media screen and (min-width: 768px) {
  .top-academy {
    margin-top: 0;
  }

  .top-seconditem .top-academy {
    max-width: 100%;
  }
}

.top-academy__inner {
  padding: 32px 4%;
}
@media screen and (min-width: 768px) {
  .top-academy__inner {
    margin: 0 auto;
    max-width: 1324px;
    padding: 24px 42px;
  }
}

.top-academy__head {
}
@media screen and (min-width: 768px) {
  .top-academy__head {
  }
}

.top-academy__title {
  color: #333;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .top-academy__title {
  }
}

.top-academy__text {
  color: #333;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.6;
  margin-top: 8px;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .top-academy__text {
    font-size: 1.6rem;
    line-height: 1.42;
  }
}

.top-academy__body {
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .top-academy__body {
  }
}

.top-academy-article {
}
@media screen and (min-width: 768px) {
  .top-academy-article {
    display: flex;
  }
}

.top-academy-article-contents {
  width: 100%;
}

.top-academy-article-contents:not(:first-child) {
  margin-top: 26px;
}
@media screen and (min-width: 768px) {
  .top-academy-article-contents {
    width: 30.43%;
  }

  .top-academy-article-contents:not(:first-child) {
    margin-top: 0;
  }

  .top-academy-article-contents:not(:nth-child(3n + 1)) {
    margin-left: 54px;
  }
}

.top-academy-article__link {
  background-color: #fff;
  border-radius: 10px;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 0.2);
  display: block;
  height: 100%;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .top-academy-article__link {
  }
}

.top-academy-article__image {
}
@media screen and (min-width: 768px) {
  .top-academy-article__image {
  }
}

.top-academy-article__image img {
  width: 100%;
}

.top-academy-article__body {
  padding: 16px 36px 32px 16px;
}
@media screen and (min-width: 768px) {
}

.top-academy-article__text {
  color: #285ae1;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.2;
  position: relative;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .top-academy-article__text {
  }
}

.top-academy-article__text::after {
  background: url(/common2024/images/icon/icon_triangle.png) no-repeat;
  background-size: contain;
  content: '';
  display: block;
  height: 12px;
  position: absolute;
  right: -20px;
  top: 0;
  width: 12px;
}
@media screen and (min-width: 768px) {
  .top-academy-article__text::after {
  }
}

.top-academy-pagetop {
  margin-top: 16px;
}
@media screen and (min-width: 768px) {
  .top-academy-pagetop {
  }
}

.top-academy-pagetop__link {
  color: #0000b3;
}
@media screen and (min-width: 768px) {
  .top-academy-pagetop__link {
  }
}

.top-news {
  margin-top: 48px;
}
@media screen and (min-width: 768px) {
  .top-news {
  }
}

.top-news__inner {
  background-color: rgb(255 255 255 / 0.9);
  border: 1px solid #fff;
  border-radius: 10px;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 0.2);
  padding: 32px 4%;
}

@media screen and (min-width: 768px) {
  .top-news__inner {
    padding: 48px 60px 30px;
  }
}

.top-news__tab {
}
@media screen and (min-width: 768px) {
  .top-news__tab {
    margin: 0;
    width: 100%;
  }
}

.top-news__tab-head {
  max-width: 100%;
  padding: 0;
}

.top-news__tab-list {
}
@media screen and (min-width: 768px) {
  .top-news__tab-list {
  }
}

.top-news__tab-item {
}
@media screen and (min-width: 768px) {
  .top-news__tab-item {
  }
}

.top-news__tab-item-inner {
  padding: 20px 12px;
}
@media screen and (min-width: 768px) {
  .top-news__tab-item-inner {
    padding: 20px 24px;
  }
}

.top-news__tab-content {
}
@media screen and (min-width: 768px) {
  .top-news__tab-content {
  }
}

.top-news__tab-body {
  margin-top: 24px;
}
@media screen and (min-width: 768px) {
  .top-news__tab-body {
    margin-top: 32px;
  }
}

.top-news__tab-body > .top-news-topics {
  max-width: 100%;
}
@media screen and (min-width: 768px) {
}

.top-news-topics {
}
@media screen and (min-width: 768px) {
  .top-news-topics {
  }
}

.top-news-topics__item {
  border-top: 1px solid #ccc;
  padding: 16px 0 24px;
}

.top-news-topics__item:last-child {
  border-bottom: 1px solid #ccc;
}
@media screen and (min-width: 768px) {
  .top-news-topics__item {
  }
}

.top-news-topics__head {
}

.top-news-topics__head *:not(:first-child) {
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .top-news-topics__head {
    align-items: center;
    display: flex;
  }

  .top-news-topics__head *:not(:first-child) {
    margin-left: 8px;
    margin-top: 0;
  }
}

.top-news-topics__date {
  color: #555;
  font-weight: 700;
  line-height: 1.2;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .top-news-topics__date {
    line-height: 1.18;
  }
}

.top-news-topics__body {
  margin-top: 8px;
}
@media screen and (min-width: 768px) {
  .top-news-topics__body {
  }
}

.top-news-topics__text {
}

.top-news-topics__body :not(:last-child) {
  margin-bottom: 4px;
}
@media screen and (min-width: 768px) {
  .top-news-topics__text {
  }

  .top-news-topics__body :not(:last-child) {
    margin-bottom: 6px;
  }
}

.top-news-topics__list.section__list {
}
@media screen and (min-width: 768px) {
  .top-news-topics__list.section__list {
  }
}

.top-news-topics__list.section__list:not(:last-child) {
  margin-bottom: 4px;
}

.top-news-topics__list-link {
}
@media screen and (min-width: 768px) {
  .top-news-topics__list-link {
  }
}

.top-news-topics__list .top-news-topics__list-link + .top-news-topics__list-link {
  border: none;
  padding-top: 0;
}

.top-news-topics__list-item {
}
@media screen and (min-width: 768px) {
  .top-news-topics__list .top-news-topics__list-item {
    margin: 0 14px 0 0;
  }
}

.top-news-topics__list-item.top-news-topics__list-link:first-child {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  .top-news-topics__list-item.top-news-topics__list-link:first-child {
    margin-top: 0;
  }
}

.top-news-topics__link {
}
@media screen and (min-width: 768px) {
  .top-news-topics__link {
  }
}

.top-news-topics__link-text {
  color: #0000b3;
}
@media screen and (min-width: 768px) {
  .top-news-topics__link-text {
  }
}

.top-news-topics__list-label-item {
  background-color: #e2eaff;
  color: #333;
  font-size: 1.2rem;
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .top-news-topics__list-label-item {
  }
}

.top-news__tab-body > .top-news-others {
  margin-top: 24px;
  max-width: 100%;
}
@media screen and (min-width: 768px) {
  .top-news__tab-body > .top-news-others {
    margin-top: 32px;
  }
}

.top-news-others__list .top-news-others__list-item + .top-news-others__list-item {
  border: none;
}

.top-news-others__link-text {
  color: #0000b3;
}
@media screen and (min-width: 768px) {
  .top-news-others__link-text {
  }
}

.top-social {
  margin-left: 4%;
  margin-right: 4%;
  margin-top: 48px;
  max-width: 92%;
}
@media screen and (min-width: 768px) {
  .top-social {
    margin-left: auto;
    margin-right: auto;
    max-width: 1242px;
  }
}

.top-social__inner {
  background-color: rgb(255 255 255 / 0.9);
  border-radius: 10px;
  box-shadow: 0 0 20px 0 rgb(0 0 0 / 0.2);
  padding: 8px 15px;
}
@media screen and (min-width: 768px) {
  .top-social__inner {
    background-color: rgb(255 255 255 / 0.9);
    padding: 24px;
  }
}

.top-social-list {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .top-social-list {
    flex-direction: row;
    justify-content: center;
  }
}

.top-social-list__item {
  padding: 16px 0;
}
@media screen and (min-width: 768px) {
  .top-social-list__item {
    align-items: center;
    display: flex;
    padding: 0 42px;
  }
}

.top-social-list__item + .top-social-list__item {
  border-top: 1px solid #ccc;
}
@media screen and (min-width: 768px) {
  .top-social-list__item + .top-social-list__item {
    border-left: 1px solid #ccc;
    border-top: none;
  }
}

.top-social-list__text {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.42;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .top-social-list__text {
    text-align: left;
  }
}

.top-social-icon-list {
  display: flex;
  justify-content: center;
  margin-top: 15px;
}
@media screen and (min-width: 768px) {
  .top-social-icon-list {
    margin-left: 32px;
    margin-top: 0;
  }
}

.top-social-icon-list__item {
  max-width: 40px;
}

.top-social-icon-list__item + .top-social-icon-list__item {
  margin-left: 24px;
}

.top-cp {
  margin-top: 48px;
}
@media screen and (min-width: 768px) {
  .top-cp {
  }
}

.top-cp__inner {
  margin-left: 4%;
  margin-right: 4%;
}
@media screen and (min-width: 768px) {
  .top-cp__inner {
    margin-left: 0;
    margin-right: 0;
  }
}

.top-footer {
  background-color: #08287f;
  height: auto;
  margin-top: 0;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .top-footer {
  }
}

.top-footer__img {
}
@media screen and (min-width: 768px) {
  .top-footer__img {
    margin-left: auto;
    margin-right: auto;
    max-width: 1242px;
  }
}

.top-skiplink {
  display: none;
}
@media screen and (min-width: 967px) {
  .top-skiplink {
    background-color: #000;
    display: block;
    left: -9999em;
    padding: 10px;
    position: absolute;
    top: 0;
  }

  .top-skiplink.is-show {
    left: 0;
    position: static;
  }
}
@media screen and (min-width: 768px) {
  .top-skiplink__list {
    display: flex;
    justify-content: center;
  }
}
@media screen and (min-width: 768px) {
  .top-skiplink__list-item + .top-skiplink__list-item {
    margin-left: 15px;
  }
}
@media screen and (min-width: 768px) {
  .top-skiplink__list-item-link {
    color: #fff;
    cursor: pointer;
    text-decoration: underline;
  }
}

.top-loading {
  background-color: #fff;
  height: 100%;
  left: 0;
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: 1920px !important;
  overflow: hidden;
  position: relative;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: -1;
}

@media screen and (min-width: 768px) {
  .top-loading {
    max-width: 100% !important;
  }
}

.js-top-loading {
  height: 100%;
  opacity: 1;
  overflow: hidden;
}

.top-rect1 {
  height: auto;
  mix-blend-mode: multiply;
  opacity: 0;
  overflow: hidden;
  padding-top: 100%;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 56lvh;
  transition: all 0.5s ease-out;
  width: 100%;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .top-rect1 {
    padding-top: 83%;
    top: -26.5%;
    width: 83%;
  }
}

.top-rect1.is-show,
.top-rect1.is-first {
  opacity: 1;
}

.top-rect2 {
  background-image: url(/common2024/images/bg_bluelink-full_sp.svg);
  background-position: top right;
  background-repeat: no-repeat;
  background-size: 100%;
  border: none;
  height: 100%;
  left: 0;
  mix-blend-mode: multiply;
  padding-top: 100%;
  position: absolute;
  top: 0;
  transform: rotate(0deg);
  transform-origin: bottom left;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .top-rect2 {
    /* animation: 1s ease-out 0.2s forwards bluelink; */
    background-image: url(/common2024/images/bg_bluelink_pc2.svg);
    background-position: 102% 0;
    background-size: 55%;
    padding-top: 130%;
    right: -17%;
    top: -16%;

    /* transform: rotate(-90deg); */
    width: 130%;
  }
}

.top-rect2::after {
  animation: 1s ease-out 0.75s forwards bluelink-grad-reverse;
  background: linear-gradient(270deg, rgb(255 255 255 / 0) 0%, rgb(255 255 255 / 1) 10%);
  background-size: 100%;
  border: none;
  bottom: 0;
  content: '';
  display: block;
  left: -20%;
  padding-top: 104%;
  position: absolute;
  transform: rotate(-90deg);
  transform-origin: bottom right;
  width: 120%;
}

.top-rect1.is-show .top-rect2::after {
  animation: 1s ease-out 0.5s forwards bluelink-grad;
  background: linear-gradient(0deg, rgb(255 255 255 / 0) 0%, rgb(255 255 255 / 1) 10%);
  transform: rotate(0deg);
}

.top-rect1.is-first .top-rect2::after {
  animation-delay: 1.2s;
}
@media screen and (min-width: 1000px) {
  .top-rect2::after {
    animation: 1s ease-out 0s forwards bluelink-grad-pc-reverse;
    background: linear-gradient(180deg, rgb(255 55 255 / 0) 0%, rgb(255 255 255 / 1) 20%);
    opacity: 1;
    transform: rotate(90deg);
    transform-origin: top left;
  }

  .top-rect1.is-show .top-rect2::after {
    animation: 2s ease-out 0.5s forwards bluelink-grad-pc;
    background: linear-gradient(90deg, rgb(255 55 255 / 0) 0%, rgb(255 255 255 / 1) 20%);
    opacity: 1;
    transform: rotate(0deg);
    padding-top: 140%;
    height: 140%;
  }
}
@media screen and (min-width: 768px) and (max-width: 999px) {
  .top-rect2::after {
    animation: 1s ease-out 0s forwards bluelink-grad-pc-reverse;
    background: linear-gradient(180deg, rgb(255 55 255 / 0) 0%, rgb(255 255 255 / 1) 20%);
    opacity: 1;
    padding-top: 119%;
    transform: rotate(90deg);
    transform-origin: top left;
  }

  .top-rect1.is-show .top-rect2::after {
    animation: 1s ease-out 0.5s forwards bluelink-grad-pc2;
    background: linear-gradient(90deg, rgb(255 55 255 / 0) 0%, rgb(255 255 255 / 1) 20%);
    opacity: 1;
    transform: rotate(-15deg);
  }
}

.top-rect1.is-first .top-rect2::after {
  animation-delay: 1.2s;
}
@media screen and (min-width: 768px) {
  .top-rect1 {
    top: -37.5%;
  }
}

@media screen and (min-width: 1350px) {
  .top-rect1 {
    right: 2%;
  }

  /* .top-rect2 {
    background-size: 82%;
  } */
}
@media screen and (min-width: 1200px) and (max-width: 1350px) {
  .top-rect1 {
    right: 1%;
  }

  /* .top-rect2 {
    background-size: 94%;
  } */
}
@media screen and (min-width: 1100px) and (max-width: 1200px) {
  .top-rect1 {
    right: 1%;
  }

  /* .top-rect2 {
    background-size: 92%;
  } */
}
@media screen and (min-width: 1000px) and (max-width: 1100px) {
  .top-rect1 {
    right: 1%;
  }

  /* .top-rect2 {
    background-size: 94%;
  } */
}
@media screen and (min-width: 900px) and (max-width: 1000px) {
  .top-rect1 {
    right: 1%;
  }

  /* .top-rect2 {
    background-size: 106%;
  } */
}
@media screen and (min-width: 768px) and (max-width: 900px) {
  .top-rect1 {
    right: 1%;
  }

  /* .top-rect2 {
    background-size: 112%;
  } */
}
@media screen and (min-width: 768px) {
  .top-rect1 {
    left: 0;
    margin: auto;
    max-width: 1366px;
    padding-top: 100vh;
    top: 0;
    width: 100%;
  }

  .top-rect2 {
    bottom: auto;
    left: 0;
    padding-top: 100%;
    right: 0;
    top: 0;

    /* transform: rotate(90deg); */
    width: 100%;
  }
}

@media screen and (min-width: 768px) and (max-width: 1366px) {
  .top-rect2 {
    background-size: 70%;
  }
}

/* @media screen and (min-width: 980px) and (max-width: 1080px) {
  .top-rect1 {
    right: -12.5%;
    top: -42%;
  }

  .top-rect2 {
    padding-top: 140%;
    width: 140%;
  }
} */

.top-rect3 {
  background-image: url(/top/images/top_bg_bluelink_01_sp.svg);
  background-position-y: 50px;
  background-repeat: no-repeat;
  background-size: 47.3%;
  border: none;
  mix-blend-mode: multiply;
  opacity: 0;
  padding-top: 100vh;
  position: fixed;
  top: 0;
  transition: all 0.5s ease-out;
  transition-delay: 0s;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .top-rect3 {
    background-image: url(/top/images/top_bg_bluelink_01_pc.svg);
    padding-top: 100%;
    top: -24%;
    background-size: 18.5%;
  }
}

.top-rect4 {
  background-image: url(/top/images/top_bg_bluelink_02_sp.svg);
  background-position: right;
  background-position-y: 330px;
  background-repeat: no-repeat;
  background-size: 77.3%;
  border: none;
  bottom: 0;
  mix-blend-mode: multiply;
  opacity: 0;
  padding-top: 100vh;
  position: fixed;
  transition: opacity 0.5s ease-out,background-position-y 0.5s ease-out;
  transition-delay: 0.75s;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .top-rect4 {
    background-image: url(/top/images/top_bg_bluelink_02_pc.svg);
    padding-top: 100vh;
    top: 0;
  }
}

.top-bg.is-show > .top-rect3 {
  background-position-y: 25px;
  opacity: 1;
  transition-delay: 1.5s;
}
@media screen and (min-width: 768px) {
  .top-bg.is-show > .top-rect3 {
    transition-delay: 1s;
  }
}

.top-bg.is-show > .top-rect4 {
  background-position-y: 315px;
  opacity: 1;
  transition-delay: 2.25s;
}
@media screen and (min-width: 768px) {
  .top-bg.is-show > .top-rect4 {
    transition-delay: 1.75s;
    background-size: 47.3%;
  }
}

/* rect3,4を即座に非表示にする */
.top-bg.hide-immd > .top-rect3,
.top-bg.hide-immd > .top-rect4 {
  opacity: 0;
  transition: all 0.1s;
}

.js-top-loading-header {
  animation: 0.5s ease-out 1.5s forwards top-header;
  opacity: 0;
}

.js-top-loading-cont {
  opacity: 0;
}

.top-keyvisual.js-top-loading-cont,
.important.js-top-loading-cont {
  animation: 0.5s ease-out 1.7s forwards top-keyvisual;
}

.top-pickupservice.js-top-loading-cont {
  animation: 0.5s ease-out 2s forwards top-pickupservice;
}

.top-firstitem {
  margin: auto;
  max-width: 100%;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .top-firstitem {
  }
}

.top-firstitem > * {
  margin-left: 4%;
  margin-right: 4%;
  margin-top: 16px;
  max-width: 92%;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .top-firstitem > * {
    margin-left: auto;
    margin-right: auto;
    max-width: 1242px;
  }
}

.top-seconditem {
  max-width: 100%;
  padding-bottom: 48px;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .top-seconditem {
  }
}

.top-seconditem > * {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .top-seconditem > * {
    margin-left: auto;
    margin-right: auto;
    max-width: 1242px;
  }
}

.top-seconditem > .top-bg {
  background-color: #fff;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: relative;
  top: 0;
  transition: all 0.5s ease-out;
  transition-delay: 1.5s;
  width: 100%;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .top-seconditem > .top-bg {
    bottom: 0;
    margin-left: 0;
    margin-right: 0;
    max-width: 100%;
    top: auto;
  }
}

.top-seconditem > .top-bg.is-show {
  opacity: 1;
  transition-delay: 0s;
}

/* Keyvisual
============================================ */
@keyframes bluelink {
  0% {
    opacity: 0;
    transform: rotate(145deg);
  }

  100% {
    opacity: 1;
    transform: rotate(90deg);
  }
}
@keyframes bluelink-grad {
  0% {
    /* width: 56%; */
    transform: rotate(0deg);
  }

  100% {
    /* width: 0; */
    transform: rotate(90deg);
  }
}
@keyframes bluelink-grad-reverse {
  0% {
    transform: rotate(-90deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

@keyframes bluelink-grad-pc {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(-115deg);
  }
}

@keyframes bluelink-grad-pc2 {
  0% {
    transform: rotate(-15deg);
  }

  100% {
    transform: rotate(-115deg);
  }
}

@keyframes bluelink-grad-pc-reverse {
  0% {
    transform: rotate(90deg);
  }

  100% {
    transform: rotate(-15deg);
  }
}

@keyframes top-header {
  0% {
    opacity: 0;
    transform: translateY(-140%);
  }

  100% {
    opacity: 1;
    transition: all 0.4s ease-out;
  }
}

@keyframes top-keyvisual {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes top-pickupservice {
  0% {
    opacity: 0;
    transform: translateY(25%);
  }

  100% {
    opacity: 1;
    transform: translateY(0%);
  }
}

@keyframes top-keyvisual-info {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

/* top override */
@media screen and (max-width: 767.9px) {
  .campaign-carousel {
    backdrop-filter: unset;
    background-color: rgb(255 255 255 / 0.9);
  }
}
