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

	- pageKv
	- pageMain
	- summary
	- category_l
	- relatedPage_first
	- categoryList
	- video
	- info

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

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

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

.pageKv h1 {
	position: relative;
	block-size: 100%;
	margin-inline-start: -3.15em;
	margin-inline-end: -2.05em;
	color: var(--color-white01);
	font-size: var(--font-size60);
	line-height: var(--line-height10);
	writing-mode: vertical-rl;
}

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

	.pageKv h1 {
		position: relative;
		block-size: 96%;
		margin-inline-start: -2.55em;
		margin-inline-end: -2.69em;
		font-size: var(--font-size44);
	}
}

/*----------------------------------------
	pageMain
-----------------------------------------*/
.pageMain {
	z-index: 1;
	position: relative;
	overflow: hidden;
}

.pageMain .pageMainContainer {
	position: relative;
	inline-size: min(80%, 1120px);
	margin-inline: auto;
	padding-block: 24px 32px;
	padding-inline-start: 64px;
}

.pageMain .pageMainContainer::before {
	content: '';
	display: block;
	z-index: 10;
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: -20vw;
	block-size: 100%;
	inline-size: 20vw;
	background: var(--color-pearl01);
}

.pageMain .pageMainContainer::after {
	content: '';
	display: block;
	z-index: -1;
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: 0;
	block-size: 100%;
	inline-size: 100vw;
	border-end-start-radius: 64px;
	background: linear-gradient(160deg, var(--color-gradient-ritual01) 10%, var(--color-gradient-ritual02) 50%, var(--color-gradient-ritual03) 90%);
}

.pageMain .pageMainContainer .pageCategory {
	gap: 0 15px;
	min-inline-size: 201px;
	margin-inline-end: 10px;
	font-size: var(--font-size50);
}

.pageMain .pageMainContainer .pageCategory>span:not(:first-of-type) {
	margin-block-start: 2px;
	margin-inline-end: 0;
	border-block-start-style: unset;
	border-block-start-width: unset;
}

.pageMain .pageMainContainer .pageCategory>span:not(:first-of-type) span {
	font-size: var(--font-size12);
}

@media (width <=800px) {
	.pageMain {
		overflow: unset;
	}

	.pageMain .pageMainContainer {
		inline-size: 100%;
		margin-inline: 0;
		padding-block: 26px 64px;
		padding-inline-start: 4%;
		overflow: hidden;
	}

	.pageMain .pageMainContainer::before {
		display: none;
	}

	.pageMain .pageMainContainer::after {
		inline-size: 100%;
		background: linear-gradient(130deg, var(--color-gradient-ritual01) 10%, var(--color-gradient-ritual02) 50%, var(--color-gradient-ritual03) 90%);
	}

	.pageMain .pageMainContainer .pageCategory {
		gap: 0 10px;
		min-inline-size: 162px;
		font-size: var(--font-size36);
	}

	.pageMain .pageMainContainer .pageCategory>span:not(:first-of-type) {
		margin-block-start: 0;
	}

	.pageMain .pageMainContainer .pageCategory span:not(:first-of-type) span {
		transform: unset;
	}
}

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

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

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

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

.category_l+.category_l {
	margin-block-start: 140px;
}

.category_l .categoryImg {
	margin-inline-start: calc(50% - (50vw - 7.5px));
}

.category_l .categoryImg a {
	display: block;
}

.category_l .categoryContainer {
	display: grid;
	gap: 0 39px;
	align-items: start;
	grid-template-columns: auto max-content minmax(auto, 368px);
	grid-template-areas: 'categoryTitle categoryLead categoryLink';
	position: relative;
}

.category_l .categoryContainer .categoryNumber {
	display: grid;
	grid-template-rows: auto max-content;
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: -0.85em;
	margin-block-start: 48px;
	color: var(--color-rituallight01);
}

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

.category_l .categoryContainer .categoryNumber p:first-of-type {
	inline-size: 120px;
	margin-block: auto -1px;
	font-size: var(--font-size10);
	line-height: var(--line-height10);
	font-family: var(--font-family-jost);
	writing-mode: vertical-rl;
}

.category_l .categoryContainer .categoryNumber p:last-of-type {
	padding-inline: 4px;
	font-size: var(--font-size20);
	line-height: var(--line-height125);
	font-family: var(--font-family-playfairdisplay);
}

.category_l .categoryContainer .categoryTitle {
	grid-area: categoryTitle;
	margin-block-start: 48px;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size40);
	line-height: var(--line-height15);
}

.category_l .categoryContainer .categoryTitle a {
	display: block;
	opacity: 1;
	padding-inline-start: 64px;
}

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

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

@media (hover: hover) {
	.category_l .categoryContainer .categoryTitle a:hover::after {
		border-color: var(--color-darkgray01);
		background-color: var(--color-darkgray01);
		background-image: url(/asset/img/common/arrow01w_l.svg);
	}

	.category_l .categoryContainer .categoryTitle a:hover>span {
		opacity: 0.6;
	}
}

.category_l .categoryContainer .categoryLead {
	grid-area: categoryLead;
	margin-inline-start: 53px;
	font-size: var(--font-size16);
	font-family: var(--font-family-mincho);
	writing-mode: vertical-rl;
}

.category_l .categoryContainer .categoryLink {
	display: grid;
	gap: 7px 0;
	grid-area: categoryLink;
	padding-block: 31px 47px;
	padding-inline: 64px;
	border-end-end-radius: 64px;
	background: var(--color-darkgray01);
	font-size: var(--font-size16);
	line-height: var(--line-height125);
}

.category_l .categoryContainer .categoryLink li {
	border-block-end: var(--border-width1) solid var(--color-white01);
}

.category_l .categoryContainer .categoryLink li a {
	display: grid;
	grid-template-rows: minmax(22px, 100%);
	align-items: center;
	position: relative;
	block-size: 100%;
	padding-block: 15px;
	padding-inline-end: 0;
	color: var(--color-white01);
}

.category_l .categoryContainer .categoryLink li a::after {
	content: '';
	display: block;
	position: absolute;
	inset-block-start: 50%;
	inset-inline-end: 0;
	transform: translateY(-50%);
	block-size: 10px;
	inline-size: 10px;
	background: url(/asset/img/common/arrow01w_m.svg) no-repeat center center;
	background-size: cover;
}

@media (width <=1024px) {
	.category_l .categoryContainer {
		gap: 48px 48px;
		grid-template-columns: 1fr max-content;
		grid-template-areas: 'categoryTitle categoryLead'
			'categoryLink categoryLink';
		margin-block-start: 48px;
	}

	.category_l .categoryContainer :is(.categoryNumber, .categoryTitle) {
		margin-block-start: 0;
	}

	.category_l .categoryContainer .categoryLead {
		margin-block-start: -0.6em;
		margin-inline-start: 5px;
	}

	.category_l .categoryContainer .categoryLink {
		position: relative;
		margin-inline-start: 0;
		border-end-end-radius: 0;
		background: unset;
	}

	.category_l .categoryContainer .categoryLink::after {
		content: '';
		display: block;
		z-index: -1;
		position: absolute;
		inset-block-start: 0;
		inset-inline-end: 0;
		block-size: 100%;
		inline-size: 100vw;
		border-end-end-radius: 64px;
		background: var(--color-darkgray01);
	}
}

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

	.category_l+.category_l {
		margin-block-start: 65px;
	}

	.category_l .categoryImg {
		margin-inline-start: 0;
	}

	.category_l .categoryContainer {
		gap: 0;
		grid-template-columns: auto;
		grid-template-areas: 'categoryTitle'
			'categoryLead'
			'categoryLink';
		inline-size: 84%;
		margin-block-start: 32px;
		margin-inline: auto;
	}

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

	.category_l .categoryContainer .categoryTitle {
		font-size: var(--font-size32);
	}

	.category_l .categoryContainer .categoryTitle a {
		padding-inline-start: 32px;
	}

	.category_l .categoryContainer .categoryTitle a::after {
		block-size: 32px;
		inline-size: 32px;
		margin-block-start: 12px;
		background: url(/asset/img/common/arrow01_s.svg) no-repeat center center;
		background-size: 10px 10px;
	}

	.category_l .categoryContainer .categoryLink {
		margin-block-start: 20px;
		padding-inline: 32px 64px;
	}
}

/*----------------------------------------
	relatedPage_first
-----------------------------------------*/
.relatedPage_first {
	margin-block-start: 78px;
}

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

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

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

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

.categoryList .category_s .categoryContainer .categoryTitle>span:first-of-type {
	display: block;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size28);
	line-height: var(--line-height15);
}

.categoryList .category_s .categoryContainer .categoryTitle>span:first-of-type::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;
}

.categoryList .category_s .categoryContainer .categoryTitle>span:first-of-type>span {
	display: block;
}

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

	.categoryList .category_s a:hover .categoryContainer .categoryTitle>span:first-of-type::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 .categoryTitle>span:first-of-type>span span {
	display: block;
	font-size: var(--font-size14);
}

.categoryList .category_s .categoryContainer .categoryTitle .status {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 8px;
	margin-block-start: 16px;
}

.categoryList .category_s .categoryContainer .categoryTitle .status span {
	display: grid;
	justify-content: center;
	align-items: center;
	block-size: 19px;
	inline-size: 80px;
	background-color: var(--color-white01);
	font-size: var(--font-size12);
	line-height: var(--line-height125);
}

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

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

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

@media (width <=1280px) {
	.info.black .infoTitle br {
		display: none;
	}
}

@media (width <=1040px) {
	.info.black .infoTitle br {
		display: block;
	}
}

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

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