/* CSS Document */

body {
	min-width: 1080px;
	max-width: 1920px;
	margin: auto;
}
.inner {
	max-width: 1200px;
	margin: auto;
	padding: 0 20px;
	box-sizing: border-box;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}



#header {
	width: 100%;
	max-width: 1920px;
	position: relative;
}
#header h1 {
	width: 67%;
	text-align: center;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50% , -50%);
}


#header nav.global {
	display: flex;
	align-items: center;
	gap: 20px;
	width: calc(100% - 300px - 80px);
	margin: 0 80px 0 0;
}
#header nav.global ul {
	display: flex;
	justify-content: flex-end;
	gap: 20px;
	position: fixed;
}
#header nav.global ul li {
	word-break: keep-all;
}
#header nav.global ul li a {
	padding: 5px;
}
#header nav.global ul li a:hover {
}

#header nav.popmenu {
	width: 40px;
	position: absolute;
	top: 20px;
	right: 20px;
}
#header nav.popmenu label.menuBtn {
	display: block;
	width: 40px;
	height: 40px;
	position: fixed;
	z-index: 99;
}
#header nav.popmenu label.menuBtn:before {
	content: url("../img/menu.svg");
}
#header nav.popmenu input:checked ~ .menuBtn:before {
	content: url("../img/menu_close.svg");
	z-index: 99;
	position: relative;
}
#header nav.popmenu input:checked ~ .menuBtn {
	color: #fff;
}
#header nav.popmenu label.menuBtn:hover {
	cursor: pointer;
	color: #fff;
}
#header nav.popmenu .menu {
	position: fixed;
	top: 0;
	right: 0;
	height: 0;
	width: 0;
	overflow: hidden;
	transition: all .4s;
	cursor: auto;
	z-index: 9;
	opacity: 0;
	background: rgba(0,0,0,.9);
}
#header nav.popmenu .menu .menuInner {
	padding: 40px;
}
#header nav.popmenu input {
	display: none;
}
#header nav.popmenu input:checked ~ .menu {
	box-sizing: border-box;
	height: 100vh;
	width: 100vw;
	opacity: 1;
	overflow: scroll;
}
#header nav.popmenu .menu .close {
	position: absolute;
	top: 20px;
	right: 20px;
	font-size: 3em;
	line-height: 1em;
	cursor: pointer;
}
#header nav.popmenu .menu .close:hover {
	color: #666;
}



#main {
}









#footer {
	text-align: center;
	background: #D3E8FC;
	padding: 30px 0 20px;
	margin: 200px 0 0;
	position: relative;
}
#footer h2 {
	line-height: 1.4;
	color: #1F355C;
	background: #fff;
	display: inline-block;
  padding: 2px 20px;
  border-radius: 40px;
}
#footer address {
	letter-spacing: 1px;
	margin: 10px 0;
}
#footer small {
	font-size: 80%;
	text-align: center;
	display: block;
	margin: 30px 0 0;
}



#footer .topBtnBox {
	width: 200px;
	position: absolute;
	bottom: 0;
	right: 0;
}
#footer .topBtnBox #topBtn {
	font-size: 90%;
	text-align: center;
	color: #fff;
	width: 200px;
	height: 45px;
	background: rgba(120, 146, 191, 0.5);
	/*mix-blend-mode: multiply;*/
	right: 20px;
	border-radius: 5px 5px 0 0;
	display: flex;
  justify-content: center;
  align-items: center;
	gap: 15px;
}
#footer .topBtnBox #topBtn::before {
	content: '';
	width: 5px;
	height: 20px;
	border: solid rgba(255,255,255,.8);
	border-width: 3px 0 0 2px;
	transform: skewY(45deg);
}
#footer .topBtnBox #topBtn:hover {
	opacity: 0.8 !important;
	cursor: pointer;
}





@media screen and (max-width: 480px) {

	body {
		min-width: initial;
		font-size: 14px; font-size: 1.4rem;
	}
	.inner { width: auto;}
	
	
	
	#header {
		overflow-x: clip;
	}
	#header img.bg {
		max-width: 150%;
		position: relative;
		left: -25%;
	}
	#header h1 {
		width: 100%;
	}
	
	
	#header .hd {
		min-width: auto;
		padding: 0 10px;
	}
	#header .hd ul.hdInfo {
		display: none;
	}
	#header nav.popmenu .menu .menuInner {
		padding: 80px 20px 20px;
	}
	
	
	
	#main {
	}
	#main section {
	}
	#main aside {
	}
	
  
	
	#footer {
		margin: 140px 0 0;
	}
	#footer small {
		font-size: 80%;
	}
	#footer .topBtnBox {
		width: 140px;
	}
	#footer .topBtnBox #topBtn {
		width: 140px;
		height: 40px;
		right: 5px;
		gap: 10px;
	}
	
}


