@charset "utf-8";
/* CSS Document */
/*--------------------------------------
　Main Index
---------------------------------------*/
#contents {
 width: 100%;
 margin: 0 auto 19rem;
}
#toc .chapter .chapter-h:first-child {
 display: none;
}
/*--------------------------------------
　visArea TOPページ
---------------------------------------*/
#visArea {
 margin: 0 auto;
 overflow: hidden;
}
#visArea .mainArea {
 background: #fff;
 display: block;
 max-width: 100%;
 height: auto;
 padding: 0 1.5rem;
}
#visArea .mainArea .mainAreaInner {
 max-width: 1350px;
 min-height: 609px;
 display: block;
 position: relative;
 z-index: 0;
 margin: 0 auto;
 padding: 2.8rem 0 6.3rem;
}
#visArea .mainArea .mainAreaInner::after {
 content: "";
 width: calc(100% - 8vw);
 width: 100%;
 height: 100%;
 position: absolute;
 background: url(img/mv_pic_pc.jpg) no-repeat right bottom;
 background-size: cover;
 left: 8vw;
 z-index: -1;
 top: 0;
}
#visArea .mainArea__item {
 margin: 0 auto 0 0;
 width: 750px;
 max-width: 100%;
 text-align: left;
}
#visArea .mainArea .siteNameArea {
 margin: 0 0 30px;
}
#visArea .mainArea .siteName {
 margin: 0 auto 9rem;
}
#visArea .mainArea .siteName img {
 width: 160px;
 margin: 0 auto 0 0;
}
#visArea .mainArea .siteNameSmall {
 font-size: 1.6rem;
}
#visArea .mainArea .mainTxtBox {
 width: 100%;
 padding: 0;
 margin: 0 auto;
}
#visArea .mainArea .catchArea {
 position: relative;
 z-index: 0;
 margin: 0 auto 2.5rem;
}
#visArea .mainArea .catchArea::after {
 content: "";
 width: 100%;
 height: 124px;
 background: #fff;
 position: absolute;
 bottom: 0;
 left: 0;
 z-index: -1;
}
#visArea .mainArea .catchArea .catch {
 font-size: 4rem;
 font-weight: bold;
 line-height: 1.6;
 text-align: left;
 color: #010101;
 margin: 0 auto;
 padding: 0 0 3.3rem 1.3rem;
 letter-spacing: 0.15em;
}
#visArea .mainArea .catchArea .catch .green {
 color: #4b887d;
}
#visArea .mainArea .txtArea {
 text-align: left;
 font-size: 1.76rem;
}
#visArea .mainArea .txtArea p {
 color: #010101;
 max-width: 100%;
}
#visArea .mainArea .txtArea p + p {
 margin-top: 1.5rem;
}
/*--------------------------------------
オリジナル
---------------------------------------*/
.frame-wrap + .btn-accordion {
 margin-top: 5rem;
}
/***** h2 *****/
.addTopArea02 {
 width: 100%;
 margin: 3rem auto 6.6rem;
 display: flex;
 justify-content: space-between;
}
.addTopArea02 .addTopPic {
 width: 354px;
 position: relative;
 order: 2;
 flex-shrink: 0;
 max-width: 100%;
}
.addTopArea02 .addTopPic img {
 display: block;
 margin: 0 auto;
 box-shadow: 12px -12px 0 0 #dadada;
}
.addTopArea02 .addTopTxt {
 width: 707px;
 order: 1;
}
.addTopArea02 .sttl {
 display: block;
 text-align: left;
 background-size: 40px auto;
 position: relative;
 margin: 0 auto 9rem;
 font-size: 4.0rem;
 letter-spacing: 0.015em;
 color: #010101;
 border-bottom: 2px solid #111;
 padding: 0 1.6rem 1.7rem 0;
 font-weight: bold;
 line-height: 1.3;
}
.addTopArea02 .sttl::before {
 content: "";
 display: block;
 width: 100vw;
 height: 146px;
 background: #ffefbc;
 position: absolute;
 right: 35px;
 bottom: -57px;
 z-index: -1;
}
.addTopArea02 .sttl::after {
 content: "";
 display: block;
 width: 100%;
 height: 38px;
 background: url("img/addTopArea02_feature.png") no-repeat bottom 0 left 4px;
 position: absolute;
 bottom: -38px;
 left: 0;
 z-index: -1;
}
.addTopArea02 .sttl a {
 display: block;
 background-size: 34px auto;
}
.addTopArea02 .addTxt {
 width: auto;
 font-size: 1.6rem;
}
.interviewTitArea { 
 margin: 3.5rem 0 9rem; 
 position: relative;
 z-index: 1;
}
.interviewTitArea::after {
 content: "";
 width: 100%;
 height: 36px;
 background: url("img/interviewTit_en.png") no-repeat;
 background-size: auto 100%;
 position: absolute;
 top: -35px;
 left: 0;
}
.interviewTitArea .interviewTit {
 background-color: #fff;
 font-size: 4rem;
 font-weight: bold;
 line-height: 1.55;
 padding: 4.8rem 8rem 4.8rem 0;
 color: #010101;
 box-sizing: border-box;
 letter-spacing: 0.015em;
 font-feature-settings: "palt";
 position: relative;
}
.interviewTitArea .interviewTit::after {
 content: "";
 position: absolute;
 top: 0;
 right: 100%;
 bottom: 0;
 margin: auto 0;
 width: 50vw;
 background-color: #fff;
 height: 100%;
}
.interviewTitArea .interviewTit::before {
 content: "";
 width: 100vw;
 height: 100%;
 background: #e2b840;
 position: absolute;
 top: 19px;
 right: 23px;
 z-index: -1;
}
.interviewTitArea .interviewTit a {
 display: block;
}
/***** addParts--mokuji *****/
.addParts--mokuji .btn-accordion {
 margin-top: 0;
}
/***** addParts--recommended *****/
.addParts--recommended .btn-internal a::after {
 transform: translateY(-50%) rotate(90deg);
}
/***** addParts--detail *****/
.addParts--detail {
 width: 100%;
 background-color: #f3f2ea;
 padding: 7rem 0 0;
 position: relative;
}
.addParts--detail::before {
 content: "";
 width: 100%;
 max-width: 80%;
 height: 98px;
 background: url(img/addparts_detail_deco.png) no-repeat center top;
 background-size: auto 100%;
 margin: 0 auto;
 position: absolute;
 left: 0;
 right: 0;
 top: -28px;
}
.addParts--detail .addTopArea .sttl {
 text-align: center;
 background: none;
 font-size: 4.2rem;
 line-height: 61px;
 font-weight: bold;
 padding: 0;
 margin: 0 auto 5rem;
 letter-spacing: 0.15em;
}
.addParts--detail .addTopArea .sttl .small {
 font-size: 3rem;
}
.addParts--detail .addTopArea .sttl .small span {
 font-size: 3.5rem;
}
.addParts--detail .addTxt {
 padding: 0 11%;
}
.addParts--detail .block {
 background-color: #fff;
 padding: 5rem 0 6rem;
 margin: 2rem auto 0;
 position: relative;
}
.addParts--detail .block + .block {
 margin-top: 4rem;
}
.addParts--detail .block::before {
 content: "";
 width: 13px;
 height: 415px;
 background: url("img/detail_block_deco.png") no-repeat;
 background-size: 100% auto;
 position: absolute;
 top: -18px;
 left: 64px;
 z-index: 1;
}
.addParts--detail .blockTitArea {
 text-align: center;
 padding: 0 12rem;
 margin: 0 auto 5rem;
 position: relative;
 z-index: 1;
}
.addParts--detail .blockTitSub {
 font-size: 3.4rem;
 line-height: 1.4;
 text-align: center;
 margin: 0 auto 3rem;
 display: inline-block;
 font-weight: bold;
 border: 1px solid #1f1f1f;
 background-color: #ffefbc;
 border-radius: 8px;
 padding: 1.5rem 3.2rem;
 position: relative;
}
.addParts--detail .blockTitSub::before {
 content: "";
 width: 100%;
 height: 100%;
 position: absolute;
 top: -9px;
 left: -11px;
 background: #ffc523;
 z-index: -1;
 border-radius: 8px;
}
.addParts--detail .blockTit {
 display: block;
 font-size: 3rem;
 font-weight: bold;
 line-height: 1.5;
 text-align: center;
 padding: 0;
 position: relative;
}
.addParts--detail .blockTit .marker {
 border: none;
 display: inline;
 color: inherit;
 font-weight: inherit;
 background: linear-gradient(transparent 75%, rgba(226, 184, 64, 0.4) 75%);
}
.addParts--detail .thum {
 width: 638px;
 margin: 0 auto;
 text-align: center;
}
.addParts--detail .thum .caption {
 color: #999999;
}
.addParts--detail .block__item {
 margin: 6rem auto 0;
 padding: 5rem 4.5rem 0;
 background: url("img/detail_feature_deco.png") no-repeat top left;
}
.addParts--detail .block__item.block__item--voices { background-image: url("img/detail_voices_deco.png"); }
.addParts--detail .block__item.infoArea--information { background-image: url("img/detail_information_deco.png"); }
.addParts--detail .block__item.infoArea--company { background-image: url("img/detail_company_deco.png"); }
.addParts--detail .block__item__title {
 text-align: center;
 font-size: 2.6rem;
 font-weight: bold;
 color: #010101;
 margin: 0 auto 4rem;
}
.addParts--detail .personArea .personBox {
 display: table;
 padding: 3.5rem 4rem 2.5rem;
 position: relative;
 background: #fff;
 border: 1px solid #000;
 width: 100%;
}
.addParts--detail .personArea .personBox + .personBox {
 margin-top: 2rem;
}
.addParts--detail .personArea .personBox .pic {
 display: table-cell;
 vertical-align: top;
 width: 90px;
}
.addParts--detail .personArea .personBox .pic img {
 display: block;
 margin: 0 auto;
}
.addParts--detail .personArea .personBox dl {
 display: table-cell;
 vertical-align: middle;
 padding: 0 0 0 3rem;
}
.addParts--detail .personArea .personBox dl dt {
 font-size: 2.3rem;
 font-weight: bold;
 line-height: 1.4;
 color: #4b887d;
 letter-spacing: 0.03em;
 margin: 0 auto 2rem;
}
.addParts--detail .personArea .personBox dl dd {
 position: relative;
 margin: 0 auto;
 color: #333;
 line-height: 2;
}
.addParts--detail .personArea .personBox dl dd + dd {
 margin-top: 2rem;
}
.addParts--detail .personArea .personBox dl dd.caption--voices {
 text-align: right;
 font-size: 1.4rem;
 color: #9a9a9a;
 line-height: 1.6;
}
.addParts--detail .personMainArea {
 width: 100%;
 padding: 3rem 22.2rem 4rem;
 margin: 7rem 0 4rem;
 position: relative;
 background: #ffebab;
}
.addParts--detail .personMainArea__title {
 background: #fff;
 position: absolute;
 left: 15px;
 top: 0;
 font-size: 1.5rem;
 font-weight: bold;
 color: #010101;
 padding: 1.4rem 2.9rem;
 line-height: 1.5;
}
.addParts--detail .personBox__item--detail {
 padding: 1rem 0 1rem 6.5rem;
 font-size: 1.9rem;
 line-height: 1.4;
 font-weight: bold;
 color: #000;
 background: url(img/detail_list_icon.png) no-repeat left 1rem center;
}
.addParts--detail .personBox__item--detail + p {
 margin: 0;
}
#contents .addParts--detail .infoArea .infoBox table th {
 width: 25%;
 background: #747474;
 font-weight: normal;
}
#contents .addParts--detail .infoArea .infoBox table td {
 background: #f5f5f5;
}
/***** addParts--special *****/
.addParts--special {
 background-color: #ddf4f0;
}
.addParts--special .float-wrap {
 font-size: 1.7rem;
}
.addParts--special .float-wrap .fl {
 width: 392px;
}
.addParts--special .float-wrap .text {
 overflow: hidden;
}
.addParts--special .float-wrap .text p {
 margin-top: 0;
}
/***** addParts--feature *****/
.addParts--feature .addTopArea02 .sttl::after {
 background-image: url("img/addTopArea02_feature.png");
}
/***** addParts--method *****/
.addParts--method .addTopArea02 .sttl::after {
 background-image: url("img/addTopArea02_method.png");
}
/***** addParts--reality *****/
.addParts--reality .addTopArea02 .sttl::after {
 background-image: url("img/addTopArea02_reality.png");
}
/***** addParts--list *****/
.addParts--list .addTopArea02 .sttl::after {
 background-image: url("img/addTopArea02_list.png");
}
.addParts--list .frame-wrap .type-a .frame-head {
 padding-top: 2.6rem;
 border-bottom: solid 1px #635246;
 margin: 0 0 2rem;
}
/***** addParts--host *****/
.addParts--host .addInner {
 padding-top:0;
 padding-bottom:0;
}

@media screen and (max-width: 480px) {
 /* SP */
 /*------------
	Index
	------------*/
 #contents {
  width: 100%;
  margin: 0 auto 10rem;
 } 
 /*--------------------------------------
	　visArea
	---------------------------------------*/
 #visArea {
  margin: 0 auto;
 }
 #visArea .mainArea {
  background: none;
  width: 100%;
  margin: 0 auto;
  padding: 0;
 }
 #visArea .mainArea .mainAreaInner {
  max-width: 100%;
  min-height: unset;
  padding: 48.79807692307692% 0 0;
  background: url("img/mv_pic_pc.jpg") no-repeat top center;
  background-size: 100% auto;
  position: relative;
 }
 #visArea .mainArea .mainAreaInner::after {
  content: none;
 }
 #visArea .mainArea .siteNameArea {
  display: table;
  background: url("img/mv_pic_sp.jpg") center top no-repeat;
  background-size: cover;
  height: 130px;
  width: 100%;
  margin: 0 auto;
 }
 #visArea .mainArea .siteName {
  margin: 0 auto;
  text-align: left;
  position: absolute;
  top: 10vw;
  left: 14.375vw;
  width: 18.75vw;
 }
 #visArea .mainArea .mainTxtBox {
  width: 100%;
  padding: 0;
  margin: 2.2rem auto 0;
 }
 #visArea .mainArea .catchArea {
  margin: 0 auto 2rem;
 }
 #visArea .mainArea .catchArea .catch {
  font-size: 2rem;
  padding: 0 0 0 4%;
  max-width: 96%;
  margin: 0 auto 0 0;
 }
 #visArea .mainArea .catchArea::after {
  content: none;
 }
 #visArea .mainArea .txtArea {
  max-width: 92%;
  margin: 0 auto;
 }
 #visArea .mainArea__item {
  margin: 0 auto;
  width: 100%;
 }
 #visArea .mainArea .siteNameArea {
  margin: 0 0 30px;
 }
 #visArea .mainArea .siteName img.sp {
  margin: 0 auto 0 0;
  width: auto;
 }
 #visArea .mainArea .txtArea p {
  color: #333;
  line-height: 1.71;
  width: 100%;
 }
 /*--------------------------------------
	オリジナル
	---------------------------------------*/
 .addTopArea02 {
  display: block;
  margin: 0 auto 2rem;
 }
 .addTopArea02 .addTopPic {
  width: 100%;
  margin: 0 0 2rem;
 }
 .addTopArea02 .addTopTxt {
  width: 100%;
 }
 .addTopArea02 .sttl {
  margin: 0 auto 5rem;
  font-size: 2rem;
  padding: 0 0 1rem 0;
 }
 .addTopArea02 .sttl::before {
  height: 55px;
  bottom: -30px;
 }
 .addTopArea02 .addTxt {
  font-size: 1.4rem;
 }
 .addTopArea02 .sttl::after {
  background-size: auto 10px;
  height: 20px;
  bottom: -20px;
 }
 .interviewTitArea {
  margin: 2rem 0 6rem;
 }
 .interviewTitArea::after {
  height: 20px;
  top: -19px;
 }
 .interviewTitArea .interviewTit {
  font-size: 2rem;
  padding: 1.4rem 1rem 1.4rem 0;
 }
 /***** addParts--detail *****/
 .addParts--detail {
  padding: 0;
 }
 .addParts--detail::before {
  height: 31px;
  top: -11px;
 }
 .addParts--detail .addTopArea .sttl {
  font-size: 2.4rem;
  letter-spacing: normal;
  line-height: 1.4;
 }
 .addParts--detail .addTopArea .sttl .small {
  font-size: 1.8rem;
 }
 .addParts--detail .addTopArea .sttl .small span {
  font-size: 2rem;
 }
 .addParts--detail .addTxt {
  padding: 0 4%;
 }
 .addParts--detail .block {
  padding: 3rem 0;
 }
 .addParts--detail .block::before {
  width: 10px;
  height: 255px;
  background-size: contain;
  top: -10px;
  left: 9px;
 }
 .addParts--detail .blockTitArea {
  padding: 0 4rem;
  margin: 0 0 2.5rem;
 } 
 .addParts--detail .blockTitSub {
  font-size: 2rem;
 }
 .addParts--detail .blockTit {
  font-size: 1.8rem;
 }
 .addParts--detail .thum {
  width: 100%;
  padding: 0 1.2rem;
 }
 .addParts--detail .thum .caption {
  padding: 0 1rem;
 }
 .addParts--detail .block__item {
  background-size: auto 30px;
  padding: 1.2rem 4% 0;
  margin: 6rem 0 0;
 }
 .addParts--detail .block__item__title {
  font-size: 1.8rem;
 }
 .addParts--detail .personArea .personBox {
  padding: 2rem 4%;
  display: block;
 }
 .addParts--detail .personArea .personBox .pic {
  display: block;
  width: 80px;
  float: left;
  margin: 0 1.5rem 1rem 0.8rem;
 }
 .addParts--detail .personArea .personBox dl {
  display: block;
  width: 100%;
  padding: 1rem 0 0;
 }
 .addParts--detail .personArea .personBox dl dt {
  font-size: 1.6rem;
 }
 .addParts--detail .personMainArea {
  padding: 4.5rem 2rem 2rem 2rem;
  margin: 4rem 0;
 }
 .addParts--detail .personMainArea__title {
  font-size: 1.2rem;
  padding: 1rem 2rem;
 }
 .addParts--detail .personBox__item--detail {
  padding-left:4rem;
  font-size: 1.4rem;
  background-size: 16px auto;
 }
 #contents .addParts--detail .infoArea .infoBox table th,
 #contents .addParts--detail .infoArea .infoBox table td {
  display: table-cell;
 }
 #contents .addParts--detail .infoArea .infoBox table th {
  width: 90px;
 }
 /***** addParts--special *****/
 .addParts--special .float-wrap .fl {
  width: 100%;
 }
 /***** addParts--feature *****/
 /***** addParts--method *****/
 /***** addParts--reality *****/
 /***** addParts--list *****/
 /***** addParts--host *****/


 #visArea .mainArea .siteName img {
    margin: -19px auto 0 -37px;
    display: none;
}
}

