@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&family=Noto+Serif+JP:wght@400;500;700;900&display=swap');
/* CSS Document */
html{
	font-size: 10px;
	width: 100%;
	overflow-x: hidden;
}
body{
	font-family: "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	background-color: #fff;
	color: #000000;
	padding-top: 90px;
}
.font-serif{
	font-family: "Noto Serif JP", "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}
.font-medium{
	font-weight: 500;
}
.font-black{
	font-weight: 900;
}
/* ---------- common ---------- */
.sc-icon{
	width: 90px;
	margin: 20px auto 0;
}

.more a,.more > div{
	display: inline-block;
	position: relative;
	min-width: 280px;
	padding: 10px 15px;
	padding-right: 30px;
	box-sizing: border-box; 
	font-family: "Noto Serif JP", "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
	font-size: 16px;
	transition: ease 0.3s;
	text-align: left;
}
.more a:hover{
}
.more a span,.more > div p{
	color: #fff;
	position: relative;
	z-index: 2;
	letter-spacing: 1px;
}
.more a::before,.more > div::before{
	content: "";
	position: absolute;
	z-index: 2;
	width: 10px;
	height: 100%;
	top: 0;
	right: 15px;
	background-image: url("img/arrow1.png");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: 100% auto;
	transition: ease 0.3s;
}
.more a:hover::before,.more > div:hover::before{
	right: 12px;
}
.more a::after,.more > div::after{
	content: "";
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-color: #8E1728;
	mix-blend-mode: multiply;
	transition: ease 0.3s;
}
.more a:hover::after,.more > div:hover::after{
	opacity: 0.7;
}
.more1 a::after{
}
.more2 a{
	background-color: #b9b9b9;
}

#page-top{
	transition: ease 0.3s;
	cursor: pointer;
}
#page-top:hover{
	opacity: 0.5;
	transform: translateY(-3px);
}
/* ---------- footer ---------- */
footer{
	position: relative;
	background-color: #8E1728;
}
footer.index{
	background-color: #fff;
}
footer #footer > div{
	padding: 80px 50px;
}
footer #footer .left-box h2{
	width: 60%;
	max-width: 300px;
}
footer #footer .right-box{
	position: relative;
}
footer #footer .right-box > p{
	color: #fff;
}
footer.index #footer .right-box > p{
	color: #000;
}
footer #footer .right-box nav ul li:not(:last-of-type){
	margin-bottom: 10px;
}
footer #footer .right-box nav ul li a{
	position: relative;
	display: inline-block;
	padding-left: 30px;
	transition: ease 0.3s;
	color: #fff;
}
footer.index #footer .right-box nav ul li a{
	color: #000;
}
footer #footer .right-box nav ul li a:hover{
	opacity: 0.5;
}
footer #footer .right-box nav ul li a::after{
	content: "＞";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	transition: ease 0.3s;
}
footer #footer .right-box nav ul li a:hover::after{
	transform: translateY(-50%) translateX(3px);
}
footer #copyright{
	position: absolute;
	width: 100%;
	left: 0;
	bottom: 0;
	text-align: right;
	box-sizing: border-box;
	padding: 10px 50px;
	color: #fff;
}
footer.index #copyright{
	color: #000;
}
/* ---------- header ---------- */
header{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 99;
	background-color: #000;
}
header #header h1{
	width: 20%;
	max-width: 270px;
}
header #header h1 a{
	display: block;
	transition: ease 0.3s;
}
header #header h1 a:hover{
	opacity: 0.5;
}
header #header{
	width: 100%;
	height: 90px;
	box-sizing: border-box;
	padding-left: 20px;
	padding-right: 110px;
}
header #header nav ul{
	gap: 20px;
}
header #header nav ul li{
	font-size: 0.8vw;
	position: relative;
	padding-right: 20px;
	font-family: "Noto Serif JP", "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}
header #header nav ul li:not(:last-of-type)::after{
	content: "";
	position: absolute;
	width: 1px;
	height: 100%;
	top: 0;
	right: 0;
	background-color: #fff;
}
header #header nav ul li a{
	color: #fff;
	display: inline-block;
	transition: ease 0.3s;
}
header #header nav ul li a:hover{
	opacity: 0.5;
}


#menu-bt{
	position: fixed;
	z-index: 999;
	width: 90px;
	height: 90px;
	top: 0;
	right: 0;
	background-color: #8E1728;
	cursor: pointer;
}
#menu-bt span{
	background-color: #fff;
	width: 60%;
	height: 1px;
	position: absolute;
	left: 50%;
	top: 50%;
	transition: ease 0.3s;
}
#menu-bt span:nth-of-type(1){
	transform: translate(-50%,-22px);
}
#menu-bt span:nth-of-type(2){
	transform: translate(-50%,-50%);
}
#menu-bt span:nth-of-type(3){
	transform: translate(-50%,21px);
}
#menu-bt.active span:nth-of-type(1){
	transform: translate(-50%,-50%) rotate(45deg);
}
#menu-bt.active span:nth-of-type(2){
	transform: translate(50%,-50%);
	opacity: 0;
}
#menu-bt.active span:nth-of-type(3){
	transform: translate(-50%,-50%) rotate(-45deg);
}
#menu-wrap{
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 998;
}
#menu-wrap::after{
	content: "";
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-color: #8E1728;
	mix-blend-mode: multiply;
	opacity: 0.9;
}
#menu-wrap nav{
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 3;
}
#menu-wrap nav ul{
	width: 90%;
	max-width: 1000px;
	gap: 30px;
}
#menu-wrap nav ul li{
	width: calc(100% / 3 - 20px);
}
#menu-wrap nav ul li:not(:last-of-type){
	margin-bottom: 10px;
}
#menu-wrap nav ul li a{
	position: relative;
	display: inline-block;
	padding-left: 30px;
	transition: ease 0.3s;
	color: #fff;
	font-size: 18px;
}
#menu-wrap nav ul li a:hover{
	opacity: 0.5;
}
#menu-wrap nav ul li a::after{
	content: "＞";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	transition: ease 0.3s;
}
#menu-wrap nav ul li a:hover::after{
	transform: translateY(-50%) translateX(3px);
}

/* ANIME */
.sc-anime.topin.on{
	opacity:0;
	transform: translateY(-50px);
}
.sc-anime.topin.on.active{
	animation-name: topin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.bottomin.on{
	opacity:0;
	transform: translateY(50px);
}
.sc-anime.bottomin.on.active{
	animation-name: bottomin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.leftin.on{
	opacity:0;
	transform: translateX(-50px);
}
.sc-anime.leftin.on.active{
	animation-name: leftin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.rightin.on{
	opacity:0;
	transform: translateX(50px);
}
.sc-anime.rightin.on.active{
	animation-name: rightin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
.sc-anime.fadein.on{
	opacity:0;
}
.sc-anime.fadein.on.active{
	animation-name: fadein;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}

@keyframes topin {
	0% {
		opacity:0;
		transform: translateY(-50px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
	}
}
@keyframes bottomin {
	0% {
		opacity:0;
		transform: translateY(50px);
	}
	100% {
		opacity:1;
		transform: translateY(0px);
	}
}
@keyframes leftin {
	0% {
		opacity:0;
		transform: translateX(-50px);
	}
	100% {
		opacity:1;
		transform: translateX(0px);
	}
}
@keyframes rightin {
	0% {
		opacity:0;
		transform: translateX(50px);
	}
	100% {
		opacity:1;
		transform: translateX(0px);
	}
}
@keyframes upin {
	0% {
		transform: translateY(100%);
	}
	100% {
		transform: translateY(0);
	}
}
@keyframes fadein {
	0% {
		opacity:0;
	}
	100% {
		opacity:1;
	}
}

/* color */
.txt-color-normal{color: #000000;}
.txt-white{color: #ffffff;}
.txt-red{color: red;}
.txt-color1{color: #8E1728}
.txt-color2{color: #F1F1E9}
.txt-color3{color: #021745}
.txt-color4{color: #EBF5E5}
.bg-white{background-color: #ffffff;}
.bg-black{background-color: black}
.bg-color1{background-color: #8E1728}
.bg-color1-2{
	background-color: #8E1728;
	mix-blend-mode: multiply;
}
.bg-color2{background-color: #F1F1E9}
.bg-color3{background-color: #021745}
.bg-color4{background-color: #EBF5E5}
.border-color1{border-color: #8E1728}
.border-color2{border-color: #F1F1E9}
.border-color3{border-color: #021745}
.border-color4{border-color: #EBF5E5}

.hvr-txt-color-normal:hover{color: #000000;}
.hvr-txt-white:hover{color: #ffffff;}
.hvr-txt-red:hover{color: red;}
.hvr-txt-color1:hover{color: #8E1728}
.hvr-txt-color2:hover{color: #F1F1E9}
.hvr-txt-color3:hover{color: #021745}
.hvr-txt-color4:hover{color: #EBF5E5} 
.hvr-bg-white:hover{background-color: #ffffff;}
.hvr-bg-black:hover{background-color: black}
.hvr-bg-color1:hover{background-color: #8E1728}
.hvr-bg-color2:hover{background-color: #F1F1E9}
.hvr-bg-color3:hover{background-color: #021745}
.hvr-bg-color4:hover{background-color: #EBF5E5}
.hvr-border-color1:hover{border-color: #8E1728}
.hvr-border-color2:hover{border-color: #F1F1E9}
.hvr-border-color3:hover{border-color: #021745}
.hvr-border-color4:hover{border-color: #EBF5E5}

/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
	header #header nav ul li{
		margin-right: 20px;
	}
}

/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
	body{
		padding-top: 70px;
	}
/* ---------- common ---------- */
	.sc-icon{
		width: 80px;
		margin: 20px auto 0;
	}

/* ---------- footer ---------- */

/* ---------- header ---------- */
	header #header{
		padding-right: 70px;
		height: 70px;
	}
	header #header h1{
		width: 19%;
	}
	header #header nav ul{
		gap: 5px;
	}
	header #header nav ul li{
		padding-right: 10px;
	}
	
	#menu-bt{
		width: 70px;
		height: 70px;
	}
	#menu-bt span:nth-of-type(1){
		transform: translate(-50%,-16px);
	}
	#menu-bt span:nth-of-type(2){
		transform: translate(-50%,-50%);
	}
	#menu-bt span:nth-of-type(3){
		transform: translate(-50%,15px);
	}
}
/* ---------- 1000px ~ ---------- */
@media screen and (max-width: 1000px){
/* ---------- common ---------- */

/* ---------- footer ---------- */

/* ---------- header ---------- */
	header #header h1{
		width: 25%;
	}
	header #header nav{
		display: none;
	}
	
	#menu-wrap nav ul li a{
		font-size: 16px;
	}
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
/* ---------- common ---------- */
	.sc-icon{
		width: 80px;
		margin: 20px auto 0;
	}

/* ---------- footer ---------- */
	footer #footer > div{
		padding: 50px 30px 80px;
	}
	footer #footer .right-box nav ul li a{
		font-size: 14px;
	}

/* ---------- header ---------- */
	header #header h1{
		width: 30%;
	}
}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
	body{
		padding-top: 50px;
	}
/* ---------- common ---------- */
	.sc-icon{
		width: 60px;
		margin: 20px auto 0;
	}
	.more a,.more > div{
		min-width: 240px;
		padding: 10px 10px;
		padding-right: 20px;
		font-size: 14px;
	}

/* ---------- footer ---------- */
	footer #footer > div{
		padding: 50px 30px 80px;
	}
	footer #footer .right-box{
		display: none;
	}
	
	footer #copyright{
		color: #fff;
		font-size: 12px;
		text-align: center;
		padding: 10px;
	}
	footer.index #copyright{
		color: #fff;
	}

/* ---------- header ---------- */
	header #header h1{
		width: 60%;
	}
	#menu-wrap nav ul{
		gap: 15px;
	}
	#menu-wrap nav ul li{
		width: 100%;
	}
	header #header{
		padding-right: 50px;
		height: 50px;
	}
	#menu-bt{
		width: 50px;
		height: 50px;
	}
	#menu-bt span:nth-of-type(1){
		transform: translate(-50%,-11px);
	}
	#menu-bt span:nth-of-type(2){
		transform: translate(-50%,-50%);
	}
	#menu-bt span:nth-of-type(3){
		transform: translate(-50%,10px);
	}
}