@charset "UTF-8";

/* ページトップ */
#topImage-block figure {
	height: 640px;
}

#topImage-block figure img {
	object-position: 50% 60%;
}


/* ページ内リンク */
.categories-nav-block {
	margin: 80px auto;
}

.categories-nav-block .content {
	max-width: 960px;
	margin: 0 auto;
}

.categories-nav-block .categories-nav__list {
	display: grid;
	grid-template-columns: repeat(auto-fit,minmax(184px,1fr));
	gap: 16px 2%;
}

.categories-nav-block .categories-nav__item {
	display: block;
	height: 100%;
	color: var(--color_white);
	text-decoration: none;
	background-color: var(--color01);
	border-radius: 8px;
	-webkit-border-radius: 8px;
	-moz-border-radius: 8px;
	-ms-border-radius: 8px;
	-o-border-radius: 8px;
	text-align: center;
	font-weight: var(--fw_jp_bold);
	line-height: 1.4;
	padding: 0.8em 1em;
	transition: .3s;
	-webkit-transition: .3s;
	-moz-transition: .3s;
	-ms-transition: .3s;
	-o-transition: .3s;
}
.categories-nav-block .categories-nav__item:hover {
	background-color: var(--color05);
}


/* FAQ */
.faq-block {
	margin: 80px auto;
}
.faq-block:last-of-type {
	margin: 80px auto 160px;
}

.faq-block .content {
	max-width: 960px;
	margin: 0 auto;
}

.faq-block .cont-ttl {
	margin-bottom: 24px;
}

.faq-block .cont-ttl--jp {
	font-size: clamp(16px, 32 / 768 * 100vw, 32px);
}

.faq-block .inner {
	display: flex;
	flex-direction: column;
	gap: 24px;
}


/* アコーディオンメニュー-FAQ */
.faq__unit {
	padding: 24px;
	background-color: var(--color_white);
	border-radius: 24px;
	-webkit-border-radius: 24px;
	-moz-border-radius: 24px;
	-ms-border-radius: 24px;
	-o-border-radius: 24px;
}

.faq__unit input {
	display: none;
}

.faq__unit .faq__q {
	display: flex;
	align-items: start;
	gap: 0 0.8em;
	padding-right: 2.3em;
	position: relative;
	cursor: pointer;
}

.faq__unit .faq__q::after,
.faq__unit .faq__q::before {
	content: "";
	position: absolute;
	right: 0.75em;
	top: 0.2em;
	width: 1px;
	height: 1.5em;
	background-color: var(--color_black);
	transition: 0.3s;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-ms-transition: 0.3s;
	-o-transition: 0.3s;
}

.faq__unit .faq__q::after {
	transform: rotate(90deg);
}

.faq__unit input:checked ~ .faq__q::before {
	transform: rotate(90deg) !important;
	-webkit-transform: rotate(90deg) !important;
	-moz-transform: rotate(90deg) !important;
	-ms-transform: rotate(90deg) !important;
	-o-transform: rotate(90deg) !important;
}

.faq__unit .faq__q .q-mark {
	font-size: clamp(22px, 28 / 768 * 100vw, 28px);
	line-height: 1.0;
	font-weight: var(--fw_en_bold);
	color: var(--color01);
}

.faq__unit .faq__q .question {
	font-size: clamp(15px, 18 / 768 * 100vw, 18px);
	line-height: 1.4;
	font-weight: var(--fw_jp_bold);
	margin-top: 0.1em;
}

.faq__unit .faq__a {
	max-height: 0;
	padding: 0 24px;
	visibility: hidden;
	margin-top: 0;
	overflow: hidden;
	background-color: var(--color03);
	border-radius: 16px;
	-webkit-border-radius: 16px;
	-moz-border-radius: 16px;
	-ms-border-radius: 16px;
	-o-border-radius: 16px;
	transition: 0.3s ease-in;
	-webkit-transition: 0.3s ease-in;
	-moz-transition: 0.3s ease-in;
	-ms-transition: 0.3s ease-in;
	-o-transition: 0.3s ease-in;
}

.faq__unit input:checked ~ .faq__a {
	max-height: 100%;
	padding: 24px;
	visibility: visible;
	margin-top: 24px;
}



/* スマートフォン用 */
@media screen and (max-width: 768px) {

	/* ページトップ */
	#topImage-block figure {
		height: 240px;
	}


	/* ページ内リンク */
	.categories-nav-block {
		margin: 40px auto;
	}

	.categories-nav-block .categories-nav__list {
		gap: 8px 2%;
	}

	.categories-nav-block .categories-nav__item {
		padding: 0.4em 1em;
	}


	/* FAQ */
	.faq-block {
		margin: 40px auto;
	}
	.faq-block:last-of-type {
		margin: 40px auto 80px;
	}

	.faq-block .cont-ttl {
		margin-bottom: 8px;
	}

	.faq-block .inner {
		gap: 14px;
	}


	/* アコーディオンメニュー-FAQ */
	.faq__unit {
		padding: 16px;
		border-radius: 16px;
		-webkit-border-radius: 16px;
		-moz-border-radius: 16px;
		-ms-border-radius: 16px;
		-o-border-radius: 16px;
	}

	.faq__unit .faq__q {
		gap: 0 0.4em;
		padding-right: 1.6em;
	}

	.faq__unit .faq__q::after,
	.faq__unit .faq__q::before {
		right: 0.5em;
		top: 0.3em;
		height: 1.0em;
	}

	.faq__unit .faq__q .question {
		margin-top: 0;
	}

	.faq__unit .faq__a {
		padding: 0 16px;
		border-radius: 8px;
		-webkit-border-radius: 8px;
		-moz-border-radius: 8px;
		-ms-border-radius: 8px;
		-o-border-radius: 8px;
	}

	.faq__unit input:checked ~ .faq__a {
		padding: 16px;
		margin-top: 16px;
	}

}
