@charset "utf-8";
/* CSS Document */ :root {
	--event01-color: #2178bb;
	--event02-color: #2ba461;
	/*--event03-color: #ff8d3d;
	--event04-color: #e86362;*/
	--event03-color: #aaa;
	--event04-color: #838a92;
	--sat-txtcolor: #1976d2;
	--sun-txtcolor: #e86362;
	--color-text: #333;
	--grid-hover-bgcolor: #e5e5e5;
}
/* ---- 置き換え ---- */
body:before {
	z-index: 102;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: #fff;
	content: "";
	touch-action: none;
	transition: opacity .6s, visibility 0s .6s;
	display: none;
}
.aside-nav__list a:after {
	background: url(../image/parts/sprite.svg#arrow-next-primary) no-repeat 50%/contain;
}
.aside-nav__list a[aria-current=page]:after {
	background-image: url(../image/parts/sprite.svg#arrow-next-white)
}
.wave-layer--1:after, .wave-layer--1:before {
	background-image: url(../image/parts/wave1.svg);
}
.wave-layer--2:after, .wave-layer--2:before {
	background-image: url(../image/parts/wave2.svg);
}
.link-arrow:before {
	background: url(../image/parts/sprite.svg#circle-arrow-next-primary) no-repeat 50%/contain;
}
.external:after, .link-external:after {
	background: url(../image/parts/sprite.svg#external) no-repeat 50%;
}
.add-fileicon[href*=".pdf"]:before {
	background-image: url(../image/parts/sprite.svg#pdf)
}
.add-fileicon[href*=".doc"]:before {
	background-image: url(../image/parts/sprite.svg#doc)
}
.add-fileicon[href*=".xls"]:before {
	background-image: url(../image/parts/sprite.svg#xls)
}
.btn2:after {
	background: url(../image/parts/sprite.svg#arrow-next-white) no-repeat 50%/contain;
}
.btn2 .external:after {
	background-image: url(../image/parts/sprite.svg#external-white)
}
.btn3:after {
	background: url(../image/parts/sprite.svg#circle-arrow-next-white) no-repeat 50%/contain;
}
.btn3[target=_blank]:after {
	background-image: url(../image/parts/sprite.svg#external-white)
}
.unit-file p a[href*=".pdf"]:before {
	background: url(../image/parts/sprite.svg#pdf)
}
.unit-file p a[href*=".doc"]:before {
	background: url(../image/parts/sprite.svg#doc)
}
.unit-file p a[href*=".xls"]:before {
	background: url(../image/parts/sprite.svg#xls)
}
.anchor-nav a:before {
	background: url(../image/parts/sprite.svg#arrow-next-primary) no-repeat 50%/contain;
}
.faq-list dt:before {
	background: url(../image/parts/icon_q.svg) no-repeat 50%/contain
}
.faq-list dd:before {
	background: url(../image/parts/icon_a.svg) no-repeat 50%/contain
}
.photoswipe:before {

	background: #fff url(../image/parts/sprite.svg#plus) no-repeat 50%/contain;
}
.news-list > li:has(a):after {
	background: url(../image/parts/sprite.svg#circle-arrow-next) no-repeat 50%/contain;
}
.gnav-sub a:before {
	background: #fff url(../image/parts/sprite.svg#arrow-next-primary) no-repeat 50%/10px;
}
.megamenu-list a:before {

	background: #d2f2f6 url(../image/parts/sprite.svg#arrow-next-primary) no-repeat 50%/12px;

}
.megamenu-list > li:hover a:before {
	background-image: url(../image/parts/sprite.svg#arrow-next-white);

}
.gnav-sub a:before {
	background: #d2f2f6 url(../image/parts/sprite.svg#arrow-next-primary) no-repeat 50%/10px;
}
.news-list > li:has(a):hover:after {
	background-image: url(../image/parts/sprite.svg#circle-arrow-next-primary)
}
/* ---- 置き換え ---- */

/* ---- テキスト ----*/
.fc a[data-navlink].fc-daygrid-day-number {
	cursor: default;
}
.fc a[data-navlink].fc-daygrid-day-number:hover {
	text-decoration: inherit;
}

/* ---- イベント ---- */
.fc-event {
	transition: .14s;
}
.fc-event.hide {
	opacity: 0;
	pointer-events: none;
} 
.fc-h-event {
	background: transparent;
	border: none;
}

/* イベント背景・ドット */
.event01 .fc-daygrid-event-dot,
.fc-v-event.event01,
.fc .event01 .fc-list-event-dot {
	background-color: var(--event01-color);
	border-color: var(--event01-color);
}
.event02 .fc-daygrid-event-dot,
.fc-v-event.event02,
.fc .event02 .fc-list-event-dot {
	background-color: var(--event02-color);
	border-color: var(--event02-color);
}
.event03 .fc-daygrid-event-dot,
.fc .event03 .fc-list-event-dot {
	/*background-color: var(--event03-color);
	border-color: var(--event03-color);
	*/
	display: none;
}
.fc-v-event.event03 {
	background-color: #888;
	border-color: #888;
}
.event04 .fc-daygrid-event-dot,
.fc-v-event.event04,
.fc .event04 .fc-list-event-dot {
	/*background-color: var(--event04-color);
	border-color: var(--event04-color);*/
	display: none;
}
/* ---- イベント ---- */

/* ---- 休館日 ---- */
.fc-daygrid-day:has(.event04),
.fc .fc-timegrid-col.event04-cell:not(:has(.fc-day-today)),
.fc-daygrid-day.event04-cell,
.fc-daygrid-day.event04-cell:where(.fc-day-sat, .fc-day-sun, .fc-day-today),
.newyear_holiday {
	background: #eef0f1;
}
.fc-list-event.event04  {
	background: #f9f9fa;
}
.fc .fc-timegrid-col.event04-cell.fc-day-today {
	background: #fffadf;
}
.fc .fc-h-event.event04 {
	border: none;
	background: transparent !important;
	pointer-events: none;
}
.fc .fc-h-event.event04 .fc-event-main,
.event04-cell .fc-event.holiday .fc-event-main {
	color: #686f78;
}
.fc .fc-h-event.event04 .fc-event-title,
.event04-cell :where(.fc-event-title, .fc-event-main) {
	font-weight: 500;
}
.fc .fc-list-event.fc-event-forced-url.event04,
.event04-cell .fc-list-event.fc-event-forced-url {
	pointer-events: none;
}

.event04-cell:not(:has(.fc-daygrid-event-harness)) .fc-daygrid-day-events:before,
.event04-cell .fc-daygrid-event-harness:has(.holiday):before {
	content: "休館日";
	display: inline-block;
	font-size: 1.2rem;
	color: #686f78;
	font-weight: 500;
	margin: -1px 3px 2px;
}
.event04-cell .fc-daygrid-event-harness:has(.holiday,.event04):before {
	content: none;
}

/* ---- 休館日 ---- */

/* ---- 祝日 ----*/
.fc-event.holiday {
	display: none;
}
.fc-event.holiday .fc-event-main {
	color: #e86362;
}
/* ---- 祝日 ----*/


/* ---- 週表示 ---- */
.fc-h-event .fc-event-main {
	color:var(--color-text);
}

/* ---- リスト ---- */

tr.fc-list-day:has(+.holiday + .fc-list-day),
tr.fc-list-day:has(+tr.holiday:last-of-type){
	display: none;
	pointer-events: none;
}

.fc-direction-ltr .fc-list-table .fc-list-event-graphic {
	vertical-align: middle;
}
tr.fc-list-day th, tr.fc-list-day td {
	border-top: none;
}

tr.fc-list-row {
	display: table-row;
}

tr.fc-list-none {
	display: none;
}

/* ---- リスト ---- */

/* ---- filter  ---- */
#filter_block .checkboxs {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: center;
	gap: 16px 16px;
	margin: 24px auto;
}
#filter_block .checkboxs span:not(:has(button)) {
	max-width: calc(100% / 5);
	min-width: 140px;
	padding: 5px 10px;
	display: inline-block;
}
#filter_block button {
	background-color: #00b7cc;
	border: 1px solid #00b7cc;
	color: #fff;
	font-size: 1.125em;
	font-weight: 500;
	padding: 10px 24px 12px;
	border-radius: 9999px;
	cursor: pointer;
	transition: .3s;
}
#filter_block button:hover {
	opacity: .7;
}
#filter_block .checkboxs span input[type="checkbox"] {
	appearance: none;
}
#filter_block .checkboxs label {
	display: inline-flex;
	align-items: center;
	gap: 0 5px;
	line-height: 0;
	cursor: pointer;
	color: #4d4d4d;
	transition: .1s;
}
#filter_block .checkboxs label::before {
	content: "";
	width: 1.25em;
	height: 1.25em;
	aspect-ratio: 1 / 1;
	background: #ccc;
	border-radius: 9999px;
	display: inline-block;
	position: relative;
	transition: .1s;
}
#filter_block .checkboxs input[id^="eventAll"] + label::before {
	background-color: #ccc;
}
#filter_block .checkboxs input[id^="event01"] + label::before {
	background-color: var(--event01-color);
}
#filter_block .checkboxs input[id^="event02"] + label::before {
	background-color: var(--event02-color);
}
#filter_block .checkboxs input[id^="event03"] + label::before {
	background-color: var(--event03-color);
}
#filter_block .checkboxs input[id^="event04"] + label::before {
	background-color: var(--event04-color);
}
#filter_block .checkboxs input[id^="event"]:checked + label {
	color: #999;
}
#filter_block .checkboxs input[id^="event"]:checked + label::before {
	background: #ccc;
}
#filter_block .checkboxs input#facClese,
#filter_block .checkboxs input#facClese + label {
	pointer-events: none;
	display: none;
}
@media (max-width: 768px) {
	#filter_block .checkboxs {
		gap: 24px 16px;
	}
	#filter_block .checkboxs span:has(#eventAll-view) {
		display: block;
		text-align :center;
		width: 100%;
	}
	#filter_block .checkboxs span:not(:has(button)) {
		padding: 0;
		max-width: inherit;
		min-width: inherit;
	}
	
}
/* ---- filter  ---- */

/* モーダルの背景 */
#event-modal {
  display: none;           /* 非表示がデフォルト */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 199;
  overflow-y: auto;
  transition: opacity 0.3s ease;
  opacity: 0;
}

/* モーダルを表示 */
#event-modal.show {
  display: block;
  opacity: 1;
}

/* モーダルコンテンツ */
.event-modal-content {
  background-color: #fff;
  max-width: 700px;
	max-height: 600px;
	width: 85%;
  margin: 0 auto;
	position: fixed;
	top: 50%;
	left: 50%;
	translate: -50% -50%;
  padding: 24px 64px 24px 24px;
  border-radius: 3px;
  transition: transform 0.3s ease, opacity 0.3s ease;
  opacity: 0;
}

/* フェードイン */
.event-modal-content.show {
  opacity: 1;
}

/* モーダルヘッダーやテキスト */
.event-content h3 {
  margin-top: 0;
	margin-bottom: 16px;
  font-size: 2.0rem;
}

.event-content p {
  margin: 10px 0;
  line-height: 1.4;
  word-break: break-word; /* 長いURLや文字列も折り返す */
	font-size: 1.4rem;
	font-weight: 500;
}
.event-content p + p {
	margin-top: 16px;
}
.event-content p:has(.map) {
	margin-top: 10px;
}
.event-content p span {
	color: #888;
	margin-right: 1em;
}

/* リンクスタイル */
.event-content a {
  color: #007bff;
  text-decoration: none;
}

.event-content a:hover {
  text-decoration: underline;
}

/* 閉じるボタン */
#close-modal {
  position: fixed;
  top: 16px;
  right: 12px;
  cursor: pointer;
  color: #333;
	background: #fff;
	aspect-ratio: 1 / 1;
	padding: 8px 7px 6px 8px;
	font-size: 2.4em;
	line-height: 0;
	border-radius: 9999px;
	border: 2px solid #333;
	transition: .3s;
	z-index: 200;
}
@media (hover:hover) {
	#close-modal:hover {
		background: #333;
		color: #fff;
	}
}
	#close-modal:active {
		background: #333;
		color: #fff;
	}

/* レスポンシブ対応 */
@media (max-width: 768px) {
	#event-modal {
		align-items: center;
		justify-content: center;
	}
	#event-modal.show {
		display: flex;
	}
  .event-modal-content {
    width: 90%;
    padding: 16px;
	  translate: none;
	  top: auto;
	  left: auto;
	  
  }

  .event-content h3 {
    font-size: 1.6em;
  }
}