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

	- pageTitle
	- pageKv
	- amuletInfo
	- info
	- 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.visit>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;
}

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

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

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

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

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

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

/*----------------------------------------
	amuletInfo
-----------------------------------------*/
.amuletInfo {
	display: grid;
	gap: 0 40px;
	grid-template-columns: minmax(calc(30.35% - 40px), 268px) minmax(69.64%, 780px);
	inline-size: min(80%, 1120px);
	margin-block-start: 160px;
	margin-inline: auto;
	scroll-margin-block-start: 162px;
}

.info+.amuletInfo {
	margin-block-start: 130px;
}

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

.amuletInfo>div>p:has(span) {
	margin-block-end: 32px;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size24);
	line-height: var(--line-height15);
}

.amuletInfo>div>p>span {
	display: block;
	margin-block-start: 9px;
	font-size: var(--font-size16);
	line-height: var(--line-height222);
}

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

.amuletInfo .clm2 div>a {
	display: block;
}

.amuletInfo .clm2 div dl dt {
	margin-block-start: 17px;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size20);
	line-height: var(--line-height15);
}

.amuletInfo .clm2 div dl dd {
	margin-block-start: 6px;
	font-size: var(--font-size16);
	line-height: var(--line-height2);
}

.amuletInfo .clm2 div .btn02 {
	margin-block-start: 17px;
}

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

@media (width <=800px) {
	.amuletInfo {
		gap: 32px 0;
		inline-size: 84%;
		margin-block-start: 128px;
		margin-inline: auto;
		scroll-margin-block-start: 32px;
	}

	.amuletInfo+.amuletInfo {
		margin-block-start: 64px;
	}

	.info+.amuletInfo {
		margin-block-start: 62px;
	}

	.amuletInfo h2 {
		font-size: var(--font-size24);
	}

	.amuletInfo>div>p:has(span) {
		font-size: var(--font-size18);
	}

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

	.amuletInfo .clm2 {
		gap: 64px 15px;
		margin-block-start: 0;
	}

	.amuletInfo .clm2 div dl dt {
		margin-block-start: 13px;
		font-size: var(--font-size16);
	}

	.amuletInfo .clm2 div dl dd {
		font-size: var(--font-size14);
	}

	.amuletInfo .clm2 div .btn02 {
		max-inline-size: 113px;
		margin-block-start: 19px;
	}
}

/*----------------------------------------
	info
-----------------------------------------*/

.info {
	margin-block-start: 32px;
}

.info .infoTxt p+p {
	margin-block-start: 38px;
}


@media (width <=800px) {
	.info {
		margin-block-start: 32px;
	}

	.info .infoTxt p+p {
		margin-block-start: 31px;
	}
}

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

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

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

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

.description>div:not(.clm2) {
	margin-block-start: 28px;
	border-block: var(--border-width1) solid var(--color-black01);
}

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

.description div.clm2 {
	margin-block-start: 63px;
}

.description .clm2 p:not(:has(.btn01)) {
	margin-block-start: 32px;
	font-size: var(--font-size16);
	line-height: var(--line-height20);
}

.description .clm2 .btn01 {
	margin-block-start: 63px;
}

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

.description dl:has(dl)>dd {
	margin-block-start: 32px;
	border-block: var(--border-width1) solid var(--color-black01);
}

.description dl:not(:has(dl)) {
	display: grid;
	grid-template-columns: max-content auto;
}

.description dl:not(:has(dl))+dl {
	margin-block-start: 0;
	border-block-start: var(--border-width1) solid var(--color-opalgray01);
}

.description dl:not(:has(dl)) :is(dt, dd) {
	padding-block: 19px;
}

.description dl:not(:has(dl)) dt {
	min-inline-size: 136px;
	padding-inline-end: 16px;
	font-weight: var(--font-weight-medium);
	line-height: var(--line-height20);
}

.description dl:not(:has(dl)) dd {
	font-size: var(--font-size16);
}

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

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

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

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

	.description .clm2 p:not(:has(.btn01)) {
		font-size: var(--font-size14);
	}

	.description .clm2 .btn01 {
		margin-inline: auto;
	}

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

	.description dl:not(:has(dl)) dt {
		min-inline-size: 113px;
	}

	.description dl:not(:has(dl)) dd {
		font-size: var(--font-size14);
	}
}
