/* ----------------------------------------
タイトル調整
---------------------------------------- */
.c-content__title {margin-bottom:40px;}



/* ----------------------------------------
お問い合わせ頂く前に
---------------------------------------- */
.qaWrap{
  display: flex;
  flex-wrap: nowrap;
}

.qaWrap p{
  margin-right:30px;
}

.c-main .c-content__detail {
  padding: 35px 30px;
  margin-top:100px;}


/* QAボタン */
.c-article .qaWrap .toQA{
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  box-sizing: border-box;
  height: 50px;
  color: #008b56;
  border: 1px solid #008b56;
  width: 260px;
  border-radius:25px;
  background: #fff;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  transition: background-color 0.2s, border 0.2s, color 0.2s;
  padding-left:2rem;
}

.c-main .toQA figure {
    display: flex;
    align-items: center;
    width: 34px;
    height: 26px;
    position: relative;
}

.c-main .toQA p {
    color: #008b56;
    display: block;
    align-items: center;
    font-size: 1.6rem;
    line-height: 1.2;
  text-indent: 1rem;
    padding: 0;
  margin-bottom:0;
    transition: color 0.2s ease;
}

.c-main .toQA.hover{background-color: #008b56;}
.c-main .toQA.hover p {color: #fff;}


/* ----------------------------------------
ステップの矢印
---------------------------------------- */

.stepBar{
  display: flex;
  position: relative;
  text-align: center;
  overflow: hidden;
  
  margin-top:60px;
  margin-bottom: 30px;  
  border-right:1px solid #e5ebeb;
}

.stepBar li{
 font-size: 1.6rem;
 color: #666;
 position: relative;
 display: inline-block;
 line-height: 3.125;
 box-sizing: border-box;
 background-color: #f2f6f6;
  width: calc(100% / 3);
  border:1px solid #e5ebeb;
  border-right:none;
}

.stepBar li::before,
.stepBar li::after{
 content:'';
 position:absolute;
 top:0;
 left:100%;
 height:0;
 width:0;
 border: 25px solid transparent;
 border-right-width:0;
 border-left-width: 13px;
}
.stepBar li::after{
 z-index:1;
 transform: translateX(1px);
 border-left-color:#e5ebeb;
}
.stepBar li::before{
 z-index:2;
 border-left-color:#f2f6f6;
}
.stepBar li:last-child{ margin-right: 0;}
.stepBar li:last-child::before,
.stepBar li:last-child::after{ content: none;}
.stepBar li.current{
 color: #fff;
 background-color: #008b56;
}
.stepBar li.current::before{ border-left-color:#008b56;}



/* ----------------------------------------
説明部分
---------------------------------------- */
.description > p{
 font-size: 1.6rem;
 line-height: 2.25;
}

.description .attention{
 color: #e60012;
 margin-top: 10px;
}
.description .attention span{ margin-right: 10px;}



/* ----------------------------------------
必須、任意アイコン
---------------------------------------- */

.contactForm span.required,
.contactForm span.any{
 color: #fff;
 display: inline-block;
 font-size: 1.4rem;
 padding: 2px 8px;
 font-weight: normal;
 line-height: 1.4;
  width: 60px;
  text-align: center;
}
.contactForm span.required{ background-color: #e60012;}
.contactForm span.any{ background-color: #bec3c3;}



/* ----------------------------------------
エラーメッセージ
---------------------------------------- */
.errorMessage{
 border: 1px solid #e60012;
 padding: 20px;
 color: #e60012;
 margin-top: 20px;
}
.errorMessage p{
 font-size: 2.1rem;
 font-weight: bold;
 padding-left: 30px;
 position: relative;
}
.error{
	height:0px;
	visibility:hidden;
	line-height:0;}
	
.err{
 visibility: inherit;
 color: #e60012;
 font-size: 1.6rem;
 padding-left: 25px;
 position: relative;
 line-height: 1.429;
 margin-bottom: 30px;
}
.errorMessage p::before,
.err::before{
 content: '!';
 display: inline-block;
 background-color: #e60012;
 width: 24px;
 height: 24px;
 border-radius: 12px;
 font-size: 1.8rem;
 font-weight: normal;
 text-align: center;
 color: #fff;
 position: absolute;
 left: 0;
}	

.err::before{
  font-size: 1.4rem;
  width: 20px;
  height: 20px;
  border-radius: 10px;}


.policy-err{
  margin:auto;
  width:770px;
  height:auto;
  margin-bottom:10px;
}

.errorMessage p::before{
  top: 5px;
  line-height: 1.2;}

.err::before {top:0;}
.errorMessage ul{
 list-style: disc;
 font-size: 1.6rem;
 margin-top: 15px;
 padding-left: 50px;
}
.errorMessage ul li:not(:last-child){ margin-bottom: 8px;}




/* ----------------------------------------
入力エリア
---------------------------------------- */
.contactForm section{ margin-top: 60px;}

.contactForm table{
 width: 100%;
 font-size: 1.6rem;
}
.contactForm th,
.contactForm td{
 border: 1px solid #e5ebeb;
 box-sizing: border-box;
 border-collapse: collapse;
 padding: 18px;
 text-align: left;
 vertical-align: top;
 overflow: hidden;
}
.contactForm th{
  width: 250px;
  line-height: 1.4;
  background-color: #f2f6f6;
}
.contactForm th span{ float: right;}
/*form*/
.contactForm input[type="text"],
.contactForm input[type="tel"],
.contactForm input[type="email"],
.contactForm textarea,
.contactForm .radioWrap{
 -webkit-appearance: none;
 -moz-appearance: none;
 appearance: none;
 border-radius: 0;
 outline: none;
 cursor: auto;
 border: 1px solid #d0d5da;
 font-size: 1.6rem;
 color: #333;
}
.contactForm input[type="text"],
.contactForm input[type="tel"],
.contactForm input[type="email"]{
 display: inline-block;
 width: 360px;
 height: 50px;
 padding: 0 10px;
}
.contactForm textarea{
 display: block;
 min-width: 100%;
 max-width: 728px;
 min-height: 180px;
 padding: 15px 10px;
}
.contactForm input[type="text"].wideTxt{ width: 100%;}
.contactForm input[type="text"].yubin{ width: 230px;}
/*placeholder*/
.contactForm input::-webkit-input-placeholder{ color: #cdcdcd;}
.contactForm input:-ms-input-placeholder{ color: #cdcdcd;}
.contactForm input::-moz-placeholder{ color: #cdcdcd;}
/*radio*/
.contactForm input[type="radio"]{ display: none;}
.contactForm .radioWrap{
 width: 110px;
 display: inline-block;
 padding: 16px 0 14px 20px;
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
 line-height: 1.125;
 cursor: pointer;
}
.contactForm td .radioWrap:nth-of-type(n+2){ margin-left: 6px;}
.contactForm .radioCircle{
 position: relative;
 display: inline-block;
 width: 18px;
 height: 18px;
 margin: 0 8px 0 0;
 vertical-align: top;
 border: 1px solid #999;
 border-radius: 50%;
}
.contactForm .radioCircle::before{
 content: "";
 position: absolute;
 top: 2px;
 left: 2px;
 display: block;
 width: 12px;
 height: 12px;
 border-radius: 50%;
 background: #e60012;
 transform: scale(0);
 transition: 0.2s cubic-bezier(0.18, 0.85, 0.5, 1.2);
}
.contactForm .radioWrap.hover .radioCircle::before,
.contactForm .radioWrap input[type="radio"]:checked + .radioCircle::before{ transform: scale(1);}



/*セレクトボックス*/
.selectWrap{
 position: relative;
 display: inline-block;
}
.selectWrap .selectArrow{
 display: inline-block;
 width: 8px;
 height: 8px;
 border-bottom: 2px solid #008b56;
 border-right: 2px solid #008b56;
 transform: rotate(45deg);
 position: absolute;
 top: calc(50% - 6px);
 right: 13px;
 z-index: -1;
}
.selectWrap select{
 -webkit-appearance: none;
 -moz-appearance: none;
 appearance: none;
 border-radius: 0;
 outline: none;
 cursor: pointer;
 min-width: 220px;
 box-sizing: border-box;
 border: 1px solid #d0d5da;
 padding: 9px 30px 8px 20px;
 font-size: 1.6rem;
 color: #333;
 background-color: transparent;
 transition-property: border-color;
 transition-duration: 0.12s;
 z-index: 1;
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.selectWrap select::-ms-expand { display: none;}
.selectWrap select.hover{ border-color: #008b56;}


.contactForm .selectWrap{
 display: block;
 width: 360px;
}
.contactForm .selectWrap select{
 width: 100%;
 padding: 0 30px 0 10px;
 height: 50px;
}
.contactForm .addressWrap .selectWrap{ margin-bottom: 10px;}
.contactForm td input[type="text"]:nth-of-type(2n){ float: right;}
.contactForm td input[type="text"]:nth-of-type(n+3){ margin-top: 10px;}




/* ----------------------------------------
個人情報の取り扱いについて
---------------------------------------- */

.contactForm .privacy {
  font-size:1.6rem;
  line-height: 2.25;}

.privacy_title {
    font-size: 2.1rem;
    font-weight: bold;
    background-color: #e5ebeb;
    padding: 15px 15px 13px 15px;
    margin-bottom: 20px;
}

.contactForm .privacy{
 border: 1px solid #e5ebeb;
 padding: 35px 40px;
 overflow-y: scroll;
 height: 300px;
 box-sizing: border-box;
 margin-bottom: 40px;
}

.contactForm .privacy p {
 margin-bottom: 40px;}


.contactForm .privacy h3 {
  font-size: 2.1rem;
  line-height: 1.2;
  font-weight: bold;
  text-align: left;
  background: none;
  padding:0;
  margin-bottom:40px;
  position: relative;
}


/* dl */
.contactForm .privacy dl {
  counter-reset: privacy_dt;
  margin-bottom: 80px;
}

.contactForm .privacy dl > dt::before {
  margin-right: 0.25rem;
  content:counter(privacy_dt) ".";
  counter-increment: privacy_dt;
  font-weight: bold;
}

.contactForm .privacy dl dt {
  font-size:1.8rem;
  font-weight: bold;
  margin-bottom:10px;}

.contactForm .privacy dl dd {
  margin-bottom:30px;}

/* li */
.contactForm .privacy dl li {
  list-style:disc;
  margin-left:2rem;
}

/* dl お問合せ */
.contactForm .privacy dl.contact {margin-bottom:120px;}

.contactForm .privacy dl.contact > dt::before {
  margin-right: 0;
  content:none;
}

.contactForm .privacy p.caution{
 color: #555;
 text-align: right;
  margin-bottom:0;
}



/* ----------------------------------------
同意する
---------------------------------------- */
/*同意するボタン*/
.contactForm .consentCheck{
 width: 770px;
 height: 80px;
 color: #e60012;
 font-size: 1.6rem;
 display: flex;
 justify-content: center;
 align-items: center;
 margin: 0 auto 55px;
 box-sizing: border-box;
 border: 1px solid #e60012;
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
 cursor: pointer;
 transition: background 0.12s;
}
.contactForm .consentCheck.hover{ background-color: #f8e2e3;}
.contactForm input[type="checkbox"]{ display: none;}
.contactForm .checkBox{
 display: inline-block;
 width: 15px;
 height: 15px;
 border: 1px solid #d0d5da;
 margin-right: 15px;
 position: relative;
 top: -1px;
 background-color: #fff;
}
.contactForm .checkBox::after{
 content: '';
 display: inline-block;
 position: absolute;
 width: 11px;
 height: 7px;
 border-left: 2px solid #e60012;
 border-bottom: 2px solid #e60012;
 transform: rotate(-45deg);
 top: 0;
 left: 1px;
 opacity: 0;
 transition: opacity 0.12s;
}
.contactForm input[type="checkbox"]:checked + .checkBox::after{ opacity: 1;}

/*次へ進むボタン*/
.contactForm .submit{
 width: 300px;
 height: 80px;
 color: #fff;
 background-color: #008b56;
 font-size: 1.8rem;
 box-shadow: 0 3px 7px rgba(0,0,0,0.25);
 transition: box-shadow 0.12s;
 position: relative;
 display: block;
 margin: 55px auto 120px;
 box-sizing: border-box;
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  border-radius: 3px;
}
.contactForm .submit.hover{ box-shadow: none;}



/*--------------------------------------
step2
---------------------------------------*/
@media (min-width:768px){.step2 .contactForm th{ padding: 20px 19px;}}
.step2 .contactForm td{ line-height: 1.813;}
@media (min-width:768px){.step2 .contactForm td{ padding: 15px 19px;}}

.step2 .description {margin-top:100px;}
.step2 .contactForm .submit {margin-bottom:60px;}

/*入力内容を修正するボタン*/
.contactForm .backBtn{
 width: 260px;
 height: 50px;
 color: #008b56;
 border: 1px solid #008b56;
 font-size: 1.6rem;
 display: block;
 margin: 25px auto 120px;
 box-sizing: border-box;
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
 transition: background-color 0.2s, border 0.2s, color 0.2s;
  border-radius:25px;
}

.contactForm .backBtn.hover{
 color: #fff;
 background-color: #008b56;

}

/*--------------------------------------
step3
---------------------------------------*/

.step3 .description {margin-top:100px;}

.step3 .description > p{
  font-size:1.6rem;
  text-align: center;
  margin-bottom:50px;
}

.step3 .description > p:last-child { margin-bottom:90px;}

.step3 .description .thanks{
 font-size: 2.4rem;
 line-height: 1.75;
 margin: 90px 0 50px;
}

/*トップへボタン*/
.contactForm .toTop{
 position: relative;
 display: flex;
 align-items: center;
 justify-content: center;
 margin: 0 auto 120px;
 font-size: 1.8rem;
 box-sizing: border-box;
  border-radius:3px;
 width: 300px;
 height: 80px;
 color: #ffffff;
  background: #008b56;
 -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  box-shadow: 0 3px 7px rgba(0,0,0,0.25);
 transition: box-shadow 0.12s;
}
.contactForm .toTop.hover{box-shadow: none;}



/*--------------------------------------
contact send loading
---------------------------------------*/
.ProductC .loadingP{
			width: 100%;
			height: 100%;
			position: fixed;
			background-color: #FFF;
			z-index: 20;
		}
.ProductC .loadingP.hidden{
			visibility: hidden;
		}
.ProductC .loadingP p{
			display: block;
			color: #000;
			text-align: center;
		}
.ProductC .loader,
.ProductC .loader:before,
.ProductC .loader:after {
  border-radius: 50%;
  width: 20px;
  height: 20px;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation: load 1.8s infinite ease-in-out;
  animation: load 1.8s infinite ease-in-out;
}
.ProductC .loader {
  color: #e60012;
  font-size: 10px;
  margin: 80px auto;
  position: relative;
  text-indent: -9999em;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}
.ProductC .loader:before,
.ProductC .loader:after {
  content: '';
  position: absolute;
  top: 0;
}
.ProductC .loader:before {
  left: -3.5em;
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}
.ProductC .loader:after {
  left: 3.5em;
}
@-webkit-keyframes load {
  0%,
  80%,
  100% {
    box-shadow: 0 2.5em 0 -1.3em;
  }
  40% {
    box-shadow: 0 2.5em 0 0;
  }
}
@keyframes load {
  0%,
  80%,
  100% {
    box-shadow: 0 2.5em 0 -1.3em;
  }
  40% {
    box-shadow: 0 2.5em 0 0;
  }
}