@charset "utf-8";/* フォント */
@font-face {
   font-family: 'MonteCarlo';
   src: url('/photo/page/20251118/font/MonteCarlo-Regular.ttf') format("truetype");
}
@font-face {
   font-family: 'jsMathCmr10';
   src: url('/photo/page/20251118/font/jsMath-cmr10.ttf') format("truetype");
}
@font-face {
   font-family: 'NotoSerifJp';
   src: url('/photo/page/20251118/font/NotoSerifJP-Medium.ttf') format("truetype");
}
@font-face {
   font-family: 'NotoSerif';
   src: url('/photo/page/20251118/font/NotoSerif_Condensed-Light.ttf') format("truetype");
}
@font-face {
   font-family: 'NotoSans';
   src: url('/photo/page/20251118/font/NotoSans_Condensed-Regular.ttf') format("truetype");
}
.font-monte-carlo {
	font-family: 'MonteCarlo';
}
.font-jsmath-cmr10 {
	font-family: 'jsMathCmr10';
}
.font-noto-serif-jp {
	font-family: 'NotoSerifJp';
}
.font-noto-serif {
	font-family: 'NotoSerif';
}
.font-noto-sans {
	font-family: 'NotoSans';
}
/* メイン */
.red-background {
	padding-left: 10px;
	position: fixed;
	width: 100%;
	height: 100vh;
	display: grid;
	place-items: center;
	top: 0px;
	background-color: #A60000;
	z-index: 30000;	/* headerが20000のため */
}
.red-background .message {
	margin-top: 200px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 45px;
}
.red-background .message .message-holidays {
	visibility: hidden;
	color: white;
	font-size: 99px;
}
.red-background .message .message-are {
	font-size: 24px;
}
.red-background .message .message-coming {
	font-size: 24px;
}
.no-scroll {
    overflow-y: scroll;
    position: fixed;
    width: 100%;
}
.main .article .article-title-container {
	margin-bottom: 195px;
	height: calc(100vh - 193px);
	display: grid;
	place-items: center;
	overflow: hidden;
}
.main .article .article-title {
	width: 85%;
	display: flex;
	gap: 25px;
	justify-content: center;
}
.main .article .article-title .image {
	width: 33.7%;
}
.main .article .article-title .message {
	margin-top: 100px;
	width: 32.6%;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.main .article .article-title .message .sp-decoration {
	display: none;
}
.main .article .article-title .message .message-holidays {
	width: 100%;
}
.main .article .article-title .message .message-are {
	margin-top: 10%;
	width: 10.5%;
}
.main .article .article-title .message .message-coming {
	margin-top: 13%;
	width: 26.5%;
}
.main .article .container {
	width: 100%;
	display: flex;
	justify-content: center;
}
.main .article .section-container {
	margin-left: 17.5%;
	width: 65%;
}
.main .article .section:not(:last-child) {
	margin-bottom: 115px;
}
.main .article .section .section-title {
	margin-bottom: 40px;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.main .article .section .section-title p:first-child {
	color: #A60000;
	font-size: 32px;
	line-height: 1;
}
.main .article .section .section-title p:nth-child(2) {
	margin-top: 5px;
	color: #A60000;
	font-size: 40px;
	line-height: 1;
}
.main .article .section .section-title p:nth-child(3),
.main .article .section .section-title p:nth-child(4),
.main .article .section .section-title p:nth-child(5) {
	margin-top: 5px;
	font-size: 16px;
	line-height: 2;
}
.main .article .section .section-title p:nth-child(3)::after,
.main .article .section .section-title p:nth-child(4)::after,
.main .article .section .section-title p:nth-child(5)::after {
	content: '';
	width: 100%;
	display: block;
	border-bottom: 1px solid black;
}
.main .article .section .section-title p:nth-child(4), 
.main .article .section .section-title p:nth-child(5) {
	display: none;
}

.main .article .section .section-title .sp {
	display: none;
}
.main .article .section .section-image {
	width: 100%;
	display: flex;
	justify-content: center;
	gap: 25px;
}
.main .article .section .section-image a {
	width: calc(50% - 12.5px);
	display: block;
}
.main .article .section .section-image a .plus {
	display: none;
}

.main .article .section .section-image img {
	width: 100%;
}
.main .article .section:nth-child(5) .section-image .image {
	width: 50%;
}
.main .article .section:nth-child(5) .section-image .image a {
	width: 100%;
	display: block;
}
.main .article .section:nth-child(5) .section-image .image .about-item a {
	display: inline;
}
.main .article .section:nth-child(6) .section-image {
	width: 100%;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}
.main .article .section:nth-child(6) .about-item,
.main .article .section:nth-child(8) .about-item {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 70px;
}
.main .article .section .about-item {
	margin-top: 15px;
	font-size: 14px;
	text-align: center;
}
.main .article .section .about-item a:nth-child(2) {
	padding-left: 6px;
}
.main .article .container .sticky-decoration-container {
	width: 17.5%;
	position: relative;
}
.main .article .sticky-decoration {
	margin: 380px auto 40px;
	width: 100%;
	position: sticky;
	top: 500px;
	z-index: 1000;
	text-align: center;
}
.main .article .sticky-decoration .holidays {
	color: #A60000;
	font-size: 45px;
}
.main .article .sticky-decoration .are,
.main .article .sticky-decoration .coming {
	font-size: 10px;
}
.main .article .bottom {
	margin-top: 274px;
}
.main .article .bottom .decoration {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.main .article .bottom .decoration .image {
	width: 23%;
	position: relative;
}
.main .article .bottom .decoration .image p {
	width: 400px;
	position: absolute;
	top: -75px;
	left: 118px;
	transform: rotate(5.13deg);
	color: #A60000;
	font-size: 48px
}
.main .article .bottom .decoration .image img {
	width: 100%;
}
.main .article .bottom .decoration .logo {
	margin: 8px 0 105px;
	width: 20%;
}
.main .article .bottom .links {
	margin-bottom: 108px;
	font-size: 16px;
	text-align: center;
}
.main .article .bottom .links p {
	margin-bottom: 19px;
}
.main .article .staff-credit {
	margin-bottom: 80px;
	font-size: 14px;
	text-align: center;
}
.main .article .staff-credit p:nth-child(4) {
	margin-bottom: 18px;
}
/* ヘッダーの変化に対応させる */
@media screen and (max-width:1279px) {
	.main .article .container .sticky-decoration-container .sticky-decoration {
		display: none;
	}
	.main .article .article-title-container {
		height: calc(100vh - 143.25px);
	}
}
/* スマートフォン */
@media screen and (max-width:751px) {
	.sp-return {
		display: block;
	}
	.red-background .message {
		margin-top: 100px;
	}
	.main .article .article-title-container {
		margin: 40px auto 90px;
		height: calc(100vh - 133.25px);
	}
	.main .article .article-title {
		flex-direction: column;
		align-items: center;
		gap: 50px;
	}
	.main .article .article-title .message {
		margin-top: 0;
		position: relative;
	}
	.main .article .article-title .message .sp-decoration {
		width: 19.5%;
		display: block;
		position: absolute;
		top: 38px;
		left: 30px;
		transform: rotate(14.04deg);
		z-index: 10;
	}
	.main .article .article-title .message .message-holidays {
		width: 54.6%;
		z-index: 20;
	}
	.main .article .article-title .image:nth-of-type(1) {
		width: 100%;
		order: 1;
	}
	.main .article .article-title .image:nth-of-type(2) {
		display: none;
	}
	.main .article .article-title .message {
		width: 100%;
		order: 0;
	}
	.main .article .section-container {
		margin-left: 7.5%;;
		width: 85%;
	}
	.main .article .section:not(:last-child) {
		margin-bottom: 55px;
	}
	.main .article .section .section-title p:first-child {
		font-size: 20px;
	}
	.main .article .section .section-title p:nth-child(2) {
		font-size: 21.54px;
	}
	.main .article .section .section-title p:nth-child(3) {
		font-size: 14px;
	}
	.main .article .section .section-image {
		flex-direction: column;
	}
	.main .article .section .section-image a {
		width: 100%;
		position: relative;
	}
	.main .article .section .section-image a .plus {
		width: 9.9%;
		padding-top: 9.9%;
		height: auto;
		display: block;
		position: absolute;
		bottom: 15px;
		right: 15px;
		background-image: url('/photo/page/20251118/plus.png');
		background-size: cover;
	}
	.main .article .section .section-image img {
		width: 100%;
	}
	.main .article .section:nth-child(5) .section-image .image {
		width: 100%;
	}
	.main .article .section:nth-child(6) .about-item,
	.main .article .section:nth-child(8) .about-item {
		flex-direction: column;
		gap: 5px;
	}
	.main .article .container .sticky-decoration-container {
		width: 7.5%;
	}
	.main .article .bottom {
		margin-top: 185px;
	}
	.main .article .bottom .decoration .image {
		width: 45%;
	}
	.main .article .bottom .decoration .image p {
		top: -30px;
		left: 55px;
		font-size: 25px;
	}
	.main .article .bottom .decoration .logo {
		margin: 8px 0 105px;
		width: 45%;
	}
	.main .article .staff-credit {
		margin-bottom: 100px;
		font-size: 10px;
	}
}

@media screen and (max-width:400px) {
	.main .article .section .section-title p:nth-child(3).pc {
		display: none;
	}
	.main .article .section .section-title p:nth-child(4),
	.main .article .section .section-title p:nth-child(5) {
		display: block;
		font-size: 14px;
	}
}

/* 下から上へ画像が動く */
.vertical-move {
	object-fit: cover;
	opacity: 0;
	transform: translateY(100px); /* 下に初期配置 */
	transition: all 1s ease-out;
}