@charset 'UTF-8';
/*----------------------------------------

	- pageTitle
	- contentWrap

-----------------------------------------*/

/*----------------------------------------
	pageTitle
-----------------------------------------*/
.pageTitle {
	inline-size: min(80%, 1120px);
	margin-block: 191px 40px;
	margin-inline: auto;
}

.pageTitle h1 {
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size52);
	line-height: var(--line-height15);
}

.pageTitle .internalLink {
	display: grid;
	gap: 16px 64px;
	grid-template-columns: repeat(3, 1fr);
	inline-size: min(91.78%, 1028px);
	margin-block-start: 40px;
	font-size: var(--font-size20);
	line-height: var(--line-height125);
}

.pageTitle .internalLink li {
	border-block-end: var(--border-width1) solid var(--color-black01);
}

.pageTitle .internalLink li a {
	display: grid;
	grid-template-rows: minmax(26px, 100%);
	align-items: center;
	position: relative;
	block-size: 100%;
	padding-block: 15px;
	padding-inline-end: 15px;
}

.pageTitle .internalLink li a::before {
	content: '';
	display: block;
	position: absolute;
	inset-block-start: 50%;
	inset-inline-end: 7px;
	transform: rotate(135deg) translateX(-50%);
	block-size: 12px;
	inline-size: 12px;
	background: url(/asset/img/common/arrow01_m.svg) no-repeat center center;
	background-size: cover;
}

@media (width <=1024px) {
	.pageTitle .internalLink {
		grid-template-columns: repeat(2, 1fr);
		inline-size: 100%;
	}
}

@media (width <=800px) {
	.pageTitle {
		inline-size: 88%;
		margin-block: 100px 24px;
	}

	.pageTitle h1 {
		font-size: var(--font-size32);
	}

	.pageTitle .internalLink {
		gap: 4px 20px;
		margin-block-start: 40px;
		font-size: var(--font-size14);
	}

	.pageTitle .internalLink li a {
		grid-template-rows: minmax(20px, 100%);
		padding-block: 15px 14.5px;
	}

	.pageTitle .internalLink li a::before {
		inset-inline-end: 4px;
		block-size: 9px;
		inline-size: 9px;
		background-image: url(/asset/img/common/arrow01_xs.svg);
		background-size: cover;
	}
}

/*----------------------------------------
	contentWrap
-----------------------------------------*/
.contentWrap {
	display: grid;
	grid-template-columns: 1fr;
	inline-size: min(80%, 1120px);
	margin-block-start: 128px;
	margin-inline: auto;
	scroll-margin-block-start: 162px;
}

.contentWrap#visit {
	margin-block-start: 160px;
}

.contentWrap h2 {
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size36);
	line-height: var(--line-height15);
}

.contentWrap > dl {
	margin-block-start: 64px;
}

.contentWrap .accordionMenu {
	padding-block: 23.5px;
	padding-inline-end: 58px;
}

.contentWrap .accordionMenu span {
	display: block;
	text-indent: -1.4em;
	padding-inline-start: 1.4em;
}

.contentWrap .accordionMenu span::before {
	content: "Q. ";
}

.contentWrap .accordionContent > div {
	padding-block: 64px 95px;
	padding-inline: 30px 0;
	display: grid;
	gap: 32px;
}

.contentWrap .accordionContent > div > p:nth-of-type(1) {
	position: relative;
}

.contentWrap .accordionContent > div > p:nth-of-type(1)::before {
	content: "A.";
	position: absolute;
	left: -30px;
}

.contentWrap .accordionContent > div :where(p, li, dt, dd) {
	font-size: var(--font-size18);
	line-height: var(--line-height222);
}

.contentWrap .accordionContent > div a {
	text-decoration: underline;
}

.contentWrap .accordionContent > div a[target="_blank"]::after {
	content: '';
	display: inline-block;
	block-size: 14px;
	inline-size: 14px;
	margin-inline-start: 16px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	background-image: url(/asset/img/common/ic_external01_m.svg);
}

.contentWrap .accordionContent > div li {
	padding-inline-start: 1em;
	text-indent: -1em;
}

.contentWrap .accordionContent > div li::before {
	content: "\030FB";
}

.contentWrap .accordionContent > div dl {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0 20px;
	width: fit-content;
}

.contentWrap .accordionContent > div dt {
	grid-column: 1/2;
	grid-row: 1/4;
}

@media (width <=800px) {
	.contentWrap {
		grid-template-columns: 1fr;
		inline-size: 100%;
		margin-block-start: 96px;
		scroll-margin-block-start: 32px;
	}

	.contentWrap#visit {
		margin-block-start: 128px;
	}

	.contentWrap h2 {
		font-size: var(--font-size24);
		inline-size: 84%;
		margin-inline: auto;
	}
	
	.contentWrap .accordionMenu {
		padding-inline-end: 50px;
	}

	.contentWrap .accordionContent > div {
		padding-block: 48px 80px;
		padding-inline: 24px 0;
		inline-size: 84%;
		margin-inline: auto;
	}

	.contentWrap .accordionContent > div > p:nth-of-type(1)::before {
		left: -24px;
	}

	.contentWrap .accordionContent > div :where(p, li, dt, dd) {
		font-size: var(--font-size16);
	}
}