@charset "UTF-8";
/*施設紹介ヘッダ----------------------------------------------*/
.institution-header{
	position: relative;
	margin: 0;
	padding: 0;
	width: 100%;
	height: calc(((100vw - var(--contents-width)) / 2 + 597px) * 0.767 - 60px);
}
.institution-header .image{
	position: absolute;
	top: -180px;
	right: 0;
	margin: 0;
	padding: 0;
}
.institution-header .image img{
	min-width: 597px;
	width: calc((100vw - var(--contents-width)) / 2 + 597px);
}
.institution-header h3{
	position: relative;
	width: 503px;
	margin: 0;
	margin-left: calc((100vw - var(--contents-width)) / 2);
	margin-bottom: 40px;
	padding: 0;
	font-family: var(--min-font);
	font-size: 32px;
	line-height: 52px;
	font-weight: var(--font-weight-bold);
}
.institution-header .description{
	position: relative;
	width: 443px;
	margin: 0;
	margin-left: calc((100vw - var(--contents-width)) / 2);
	margin-bottom: 40px;
	padding: 0;
	font-size: 16px;
	line-height: 32px;
	font-weight: var(--font-weight-medium);
}
.institution-header dl.data{
	position: relative;
	width: 443px;
	margin: 0;
	margin-left: calc((100vw - var(--contents-width)) / 2);
	margin-bottom: 18px;
	padding: 0;
	border-bottom: 1px solid var(--font-color-normal);
}
.institution-header dl.data dt{
	clear: both;
	float: left;
	width: 140px;
	margin: 0;
	padding: 12px 0;
	border-top: 1px solid var(--font-color-normal);
	font-size: 16px;
	line-height: 32px;
	font-weight: var(--font-weight-bold);
}
.institution-header dl.data dd{
	clear: none;
	float: right;
	width: 303px;
	margin: 0;
	padding: 12px 0;
	border-top: 1px solid var(--font-color-normal);
	font-size: 16px;
	line-height: 32px;
	font-weight: var(--font-weight-medium);
}
.institution-header .note{
	position: relative;
	width: 443px;
	margin: 0;
	margin-left: calc((100vw - var(--contents-width)) / 2);
	margin-bottom: 76px;
	padding-left: 1rem;
	font-size: 14px;
	line-height: 24px;
	font-weight: var(--font-weight-medium);
}
.institution-header .note:before{
	content: "※";
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 14px;
	height: 24px;
}

@media screen and (max-width: 1259px) {
	.institution-header{
		margin-top: -28px;
		height: auto;
		display: grid;
		grid-template-rows: auto auto auto;
	}
	.institution-header .image{
		position: relative;
		top: 0;
		width: 100%;
		margin-bottom: 40px;
	}
	.institution-header .image img{
		min-width: 200px;
		width: 100%;
	}
	.institution-header h3{
		width: calc(100vw - 40px);
		margin: 0 auto 43px;
		font-size: 24px;
		line-height: 38px;
	}
	.institution-header .description{
		width: calc(100vw - 40px);
		margin: 0 auto 61px;
		line-height: 28px;
	}
	.institution-header .description2{
		width: calc(100vw - 40px);
		margin: 0 auto 61px;
	}
	.institution-header dl.data{
		width: calc(100vw - 40px);
		margin: 0 auto 18px;
		border-bottom: 1px solid var(--font-color-normal);
	}
	.institution-header dl.data dt{
		width: 124px;
	}
	.institution-header dl.data dd{
		width: calc(100vw - 164px);
	}
	.institution-header .note{
		width: calc(100vw - 40px);
		margin: 0 auto 80px;
	}
}

/*施設紹介----------------------------------------------*/
.institution{
	position: relative;
	margin: 0 auto 120px;
	padding: 0;
	width: var(--contents-width);
}
.institution ul.list{
	display: flex;
	list-style: none;
	width: var(--contents-width);
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 0;
	padding: 0;
}
.institution ul.list > li{
	position: relative;
	display: grid;
	width: 500px;
	margin: 0 0 109px;
	padding: 0;
	grid-template-rows: auto auto 60px;
	grid-template-columns: 80px 420px;
}
.institution ul.list li h4{
	width: 420px;
	margin: 0 0 40px;
	padding: 0;
	font-family: var(--min-font);
	font-size: 32px;
	line-height: 50px;
	font-weight: var(--font-weight-semibold);
	grid-row: 1;
	grid-column: 2;
}
.institution ul.list li h4:before{
	content: "";
	position: absolute;
	display: block;
	top: 25px;
	left: 0px;
	width: 64px;
	height: 1px;
	background: var(--font-color-normal);
}
.institution ul.list li .thumb{
	margin-bottom: 32px;
	width: 500px;
	grid-row: 2;
	grid-column: 1;
}
.institution ul.list li .thumb img{
	width: 500px;
}
.institution ul.list li a.link{
	display: block;
	margin: 0;
	width: 500px;
	height: 60px;
	grid-row: 3;
	grid-column: 1;
	font-family: var(--min-font);
	text-indent: 30px;
	text-align: left;
	font-size: 16px;
	line-height: 60px;
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	background: 90% center no-repeat url("../img/common/button-arrow.png");
	color: var(--font-color-normal);
	border: 1px solid var(--font-color-normal);
	border-radius: 4px;
	animation-name: offArrow;
	animation-duration: .2s;
	animation-fill-mode: forwards;
}
.institution ul.list li a.link:hover{
	animation-name: onArrow;
	animation-duration: .2s;
	animation-fill-mode: forwards;
}

@media screen and (max-width: 1259px) {
	.institution,
	.institution ul.list{
		width: calc(100vw - 40px);
	}
	.institution ul.list > li{
		width: calc(100vw - 40px);
		margin: 0 0 60px;
		padding: 0;
		grid-template-columns: 48px auto auto;
	}
	.institution ul.list li h4{
		width: calc(100vw - 88px);
		margin: 0 0 32px;
		font-size: 24px;
		line-height: 32px;
		grid-row: 1;
	}
	.institution ul.list li h4:before{
		top: 16px;
		width: 32px;
	}
	.institution ul.list li .thumb{
		margin: 0 0 32px;
		width: calc(100vw - 40px);
		height: auto;
		grid-row: 2;
		grid-column: 1;
	}
	.institution ul.list li .thumb img{
		width: calc(100vw - 40px);
	}
	.institution ul.list li a.link{
		width: calc(100vw - 40px);
		grid-row: 3;
		grid-column: 1;
	}
}

/*施設紹介2----------------------------------------------*/
.institution ul.list2{
	display: flex;
	list-style: none;
	width: var(--contents-width);
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 0;
	padding: 0;
}
.institution ul.list2 > li{
	position: relative;
	display: grid;
	width: var(--contents-width);
	min-height: 375px;
	margin: 0 0 80px;
	padding: 0;
	grid-template-rows: 67px auto auto;
	grid-template-columns: 80px 520px 500px;
}
.institution ul.list2 li h4{
	width: 520px;
	margin: 0;
	padding: 0;
	font-family: var(--min-font);
	font-size: 24px;
	line-height: 24px;
	font-weight: var(--font-weight-bold);
	grid-row: 1;
	grid-column: 2;
}
.institution ul.list2 li h4:before{
	content: "";
	position: absolute;
	display: block;
	top: 12px;
	left: 0px;
	width: 64px;
	height: 1px;
	background: var(--font-color-normal);
}
.institution ul.list2 li .body{
	margin-bottom: 32px;
	width: 500px;
	grid-row: 2;
	grid-column: 1;
	text-align: justify;
	font-size: 16px;
	line-height: 32px;
}
.institution ul.list2 dl.data{
	position: relative;
	width: 500px;
	height: 120px;
	grid-row: 3;
	grid-column: 1;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid var(--font-color-normal);
}
.institution ul.list2 dl.data dt{
	clear: both;
	float: left;
	width: 140px;
	margin: 0;
	padding: 12px 0;
	border-top: 1px solid var(--font-color-normal);
	font-size: 16px;
	line-height: 32px;
	font-weight: var(--font-weight-bold);
}
.institution ul.list2 dl.data dd{
	clear: none;
	float: right;
	width: 360px;
	margin: 0;
	padding: 12px 0;
	border-top: 1px solid var(--font-color-normal);
	font-size: 16px;
	line-height: 32px;
	font-weight: var(--font-weight-medium);
}
.institution ul.list2 li .thumb{
	width: 500px;
	grid-row: 1;
	grid-column: 3;
}
.institution ul.list2 li .thumb img{
	width: 500px;
}
.institution ul.list2 li a.link{
	display: block;
	margin: 0;
	padding: 0;
	width: 500px;
	height: 60px;
	grid-row: 3;
	grid-column: 1;
	font-family: var(--min-font);
	text-indent: 30px;
	text-align: left;
	font-size: 16px;
	line-height: 60px;
	font-weight: var(--font-weight-bold);
	text-decoration: none;
	background: 90% center no-repeat url("../img/common/button-arrow.png");
	color: var(--font-color-normal);
	border: 1px solid var(--font-color-normal);
	border-radius: 4px;
	animation-name: offArrow;
	animation-duration: .2s;
	animation-fill-mode: forwards;
}
.institution ul.list2 li a.link:hover{
	animation-name: onArrow;
	animation-duration: .2s;
	animation-fill-mode: forwards;
}

@media screen and (max-width: 1259px) {
	.institution ul.list2{
		width: calc(100vw - 40px);
	}
	.institution ul.list2 > li{
		width: calc(100vw - 40px);
		margin: 0 0 60px;
		padding: 0;
		grid-template-rows: 67px auto auto auto;
		grid-template-columns: 48px auto;
	}
	.institution ul.list2 li h4{
		width: calc(100vw - 88px);
		margin: 0 0 32px;
		line-height: 32px;
		grid-row: 1;
	}
	.institution ul.list2 li h4:before{
		top: 16px;
		width: 32px;
	}
	.institution ul.list2 li .body{
		width: calc(100vw - 40px);
		font-size: 14px;
		line-height: 28px;
	}
	.institution ul.list2 dl.data{
		margin: 0 0 32px;
		width: calc(100vw - 40px);
		height: auto;
	}
	.institution ul.list2 dl.data dt{
		width: 104px;
	}
	.institution ul.list2 dl.data dd{
		width: calc(100vw - 144px);
	}
	.institution ul.list2 li .thumb{
		margin: 0 0 32px;
		width: calc(100vw - 40px);
		height: auto;
		grid-row: 4;
		grid-column: 1;
	}
	.institution ul.list2 li .thumb img{
		width: calc(100vw - 40px);
	}
	.institution ul.list2 li a.link{
		width: calc(100vw - 40px);
		grid-row: 5;
	}
}

/*レストランのご案内----------------------------------------------*/
.restaurant{
	position: relative;
	display: grid;
	margin: 0 auto 120px;
	padding: 0;
	width: var(--contents-width);
	grid-template-rows: 67px auto;
	grid-template-columns: 80px 1020px;
}
.restaurant h4{
	width: 1020px;
	margin: 0;
	padding: 0;
	font-family: var(--min-font);
	font-size: 24px;
	line-height: 24px;
	font-weight: var(--font-weight-bold);
	grid-row: 1;
	grid-column: 2;
}
.restaurant h4:before{
	content: "";
	position: absolute;
	display: block;
	top: 12px;
	left: 0px;
	width: 64px;
	height: 1px;
	background: var(--font-color-normal);
}
.restaurant .photo{
	position: relative;
	display: flex;
	list-style: none;
	margin: 0 auto 120px;
	padding: 0;
	width: var(--contents-width);
	justify-content: space-between;
	flex-wrap: wrap;
	grid-row: 2;
	grid-column: 1;
}
.restaurant .photo li{
	width: 340px;
	margin: 0;
	padding: 0;
	text-align: center;
	font-size: 16px;
	line-height: 24px;
	font-weight: var(--font-weight-medium);
}
.restaurant .photo li img{
	width: 340px;
}

@media screen and (max-width: 1259px) {
	.restaurant{
		margin: 0 auto 100px;
		width: calc(100vw - 40px);
		grid-template-rows: auto auto;
		grid-template-columns: 48px auto;
	}
	.restaurant h4{
		width: calc(100vw - 88px);
		margin: 0 0 32px;
		line-height: 32px;
		grid-row: 1;
	}
	.restaurant h4:before{
		top: 16px;
		width: 32px;
	}
	.restaurant .photo{
		width: calc(100vw - 40px);
	}
	.restaurant .photo li{
		width: calc(100vw - 40px);
		margin: 0 0 32px;
	}
	.restaurant .photo li img{
		width: calc(100vw - 40px);
	}
}

/*館内施設のご案内----------------------------------------------*/
.bathhouse{
	position: relative;
	display: grid;
	margin: 0 auto 120px;
	padding: 0;
	width: var(--contents-width);
	min-height: calc(((100vw - var(--contents-width)) / 2 + 597px) * 0.753 + 35px);
	grid-template-rows: 67px auto auto;
	grid-template-columns: 653px 80px 367px;
}
.bathhouse h4{
	position: relative;
	width: 367px;
	margin: 0;
	padding: 0;
	font-family: var(--min-font);
	font-size: 24px;
	line-height: 24px;
	font-weight: var(--font-weight-bold);
	grid-row: 1;
	grid-column: 3;
}
.bathhouse h4:before{
	content: "";
	position: absolute;
	display: block;
	top: 12px;
	left: -80px;
	width: 64px;
	height: 1px;
	background: var(--font-color-normal);
}
.bathhouse .body{
	margin-bottom: 32px;
	width: 447px;
	grid-row: 2;
	grid-column: 2;
	text-align: justify;
	font-size: 16px;
	line-height: 32px;
}
.bathhouse dl.data{
	position: relative;
	width: 447px;
	grid-row: 3;
	grid-column: 2;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid var(--font-color-normal);
}
.bathhouse dl.data dt{
	clear: both;
	float: left;
	width: 147px;
	margin: 0;
	padding: 12px 0;
	border-top: 1px solid var(--font-color-normal);
	font-size: 16px;
	line-height: 32px;
	font-weight: var(--font-weight-bold);
}
.bathhouse dl.data dd{
	clear: none;
	float: right;
	width: 300px;
	margin: 0;
	padding: 12px 0;
	border-top: 1px solid var(--font-color-normal);
	font-size: 16px;
	line-height: 32px;
	font-weight: var(--font-weight-medium);
}
.bathhouse .thumb{
	position: relative;
	width: 653px;
	grid-row: 1;
	grid-column: 1;
}

@media screen and (max-width: 1259px) {
	.bathhouse{
		margin: 0 auto 80px;
		width: calc(100vw - 40px);
		min-height: 200px;
		grid-template-rows: calc((100vw - 40px) * 0.753 + 68px) auto auto auto;
		grid-template-columns: 48px auto;
	}
	.bathhouse h4{
		width: calc(100vw - 88px);
		margin: 0 0 32px;
		font-size: 24px;
		line-height: 32px;
		grid-row: 2;
		grid-column: 2;
	}
	.bathhouse h4:before{
		top: 16px;
		left: -48px;
		width: 32px;
	}
	.bathhouse .body{
		width: calc(100vw - 40px);
		grid-row: 3;
		grid-column: 1;
	}
	.bathhouse dl.data{
		width: calc(100vw - 40px);
		grid-row: 4;
		grid-column: 1;
	}
	.bathhouse dl.data dt{
		width: 104px;
	}
	.bathhouse dl.data dd{
		width: calc(100vw - 144px);
	}
	.bathhouse .thumb{
		width: calc(100vw - 40px);
	}
}

/*スライダー----------------------------------------------*/
.bathhouse .bathSlider{
	position: absolute;
	left: calc((100vw - var(--contents-width)) / -2);
	top: 0;
	margin: 0 auto 120px;
	padding: 0;
	width: calc((100vw - var(--contents-width)) / 2 + 597px);
	height: calc(((100vw - var(--contents-width)) / 2 + 597px) * 0.753 + 35px);
}
.bathhouse .bathSlider ul.slider{
	position: relative;
	display: flex;
	list-style: none;
	height: calc(((100vw - var(--contents-width)) / 2 + 597px) * 0.753);
	margin: 0;
	padding: 0;
	justify-content: start;
	flex-wrap: nowrap;
}
.bathhouse .bathSlider ul.slider li{
	width: calc((100vw - var(--contents-width)) / 2 + 597px);
	height: calc(((100vw - var(--contents-width)) / 2 + 597px) * 0.753);
	margin: 0 24px 0 0;
	padding: 0;
}
.bathhouse .bathSlider ul.slider li img{
	width: calc((100vw - var(--contents-width)) / 2 + 597px);
	height: calc(((100vw - var(--contents-width)) / 2 + 597px) * 0.753);
}
.bathhouse .bathSlider .selector ul{
	position: relative;
	display: flex;
	list-style: none;
	margin: 14px auto;
	padding: 0;
	justify-content: center;
	flex-wrap: wrap;
}
.bathhouse .bathSlider .selector ul li{
	width: 8px;
	height: 8px;
	margin: 0 4px;
	padding: 0;
	border: 1px solid var(--font-color-normal);
	border-radius: 4px;
	cursor: pointer;
}
.bathhouse .bathSlider .selector ul li.slick-active{
	background: var(--font-color-normal);
}
.bathhouse .bathSlider ul.selector li:hover{
	opacity: .75;
}
.slick-prev{
	left: 43px !important;
}
.slick-next{
	right: 43px !important;
}

@media screen and (max-width: 1259px) {
	.bathhouse .bathSlider{
		left: 0;
		top: 0;
		margin: 0 10px 120px;
		padding: 0;
		width: calc(100vw - 60px);
		height: calc((100vw - 60px) * 0.753);
	}
	.bathhouse .bathSlider ul.slider{
		width: calc(100vw - 60px);
		height: calc((100vw - 60px) * 0.753);
	}
	.bathhouse .bathSlider ul.slider li{
		width: calc(100vw - 60px);
		height: calc((100vw - 60px) * 0.753);
		margin: 0 24px 0 0;
	}
	.bathhouse .bathSlider ul.slider li img{
		width: calc(100vw - 60px);
		height: calc((100vw - 60px) * 0.753);
	}
	.bathhouse .bathSlider ul.selector{
		margin: 14px auto;
	}
	.slick-prev{
		left: 0 !important;
	}
	.slick-next{
		right: 0 !important;
	}
}
