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

	- pageTitle
	- pageKv
	- summary
	- amuletInfo
	- info
	- categoryList

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

/*----------------------------------------
	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 h1 span {
	font-size: var(--font-size40);
}

@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 h1 span {
		font-size: var(--font-size24);
	}
}

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

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

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

/*----------------------------------------
	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-inline: auto;
	margin-block-start: 64px;
	scroll-margin-block-start: 162px;
}

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

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

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

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

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

.amuletInfo .clm3 div>div {
	margin-block-start: 17px;
}

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

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

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

@media (width <=1280px) {
	.amuletInfo .clm3 {
		gap: 64px 30px;
		grid-template-columns: repeat(2, 1fr);
	}

	.amuletInfo .clm3>div:last-of-type {
		display: grid;
		gap: 0 30px;
		grid-template-columns: repeat(2, 1fr);
		grid-area: 2 / 1 / 3 / 3;
	}

	.amuletInfo .clm3>div:last-of-type>div {
		margin-block-start: 0;
	}
}

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

	.amuletInfo>div:has(div) {
		margin-block-start: 0;
	}
}

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

	.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 .clm3 {
		gap: 64px 15px;
	}

	.amuletInfo .clm3>div:last-of-type {
		gap: 0 15px;
	}

	.amuletInfo .clm3 div>div {
		margin-block-start: 13px;
	}

	.amuletInfo .clm3 div dl dt {
		font-size: var(--font-size16);
	}

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

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

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

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

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

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

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

.info .infoTxt div>p+p {
	margin-block-start: 37px;
}

.info .infoTxt div>p a {
	border-block-end: var(--border-width1) solid currentColor;
}

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

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

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

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

	.info .infoTxt div>p+p {
		margin-block-start: 30px;
	}
}

@media (width <=375px) {
	.info .infoTxt div dl {
		gap: unset;
		grid-template-columns: 1fr;
	}

	.info .infoTxt div dl dd+dt {
		margin-block-start: 9px;
	}
}

/*----------------------------------------
		categoryList
-----------------------------------------*/
.categoryList {
	display: flex;
	flex-wrap: wrap;
	gap: 80px 56px;
	justify-content: center;
	inline-size: min(80%, 1120px);
	margin-block-start: 80px;
	margin-inline: auto;
}

.categoryList .category_s {
	inline-size: calc((100%/3) - (112px/3));
}

.categoryList .category_s a {
	display: block;
	opacity: 1;
}

@media (hover: hover) {
	.categoryList .category_s a:hover .categoryImg {
		opacity: 0.6;
		transition: all 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	}
}

.categoryList .category_s .categoryContainer {
	display: grid;
	gap: 0 5px;
	grid-template-columns: auto max-content;
	position: relative;
	margin-block-start: 24px;
}

.categoryList .category_s .categoryContainer .categoryNumber {
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: -0.85em;
	color: var(--color-visitlight01);
}

.categoryList .category_s .categoryContainer .categoryNumber::before {
	content: '';
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: 50%;
	block-size: 120px;
	inline-size: 1px;
	border-inline-start: var(--border-width1) solid var(--color-visitlight01);
}

.categoryList .category_s .categoryContainer .categoryNumber p {
	margin-block-start: 121px;
	padding-inline: 6px;
	font-size: var(--font-size16);
	line-height: var(--line-height125);
	font-family: var(--font-family-playfairdisplay);
}

.categoryList .category_s .categoryContainer .categoryTitle {
	margin-inline-start: 32px;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size28);
	line-height: var(--line-height15);
}

.categoryList .category_s a .categoryContainer .categoryTitle>span {
	display: block;
}

.categoryList .category_s .categoryContainer .categoryTitle::after {
	content: '';
	display: block;
	block-size: 28px;
	inline-size: 28px;
	margin-block-start: 12px;
	border: 1px solid var(--color-black01);
	border-radius: 100vh;
	background: url(/asset/img/common/arrow01_s.svg) no-repeat center center;
	background-size: 8px 8px;
}

@media (hover: hover) {
	.categoryList .category_s a:hover .categoryContainer .categoryTitle>span {
		opacity: 0.6;
		transition: all 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	}

	.categoryList .category_s a:hover .categoryContainer .categoryTitle::after {
		border-color: var(--color-darkgray01);
		background-color: var(--color-darkgray01);
		background-image: url(/asset/img/common/arrow01w_s.svg);
		transition: all 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	}
}

.categoryList .category_s .categoryContainer .categoryLead {
	margin-block-start: -0.5em;
	margin-inline-start: 5px;
	font-size: var(--font-size14);
	line-height: var(--line-height20);
	font-family: var(--font-family-mincho);
	writing-mode: vertical-rl;
}

@media (width <=1152px) {
	.categoryList .category_s {
		inline-size: calc(50% - 28px);
	}
}

@media (width <=800px) {
	.categoryList {
		gap: 30px 0;
		inline-size: 84%;
		margin-block-start: 65px;
	}

	.categoryList .category_s {
		inline-size: 100%;
	}

	.categoryList .category_s .categoryContainer .categoryNumber {
		inset-inline-start: -0.9em;
	}

	.categoryList .category_s .categoryContainer .categoryNumber p {
		padding-inline: 5px;
	}
}