@charset "utf-8";

/* -----------------------------------------------------------
    FAQページとサービス3ページ共通
-------------------------------------------------------------- */
.faq-contents .faq-cmn-ttl {
	border-radius: 2px;
	background: var(--main);
	color: #fff;
	display: block;
	font-size: 2.2rem;
	font-weight: bold;
	padding: 12px 25px 11px 20px;
	margin: 0 0 20px;
	line-height: 1.5;
	letter-spacing: .03em;
	width: 100%;
}

.faq-accordion .faq-box {
	border-bottom: var(--border2) solid 1px;
	transition: .5s;
}

.faq-accordion .faq-box:hover {
	border-bottom-color: var(--main);
}

.faq-accordion .title {
	color: var(--cmnblack);
	line-height: 1.5;
	letter-spacing: .05em;
	width: 100%;
	transition: .5s;
	font-size: 1.7rem;
}

.faq-accordion .title:hover {
	color: var(--main);
}

.faq-accordion .quest {
	display: flex;
	gap: 15px;
	position: relative;
	padding: 24px 20px 26px 70px;
	justify-content: space-between;
	width: 100%;
	transition: .5s;
}

.faq-accordion .quest::before {
	content: "Q";
	font: 700 2.5rem /1 var(--serif);
	color: var(--sub);
	display: block;
	position: absolute;
	height: 30px;
	line-height: 30px;
	left: 15px;
	top: 22px;
	text-align: center;
	width: 34px;
}

.faq-accordion .quest:hover {
	cursor: pointer;
	color: #6c6d5d;
}

.faq-accordion .answer {
	display: none;
	background: var(--cmnbg2);
	padding: 0 60px 0 70px;
	position: relative;
}

.faq-accordion .answer::before {
	content: "A";
	font: 700 2.9rem /1 var(--serif);
	color: var(--main);
	display: block;
	position: absolute;
	height: 30px;
	line-height: 30px;
	left: 17px;
	text-align: center;
	width: 34px;
	top: 32px;
}

.faq-accordion .answer-txt {
	padding: 30px 0;
}

.faq-accordion .answer-txt p {
	line-height: 1.8;
	letter-spacing: .07em;
}

.faq-accordion .answer-txt a {
	color: var(--main);
	text-decoration: underline;
}

@media screen and (min-width: 769px) {
	.faq-accordion a[href^="tel:"] {
		color: #333 !important;
		text-decoration: none;
	}
}

.faq-accordion .answer-txt a:hover {
	text-decoration: none;
}

.faq-accordion-icon {
	height: 24px;
	padding: 10px 0 0 0;
	position: relative;
	width: 24px;
}

.faq-accordion .faq-section:first-of-type {
	margin: 20px 0 0 0;
}

.faq-accordion-icon::before, .faq-accordion-icon::after {
	background-color: var(--border3);
	content: "";
	height: 1px;
	position: absolute;
	width: 100%;
	transition: all .3s;
}

.faq-accordion-icon::before {
	transform: rotate(0deg);
}

.faq-accordion-icon::after {
	transform: rotate(90deg);
}

.quest.faq-accordion-active .faq-accordion-icon::after {
	transform: rotate(180deg);
}

@media screen and (max-width: 768px) {
	.faq-contents .faq-cmn-ttl {
		padding: 12px 15px;
		margin: 0 0 15px;
		font-size: 2.2rem;
	}

	.faq-accordion .faq-box a {
		position: relative;
	}

	.faq-accordion .faq-box .title {
		font-size: 1.7rem;
		line-height: 1.7;
	}

	.faq-accordion .quest {
		padding: 19px 8px 19px 40px;
	}

	.faq-accordion .quest::before {
		font-size: 2.3rem;
		top: 21px;
		height: 28px;
		line-height: 28px;
		left: 4px;
		width: 28px;
	}

	.faq-accordion .answer {
		padding: 23px 15px 8px 40px;
	}

	.faq-accordion .answer::before {
		font-size: 2.3rem;
		top: 27px;
		height: 28px;
		line-height: 28px;
		left: 6px;
		width: 28px;
	}

	.faq-accordion .answer-txt {
		padding: 0 0 20px 0;
		width: 100%;
	}

	.faq-accordion .answer-txt p {
		font-size: 1.6rem;
		line-height: 2;
		letter-spacing: .07em;
	}

	.faq-accordion-icon {
		height: 18px;
		padding: 15px 0 0 0;
		width: 18px;
	}
}