@charset "utf-8";

/* ========================================================
	faq.css => よくあるご質問
======================================================== */


/* faq_block
============================================================================================================ */
.faq_block {
	font-size: 1.5rem;
	line-height: 1.7;
}
.faq_block:before {
	content: "";
	display: block;
	border-top: 1px solid #dfddd5;
}
.faq_block section {
	padding: 18px 0;
	border-bottom: 1px solid #dfddd5;
}
.faq_block section header {
	position: relative;
	display: table;
	width: 100%;
	padding-right: 60px;
	color: #dc6b7f;
	cursor: pointer;
}
.faq_block section header:before {
	content: "";
	position: absolute;
	top: 12px;
	right: 20px;
	width: 12px;
	height: 12px;
	border-bottom: 1px solid #444;
	border-right: 1px solid #444;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transition: -webkit-transform .3s;
	-o-transition: -o-transform .3s;
	transition: transform .3s;
}
.faq_block section header.open:before {
	-webkit-transform: translateY(5px) rotate(225deg);
	-ms-transform: translateY(5px) rotate(225deg);
	-o-transform: translateY(5px) rotate(225deg);
	transform: translateY(5px) rotate(225deg);
}

.faq_block section header > * {
	display: table-cell;
}
.faq_block section header p {
	width: 45px;
	vertical-align: top;
}
.faq_block section header p span {
	display: block;
	width: 45px;
	height: 45px;
	background-color: #dc6b7f;
	color: #fff;
	font-size: 2.6rem;
	line-height: 45px;
	text-align: center;
}
.faq_block section header h1 {
	padding-left: 25px;
	vertical-align: middle;
	font-weight: normal;
}
.faq_block section .contents {
	display: none;
}
.faq_block section .contents > * {
	display: table;
	padding-top: 15px;
}
.faq_block section .contents > * > * {
	display: table-cell;
}
.faq_block section .contents > * > p {
	width: 45px;
	vertical-align: top;
}
.faq_block section .contents > * > p span {
	display: block;
	width: 45px;
	height: 45px;
	background-color: #faeeeb;
	border: 1px solid #dc6b7f;
	color: #dc6b7f;
	font-size: 2.6rem;
	line-height: 43px;
	text-align: center;
}
.faq_block section .contents > * > div {
	padding-left: 25px;
	vertical-align: middle;
}
.faq_block section .contents > * > div p + p {
	margin-top: 1.5em;
}
@media screen and (min-width: 769px), print {
	.faq_block section header:hover h1 {
		text-decoration: underline;
	}
}
@media screen and (max-width: 768px) {
	.faq_block {
		font-size: 1.2rem;
	}
	.faq_block section header {
		padding-right: 30px;
	}
	.faq_block section header:before {
		top: 12px;
		right: 5px;
		width: 8px;
		height: 8px;
	}
	.faq_block section header p {
		width: 36px;
	}
	.faq_block section header p span {
		width: 36px;
		height: 36px;
		font-size: 2rem;
		line-height: 36px;
	}
	.faq_block section header h1 {
		padding-left: 15px;
	}
	.faq_block section .contents > * > p {
		width: 36px;
	}
	.faq_block section .contents > * > p span {
		width: 36px;
		height: 36px;
		font-size: 2rem;
		line-height: 34px;
	}
	.faq_block section .contents > * > div {
		padding-left: 15px;
	}
}
