@charset "UTF-8";
.c-link-button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.c-link-button .text {
  font-weight: 500;
  -webkit-transition: color 0.3s ease;
  transition: color 0.3s ease;
}
.c-link-button .arrow {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 50%;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
.c-link-button .arrow-svg {
  display: block;
  -webkit-transform: translateX(8%);
      -ms-transform: translateX(8%);
          transform: translateX(8%);
  -webkit-transition: stroke 0.3s ease;
  transition: stroke 0.3s ease;
}
@media screen and (min-width: 769px) {
  .c-link-button {
    height: 35px;
    padding: 0 12px 0 16px;
    border-radius: 36px;
  }
  .c-link-button .text {
    font-size: 1.4rem;
  }
  .c-link-button .arrow {
    width: 20px;
    height: 20px;
    margin-left: 8px;
  }
  .c-link-button .arrow-svg {
    width: 6px;
    height: 10px;
  }
}
@media screen and (max-width: 768px) {
  .c-link-button .text {
    font-size: 3.7333333333vw;
  }
  .c-link-button .arrow {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
    margin-left: 2.1333333333vw;
  }
  .c-link-button .arrow-svg {
    width: 1.6vw;
    height: 2.6666666667vw;
  }
}

.c-link-card__link {
  overflow: hidden;
  display: block;
  position: relative;
  z-index: 0;
  height: 100%;
}
@media screen and (min-width: 769px) {
  .c-link-card__link:hover .c-link-card__image {
    -webkit-transform: scale(1.15);
        -ms-transform: scale(1.15);
            transform: scale(1.15);
  }
  .c-link-card__link:hover .c-link-card__content.light .push:hover .c-link-button-none, .c-link-card__link:hover .c-link-card__content.dark .push:hover .c-link-button-none {
    height: 35px;
    padding: 0 12px 0 16px;
    border-radius: 36px;
    background-color: rgba(255, 255, 255, 0.2);
  }
  .c-link-card__link:hover .c-link-card__content.light .c-link-button, .c-link-card__link:hover .c-link-card__content.dark .c-link-button {
    background-color: rgba(255, 255, 255, 0.2);
  }
  .c-link-card__link:hover .c-link-card__content.light .c-link-button-none, .c-link-card__link:hover .c-link-card__content.dark .c-link-button-none {
    background-color: transparent;
  }
}
.c-link-card__inner {
  height: 100%;
}
.c-link-card__image {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
  transition: transform 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.c-link-card__image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-link-card__content {
  position: relative;
  z-index: 0;
  height: 100%;
  color: #fff;
}
.c-link-card__content.light {
  background-color: rgba(30, 145, 209, 0.8);
}
.c-link-card__content.light .c-link-button .arrow {
  background-color: #fff;
}
.c-link-card__content.light .c-link-button .arrow-svg {
  stroke: #12305a;
}
.c-link-card__content.dark {
  background-color: rgba(18, 48, 90, 0.8);
}
.c-link-card__content.dark .c-link-button .arrow {
  background-color: #1e91d1;
}
.c-link-card__content.dark .c-link-button .arrow-svg {
  stroke: #fff;
}
.c-link-card__content .text {
  font-weight: 500;
  line-height: 1.71;
  text-align: justify;
}
.c-link-card__content .link-button {
  position: absolute;
}
@media screen and (min-width: 769px) {
  .c-link-card {
    height: 400px;
  }
  .c-link-card__inner {
    padding: 50px 80px;
  }
  .c-link-card__content {
    width: calc(50% - 40px);
    padding: 40px 48px;
    -webkit-box-shadow: 0 10px 25px 0 rgba(0, 0, 0, 0.4);
            box-shadow: 0 10px 25px 0 rgba(0, 0, 0, 0.4);
  }
  .c-link-card__content.right {
    margin: 0 0 0 auto;
  }
  .c-link-card__content .c-section-header {
    margin-bottom: 15px;
  }
  .c-link-card__content .text {
    font-size: 1.4rem;
  }
  .c-link-card__content .link-button {
    right: 28px;
    bottom: 30px;
  }
  .c-link-card__content .link-button-ja {
    bottom: 70px;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .c-link-card__inner {
    padding: 50px 40px;
  }
  .c-link-card__content {
    width: calc(50% - 20px);
    padding: 30px 35px;
  }
}
@media screen and (max-width: 768px) {
  .c-link-card {
    height: 100vw;
  }
  .c-link-card__inner {
    height: 100%;
    padding: 10.6666666667vw 6.4vw;
  }
  .c-link-card__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 10.6666666667vw;
    -webkit-box-shadow: 0 2.6666666667vw 6.6666666667vw 0 rgba(0, 0, 0, 0.4);
            box-shadow: 0 2.6666666667vw 6.6666666667vw 0 rgba(0, 0, 0, 0.4);
  }
  .c-link-card__content .c-section-header {
    margin-bottom: 4vw;
  }
  .c-link-card__content .text {
    font-size: 3.7333333333vw;
  }
  .c-link-card__content .link-button {
    right: 10.6666666667vw;
    bottom: 8vw;
  }
  .c-link-card__content .link-button-ja {
    bottom: 13.3333333333vw;
  }
  .c-link-card__content .link-button-el {
    bottom: 5.3333333333vw;
  }
}

.c-section-header__sub {
  font-family: "Lexend Deca", sans-serif;
  font-size: 1.7rem;
}
.c-section-header__heading {
  font-size: 4.4rem;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.01125em;
}
.c-section-header__heading span {
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .c-section-header__sub {
    font-size: 4.5333333333vw;
  }
  .c-section-header__heading {
    font-size: 8.5333333333vw;
  }
}

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
}
.page-top-hero {
  background-color: #000;
}
.page-top-hero__video {
  position: relative;
  z-index: 0;
  background-color: #000;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.page-top-hero__video video {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.page-top-hero__video::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.7)), color-stop(48%, rgba(0, 0, 0, 0.4)));
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.4) 48%);
  content: "";
}
.page-top-hero__content {
  color: #fff;
}
.page-top-hero__content .text-main span {
  overflow: hidden;
  display: block;
  text-indent: 100%;
  white-space: nowrap;
}
.page-top-hero__content .link-button .c-link-button {
  background-color: #fff;
  cursor: pointer;
}
.page-top-hero__content .link-button .c-link-button .text {
  color: #000;
}
.page-top-hero__content .link-button .c-link-button .arrow-svg {
  stroke: #fff;
}
@media screen and (min-width: 769px) {
  .page-top-hero {
    height: 100vh;
  }
  .page-top-hero__video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .page-top-hero__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
    z-index: 1;
    height: 100%;
    padding: 0 80px;
  }
  .page-top-hero__content .text-lead {
    margin-bottom: 45px;
    font-size: 1.3rem;
  }
  .page-top-hero__content .text-main {
    width: 600px;
    height: 125px;
    background: url(/assets/images/top/text_hero.svg) no-repeat 0 0/cover;
  }
  .page-top-hero__content .link-button {
    margin-top: 40px;
  }
  .page-top-hero__content .link-button .c-link-button {
    height: 32px;
  }
  .page-top-hero__content .link-button .c-link-button .arrow {
    background-color: #1e91d1;
  }
  .page-top-hero__content .link-button .c-link-button:hover {
    background-color: #1e91d1;
  }
  .page-top-hero__content .link-button .c-link-button:hover .text {
    color: #fff;
  }
  .page-top-hero__content .link-button .c-link-button:hover .arrow {
    background-color: #12305a;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .page-top-hero__inner {
    padding: 0 40px;
  }
}
@media screen and (max-width: 768px) {
  .page-top-hero {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-top: 16.5333333333vw;
  }
  .page-top-hero__video {
    padding-top: 56.25%;
  }
  .page-top-hero__video video {
    position: absolute;
    top: 0;
    left: 0;
  }
  .page-top-hero__inner {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 5.3333333333vw 6.4vw 21.3333333333vw;
  }
  .page-top-hero__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 100%;
  }
  .page-top-hero__content .text-lead {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin-top: 5.8666666667vw;
    font-size: 3.4666666667vw;
  }
  .page-top-hero__content .text-main {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    width: 81.0666666667vw;
    height: 46.4vw;
    background: url(/assets/images/top/text_hero_sp.svg) no-repeat 0 0/cover;
  }
  .page-top-hero__content .link-button {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    margin-top: 8.5333333333vw;
  }
  .page-top-hero__content .link-button .c-link-button {
    height: 6.9333333333vw;
    padding: 0 3.2vw;
    border-radius: 3.4666666667vw;
  }
  .page-top-hero__content .link-button .c-link-button .text {
    font-size: 3.2vw;
  }
  .page-top-hero__content .link-button .c-link-button .arrow {
    width: 4.2666666667vw;
    height: 4.2666666667vw;
    background-color: #12305a;
  }
  .page-top-hero__content .link-button .c-link-button .arrow-svg {
    width: 1.3333333333vw;
    height: 2.1333333333vw;
  }
}
.page-top-youtube {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 15000;
  width: 100%;
  height: 100%;
  background-color: #000;
  -webkit-animation: 0.6s fadeIn;
          animation: 0.6s fadeIn;
}
.page-top-youtube.is-hidden {
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  pointer-events: none;
}
.page-top-youtube__wrapper {
  position: relative;
  z-index: 0;
  width: 100%;
}
.page-top-youtube__wrapper iframe {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.page-top-youtube__button {
  position: absolute;
  z-index: 1;
}
.page-top-youtube__button .button {
  display: block;
  position: relative;
  cursor: pointer;
}
.page-top-youtube__button .button::before, .page-top-youtube__button .button::after {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  background-color: #fff;
  content: "";
}
.page-top-youtube__button .button::before {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.page-top-youtube__button .button::after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
@media screen and (min-width: 769px) and (min-aspect-ratio: 32/15) {
  .page-top-youtube__wrapper {
    height: 100%;
  }
}
@media screen and (min-width: 769px) and (max-aspect-ratio: 32/15) {
  .page-top-youtube__wrapper {
    aspect-ratio: 32/15;
  }
  @supports not (aspect-ratio: 32/15) {
    .page-top-youtube__wrapper {
      padding-top: 46.8755%;
    }
  }
}
@media screen and (min-width: 769px) {
  .page-top-youtube__button {
    top: 10px;
    right: 10px;
  }
  .page-top-youtube__button .button {
    width: 40px;
    height: 40px;
  }
  .page-top-youtube__button .button::before, .page-top-youtube__button .button::after {
    width: 32px;
    height: 1px;
  }
}
@media screen and (max-width: 768px) and (orientation: landscape) {
  .page-top-youtube__wrapper {
    height: 100%;
  }
}
@media screen and (max-width: 768px) and (orientation: portrait) {
  .page-top-youtube__wrapper {
    aspect-ratio: 16/9;
  }
  @supports not (aspect-ratio: 16/9) {
    .page-top-youtube__wrapper {
      padding-top: 56.25%;
    }
  }
}
@media screen and (max-width: 768px) {
  .page-top-youtube__button {
    top: 2.6666666667vw;
    right: 2.6666666667vw;
  }
  .page-top-youtube__button .button {
    width: 10.6666666667vw;
    height: 10.6666666667vw;
  }
  .page-top-youtube__button .button::before, .page-top-youtube__button .button::after {
    width: 8.5333333333vw;
    height: 0.2666666667vw;
  }
}
.page-top-vision {
  background-color: #f9f9f9;
}
.page-top-vision__content .text {
  font-weight: 500;
  line-height: 1.85;
  text-align: justify;
}
.page-top-vision__video .video-box {
  position: relative;
  z-index: 0;
  width: 100%;
  aspect-ratio: 16/9;
}
.page-top-vision__video .video-box__dummy, .page-top-vision__video .video-box__thumb {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
}
.page-top-vision__video .video-box__dummy img, .page-top-vision__video .video-box__thumb img {
  display: block;
}
.page-top-vision__video .video-box__thumb {
  cursor: pointer;
}
.page-top-vision__video .video-box__thumb img {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-filter: brightness(0.5);
          filter: brightness(0.5);
}
.page-top-vision__video .video-box__thumb::before {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 1;
  margin: auto;
  background: url(/assets/images/top/parts_play.svg) no-repeat 0 0/100%;
  content: "";
}
.page-top-vision .link-button {
  text-align: left;
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .page-top-vision .link-button {
    text-align: center;
    margin-top: 5.3333333333vw;
  }
}
.page-top-vision .link-button .c-link-button {
  height: 42px;
  background-color: #2990D0;
  color: #fff;
  padding: 0 12px 0 16px;
  -webkit-box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
          box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
}
@media screen and (max-width: 768px) {
  .page-top-vision .link-button .c-link-button {
    padding: 2.1333333333vw 3.2vw 2.1333333333vw 4.2666666667vw;
    border-radius: 50vh;
    height: auto;
  }
}
.page-top-vision .link-button .c-link-button:hover {
  opacity: 0.75;
}
@media screen and (min-width: 769px) {
  .page-top-vision .link-button .c-link-button .text {
    font-size: 1.6rem;
  }
}
.page-top-vision .link-button .c-link-button .arrow {
  background-color: #fff;
}
.page-top-vision .link-button .c-link-button .arrow-svg {
  stroke: #12305a;
}
@media screen and (min-width: 769px) {
  .page-top-vision {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 120px 80px;
  }
  .page-top-vision > * {
    min-width: 50%;
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
  }
  .page-top-vision__content {
    padding-right: 80px;
    /*.link-button {
      margin-top: 26px;
      margin-left: -16px;

      .c-link-button {
        &:hover {
          background-color: #e7e7e7;
        }
      }
    }*/
  }
  .page-top-vision__content .c-section-header {
    margin-bottom: 16px;
  }
  .page-top-vision__content .c-section-header__heading {
    font-family: "Lexend Deca", sans-serif;
    font-size: 4rem;
  }
  .page-top-vision__content .text {
    font-size: 1.3rem;
  }
  .page-top-vision__video .video-box__thumb img {
    -webkit-transition: -webkit-filter 0.3s ease;
    transition: -webkit-filter 0.3s ease;
    transition: filter 0.3s ease;
    transition: filter 0.3s ease, -webkit-filter 0.3s ease;
  }
  .page-top-vision__video .video-box__thumb:hover img {
    -webkit-filter: brightness(1);
            filter: brightness(1);
  }
  .page-top-vision__video .video-box__thumb::before {
    width: 110px;
    height: 110px;
  }
  .page-top-vision__video .video-box .irIndividual_movie {
    width: 100%;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .page-top-vision {
    padding-left: 40px;
    padding-right: 40px;
  }
  .page-top-vision__content {
    padding-right: 40px;
  }
}
@media screen and (max-width: 1024px) and (min-width: 769px) {
  .page-top-vision {
    display: block;
  }
  .page-top-vision > * {
    max-width: none;
  }
  .page-top-vision__content {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 768px) {
  .page-top-vision {
    padding: 21.3333333333vw 6.4vw 18.6666666667vw;
  }
  .page-top-vision__content .c-section-header {
    display: none;
    margin-bottom: 5.3333333333vw;
  }
  .page-top-vision__content .text {
    font-size: 3.7333333333vw;
  }
  .page-top-vision__video {
    margin-top: 5.3333333333vw;
  }
  .page-top-vision__video .video-box {
    width: 100%;
  }
  .page-top-vision__video .video-box .irIndividual_movie {
    width: 100%;
  }
  .page-top-vision__video .video-box__thumb::before {
    width: 20.2666666667vw;
    height: 20.2666666667vw;
  }
  .page-top-vision__video .link-button {
    margin-top: 5.3333333333vw;
    text-align: right;
  }
}
.page-top-service__content .service-item {
  display: block;
}
.page-top-service__content .service-item--left {
  background-color: #1e91d1;
  color: #fff;
}
.page-top-service__content .service-item--left .link-button .c-link-button .arrow {
  background-color: #fff;
}
.page-top-service__content .service-item--left .link-button .c-link-button .arrow-svg {
  stroke: #12305a;
}
.page-top-service__content .service-item--center {
  background-color: #1e91d1;
  color: #fff;
}
.page-top-service__content .service-item--center .link-button .c-link-button .arrow {
  background-color: #fff;
}
.page-top-service__content .service-item--center .link-button .c-link-button .arrow-svg {
  stroke: #12305a;
}
.page-top-service__content .service-item--center-02 {
  background-color: #6ab2de;
  color: #fff;
}
.page-top-service__content .service-item--center-02 .c-link-button .arrow {
  background-color: #1e91d1;
}
.page-top-service__content .service-item--center-02 .c-link-button .arrow-svg {
  stroke: #fff;
}
.page-top-service__content .service-item--center-03 {
  background-color: #60d7ff;
  color: #fff;
}
.page-top-service__content .service-item--center-03 .c-link-button .arrow {
  background-color: #fff;
}
.page-top-service__content .service-item--center-03 .c-link-button .arrow-svg {
  stroke: #12305a;
}
.page-top-service__content .service-item--right {
  background-color: #eef9ff;
}
.page-top-service__content .service-item--right .link-button .c-link-button .arrow {
  background-color: #1e91d1;
}
.page-top-service__content .service-item--right .link-button .c-link-button .arrow-svg {
  stroke: #fff;
}
.page-top-service__content .service-item--right-02 {
  background-color: #bbeeff;
}
.page-top-service__content .service-item--right-02 .link-button .c-link-button .arrow {
  background-color: #1e91d1;
}
.page-top-service__content .service-item--right-02 .link-button .c-link-button .arrow-svg {
  stroke: #fff;
}
.page-top-service__content .service-item--left-02 {
  background-color: #00bfff;
  color: #fff;
}
.page-top-service__content .service-item--left-02 .link-button .c-link-button .text {
  color: #fff;
}
.page-top-service__content .service-item--left-02 .link-button .c-link-button .arrow {
  background-color: #fff;
}
.page-top-service__content .service-item--left-02 .link-button .c-link-button .arrow-svg {
  stroke: #00bfff;
}
.page-top-service__content .service-item__header {
  text-align: center;
}
.page-top-service__content .service-item__header .sub {
  color: #fff;
  font-weight: 500;
}
.page-top-service__content .service-item__header .c-black {
  color: #000;
}
.page-top-service__content .service-item__header .heading {
  font-weight: 500;
}
.page-top-service__content .service-item__header .heading span {
  display: inline-block;
}
.page-top-service__content .service-item__header .heading--image {
  padding: 0;
}
.page-top-service__content .service-item__header .heading--image img {
  vertical-align: bottom;
}
.page-top-service__content .service-item__list .text {
  font-weight: 500;
  line-height: 1.71;
}
.page-top-service__content .service-item__image {
  text-align: center;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.page-top-service__content .service-item__image img {
  vertical-align: bottom;
}
.page-top-service__content .service-item__content .text {
  font-weight: 500;
  line-height: 1.71;
  text-align: justify;
}
.page-top-service__content .service-item__content .link-button {
  text-align: right;
}
@media screen and (min-width: 769px) {
  .page-top-service {
    padding-top: 100px;
  }
  .page-top-service .c-section-header {
    margin-bottom: 40px;
    padding: 0 80px;
  }
  .page-top-service__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .page-top-service__content .service-item {
    position: relative;
    z-index: 1;
    max-width: 33.33%;
    -ms-flex-preferred-size: 33.33%;
        flex-basis: 33.33%;
    padding: 40px 30px 82px;
    -webkit-transition: z-index 0.3s ease;
    transition: z-index 0.3s ease;
  }
  .page-top-service__content .service-item::after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    content: "";
    pointer-events: none;
    -webkit-transition-property: -webkit-box-shadow, -webkit-transform;
    transition-property: -webkit-box-shadow, -webkit-transform;
    transition-property: box-shadow, transform;
    transition-property: box-shadow, transform, -webkit-box-shadow, -webkit-transform;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
            transition-timing-function: ease;
  }
  .page-top-service__content .service-item:hover {
    z-index: 10;
    -webkit-transition: none;
    transition: none;
  }
  .page-top-service__content .service-item:hover::after {
    -webkit-box-shadow: 4px 10px 14px 0 rgba(0, 0, 0, 0.2);
            box-shadow: 4px 10px 14px 0 rgba(0, 0, 0, 0.2);
    -webkit-transform: scale(1.0125, 1.03);
        -ms-transform: scale(1.0125, 1.03);
            transform: scale(1.0125, 1.03);
  }
  .page-top-service__content .service-item--left::after {
    background-color: #1e91d1;
    -webkit-transform-origin: 0 50%;
        -ms-transform-origin: 0 50%;
            transform-origin: 0 50%;
  }
  .page-top-service__content .service-item--left:hover .link-button .c-link-button {
    background-color: #fff;
  }
  .page-top-service__content .service-item--left:hover .link-button .c-link-button .text {
    color: #000;
  }
  .page-top-service__content .service-item--left:hover .link-button .c-link-button .arrow {
    background-color: #12305a;
  }
  .page-top-service__content .service-item--left:hover .link-button .c-link-button .arrow-svg {
    stroke: #fff;
  }
  .page-top-service__content .service-item--center-02::after {
    background-color: #6ab2de;
    -webkit-transform-origin: 100% 50%;
        -ms-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
  }
  .page-top-service__content .service-item--center-02:hover .link-button .c-link-button {
    background-color: #1e91d1;
  }
  .page-top-service__content .service-item--center-02:hover .link-button .c-link-button .text {
    color: #fff;
  }
  .page-top-service__content .service-item--center-02:hover .link-button .c-link-button .arrow {
    background-color: #fff;
  }
  .page-top-service__content .service-item--center-02:hover .link-button .c-link-button .arrow-svg {
    stroke: #12305a;
  }
  .page-top-service__content .service-item--center-03::after {
    background-color: #60d7ff;
    -webkit-transform-origin: 100% 50%;
        -ms-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
  }
  .page-top-service__content .service-item--center-03:hover .link-button .c-link-button {
    background-color: #fff;
  }
  .page-top-service__content .service-item--center-03:hover .link-button .c-link-button .text {
    color: #000;
  }
  .page-top-service__content .service-item--center-03:hover .link-button .c-link-button .arrow {
    background-color: #60d7ff;
  }
  .page-top-service__content .service-item--center-03:hover .link-button .c-link-button .arrow-svg {
    stroke: #fff;
  }
  .page-top-service__content .service-item--right::after {
    background-color: #eef9ff;
    -webkit-transform-origin: 100% 50%;
        -ms-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
  }
  .page-top-service__content .service-item--right:hover .link-button .c-link-button {
    background-color: #1e91d1;
  }
  .page-top-service__content .service-item--right:hover .link-button .c-link-button .text {
    color: #fff;
  }
  .page-top-service__content .service-item--right:hover .link-button .c-link-button .arrow {
    background-color: #fff;
  }
  .page-top-service__content .service-item--right:hover .link-button .c-link-button .arrow-svg {
    stroke: #12305a;
  }
  .page-top-service__content .service-item--right-02::after {
    background-color: #bbeeff;
    -webkit-transform-origin: 100% 50%;
        -ms-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
  }
  .page-top-service__content .service-item--right-02:hover .link-button .c-link-button {
    background-color: #1e91d1;
  }
  .page-top-service__content .service-item--right-02:hover .link-button .c-link-button .text {
    color: #fff;
  }
  .page-top-service__content .service-item--right-02:hover .link-button .c-link-button .arrow {
    background-color: #fff;
  }
  .page-top-service__content .service-item--right-02:hover .link-button .c-link-button .arrow-svg {
    stroke: #12305a;
  }
  .page-top-service__content .service-item--left-02::after {
    background-color: #00bfff;
    -webkit-transform-origin: 0 50%;
        -ms-transform-origin: 0 50%;
            transform-origin: 0 50%;
  }
  .page-top-service__content .service-item--left-02:hover .link-button .c-link-button {
    background-color: #fff;
  }
  .page-top-service__content .service-item--left-02:hover .link-button .c-link-button .text {
    color: #000;
  }
  .page-top-service__content .service-item--left-02:hover .link-button .c-link-button .arrow {
    background-color: #00bfff;
  }
  .page-top-service__content .service-item--left-02:hover .link-button .c-link-button .arrow-svg {
    stroke: #fff;
  }
  .page-top-service__content .service-item__header .sub {
    margin-bottom: 2px;
    font-size: 1.4rem;
  }
  .page-top-service__content .service-item__header .heading {
    padding: 2px 0 1px;
    font-size: 3.4rem;
  }
  .page-top-service__content .service-item__header .heading--image img {
    width: 264px;
  }
  .page-top-service__content .service-item__header .heading--image .img_sub {
    width: 280px;
    vertical-align: sub;
  }
  .page-top-service__content .service-item__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    margin-top: 24px;
  }
  .page-top-service__content .service-item__list .text {
    width: 54%;
    font-size: 0.8333333333vw;
    padding: 0 0 1em;
  }
  .page-top-service__content .service-item__image {
    width: 46%;
  }
  .page-top-service__content .service-item__content {
    margin-top: 0;
  }
  .page-top-service__content .service-item__content .text {
    font-size: 1.4rem;
  }
  .page-top-service__content .service-item__content .link-button {
    position: absolute;
    bottom: 32px;
    right: 30px;
  }
}
@media screen and (min-width: 1441px) {
  .page-top-service__content .service-item__list .text {
    font-size: 1.32rem;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .page-top-service .c-section-header {
    padding: 0 40px;
  }
  .page-top-service__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .page-top-service__content .service-item {
    padding-left: 20px;
    padding-right: 20px;
  }
  .page-top-service__content .service-item__header .heading {
    padding: 8px 0;
  }
  .page-top-service__content .service-item__header .heading--image {
    padding: 2px 0 1px;
  }
  .page-top-service__content .service-item__header .heading--image img {
    width: 264px;
  }
  .page-top-service__content .service-item__image img {
    width: 100%;
  }
}
@media screen and (max-width: 1024px) and (min-width: 769px) {
  .page-top-service__content {
    display: block;
  }
  .page-top-service__content .service-item {
    max-width: none;
  }
  .page-top-service__content .service-item__list .text {
    font-size: 1.6rem;
  }
  .page-top-service__content .service-item:hover::after {
    -webkit-transform: scaleY(1.02);
        -ms-transform: scaleY(1.02);
            transform: scaleY(1.02);
  }
}
@media screen and (max-width: 768px) {
  .page-top-service {
    padding-top: 21.3333333333vw;
  }
  .page-top-service .c-section-header {
    margin-bottom: 12vw;
    padding: 0 6.4vw;
  }
  .page-top-service__content .service-item {
    padding: 16vw 0 16vw;
  }
  .page-top-service__content .service-item:nth-of-type(n+4) .heading--image img {
    width: 71.4666666667vw;
  }
  .page-top-service__content .service-item__header .sub {
    margin-bottom: 2.1333333333vw;
    font-size: 3.7333333333vw;
  }
  .page-top-service__content .service-item__header .heading {
    padding: 1.3333333333vw 0;
    font-size: 9.0666666667vw;
    line-height: 1.2;
  }
  .page-top-service__content .service-item__header .heading--image {
    padding: 0.5333333333vw 0 0.2666666667vw;
  }
  .page-top-service__content .service-item__header .heading--image img {
    width: 80vw;
  }
  .page-top-service__content .service-item__list {
    margin-top: 4.2666666667vw;
    padding: 0 6.4vw;
  }
  .page-top-service__content .service-item__list .text {
    font-size: 3.7333333333vw;
    margin-top: -2.6666666667vw;
  }
  .page-top-service__content .service-item__image img {
    width: 100%;
  }
  .page-top-service__content .service-item__content {
    padding: 0 6.4vw;
  }
  .page-top-service__content .service-item__content .text {
    font-size: 3.7333333333vw;
  }
  .page-top-service__content .service-item__content .link-button {
    margin-top: 5.3333333333vw;
  }
}
.page-top-news__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.page-top-news__nav .nav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.page-top-news__nav .nav-list__cate {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  -webkit-transition-property: color, background-color;
  transition-property: color, background-color;
  -webkit-transition-duration: 0.25s;
          transition-duration: 0.25s;
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
}
.page-top-news__nav .nav-list__cate.is-current {
  color: #fff;
  background-color: #1e91d1;
  pointer-events: none;
}
.page-top-news__nav .link-button .c-link-button .arrow {
  background-color: #1e91d1;
}
.page-top-news__nav .link-button .c-link-button .arrow-svg {
  stroke: #fff;
}
@media screen and (min-width: 769px) {
  .page-top-news__nav .link-button .c-link-button:hover {
    background-color: #e7e7e7;
  }
}
.page-top-news__list .news-list__link {
  display: block;
}
.page-top-news__list .news-list__link .cate {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 0.4em;
  color: #1e91d1;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.page-top-news__list .news-list__link .title {
  font-weight: bold;
  line-height: 1.56;
  letter-spacing: 0.05em;
  text-align: justify;
}
.page-top-news__list .news-list__link .date {
  display: block;
  color: #1e91d1;
  font-family: "Lexend Deca", sans-serif;
  letter-spacing: 0.0886em;
}
@media screen and (min-width: 769px) {
  .page-top-news {
    padding: 120px 80px 80px;
  }
  .page-top-news .c-section-header {
    margin-bottom: 24px;
  }
  .page-top-news__nav {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 10px;
  }
  .page-top-news__nav .nav-list {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1.3rem;
  }
  .page-top-news__nav .nav-list__cate {
    height: 28px;
    padding: 0 10px;
    border-radius: 14px;
  }
  .page-top-news__nav .nav-list__cate:hover:not(.is-current) {
    color: #000;
    background-color: #e7e7e7;
  }
  .page-top-news__nav .nav-list__cate:not(:first-child) {
    margin-left: 8px;
  }
  .page-top-news__nav .nav-list__link {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-left: 18px;
    text-decoration: underline;
    -webkit-transition: color 0.2s ease;
    transition: color 0.2s ease;
  }
  .page-top-news__nav .nav-list__link:hover {
    color: #1e91d1;
  }
  .page-top-news__nav .nav-list__link .icon {
    margin-left: 4px;
  }
  .page-top-news__nav .nav-list__link .icon-svg {
    display: block;
    width: 14px;
    height: 14px;
  }
  .page-top-news__nav .nav-list__link .icon-svg path {
    fill: currentColor;
  }
  .page-top-news__nav .link-button {
    margin-right: -12px;
  }
  .page-top-news__list {
    margin: 0 -40px;
    padding: 20px 0;
  }
  .page-top-news__list .news-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .page-top-news__list .news-list__item {
    max-width: 25%;
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
  }
  .page-top-news__list .news-list__item:not(:first-child) {
    border-left: 1px solid #cdcdcd;
  }
  .page-top-news__list .news-list__item:nth-child(4) ~ * {
    display: none;
  }
  .page-top-news__list .news-list__link {
    position: relative;
    z-index: 0;
    height: calc(100% + 40px);
    margin: -20px 0;
    padding: 20px 40px;
  }
  .page-top-news__list .news-list__link::after {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: -1px;
    right: -1px;
    z-index: -1;
    background-color: #fff;
    opacity: 0;
    pointer-events: none;
    content: "";
    -webkit-transition-property: opacity, -webkit-box-shadow;
    transition-property: opacity, -webkit-box-shadow;
    transition-property: box-shadow, opacity;
    transition-property: box-shadow, opacity, -webkit-box-shadow;
    -webkit-transition-duration: 0.3s;
            transition-duration: 0.3s;
    -webkit-transition-timing-function: ease;
            transition-timing-function: ease;
  }
  .page-top-news__list .news-list__link:hover::after {
    -webkit-box-shadow: 4px 7px 14px 0 rgba(0, 0, 0, 0.2);
            box-shadow: 4px 7px 14px 0 rgba(0, 0, 0, 0.2);
    opacity: 1;
  }
  .page-top-news__list .news-list__link .cate {
    margin-bottom: 18px;
    border: 1px solid currentColor;
    font-size: 1.1rem;
  }
  .page-top-news__list .news-list__link .title {
    font-size: 1.8rem;
  }
  .page-top-news__list .news-list__link .date {
    margin-top: 40px;
    font-size: 1.4rem;
  }
  .page-top-news__bottom {
    display: none;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .page-top-news {
    overflow: hidden;
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media screen and (max-width: 1024px) and (min-width: 769px) {
  .page-top-news__list .news-list {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .page-top-news__list .news-list__item {
    max-width: 33.3333333333%;
    -ms-flex-preferred-size: 33.3333333333%;
        flex-basis: 33.3333333333%;
  }
  .page-top-news__list .news-list__item:nth-child(3) ~ * {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .page-top-news {
    padding: 21.3333333333vw 6.4vw 26.6666666667vw;
  }
  .page-top-news .c-section-header {
    margin-bottom: 4vw;
  }
  .page-top-news__nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    margin-bottom: 8vw;
  }
  .page-top-news__nav .nav-list {
    font-size: 3.4666666667vw;
  }
  .page-top-news__nav .nav-list__cate {
    height: 7.4666666667vw;
    padding: 0 2.6666666667vw;
    border-radius: 3.7333333333vw;
  }
  .page-top-news__nav .nav-list__cate:not(:first-child) {
    margin-left: 2.1333333333vw;
  }
  .page-top-news__nav .nav-list__cate:not(.is-current) {
    color: #606060;
  }
  .page-top-news__nav .nav-list__link {
    display: none;
  }
  .page-top-news__nav .link-button {
    margin-bottom: 16vw;
  }
  .page-top-news__list .news-list__item {
    border-bottom: 1px solid #cdcdcd;
  }
  .page-top-news__list .news-list__item:first-child {
    border-top: 1px solid #cdcdcd;
  }
  .page-top-news__list .news-list__item:nth-child(2) ~ * {
    display: none;
  }
  .page-top-news__list .news-list__link {
    padding: 8vw 0;
  }
  .page-top-news__list .news-list__link .cate {
    margin-bottom: 2.6666666667vw;
    border: 0.2666666667vw solid currentColor;
    font-size: 2.9333333333vw;
  }
  .page-top-news__list .news-list__link .title {
    font-size: 4.8vw;
  }
  .page-top-news__list .news-list__link .date {
    margin-top: 6.6666666667vw;
    font-size: 3.7333333333vw;
  }
  .page-top-news__bottom {
    margin-top: 8vw;
    text-align: right;
  }
  .page-top-news__bottom a {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 3.4666666667vw;
    text-decoration: underline;
  }
  .page-top-news__bottom a::after {
    margin-left: 0.8vw;
    width: 3.7333333333vw;
    height: 3.7333333333vw;
    background: url(/assets/images/common/parts_blank.svg) no-repeat 0 0/cover;
    content: "";
  }
}
@media screen and (min-width: 769px) {
  .page-top-cm {
    padding: 100px 80px 20px;
  }
  .page-top-cm .c-section-header {
    margin-bottom: 45px;
  }
  .page-top-cm__list .top_bnr {
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
    -webkit-box-shadow: 4px 10px 14px 0 rgba(0, 0, 0, 0.15);
            box-shadow: 4px 10px 14px 0 rgba(0, 0, 0, 0.15);
  }
  .page-top-cm__list .top_bnr:hover {
    -webkit-transform: scale(1.05);
        -ms-transform: scale(1.05);
            transform: scale(1.05);
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  }
  .page-top-cm__list .top_bnr a img {
    width: 100%;
    vertical-align: middle;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .page-top-cm {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media screen and (max-width: 768px) {
  .page-top-cm {
    padding: 21.3333333333vw 6.4vw 0;
  }
  .page-top-cm .c-section-header {
    margin-bottom: 8vw;
  }
}
.page-top-media__list .item-link {
  display: block;
}
.page-top-media__list .item-image {
  position: relative;
  z-index: 0;
}
.page-top-media__list .item-image img {
  display: block;
  width: 100%;
}
.page-top-media__list .item-content {
  position: relative;
  z-index: 1;
}
.page-top-media__list .item-content .sub {
  font-weight: bold;
  letter-spacing: 0.05em;
}
.page-top-media__list .item-content .title {
  font-family: "Lexend Deca", sans-serif;
  font-weight: normal;
}
.page-top-media__list .item-content .title_jp {
  font-family: inherit;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .page-top-media {
    padding: 80px 80px 100px;
  }
  .page-top-media .c-section-header {
    margin-bottom: 45px;
  }
  .page-top-media__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .page-top-media__list .item-link {
    width: calc(50% - 40px);
  }
  .page-top-media__list .item-link:nth-of-type(n+3) {
    margin-top: 40px;
  }
  .page-top-media__list .item-link:hover .item-image {
    -webkit-transform: scale(1.08);
        -ms-transform: scale(1.08);
            transform: scale(1.08);
  }
  .page-top-media__list .item-image {
    margin-bottom: 20px;
    -webkit-box-shadow: 4px 10px 14px 0 rgba(0, 0, 0, 0.15);
            box-shadow: 4px 10px 14px 0 rgba(0, 0, 0, 0.15);
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease, -webkit-transform 0.3s ease;
  }
  .page-top-media__list .item-content .sub {
    font-size: 1.4rem;
  }
  .page-top-media__list .item-content .title {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .page-top-media {
    padding-left: 40px;
    padding-right: 40px;
  }
  .page-top-media__list .item-link:not(:first-child) {
    margin-left: 40px;
  }
  .page-top-media__list .item-content .title {
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 768px) {
  .page-top-media {
    padding: 18.6666666667vw 6.4vw 37.3333333333vw;
  }
  .page-top-media .c-section-header {
    margin-bottom: 8vw;
  }
  .page-top-media__list .item-link:not(:first-child) {
    margin-top: 20vw;
  }
  .page-top-media__list .item-image {
    margin-bottom: 8vw;
    -webkit-box-shadow: 0 2.6666666667vw 6.6666666667vw 0 rgba(0, 0, 0, 0.15);
            box-shadow: 0 2.6666666667vw 6.6666666667vw 0 rgba(0, 0, 0, 0.15);
  }
  .page-top-media__list .item-content .sub {
    font-size: 3.7333333333vw;
  }
  .page-top-media__list .item-content .title {
    font-size: 7.7333333333vw;
  }
}
.page-top-banner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 5000;
  width: 100%;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
.page-top-banner:not(.is-visible) {
  opacity: 0;
  pointer-events: none;
}
.page-top-banner .service-item {
  max-width: 48%;
  -ms-flex-preferred-size: 48%;
      flex-basis: 48%;
}
@media screen and (min-width: 769px) {
  .page-top-banner {
    height: 80px;
  }
  .page-top-banner .service-item {
    position: relative;
    z-index: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .page-top-banner .service-item--left {
    background-color: #1e91d1;
    color: #fff;
  }
  .page-top-banner .service-item--left .c-link-button .arrow {
    background-color: #fff;
  }
  .page-top-banner .service-item--left .c-link-button .arrow-svg {
    stroke: #12305a;
  }
  .page-top-banner .service-item--center {
    background-color: #6ab2de;
  }
  .page-top-banner .service-item--center .c-link-button .arrow {
    background-color: #fff;
  }
  .page-top-banner .service-item--center .c-link-button .arrow-svg {
    stroke: #12305a;
  }
  .page-top-banner .service-item--center-02 {
    background-color: #6ab2de;
  }
  .page-top-banner .service-item--center-02 .c-link-button .arrow {
    background-color: #1e91d1;
  }
  .page-top-banner .service-item--center-02 .c-link-button .arrow-svg {
    stroke: #fff;
  }
  .page-top-banner .service-item--right {
    background-color: #fff;
  }
  .page-top-banner .service-item--right .c-link-button .arrow {
    background-color: #1e91d1;
  }
  .page-top-banner .service-item--right .c-link-button .arrow-svg {
    stroke: #fff;
  }
  .page-top-banner .service-item--left-02 {
    background-color: #00bfff;
    color: #fff;
  }
  .page-top-banner .service-item--left-02 .c-link-button .arrow {
    background-color: #fff;
  }
  .page-top-banner .service-item--left-02 .c-link-button .arrow-svg {
    stroke: #00bfff;
  }
  .page-top-banner .service-item__image img {
    margin-bottom: 15px;
    width: 145px;
  }
  .page-top-banner .service-item .marunage {
    width: 160px;
  }
  .page-top-banner .service-item__content .text {
    display: inline-block;
    font-size: 1.3rem;
    font-weight: 500;
    letter-spacing: 0.0669em;
    border-bottom: 4px solid #ffff0c;
    width: 162px;
    margin-bottom: 3px;
    letter-spacing: 0px;
  }
  .page-top-banner .service-item__content .text span {
    font-size: 1.4rem;
    font-weight: bold;
  }
  .page-top-banner .service-item__content .image {
    margin-top: 1px;
  }
  .page-top-banner .service-item__content .image img {
    display: block;
  }
  .page-top-banner .service-item__content .image_02 {
    margin-top: 2px;
  }
  .page-top-banner .service-item__content .title {
    margin-top: 4px;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.27;
  }
  .page-top-banner .service-item .c-link-button {
    position: absolute;
    right: 16px;
    bottom: 12px;
    height: auto;
    padding: 0;
  }
  .page-top-banner .service-item .c-link-button .text {
    font-size: 1.2rem;
  }
  .page-top-banner .service-item .c-link-button .arrow {
    width: 16px;
    height: 16px;
  }
  .page-top-banner .service-item .c-link-button .arrow-svg {
    width: 5px;
    height: 8px;
  }
}
@media screen and (max-width: 1024px) and (min-width: 769px) {
  .page-top-banner .service-item .c-link-button {
    bottom: 8px;
  }
}
@media screen and (max-width: 1300px) and (min-width: 1201px) {
  .page-top-banner .service-item {
    padding-right: 60px;
  }
}
@media screen and (max-width: 1199px) and (min-width: 769px) {
  .page-top-banner .c-link-button .text {
    display: none;
  }
}
@media screen and (max-width: 1024px) and (min-width: 769px) {
  .page-top-banner {
    height: 64px;
  }
  .page-top-banner .service-item__image {
    margin-left: -20px;
  }
  .page-top-banner .service-item__image img {
    display: none;
  }
  .page-top-banner .service-item__content .text {
    font-size: 1.3rem;
  }
  .page-top-banner .service-item__content .text span {
    font-size: 1.4rem;
  }
  .page-top-banner .service-item__content .image_02 {
    margin-top: 0;
  }
  .page-top-banner .service-item__content .title {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .page-top-banner {
    padding: 2.6666666667vw;
    background-color: #12305a;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 10px;
  }
  .page-top-banner .service-item {
    overflow: hidden;
    border-radius: 1.0666666667vw;
    background-color: #fff;
    text-align: center;
    position: relative;
  }
  .page-top-banner .service-item__image {
    display: none;
  }
  .page-top-banner .service-item__content .text {
    display: none;
  }
  .page-top-banner .service-item__content .image {
    padding: 2.6666666667vw 0 2.6666666667vw 5.3333333333vw;
  }
  .page-top-banner .service-item__content .image img {
    display: block;
    width: 26.6666666667vw;
  }
  .page-top-banner .service-item__content .image img.marunage {
    width: 32vw;
  }
  .page-top-banner .service-item__content .image .arrow {
    display: inline-block;
    width: 3.2vw;
    height: 3.2vw;
    background-color: #1e91d1;
    margin-left: 1.0666666667vw;
  }
  .page-top-banner .service-item__content .image .arrow-svg {
    width: 1.0666666667vw;
    height: 1.8666666667vw;
    stroke: #fff;
  }
  .page-top-banner .service-item__content .title {
    margin: 1.0666666667vw 0 0.2666666667vw;
    font-size: 3.4666666667vw;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.0769em;
  }
  .page-top-banner .service-item__content .title span {
    display: inline-block;
  }
  .page-top-banner .service-item .c-link-button {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 4%;
  }
  .page-top-banner .service-item .c-link-button .button_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .page-top-banner .service-item .c-link-button .button_flex p {
    font-size: 2.6666666667vw;
    font-weight: bold;
  }
  .page-top-banner .service-item .c-link-button .text {
    font-size: 2.6666666667vw;
  }
  .page-top-banner .service-item .c-link-button .arrow {
    width: 3.2vw;
    height: 3.2vw;
    background-color: #1e91d1;
    margin-left: 1.0666666667vw;
  }
  .page-top-banner .service-item .c-link-button .arrow-svg {
    width: 1.0666666667vw;
    height: 1.8666666667vw;
    stroke: #fff;
  }
}
@media screen and (max-width: 768px) {
  .page-top #n_outline .video_area {
    margin-top: 8vw;
  }
}
.page-top #n_outline .video_area .ft-movie_inr .modal_btn {
  display: block;
  position: relative;
}
.page-top #n_outline .video_area .ft-movie_inr .modal_btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100px;
  height: 60px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.6);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.page-top #n_outline .video_area .ft-movie_inr .modal_btn::after {
  content: "▶";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-size: 26px;
  color: #fff;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.page-top #n_outline .video_area .ft-movie_inr:hover .modal_btn::before {
  background: #ff0400;
}
.page-top #n_outline .video_area .ft-movie_inr:hover .modal_btn::after {
  color: white;
}
.page-top #n_outline .video_area .ft-movie_inr .modal_btn {
  display: block;
  position: relative;
}
.page-top #n_outline .video_area .ft-movie_inr .modal_btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100px;
  height: 60px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.6);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.page-top #n_outline .video_area .ft-movie_inr .modal_btn::after {
  content: "▶";
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  font-size: 26px;
  color: #fff;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.page-top #n_outline .modal_open {
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.page-top #n_outline .modal_open img {
  max-width: 100%;
  width: auto;
}
@media screen and (max-width: 768px) {
  .page-top #n_outline .modal_open .btn.left {
    display: none;
  }
}
.page-top #n_outline #modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 10000;
}
.page-top #n_outline #modal .modal_mask {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 10;
  background-color: rgba(0, 0, 0, 0.85);
}
.page-top #n_outline #modal .modal_wrap {
  position: absolute;
  width: 80%;
  height: 90%;
  top: 0;
  left: 30px;
  right: 30px;
  bottom: 0;
  z-index: 200;
  margin: auto;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 40px 0;
  background: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (max-width: 640px) {
  .page-top #n_outline #modal .modal_wrap {
    width: 90%;
    height: 40%;
    left: 0;
    right: 0;
  }
}
.page-top #n_outline #modal .modal_wrap .modal_content {
  width: 80%;
  height: 100%;
  overflow: auto;
  display: none;
}
@media screen and (max-width: 768px) {
  .page-top #n_outline #modal .modal_wrap .modal_content {
    height: auto;
  }
}
.page-top #n_outline #modal .modal_wrap .modal_content .inner {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.page-top #n_outline #modal .modal_wrap .modal_content .modal_video {
  max-width: 1100px;
  height: 75%;
}
@media screen and (max-width: 768px) {
  .page-top #n_outline #modal .modal_wrap .modal_content .modal_video {
    height: auto;
    width: 100%;
  }
}
.page-top #n_outline #modal .modal_wrap .modal_content h3 {
  font-size: 2rem;
  text-align: center;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .page-top #n_outline #modal .modal_wrap .modal_content h3 {
    font-size: 1.6rem;
    line-height: 1.4;
    margin-bottom: 2rem;
  }
}
.page-top #n_outline #modal .modal_wrap .modal_close_btn {
  display: block;
  position: absolute;
  top: -20px;
  right: 0;
  z-index: 100;
}
@media screen and (max-width: 768px) {
  .page-top #n_outline #modal .modal_wrap .modal_close_btn {
    right: 7.5%;
  }
}
.page-top #n_outline #modal .modal_wrap .modal_close_btn .icnArea {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 30px;
  height: 30px;
}
.page-top #n_outline #modal .modal_wrap .modal_close_btn .icnArea::before, .page-top #n_outline #modal .modal_wrap .modal_close_btn .icnArea::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 2px;
  background-color: #ffffff;
  -webkit-transition: transform 0.3s ease;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.page-top #n_outline #modal .modal_wrap .modal_close_btn .icnArea::before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  top: 0;
}
.page-top #n_outline #modal .modal_wrap .modal_close_btn .icnArea::after {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  bottom: 0;
}
.page-top #modal {
  display: none;
}
.page-top .is-fade-hidden {
  opacity: 0;
  pointer-events: none;
}
@media screen and (min-width: 769px) {
  .page-top .is-fade-show {
    -webkit-animation: 1s ease-out forwards slideFadePC;
            animation: 1s ease-out forwards slideFadePC;
  }
}
@media screen and (max-width: 768px) {
  .page-top .is-fade-show {
    -webkit-animation: 1s ease-out forwards slideFadeSP;
            animation: 1s ease-out forwards slideFadeSP;
  }
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes slideFadePC {
  0% {
    opacity: 0;
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes slideFadePC {
  0% {
    opacity: 0;
    -webkit-transform: translateY(100px);
            transform: translateY(100px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes slideFadeSP {
  0% {
    opacity: 0;
    -webkit-transform: translateY(13.3333333333vw);
            transform: translateY(13.3333333333vw);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes slideFadeSP {
  0% {
    opacity: 0;
    -webkit-transform: translateY(13.3333333333vw);
            transform: translateY(13.3333333333vw);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}