@charset "UTF-8";
/*@function vw($size, $viewport:1920) {
  $rate: 100 / $viewport;
  @return $rate * $size * 1vw;
}*/
.sp {
  display: none;
}

.pc {
  display: block;
}

/*ヘッダー*/
.hd_btn02 {
  position: fixed;
  right: 0;
  top: 23.5rem;
  z-index: 10;
}
@media screen and (max-width: 1872px) {
  .hd_btn02 {
    top: 20.5rem;
  }
}
@media screen and (max-width: 1648px) {
  .hd_btn02 {
    top: 20.8rem;
  }
}
.hd_btn02 a {
  position: relative;
}
.hd_btn02 a:hover {
  top: -5px;
}
@media screen and (max-width: 1872px) {
  .hd_btn02 img {
    width: 14rem;
  }
}
@media screen and (max-width: 1440px) {
  .hd_btn02 img {
    width: 18rem;
  }
}
@media screen and (max-width: 1294px) {
  .hd_btn02 img {
    width: 20rem;
  }
}
.hd_btn02.stab {
  display: none;
}
@media screen and (max-width: 1440px) {
  .hd_btn02.stab {
    display: block;
  }
}

@media screen and (max-width: 1440px) {
  .hd_btn02 {
    position: absolute;
    right: 0;
    top: 15rem;
    z-index: 10;
  }
}
@media screen and (max-width: 1440px) and (max-width: 1294px) {
  .hd_btn02 {
    top: 17rem;
  }
}
@media screen and (max-width: 1440px) {
  .hd_btn02 a {
    position: relative;
  }
  .hd_btn02 a:hover {
    top: -5px;
  }
  .hd_btn02.pc {
    display: none;
  }
}
/*document list*/
.document_bg .top_document_list_ttl a {
  color: #354362;
  font-size: 1.8rem;
  font-weight: bold;
}
.document_bg .top_document_list_img {
  border-radius: 20px;
  box-shadow: 0px 0px 30px -6px rgba(8, 24, 46, 0.5);
  margin-bottom: 3rem;
}
.document_bg .top_document_list_img a {
  aspect-ratio: 378/213;
  display: flex;
  align-items: center;
}
.document_bg .top_document_list_img .su {
  padding: 8rem;
}

/*document_detail*/
.document_detail .document_bg .common_inner {
  margin: 0 auto;
}
.document_detail .document_detail_flex {
  margin-bottom: 100px;
  display: flex;
}
.document_detail .document_detail_flex .document_detail_wrap {
  width: calc(100% - 500px);
  display: flex;
  flex-direction: column;
  gap: 3rem;
}
.document_detail .document_detail_flex .document_detail_wrap .document_detail_ttl {
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  background-color: #004ea2;
  display: block;
  text-align: center;
  color: #fff;
  padding: 0.5rem 2rem;
  border-radius: 25px;
}
.document_detail .document_detail_flex .document_detail_wrap .detail_list_block {
  border: 1px solid #074e9b;
  border-radius: 20px;
  padding: 4rem 5rem;
}
.document_detail .document_detail_flex .document_detail_wrap .detail_list_block .detail_list_ttl {
  font-size: 2.2rem;
  font-weight: bold;
  color: #354362;
  text-align: center;
  margin-bottom: 2rem;
}
.document_detail .document_detail_flex .document_detail_wrap .detail_list_block .list_li {
  padding-left: 1.2em;
  position: relative;
  margin-bottom: 1rem;
  font-weight: 500;
}
.document_detail .document_detail_flex .document_detail_wrap .detail_list_block .list_li::before {
  content: "";
  position: absolute;
  top: 0.5em;
  left: 0px;
  width: 10px;
  height: 10px;
  background: #004ea2;
  border-radius: 50%;
}
.document_detail .document_detail_flex .document_contact_wrap {
  width: 500px;
  padding-left: 50px;
}

/*mass_production*/
.mass_production .common_sub_main .common_w_inner {
  background: url(../images/massproduction/massproduction_mainimg.png) no-repeat center center;
  background-size: cover;
}

.sub_mass_production_container01_bg {
  padding: 7rem 0 0 0;
}
.sub_mass_production_container01_bg .common_inner,
.sub_mass_production_container01_bg .common_m_inner {
  margin-left: auto;
  margin-right: auto;
}
.sub_mass_production_container01_bg .common_sub_menu_box01 ul {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  margin: 4rem 0;
  flex-wrap: wrap;
}
.sub_mass_production_container01_bg .common_sub_menu_box01 ul li {
  width: 100%;
  max-width: 164px;
}
.sub_mass_production_container01_bg .common_sub_menu_box01 ul li a {
  font-size: 1.6rem;
  text-align: center;
}
.sub_mass_production_container01_flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sub_mass_production_container01_lead {
  margin-bottom: 10rem;
  padding: 6.5rem;
  background-color: #fff;
  border-radius: 20px;
  box-shadow: 0px 0px 30px -6px rgba(8, 24, 46, 0.3);
}
.sub_mass_production_container01_lead .common_inner {
  width: 100%;
}
.sub_mass_production_container01_lead_ttl {
  font-size: 3.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
  margin-bottom: 3rem;
}
.sub_mass_production_container01_lead_disc {
  width: calc(55% - 6.5rem);
}
.sub_mass_production_container01_lead_img {
  width: 45% img;
  width-width: 100%;
}
.sub_mass_production_container01_lead .ft_contact_btn.btn01 {
  margin-right: 0;
  margin-top: 5rem;
}
.sub_mass_production_container01_lead .ft_contact_btn.btn01 .btn_bf {
  border: 1px solid #007fc8;
  color: #004ea2;
  background: #fff;
}
.sub_mass_production_container01_lead .ft_contact_btn.btn01 .btn_bf::after {
  background: #fff;
}
.sub_mass_production_container01_lead .ft_contact_btn.btn01 a {
  background: linear-gradient(to right, #004ea2, #14b6f2);
  border: 1px solid #acd5ff;
}
.sub_mass_production_container01_lead .ft_contact_btn.btn01 a .icon_txt {
  color: #fff;
}
.sub_mass_production_container01_lead .ft_contact_btn.btn01 a .icon_txt::before {
  background: url(../images/common/icon_mail_wh.svg);
  background-size: contain;
}
.sub_mass_production_container01_box {
  padding: 6rem 0 0 0;
}
.sub_mass_production_container01_box_cover {
  padding: 8rem 0 0 0;
}
.sub_mass_production_container01_box_cover .sub_mass_production_container01_box_sec:nth-child(2n+0) .sub_mass_production_container01_box_disc {
  order: 1;
}
.sub_mass_production_container01_box_cover .sub_mass_production_container01_box_sec:nth-child(2n+0) .sub_mass_production_container01_box_img {
  order: 0;
}
.sub_mass_production_container01_box_sec {
  margin-bottom: 12rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sub_mass_production_container01_box_disc {
  width: 46.66%;
}
.sub_mass_production_container01_box_disc .common_txt01 .cl_txt {
  font-weight: 700;
  color: #ed5e13;
}
.sub_mass_production_container01_box_img {
  width: 48.33%;
}
.sub_mass_production_container01_box_ttl {
  display: flex;
  align-items: center;
  margin-bottom: 1.5rem;
  position: relative;
  padding-left: 48px;
}
.sub_mass_production_container01_box_ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  left: 0px;
  width: 14px;
  height: 14px;
  border: 1px solid #004ea2;
  border-radius: 50%;
}
.sub_mass_production_container01_box_ttl::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  left: 14px;
  width: 22px;
  height: 1px;
  background: #004ea2;
  transition: 0.3s;
}
.sub_mass_production_container01_box_ttl .common_en01 {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #004ea2;
  display: flex;
  align-items: center;
  margin-right: 1.5rem;
}
.sub_mass_production_container01_box_ttl .common_en01 .big_txt {
  font-size: 4.2rem;
  margin-left: 1rem;
  font-weight: 500;
  position: relative;
  top: -2px;
}
.sub_mass_production_container01_box_ttl .h3_ttl {
  color: #004ea2;
  border: 2px solid #004ea2;
  border-radius: 9999px;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  min-width: 8rem;
  height: 3.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  padding: 0 2rem;
}
.sub_mass_production_container01_box_catch {
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: 3rem;
}
.sub_mass_production_container01_box_catch .common_en02 {
  font-size: 3.8rem;
}
.sub_mass_production_container02_bg {
  display: flex;
  justify-content: center;
  padding: 7rem 0;
  position: relative;
  background-color: #d2dfee;
}
.sub_mass_production_container02_bg::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translate(-50%, 0);
  bottom: -24px;
  width: 80px;
  height: 25px;
  background: #d2dfee;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.sub_mass_production_container02_ttl {
  background: #004ea2;
  color: #fff;
  font-size: 3.2rem;
  letter-spacing: 0.05em;
  font-weight: 700;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 9999px;
  width: 62rem;
  height: 6rem;
  margin-left: auto;
  margin-right: auto;
}
.sub_mass_production_container02_box {
  position: relative;
  display: flex;
  justify-content: center;
  padding: 0 6rem;
  margin-top: 5rem;
}
.sub_mass_production_container02_box ul {
  display: flex;
  flex-wrap: wrap;
  gap: 3rem;
}
.sub_mass_production_container02_box ul li {
  width: calc((100% - 6rem) / 3);
  margin-bottom: 1rem;
  position: relative;
}
.sub_mass_production_container02_box ul li::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  left: 0px;
  width: 70px;
  height: 70px;
}
.sub_mass_production_container02_box ul li.icon01::before {
  background: url(../images/top/top_service_icon01.png) no-repeat left top;
  background-size: contain;
}
.sub_mass_production_container02_box ul li.icon02::before {
  background: url(../images/top/top_service_icon02.png) no-repeat left top;
  background-size: contain;
}
.sub_mass_production_container02_box ul li.icon03::before {
  background: url(../images/top/top_service_icon03.png) no-repeat left top;
  background-size: contain;
}
.sub_mass_production_container02_box ul li .fuki {
  background-color: #fff;
  padding: 1rem 1.5rem 1rem 2rem;
  border-radius: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  position: relative;
  min-height: 70px;
  margin-left: 90px;
  display: flex;
  align-items: center;
}
.sub_mass_production_container02_box ul li .fuki::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  left: -11px;
  width: 12px;
  height: 16px;
  background: #fff;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
}
.sub_mass_production_container02_box ul li .fuki .cl_txt {
  color: #004ea2;
}
.sub_mass_production_container03_bg {
  display: flex;
  justify-content: center;
  padding: 12rem 0 11rem 0;
  background: #f5f7fb;
}
.sub_mass_production_container04_bg {
  display: flex;
  justify-content: center;
  padding: 12rem 0 11rem 0;
}
.sub_mass_production_container04_bg .common_sub_item_box {
  gap: 3.5rem;
}
.sub_mass_production_container04_bg .common_sub_item_box .sub_mass_production_h3_ttl {
  border: 1px solid #004ea2;
  border-radius: 9999px;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  box-sizing: border-box;
  height: 60px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.4;
  text-align: center;
  position: relative;
  background-color: #f5f7fb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #074e9b;
  width: 100%;
}
.sub_mass_production_container04_bg .common_sub_item_box .sub_mass_production_h3_ttl::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translate(-50%, 0);
  bottom: -16px;
  width: 26px;
  height: 16px;
  background: #004ea2;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.sub_mass_production_container04_bg .common_sub_item_box .sub_mass_production_h3_ttl::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translate(-50%, 0);
  bottom: -15px;
  width: 25px;
  height: 16px;
  background: #f5f7fb;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.sub_mass_production_container04_bg .common_sub_item_box .sub_mass_production_h3_ttl .deco {
  font-size: 1.4rem;
  font-weight: 500;
}
.sub_mass_production_container05_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background: #f5f7fb;
}
.sub_mass_production_container06_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
}
.sub_mass_production_container06_bg .common_sub_item_box {
  display: flex;
  justify-content: space-between;
}
.sub_mass_production_container06_bg .common_sub_item_box .sub_item_dd_wrap {
  border-radius: 20px;
  overflow: hidden;
  width: 41.67%;
}
.sub_mass_production_container06_bg .common_sub_item_box .sub_item_dd_wrap dl {
  display: flex;
  border-bottom: 1px solid #e6e8ed;
}
.sub_mass_production_container06_bg .common_sub_item_box .sub_item_dd_wrap dl:last-of-type {
  border-bottom: none;
}
.sub_mass_production_container06_bg .common_sub_item_box .sub_item_dd_wrap dl dt {
  font-weight: 500;
  background-color: #004ea2;
  color: #fff;
  width: 36%;
  padding: 6rem 3rem;
  display: flex;
  align-items: center;
}
.sub_mass_production_container06_bg .common_sub_item_box .sub_item_dd_wrap dl dd {
  color: #354362;
  background-color: #f9f9f9;
  font-weight: 500;
  width: 64%;
  padding: 6rem 3rem;
  display: flex;
  align-items: center;
}
.sub_mass_production_container06_bg .common_sub_item_box .sub_item_img_wrap {
  width: 53.33%;
}
.sub_mass_production_container07_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 3rem 0;
  background: #f5f7fb;
}
.sub_mass_production_container08_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 3rem 0;
}

.power_device .common_sub_menu_box01 ul li {
  width: calc((100% - 5rem) / 6);
}

/*design*/
.design .common_sub_main .common_w_inner {
  background: url(../images/design/design_mainimg.png) no-repeat center center;
  background-size: cover;
}

.sub_design_container01_bg {
  padding: 7rem 0 12.5rem 0;
}
.sub_design_container01_bg .common_inner,
.sub_design_container01_bg .common_m_inner {
  margin-left: auto;
  margin-right: auto;
}
.sub_design_container01_bg .common_sub_h2_ttl02_sml {
  margin-bottom: 3rem;
}
.sub_design_container01_bg .common_txt01.center {
  text-align: center;
}
.sub_design_container01_bg .sub_company_txt01 {
  text-align: center;
  font-size: 2.6rem;
  font-weight: 700;
  margin-bottom: 2rem;
  color: #074e9b;
}
.sub_design_container01_bg .sub_company_box_ttl {
  width: 20rem;
}
.sub_design_container01_bg .sub_comment_box {
  display: flex;
  gap: 3rem;
  padding-bottom: 2rem;
  margin-bottom: 3rem;
}
.sub_design_container01_bg .sub_comment_box .comment_wrap {
  background-color: #ecf1fa;
  border-radius: 25px;
  padding: 2rem 1rem;
  max-width: 380px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.sub_design_container01_bg .sub_comment_box .comment_wrap::before {
  position: absolute;
  content: "";
  background-color: #ecf1fa;
  width: 25px;
  height: 20px;
  clip-path: polygon(100% 0, 0 0, 50% 100%);
  bottom: -18px;
  left: 50%;
  transform: translateX(-50%);
}
.sub_design_container01_bg .sub_comment_box .comment_wrap.wrap01::before {
  width: 20px;
  clip-path: polygon(100% 0, 0 0, 100% 100%);
}
.sub_design_container01_bg .sub_comment_box .comment_wrap.wrap03::before {
  width: 20px;
  clip-path: polygon(100% 0, 0 0, 0 100%);
}
.sub_design_container01_bg .sub_comment_box .comment_wrap .common_txt01 {
  font-weight: bold;
  text-align: center;
}
.sub_design_container01_bg .sub_txt_wrap {
  margin-bottom: 6rem;
}
.sub_design_container01_bg .ft_contact_btn.btn01 {
  margin: 0 auto;
}
.sub_design_container01_bg .ft_contact_btn.btn01 .btn_bf {
  border: 1px solid #007fc8;
  color: #004ea2;
  background: #fff;
}
.sub_design_container01_bg .ft_contact_btn.btn01 .btn_bf::after {
  background: #fff;
}
.sub_design_container01_bg .ft_contact_btn.btn01 a {
  background: linear-gradient(to right, #004ea2, #14b6f2);
  border: 1px solid #acd5ff;
}
.sub_design_container01_bg .ft_contact_btn.btn01 .icon_txt {
  color: #fff;
}
.sub_design_container01_bg .ft_contact_btn.btn01 .icon_txt::before {
  background: url(../images/common/icon_mail_wh.svg);
  background-size: contain;
}
.sub_design_container02_bg {
  display: flex;
  justify-content: center;
  padding: 11rem 0;
  position: relative;
  background-color: #f5f7fb;
}
.sub_design_container02_bg .common_sub_h2_ttl02_sml {
  margin-bottom: 5rem;
}
.sub_design_container02_bg .sub_design_box {
  margin-bottom: 6rem;
}
.sub_design_container02_bg .sub_design_box .sub_h3_ttl {
  font-weight: 700;
  font-size: 2.2rem;
  padding-left: 4rem;
  position: relative;
  margin-bottom: 2rem;
}
.sub_design_container02_bg .sub_design_box .sub_h3_ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  left: 0px;
  width: 10px;
  height: 10px;
  border: 1px solid #004ea2;
  border-radius: 50%;
}
.sub_design_container02_bg .sub_design_box .sub_h3_ttl::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  left: 10px;
  width: 16px;
  height: 1px;
  background: #004ea2;
  transition: 0.3s;
}
.sub_design_container02_bg .sub_design_box > .common_txt01 {
  margin-bottom: 5rem;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5rem 4rem;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap .design_box_in .box_ttl {
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  background-color: #004ea2;
  padding: 1.5rem 0;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.1rem;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap .design_box_in .box_ttl .common_en02 {
  font-size: 3rem;
  margin-left: 1rem;
  font-weight: 500;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap .design_box_in .box_flex {
  display: flex;
  padding: 4rem;
  background-color: #fff;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap .design_box_in .box_flex .box_img_wrap {
  width: 50%;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap .design_box_in .box_flex .box_img_wrap .btn_zoom {
  position: relative;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap .design_box_in .box_flex .box_img_wrap .btn_zoom::after {
  content: "";
  position: absolute;
  bottom: 5px;
  right: 5px;
  width: 32px;
  height: 32px;
  background: url(../images/common/icon_zoom.svg) no-repeat left top;
  background-size: contain;
}
.sub_design_container02_bg .sub_design_box .design_box01_wrap .design_box_in .box_flex .box_detail_wrap {
  width: 50%;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap {
  display: flex;
  justify-content: space-between;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in01 {
  width: 31.66%;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in01 .box_img_wrap {
  margin-bottom: 2.5rem;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in02 {
  width: 31.66%;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in02 .box_img_wrap {
  margin-bottom: 2.5rem;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in03 {
  width: 30.916%;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in03 .box_comment_wrap {
  padding-left: 2rem;
  position: relative;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in03 .box_comment_wrap::before {
  position: absolute;
  content: "";
  background-color: #004ea2;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
  width: 20px;
  height: 40px;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  z-index: 0;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in03 .box_comment_wrap::after {
  position: absolute;
  content: "";
  background-color: #fff;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
  width: 19px;
  height: 39px;
  top: 50%;
  transform: translateY(-50%);
  left: 2px;
  z-index: 1;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in03 .box_comment_wrap .comment {
  background-color: #fff;
  border: 1px solid #004ea2;
  font-size: 2rem;
  font-weight: 700;
  border-radius: 20px;
  padding: 7rem 5rem;
}
.sub_design_container02_bg .sub_design_box.box02 .design_box01_wrap .in03 .box_comment_wrap .comment .blue {
  color: #004ea2;
}
.sub_design_container03_bg {
  background-image: url(../images/design/design_img09.png) !important;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  padding: 8rem 0 7rem 0;
  background: #f5f7fb;
}
.sub_design_container03_bg .ft_contact_btn.btn01 {
  margin: 0 auto;
  width: 52rem;
  height: 9rem;
}
.sub_design_container03_bg .ft_contact_btn.btn01 .btn_bf {
  width: 42rem;
  height: 3.7rem;
  font-size: 1.6rem;
  padding: 0 1rem;
}
.sub_design_container03_bg .ft_contact_btn.btn01 .icon_txt {
  font-size: 2.4rem;
}
.sub_design_container03_bg .ft_contact_btn.btn01 .icon_txt::before {
  width: 32px;
  height: 22px;
}
.sub_design_container04_bg {
  display: flex;
  justify-content: center;
  padding: 12rem 0 11rem 0;
  background-color: #f5f7fb;
}
.sub_design_container05_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background-color: #fff;
}
.sub_design_container06_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background: #f5f7fb;
  margin-bottom: 6rem;
}

.power_device .common_sub_menu_box01 ul li {
  width: calc((100% - 5rem) / 6);
}

/*prototype:スライダー*/
.sub_slider_wrap {
  max-width: 1400px;
  overflow: hidden;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  position: relative;
  width: 100%;
}

.swiper-container {
  padding: 40px 0;
  position: relative;
  width: 1200px;
  overflow: hidden;
  margin: 0 10rem;
}

.swiper-slide {
  height: 200px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
}

/* ボタンを外に出す */
.custom-prev,
.custom-next {
  position: absolute;
  top: 50%;
  z-index: 10;
  width: 42px;
  height: 42px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  cursor: pointer;
}

.swiper-button-prev::after,
.swiper-button-next::after {
  display: none;
}

.custom-prev {
  left: 0;
  margin-left: 2rem;
  background-image: url("../images/prototype/prototype_arrow01.png");
}

.custom-next {
  right: 0;
  margin-right: 2rem;
  background-image: url("../images/prototype/prototype_arrow02.png");
}

/*prototype:メイン*/
.sub_prototype_container01_bg {
  padding: 7rem 0 11rem 0;
}
.sub_prototype_container01_bg .common_inner,
.sub_prototype_container01_bg .common_m_inner {
  margin-left: auto;
  margin-right: auto;
}
.sub_prototype_container01_bg .common_txt01.center {
  text-align: center;
}
.sub_prototype_container01_bg .sub_company_txt01 {
  text-align: center;
  font-size: 2.6rem;
  font-weight: 700;
  margin-bottom: 2rem;
  color: #074e9b;
}
.sub_prototype_container01_bg .sub_company_box {
  margin-bottom: 5rem;
}
.sub_prototype_container01_bg .sub_company_box_ttl {
  width: 20rem;
}
.sub_prototype_container01_bg .sub_txt_box {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 4rem;
  gap: 1.5rem;
}
.sub_prototype_container01_bg .sub_txt_box .sub_ttl_txt {
  font-size: 2.8rem;
  font-weight: bold;
  letter-spacing: 0.1rem;
  position: relative;
  line-height: 1;
}
.sub_prototype_container01_bg .sub_txt_box .sub_ttl_txt::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 40%;
  bottom: 0;
  left: 0;
  background-color: #ffee5f;
  z-index: -1;
}
.sub_prototype_container01_bg .sub_txt_box .sub_ttl_txt .big {
  font-size: 3.8rem;
}
.sub_prototype_container01_bg .sub_txt_box .sub_ttl_txt .big_m {
  font-size: 3.4rem;
}
.sub_prototype_container01_bg .sub_txt_wrap {
  margin-bottom: 9rem;
}
.sub_prototype_container01_bg .ft_contact_btn.btn01 {
  margin: 0 auto;
}
.sub_prototype_container01_bg .ft_contact_btn.btn01 .btn_bf {
  border: 1px solid #007fc8;
  color: #004ea2;
  background: #fff;
}
.sub_prototype_container01_bg .ft_contact_btn.btn01 .btn_bf::after {
  background: #fff;
}
.sub_prototype_container01_bg .ft_contact_btn.btn01 a {
  background: linear-gradient(to right, #004ea2, #14b6f2);
  border: 1px solid #acd5ff;
}
.sub_prototype_container01_bg .ft_contact_btn.btn01 .icon_txt {
  color: #fff;
}
.sub_prototype_container01_bg .ft_contact_btn.btn01 .icon_txt::before {
  background: url(../images/common/icon_mail_wh.svg);
  background-size: contain;
}
.sub_prototype_container02_bg {
  display: flex;
  justify-content: center;
  padding: 5rem 0;
  position: relative;
  background-color: #f5f7fb;
}
.sub_prototype_container02_bg .common_sub_menu_box01 ul {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin: 4rem 0;
}
.sub_prototype_container02_bg .common_sub_menu_box01 ul li {
  width: 100%;
  max-width: 164px;
}
.sub_prototype_container02_bg .common_sub_menu_box01 ul li a {
  font-size: 1.6rem;
  text-align: center;
}
.sub_prototype_container03_bg {
  display: flex;
  justify-content: center;
  padding: 12rem 0 12rem 0;
  background: #fff;
}
.sub_prototype_container03_bg .common_sub_h2_ttl02_sml {
  color: #354362;
}
.sub_prototype_container03_bg .sub_figure_box.box01 {
  margin-top: 8rem;
  display: flex;
  margin-bottom: 10rem;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item {
  display: flex;
  align-items: stretch;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block {
  padding: 4rem;
  border-radius: 20px;
  box-shadow: 0px 0px 30px -6px rgba(8, 24, 46, 0.3);
  position: relative;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block .sub_figure_ttl_wrap {
  padding: 0 5rem;
  position: absolute;
  top: -3rem;
  left: 0;
  width: 100%;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block .sub_figure_ttl {
  font-size: 2.2rem;
  font-weight: bold;
  color: #fff;
  padding: 1.5rem 2rem;
  background: linear-gradient(to right, #004ea2, #14b6f2);
  border-radius: 30px;
  display: block;
  text-align: center;
  width: 100%;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block.block01 {
  padding-top: 7rem;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block.block02 {
  padding-top: 7rem;
  width: 100%;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block.block02 .sub_figure_block_in_wrap {
  display: flex;
  gap: 4rem;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block.block02 .sub_figure_block_in_wrap .sub_figure_block_in .figure_block_in_txt {
  font-size: 2rem;
  color: #004ea2;
  font-weight: bold;
  background-color: #dbe4f5;
  padding: 1rem;
  border-radius: 10px;
  display: block;
  width: 100%;
  text-align: center;
  margin-bottom: 2rem;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block.block02 .sub_figure_block_in_wrap .sub_figure_block_in.in01 {
  width: 50%;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block.block02 .sub_figure_block_in_wrap .sub_figure_block_in.in02 {
  width: 50%;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item .sub_figure_block.block02 .sub_figure_block_in_wrap .sub_figure_block_in.in02 .figure_block_in_img {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 2rem;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item.item01 {
  width: 30%;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item.item01 .figure_block_txt {
  font-size: 2rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 4rem;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_item.item02 {
  width: 61.66%;
}
.sub_prototype_container03_bg .sub_figure_box .sub_figure_arrow01 {
  width: 8.34%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1rem;
}
.sub_prototype_container03_bg .sub_figure_box.box02 {
  border: 1px solid #004ea2;
  border-radius: 20px;
  background-color: #f9f9f9;
  padding: 5rem 6rem;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_h3_ttl {
  font-size: 2.2rem;
  font-weight: bold;
  color: #fff;
  background-color: #004ea2;
  padding: 1rem;
  border-radius: 25px;
  max-width: 460px;
  text-align: center;
  margin: 0 auto;
  margin-bottom: 4.5rem;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap {
  display: flex;
  gap: 3rem;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block {
  width: 33.3333333333%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block .sub_figure_comment01 {
  padding-left: 2rem;
  width: 77%;
  margin-left: auto;
  margin-right: 0;
  position: relative;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block .sub_figure_comment01::before {
  position: absolute;
  content: "";
  background-color: #fff;
  clip-path: polygon(100% 0, 0 50%, 100% 100%);
  width: 2rem;
  height: 2rem;
  top: 50%;
  transform: translateY(-50%);
  left: 1rem;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block .sub_figure_comment01::after {
  position: absolute;
  content: "";
  background-image: url(../images/top/top_service_icon02.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 7rem;
  height: 7rem;
  top: 50%;
  transform: translateY(-50%);
  left: -77px;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block .sub_figure_comment01 .comment {
  font-weight: bold;
  background-color: #fff;
  border-radius: 20px;
  padding: 1.5rem 2rem;
  display: block;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block .sub_figure_arrow02 {
  height: 5rem;
  position: relative;
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block .sub_figure_arrow02::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  background-color: #004ea2;
  width: 42px;
  height: 16px;
  clip-path: polygon(100% 0, 0 0, 49% 100%);
}
.sub_prototype_container03_bg .sub_figure_box.box02 .sub_figure_comment_wrap .sub_figure_comment_block .sub_figure_comment02 {
  border: 1px solid #004ea2;
  border-radius: 20px;
  height: 100%;
  padding: 2rem;
  background-color: #fff;
}
.sub_prototype_container04_bg {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12rem 0 11rem 0;
  background-color: #f5f7fb;
}
.sub_prototype_container04_bg .common_txt01.center {
  text-align: center;
}
.sub_prototype_container04_bg .common_sub_h2_ttl02_sml {
  margin-bottom: 5rem;
}
.sub_prototype_container04_bg .common_sub_h2_ttl02_sml_hosoku02 {
  font-size: 2rem;
  text-align: center;
  font-weight: bold;
}
.sub_prototype_container04_bg .common_sub_h2_ttl02_sml_hosoku02 span {
  padding: 0 1rem;
  position: relative;
}
.sub_prototype_container04_bg .common_sub_h2_ttl02_sml_hosoku02 span::before {
  position: absolute;
  content: "";
  background-color: #004ea2;
  width: 1px;
  height: 30px;
  transform: rotate(-30deg) translateY(-50%);
  top: 50%;
  left: 0;
}
.sub_prototype_container04_bg .common_sub_h2_ttl02_sml_hosoku02 span::after {
  position: absolute;
  content: "";
  background-color: #004ea2;
  width: 1px;
  height: 30px;
  transform: rotate(30deg) translateY(-50%);
  top: 50%;
  right: 0;
}
.sub_prototype_container04_bg .sub_slider_wrap {
  margin-bottom: 10rem;
}
.sub_prototype_container04_bg .sub_figure_h3_ttl {
  background: #004ea2;
  color: #fff;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  font-weight: 700;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 9999px;
  width: 46rem;
  height: 5rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 3rem;
  margin-top: 2rem;
}
.sub_prototype_container04_bg .sub_contents_box .sub_contents_block.block01 {
  display: flex;
  gap: 4rem;
  margin-bottom: 5rem;
  margin-top: 6rem;
  flex-wrap: wrap;
}
.sub_prototype_container04_bg .sub_contents_box .sub_contents_block.block01 .common_sub_item_sn {
  width: calc((100% - 8rem) / 2);
}
.sub_prototype_container04_bg .sub_contents_box .sub_contents_block.block01 .common_sub_item_sn .common_sub_item_sn_name {
  text-align: left;
}
.sub_prototype_container04_bg .sub_contents_box .sub_contents_block.block01 .common_sub_item_sn .common_sub_item_sn_name .min {
  font-size: 1.4rem;
  margin-left: 1rem;
  font-weight: 500;
}
.sub_prototype_container04_bg .sub_contents_box .sub_contents_block.block01 .common_sub_item_sn .common_sub_item_sn_img {
  background-color: #fff;
  border-radius: 20px;
}
.sub_prototype_container04_bg .sub_contents_box .sub_contents_block.block02 {
  border: 1px solid #004ea2;
  border-radius: 20px;
  background-color: #fff;
  padding: 2rem;
  text-align: center;
  margin-bottom: 6rem;
  flex-wrap: wrap;
}
.sub_prototype_container04_bg .sub_contents_box.box02 .common_sub_item_sn {
  width: calc((100% - 12rem) / 4) !important;
}
@media screen and (max-width: 1125px) {
  .sub_prototype_container04_bg .sub_contents_box.box02 .common_sub_item_sn {
    width: calc((100% - 8rem) / 2) !important;
  }
}
.sub_prototype_container04_bg .sub_table_wrap {
  margin-top: 4rem;
}
.sub_prototype_container05_bg {
  background-image: url(../images/design/design_img09.png) !important;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  padding: 8rem 0 7rem 0;
  background: #f5f7fb;
}
.sub_prototype_container05_bg .btn01 {
  margin: 0 auto;
  width: 52rem;
  height: 9rem;
}
.sub_prototype_container05_bg .btn01 .btn_bf {
  width: 46rem;
  height: 3.7rem;
  font-size: 1.6rem;
  padding: 0 1rem;
}
.sub_prototype_container06_bg {
  display: flex;
  justify-content: center;
  padding: 12rem 0 11rem 0;
  background: #fff;
}
.sub_prototype_container06_bg .sub_h2_ttl_wrap {
  display: flex;
  justify-content: center;
}
.sub_prototype_container06_bg .sub_h2_ttl_wrap .common_sub_h2_ttl02_sml {
  display: inline-block;
  position: relative;
  padding: 0 29rem;
}
.sub_prototype_container06_bg .sub_h2_ttl_wrap .h2_sub_ttl {
  background-image: url(../images/prototype/prototype_img37.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 27.4rem;
  height: 7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.4rem;
  font-weight: bold;
  color: #fff;
  position: absolute;
  top: -20px;
  left: 0;
}
.sub_prototype_container06_bg .sub_contents_txt_wrap .common_txt01 {
  width: 66.66%;
  margin: 6rem auto;
}
.sub_prototype_container06_bg .sub_contents_txt_wrap .common_txt01 .cl_txt {
  font-weight: 700;
  color: #ed5e13;
}
.sub_prototype_container06_bg .sub_contents_img_box {
  display: flex;
  gap: 5rem;
}
.sub_prototype_container06_bg .sub_contents_img_box.box01 {
  margin-bottom: 9rem;
}
.sub_prototype_container06_bg .sub_contents_img_box .common_txt01 {
  text-align: center;
  font-weight: bold;
  margin-top: 1rem;
}
.sub_prototype_container06_bg .sub_contents_img_box.box02 {
  gap: 3rem;
}
.sub_prototype_container06_bg .sub_contents_img_box.box02 .contents_img_block {
  position: relative;
}
.sub_prototype_container06_bg .sub_contents_img_box.box02 .contents_img_block .img_wrap {
  position: relative;
}
.sub_prototype_container06_bg .sub_contents_img_box.box02 .contents_img_block .img_wrap::before {
  content: "";
  position: absolute;
  background-color: #004ea2;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
  width: 18px;
  height: 18px;
  top: 50%;
  transform: translateY(-50%);
  right: -25px;
}
.sub_prototype_container06_bg .sub_contents_img_box.box02 .contents_img_block:last-of-type .img_wrap::before {
  display: none;
}
.sub_prototype_container06_bg .sub_contents_img_box.box02 .contents_img_block .img_sub_num {
  background: linear-gradient(to right, #004ea2, #14b6f2);
  width: 42px;
  height: 42px;
  border-radius: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -18px;
  left: 10px;
  color: #fff;
  font-weight: 500;
  z-index: 10;
}
.sub_prototype_container06_bg .sub_contents_img_box.box02 .common_txt01 {
  text-align: left;
}
.sub_prototype_container06_bg .sub_h3_ttl_wrap .sub_h3_ttl {
  font-size: 2.6rem;
  font-weight: bold;
  color: #004ea2;
  padding: 0 8rem;
  margin: 0 auto;
  width: fit-content;
  position: relative;
}
.sub_prototype_container06_bg .sub_h3_ttl_wrap .sub_h3_ttl::before {
  position: absolute;
  content: "";
  height: 1px;
  width: 60px;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  background-color: #004ea2;
}
.sub_prototype_container06_bg .sub_h3_ttl_wrap .sub_h3_ttl::after {
  position: absolute;
  content: "";
  height: 1px;
  width: 60px;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  background-color: #004ea2;
}
.sub_prototype_container06_bg .sub_h3_ttl_wrap .common_txt01 {
  width: 66.66%;
  margin: 3rem auto 6rem auto;
  text-align: center;
}
.sub_prototype_container07_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background: #f5f7fb;
}
.sub_prototype_container07_bg .common_txt01 {
  text-align: center;
  margin-top: 3rem;
}
.sub_prototype_container07_bg .sub_contents_block {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 3rem;
  margin-top: 6rem;
}
.sub_prototype_container07_bg .sub_contents_block .common_sub_item_sn {
  width: calc((100% - 6rem) / 3);
}
.sub_prototype_container08_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background: #fff;
  margin-bottom: 6rem;
}
.sub_prototype_container08_bg .common_sub_h2_ttl02_sml {
  margin-bottom: 3rem;
}
.sub_prototype_container08_bg .common_txt01.center {
  text-align: center;
}
.sub_prototype_container08_bg .sub_prototype_h3_ttl {
  border: 1px solid #004ea2;
  border-radius: 9999px;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  box-sizing: border-box;
  height: 60px;
  max-width: 520px;
  margin-top: 5rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 3rem;
  line-height: 1.4;
  text-align: center;
  position: relative;
  background-color: #f5f7fb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #074e9b;
  width: 100%;
}
.sub_prototype_container08_bg .sub_prototype_h3_ttl::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translate(-50%, 0);
  bottom: -16px;
  width: 26px;
  height: 16px;
  background: #004ea2;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.sub_prototype_container08_bg .sub_prototype_h3_ttl::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translate(-50%, 0);
  bottom: -15px;
  width: 25px;
  height: 16px;
  background: #f5f7fb;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.sub_prototype_container08_bg .sub_prototype_h3_ttl .deco {
  font-size: 1.4rem;
  font-weight: 500;
}
.sub_prototype_container09_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 10rem 0;
  background: #fff;
}
.sub_prototype_container09_bg .common_sub_h2_ttl02_sml {
  margin-bottom: 3rem;
}
.sub_prototype_container09_bg .contents_img_wrap {
  display: flex;
  justify-content: center;
  margin: 9rem 0;
}
.sub_prototype_container09_bg .sub_contents_box.box02 {
  display: flex;
  gap: 4rem;
  margin-bottom: 5rem;
}
.sub_prototype_container09_bg .sub_contents_box.box02 .sub_contents_block {
  width: calc((100% - 8rem) / 2);
}
.sub_prototype_container09_bg .sub_contents_box.box02 .contents_img_wrap {
  margin: 3rem 0;
}
.sub_prototype_container09_bg .sub_contents_box.box03 .sub_contents_block_wrap {
  display: flex;
  gap: 4rem;
}
.sub_prototype_container09_bg .sub_contents_box.box03 .sub_contents_block_wrap .sub_contents_block.block01 {
  width: 58.33%;
}
.sub_prototype_container09_bg .sub_contents_box.box03 .sub_contents_block_wrap .sub_contents_block.block02 {
  width: 41.67%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sub_prototype_container09_bg .sub_contents_box.box03 .sub_contents_block_wrap .sub_contents_block.block02 .common_btn01 {
  max-width: 46rem;
  width: 100%;
  height: 8rem;
}
.sub_prototype_container09_bg .sub_contents_box.box03 .sub_contents_block_wrap .contents_img_wrap {
  margin-top: 5rem;
}
.sub_prototype_container10_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background: #f5f7fb;
  margin-bottom: 6rem;
}
.sub_prototype_container11_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background: #fff;
  margin-bottom: 6rem;
}
.sub_prototype_container12_bg {
  display: flex;
  justify-content: center;
  padding: 10rem 0 11rem 0;
  background: #f5f7fb;
  margin-bottom: 6rem;
}/*# sourceMappingURL=pc02.css.map */