.faq-wrap {
	margin-bottom: 40px;
}

.faq-info {
	margin-bottom: 60px;
}

.faq-info__text {
	text-align: center;
	margin-bottom: 30px;
}

.faq {
	margin-bottom: 10px;
}

.faq__question,
.faq__answer {
	position: relative;
}

.faq__question:before,
.faq__answer:before {
	font-family: "Roboto", sans-serif;
	font-weight: 600;
	color: #FFFFFF;
	line-height: 1;
	width: 30px;
	height: 30px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	background: #0fa044;
	border-radius: 50%;
	font-size: 2.0rem;
	padding-bottom: 3px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: absolute;
}

.faq__question {
	background: #F1F1F1;
	width: 100vw;
	margin-left: -5.35vw;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 500;
}

.faq__question:before {
	content: "Q";
	background: #0fa044;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	left: 5.35vw;
}

.faq__question a {
	padding: 16px 5.35vw 18px;
	display: block;
	position: relative;
}

.faq__question a:after {
	content: "";
	display: block;
	width: 5px;
	height: 5px;
	border-right: 1px solid #333333;
	border-bottom: 1px solid #333333;
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	-ms-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg);
	position: absolute;
	top: 50%;
	right: 5.35vw;
}

.faq__question a span {
	padding: 0 15px 0 40px;
	display: block;
}

.faq__question a:hover:before {
	background: #333333;
}

.faq__question.is-opend a:before {
	background: #333333;
}

.faq__question.is-opend a:after {
	-webkit-transform: translate(-50%, -50%) rotate(-135deg);
	-ms-transform: translate(-50%, -50%) rotate(-135deg);
	transform: translate(-50%, -50%) rotate(-135deg);
}

.faq__content {
	display: none;
	padding-bottom: 30px;
}

.faq__answer {
	font-size: 1.5rem;
	line-height: 1.86667;
	padding: 13px 0 0 40px;
}

.faq__answer:before {
	top: 20px;
	left: 0;
	content: "A";
	background: #A3A3A3;
}

.faq__answer a {
	color: #0fa044;
	text-decoration: underline;
}

.faq__answer a:hover {
	text-decoration: none;
}

.faq__answer p:not(:last-child) {
	margin-bottom: 1.86667em;
}

.faq__close {
	width: 100%;
	max-width: 300px;
	margin-left: auto;
	margin-right: auto;
	height: 40px;
	color: #FFFFFF;
	background: #AAAAAA;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	margin-top: 24px;
}

@media screen and (min-width: 681px) {

.faq-wrap { /* md */
	margin-bottom: 80px;
}

.faq-info { /* md */
	margin-bottom: 100px;
}

.faq__question { /* md */
	margin-left: 0;
	width: 100%;
	font-size: 1.8rem;
}

.faq__question:before { /* md */
	left: 20px;
}

.faq__question a { /* md */
	padding: 0 80px 0 20px;
	height: 70px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.faq__question a:after { /* md */
	border-color: #FFFFFF;
	right: 28px;
}

.faq__question a:before { /* md */
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	width: 70px;
	background: #AAAAAA;
	-webkit-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}

.faq__question a span { /* md */
	padding: 0 0 0 46px;
}

.faq__answer { /* md */
	padding: 23px 0 0 66px;
}

.faq__answer:before { /* md */
	top: 30px;
	left: 20px;
}

}

@media screen and (min-width: 1100px) {

.faq-info { /* lg */
	margin-bottom: 160px;
}

.faq-info__text { /* lg */
	margin-bottom: 40px;
}

.faq__close { /* lg */
	display: none;
}

}

