@charset "utf-8";

/*--------------------
common
--------------------*/
:root{
	--max-wrap: 1880px;
	--wide-wrap: 1080px;
	--wide-wrap-mid: 90%;
	--wide-wrap-small: 92%;
	--normal-wrap: 1070px;
	--normal-wrap-mid: 80%;
	--narrow-wrap: 960px;
	--narrow-wrap-mid: 75%;
	--narrow-wrap-small:92%;
	--txt-color: #4d4d4d;
	--base-color: #eee;
	--nav-padding:15px;
	--base-padding: 0px;
	--base-top-margin: 145px;
	--base-fontsize: 18px;
	@media (width <=1121px) {
		--nav-padding: 8px;
		--base-padding:70px;
	}
	@media (min-width: 320px)
	and (max-width: 767px) {
		--nav-padding: 20px;
		--base-padding: 6%;
	}
}


/* for List font */
@font-face {
	font-family: 'icomoon';
	src: url('../fonts/icomoon.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

[class^="icon-"], [class*=" icon-"] {
	font-family: 'icomoon';
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	line-height: 1;

	/* Better Font Rendering =========== */
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.icon-arrow-down2:before {
	content: "\e900";
}


body{
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	-webkit-font-smoothing: antialiased;
	font-size: var(--base-fontsize);
	background-color: var(--base-color) ;
}
*{
	margin:0;
	padding:0;
}
.montserrat{
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
}

.sp-on{
	display:none !important;
}
.sp-off{
	display: inline !important;;
}
.sm-on{
	display: none;
}
.sm-off{
	display: inline;
}

/* Changes Map Show */
.pc-show{
	display:block !important;
}
.pc-mid-show{
	display:none !important;
}
.sp-show{
	display:none !important;
}

/* old css */
#contents{
	position: relative;
	display: block;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto 150px;
	color:var(--txt-color);
	background: var(--base-color);
	z-index: 1;
}


/* ----------
scroll down arron */
div#scrolldown{
	display: block;
	position: absolute;
	bottom: 20%;
	left: 0;
	right: 0;
	width: 100px;
	height: 50px;
	margin: 0 auto;
	color: var(--txt-color);
	font-weight: 500;
	text-align: center;
	opacity:0;
}
div#scrolldown .down-arrow{
	font-size: 1.7em;
	line-height: 1.7em;
}


/* new css */
.wrapper{
	position: relative;
	width:100%;
	height: 100%;
	padding-bottom:120px;
	overflow:hidden;
	background: var(--base-color);
	color:var(--txt-color);
}


/* next button */
.next-page{
	position: relative;
	max-width: 380px;
	width: 100%;
	margin: 0 auto;
}
.next-page a{
	display: flex;
	width: 100%;
	height: 100%;
	transition: 0.3s;
}

.next-page a:hover{
	background: var(--txt-color);
	color: var(--base-color);
}
.next-page a:hover img{
	filter:invert(100%);
}


/* News External Link */
.news-external{
	margin-bottom: 4em;
}
.external-link a{
	display:block;
	width: 350px;
	height: 30px;
	font-size: 0.78em;
	text-decoration: none;
	color:#fff;
	background: #999;
	border-radius: 10px;
	text-align:center;
	padding-left: 1.3em;
	padding-right: 1.3em;
	padding-top: 6px;
	margin: 1em auto;
}
.external-link a:hover{
	color:#333;
	background: #ccc;
}

/* ----------------------
  PC版 1300px 以下
---------------------- */
@media (width <=1300px) {
	.pc-mid-on{
		display: inline !important;
	}
}
/* -------------------
  iPhone <767
------------------- */
@media (width <=767px) {

	/* Changes Map Show (iPhone <=767)  */
	.pc-show{
		display:none !important;
	}
	.pc-mid-show{
		display:block !important;
	}
	.sp-show{
		display:none !important;
	}
	.sp-on{
		display: inline !important;
	}
	.sp-off{
		display: none !important;
	}
	
	.sm-on{
		display:inline;
	}
	.sm-off{
		display: none;
	}

}
/* -------------------
  iPhone Setting
------------------- */
@media (min-width: 320px)
and (max-width: 499px) {
	.sp-on{
		display: inline !important;
	}
	.sp-off{
		display: none !important;
	}
	
	.sm-on{
		display:inline;
	}
	.sm-off{
		display: none;
	}
	
	/* Changes Map Show (iPhone)  */
	.pc-show{
		display:none !important;
	}
	.pc-mid-show{
		display:none !important;
	}
	.sp-show{
		display:block !important;
	}

	
	.next-page{
		max-width: 250px;	
	}
	.next-page a{
		font-size:40px;
	}
	.next-page a::after{
		right: 45px;
	}

}