@charset "UTF-8";

/* よくあるご質問 */
section.qa {
	background: none;
	padding: 0;
	margin-bottom: 40px;
}
section.qa .qa-box {
	margin-bottom: 40px;
}
section.qa p.qa_p {
	margin: 0 5% 10px;
}
section.qa dl.qa-dl {
	width: auto;
	background: none;
	margin: 0 5% 15px;
	padding: 0 0 5px;
	background: url(../img/contents_bg.webp);
	position: relative;
}

section.qa dt.qa-dt {
  display: flex;
	border: none;
	margin: 10px 0 0;
	font-size: 0;
	cursor: pointer;
}
section.qa dt.qa-dt .qa-dt-box {
	display: flex;
	justify-content: center;
	align-items:center;
	padding: 20px 15px;
}
section.qa dt.qa-dt .question {
	font-size: 16px;
	font-weight: bold;
	line-height: 1.2em;
}

section.qa dd.qa-dd {
	font-size: 0;
	margin: 0 5px;
	padding: 10px;
	background: #fff;
	position: relative;
	display: none;
}
section.qa dd.qa-dd .qa-dd-box {
	font-size: 0;
}
section.qa dd.qa-dd .answer {
	font-size: 15px;
	padding-top: 5px;
}
section.qa dd.qa-dd p {
	display: inline-block;
}

section.qa dl.qa-dl .q-img {
	position: relative;
	display: inline-block;
	width: 34px;
	height: 34px;
	margin-right: 10px;
	vertical-align: top;
	background: #007151
}
section.qa dl.qa-dl dd .q-img {
	background: #fff;
	border: 1px solid #007151;
	box-sizing: border-box;
}
section.qa dl.qa-dl .q-img span,
section.qa dl.qa-dl dd .q-img span {
	font-size: 22px;
	color: #fff;
	font-weight: bold;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
}
section.qa dl.qa-dl dd .q-img span {
	color: #007151;
}
section.qa dt.qa-dt .question,
section.qa dd.qa-dd .answer {
	display: inline-block;
	vertical-align: top;
	width: calc( 100% - 44px );
}
section.qa dt.qa-dt .answer-open {
	position: absolute;
	font-size: 13px;
	display: inline-block;
	background: rgba(0,0,0,0.3);
	width: 20px;
	height: 20px;
	border-radius: 22px;
	text-align: center;
	left: 50%;
	bottom: -10px;
	margin-left: -10px;
	z-index: 1;
}
section.qa dt.qa-dt .answer-open::before {
	font-family: 'FontAwesome';
	content: "\f078";
	position: absolute;
	left: 3px;
	top: 0px;
	color: #fff;
}
section.qa dt.qa-dt.open .answer-open {
	transform: rotate(-180deg);
}
.qa-box h4 {
	width: 100%;
	margin: 10px auto;
	color: #007151;
	font-weight: bold;
	font-size: 20px;
}
@media screen and (min-width: 769px) {
	/* PC */
	/* よくあるご質問 */
	section.qa {
		display: inline-block;
		width: 98%;
		margin: 0 1%;
	}
	section.qa dl.qa-dl {
		margin: 0 0 15px;
	}
	.qa-box {
		width: 59%;
		margin: 0 auto 40px;
	}
}
