.p-faq {
	--side-pad: 1.5rem;
	--vertical-pad: 1rem;
	--gap: 0em;
	--this-color: var(--c-dark);
	display: block;
	padding: var(--vertical-pad) var(--side-pad); /* クリック可能範囲の確保 */
	background: var(--c-light);
	border-radius: var(--bd-r--sm);
	overflow: hidden;
	box-shadow: var(--shdw);
	font-family: var(--ff-g);
}
.p-faq:not(:last-of-type) {
	margin-bottom: 1.5rem;
	border-bottom: 1px solid var(--c-gray);
}

/**********************************
* ***質問
* **********************************/
.p-faq__head {
	display: flex;
	gap: var(--gap);
	cursor: pointer;
	transition: var(--ani-t--normal) ease-out;
}
/* アニメーション */
.p-faq[open] .p-faq__head {
	margin-bottom: 1.5rem;
}
.p-faq__head:hover,
.p-faq__head:focus {
	opacity: 0.8;
}
.p-faq__headInner {
	flex-grow: 1;
}

/**********************************
* ***回答
* **********************************/
.p-faq__body {
	display: flex;
	gap: var(--gap);
}
/* アニメーション */
.p-faq[open] .p-faq__body {
	animation: fadein 0.5s ease;
}
@keyframes fadein {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
.p-faq__bodyInner {
	flex-grow: 1;
}

/**********************************
* ***QA文字
* **********************************/
/* QA文字　共通 */
.p-faq__icon {
	display: inline-block;
}
/* Q.文字 */
.p-faq__icon.--q::before {
	content: "Q.";
}
/* A.文字 */
.p-faq__icon.--a::before {
	content: "A.";
}

/**********************************
* ***開閉アイコン
* **********************************/
.p-faq__toggle {
	--toggle-size: 0.5em;
	position: relative;
	display: inline-block;
	margin-left: 0.5em;
	width: var(--toggle-size);
	min-width: var(--toggle-size);
	aspect-ratio: 1;
}
.p-faq__toggle::before,
.p-faq__toggle::after {
	position: absolute;
	top: 25%;
	left: 50%;
	content: "";
	width: var(--toggle-size);
	height: 1px;
	background: var(--this-color);
	transition: var(--ani-t--normal) ease-out;
}
.p-faq__toggle::before {
	transform: translate(-50%, -50%) rotate(90deg);
}
.p-faq__toggle::after {
	transform: translate(-50%, -50%) rotate(0deg);
}

/* アニメーション */
.p-faq[open] .p-faq__toggle::before {
	transform: translate(-50%, -50%) rotate(180deg);
}
.p-faq[open] .p-faq__toggle::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}
/* 既存のマーカー */
.p-faq__head {
	list-style: none;
}
.p-faq__head::-webkit-details-marker {
	display: none;
}
