@charset "UTF-8";
/* ---------------------------------------
トップページ
-----------------------------------------*/
/* 共通
--------------------------------*/
main section {
  padding: 9rem 0 12rem;
}
@media screen and (max-width: 767px) {
  main section {
    padding: 12rem 0 15rem;
  }
}

/* sec_concept
--------------------------------*/
#sec_concept {
  padding-bottom: 23.6rem;
}
@media screen and (max-width: 767px) {
  #sec_concept {
    padding-bottom: 0;
  }
}
#sec_concept .sec_head .txt_wrap {
  width: 49.5rem;
}
@media screen and (max-width: 767px) {
  #sec_concept .sec_head .txt_wrap {
    width: 100%;
  }
  #sec_concept .sec_head .txt_wrap .ttl01 {
    letter-spacing: -0.05em;
  }
}
#sec_concept .img {
  overflow: hidden;
  position: absolute;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #sec_concept .img {
    position: relative;
  }
}
#sec_concept .img .img_clip {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}
#sec_concept .img img {
  width: 100%;
  height: 120%;
  object-fit: cover;
  transition: 0.5s ease;
}
#sec_concept .img._01 {
  width: calc(50% - 1.1rem);
  height: 53.9rem;
  left: 0;
  bottom: -11rem;
}
@media screen and (max-width: 767px) {
  #sec_concept .img._01 {
    width: 64rem;
    height: 36.3rem;
    left: 0;
    bottom: 0;
    margin-top: 11rem;
  }
}
#sec_concept .img._01 img {
  object-position: right top;
  transform-origin: right top;
}
#sec_concept .img._02 {
  width: calc(50% - 11rem);
  height: 53.9rem;
  right: 0;
  bottom: -38.4rem;
}
@media screen and (max-width: 767px) {
  #sec_concept .img._02 {
    width: 63rem;
    height: 40.1rem;
    right: 0;
    bottom: 0;
    margin-left: auto;
    margin-top: 9rem;
  }
}
#sec_concept .img._02 img {
  object-position: left top;
  transform-origin: left top;
}

/* sec_feature
--------------------------------*/
#sec_feature {
  padding-top: 30rem;
  background-color: #ffffff;
}
@media screen and (max-width: 767px) {
  #sec_feature {
    margin-top: -20rem;
  }
}
#sec_feature::before {
  height: 30rem;
}
#sec_feature::after {
  height: calc(100% - 42rem);
}
#sec_feature .block {
  position: relative;
  margin-top: 12rem;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #sec_feature .block {
    margin-top: 10rem;
  }
}
#sec_feature .block .txt_wrap {
  position: relative;
  padding: 4rem 4rem 4.5rem;
  background-color: #ffffff;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .txt_wrap {
    padding: 0;
    background: none;
  }
}
#sec_feature .block .txt_wrap .num {
  width: 100%;
  color: #E8E8E8;
  font-size: 7rem;
  line-height: 0.8;
  letter-spacing: 0.11em;
  position: absolute;
  left: 0;
  bottom: 100%;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .txt_wrap .num {
    text-align: right;
    font-size: 9rem;
    position: static;
    margin-bottom: 5rem;
  }
}
#sec_feature .block .txt_wrap .txt {
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .txt_wrap .txt {
    margin-top: 8rem;
  }
}
#sec_feature .block .inner {
  align-items: center;
  width: 130rem;
  margin-right: -10rem;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .inner {
    width: 100%;
    margin-right: 0;
  }
}
#sec_feature .block .inner .txt_wrap {
  width: 59.8rem;
  padding: 4rem 4rem 4.5rem 0;
  margin-right: -8.8rem;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .inner .txt_wrap {
    width: 100%;
    padding: 0;
    margin-right: 0;
  }
}
#sec_feature .block .inner .img_wrap {
  width: 79rem;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .inner .img_wrap {
    width: 100vw;
    margin: 9rem -5rem 0 -10rem;
  }
}
#sec_feature .block .inner.reverse {
  margin-right: 0;
  margin-left: -10rem;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .inner.reverse {
    margin-left: 0;
  }
}
#sec_feature .block .inner.reverse .txt_wrap {
  padding: 4rem 0 4.5rem 4rem;
  margin-right: 0;
  margin-left: -8.8rem;
}
@media screen and (max-width: 767px) {
  #sec_feature .block .inner.reverse .txt_wrap {
    width: 100%;
    padding: 0;
    margin-left: 0;
  }
}
#sec_feature .block .inner.reverse .txt_wrap .num {
  text-align: right;
}
#sec_feature .block._01 {
  margin-top: 14rem;
}
@media screen and (max-width: 767px) {
  #sec_feature .block._01 {
    margin-top: 7rem;
  }
}
#sec_feature .block._01 .txt_wrap {
  width: 76rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  #sec_feature .block._01 .txt_wrap {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #sec_feature .block._01 .txt_wrap .ttl01 {
    text-align: left;
  }
}
#sec_feature .block._01 .img_wrap {
  position: relative;
  margin: -4.3rem -10rem 0;
}
@media screen and (max-width: 767px) {
  #sec_feature .block._01 .img_wrap {
    margin: 9rem -5rem 0 -10rem;
  }
}
#sec_feature .block._01 .img_wrap .img {
  width: 25%;
}
@media screen and (max-width: 767px) {
  #sec_feature .block._01 .img_wrap .img {
    width: 50%;
  }
}
#sec_feature .block._02 .img_wrap {
  height: 86rem;
}
#sec_feature .block._02 .img_wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right center;
}

/* sec_developer
--------------------------------*/
#sec_developer .sec_ttl_en .ttl_ja {
  letter-spacing: -0.05em;
}
#sec_developer .txt_wrap {
  width: 80rem;
  margin: 8.5rem auto 0;
}
@media screen and (max-width: 767px) {
  #sec_developer .txt_wrap {
    width: 100%;
    margin-top: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #sec_developer .txt_wrap .ttl01 {
    text-align: left;
  }
}
#sec_developer .developer_list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8rem 2.4rem;
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list {
    grid-template-columns: 1fr;
    gap: 10rem;
  }
}
#sec_developer .developer_list .item .img {
  width: 100%;
  height: 23rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list .item .img {
    height: 42rem;
  }
}
#sec_developer .developer_list .item:nth-child(1) img {
  width: 29.2rem;
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list .item:nth-child(1) img {
    width: 47.6rem;
  }
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list .item:nth-child(2) .img {
    justify-content: flex-end;
  }
}
#sec_developer .developer_list .item:nth-child(2) img {
  width: 35.7rem;
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list .item:nth-child(2) img {
    width: 58.2rem;
  }
}
#sec_developer .developer_list .item:nth-child(3) img {
  width: 32rem;
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list .item:nth-child(3) img {
    width: 53rem;
  }
}
#sec_developer .developer_list .item .ttl {
  font-weight: 500;
  font-size: 2.2rem;
  line-height: 1.6363636364;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list .item .ttl {
    font-size: 3.6rem;
  }
}
#sec_developer .developer_list .item .txt {
  text-align: justify;
  padding-right: 2rem;
  margin-top: 3rem;
}
@media screen and (max-width: 767px) {
  #sec_developer .developer_list .item .txt {
    letter-spacing: 0;
    padding-right: 0;
  }
}
#sec_developer .btn_wrap {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #sec_developer .btn_wrap {
    margin-top: 10rem;
  }
}
#sec_developer .btn_wrap .txt {
  font-weight: 500;
  font-size: 2rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #sec_developer .btn_wrap .txt {
    font-size: 3rem;
    line-height: 1.8;
  }
}
#sec_developer .btn_wrap .btn_box {
  width: 63.8rem;
  height: 8.9rem;
  margin: 3rem auto 0;
}
@media screen and (max-width: 767px) {
  #sec_developer .btn_wrap .btn_box {
    width: 100%;
    height: 15rem;
    margin-top: 5rem;
  }
}
#sec_developer .btn_wrap .btn_box a::before {
  background-color: #9C9D9D;
}
#sec_developer .btn_wrap .btn_box .btn_txt {
  color: #ffffff;
}

/* sec_manufacturer
--------------------------------*/
@media screen and (max-width: 767px) {
  #sec_manufacturer .sec_ttl_en .ttl_ja {
    width: 100%;
    text-align: right;
    padding-right: 7rem;
  }
}
#sec_manufacturer .txt_wrap {
  width: 80rem;
  margin: 8.5rem auto 0;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .txt_wrap {
    width: 100%;
    margin-top: 5rem;
  }
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .txt_wrap .ttl01 {
    text-align: left;
  }
}
#sec_manufacturer .manufacturer_list {
  justify-content: center;
  gap: 2.4rem;
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list {
    flex-direction: column;
    gap: 3rem 0;
    margin-top: 9rem;
  }
}
#sec_manufacturer .manufacturer_list .item {
  width: 28.2rem;
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background-color: #E8E8E8;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item {
    width: 100%;
    padding: 1.5rem 2rem;
  }
}
#sec_manufacturer .manufacturer_list .item .ico {
  width: 7.5rem;
  height: 7.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item .ico {
    width: 9rem;
    height: 9rem;
    margin-right: 3rem;
  }
}
#sec_manufacturer .manufacturer_list .item .txt {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item .txt {
    font-size: 3.4rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(1) .ico img {
  width: 3.2rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(1) .ico img {
    width: 4.9rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(2) .ico img {
  width: 3rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(2) .ico img {
    width: 4.6rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(3) .ico img {
  width: 3.3rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(3) .ico img {
    width: 5rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(4) .ico img {
  width: 3.5rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(4) .ico img {
    width: 5.3rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(5) .ico img {
  width: 3.7rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(5) .ico img {
    width: 5.6rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(6) .ico img {
  width: 3.7rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(6) .ico img {
    width: 5.6rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(7) .ico img {
  width: 4.2rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(7) .ico img {
    width: 6.3rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(8) .ico img {
  width: 2.6rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(8) .ico img {
    width: 4rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(9) .ico img {
  width: 4.1rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(9) .ico img {
    width: 6.2rem;
  }
}
#sec_manufacturer .manufacturer_list .item:nth-child(10) .ico img {
  width: 4.1rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .manufacturer_list .item:nth-child(10) .ico img {
    width: 6.2rem;
  }
}
#sec_manufacturer .partner {
  padding: 4rem 6rem;
  border: 1px solid #414141;
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .partner {
    padding: 4rem 4.8rem;
    margin-top: 10rem;
  }
}
#sec_manufacturer .partner .ttl {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  font-weight: 500;
  font-size: 3.2rem;
  letter-spacing: 0.03em;
  padding-right: 14rem;
  margin-right: 3rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .partner .ttl {
    font-size: 3.6rem;
    flex-direction: row;
    justify-content: flex-start;
    align-items: flex-end;
    padding-right: 0;
    padding-bottom: 7.5rem;
    margin-right: 0;
  }
}
#sec_manufacturer .partner .ttl span {
  display: block;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .partner .ttl span {
    font-size: 2.2rem;
    margin-left: 1.5em;
    margin-bottom: 0.5rem;
  }
}
#sec_manufacturer .partner .ttl::after {
  content: "";
  width: 1px;
  height: 125%;
  background-color: #414141;
  position: absolute;
  right: 6.5rem;
  top: -11%;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .partner .ttl::after {
    height: 7rem;
    left: 26rem;
    top: auto;
    right: auto;
    bottom: 0;
    margin: 0 auto;
  }
}
#sec_manufacturer .partner .txt {
  flex: 1;
  text-align: justify;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .partner .txt {
    letter-spacing: 0;
    margin-top: 3.5rem;
  }
}
#sec_manufacturer .btn_wrap {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .btn_wrap {
    margin-top: 10rem;
  }
}
#sec_manufacturer .btn_wrap .txt {
  font-weight: 500;
  font-size: 2rem;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .btn_wrap .txt {
    font-size: 3rem;
    line-height: 1.8;
  }
}
#sec_manufacturer .btn_wrap .txt_s {
  margin-top: 1.2rem;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .btn_wrap .txt_s {
    text-align: left;
    margin-top: 2.4rem;
  }
}
#sec_manufacturer .btn_wrap .btn_box {
  width: 63.8rem;
  height: 8.9rem;
  margin: 3rem auto 0;
}
@media screen and (max-width: 767px) {
  #sec_manufacturer .btn_wrap .btn_box {
    width: 100%;
    height: 15rem;
    margin-top: 5rem;
  }
}
#sec_manufacturer .btn_wrap .btn_box a::before {
  background-color: #9C9D9D;
}
#sec_manufacturer .btn_wrap .btn_box .btn_txt {
  color: #ffffff;
}