@charset "UTF-8";

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

	- attention
	- emergency
	- kv
	+ grid-container
		+ card
		+ excard
			- decoration
			- quicklinks
			- about
			+ first
				- roundarrow01
			- ritual
			- visit
			+ amulet
				- roundarrow01
	- hours
	- bnr_movie
	+ topics
		- middlesize
		- smallsize
	- nature
	+ feel
		- roundarrow01
	+ split
		- sengu
		- access
	- relatedpage
	- aside

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

/* アニメーションのはみ出し抑制 */
#content {
	overflow: hidden;
}

/*----------------------------------------
	attention
-----------------------------------------*/
#attention {
	display: none;
}

.isOthers #attention {
	display: block;
	width: 100%;
	padding: 50px 0;
	background-color: #e1ebff;
}

.isOthers #attention p {
	text-align: center;
}

/*----------------------------------------
	emergency
-----------------------------------------*/
#emergency {
	width: 100%;
	background-color: #f6f4f1;
}

#emergency div {
	padding: 64px 0 56px;
}

#emergency #e_tit {
	letter-spacing: 0.085em;
}

#emergency #e_date {
	margin-top: 11px;
}

#emergency #e_txt {
	margin-top: 48px;
}

#emergency .e_link {
	margin-top: 26px;
}

#emergency .e_link+.e_link {
	margin-top: 12px;
}

#emergency .blank {
	display: inline;
}

#emergency .blank::before {
	background-color: #f6f4f1;
}

#emergency .blank::after {
	background-color: #f6f4f1;
	box-shadow: 0px 0px 0px 1px #f6f4f1;
}

@media screen and (max-width: 1023px) {
	#emergency div {
		padding: 46px 0 36px;
	}

	#emergency #e_date {
		margin-top: 3px;
	}

	#emergency #e_txt {
		margin-top: 28px;
	}

	#emergency .e_link {
		margin-top: 18px;
	}

	#emergency .e_link+.e_link {
		margin-top: 22px;
	}
}

/*----------------------------------------
	kv
-----------------------------------------*/
#kv {
	position: relative;
	width: 100%;
	margin: auto;
}

#kv>p {
	z-index: 20;
	position: absolute;
	bottom: 30%;
	left: 8%;
	margin: auto;
	letter-spacing: 0.11em;
	opacity: 0;
	-webkit-animation: txtFadeIn 2s ease-out 4s;
	animation: txtFadeIn 2s ease-out 4s;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
}

#kv .swiper-container {
	z-index: 10;
	background: transparent url(../img/i_kv_loading.png) no-repeat center center;
	background-size: 120px;
}

#kv .swiper-slide-active img,
#kv .swiper-slide-duplicate-active img,
#kv .swiper-slide-prev img {
	-webkit-animation: zoomUp 12s linear 0s;
	animation: zoomUp 12s linear 0s;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
}

#kv .swiper-slide {
	overflow: hidden;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

#kv .swiper-slide img {
	background-size: contain;
	background-position: center center;
}

@keyframes txtFadeIn {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

@keyframes zoomUp {
	0% {
		-webkit-transform: scale(1);
		transform: scale(1);
	}

	100% {
		-webkit-transform: scale(1.15) rotate(0.1deg);
		transform: scale(1.15) rotate(0.1deg);
	}
}

@media screen and (max-width: 1023px) {
	#kv .swiper-container {
		background-size: 20%;
	}
}


#kv .pc {
	display: block;
}

#kv .sp {
	display: none;
}

@media screen and (max-width: 1023px) {
	#kv>p {
		bottom: 23.4%;
		left: 4.6%;
	}

	#kv .pc {
		display: none;
	}

	#kv .sp {
		display: block;
	}
}

/*----------------------------------------
	grid-container
-----------------------------------------*/
.grid-container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 320px 1fr;
	gap: 0 40px;
	grid-template-areas:
		"g0 g1"
		"g2 g1"
		"g2 g4"
		"g3 g4"
		"g5 g6"
		"g5 g6";
}

.g0 {
	grid-area: g0;
}

.g1 {
	grid-area: g1;
}

.g2 {
	grid-area: g2;
}

.g3 {
	grid-area: g3;
}

.g4 {
	grid-area: g4;
}

.g5 {
	grid-area: g5;
}

.g6 {
	grid-area: g6;
}

@media screen and (max-width: 1023px) {
	.grid-container {
		display: block;
	}
}

@media all and (-ms-high-contrast:none) {
	.grid-container {
		display: -ms-grid;
		-ms-grid-columns: 50% 50%;
		-ms-grid-rows: 320px 1fr;
	}

	.g0 {
		-ms-grid-row: 1;
		-ms-grid-row-span: 1;
		-ms-grid-column: 1;
		-ms-grid-column-span: 1;
	}

	.g1 {
		-ms-grid-row: 1;
		-ms-grid-row-span: 2;
		-ms-grid-column: 2;
		-ms-grid-column-span: 1;
		/*margin-left: 40px;*/
		margin-left: 20px;
	}

	.g2 {
		-ms-grid-row: 2;
		-ms-grid-row-span: 2;
		-ms-grid-column: 1;
		-ms-grid-column-span: 1;
	}

	.g3 {
		-ms-grid-row: 4;
		-ms-grid-row-span: 1;
		-ms-grid-column: 1;
		-ms-grid-column-span: 1;
	}

	.g4 {
		-ms-grid-row: 3;
		-ms-grid-row-span: 2;
		-ms-grid-column: 2;
		-ms-grid-column-span: 1;
		/*margin-left: 40px;*/
		margin-left: 20px;
	}

	.g5 {
		-ms-grid-row: 5;
		-ms-grid-row-span: 2;
		-ms-grid-column: 1;
		-ms-grid-column-span: 1;
	}

	.g6 {
		-ms-grid-row: 5;
		-ms-grid-row-span: 2;
		-ms-grid-column: 2;
		-ms-grid-column-span: 1;
		/*margin-left: 40px;*/
		margin-left: 20px;
	}
}

@media all and (-ms-high-contrast:none) and (max-width: 1525px) {
	.g1 {
		margin-left: 40px;
	}

	.g4 {
		margin-left: 40px;
	}

	.g6 {
		margin-left: 40px;
	}
}

@media all and (-ms-high-contrast:none) and (max-width: 1023px) {
	.grid-container {
		display: block;
	}
}


/*----------------------------------------
	card
-----------------------------------------*/
.card {
	position: relative;
	z-index: 100;
	max-width: 600px;
}

.card a {
	display: block;
	transition: color .1s ease-in-out .0s;
}

.pc .card:hover a {
	color: #fff !important;
}

.card p.font20_14 a {
	transition: opacity .1s ease-in-out .0s;
}

.pc .card p.font20_14 a:hover {
	opacity: .5 !important;
}

.card figure {
	transition: all .1s ease-in-out .0s;
}

.pc .card:hover figure {
	background-color: #fff;
	opacity: .5;
}

.card>div {
	background-color: #fff;
	box-shadow: 0 30px 27px 3px rgba(0, 0, 0, 0.08);
	transition: all .1s ease-in-out .0s;
}

.pc .card:hover div {
	background-color: #696b76;
}

.card>div {
	position: relative;
	min-height: 500px;
	padding: 43px 35px 35px 35px;
	box-sizing: border-box;
}

.card>div p.decoration {
	top: 72px;
	right: 31px;
}

.card>div h1 {
	width: calc(100% - 40px);
}

.card>div h1+p {
	/*display: flex;
	align-items: flex-end;*/
	width: 300px;
	margin-top: 138px;
	padding-left: 3px;
}

.card>div p.font20_14,
.card>div ul,
.card>div ul li:nth-of-type(1) {
	margin-top: 30px;
}

.card>div p.font20_14:nth-of-type(1)::before,
.card>div ul::before {
	content: '';
	display: block;
	height: 1px;
	max-width: 440px;
	width: 100%;
	margin-bottom: 32px;
	background-color: #373d44;
}

.card>div p.font20_14+p.font20_14,
.card>div ul li+li {
	margin-top: 18px;
}

.card>div p.font20_14 a {
	display: inline-block;
	letter-spacing: 0.13em;
}

.card>div p.font20_14 span.simplearrow.large,
.card>div ul li span.simplearrow.large {
	width: 26px;
	height: 26px;
	margin-left: 14px;
}

.card>div p.font20_14 span.simplearrow.large::before,
.card>div ul li span.simplearrow.large::before {
	top: 12px;
	width: 26px;
	height: 2px;
}

.card>div p.font20_14 span.simplearrow.large::after,
.card>div ul li span.simplearrow.large::after {
	top: 12px;
	left: calc(50% - 2px);
	width: 12px;
	height: 12px;
	border-top-width: 2px;
    border-right-width: 2px;
}

.card>div ul li a,
#nature div p a {
	display: inline-block;
}

@media screen and (min-width: 1024px) and (max-width: 1400px) {
	.card>div h1 {
		font-size: 3.8rem;
	}

}

@media screen and (max-width: 1400px) {
	.card>div {
		min-height: 350px;
	}

	.card>div h1+p {
		margin-top: 70px;
	}

}

@media screen and (max-width: 1200px) {
	.card>div {
		padding: 25px 35px 35px 35px;
	}

	.card>div h1+p {
		width: 70%;
	}
}

@media screen and (max-width: 1023px) {
	.card {
		max-width: 100%;
	}

	.card>div {
		min-height: 100%;
		padding: 25px 19px 28px 19px;
		box-shadow: 0 15px 20px 3px rgba(0, 0, 0, 0.08);
	}

	.card>div p.decoration {
		top: 41px;
		right: 12px;
	}

	.card>div h1 {
		width: calc(100% - 20px);
	}

	.card>div h1+p {
		width: 78%;
		margin-top: 63px;
		padding-left: 1px;
		line-height: 1.8;
	}

	.card>div p.font20_14,
	.card>div ul,
	.card>div ul li:nth-of-type(1) {
		margin-top: 26px;
	}

	.card>div p.font20_14:nth-of-type(1)::before,
	.card>div ul::before {
		width: 74%;
		margin-bottom: 28px;
	}

	.card>div p.font20_14+p.font20_14,
	.card>div ul li+li {
		margin-top: 21px;
	}

	.card>div p.font20_14 span.simplearrow.large,
	.card>div ul li span.simplearrow.large {
		width: 15px;
		height: 15px;
		margin-left: 7px;
	}

	.card>div p.font20_14 span.simplearrow.large::before,
	.card>div ul li span.simplearrow.large::before {
		top: 5px;
		width: 15px;
		height: 1px;
	}

	.card>div p.font20_14 span.simplearrow.large::after,
	.card>div ul li span.simplearrow.large::after {
		top: 5px;
		left: 50%;
		width: 6px;
		height: 6px;
		border-width: 1px;
	}
}

/*----------------------------------------
	excard
-----------------------------------------*/
.excard {
	max-width: 600px;
}

@media screen and (max-width: 1023px) {
	.excard {
		max-width: 100%;
	}

	.excard {
		width: 100%;
	}
}

/*----------------------------------------
	decoration　右肩　花菱
-----------------------------------------*/
#about p.decoration::before {
	background: url(/img/c_icon_hanabishi01.png) no-repeat right top;
	background-size: 47px 36px;
}

#ritual p.decoration::before {
	background: url(/img/c_icon_hanabishi05.png) no-repeat right top;
	background-size: 47px 36px;
}

#visit p.decoration::before {
	background: url(/img/c_icon_hanabishi03.png) no-repeat right top;
	background-size: 47px 36px;
}

#nature p.decoration::before {
	background: url(/img/c_icon_hanabishi04.png) no-repeat right top;
	background-size: 47px 36px;
}

#sengu p.decoration::before {
	background: url(/img/c_icon_hanabishi06.png) no-repeat right top;
	background-size: 47px 36px;
}

#access p.decoration::before {
	background: url(/img/c_icon_hanabishi02.png) no-repeat right top;
	background-size: 47px 36px;
}

@media screen and (max-width: 1023px) {
	#about p.decoration::before {
		background-size: 24px 18px;
	}

	#ritual p.decoration::before {
		background-size: 24px 18px;
	}

	#visit p.decoration::before {
		background-size: 24px 18px;
	}

	#nature p.decoration::before {
		background-size: 24px 18px;
	}

	#sengu p.decoration::before {
		background-size: 24px 18px;
	}

	#access p.decoration::before {
		background-size: 24px 18px;
	}
}

/*----------------------------------------
	quicklinks
-----------------------------------------*/
#quicklinks {
	position: relative;
	height: 820px;
}

#quicklinks h1 {
	z-index: 50;
	position: absolute;
	top: -71px;
	right: 250px;
	width: 215px;
	margin: auto;
}

#quicklinks dl {
	position: absolute;
	right: 0;
	bottom: 59px;
}

#quicklinks dl::before {
	content: '';
	display: block;
	position: absolute;
	top: -44px;
	left: -12px;
	height: 1px;
	width: 130px;
	background-color: #a7a7a4;
	transform: rotateZ(-34.5deg);
}

#quicklinks dl dt {
	margin-bottom: 30px;
}

#quicklinks dl dd+dd {
	margin-top: 58px;
}

#quicklinks .spmenu {
	display: none;
}

#quicklinks .sns {
	display: flex;
	align-items: center;
	margin-top: 62px;
}

#quicklinks .sns a {
	display: block;
	transition: opacity .1s ease-in-out .0s;
}

.pc #quicklinks .sns a:hover {
	opacity: .5;
}

#quicklinks .sns a:nth-of-type(1) {
	width: 36px;
}

#quicklinks .sns a:nth-of-type(2) {
	width: 40px;
	margin-left: 34px;
}

#quicklinks P {
	position: absolute;
	bottom: 74px;
	right: 345px;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

#quicklinks P a span.simplearrow {
	transform: translate(1px, 13px) rotate(90deg);
}

#quicklinks P a span.simplearrow::before {
	width: 18px;
	background-color: #ec4414;
}

#quicklinks P a span.simplearrow::after {
	width: 8px;
	height: 8px;
	border-top-color: #ec4414;
	border-right-color: #ec4414;
}

.pc #quicklinks P a:hover span.simplearrow::before {
	background-color: #ec4414;
}

.pc #quicklinks P a:hover span.simplearrow::after {
	border-top-color: #ec4414;
	border-right-color: #ec4414;
}



@media screen and (max-width: 1400px) {
	#quicklinks h1 {
		right: 15.625vw;
	}

	#quicklinks P {
		right: calc(15.625vw + 100px);
	}
}

@media screen and (max-width: 1023px) {
	#quicklinks {
		height: 375px;
	}

	#quicklinks h1 {
		top: -11px;
		right: auto;
		left: 20px;
		width: 82.5px;
		margin: auto;
	}

	#quicklinks dl {
		right: 0;
		bottom: 30px;
		width: 96px;
	}

	#quicklinks dl::before {
		top: -19px;
		left: -4px;
		height: 1px;
		width: 64px;
	}

	#quicklinks dl dt {
		margin-bottom: 15px;
	}

	#quicklinks dl dd+dd {
		margin-top: 26px;
	}

	#quicklinks .spmenu {
		display: block;
	}

	#quicklinks .sns {
		margin-top: 27px;
	}

	#quicklinks .sns a:nth-of-type(1) {
		margin-left: 2px;
		width: 22px;
	}

	#quicklinks .sns a:nth-of-type(2) {
		width: 24px;
		margin-left: 25px;
	}

	#quicklinks P {
		right: auto;
		bottom: 30px;
		left: 50px;
	}

	#quicklinks P a span.simplearrow {
		transform: translate(0, 1px) rotate(90deg);
	}

	#quicklinks P a span.simplearrow::before {
		width: 10px;
	}

	#quicklinks P a span.simplearrow::after {
		width: 4px;
		height: 4px;
	}
}

/*----------------------------------------
	about
-----------------------------------------*/
#about {
	position: relative;
	max-height: 1000px;
}

@media screen and (max-width: 1023px) {
	#about {
		width: 100%;
		max-height: 100%;
		margin: auto;
	}
}

/*----------------------------------------
	first
-----------------------------------------*/
#first {
	position: relative;
	height: 500px;
	background: transparent url(../img/i_p02.png) no-repeat right bottom 57px;
	background-size: auto 72.6%;
}

#first>a {
	display: block;
	height: inherit;
}

#first div {
	padding: 63px 0 0 25px;
}

#first div h1 span {
	display: block;
}

#first div h1 span:nth-of-type(2) {
	margin: -24px 0 0 4px;
}

#first div p {
	margin: 31px 0 0 5px;
}

.roundarrow01 {
	width: 91px;
	height: 91px;
	margin: 11px 0 0 4px;
	background-color: transparent;
}

.roundarrow01::before {
	left: -6px;
	width: 44px;
	height: 4px;
}

.roundarrow01::after {
	left: calc(50% - 4px);
	width: 18px;
	height: 18px;
}

@media screen and (max-width: 1400px) {
	#first {
		height: 580px;
		background: transparent url(../img/i_p02.png) no-repeat right bottom 120px;
		background-size: auto 25vw;
	}

	#first div p {
		margin-top: 130px;
	}
}

@media screen and (max-width: 1023px) {
	#first {
		width: 100%;
		min-height: 412px;
		height: calc(97vw + 48px);
		margin: auto;
		background: transparent url(../img/i_p02.png) no-repeat right 10px top 150px;
		background-size: 76.2% auto;
	}

	#first div {
		overflow: hidden;
		position: relative;
		height: inherit;
		padding: 39px 0 0 7px;
		box-sizing: border-box;
	}

	#first div h1 span:nth-of-type(2) {
		margin: -14px 0 0 2px;
	}

	#first div p {
		position: absolute;
		bottom: 30px;
		left: 22px;
		margin-top: auto;
	}

	#first div p br {
		display: none;
	}

	.roundarrow01 {
		width: 51px;
		height: 51px;
		margin: 4px 0 0 4px;
	}

	.roundarrow01::before {
		left: -3px;
		width: 24px;
		height: 2px;
	}

	.roundarrow01::after {
		left: calc(50% - 4px);
		width: 10px;
		height: 10px;
	}
}

@media screen and (min-width: 768px) and (max-width: 1023px) {
	#first div h1 {
		transform: scale(2.5);
		transform-origin: left top;
	}
}

@media screen and (max-width: 767px) {
	#first div h1 {
		transform: scale(1.75);
		transform-origin: left top;
	}
}

@media screen and (min-width: 650px) and (max-width: 767px) {
	#first {
		background-position: right 10px top 130px;
	}
}

@media screen and (max-width: 649px) {
	#first div h1 {
		transform: scale(1);
		transform-origin: left top;
	}
}

@media screen and (min-width: 348px) and (max-width: 649px) {
	#first {
		background-position: right 10px top 75px;
	}
}

@media screen and (max-width: 347px) {
	#first {
		min-height: 100%;
		height: calc(100vw + 48px);
		background-position: right 10px top 75px;
		background-size: 66.2% auto;
	}
}

/*----------------------------------------
	ritual
-----------------------------------------*/
#ritual {
	position: relative;
	max-height: 1000px;
}

#ritual p.decoration span {
	margin: 3px 0 4px;
}

@media screen and (max-width: 1023px) {
	#ritual {
		width: 100%;
		max-height: 100%;
		margin: auto;
	}
}

/*----------------------------------------
	visit
-----------------------------------------*/
#visit {
	position: relative;
	max-height: 1000px;
}

/*#visit h1 {
	letter-spacing: -0.03em;
}*/

#visit h1 span {
	display: inline-block;
	margin: 0 -0.4em 0 -0.2em;
}

#visit p.decoration span {
	margin: 7px 0 7px;
}

@media screen and (max-width: 1023px) {
	#visit {
		width: 100%;
		max-height: 100%;
		margin: 50px auto 0;
	}

	#visit h1 {
		letter-spacing: 0;
	}

	#visit h1 span {
		margin: 0;
	}
}

/*----------------------------------------
	amulet
-----------------------------------------*/
#amulet a {
	display: block;
	width: calc(100% + 40px);
	height: 100%;
	margin-left: -40px;
	background: transparent url(../img/i_p05.jpg) no-repeat right -110px bottom -6px;
	background-size: auto 78%;
}

#amulet div {
	position: relative;
	height: inherit;
	padding: 63px 25px 0;
}

#amulet div h1 {
	position: relative;
}

#amulet div h1 span {
	display: block;
	position: absolute;
}

#amulet div h1 span:nth-of-type(1) {
	top: 5px;
	right: 7px;
}

#amulet div h1 span:nth-of-type(2) {
	top: 94px;
	right: -27px;
	height: 4em;
	letter-spacing: -0.005em;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

#amulet div h1 span:nth-of-type(2) span {
	top: 282px;
	right: 49px;
	height: 3em;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

#amulet div h1 span:nth-of-type(3) {
	top: 94px;
	right: 73px;
	height: 4em;
	letter-spacing: -0.005em;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

#amulet div p {
	position: absolute;
	right: 10px;
	bottom: 150px;
	text-align: right;
}

#amulet .roundarrow01 {
	position: absolute;
	right: -4px;
	top: 454px;
	margin: auto;
}

@media screen and (max-width: 1400px) {
	#amulet a {
		width: calc(100% + 40px);
		background-position: right -1vw bottom -6px;
		background-size: auto 45vw;
	}

	#amulet div {
		padding: 63px 25px 0;
	}

	#amulet div p {
		right: 10px;
		bottom: 5vw;
	}

	#amulet .roundarrow01 {
		right: -4px;
		top: 454px;
	}
}

@media screen and (min-width: 1024px) and (max-width: 1400px) {
	#amulet a {
		background-position: left -2vw bottom 0;
		background-size: 118% auto;
	}
}

@media screen and (max-width: 1023px) {
	#amulet {
		overflow: hidden;
		width: 100vw;
		max-width: none;
		min-height: 100%;
		height: 113vw;
		margin: auto auto auto -20px;
	}

	#amulet a {
		background-position: left 5vw bottom 1vw;
		background-size: 90% auto;
	}

	#amulet div {
		height: inherit;
		padding: 59px 25px 0;
		box-sizing: border-box;
	}

	#amulet div h1 {
		margin-top: 2.5vw;
		margin-right: 5vw;
		transform: scale(2);
		transform-origin: top right;
	}

	#amulet div h1 span:nth-of-type(1) {
		top: -23px;
		right: 12px;
	}

	#amulet div h1 span:nth-of-type(2) {
		top: 27px;
		right: -6px;
	}

	#amulet div h1 span:nth-of-type(2) span {
		top: 156px;
		right: 26px;
	}

	#amulet div h1 span:nth-of-type(3) {
		top: 27px;
		right: 49px;
	}

	#amulet div p {
		right: 0;
		bottom: 8.5vw;
		/*bottom: 32px;*/
		left: 80px;
		width: 80%;
		margin: auto auto auto 0;
		text-align: left;
		line-height: 1.8;
	}

	#amulet .roundarrow01 {
		right: 5px;
		top: 225px;
	}
}

@media screen and (max-width: 667px) {
	#amulet div h1 {
		margin-top: 2.5vw;
		margin-right: 2.5vw;
		transform: scale(1.5);
		transform-origin: top right;
	}
}

@media screen and (max-width: 424px) {
	#amulet a {
		background-position: left 10vw bottom 0;
	}

	#amulet div h1 {
		margin-top: 0;
		margin-right: 0;
		transform: scale(1);
		transform-origin: top right;
	}
}


/*----------------------------------------
	hours
-----------------------------------------*/
#hours {
	margin-top: 105px;
	padding: 145px 0 123px;
}

#hours section {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#hours section h1 {
	margin-left: 40px;
}

#hours section ul {
	width: 600px;
}

#hours section ul::before {
	content: '';
	display: block;
	width: 100%;
	height: 1px;
	margin: 5px 0 35px;
	background-color: #a7a7a4;
}

#hours section ul li {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#hours section ul li:nth-of-type(n+2) {
	margin-top: 50px;
}

#hours section ul li span+span {
	margin-right: 70px;
}

@media screen and (max-width: 1400px) {
	#hours {
		padding: 105px 0 83px;
	}
}

@media screen and (max-width: 1200px) {
	#hours section h1 {
		margin-left: 20px;
	}

	#hours section ul {
		width: 500px;
	}

	#hours section ul li span+span {
		margin-right: 0;
	}
}

@media screen and (max-width: 1023px) {
	#hours {
		margin-top: 0;
		padding: 72px 0 75px;
	}

	#hours section h1 {
		margin-left: 0;
	}

	#hours section ul {
		width: 100%;
	}

	#hours section ul::before {
		height: 1px;
		margin: 17px 0;
	}

	#hours section ul li:nth-of-type(n+2) {
		margin-top: 22px;
	}
}

/*----------------------------------------
	bnr_movie
-----------------------------------------*/
#bnr_movie {
	margin-top: 30px;
}

#bnr_movie > a {
	display: block;
	position: relative;
	height: 31.25vw;
	background: #22252b;
	color: #fff;
	overflow: hidden;
}

#bnr_movie > a > #bnr_mv_txt {
	position: absolute;
	bottom: 27px;
	left: calc(22.86% - 70px);
	z-index: 10;
}

#bnr_movie > a > #bnr_mv_txt h1 {
	width: 321px;
	height: 176px;
}

#bnr_movie > a > #bnr_mv_txt p {
	margin-top: 59px;
	margin-left: 99px;
	opacity: .6;
	transition: all .5s ease-in-out .0s;
}

#bnr_movie > a:hover > #bnr_mv_txt p {
	opacity: 1;
}

#bnr_movie > a > p {
	display: inline-block;
	position: absolute;
	right: 33px;
	bottom: 28px;
	padding-left: 54px;
	background: url(../img/c_bnr_mv_open_yt01.png) no-repeat left center;
	letter-spacing: normal;
	z-index: 10;
	opacity: .6;
	transition: all .5s ease-in-out .0s;
}

#bnr_movie > a:hover > p {
	opacity: 1;
}

#bnr_movie > a > #bnr_mv_slide {
	position: relative;
	width: 77.14%;
	height: 100%;
	margin-left: 22.86%;
}

#bnr_movie > a > #bnr_mv_slide #bnr_mv_slide_cover {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(255, 255, 255, 0);
	z-index: 5;
	opacity: 0;
	transition: all .5s ease-in-out .0s;
}

#bnr_movie > a:hover > #bnr_mv_slide #bnr_mv_slide_cover {
	background: rgba(0, 0, 0, .6);
	opacity: 1;
}

#bnr_movie > a:hover > #bnr_mv_slide .swiper-container {
	height: 100%;
}

#bnr_movie > a > #bnr_mv_slide img {
	height: 31.25vw;
}

@media screen and (max-width: 1200px) {
	#bnr_movie > a > #bnr_mv_txt h1 {
		width: calc(22.92vw * (90 / 100));
		height: calc(12.57vw * (90 / 100));
	}
	#bnr_movie > a > #bnr_mv_txt p br.sp {
		display: block;
	}
}

@media screen and (max-width: 1023px) {
	#bnr_movie > a {
		height: 80vw;
	}
	
	#bnr_movie > a > #bnr_mv_slide #bnr_mv_slide_cover {
		display: none;
	}
	
	#bnr_movie > a > #bnr_mv_txt {
		bottom: 4vw;
		left: calc(16% - 9.2vw);
	}
	
	#bnr_movie > a > #bnr_mv_txt h1 {
		width: 42.8vw;
		height: 23.46vw;
	}
	
	#bnr_movie > a > #bnr_mv_txt p {
		margin-top: calc(5.33vw - 3px);
		margin-left: 13.06vw;
		opacity: 1;
		transition: none;
	}
	
	#bnr_movie > a > p {
		right: calc(4vw + 4px);
		bottom: 16vw;
		padding-left: 35px;
		background: url(../img/c_bnr_mv_open_yt01.png) no-repeat left center;
		background-size: 26px 18px;
		opacity: 1;
		transition: none;
	}

	#bnr_movie > a > #bnr_mv_slide {
		width: 84%;
		margin-left: 16%;
	}
	
	#bnr_movie > a > #bnr_mv_slide .swiper-container .swiper-slide {
		width: 100% !important;
	}
	
	#bnr_movie > a > #bnr_mv_slide img {
		height: 80vw;
		background: none;
		transition: none;
	}
	
	#bnr_movie > a:hover > #bnr_mv_slide img {
		opacity: 1;
	}
}

/*----------------------------------------
	topics
-----------------------------------------*/
#topics {
	padding-top: 98px;
}

#topics>h1 {
	display: flex;
	align-items: baseline;
	position: relative;
	width: 0;
	margin: auto;
	line-height: 0;
}

#topics>h1 span {
	display: block;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}

#topics>h1 span:nth-of-type(2) {
	position: absolute;
	top: 0;
	right: -69px;
}

@media screen and (max-width: 1023px) {
	#topics {
		padding-top: 39px;
	}

	#topics>h1 span:nth-of-type(2) {
		right: -36px;
	}
}

/* 日別朝夕大御饌祭専用 */
#topics>section {
	display: flex;
	justify-content: space-between;
	max-width: 870px;
	width: calc(100% - 80px);
	margin: 57px auto 0;
}

#topics>section figure {
	width: 260px;
	height: 260px;
}

#topics>section figure a {
	transition: all .1s ease-in-out .0s;
}

.pc #topics>section figure a:hover {
	opacity: .5;
}

#topics>section div {
	max-width: 540px;
	width: calc(100% - 330px);
	padding-top: 5px;
}

#topics>section div h1 {
	display: flex;
	align-items: center;
}

#topics>section div h1+p {
	margin-top: 55px;
	padding-top: 33px;
	border-top: 1px solid #373d44;
}

#topics>section div p.link {
	margin-top: 23px;
}

#topics>section div p.link a {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 200px;
	margin: auto;
	margin-right: 0;
}

#topics>section div p.link a .roundarrow02 {
	width: 50px;
	height: 50px;
	margin: 1px 0 0 10px;
	border-width: 2px;
	border-color: #a7a7a4;
	background-color: #fff;
}

.pc #topics>section div p.link a:hover .roundarrow02 {
	background-color: #a7a7a4;
}

#topics>section div p.link a .roundarrow02::before {
	left: -4px;
	width: 25px;
	height: 2px;
}

#topics>section div p.link a .roundarrow02::after {
	left: calc(50% - 2px);
	width: 10px;
	height: 10px;
	border-width: 2px;
}

@media screen and (max-width: 1023px) {
	#topics>section {
		display: block;
		max-width: none;
		width: calc(100% - 40px);
		margin: 28px auto 0;
	}

	#topics>section figure {
		max-width: 260px;
		width: 34.66vw;
		max-height: 260px;
		height: 34.66vw;
		margin: auto;
	}

	#topics>section div {
		max-width: none;
		width: calc(100% - 60px);
		margin: 20px auto 0;
		padding-top: 5px;
	}

	#topics>section div h1 {
		justify-content: center;
	}

	#topics>section div h1+p {
		margin-top: 27px;
		padding-top: 15px;
		line-height: 1.7;
	}

	#topics>section div p.link {
		margin-top: 15px;
	}

	#topics>section div p.link a .roundarrow02 {
		width: 25px;
		height: 25px;
		margin: 1px 0 0 7px;
		border-width: 1px;
	}

	#topics>section div p.link a .roundarrow02::before {
		left: -2px;
		width: 12px;
		height: 1px;
	}

	#topics>section div p.link a .roundarrow02::after {
		left: calc(50% - 2px);
		width: 5px;
		height: 5px;
		border-width: 1px;
	}
}

/* お知らせ・中 */
#middlesize {
	position: relative;
	margin-top: 60px;
	background-color: #525461;
}

#middlesize::before {
	content: '';
	display: block;
	z-index: 1;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100px;
	margin: auto;
	background-color: #fff;
}

#middlesize .swiper-container {
	width: 100% !important;
	padding-bottom: 0 !important;
}

#middlesize .swiper-wrapper {
	display: flex;
	justify-content: space-between;
}

#middlesize .swiper-slide {
	position: relative;
	width: 394px;
	background-color: #fff;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

#middlesize .swiper-slide figure {
	width: 394px;
	height: 262px;
}

#middlesize .swiper-slide figure a {
	display: block;
	width: 100%;
	height: 100%;
	transition: all .1s ease-in-out .0s;
}

.pc #middlesize .swiper-slide figure a:hover {
	opacity: .5;
}

#middlesize .swiper-slide>div:nth-of-type(1) {
	padding: 21px 30px 81px;
}

#middlesize .swiper-slide>div:nth-of-type(1) h1 {
	line-height: 1.7;
}

#middlesize .swiper-slide>div:nth-of-type(1) h1 a {
	letter-spacing: 0.085em;
}

#middlesize .swiper-slide>div:nth-of-type(1) p.font16_12 {
	margin: 15px 0 0 1px;
}

#middlesize .swiper-slide>div:nth-of-type(1) p.font14_12 {
	margin: 2px 0 0 1px;
}

#middlesize .swiper-slide>div:nth-of-type(1) p.font14_12:empty {
	display: none;
}

#middlesize .swiper-slide>div:nth-of-type(2) {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: absolute;
	bottom: 20px;
	left: 30px;
	width: calc(100% - 60px);
}

#middlesize .swiper-slide>div:nth-of-type(2) div {
	width: 60%;
}

#middlesize .swiper-slide>div:nth-of-type(2) p.date {
	margin: -1px -4px 0 0;
}

#middlesize .swiper-container .category,
#middlesize .swiper-container .status {
	margin-left: 0;
}

#middlesize .swiper-container .category+.status {
	margin-left: 6px;
}

@media screen and (min-width: 1458px) {
	#middlesize .swiper-wrapper .order1 {
		order: 2;
	}

	#middlesize .swiper-wrapper .order2 {
		order: 3;
	}

	#middlesize .swiper-wrapper .order3 {
		order: 1;
	}
}

@media screen and (min-width: 1440px) {
	.macOS #middlesize .swiper-wrapper .order1 {
		order: 2;
	}

	.macOS #middlesize .swiper-wrapper .order2 {
		order: 3;
	}

	.macOS #middlesize .swiper-wrapper .order3 {
		order: 1;
	}
}

@media screen and (max-width: 1023px) {
	#middlesize {
		margin-top: 40px;
	}

	#middlesize::before {
		width: 100%;
		height: 50px;
	}

	#middlesize .swiper-slide {
		width: 270px;
	}

	#middlesize .swiper-slide figure {
		width: 270px;
		height: 180px;
	}

	#middlesize .swiper-slide>div:nth-of-type(1) {
		padding: 13px 18px 53px;
	}

	#middlesize .swiper-slide>div:nth-of-type(1) h1 {
		line-height: 2;
	}

	#middlesize .swiper-slide>div:nth-of-type(1) h1 .blank {
		margin-bottom: -4px;
		padding-left: 6px;
	}

	#middlesize .swiper-slide>div:nth-of-type(1) p.font16_12 {
		margin: 5px 0 0 1px;
	}

	#middlesize .swiper-slide>div:nth-of-type(1) p.font16_12+p.font14_12 {
		display: none;
	}

	#middlesize .swiper-slide>div:nth-of-type(2) {
		bottom: 10px;
		left: 9px;
		width: calc(100% - 36px);
	}

	#middlesize .swiper-slide>div:nth-of-type(2) div {
		width: 50%;
	}

	#middlesize .swiper-slide>div:nth-of-type(2) p.date {
		margin: -1px -4px 0 0;
	}
}

/* お知らせ・小 */
#smallsize {
	padding: 40px 0 54px;
	background-color: #525461;
}

#smallsize>div {
	display: flex;
	justify-content: space-between;
}

#smallsize ul {
	/*width: calc(100% - 450px);*/
	width: 60%;
}

#smallsize ul li {
	display: flex;
	justify-content: space-between;
}

#smallsize ul li+li {
	margin-top: 24px;
}

#smallsize ul li>p {
	width: 170px;
}

#smallsize ul li span {
	display: inline-block;
}

#smallsize ul li>div {
	width: calc(100% - 210px);
	margin-top: -5px;
}

#smallsize ul li>div p:nth-of-type(1) a {
	letter-spacing: 0.085em;
}


#smallsize .category,
#smallsize .status {
	margin-left: 16px;
}

#smallsize ul+p {
	width: 35%;
	margin-top: 20px;
}

#smallsize .rounded {
	width: 100%;
	height: 100px;
	border-radius: 50px;
}

.pc #smallsize .rounded:hover {
	background-color: #fff;
	border-color: #fff;
	color: #373d44 !important;
	opacity: 1;
}

#smallsize .blank::before {
	border: 1px solid #a7a7a4;
	background-color: #525461;
}

#smallsize .blank::after {
	border: 1px solid #a7a7a4;
	background-color: #525461;
	box-shadow: 0px 0px 0px 1px #525461;
}

@media screen and (max-width: 1023px) {
	#smallsize {
		padding: 26px 0 30px;
	}

	#smallsize>div {
		display: block;
	}

	#smallsize ul {
		width: 92%;
		margin: auto;
	}

	#smallsize ul li+li {
		margin-top: 9px;
	}

	#smallsize ul li>p {
		width: 67px;
	}

	#smallsize ul li span:not(.blank) {
		display: block;
	}

	#smallsize ul li span.blank {
		margin-bottom: -5px;
	}

	#smallsize ul li>div {
		width: calc(100% - 67px);
		margin-top: -3px;
	}

	#smallsize .category,
	#smallsize .status {
		margin: 5px 0 0 0;
	}

	#smallsize ul+p {
		width: 100%;
		margin-top: 28px;
	}

	#smallsize .rounded {
		width: 220px;
		height: 50px;
		border-radius: 25px;
	}
}

/*----------------------------------------
	nature
-----------------------------------------*/
#nature {
	width: calc((100% - 40px)/2);
	margin: 150px auto auto 0;
}

#nature div {
	background-color: #fff;
	box-shadow: 0 30px 27px 3px rgba(0, 0, 0, 0.08);
	transition: all .1s ease-in-out .0s;
}

.pc #nature:hover div {
	background-color: #696b76;
}

/* IE11用huck */
_:-ms-lang(x)::-ms-backdrop,
#nature.card div {
	box-shadow: none;
}

#nature p.decoration span {
	display: inline-block;
	margin: 4px 0 3px;
}

#nature a {
	display: block;
	transition: color .1s ease-in-out .0s;
}

.pc #nature:hover a {
	color: #fff !important;
}

#nature p.font20_14 a {
	transition: opacity .1s ease-in-out .0s;
}

.pc #nature p.font20_14 a:hover {
	opacity: .5 !important;
}

#nature figure {
	transition: all .1s ease-in-out .0s;
}

.pc #nature:hover figure {
	background-color: #fff;
	opacity: .5;
}

@media screen and (max-width: 1023px) {
	#nature {
		width: 100%;
		margin-top: 50px;
	}

	#nature div {
		background-color: #fff;
		box-shadow: 0 15px 20px 3px rgba(0, 0, 0, 0.08);
		transition: all .1s ease-in-out .0s;
	}

	#nature p.decoration span {
		display: inline-block;
		margin: 4px 0 3px;
	}
}

/*----------------------------------------
	feel
-----------------------------------------*/
#feel {
	margin: -660px auto auto 0;
	padding-bottom: 752px;
	background: transparent url(../img/i_feel_bg.jpg) no-repeat center bottom;
	background-size: 100% auto;
}

#feel div {
	width: 40%;
	margin: auto 40px auto auto;
}

#feel div a {
	display: inline-block;
}

#feel div a h1 {
	position: relative;
	width: 500px;
	margin: auto 0 auto auto;
}

#feel div a h1 span {
	display: block;
	line-height: 1;
}

#feel div a h1 span:nth-of-type(1) {
	margin: 0 0 0 -2px;
}

#feel div a h1 span:nth-of-type(2) {
	margin: -2px 0 0 -8px;
}

#feel div a h1 span:nth-of-type(3) {
	margin: -24px 0 0 -8px;
}

#feel div a h1 span.roundarrow01 {
	position: absolute;
	top: 126px;
	right: 1px;
	width: 101px;
	height: 101px;
	border-color: #d5dede;
}

.pc #feel div a:hover h1 span.roundarrow01 {
	border-color: #696b76;
}

#feel div a h1 span.roundarrow01::before {
	left: -12px;
	width: 48px;
	height: 4px;
	background-color: #d5dede;
}

#feel div a h1 span.roundarrow01::after {
	left: calc(50% - 6px);
	width: 20px;
	height: 20px;
	border-color: #d5dede;
}

#feel div a p {
	width: 500px;
	margin: 41px -4px auto auto;
}

@media screen and (max-width: 1400px) {
	#feel div a h1 {
		width: 370px;
		margin: auto 0 auto auto;
		transform: scale(0.9);
		transform-origin: right bottom;
	}

	#feel div a h1 span.roundarrow01 {
		top: 315px;
	}

	#feel div a p {
		width: 333px;
		margin-top: 130px;
	}
}

@media screen and (max-width: 1100px) {
	#feel div {
		margin: auto 80px auto auto;
	}
}

@media screen and (max-width: 1023px) {
	#feel {
		margin: 47px auto 0;
		padding-bottom: 53.7vw;
		background-color: #f0fbfc;
	}

	#feel div {
		margin: auto 38px auto auto;
		padding-top: 48px;
	}

	#feel div a h1 {
		width: 90%;
		margin: auto 0 auto 14.5vw;
		transform: scale(1);
	}

	#feel div a h1 span:nth-of-type(3) {
		margin-top: -11px;
	}

	#feel div a h1 span.roundarrow01 {
		top: 64px;
		right: auto;
		left: 191px;
		width: 50px;
		height: 50px;
	}

	#feel div a h1 span.roundarrow01::before {
		left: -3px;
		width: 24px;
		height: 2px;
	}

	#feel div a h1 span.roundarrow01::after {
		left: calc(50% - 2px);
		width: 10px;
		height: 10px;
	}

	#feel div a p {
		width: 90%;
		margin: 70px 0 0 11.2vw;
	}
}

/*----------------------------------------
	split（左右分割エリア用）
-----------------------------------------*/
.split {
	display: flex;
	justify-content: space-between;
	margin-top: 100px;
}

@media screen and (max-width: 1023px) {
	.split {
		display: block;
		margin-top: 50px;
	}
}

/*----------------------------------------
	sengu
-----------------------------------------*/
#sengu {
	width: 50%;
	margin: 0 auto;
}

#sengu p.decoration span {
	display: inline-block;
	margin: 4px 0 3px;
}

#sengu>div {
	min-height: 400px;
}

#sengu ul {
	padding-bottom: 52px;
}

@media screen and (max-width: 1023px) {
	#sengu {
		width: 100%;
		margin: 0 auto 0;
	}

	#sengu>div {
		min-height: 100%;
	}

	#sengu ul {
		padding-bottom: 0;
	}
}

/*----------------------------------------
	access
-----------------------------------------*/
#access {
	width: 50%;
	margin: 0 auto 0 40px;
}

#access>div {
	min-height: 400px;
}

#access h1+p {
	width: 70%;
}

@media screen and (max-width: 1023px) {
	#access {
		width: 100%;
		margin: 50px auto 0;
	}

	#access>div {
		min-height: 100%;
	}
}

/*----------------------------------------
	relatedpage
-----------------------------------------*/
#relatedpage {
	display: flex;
	justify-content: space-between;
	margin-top: 199px;
}

#relatedpage li {
	width: calc((100% - 10px)/3);
}

#relatedpage li a {
	display: block;
	transition: opacity .1s ease-in-out .0s;
}

.pc #relatedpage li a:hover {
	opacity: .5;
}

#relatedpage li a figure {
	position: relative;
}

#relatedpage li a figure span {
	display: block;
	position: absolute;
	top: 16px;
	right: 0;
	left: 0;
	margin: auto;
	text-align: center;
	letter-spacing: 0.09em;
}

#relatedpage li a figure span+span {
	top: 43px;
}

@media screen and (max-width: 1023px) {
	#relatedpage {
		display: block;
		margin-top: 51px;
	}

	#relatedpage li {
		width: 100%;
	}

	#relatedpage li+li {
		margin-top: 3px;
	}

	#relatedpage li a figure span {
		top: 11px;
	}

	#relatedpage li a figure span+span {
		top: 31px;
	}
}

/*----------------------------------------
	aside
-----------------------------------------*/
@media screen and (max-width: 1023px) {
	aside {
		margin-top: 30px;
	}
}

/*----------------------------------------
	time-change
-----------------------------------------*/
#time-change {
	margin: 100px 0 0;
	text-align: center;
}

@media screen and (max-width: 1023px) {
	#time-change {
		margin: 0 0 20px;
	}
}