/*************************************************

top-com

*************************************************/
.top-com-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .top-com-title {
    margin-bottom: 2rem;
  }
}
.top-com-title .in-ja {
  color: #222;
  font-size: 4.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .top-com-title .in-ja {
    font-size: 2.7rem;
  }
}
.top-com-title .in-en {
  color: #004292;
  font-size: 2.4rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .top-com-title .in-en {
    font-size: 1.4rem;
  }
}

/*************************************************

top-mv

*************************************************/
.top-mv {
  position: relative;
}

/* top-mv-letters
---------------------------------------*/
.top-mv-letters {
  position: absolute;
  top: 5.5555555556vw;
  left: 9.7222222222vw;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .top-mv-letters {
    top: 4rem;
    left: 3rem;
  }
}

.top-mv-title {
  color: #fff;
  font-size: 2.6388888889vw;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .top-mv-title {
    font-size: 1.9rem;
  }
}

.top-mv-btn {
  position: relative;
  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;
  width: 10.0694444444vw;
  height: 2.7777777778vw;
  margin-top: 8rem;
  color: #004292;
  font-size: 0.9722222222vw;
  font-weight: 700;
  background-color: #fff;
  text-decoration: none;
  border-radius: 9.7222222222vw;
}
@media screen and (max-width: 767px) {
  .top-mv-btn {
    width: 9rem;
    height: 2.5rem;
    margin-top: 7rem;
    font-size: 0.9rem;
  }
}
.top-mv-btn::before {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  position: absolute;
  top: 50%;
  right: 1.1805555556vw;
  display: block;
  content: "";
  width: 0.3472222222vw;
  height: 0.3472222222vw;
  margin-top: -0.2777777778vw;
  border-top: #004292 solid 0.2083333333vw;
  border-right: #004292 solid 0.2083333333vw;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .top-mv-btn::before {
    right: 1rem;
    width: 0.4rem;
    height: 0.4rem;
    margin-top: -0.3rem;
    border-top-width: 0.2rem;
    border-right-width: 0.2rem;
  }
}

/* top-mv-slider
---------------------------------------*/
.top-mv-slider {
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.top-mv-slider figure {
  line-height: 0;
}
@media screen and (max-width: 767px) {
  .top-mv-slider figure {
    width: 100%;
    height: auto;
    aspect-ratio: 390/302;
  }
}
.top-mv-slider img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .top-mv-slider img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 100%;
  }
}

.top-mv-slider__controls {
  position: absolute;
  bottom: 0;
  right: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #fff;
  border-radius: 1rem 0 0 0;
  line-height: 0;
  z-index: 10;
}

.top-mv-slider__button {
  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;
  width: 7.2rem;
  height: auto;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 767px) {
  .top-mv-slider__button {
    width: 3.7rem;
  }
}
.top-mv-slider__button img {
  width: 0.9rem;
  height: auto;
}
@media screen and (max-width: 767px) {
  .top-mv-slider__button img {
    width: 0.5rem;
  }
}
.top-mv-slider__button.is-prev {
  border-right: #E8EBF5 solid 1px;
}
.top-mv-slider__button.is-prev img {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

/*************************************************

top-lead

*************************************************/
.top-lead {
  overflow: hidden;
  position: relative;
  padding: 6.5rem 2.3rem 16rem;
}
@media screen and (max-width: 767px) {
  .top-lead {
    padding: 4.5rem 2.3rem 5rem;
  }
}

.top-lead-inner {
  position: relative;
  max-width: 102rem;
  margin: 0 auto;
  z-index: 3;
}

.top-lead-title {
  margin-bottom: 4rem;
  color: #222;
  font-size: 3.8rem;
  font-weight: 600;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .top-lead-title {
    margin-right: -1rem;
    margin-bottom: 3rem;
    font-size: 1.85rem;
  }
}
.top-lead-title strong {
  color: #004292;
}

.top-lead-texts {
  font-size: 1.8rem;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .top-lead-texts {
    font-size: 1.4rem;
  }
}

.top-lead-img01 {
  position: absolute;
  top: 1rem;
  right: calc(50% + 37rem);
  width: 33.8rem;
  line-height: 0;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .top-lead-img01 {
    right: auto;
    left: -9rem;
    width: 20rem;
  }
}

.top-lead-img02 {
  position: absolute;
  top: 10rem;
  left: calc(50% - 13rem);
  width: 96.9rem;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .top-lead-img02 {
    left: auto;
    right: -7rem;
    width: 31.9rem;
  }
}

/*************************************************

top-company

*************************************************/
.top-company {
  overflow: hidden;
  position: relative;
  padding: 10rem 0;
}
@media screen and (max-width: 767px) {
  .top-company {
    padding: 5rem 0 7rem 5rem;
  }
}
.top-company::before {
  position: absolute;
  top: 0;
  left: 4rem;
  display: block;
  content: "";
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(166, 205, 255, 0)), to(rgba(166, 205, 255, 0.25)));
  background: linear-gradient(0deg, rgba(166, 205, 255, 0) 0%, rgba(166, 205, 255, 0.25) 100%);
  border-top-left-radius: 6rem;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .top-company::before {
    left: 2rem;
    border-top-left-radius: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .top-company .parts-btn02 {
    margin-right: 2.8rem;
  }
}

.top-company-inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 112rem;
  margin: 0 auto;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .top-company-inner {
    display: block;
  }
}

.top-company-left {
  width: 43.5rem;
}
@media screen and (max-width: 767px) {
  .top-company-left {
    width: auto;
  }
}

.top-company-right {
  width: 62rem;
  line-height: 0;
}
@media screen and (max-width: 767px) {
  .top-company-right {
    display: none;
  }
}
.top-company-right .top-company-photo {
  margin: 0 -6rem 0 6rem;
}

@media screen and (max-width: 767px) {
  .top-company-navs {
    margin-right: 2.8rem;
  }
}

.top-company-navs__item {
  border-bottom: #E5EAF0 solid 0.2rem;
}

.top-company-navs__anchor {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 8rem;
  padding-left: 1rem;
  color: #222;
  font-size: 2.1rem;
  font-weight: 600;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .top-company-navs__anchor {
    min-height: 5.5rem;
    font-size: 1.7rem;
  }
}
.top-company-navs__anchor::before {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  position: absolute;
  top: 50%;
  right: 1.8rem;
  display: block;
  content: "";
  width: 1rem;
  height: 1rem;
  margin-top: -0.7rem;
  border-top: #222 solid 2px;
  border-right: #222 solid 2px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .top-company-navs__anchor::before {
    right: 1.6rem;
    width: 0.6rem;
    height: 0.6rem;
    margin-top: -0.5rem;
    border-width: 1px;
  }
}

.top-company-photo {
  line-height: 0;
}
@media screen and (max-width: 767px) {
  .top-company-photo {
    margin-bottom: 3rem;
  }
}

/*************************************************

top-solution

*************************************************/
.top-solution {
  overflow: hidden;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  display: block;
  max-width: 129.5rem;
  margin: 0 auto 6rem;
  padding: 8rem;
  color: #fff;
  text-decoration: none;
  border-radius: 1.5rem;
}
@media screen and (max-width: 767px) {
  .top-solution {
    margin-bottom: 3rem;
    padding: 4rem 2rem;
    border-radius: 0;
  }
}
.top-solution > * {
  position: relative;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .top-solution .top-com-title {
    margin-bottom: 4rem;
  }
}
.top-solution .top-com-title .in-ja {
  color: #fff;
}

.top-solution__text {
  max-width: 53rem;
  font-size: 2rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .top-solution__text {
    max-width: none;
    font-size: 1.4rem;
  }
}

.top-solution__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  line-height: 0;
  z-index: 1;
}
.top-solution__bg picture {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
}
.top-solution__bg img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

/*************************************************

top-pagepanel

*************************************************/
.top-pagepanel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  max-width: 116rem;
  margin: 0 auto 5rem;
}
@media screen and (max-width: 767px) {
  .top-pagepanel {
    display: block;
    margin: 0 2rem 4rem;
  }
}

.top-pagepanel-photo {
  overflow: hidden;
  width: 51.724137931%;
  border-radius: 1.5rem;
  line-height: 0;
}
@media screen and (max-width: 767px) {
  .top-pagepanel-photo {
    width: 100%;
    margin-bottom: 3rem;
    border-radius: 1rem;
    aspect-ratio: 350/168;
  }
}
.top-pagepanel-photo img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .top-pagepanel-photo img {
    -o-object-fit: cover;
       object-fit: cover;
    height: 100%;
  }
}

.top-pagepanel-letters {
  width: 38.7931034483%;
}
@media screen and (max-width: 767px) {
  .top-pagepanel-letters {
    width: 100%;
  }
}

.top-pagepanel-title {
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  .top-pagepanel-title {
    margin-bottom: 2rem;
  }
}
.top-pagepanel-title .parts-btn02__anchor {
  width: 100%;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.top-pagepanel-title .parts-btn02__text {
  font-size: 3.5rem;
}
@media screen and (max-width: 767px) {
  .top-pagepanel-title .parts-btn02__text {
    font-size: 2.4rem;
  }
}

.top-pagepanel-texts {
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  .top-pagepanel-texts {
    font-size: 1.4rem;
  }
}

.top-pagepanel-navs {
  margin-top: 1rem;
}

.top-pagepanel-navs__item {
  border-bottom: #E5EAF0 solid 0.2rem;
}

.top-pagepanel-navs__anchor {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 8rem;
  padding-left: 1rem;
  color: #222;
  font-size: 2.1rem;
  font-weight: 600;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .top-pagepanel-navs__anchor {
    min-height: 5.5rem;
    font-size: 1.7rem;
  }
}
.top-pagepanel-navs__anchor::before {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  position: absolute;
  top: 50%;
  right: 1.8rem;
  display: block;
  content: "";
  width: 1rem;
  height: 1rem;
  margin-top: -0.7rem;
  border-top: #222 solid 2px;
  border-right: #222 solid 2px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .top-pagepanel-navs__anchor::before {
    right: 1.6rem;
    width: 0.6rem;
    height: 0.6rem;
    margin-top: -0.5rem;
    border-width: 1px;
  }
}

/*************************************************

top-solution-btn

*************************************************/
.top-solution-btn {
  max-width: 116rem;
  margin: 3rem auto 10rem;
}
@media screen and (max-width: 767px) {
  .top-solution-btn {
    margin: 2rem 2rem 8rem;
  }
}

/*************************************************

top-posts

*************************************************/
.top-posts {
  overflow: hidden;
  position: relative;
  padding: 10rem 0 16rem;
}
@media screen and (max-width: 767px) {
  .top-posts {
    padding: 0;
  }
}
.top-posts::before {
  position: absolute;
  top: 0;
  left: 4rem;
  display: block;
  content: "";
  width: 100%;
  height: 19rem;
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(166, 205, 255, 0)), to(rgba(166, 205, 255, 0.25)));
  background: linear-gradient(0deg, rgba(166, 205, 255, 0) 0%, rgba(166, 205, 255, 0.25) 100%);
  border-top-left-radius: 6rem;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .top-posts::before {
    display: none;
  }
}
.top-posts .top-com-title .in-ja {
  font-size: 3.8rem;
}
@media screen and (max-width: 767px) {
  .top-posts .top-com-title .in-ja {
    font-size: 2.4rem;
  }
}

.top-posts-inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 112rem;
  margin: 0 auto;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .top-posts-inner {
    display: block;
    padding: 5rem 0 5rem 5rem;
  }
  .top-posts-inner::before {
    position: absolute;
    top: 0;
    left: 2rem;
    display: block;
    content: "";
    width: 100%;
    height: 19rem;
    background: -webkit-gradient(linear, left bottom, left top, from(rgba(166, 205, 255, 0)), to(rgba(166, 205, 255, 0.25)));
    background: linear-gradient(0deg, rgba(166, 205, 255, 0) 0%, rgba(166, 205, 255, 0.25) 100%);
    border-top-left-radius: 2rem;
    z-index: 1;
  }
}
.top-posts-inner > * {
  position: relative;
  z-index: 5;
}

@media screen and (max-width: 767px) {
  .top-posts-left {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    margin: 0 2.2rem 4rem 0;
  }
}
@media screen and (max-width: 767px) {
  .top-posts-left .top-com-title {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .top-posts-left .parts-btn03 {
    background-color: #fff;
  }
}

.top-posts-right {
  width: 73.2142857143%;
}
@media screen and (max-width: 767px) {
  .top-posts-right {
    width: auto;
    margin-right: 2.2rem;
  }
}

.top-posts-list {
  border-top: #E5EAF0 solid 1px;
}

.top-posts-list__item {
  border-bottom: #E5EAF0 solid 1px;
}

.top-posts-list__acnhor {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem 0;
  padding: 2.5rem;
  color: #333;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .top-posts-list__acnhor {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 1.5rem 0.5rem;
  }
}
.top-posts-list__acnhor .in-date {
  width: 11rem;
  color: #666;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .top-posts-list__acnhor .in-date {
    width: 9rem;
    font-size: 1.4rem;
  }
}
.top-posts-list__acnhor .in-cat {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 11rem;
  padding: 0.6rem 0;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 700;
  text-align: center;
  background-color: #32A4CB;
}
.top-posts-list__acnhor .in-cat.is-ir {
  color: #004292;
  border: #004292 solid 1px;
  background-color: #F2F5F9;
}
.top-posts-list__acnhor .in-cat.is-cat1 {
  background-color: #798FCA;
}
@media screen and (max-width: 767px) {
  .top-posts-list__acnhor .in-cat {
    width: 9rem;
    padding: 0.4rem 0;
    font-size: 1.1rem;
  }
}
.top-posts-list__acnhor .in-text {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: calc(100% - 22rem);
  padding-left: 3rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .top-posts-list__acnhor .in-text {
    width: 100%;
    padding-left: 0;
    font-size: 1.4rem;
  }
}

.top-posts-bdr {
  max-width: 120rem;
  padding: 0;
  margin: 7.5rem auto;
  -webkit-box-shadow: none;
          box-shadow: none;
  height: 0;
  border-top: #DDDDDD solid 1px;
}

/*************************************************

top-recruit

*************************************************/
.top-recruit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #004292;
}
@media screen and (max-width: 767px) {
  .top-recruit {
    display: block;
  }
}
.top-recruit .parts-btn02 {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.top-recruit .parts-btn02__text {
  font-size: 1.7rem;
}
@media screen and (max-width: 767px) {
  .top-recruit .parts-btn02__text {
    font-size: 1.6rem;
  }
}

.top-recruit-letters {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 35.5555555556%;
  color: #fff;
  background: linear-gradient(135deg, rgb(2, 186, 243) 0%, rgb(0, 59, 137) 60%);
}
@media screen and (max-width: 767px) {
  .top-recruit-letters {
    width: auto;
    padding: 4.5rem 4.5rem 5rem;
  }
}

.top-recruit-letters__inner {
  max-width: 30rem;
  margin: 0 8rem 0 auto;
}
@media screen and (max-width: 767px) {
  .top-recruit-letters__inner {
    max-width: none;
    margin: 0;
  }
}

.top-recruit-title {
  margin-bottom: 3rem;
  font-size: 5.2rem;
  font-weight: 300;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .top-recruit-title {
    margin-bottom: 2rem;
    font-size: 4.2rem;
  }
}

.top-recruit-text {
  margin-bottom: 2.5rem;
  font-size: 1.8rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .top-recruit-text {
    font-size: 1.7rem;
  }
}

.top-recruit-photo {
  width: 64.4444444444%;
  line-height: 0;
}
@media screen and (max-width: 767px) {
  .top-recruit-photo {
    width: auto;
    width: 100%;
    height: auto;
    aspect-ratio: 390/260;
  }
}
.top-recruit-photo img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

/*************************************************

lowerbtns

*************************************************/
.lowerbtns {
  margin-top: 0;
  padding-top: 4rem;
  background-color: rgba(0, 66, 146, 0.12);
}
@media screen and (max-width: 767px) {
  .lowerbtns {
    padding-top: 1.2rem;
  }
}