@charset "utf-8";
body,div,dl,dt,dd,ul,ol,li,p,h1,h2,h3,h4,h5,h6,th,td,pre,code,blockquote,form,fieldset,legend,input,textarea,figcaption,figure{margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:normal}li{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal}q:before,q:after{content:''}abbr,acronym{border:0;font-variant:normal}sup{vertical-align:text-top}sub{vertical-align:text-bottom}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit}input,textarea,select{*font-size:100%}legend{color:#FFF}hr{display:none}img{vertical-align:bottom}select,input,button,textarea{font-size:99%}table{font-size:inherit;font:100%;border-collapse:collapse;border-spacing:0}pre,code,kbd,samp,tt{font-family:monospace;*font-size:108%;line-height:100%}.hd{display:block;width:0;height:0;overflow:hidden}.cf:before,.cf:after{content:"";display:table}.cf:after{clear:both}.cf{*zoom:1}article,aside,details,figcaption,figure,footer,header,hgroup,hr,menu,nav,section,main{display:block}*{margin:0;padding:0;box-sizing:border-box;max-height:999999px;outline:none}*:focus{outline:none}button{background-color:transparent;border:none;cursor:pointer;outline:none;padding:0}
:root {
	--color-green:#355222;
	--color-red:#b70016;
}
body{
	-webkit-text-size-adjust:100%;
	background-color:#000;
	color:#000;
	font-family:"Noto Sans JP", sans-serif;
	font-size:16px;
	font-weight:normal;
	letter-spacing:0.07em;
	line-height:1.8;
	word-wrap:break-word;
}
a{color:#222}
a:hover{text-decoration:none}
.ah{transition:opacity .3s ease}
.ah:hover{opacity:.7}
::selection{
	background:var(--color-red);
	color:#fff;
}
::-moz-selection{
	background:var(--color-red);
	color:#fff;
}
@media screen and (max-width:768px){
	body{
		font-size:24px;
		min-width:320px;
	}
	.pc{display:none}
	.ah:hover{opacity:1}
}
@media screen and (min-width:769px){
	body{
		scrollbar-gutter:stable;
	}
	.sp{display:none}
	::-webkit-scrollbar{
		width:8px;
		height:8px;
	}
	::-webkit-scrollbar-track{
		border-radius:0px;
		background:#551516;
	}
	::-webkit-scrollbar-thumb{
		background:#fff;
		margin:2px;
		box-shadow:none;
	}
	@-moz-document url-prefix(){
		html{
			scrollbar-color:#fff #551516;
			scrollbar-width:thin;
		}
	}
}
.loading {
	position: fixed;
	left:0;
	top:0;
	right:0;
	bottom:0;
	z-index:20000;
	background:#000;
}
#fullWrap {
	min-height:100vh;
	min-height:100dvh;
	overflow: hidden;
	background:url(../img/common/bg_b.jpg) no-repeat center top / cover;
	position: relative;
}
@supports (background-image:url(../img/common/bg_b.webp)){
	#fullWrap {
		background-image:url(../img/common/bg_b.webp);
	}
}
#fullWrap:before {
	content:'';
	position: absolute;
	left:0;
	top:0;
	right:0;
	bottom:0;
	background:url(../img/common/bg_t.png) no-repeat center bottom / cover;
	mix-blend-mode: color-dodge;
}
@supports (background-image:url(../img/common/bg_t.webp)){
	#fullWrap:before {
		background-image:url(../img/common/bg_t.webp);
	}
}
.contentWrap {
	width:750px;
	margin:0 auto;
	position: relative;
	z-index:10;
}
.contentWrap:before {
	content:'';
	position: absolute;
	width:200px;
	height:200px;
	background:url(../img/common/face1.png) no-repeat center center / contain;
	top:110px;
	left:-20px;
}
@media screen and (min-width:900px){
	.contentWrap:before {
		left:-100px;
	}
}
.contentWrap:after {
	content:'';
	position: absolute;
	width:160px;
	height:160px;
	background:url(../img/common/face2.png) no-repeat center center / contain;
	top:400px;
	right:-20px;
	transform:rotate(15deg);
}
@media screen and (min-width:900px){
	.contentWrap:after {
		right:-90px;
	}
}
.header {
	height:290px;
	position: relative;
	padding-top:41px;
}
.header__logo {
	width:448px;
	height:212px;
	background:url(../../../assets/img/common/logo/logo.png) no-repeat center center / contain;
	transform: translateX(-1.5265%);
	margin: 0 auto;
	overflow: hidden;
}
.header__backTo {
	height:60px;
	position: absolute;
	width:160px;
	top:-5px;
	right:20px;
}
.header__backToLink {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	text-decoration: none;
	color:#fff;
	font-size:18px;
	font-weight: 700;
	background:var(--color-green);
	border-radius: 0 0 24px 24px;
	height:60px;
	transition: all 0.3s ease;
}
@media screen and (hover:hover){
	.header__backToLink:hover {
		transform:translateY(5px);
	}
}
.header__backToLink:before {
	content:'';
	position: absolute;
	left:2px;
	right:2px;
	top:0;
	bottom:2px;
	box-sizing: border-box;
	border-bottom:2px solid #fff;
	border-left:2px solid #fff;
	border-right:2px solid #fff;
	border-radius: 0 0 22px 22px;
}
.calendar {
	position: relative;
	padding-top:50px;
	margin-bottom:28px;
}
.calendar__title {
	height: 61px;
	position: relative;
	z-index:500;
}
.calendar__titleLabel {
	height:61px;
	position: relative;
	display: block;
	background:url(../img/common/title.svg) no-repeat center center / contain;
	z-index:10;
}
.calendar__title:before {
	content:'';
	height:166px;
	width:166px;
	position: absolute;
	top:50%;
	left:50%;
	margin-left:-83px;
	margin-top:-83px;
	background: url(../img/common/top_circle.svg) no-repeat center center / contain;
}
.calendar__p1 {
	height:375px;
	width:100%;
	position: relative;
	padding-top:15px;
	margin-top:-42px;
	z-index:10;
}
.calendar__p1:before {
	content:'';
	position: absolute;
	left:0;
	right:0;
	bottom:0;
	width:375px;
	height:0;
	border-top:187.5px solid transparent;
	border-bottom:187.5px solid var(--color-green);
	border-left:187.5px solid transparent;
	border-right:187.5px solid transparent;
}
.calendar__p1:after {
	content:'';
	position: absolute;
	left:0;
	right:0;
	bottom:0;
	top:0;
	pointer-events: none;
	background:url(../img/common/p1_corner.svg) no-repeat center bottom / contain;
}
.calendar__p1-1 {
	width:590px;
	height:230px;
	display: block;
	background: url(../img/common/n/1.svg) no-repeat center center / contain;
	position: relative;
	margin:0 auto;
	transition: all 0.6s ease;
}
@media screen and (hover:hover){
	.calendar__p1-1:hover{
		transform: scale(1.05);
	}
}
.calendar__ptLists {
	margin:0 -12px;
	display: flex;
	justify-content: center;
	position: relative;
	z-index:560;
}
.calendar__ptItem {
	width:calc(100% / 5);
	padding:0 12px;
}
.calendar__pbLists {
	margin:0 -15px;
	display: flex;
	justify-content: center;
	position: relative;
	z-index:560;
}
.calendar__pbItem {
	padding:0 15px;
}
.calendar__pbItem:nth-child(odd){
	width:173px;
}
.calendar__pbItem:nth-child(even){
	width:131px;
}
.calendar__pt-s {
	display: block;
	transition:all 0.6s ease;
}
@media screen and (hover:hover){
	.calendar__pt-s:hover {
		transform:scale(1.05);
	}
}
.calendar__pt-s.is-soon {
	pointer-events: none;
}
.calendar__pt-s img {
	width:100%;
	height:auto;
}
.calendar__p2 {
	background:var(--color-green);
	padding-top:25px;
	margin-top:-1px;
	padding-bottom:66px;
	position: relative;
	z-index:5;
}
.calendar__p2:before {
	content:'';
	position: absolute;
	left:0;
	right:0;
	bottom:0;
	height:66px;
	background:url(../img/common/dotborder.svg) repeat-x left center / 100% auto;
}
.calendar__p3 {
	background:var(--color-green);
	margin-top:-1px;
	padding-top:1px;
	padding-bottom:72px;
	position: relative;
}
.calendar__p3:before {
	content:'';
	position: absolute;
	width:0;
	height:0;
	border-bottom:600px solid var(--color-green);
	border-left:600px solid transparent;
	border-right:600px solid transparent;
	border-top:unset;
	bottom:0;
	left:50%;
	margin-left: -600px;
}
.calendar__p3:after {
	content:'';
	position: absolute;
	left:0;
	right:0;
	bottom:0;
	height:72px;
	background:url(../img/common/dotborder.svg) repeat-x left center / 100% auto;
}
.footer {
	padding-bottom:30px;
}
.footer__startdate {
	height:115px;
	background:url(../img/common/startdate.png) no-repeat center center / contain;
	margin-bottom:24px;
}
@supports (background-image:url(../img/common/startdate.webp)){
	.footer__startdate {
		background-image:url(../img/common/startdate.webp);
	}
}
.footer__copyright {
	text-align: center;
	font-size:14px;
	font-weight: 700;
	text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
	-1px 1px 0 #FFF, 1px -1px 0 #FFF,
	0px 1px 0 #FFF,  0-1px 0 #FFF,
	-1px 0 0 #FFF, 1px 0 0 #FFF;
}
.modal {
	position: fixed;
	left:0;
	top:0;
	right:0;
	bottom:0;
	background:rgba(0,0,0,0.8);
	z-index:9999;
	display: none;
}
.modal__inner {
	position: absolute;
	left:0;
	top:0;
	right:0;
	bottom:0;
	overflow: auto;
	overscroll-behavior:contain;
}
.modal__content {
	min-height:100vh;
	min-height:100dvh;
	position: relative;
	z-index:50;
}
@media screen and (max-width:768px){
	.modal__content {
		min-height:calc(100vh + 1px);
		min-height:calc(100dvh + 1px);
		position: relative;
		z-index:50;
	}
}
.modal__close{
	position:absolute;
	left:0;
	top:0;
	right:0;
	bottom:0;
}
.modal__closeBtn{
	position:absolute;
	z-index:500;
	width:80px;
	height:80px;
	overflow:hidden;
	right:0;
	top:0;
	z-index:51;
	transition:all 0.6s ease;
}
.modal__closeBtnLink{
	display:block;
	width:100%;
	height:80px;
	background:var(--color-red);
}
.modal__closeBtnLink:before,
.modal__closeBtnLink:after{
	content:'';
	position:absolute;
	left:-100%;
	right:-100%;
	top:50%;
	height:1px;
	background:#FFF;
}
.modal__closeBtnLink:before{
	transform:rotate(45deg);
}
.modal__closeBtnLink:after{
	transform:rotate(-45deg);
}
.modal__inBlock {
	position: relative;
	pointer-events: none;
	min-height: 100vh;
	min-height:100dvh;
	padding:80px;
	width:100%;
	display:flex;
	justify-content:center;
	align-items:center;
	z-index:50;
}
@media screen and (max-width:768px){
	.modal__inBlock {
		padding:80px 0;
	}
}
.modal__movie {
	pointer-events: auto;
	position: absolute;
	left:80px;
	top:80px;
	bottom:80px;
	right:80px;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media screen and (max-width:768px){
	.modal__movie {
		left:0;
		right:0;
	}
}
.modal__movie iframe {
	display: block;
	width:min(calc(100vw - 160px),calc((100vh - 160px) * 1.77777));
	height:min(calc(100vh - 160px),calc((100vw - 160px) * 0.5625));;
}
@media screen and (max-width:768px){
	.modal__movie iframe {
		display: block;
		width:min(100vw,calc((100vh - 160px) * 1.77777));
		height:min(calc(100vh - 160px),calc(100vw * 0.5625));
	}
}
.modal__page {
	width:750px;
	padding:40px 30px 0;
	color:#fff;
	pointer-events: auto;
}
.modal__page h3 {
	font-size:30px;
	font-weight: 700;
	text-align: center;
	border-bottom:2px solid #fff;
	line-height:1.5;
	padding-bottom:0.75em;
	margin-bottom:40px;
}
.modal__page p {
	line-height:2;
	margin-bottom:2em;
}
.modal__page img {
	max-width:100%;
	height:auto;
}
.modal__pageBtn {
	width:75%;
	margin:0 auto;
	background:#000;
}
.modal__pageBtnLink {
	text-decoration: none;
	font-size:1.5rem;
	display:flex;
	justify-content: center;
	align-items: center;
	width:100%;
	height:3em;
	background:var(--color-red);
	color:#fff;
	transition:all 0.6s ease;
	border-radius: 4px
}
@media screen and (hover:hover){
	.modal__pageBtnLink:hover {
		opacity:0.7;
	}
}
.w90p {
	width:90%;
}
.w80p {
	width:80%;
}
.w70p {
	width:70%;
}
.w60p {
	width:60%;
}
.w50p {
	width:50%;
}
.aligncenter {
	margin-left:auto;
	margin-right:auto;
	text-align: center;
}