@charset "UTF-8";

/* ==========================================================================
    Top Page style
============================================================================= */
.p-mv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  overflow: hidden;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 50vw;
}
.p-mv:first-of-type {
  background: url("../images/top/mv_bg.webp") no-repeat center/cover;
}
.p-mv:nth-of-type(2) {
  background: url("../images/top/mv_bg02.webp") no-repeat center/cover;
}
.p-mv:nth-of-type(3) {
  background: url("../images/top/mv_bg03.webp") no-repeat center/cover;
}
.p-mv:nth-of-type(4) {
  background: url("../images/top/mv_bg04.webp") no-repeat center/cover;
}
.p-mv__wrap .slider {
  width: 100%;
  height: 100%;
}
.p-mv__inner {
  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;
  height: 63.888%;
  width: 100%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.p-mv__item {
  color: #fff;
  -ms-flex-preferred-size: 31.944vw;
      flex-basis: 31.944vw;
  font-size: 2.8rem;
  font-weight: bold;
  height: 100%;
  letter-spacing: 5.6px;
  opacity: 0;
  position: relative;
  text-align: center;
}
.p-mv__item p {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
}
.p-mv__item .en {
  font-family: "Jost", sans-serif;
  font-size: 1.2rem;
  display: block;
  letter-spacing: 2.4px;
  margin-top: 15px;
}
.p-mv__item svg {
  width: 100%;
  height: 100%;
}
.p-mv__item svg .circle {
  opacity: 0;
}
.p-mv__wrap {
  margin-inline: 3.472vw;
  overflow: hidden;
  position: relative;
  z-index: 20;
  height: 50vw;
}
.p-mv__news {
  -webkit-animation-delay: 3s;
          animation-delay: 3s;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: rgba(243,246,251,0.95);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
  gap: 1.388vw;
  padding: 20px 1.388vw 20px 2.777vw;
  position: absolute;
  bottom: 0;
}
.p-mv__news--link {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 1.4rem;
  gap: 1.388vw;
  width: 100%;
}
.p-mv__news .ttl {
  color: #003f8e;
}
.p-mv__news .date {
  color: #aaa;
  font-family: "Jost", sans-serif;
}
.p-mv__news .fa-solid {
  background-color: #fff;
  border-radius: 50%;
  color: #003f8e;
  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;
  font-size: 1.2rem;
  width: 3.472vw;
  height: 3.472vw;
  margin-left: auto;
}
@media screen and (min-width: 768px) {
  .p-mv::before,
  .p-mv::after {
    background: url("../images/top/mv_circle_bg.svg") no-repeat 0 0/100%;
    content: "";
    width: 31.944vw;
    height: 31.944vw;
    opacity: 0;
    position: absolute;
  }
  .p-mv::before {
    left: -7.986vw;
  }
  .p-mv::after {
    right: -7.986vw;
  }
  .p-mv.is-active::before,
  .p-mv.is-active::after {
    -webkit-animation: fadein 2s linear forwards;
            animation: fadein 2s linear forwards;
  }
  .p-mv__item:nth-of-type(1) {
    margin-right: -3.125vw;
  }
  .p-mv__item:nth-of-type(2) {
    margin-left: -3.125vw;
  }
  .p-mv__item.is-active:nth-of-type(1) {
    -webkit-animation: fadein_left 1s 0.5s linear forwards;
            animation: fadein_left 1s 0.5s linear forwards;
  }
  .p-mv__item.is-active:nth-of-type(1) svg .circle {
    -webkit-animation: circle_rotate 1.5s linear forwards;
            animation: circle_rotate 1.5s linear forwards;
  }
  .p-mv__item.is-active:nth-of-type(2) {
    -webkit-animation: fadein_right 1s 1.5s linear forwards;
            animation: fadein_right 1s 1.5s linear forwards;
  }
  .p-mv__item.is-active:nth-of-type(2) svg .circle {
    -webkit-animation: circle_rotate 1.5s 1.25s linear forwards;
            animation: circle_rotate 1.5s 1.25s linear forwards;
  }
  .p-mv__news {
    right: 0;
  }
}
@media screen and (max-width: 767.98px) {
  .p-mv__wrap {
    /* height: 166vw; */
    height: 500px;
    padding-bottom: calc(3.8em + 50px);
    margin-inline: 20px;
  }
  .p-mv {
    background: url("../images/top/mv_bg_sp.webp") no-repeat center/cover;
    /* height: 166vw; */
    height: 500px;
  }
  .p-mv:nth-of-type(2) {
    background: url("../images/top/mv_bg_sp02.webp") no-repeat center/cover;
  }
  .p-mv:nth-of-type(3) {
    background: url("../images/top/mv_bg_sp03.webp") no-repeat center/cover;
  }
  .p-mv:nth-of-type(4) {
    background: url("../images/top/mv_bg_sp04.webp") no-repeat center/cover;
  }
  .p-mv__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: 41.602%;
  }
  .p-mv__item {
    /* -ms-flex-preferred-size: 69.23vw;
        flex-basis: 69.23vw; */
        flex-basis: 70%
  }
  .p-mv__item:nth-of-type(1) {
    margin-bottom: -25px;
  }
  .p-mv__item:nth-of-type(2) {
    margin-top: -25px;
  }
  .p-mv__item.is-active:nth-of-type(1) {
    -webkit-animation: fadein_left 1s 0.5s linear forwards;
            animation: fadein_left 1s 0.5s linear forwards;
  }
  .p-mv__item.is-active:nth-of-type(1) svg .circle {
    -webkit-animation: circle_rotate 1.5s linear forwards;
            animation: circle_rotate 1.5s linear forwards;
  }
  .p-mv__item.is-active:nth-of-type(2) {
    -webkit-animation: fadein_right 1s 1.5s linear forwards;
            animation: fadein_right 1s 1.5s linear forwards;
  }
  .p-mv__item.is-active:nth-of-type(2) svg .circle {
    -webkit-animation: circle_rotate 1.5s 1.25s linear forwards;
            animation: circle_rotate 1.5s 1.25s linear forwards;
  }
  .p-mv__news {
    box-sizing: border-box;
    padding: 25px 20px 22px;
    width: 100%;
  }
  .p-mv__news--link {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .p-mv__news--link .txt {
    -ms-flex-preferred-size: calc(100% - 40px - 14px);
        flex-basis: calc(100% - 40px - 14px);
  }
  .p-mv__news--link .fa-solid {
    width: 40px;
    height: 40px;
  }
}
/* --------------------
.p-intro
-------------------- */
.p-intro {
  padding: 140px 0 226px;
  position: relative;
}
.p-intro__img {
  position: absolute;
  max-width: 320px;
  width: 22.222vw;
}
.p-intro__img img {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
}
.p-intro__img.img001 {
  left: 0;
  top: -40px;
  z-index: 10;
}
.p-intro__img.img002 {
  right: 0;
  bottom: 36px;
}
.p-intro__lead {
  color: #003f8e;
  font-weight: bold;
  text-align: center;
}
.p-intro .txt + .txt {
  margin-top: 30px;
}
.p-intro__catch {
  -webkit-animation: flowing 40s linear infinite;
          animation: flowing 40s linear infinite;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 60vw;
}
.p-intro__catch img {
  max-width: inherit;
  height: 10.277vw;
}
.p-intro__catch-wrap {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
  width: 100vw;
  overflow: hidden;
  position: absolute;
  bottom: 0;
}
@media screen and (max-width: 767.98px) {
  .p-intro {
    padding: 204px 0 223px;
  }
  .p-intro__img {
    max-width: 156px;
    width: 39.473vw;
  }
  .p-intro__img.img001 {
    top: -20px;
  }
  .p-intro__img.img002 {
    bottom: 0;
  }
  .p-intro__catch {
    display: block;
  }
  .p-intro__catch img {
    height: 86px;
  }
  .p-intro__catch img:nth-of-type(2) {
    margin-top: 50px;
    -webkit-transform: translateX(-121.282vw);
            transform: translateX(-121.282vw);
  }
}
/* --------------------
.p-service
-------------------- */
.p-service {
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), color-stop(26.112%, #fff), color-stop(26.112%, #f6f6f6), to(#f6f6f6));
  background: -webkit-linear-gradient(top, #fff 0%, #fff 26.112%, #f6f6f6 26.112%, #f6f6f6 100%);
  background: linear-gradient(180deg, #fff 0%, #fff 26.112%, #f6f6f6 26.112%, #f6f6f6 100%);
  padding-top: 114px;
}
.p-service .c-hgroup {
  margin-bottom: 90px;
}
.p-service__list {
  margin-bottom: 62px;
}
.p-service__item .figcaption {
  font-size: 1.8rem;
  font-weight: bold;
  margin-top: 20px;
}
.p-service__item .figcaption .en {
  color: #aaa;
  display: block;
  font-size: 1.2rem;
  margin-bottom: 5px;
}
.p-quote {
  background-color: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-top: 100px;
  margin-inline: 4.166vw;
  padding: 100px 15px;
  position: relative;
  text-align: center;
  z-index: 10;
}
.p-quote::before,
.p-quote::after {
  content: "";
  background: url("../images/ico_quote.svg") no-repeat 0 0/100% auto;
  height: 6.04vw;
  width: 7.5vw;
  position: absolute;
  mix-blend-mode: multiply;
}
.p-quote::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
.p-quote__lead {
  color: #003f8e;
  font-size: 3rem;
  font-weight: bold;
  letter-spacing: 3px;
  margin-bottom: 50px;
}
.p-quote__lead .en {
  display: block;
  font-size: 1.4rem;
  letter-spacing: 2.8px;
  margin-top: 20px;
}
.p-quote .txt {
  line-height: 1.8;
}
.p-quote .txt + .txt {
  margin-top: 20px;
}
.p-quote__btn {
  position: absolute;
  left: 50%;
  bottom: -35px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .p-quote::before,
  .p-quote::after {
    top: -20px;
  }
  .p-quote::before {
    left: 5.555vw;
  }
  .p-quote::after {
    right: 3.405vw;
  }
}
@media screen and (max-width: 767.98px) {
  .p-service__list {
    gap: 40px;
  }
  .p-quote::before,
  .p-quote::after {
    width: 108px;
    height: 87px;
  }
  .p-quote::before {
    bottom: -30px;
    left: 20px;
  }
  .p-quote::after {
    top: -30px;
    right: 20px;
  }
}
/* --------------------
.p-recruit
-------------------- */
.p-recruit {
  background-color: #0067b2;
  margin-bottom: -6.527vw;
  padding: 20.138vw 0 10.416vw;
  position: relative;
  -webkit-transform: translateY(-6.527vw);
          transform: translateY(-6.527vw);
}
.p-recruit::before {
  background-color: #0b366b;
  content: "";
  height: 40vw;
  width: 68.055vw;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: -1;
}
.p-recruit .c-hgroup {
  margin-bottom: 60px;
}
.p-recruit .c-hgroup,
.p-recruit .hdg001 {
  color: #fff;
}
.p-recruit .c-hgroup .en,
.p-recruit .hdg001 .en {
  color: #fff;
}
.p-recruit__list {
  margin-bottom: 60px;
}
.p-recruit__item {
  background-color: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: #333;
  height: 100%;
  padding: 0 2.777vw 2.777vw;
}
.p-recruit__item:hover {
  opacity: 1;
}
.p-recruit__item .figure {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10.222%;
}
.p-recruit__item .figure .img {
  -ms-flex-preferred-size: 45.555%;
      flex-basis: 45.555%;
}
.p-recruit__item .figure .img img {
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.p-recruit__item .figure .figcaption span {
  display: block;
  font-weight: bold;
  line-height: 1.8;
}
.p-recruit__item .figure .figcaption .name {
  color: #003f8e;
  font-size: 4.6rem;
  letter-spacing: 4.6px;
  line-height: 1;
  margin-bottom: 20px;
}
.p-recruit__item .figure .figcaption .sub {
  color: #aaa;
}
.p-recruit__item .figure + .txt {
  margin-top: 20px;
}
@media screen and (min-width: 768px) {
  .p-recruit__item .figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-transform: translateY(-40px);
            transform: translateY(-40px);
    margin-bottom: -40px;
  }
}
@media screen and (max-width: 767.98px) {
  .p-recruit {
    padding-top: 190px;
  }
  .p-recruit .c-hgroup > .summary {
    border-color: rgba(255,255,255,0.3);
  }
  .p-recruit__list {
    gap: 80px;
  }
  .p-recruit__item {
    padding: 0 30px 30px;
  }
  .p-recruit__item .img {
    background-color: #f3f6fb;
    display: block;
    margin-right: -30px;
    text-align: right;
  }
  .p-recruit__item .img img {
    -webkit-transform: translateY(-30px);
            transform: translateY(-30px);
    margin-right: 30px;
    margin-bottom: -30px;
    width: 197px;
  }
  .p-recruit__item .figcaption {
    margin-top: 30px;
  }
  .p-recruit__item .figcaption span {
    text-align: left;
  }
}
/* --------------------
.c-btn
-------------------- */
.c-btn {
  padding: 20px 2.777vw;
}
@-webkit-keyframes flowing {
  0% {
    -webkit-transform: translateX(60px);
            transform: translateX(60px);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes flowing {
  0% {
    -webkit-transform: translateX(60px);
            transform: translateX(60px);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
/*# sourceMappingURL=maps/top.css.map */
