@charset "utf-8";

@media print, screen and (min-width:768px) {
	.first-section {
		padding-bottom: 64px;
	}
}

@media screen and (max-width:767px) {
	.first-section {
		padding-bottom: 66px;
	}
}

/* -------------------------------------------------
	.faq
------------------------------------------------- */

.first-section .cate + .cate {
	margin-top: 35px;
}

.first-section .cate .headline {
	margin-bottom: 20px;
	font-size: 22px;
	font-weight: bold;
}
.first-section .cate .headline::after {
	width: 123px;
	height: 1px;
	display: inline-block;
	background: #F27F22;
	margin-left: 10px;
	content: "";
	vertical-align: 8px;
}

.first-section .faq + .faq {
	margin-top: 11px;
}
.first-section .faq .label {
	font-size: 26px;
	font-family: 'Raleway';
	font-weight: 700;
	color: #E56600;
	line-height: 1;
	position: absolute;
	left: 19px;
	top: 16px;
}

.first-section .faq .q-box,
.first-section .faq .a-box {
	padding: 15px 0 14px 63px;
	margin-left: 30px;
	position: relative;
}

.first-section .faq .q-box {
	width: calc(100% - 30px);
	padding-right: 110px;
	background: #EFEEEA;
	border: none;
	display: block;
	text-align: left;
	cursor: pointer;
	transition: background 0.2s ease-out;
}
.first-section .faq .q-box:hover,
.first-section .faq.on .q-box {
	background: #F2D68A;
}
.first-section .faq .q-box p {
	font-size: 18px;
	line-height: calc(30 / 18);
	font-weight: bold;
	color: #0A0A0A;
}

.first-section .faq .q-box .toggle-btn {
	display: flex;
	align-items: center;
	gap: 0 12px;
	position: absolute;
	right: 23px;
	top: 19px;
}
.first-section .faq .q-box .toggle-btn .text {
	font-size: 14px;
}
.first-section .faq .q-box .toggle-btn .text::before {
	content: "開く";
}
.first-section .faq.on .q-box .toggle-btn .text::before {
	content: "閉じる";
}
.first-section .faq .q-box .toggle-btn .symbol {
	width: 18px;
	height: 18px;
	position: relative;
}
.first-section .faq .q-box .toggle-btn .symbol::before,
.first-section .faq .q-box .toggle-btn .symbol::after {
	width: 18px;
	height: 2px;
	background: #4B4B4B;
	content: "";
	display: block;
	position: absolute;
	left: 0;
	top: 50%;
}
.first-section .faq .q-box .toggle-btn .symbol::before {
	transform: translateY(-50%);
}
.first-section .faq .q-box .toggle-btn .symbol::after {
	transform: translateY(-50%) rotate(-90deg);
}
.first-section .faq.on .q-box .toggle-btn .symbol::after {
	transform: translateY(-50%) rotate(0deg);
}

.first-section .faq .acc-target {
	display: none;
}
.first-section .faq .acc-target.visible {
	display: block;
}

.first-section .faq .a-box {
	background: #FFF1C6;
	padding-right: 15px;
}
.first-section .faq .a-box p {
	font-size: 18px;
	line-height: calc(28 / 18);
}
.first-section .faq .a-box .label {
	color: #A3131E;
}

@media print, screen and (min-width:768px) {
	.first-section .faq-group {
		width: 96%;
		max-width: 1064px;
		margin: 65px auto 0;
	}
}

@media screen and (max-width:767px) {
	.first-section .faq-group {
		margin-top: 42px;
	}
	
	.first-section .cate + .cate {
		margin-top: 50px;
	}
	
	.first-section .cate .headline {
		font-size: 18px;
		position: relative;
	}
	.first-section .cate .headline::after {
		width: 90px;
		margin-left: 0;
		vertical-align: 0;
		position: absolute;
		right: 0;
		top: 7px;
	}

	.first-section .faq + .faq {
		margin-top: 15px;
	}
	.first-section .faq .label {
		font-size: 24px;
		left: 12px;
		top: 14px;
	}

	.first-section .faq .q-box,
	.first-section .faq .a-box {
		padding: 14px 0 13px 45px;
		margin-left: 0;
	}

	.first-section .faq .q-box {
		width: 100%;
		padding-right: 42px;
	}
	.first-section .faq .q-box p {
		font-size: 15px;
		line-height: calc(23 / 15);
	}

	.first-section .faq .q-box .toggle-btn {
		gap: 0;
		right: 10px;
		top: 13px;
	}
	.first-section .faq .q-box .toggle-btn .text {
		display: none;
	}
	.first-section .faq .q-box .toggle-btn .symbol {
		width: 22px;
		height: 22px;
		border: solid 1px #808080;
	}
	.first-section .faq .q-box .toggle-btn .symbol::before,
	.first-section .faq .q-box .toggle-btn .symbol::after {
		width: 14px;
		left: 50%;
	}
	.first-section .faq .q-box .toggle-btn .symbol::before {
		transform: translate(-50%,-50%);
	}
	.first-section .faq .q-box .toggle-btn .symbol::after {
		transform: translate(-50%,-50%) rotate(-90deg);
	}
	.first-section .faq.on .q-box .toggle-btn .symbol::after {
		transform: translate(-50%,-50%) rotate(0deg);
	}

	.first-section .faq .a-box {
		padding-right: 15px;
	}
	.first-section .faq .a-box p {
		font-size: 15px;
		line-height: calc(23 / 15);
	}
}