:root {
	--margin-l-sp: 55px;
	--margin-m-sp: 40px;
	--margin-s-sp: 25px;
	--margin-ss-sp: 15px;
	--margin-l-pc: 100px;
	--margin-m-pc: 60px;
	--margin-s-pc: 40px;
	--margin-ss-pc: 10px;
}
/*-----------------------------------------------------------
===  [ qa CSS ]  ====================================
------------------------------------------------------------*/
/* ***************************************************************************** */
.p_qa01 {
	background: #fff;
	border-radius: 20px;
	padding: 23px 20px;
	margin: 30px 0 20px;
	box-shadow: 0px 2px 0px rgba(25, 31, 108, 0.1);
}
.p_qa01+.p_qa01 {
	margin: 20px 0;
}
.p_qa01__ttl {
	font-weight: bold;
	line-height: 1.5;
	padding: 0 20px 0 0;
	cursor: pointer;
}
.p_qa01__ttl>span {
	display: flex;
	gap: 0 10px;
}
.p_qa01__ttl>span::before {
	content: "";
	display: inline-block;
	width: 25px;
	height: 29px;
	background: url(../../common/images/ico_q.svg) no-repeat center;
	background-size: contain;
	flex: 0 0 auto;
	align-self: flex-start;
	margin: -3px 0;
}
.p_qa01__ttl.is-acc {
	position: relative;
}
.p_qa01__ttl.is-acc::before, .p_qa01__ttl.is-acc::after {
	content: "";
	display: inline-block;
	width: 10px;
	height: 2px;
	background: rgba(25, 31, 108, 0.3);
	position: absolute;
	right: 0;
	top: calc(50% - 1px);
	pointer-events: none;
}
.p_qa01__ttl.is-acc::after {
	transform: rotate(90deg);
	transition: transform 0.3s;
}
.p_qa01__ttl.is-acc.is-accOpen::after {
	transform: rotate(0deg);
}
.p_qa01__box {
	display: flex;
	gap: 0 15px;
	margin: 20px 0 0;
}
.p_qa01__box::before {
	content: "";
	display: inline-block;
	width: 21px;
	height: 25px;
	background: url(../../common/images/ico_a.svg) no-repeat center;
	background-size: contain;
	flex: 0 0 auto;
	align-self: flex-start;
}
.p_qa01__box *:first-child {
	margin-top: 0;
}
.p_qa01__box p {
	margin: 0.5em 0 0;
}
.p_qa01__box .p_qa01__txt01 {
	margin: 0.5em 0 0 1em;
}
@media print, screen and (min-width: 768px) {
	.p_qa01 {
		border-radius: 40px;
		padding: 28px 30px 28px 27px;
		margin: 50px 0 30px;
	}
	.p_qa01+.p_qa01 {
		margin: 30px 0;
	}
	.p_qa01__wrap {
		margin: 0 -80px;
	}
	.p_qa01__ttl {
		font-size: 1.6rem;
		padding-right: 50px;
	}
	.p_qa01__ttl>span {
		gap: 0 15px;
	}
	.p_qa01__ttl>span::before {
		width: 28px;
		height: 33px;
	}
	.p_qa01__ttl.is-acc::before, .p_qa01__ttl.is-acc::after {
		width: 15px;
	}
	.p_qa01__box {
		gap: 0 17px;
		margin-top: 28px;
		padding-bottom: 14px;
	}
	.p_qa01__box::before {
		width: 28px;
		height: 25px;
	}
	.p_qa01__img01 {
		max-width: 370px;
		margin: 0 auto;
	}
}
@media print, screen and (min-width: 768px) and (max-width: 1024px) {
	.p_qa01__wrap {
		margin: 0 -40px;
	}
}
