@charset "UTF-8";  

@media screen and (min-width: 769px) {

#fadeLayer {
	position: fixed;
    width: 100%;
	height: calc(100% - 80px);
    margin: 80px auto 0;
	background: rgba(0, 0, 0, 0.5);
	top: 0;
	left: 0;
	display: none;
	z-index: 40;
	-webkit-transition: .2s ease-in-out;
	-moz-transition: .2s ease-in-out;
	transition: .2s ease-in-out;
}
#fadeLayer.visible {
	display: block;
}
div.menu {
	width: 91px;
	margin: 0;
	padding: 0;
}
div.menu span.btn {
	display: block;
	width: 91px;
	height: 80px;
	margin: auto;
	background: #142f38;
	position: relative;
	cursor: pointer;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
}
	div.menu span.btn:before,
	div.menu span.btn:after,
	div.menu span.btn span {
		display: block;
		width: 32px;
		height: 4px;
		background-color: #fff;
		border-radius: 2px;
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
	}
	div.menu span.btn span {
		top: calc(50% - 2px);
	}

	div.menu span.btn:before {
		content: "";
		top: calc(35% - 2px);
	}
	div.menu span.btn:after {
		content: "";
		bottom: calc(35% - 2px);
	}
	div.menu span.btn.on span {
		width: 0;
	}

	div.menu span.btn.on:before {
		top: calc(50% - 2px);
		-webkit-transform: rotate(315deg);
		-moz-transform: rotate(315deg);
		transform: rotate(315deg);
	}
	div.menu span.btn.on:after {
		bottom: calc(50% - 2px);
		-webkit-transform: rotate(-315deg);
		-moz-transform: rotate(-315deg);
		transform: rotate(-315deg);
	}

ul.ul_open_h {
	position: fixed;
	width: 100%;
	min-width: 1080px;
	height: calc(100% - 80px);
	background: #d2273a;
	color: #fff;
	margin: 80px 0 0;
	padding: 8% 5% 0;
	display: flex;
	justify-content: flex-end;
	align-items: flex-start;
	list-style: none;
	overflow: hidden;
	top: 0;
	-webkit-transition:all 200ms cubic-bezier(0.75, 0, 0.175, 1);
	-moz-transition:all 200ms cubic-bezier(0.75, 0, 0.175, 1);
	-o-transition:all 200ms cubic-bezier(0.75, 0, 0.175, 1);
	transition:all 200ms cubic-bezier(0.75, 0, 0.175, 1);
	overflow-y: scroll;
	z-index: 45;
}
	ul.ul_open_h::-webkit-scrollbar {
		width: 0;
	}
	/*スクロールバーの軌道*/
	ul.ul_open_h::-webkit-scrollbar-track {
		border-radius: 10px;
		box-shadow: inset 0 0 6px rgba(0, 0, 0, .1);
	}
	/*スクロールバーの動く部分*/
	ul.ul_open_h::-webkit-scrollbar-thumb {
		background-color: rgba(0, 0, 50, .5);
		border-radius: 10px;
		box-shadow:0 0 0 1px rgba(255, 255, 255, .3);
	}
	ul.ul_open_h .slide_bg {
		position: absolute;
		content: '';
		display: block;
		margin: 0;
		padding: 0;
	}
		ul.ul_open_h .slide_bg.bg_1 {
			width: 633px;
			height: auto;
			top: 8%;
			right: calc(50% + 100px);
			animation: rotation2 50s linear infinite;
		}
		ul.ul_open_h .slide_bg.bg_2 {
			width: 266px;
			height: auto;
			top: 15%;
			right: calc(50% - 300px);
			animation: rotation3 30s linear infinite;
		}
		ul.ul_open_h .slide_bg.bg_3 {
			width: 356px;
			height: auto;
			top: 50%;
			right: calc(50% - 700px);
			animation: rotation2 40s linear infinite;
		}

.ul_open_h div.nav_cont {
	width: 40%;
	max-width: 540px;
	margin: 0;
	padding: 0;
	text-align: left;
	position: relative;
	z-index: 1;
}
	.ul_open_h div.nav_cont li {
		width: 100%;
		margin: 0;
		padding: 0;
		text-align: left;
	}
		.ul_open_h div.nav_cont li a {
			margin: 0;
			padding: 10px 20px;
			color: #fff !important;
			text-decoration: none;
			white-space: nowrap;
			display: flex;
			align-items: center;
			transition: 0.2s linear;
		}
			.ul_open_h div.nav_cont li.sub a {
				margin-left: 20px;
				flex-direction: column;
				align-items: flex-start;
			}
			.ul_open_h div.nav_cont li a:hover {
				opacity: 0.7;
			}
			.ul_open_h div.nav_cont li a p {
				margin: 0 1em 0 0;
				padding: 0;
				font-size: 28px;
				line-height: 160%;
				font-family: "Reddit Sans Condensed", system-ui;
				font-optical-sizing: auto;
				font-weight: var(--main-font-extrabold);
			}
			.ul_open_h div.nav_cont li a span {
				margin: 0;
				padding: 0;
				font-size: 16px;
				line-height: 200%;
				font-weight: var(--main-font-bold2);
			}
	.ul_open_h div.nav_cont div.slide_nav_btn {
		width: 70%;
		min-width: 370px;
		margin: 10px 0 0 20px;
	}
		.ul_open_h div.nav_cont div.slide_nav_btn a {
			display: block;
			width: 100%;
			margin: 0;
			padding: 10px 50px;
			color: #000;
			background: #fff;
			text-align: center;
			text-decoration: none;
			border-radius: 0 10px;
			transition: 0.2s linear;
			position: relative;
		}
			.ul_open_h div.nav_cont div.slide_nav_btn a:after {
				position: absolute;
				display: block;
				content: '';
				width: 10px;
				height: 15px;
				margin: auto;
				padding: 0;
				background: url(../images/icon/arrow_02.png) center / contain no-repeat;
				top: 50%;
				right: 20px;
				transform: translateY(-50%);
				-webkit- transform: translateY(-50%);
				transition: 0.2s linear;
			}
			.ul_open_h div.nav_cont div.slide_nav_btn a:hover {
				opacity: 0.85;
			}
				.ul_open_h div.nav_cont div.slide_nav_btn a:hover:after {
					right: 15px;
				}
			.ul_open_h div.nav_cont div.slide_nav_btn a p {
				margin: 0 auto;
				padding: 0;
				font-size: 28px;
				line-height: 160%;
				font-family: "Reddit Sans Condensed", system-ui;
				font-optical-sizing: auto;
				font-weight: var(--main-font-extrabold);
			}
			.ul_open_h div.nav_cont div.slide_nav_btn a span {
				display: block;
				margin: 0 auto;
				padding: 0;
				font-size: 16px;
				line-height: 200%;
				font-weight: var(--main-font-bold2);
			}

}


@media screen and (max-width: 768px) {

#fadeLayer {
	position: fixed;
    width: 100%;
	height: calc(100% - 3em);
    margin: 3em auto 0;
	background: rgba(0, 0, 0, 0.5);
	top: 0;
	left: 0;
	display: none;
	z-index: 50;
	-webkit-transition: .2s ease-in-out;
	-moz-transition: .2s ease-in-out;
	transition: .2s ease-in-out;
}
#fadeLayer.visible {
	display: block;
}
div.menu {
	width: 100%;
	margin: 0;
	padding: 0;
}
div.menu span.btn {
	display: block;
	width: 100%;
	height: 3.0em;
	margin: auto;
	background: #142f38;
	position: relative;
	cursor: pointer;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
}
	div.menu span.btn:before,
	div.menu span.btn:after,
	div.menu span.btn span {
		display: block;
		width: 45%;
		height: 2px;
		background-color: #fff;
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
	}
	div.menu span.btn span {
		top: calc(50% - 1px);
	}

	div.menu span.btn:before {
		content: "";
		top: calc(30% - 1px);
	}
	div.menu span.btn:after {
		content: "";
		bottom: calc(30% - 1px);
	}
	div.menu span.btn.on span {
		width: 0;
	}

	div.menu span.btn.on:before {
		top: calc(50% - 1px);
		-webkit-transform: rotate(315deg);
		-moz-transform: rotate(315deg);
		transform: rotate(315deg);
	}
	div.menu span.btn.on:after {
		bottom: calc(50% - 1px);
		-webkit-transform: rotate(-315deg);
		-moz-transform: rotate(-315deg);
		transform: rotate(-315deg);
	}

ul.ul_open_h {
	position: fixed;
	width: 100%;
	height: 100%;
	background: #d2273a;
	color: #fff;
	margin: 0 0 0;
	padding: 4.0em 2% 0;
	list-style: none;
	overflow: hidden;
	top: 0;
	-webkit-transition:all 300ms cubic-bezier(0.75, 0, 0.175, 1);
	-moz-transition:all 300ms cubic-bezier(0.75, 0, 0.175, 1);
	-o-transition:all 300ms cubic-bezier(0.75, 0, 0.175, 1);
	transition:all 300ms cubic-bezier(0.75, 0, 0.175, 1);
	overflow-y: scroll;
	z-index: 80;
}
	ul.ul_open_h::-webkit-scrollbar {
		width: 0;
	}
	/*スクロールバーの軌道*/
	ul.ul_open_h::-webkit-scrollbar-track {
		border-radius: 10px;
		box-shadow: inset 0 0 6px rgba(0, 0, 0, .1);
	}
	/*スクロールバーの動く部分*/
	ul.ul_open_h::-webkit-scrollbar-thumb {
		background-color: rgba(0, 0, 50, .5);
		border-radius: 10px;
		box-shadow:0 0 0 1px rgba(255, 255, 255, .3);
	}

	ul.ul_open_h .slide_bg {
		position: absolute;
		content: '';
		display: block;
		margin: 0;
		padding: 0;
	}
		ul.ul_open_h .slide_bg.bg_1 {
			display: none;
		}
		ul.ul_open_h .slide_bg.bg_2 {
			width: 40%;
			height: auto;
			top: 5%;
			left: 3%;
		}
		ul.ul_open_h .slide_bg.bg_3 {
			width: 55%;
			height: auto;
			top: 50%;
			right: 5%;
		}

.ul_open_h div.nav_cont {
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: left;
	position: relative;
	z-index: 1;
}
	.ul_open_h div.nav_cont li {
		width: 100%;
		margin: 0;
		padding: 0;
	}
		.ul_open_h div.nav_cont li a {
			margin: 0;
			padding: 0.2em 5%;
			color: #fff !important;
			text-decoration: none;
			white-space: nowrap;
			display: flex;
			align-items: center;
		}
			.ul_open_h div.nav_cont li.sub a {
				margin-left: 1em;
				flex-direction: column;
				align-items: flex-start;
			}
			.ul_open_h div.nav_cont li a p {
				margin: 0 1em 0 0;
				padding: 0;
				font-size: 5.4vw;
				line-height: 160%;
				font-family: "Reddit Sans Condensed", system-ui;
				font-optical-sizing: auto;
				font-weight: var(--main-font-extrabold);
			}
			.ul_open_h div.nav_cont li a span {
				margin: 0;
				padding: 0;
				font-size: 3.2vw;
				line-height: 200%;
				font-weight: var(--main-font-bold2);
			}
	.ul_open_h div.nav_cont div.slide_nav_btn {
		width: 100%;
		margin: 0.5em 0 0;
	}
		.ul_open_h div.nav_cont div.slide_nav_btn a {
			display: block;
			width: 90%;
			margin: 0 auto;
			padding: 2% 5%;
			color: #000;
			background: #fff;
			text-align: center;
			text-decoration: none;
			border-radius: 3px;
			position: relative;
		}
			.ul_open_h div.nav_cont div.slide_nav_btn a:after {
				position: absolute;
				display: block;
				content: '';
				width: 0.6em;
				height: 0.9em;
				margin: auto;
				padding: 0;
				background: url(../images/icon/arrow_02.png) center / contain no-repeat;
				top: 50%;
				right: 5%;
				transform: translateY(-50%);
				-webkit- transform: translateY(-50%);
				transition: 0.2s linear;
			}
			.ul_open_h div.nav_cont div.slide_nav_btn a p {
				margin: 0 auto;
				padding: 0;
				font-size: 5.4vw;
				line-height: 160%;
				font-family: "Reddit Sans Condensed", system-ui;
				font-optical-sizing: auto;
				font-weight: var(--main-font-extrabold);
			}
			.ul_open_h div.nav_cont div.slide_nav_btn a span {
				display: block;
				margin: 0 auto;
				padding: 0;
				font-size: 3.2vw;
				line-height: 200%;
				font-weight: var(--main-font-bold2);
			}
}

ul.open-1 {
    right : -100%;
	opacity: 0;
	-webkit-transition: .4s ease-in-out;
	-moz-transition: .4s ease-in-out;
	transition: .4s ease-in-out;
}
	ul.open-1.active {
		right : 0px;
		opacity: 1;
		-webkit-transition: .4s ease-in-out;
		-moz-transition: .4s ease-in-out;
		transition: .4s ease-in-out;
	}


