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

	- pageTitle
	- heading
	- shrineSlider
	- summary
	- history

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

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

.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-size24);
	line-height: var(--line-height15);
}

.pageTitle .pageTitleContainer h1 span {
	display: block;
	font-size: var(--font-size52);
	margin-block-start: 13px;
}

.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 :is(.internalLink)+* {
	margin-block-start: 66px;
}

.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-size16);
	}

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

/*----------------------------------------
	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;
}

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

.heading dl {
	display: grid;
	gap: 0 31px;
	grid-template-columns: max-content auto;
	margin-block-start: 0.625em;
	align-items: baseline;
}

.heading dl dt {
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size20);
	line-height: var(--line-height15);
}

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

.heading dl dd ul li:nth-of-type(n+2) {
	margin-block-start: 5px;
}

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

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

	.heading dl {
		gap: 0 20px;
		grid-template-columns: max-content auto;
		margin-block-start: 0;
	}

	.heading dl dt {
		font-size: var(--font-size14);
	}

	.heading dl dd {
		font-size: var(--font-size16);
	}

	.heading dl dd ul li:nth-of-type(n+2) {
		margin-block-start: 1px;
	}
}

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

.shrineSlider .swiper-container {
	margin-inline-end: calc(50% - (50vw - 7.5px));
}

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

	.shrineSlider .swiper-container {
		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 h3 {
	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;
}

.summary .summaryContainer dl {
	margin-block-start: 60px;
}

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

.summary .summaryContainer dl dd {
	margin-block-start: 16px;
	font-size: var(--font-size16);
}

.summary .summaryContainer dl dd+dt {
	margin-block-start: 22px;
}

.summary .summaryContainer .btn01 {
	margin-block-start: 66px;
}

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

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

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

	.summary .summaryContainer dl {
		margin-block-start: 61px;
	}

	.summary .summaryContainer dl dd {
		margin-block-start: 16px;
		font-size: var(--font-size14);
	}

	.summary .summaryContainer dl dd+dt {
		margin-block-start: 28px;
	}

	.summary .summaryContainer .btn01 {
		margin-inline: auto;
	}
}

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

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

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

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

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

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

.history .clm2 .glossary+p {
	margin-block-start: 68px;
}

.history .clm2 .img2 {
	display: grid;
	gap: 80px 0;
	grid-template-columns: 1fr;
	grid-template-rows: repeat(2, 1fr);
}

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

	.history h3 {
		font-size: var(--font-size24);
	}

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

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

	.history .clm2 .img2 {
		gap: 64px 0;
	}
}