@charset "UTF-8";

.mv_wrap {
  position: relative;
  width: 100%;
  height: calc(100vh - var(--header-height));
  max-height: 55vw;
  padding: 5vw 0;
  overflow: hidden;
}

.mv_wrap::before {
  content: '';
  position: absolute;
  bottom: 10vw;
  left: 0;
  width: 100vw;
  height: calc(100vh - var(--header-height));
  background: url(../img/top/mv_deco_bgWhite.svg) no-repeat center bottom;
  background-size: cover;
}

.mv_wrap .mv_copy_wrap .copy_box {
  position: absolute;
  width: 35%;
  top: 35%;
  left: 7vw;
  transform: translate(0, -50%);
  z-index: 2;
}

.mv_wrap .mv_copy_wrap .mainCopy .copy_txt {
  height: 4.5vw;
  display: block;
  position: relative;
}

.mv_wrap .mv_copy_wrap .mainCopy .copy_txt img {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left;
}

.mv_wrap .mv_copy_wrap .mainCopy .copy_txt+.copy_txt {
  margin-top: 1vw;
}

.mv_wrap .mv_copy_wrap .subCopy {
  margin-top: 1vw;
  font-size: 1.35vw;
}

.mv_wrap .mv_caption_wrap {
  position: absolute;
  width: 35%;
  bottom: 0;
  left: 7vw;
}

.mv_wrap .mv_caption_wrap {
  position: absolute;
  width: 50%;
  bottom: -2%;
  left: 7vw;
  display: flex;
  align-items: center;
}

.mv_wrap .mv_caption_wrap .scroll {
  width: 2vw;
  height: 7vw;
}

.mv_wrap .mv_caption_wrap .scroll img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.mv_wrap .mv_caption_wrap .ortho_caption p {
  width: fit-content;
  font-weight: bold;
  font-size: 1vw;
  color: #fff;
  margin-left: 1.5em;
}


/*----------------------------------------
スライド Start
-----------------------------------------*/

.mv_wrap .mvSwiper {
  position: relative;
  width: 78vw;
  height: fit-content;
  margin-left: auto;
  margin-right: 0;
  padding-left: 28vw;
  overflow: visible;
}

.mv_wrap .swiper-wrapper {
  height: fit-content;
  align-items: center;
}

.mv_wrap .swiper-slide {
  position: relative;
  transform: scale(0.85);
  transition: 2s ease-in-out;
}

.mv_wrap .swiper-slide a {
  position: relative;
  display: block;
}

.mv_wrap .swiper-slide .txtBox {
  position: absolute;
  bottom: 3.5em;
  left: 50%;
  transform: translate(-50%, 0);
  text-align: center;
  width: 100%;
  font-size: 1vw;
}

.mv_wrap .swiper-slide .txtBox p {
  font-size: 1vw;
}

.mv_wrap .swiper-slide-active {
  transform: scale(1.25);
  filter: drop-shadow(0.15vw 0.15vw 0.5vw rgba(0, 163, 227, 0.65));
  transform: translateZ(0);
}

.mv_wrap .swiper-slide {
  opacity: 0;
  transition: 1s ease-in-out;
}

.mv_wrap .swiper-slide-active,
.mv_wrap .swiper-slide-active+* {
  opacity: 1;
  transition: 1s ease-in-out;
}

.mv_wrap .swiper-pagination-bullets.swiper-pagination-horizontal {
  position: relative;
  bottom: unset;
  top: unset;
  left: unset;
  width: fit-content;
}

.mv_wrap .swiper_control {
  position: absolute;
  bottom: 0;
  left: unset;
  right: 8vw;
  padding: 0 2vw;
}

.swiper-pagination-bullet {
  position: relative;
  background: unset;
  opacity: 1;
  border: 1px solid #fff;
  width: 0.5vw;
  height: 0.5vw;
}

.swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #fff;
}

.swiper-pagination-bullet.swiper-pagination-bullet-active::before {
  content: '';
  position: absolute;
  width: 1.5vw;
  height: 1.5vw;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: 3s ease-in-out;
  border-radius: 50%;
  border: 1px solid #fff;
}

.mv_wrap .swiper-button-next,
.mv_wrap .swiper-button-prev {
  bottom: unset;
  top: 60%;
  color: #fff;
  margin: 0;
  transform: translate(0, -50%);
  width: 1vw;
  height: 1vw;
}


.mv_wrap .swiper-button-prev {
  left: 0;
}

.mv_wrap .swiper-button-next {
  right: 0;
}

.swiper-button-next:after,
.swiper-button-prev:after {
  content: '';
  position: absolute;
  width: 1vw;
  height: 1vw;
  background: url(../img/common/icon/ico_arowR_wh.svg) no-repeat center center;
  background-size: contain;
}

.swiper-button-prev:after {
  transform: rotate(180deg);
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 0.65vw;
  padding: 0;
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet.swiper-pagination-bullet-active,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet.swiper-pagination-bullet-active {
  border: 1px solid #fff;
}

/*----------------------------------------
スライド End
-----------------------------------------*/

.verticalL_wrap .verticalL_tit,
.h2_txt {
  font-size: 50px;
  font-weight: bold;
}

.verticalL_wrap .verticalL_tit {
  width: 52px;
  margin-right: 10px;
}

.product_wrap .h2_txt {
  height: 52px;
}

.verticalL_wrap .verticalL_tit picture,
.verticalL_wrap .verticalL_tit img,
.product_wrap .h2_txt picture,
.product_wrap .h2_txt img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: top left;
}

.business_wrap.bg_boderR .inner {
  padding-top: 0px;
  padding-bottom: 200px;
}

.business_wrap .imgBoxList_wrap {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.business_wrap .imgBoxList_wrap li:not(:first-child) {
  width: 32%;
  flex-wrap: wrap;
}

.business_wrap .imgBoxList_wrap li+li {
  margin-top: 20px;
}

.business_wrap .imgBoxList_wrap li:first-child .txt_wrap .title_box {
  font-size: 32px;
}

.business_wrap .imgBoxList_wrap li:first-child .list_inner {
  max-height: 280px;
}

.business_wrap .imgBoxList_wrap li:first-child .list_inner .img_wrap,
.business_wrap .imgBoxList_wrap li:first-child .list_inner .txt_wrap {
  width: 50%;
}

.business_wrap .imgBoxList_wrap li:first-child .list_inner .txt_wrap p {
  font-size: 17px;
  letter-spacing: 0.15em;
}


.business_wrap .imgBoxList_wrap li:not(:first-child) a {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.business_wrap .imgBoxList_wrap li:not(:first-child) .list_inner {
  flex-wrap: wrap;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
}

.business_wrap .imgBoxList_wrap li:not(:first-child) .list_inner .img_wrap {
  width: 100%;
  border-radius: 10px 10px 0 0;

}

.business_wrap .imgBoxList_wrap li:not(:first-child) .list_inner .txt_wrap {
  width: 100%;
  padding: 20px;
}

.business_wrap .imgBoxList_wrap li:not(:first-child) .list_inner .txt_wrap {
  width: 100%;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.business_wrap .imgBoxList_wrap li:not(:first-child) .list_inner .txt_box {
  flex-grow: 1;
}

.business_wrap .imgBoxList_wrap li:first-child .list_inner .txt_wrap .btnWrap {
  margin-right: var(--inner-padding-LR);
}

.business_wrap .imgBoxList_wrap li .list_inner .txt_wrap .btnWrap {
  margin-top: 0.5em;
}

.business_wrap .imgBoxList_wrap li:nth-child(2n) .txt_wrap .title_box,
.business_wrap .imgBoxList_wrap li:nth-child(2n) .txt_wrap .txt_box {
  padding-left: 0px;
}

.business_wrap .imgBoxList_wrap li:nth-child(odd):not(:first-child) .txt_wrap .title_box,
.business_wrap .imgBoxList_wrap li:nth-child(odd):not(:first-child) .txt_wrap .txt_box {
  padding-right: 0px;
}

.service_wrap {
  margin-top: -140px;
  position: relative;
}

.service_wrap .img_wrap {
  width: 58%;
  margin-left: -80px;
}

.service_wrap .txt_wrap {
  position: absolute;
  top: 35%;
  right: var(--inner-padding-LR);
  width: 45%;
  transform: translate(0, -50%);
}

.corporate_wrap {
  position: relative;
  margin-top: -40px;
}

.corporate_wrap .flex {
  flex-direction: row-reverse;
  align-items: center;
}

.corporate_wrap .img_wrap {
  width: 58%;
  margin-right: -130px;
  position: relative;
  z-index: 2;
}

.corporate_wrap .txt_wrap {
  width: 45%;
}

.service_wrap .btnWrap,
.corporate_wrap .btnWrap {
  margin-top: 20px;
}


.bg_BlueTR {
  margin-top: -80px;
}

.product_wrap .inner_wide {
  padding-top: 80px;
  padding-left: 40px;
  padding-right: 40px;
}


.product_wrap .product_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.product_wrap .product_list>* {
  position: relative;
  width: calc(100% / 7 - 6px);
  background: #fff;
  border-radius: 10px;
  margin-bottom: 6px;
}

.product_wrap .product_list>* a {
  padding: 20px 15px;
}

.product_wrap .product_list>*+* {
  margin-left: 5px;
}

.product_wrap .product_list>*:nth-child(7n+1) {
  margin-left: 0px;
}

.product_wrap .product_list .list_inner {
  display: block;
}

.product_wrap .product_list>*::before {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 100%;
  height: 100%;
  border-radius: 15px;
  background: linear-gradient(90deg, rgba(0, 90, 169, 1) 15%, rgba(0, 167, 227, 1) 90%);
  background-size: cover;
  filter: blur(5px);
  opacity: 0.5;
  z-index: -1;
}

.product_wrap .product_list .img_wrap picture {
  display: block;
  width: 70%;
  height: 150px;
  margin: auto auto 15px;
}

.product_wrap .product_list .img_wrap picture img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}


.product_wrap .product_list .txt_wrap {
  position: relative;
  min-height: 2.5em;
  padding-right: 1.25em;
}

.product_wrap .product_list .txt_wrap::before {
  content: '';
  position: absolute;
  top: 50%;
  right: 0em;
  width: 1.25em;
  height: 1.25em;
  transform: translate(0, -50%);
  background: url(../img/common/icon/ico_more_arrowR.svg) center center no-repeat;
  background-size: contain;
}

.product_wrap .product_list .list_inner:hover .txt_wrap::before {
  right: -0.25em;
  transition: 0.3s ease-in-out;
}

.product_wrap .product_list .txt_wrap .title_box {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  line-height: 1.25;
  font-size: 15px;
}

.product_wrap .h2_txt {
  margin-bottom: 20px;
  margin-left: -30px;
}

.product_list .list_inner .imProtain picture {
  max-width: unset;
  width: 100%;
  padding-top: 10px;
}



.news_wrap .tab-group.menu2n {
  width: 100%;
  margin: 0;
  justify-content: start;
}

.news_wrap .tab-group.menu2n {
  font-size: 20px;
}

.news_wrap .tab-group.menu2n .tab__item,
.news_wrap .tab-group.menu2n .tab__item:last-child {
  width: auto;
  margin: 0;
}

.news_wrap .tab__item:first-child button {
  padding-left: 0;
}

.news_wrap .tab__item button {
  color: var(--col-gray03);
}

.news_wrap .tab__item:hover button,
.news_wrap .tab__item.is-active button {
  filter: unset;
  color: var(--col-black);
}

.news_wrap .tab_wrap .tab__content-item.is-active,
.news_wrap .tab_wrap.menuSimple .tab__item.is-active button,
.news_wrap .tab_wrap .tab__content.is-active .tab__content-item {
  display: block;
  background: unset;
}

.news_wrap .tab_wrap .tab__content-item {
  padding: 0px;
}

.news_wrap .tab_wrap .tab__content-item .tab_inner {
  margin: 0px auto;
}

.news_wrap .tab_wrap .tab__content-item .infoList_wrap .info_wrap {
  border-bottom: 1px solid #e6e6e6;
}

.news_wrap .tab_wrap .tab__content-item .infoList_wrap .info_wrap:first-child {
  border-top: 1px solid #e6e6e6;
}

.news_wrap .infoList_wrap .info_wrap .info_flex {
  margin: 0.75em 0;
}

.news_wrap .tab_wrap,
.news_wrap .tab-group {
  position: relative;
}

.news_wrap .tab-group .btnWrap.arrowOrange {
  position: absolute;
  right: 0;
  bottom: 20px;
}

@media only screen and (max-width: 1450px) {

  .service_wrap .img_wrap {
    width: 52%;
    margin-left: -2vw;
  }

  .corporate_wrap .img_wrap {
    width: 56%;
    margin-right: -2vw;
  }

  .product_wrap .product_list>* a {
    padding: 1.5vw 1vw;
  }

  .product_wrap .product_list .img_wrap picture {
    height: 11vw;
    margin: auto auto 15px;
  }


  .product_wrap .product_list .txt_wrap::before {
    content: '';
    position: absolute;
    top: 50%;
    right: 0em;
    width: 1.25em;
    height: 1.25em;
    transform: translate(0, -50%);
    background: url(../img/common/icon/ico_more_arrowR.svg) center center no-repeat;
    background-size: contain;
  }

  .product_wrap .product_list .list_inner:hover .txt_wrap::before {
    right: -0.25em;
    transition: 0.3s ease-in-out;
  }

  .product_wrap .product_list .txt_wrap,
  .product_wrap .product_list .txt_wrap .title_box {
    font-size: 1.1vw;
    letter-spacing: 0;
  }
}

@media only screen and (max-width: 1163px) {

  .mv_wrap::before {
    bottom: 12vw;
  }

  .mv_wrap .mv_copy_wrap .mainCopy .copy_txt {
    height: 5vw;
  }

  .mv_wrap .mv_copy_wrap .subCopy {
    font-size: 1.5vw;
  }

  .mv_wrap .mv_caption_wrap .scroll {
    width: 2.75vw;
    height: 11.5vw;
  }

  .mv_wrap .mv_caption_wrap .ortho_caption p {
    font-size: 1.25vw;
  }

  .verticalL_wrap .verticalL_tit,
  .h2_txt {
    font-size: 4.45vw;
  }


  .verticalL_wrap .verticalL_tit {
    width: 5.2vw;
    margin-right: 1vw;
  }

  .product_wrap .h2_txt {
    height: 5.2vw;
  }

  .business_wrap .imgBoxList_wrap li:first-child .txt_wrap .title_box {
    font-size: 2.75vw;
  }

  .business_wrap .imgBoxList_wrap li:first-child .list_inner .txt_wrap p {
    font-size: 1.7vw;
  }


  .product_wrap .inner_wide {
    padding-left: var(--inner-padding-LR);
    padding-right: var(--inner-padding-LR);
  }

  .product_wrap .product_list .img_wrap picture {
    height: 11vw;
    margin: auto auto 15px;
  }

  .product_wrap .product_list .txt_wrap .title_box {
    font-size: 1.15vw;
  }

  .product_wrap .h2_txt {
    margin-left: -1.5vw;
  }

  .news_wrap .tab-group.menu2n {
    font-size: 2vw;
  }
}

@media only screen and (max-width: 959px) {

  /* .mv_wrap::before {
    top: 0;
  } */
  .mv_wrap::before {
    height: calc(55vw - var(--header-height));
    top: 0;
  }

  .mv_wrap {
    min-height: 50vw;
  }

  .swiper-pagination-bullet {
    margin: 0 1vw;
    width: 0.75vw;
    height: 0.75vw;
  }

  .swiper-pagination-bullet.swiper-pagination-bullet-active::before {
    width: 2.5vw;
    height: 2.5vw;
  }

  .mv_wrap .swiper-button-next,
  .mv_wrap .swiper-button-prev {
    top: 60%;
    width: 1.5vw;
    height: 1.5vw;
  }



  .product_wrap .product_list {
    justify-content: start;
  }

  .product_wrap .product_list>* {
    width: calc(100% / 5 - 6px);
  }

  .product_wrap .product_list>*+*,
  .product_wrap .product_list>*:nth-child(7n+1) {
    margin-left: 5px;
  }

  .product_wrap .product_list>*:nth-child(5n+1) {
    margin-left: 0px;
  }

  .product_wrap .product_list .txt_wrap .title_box {
    font-size: 1.45vw;
  }

}

/*==========================================================================================
ここからSP
==========================================================================================*/
@media only screen and (max-width: 767px) {

  .mv_wrap {
    min-height: 190vw;
  }

  .mv_wrap::before {
    height: calc(100vh - var(--header-height));
    bottom: 30vh;
    top: unset;
  }

  .mv_wrap .mv_copy_wrap .copy_box {
    width: 100%;
    top: 18%;
  }

  .mv_wrap .mv_copy_wrap .mainCopy .copy_txt {
    height: 10vw;
  }

  .mv_wrap .mv_copy_wrap .mainCopy .copy_txt+.copy_txt {
    margin-top: 2vw;
  }

  .mv_wrap .mv_copy_wrap .subCopy {
    margin-top: 2vw;
    font-size: 3.5vw;
  }

  .mv_wrap .mv_caption_wrap {
    width: 100%;
    bottom: -2%;
    left: 7vw;
  }

  .mv_wrap .mv_caption_wrap .scroll {
    width: 5vw;
    height: 32vw;
  }

  .mv_wrap .mv_caption_wrap .ortho_caption {
    font-size: 3.5vw;
  }


  /*----------------------------------------
  スライド Start
  -----------------------------------------*/

  .mv_wrap .mvSwiper {
    position: absolute;
    width: 100%;
    /* bottom: 20%; */
    top: 33%;
    padding-left: 10vw;
  }

  .mv_wrap .swiper-slide .txtBox,
  .mv_wrap .swiper-slide .txtBox p {
    font-size: 3vw;
  }

  .mv_wrap .swiper-slide .txtBox {
    bottom: 7.25vw;
    letter-spacing: 0;
  }


  .mv_wrap .swiper_control {
    bottom: -7vw;
    right: 5vw;
    padding: 0 6vw;
  }

  .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
  .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 2vw;
  }

  .swiper-pagination-bullet {
    width: 1.65vw;
    height: 1.55vw;
  }

  .swiper-pagination-bullet.swiper-pagination-bullet-active::before {
    width: 5vw;
    height: 5vw;
  }

  .mv_wrap .swiper-button-next,
  .mv_wrap .swiper-button-prev,
  .swiper-button-next:after,
  .swiper-button-prev:after {
    width: 3vw;
    height: 3vw;
  }

  /*----------------------------------------
  スライド End
  -----------------------------------------*/
  .verticalL_wrap .verticalL_tit,
  .h2_txt {
    font-size: 6vw;
  }


  .mv_wrap .mv_caption_wrap .ortho_caption p {
    font-size: 3.5vw;
  }

  .mv_wrap {
    max-height: unset;
  }



  .verticalL_wrap .verticalL_tit {
    width: unset;
    margin-right: 1vw;
  }

  .verticalL_wrap .verticalL_tit,
  .product_wrap .h2_txt {
    height: 6vw;
  }

  .verticalL_wrap .verticalL_tit picture,
  .verticalL_wrap .verticalL_tit picture img {
    height: 100%;
  }



  .business_wrap.bg_boderR .inner {
    padding-bottom: 15vw;
  }

  .business_wrap .imgBoxList_wrap li:not(:first-child) {
    width: 100%;
  }

  .business_wrap .imgBoxList_wrap li+li {
    margin-top: 5vw;
  }

  .business_wrap .imgBoxList_wrap li:first-child .txt_wrap .title_box {
    font-size: 4.5vw;
  }

  .business_wrap .imgBoxList_wrap li:first-child .list_inner {
    max-height: unset;
  }

  .business_wrap .imgBoxList_wrap li:first-child .list_inner .img_wrap,
  .business_wrap .imgBoxList_wrap li:first-child .list_inner .txt_wrap {
    width: 100%;
  }

  .business_wrap .imgBoxList_wrap li:first-child .list_inner .txt_wrap p {
    font-size: 3.5vw;
  }

  .business_wrap .imgBoxList_wrap li:not(:first-child) .list_inner .txt_wrap {
    padding: 4vw;
  }


  .service_wrap {
    margin-top: 10vw;
  }

  .service_wrap .flex {
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }

  .service_wrap .img_wrap {
    width: 60%;
    margin-top: -7vw;
    margin-right: -0vw;
    margin-left: auto;
  }

  .service_wrap .txt_wrap {
    position: relative;
    top: 100%;
    right: unset;
    left: 0;
    width: 100%;
    transform: translate(0, 0%);
  }

  .service_wrap .btnWrap {
    margin-left: 0px;
  }


  #contents .inner {
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }

  .corporate_wrap {
    margin-top: 10vw;
  }

  .corporate_wrap .btnWrap {
    margin-left: 0px;
  }

  .corporate_wrap .img_wrap {
    width: 62%;
    margin-top: -10vw;
    margin-right: -2vw;
    margin-left: auto;
  }

  .corporate_wrap .txt_wrap {
    width: 100%;
  }

  .service_wrap .btnWrap,
  .corporate_wrap .btnWrap {
    margin-top: 4vw;
  }


  .bg_BlueTR {
    margin-top: -8vw;
  }

  .product_wrap .h2_txt {
    margin-bottom: 4vw;
  }

  .product_wrap .inner_wide {
    padding-top: 11vw;
  }

  .product_wrap .product_list>* {
    width: calc(100% / 2 - 6px);
  }

  .product_wrap .product_list>* a {
    padding: 2.5vw 2vw 2vw;
  }

  .product_wrap .product_list>*+*,
  .product_wrap .product_list>*:nth-child(5n+1),
  .product_wrap .product_list>*:nth-child(7n+1) {
    margin-left: 5px;
  }

  .product_wrap .product_list>*:nth-child(2n+1) {
    margin-left: 0px;
  }

  .product_wrap .product_list .txt_wrap,
  .product_wrap .product_list .txt_wrap .title_box {
    font-size: 3.2vw;
  }

  .product_wrap .product_list .img_wrap picture {
    height: 30vw;
    margin: auto auto 2.5vw;
  }


  .news_wrap .tab-group.menu2n {
    font-size: 3.5vw;
  }

  .news_wrap .tab-group.menu2n {
    justify-content: space-between;
  }

  .news_wrap .tab-group .btnWrap.arrowOrange {
    bottom: 14vw;
  }

  .news_wrap .verticalL_wrap .verticalL_tit,
  .h2_txt {
    margin-bottom: 0;
  }
}