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

	- pageTitle
	- pageTab
	- pageMenu
	- event

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

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

.pageTitle .pageTitleContainer h1 {
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size52);
	line-height: var(--line-height15);
}

.pageTitle .pageTitleContainer :is(h1)+* {
	margin-block-start: 65px;
	font-size: var(--font-size16);
}

.pageTitle .pageCategory>span:not(:first-of-type) {
	margin-inline-end: 0;
}

@media (width <=800px) {
	.pageTitle {
		inline-size: 94%;
		margin-block-start: 22px;
		padding-inline-start: 3%;
	}

	.pageTitle .pageTitleContainer {
		inline-size: 100%;
		margin-block: 78px 7px;
	}

	.pageTitle .pageTitleContainer h1 {
		font-size: var(--font-size32);
	}

	.pageTitle .pageTitleContainer :is(h1)+* {
		font-size: var(--font-size14);
	}
}

/*----------------------------------------
	pageTab
-----------------------------------------*/
.pageTab {
	display: grid;
	grid-template-columns: repeat(2, minmax(32.14%, 360px));
	align-items: end;
	position: relative;
	inline-size: min(80%, 1120px);
	margin-block-start: 49px;
	margin-inline: auto;
	padding-inline: 8px;
}

ul.pageTab {
	align-items: start;
	margin-block-start: 64px;
}

.pageTab :is(h2, li:first-of-type) {
	display: grid;
	justify-content: center;
	align-items: center;
	min-block-size: 102px;
	padding-block: 10px;
	border-inline: 1px solid var(--color-black01);
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size36);
	line-height: var(--line-height15);
}

.pageTab h2 {
	border-block-start: 1px solid var(--color-black01);
	border-block-end: 1px solid var(--color-pearl01);
}

.pageTab li:first-of-type {
	border-block-start: 1px solid var(--color-pearl01);
	border-block-end: 1px solid var(--color-black01);
}

.pageTab :is(p, li:last-of-type) {
	border-inline-end: 1px solid var(--color-black01);
	font-size: var(--font-size24);
	line-height: var(--line-height125);
}

.pageTab p {
	border-block-start: 1px solid var(--color-black01);
}

.pageTab li:last-of-type {
	border-block-end: 1px solid var(--color-black01);
}

.pageTab :is(p, li:last-of-type) a {
	display: grid;
	justify-content: center;
	align-items: center;
	min-block-size: 84px;
	padding-block: 10px;
	opacity: 1;
}

@media (hover: hover) {
	.pageTab :is(p, li:last-of-type):has(a:hover) {
		border-color: var(--color-darkgray01);
	}

	.pageTab :is(p, li:last-of-type) a:hover {
		background-color: var(--color-darkgray01);
		color: var(--color-white01);
		transition: all 0.2s cubic-bezier(0.45, 0, 0.55, 1);
	}
}

.pageTab::before {
	content: '';
	display: block;
	position: absolute;
	block-size: 1px;
	inline-size: 100%;
	border-block-end: 1px solid var(--color-black01);
	z-index: -1;
}

div.pageTab::before {
	inset-block-end: 0;
}

ul.pageTab::before {
	inset-block-start: 0;
}

@media (width <=800px) {
	.pageTab {
		grid-template-columns: repeat(2, 1fr);
		inline-size: 100%;
		margin-block-start: 48px;
		margin-inline: 0;
		padding-inline: 0;
	}

	.pageTab :is(h2, li:first-of-type) {
		min-block-size: 70px;
		border-inline-start: none;
		font-size: var(--font-size20);
	}

	.pageTab :is(p, li:last-of-type) {
		border-inline-end: none;
		font-size: var(--font-size16);
	}

	.pageTab :is(p, li:last-of-type) a {
		min-block-size: 60px;
	}
}

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

ul.pageTab+.pageMenu {
	margin-block-start: 65px;
}

.pageMenu .internalLink {
	display: grid;
	gap: 16px 64px;
	grid-template-columns: repeat(6, 1fr);
	margin-inline-start: 8px;
	font-size: var(--font-size20);
	line-height: var(--line-height125);
}

.pageMenu .internalLink+.internalLink {
	grid-template-columns: repeat(2, 1fr);
	margin-block-start: 16px;
}

.pageMenu .internalLink li {
	border-block-end: var(--border-width1) solid var(--color-black01);
}

.pageMenu .internalLink li :is(a, span) {
	display: grid;
	grid-template-rows: minmax(26px, 100%);
	align-items: center;
	position: relative;
	block-size: 100%;
	padding-block: 15px;
}

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

.pageMenu .internalLink li span {
	color: var(--color-opalgray01);
}

.pageMenu .internalLink+p {
	margin-block-start: 64px;
}

.pageMenu .btn01 {
	margin-block-start: 64px;
}

ul.pageTab+.pageMenu .btn01 {
	max-inline-size: 283px;
}

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

	.pageMenu .internalLink+.internalLink {
		grid-template-columns: 1fr;
	}
}

@media (width <=800px) {
	.pageMenu {
		inline-size: 88%;
		margin-block-start: 40px;
		margin-inline: auto;
	}

	.pageMenu .internalLink {
		gap: 4px 32px;
		margin-inline-start: 0;
		font-size: var(--font-size14);
	}

	.pageMenu .internalLink+.internalLink {
		margin-block-start: 4px;
	}

	.pageMenu .internalLink li :is(a, span) {
		grid-template-rows: minmax(20px, 100%);
		padding-block: 15px 14px;
	}

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

	.pageMenu .btn01 {
		margin-inline: auto;
	}

	ul.pageTab+.pageMenu .btn01 {
		max-inline-size: 230px;
	}
}

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

#Jan.event {
	margin-block-start: 160px;
}

.event .eventMonth {
	padding-block: 20px;
	padding-inline: 32px;
	background: var(--color-palegray01);
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size36);
	line-height: var(--line-height15);
}

.event .eventDate {
	display: grid;
	gap: 0 80px;
	grid-template-columns: minmax(auto, 400px) auto;
	padding-block: 32px;
	padding-inline: 32px 0;
}

.event .eventDate:not(:first-of-type) {
	margin-block-start: 30px;
	border-block-start: var(--border-width1) solid var(--color-black01);
}

.event .eventDate .eventDateTitle h4 {
	font-size: var(--font-size30);
	line-height: var(--line-height20);
	font-family: var(--font-family-mincho);
}

.event .eventDate .eventDateTitle h4 span {
	display: block;
	font-weight: var(--font-weight-medium);
	font-size: var(--font-size36);
	font-family: var(--font-family);
}

.event .eventDate .eventDateTitle h4+:is(img, figure) {
	display: block;
	margin-block-start: 22px;
}

.event .eventDate .eventDateTitle h4+figure figcaption {
	margin-block-start: 16px;
	font-size: var(--font-size14);
	line-height: var(--line-height20);
}

.event .eventDate .eventDateContainer {
	margin-block-start: 3.8em;
}

.event .eventDate .eventDateContainer :is(.eventDateTime, .eventDateTxt):not(:first-child) {
	margin-block-start: 28px;
}

.event .eventDate .eventDateContainer dl.eventDateTime dd {
	margin-inline-start: 1em;
}

.event .eventDate .eventDateContainer dl.eventDateTime dd ul {
	display: grid;
	grid-template-columns: max-content max-content auto;
	line-height: var(--line-height25);
}

.event .eventDate .eventDateContainer dl.eventDateTime dd ul li {
	display: grid;
	gap: 0 22px;
	grid-template-columns: subgrid;
	grid-column: span 3;
}

.event .eventDate .eventDateContainer ul.eventDateTime {
	display: grid;
	grid-template-columns: max-content auto;
	line-height: var(--line-height25);
}

.event .eventDate .eventDateContainer ul.eventDateTime li {
	display: grid;
	gap: 0 22px;
	grid-template-columns: subgrid;
	grid-column: span 2;
}

.event .eventDate .eventDateContainer p.eventDateTime {
	display: grid;
	gap: 0 20px;
	grid-template-columns: max-content auto;
	line-height: var(--line-height25);
}

.event .eventDate .eventDateContainer :is(dl.eventDateTime dt, ul.eventDateTime li, p.eventDateTime) {
	position: relative;
	padding-left: 1em;
}

.event .eventDate .eventDateContainer :is(dl.eventDateTime dt, ul.eventDateTime li, p.eventDateTime)::before {
	content: '\025A0';
	position: absolute;
	top: 0;
	left: 0;
}

.event .eventDate .eventDateContainer .btn01 {
	margin-block-start: 64px;
}

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

	.event .eventDate .eventDateContainer {
		margin-block-start: 0;
	}
}

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

	#Jan.event {
		margin-block-start: 127px;
	}

	.event .eventMonth {
		padding-inline: 8%;
		font-size: var(--font-size24);
	}

	.event .eventDate {
		gap: 24px 0;
		inline-size: 84%;
		margin-inline: auto;
		padding-inline: 0;
	}

	.event .eventDate:not(:first-of-type) {
		margin-block-start: 32px;
	}

	.event .eventDate .eventDateTitle h4 {
		font-size: var(--font-size20);
	}

	.event .eventDate .eventDateTitle h4 span {
		font-size: var(--font-size24);
	}

	.event .eventDate .eventDateTitle h4+:is(img, figure) {
		margin-block: 25px 6px;
	}

	.event .eventDate .eventDateContainer .btn01 {
		margin-inline: auto;
	}
}