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

	- pageTitle
	- pageKv
	- summary
	- info
	- heading
	- description

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

/*----------------------------------------
	pageTitle
-----------------------------------------*/
.pageTitle {
	display: grid;
	grid-template-columns: auto max-content;
	grid-template-areas: 'pageTitleContainer pageCategory';
	inline-size: min(80%, 1120px);
	margin-block-start: 35px;
	margin-inline: auto;
}

.pageTitle .pageCategory.about>span:not(:first-of-type) {
	margin-inline-end: 16px;
}

.pageTitle .pageTitleContainer {
	grid-area: pageTitleContainer;
	inline-size: min(100%, 1028px);
	margin-block: 156px 40px;
}

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

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

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

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

.pageTitle .pageTitleContainer .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;
}

.pageTitle .pageTitleContainer .relationLink {
	display: grid;
	gap: 16px 64px;
	grid-template-columns: repeat(3, 1fr);
	margin-block-start: 63px;
}

.pageTitle .pageTitleContainer .relationLink dl dt {
	display: inline-block;
	position: relative;
	padding-inline-end: 30px;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size20);
	line-height: var(--line-height15);
}

.pageTitle .pageTitleContainer .relationLink dl dt::after {
	content: '';
	display: block;
	position: absolute;
	inset-block-start: 0.5em;
	inset-inline-end: 0;
	block-size: 10px;
	inline-size: 10px;
	background: url(/asset/img/common/arrow01_s.svg) no-repeat center center;
	background-size: cover;
}

.pageTitle .pageTitleContainer .relationLink dl dd {
	margin-block-start: 10px;
	font-size: var(--font-size14);
	line-height: var(--line-height20);
	font-family: var(--font-family-mincho);
}

.pageTitle .pageTitleContainer .relationLink li:only-of-type dl dd {
	white-space: nowrap;
}

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

	.pageTitle .pageTitleContainer .relationLink {
		gap: 40px 0;
		grid-template-columns: auto;
	}
}

@media (width <=800px) {
	.pageTitle {
		inline-size: 94%;
		margin-block-start: 22px;
		padding-inline-start: 3%;
	}

	.pageTitle .pageTitleContainer {
		inline-size: 100%;
		margin-block: 78px 24px;
	}

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

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

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

	.pageTitle .pageTitleContainer .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;
	}

	.pageTitle .pageTitleContainer .relationLink {
		margin-block-start: 66px;
	}

	.pageTitle .pageTitleContainer .relationLink a {
		display: inline-block;
	}

	.pageTitle .pageTitleContainer .relationLink dl dd {
		margin-block-start: 11px;
	}

	.pageTitle .pageTitleContainer .relationLink li:only-of-type dl dd {
		white-space: unset;
	}
}

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

.pageKv div {
	margin-inline-end: calc(50% - (50vw - 7.5px));
}

.heading+.pageKv {
	margin-block-start: 40px;
}

.heading:has(h3:only-child, div)+.pageKv {
	margin-block-start: 39px;
}

@media (width <=800px) {
	.pageKv {
		inline-size: 100%;
		margin-inline: 0;
	}

	.heading+.pageKv {
		margin-block-start: 24px;
	}

	.heading:has(h3:only-child, div)+.pageKv {
		margin-block-start: 23px;
	}

	.pageKv div {
		margin-inline-end: 0;
	}
}

/*----------------------------------------
	summary
-----------------------------------------*/
.summary {
	display: grid;
	grid-template-columns: minmax(57.14%, 800px) auto;
	inline-size: min(80%, 1120px);
	margin-block-start: 67px;
	margin-inline: auto;
}

.summary:has(h4:only-child) {
	grid-template-columns: 1fr;
	align-items: end;
}

.summary :is(h2, h4) {
	order: 2;
	min-block-size: 270px;
	margin-block: -0.5em 10px;
	font-size: var(--font-size30);
	font-family: var(--font-family-mincho);
	writing-mode: vertical-rl;
}

.summary .summaryContainer {
	order: 1;
	inline-size: 100%;
	margin-block-start: 319px;
}

@media (width <=800px) {
	.summary {
		grid-template-columns: auto;
		inline-size: 84%;
		margin-block-start: 66px;
	}

	.summary :is(h2, h4) {
		order: 1;
		min-block-size: unset;
		margin-block: -0.7em 0;
		font-size: var(--font-size22);
	}

	.summary .summaryContainer {
		order: 2;
		margin-block-start: 65px;
	}
}

/*----------------------------------------
	info
-----------------------------------------*/
.info {
	margin-block-start: 64px;
}

.info div a.btn01 {
	margin-block-start: 64px;
}

@media (width <=800px) {
	.info a.btn01 {
		margin-inline: auto;
	}
}

/*----------------------------------------
	heading
-----------------------------------------*/
.heading {
	display: grid;
	gap: 0 126px;
	grid-template-columns: max-content auto;
	inline-size: min(80%, 1120px);
	margin-block-start: 152px;
	margin-inline: auto;
	scroll-margin-block-start: 162px;
}

.info+.heading {
	margin-block-start: 160px;
}

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

.heading dl {
	display: grid;
	gap: 6px 32px;
	grid-template-columns: max-content auto;
	align-items: baseline;
	margin-block-start: 0.8em;
	font-size: var(--font-size20);
	line-height: var(--line-height15);
}

.heading>div dl {
	gap: 4px 32px;
	margin-block-start: 0.2em;
}

.heading dl dt {
	font-weight: var(--font-weight-medium);
}

.heading dl dd {
	line-height: var(--line-height20);
	font-family: var(--font-family-mincho);
}

.heading>div p {
	margin-block-start: 32px;
	font-size: var(--font-size16);
	line-height: var(--line-height20);
}

.description .heading>div p {
	margin-block-start: 41px;
}

@media (width <=1024px) {
	.heading {
		gap: 0;
		grid-template-columns: 1fr;
	}

	.heading h3 br {
		display: none;
	}
}

@media (width <=800px) {
	.heading {
		gap: 40px 0;
		grid-template-columns: 1fr;
		inline-size: 88%;
		margin-block-start: 119px;
		scroll-margin-block-start: 32px;
	}

	.info+.heading {
		margin-block-start: 128px;
	}

	.heading h3 {
		font-size: var(--font-size32);
	}

	.heading dl {
		gap: 8px 24px;
		grid-template-columns: max-content auto;
		margin-block-start: 0;
		font-size: var(--font-size14);
	}

	.heading>div dl {
		margin-block-start: unset;
	}

	.heading>div dl {
		gap: 5px 24px;
	}

	.heading>div p {
		font-size: var(--font-size14);
	}
}

/*----------------------------------------
	description
-----------------------------------------*/
.description {
	inline-size: min(80%, 1120px);
	margin-block-start: 161px;
	margin-inline: auto;
}

.summary:has(h4:only-child)+.description {
	margin-block-start: 64px;
}

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

.description>p {
	margin-block-start: 68px;
}

.description .clm2 {
	display: grid;
	gap: 0 80px;
	grid-template-columns: repeat(2, 1fr);
	margin-block-start: 80px;
}

.description .clm2:has(dl) {
	margin-block-start: 100px;
}

.description .clm2:has(dl):first-of-type {
	margin-block-start: 80px;
	padding-block-start: 82px;
	border-block-start: var(--border-width1) solid var(--color-black01);
}

.description figure figcaption {
	margin-block-start: 16px;
	font-size: var(--font-size14);
	line-height: var(--line-height20);
}

.description .clm2 p:first-of-type {
	margin-block-start: -12px;
}

.description .clm2>dl {
	margin-block-start: -12px;
}

.description .clm2>dl dt {
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size28);
	line-height: var(--line-height15);
}

.description .clm2>dl dt span {
	padding-inline-end: 0.3em;
}

.description .clm2>dl dd {
	margin-block-start: 64px;
}

.description .clm2 :is(p, .glossary)+p {
	margin-block-start: 68px;
}

.description .heading {
	inline-size: auto;
	margin-block-start: 0;
	margin-inline: unset;
}

@media (width <=800px) {
	.description {
		inline-size: 84%;
		margin-block-start: 127px;
	}

	.description .clm2:has(dl) {
		margin-block-start: 108px;
	}

	.description .clm2:has(dl):first-of-type {
		margin-block-start: 63px;
		padding-block-start: 76px;
	}

	.description h5 {
		font-size: var(--font-size24);
	}

	.description .clm2 {
		gap: 64px 0;
		grid-template-columns: 1fr;
		margin-block-start: 67px;
	}

	.description .clm2 p:first-of-type {
		margin-block-start: 0;
	}

	.description .clm2>dl dt {
		font-size: var(--font-size20);
	}

	.description .clm2>dl dd {
		margin-block-start: 32px;
	}
}