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

	- pageTitle
	- info
	- heading
	- shrineSlider
	- summary
	- accordionMenu
	- history
	- 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 .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;
	margin-block-start: 13px;
	font-size: var(--font-size52);
}

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

/*----------------------------------------
	infoList
-----------------------------------------*/
.infoList {
	inline-size: min(80%, 1120px);
	margin-block-start: 32px;
	margin-inline: auto;
	padding: 32px;
	background-color: var(--color-palegray01);
}

.infoList .info {
	inline-size: unset;
	margin-inline: unset;
	padding: unset;
	background-color: unset;
}

.infoList .info+.info {
	padding-block-start: 32px;
}

.infoList .info .infoTxt div dl {
	display: grid;
	gap: 0 50px;
	grid-template-columns: max-content auto;
	align-items: center;
}

.infoList .info .infoTxt div dl dt {
	font-weight: var(--font-weight-medium);
}

.infoList .info .infoTxt div dl dd {
	font-size: var(--font-size18);
}

.infoList .info .infoTxt div dl+p {
	margin-block-start: 16px;
}

@media (width <=1024px) {
	.infoList .info {
		gap: 10px 0;
	}
}

@media (width <=800px) {
	.infoList {
		inline-size: 100%;
		padding-inline: 8%;
	}

	.infoList .info {
		inline-size: unset;
		padding-inline: unset;
	}

	.infoList .info+.info {
		padding-block-start: 8%;
	}

	.infoList .info .infoTxt div dl {
		gap: 0 15px;
	}

	.infoList .info .infoTxt div dl dd {
		font-size: var(--font-size16);
	}
}

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

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

.heading h2 span {
	display: block;
	margin-block-start: 13px;
	font-size: var(--font-size52);
}

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

.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 ruby+ruby {
	margin-inline: 2em 0.5em;
}

.heading>div {
	margin-block-start: 48px;
}

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

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

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

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

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

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

	.heading dl {
		margin-block-start: 0;
	}

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

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

	.heading dl dd ruby,
	.heading dl dd rt {
		letter-spacing: -0.12em;
	}

	.heading dl dd ruby+ruby {
		margin-inline: 1em 0.3em;
	}

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

	.heading>div dl {
		gap: 2px 20px;
		grid-template-columns: max-content auto;
	}

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

/*----------------------------------------
	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 ul {
	display: grid;
	gap: 0 40px;
	grid-template-columns: repeat(2, 280px);
	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 ul {
		gap: 40px 0;
		grid-template-columns: 1fr;
		grid-template-rows: auto;
	}

	.summary .summaryContainer ul a.btn01 {
		max-inline-size: 247px;
		margin-inline: auto;
	}

	.summary .summaryContainer ul a[href^='https://goo.gl/'].btn01 {
		max-inline-size: 200px;
	}

	.summary .summaryContainer ul a[href$='pamphlet_tsukiyomi_geku.pdf'].btn01 {
		max-inline-size: 260px;
	}
}

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

.summary+.accordionMenu {
	margin-block-start: 160px;
}

.accordionMenu.active+.accordionContent+.accordionMenu {
	margin-block-start: 160px;
}

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

	.summary+.accordionMenu {
		margin-block-start: 127px;
	}

	.accordionMenu.active+.accordionContent+.accordionMenu {
		margin-block-start: 127px;
	}
}

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

.history h4 {
	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);
	align-items: start;
	margin-block-start: 80px;
}

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

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

.history .clm2 :is(p, .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 h4 {
		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;
	}
}

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

.description:has(.clm2_img2) {
	scroll-margin-block-start: 162px;
}

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

.description:has(.clm2_img2) h4 {
	font-size: var(--font-size36);
}

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

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

.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 p+p {
	margin-block-start: 64px;
}

.description .clm2_img1 {
	display: grid;
	gap: 0 80px;
	grid-template-columns: minmax(62.85%, 704px) minmax(30%, 336px);
	margin-block-start: 80px;
}

.description .clm2_img1 p:first-child {
	margin-block-start: -12px;
}

.description .clm2_img2 {
	display: grid;
	gap: 0 80px;
	grid-template-columns: minmax(31.07%, 348px) minmax(61.78%, 692px);
	margin-block-start: 80px;
}

.description .clm2_img2 div ul:first-child {
	margin-block-start: -12px;
}

.description .clm2_img2 div ul+p {
	margin-block-start: 32px;
	font-size: var(--font-size16);
}

.description .clm2_img2>ul {
	display: grid;
	gap: 0 20px;
	grid-template-columns: repeat(2, 1fr);
}

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

	.description .clm2_img2 {
		grid-template-columns: repeat(2, 1fr);
	}

	.description .clm2_img2>ul {
		gap: 64px 0;
		grid-template-columns: 1fr;
	}
}

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

	.description:has(.clm2_img2) {
		scroll-margin-block-start: 32px;
	}

	.description:has(.clm2_img1) {
		inline-size: 100%;
		margin-inline: unset;
	}

	.description h4 {
		font-size: var(--font-size28);
	}

	.description:has(.clm2_img1) h4 {
		inline-size: 88%;
		margin-inline: auto;
	}

	.description:has(.clm2_img2) h4 {
		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 .img2 {
		gap: 64px 0;
	}

	.description .clm2_img1 {
		gap: 64px 0;
		grid-template-columns: 1fr;
		inline-size: 84%;
		margin-block-start: 67px;
		margin-inline: auto;
	}

	.description .clm2_img2 div ul:first-child {
		margin-block-start: 0;
	}

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

	.description .clm2_img2 div ul:first-child {
		margin-block-start: 0;
	}

	.description .clm2_img2 div ul+p {
		font-size: var(--font-size14);
	}
}
