@charset "utf-8";
/* CSS Document */

html {
	font-size: 62.5%;
}
body {
	font-family: Arial, Helvetica, "メイリオ", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HiraKakuPro-W3", Osaka, "Meiryo", Sans-Serif;
	font-size: 1.6rem;
	color :#444444;
	line-height: 1;
	background-color :#FFFFFF;
}
html, body {
	width: 100%;
	height: 100%;
}
ul, li, dl, dt, dd {
	margin: 0;
	padding: 0;
}
ul {
	list-style: none;
}
a:focus, *:focus {
	outline: none;
}
a, a:visited {
	color: #444444;
	text-decoration: none;
}
main, header .inner {
	position: relative;
	width: 1080px;
	margin: 0 auto;
}

header {
	width: 100%;
	background-color: #FFFFFF;
	box-shadow: 0 2px 10px rgba(0,0,0,0.2);
	position: fixed;
	top: 0;
	z-index: 99;
}
header .inner {
	justify-content: space-between;
	align-items: center;
}
.header_logo {
	display: block;
	width: 210px;
	height: 46px;
}
.header_logo:hover, .footer_logo:hover {
	opacity: 0.6;
}
header nav {
	flex-direction: column;
	justify-content: space-between;
	height: 75px;
}
header nav ul:last-of-type {
	align-items: center;
}
header nav a {
	justify-content: center;
	align-items: center;
}
header nav a:hover {
	font-weight: 700;
	color: #FFFFFF;
	background-color: #1C5277;
}
.menu_01 {
	justify-content: flex-end;
}
.menu_01 li:first-of-type {
	margin-right: 2px;
}
.menu_01 a {
	width: 110px;
	height: 22px;
	font-size: 1.1rem;
	background-color: #E8E8E8;
}
.menu_02 a {
	height: 40px;
	font-size: 1.4rem;
	padding: 0 20px;
}
.hd_nav_hr {
	width: 1px;
	height: 16px;
	background-color: #444444;
}
header .inner, header ul, header nav, header nav a, footer ul, footer li {
	display: flex;
}
.header_logo, header nav a, .pagetop a, .footer_logo {
	transition: 0.2s ease-out;
}

footer {
	width: 100%;
	min-width: 1080px;
	text-align: center;
	background-color: #7C98AB;
	padding: 10px 0;
}
footer ul {
	justify-content: center;
}
footer li {
	align-items: center;
	height: 17px;
	border-right: 1px solid #FFFFFF;
	padding: 0 18px;
}
footer li:last-of-type {
	border-right: 0;
}
footer li a, footer li a:visited {
	color: #FFFFFF;
	font-size: 1.3rem;
}
footer li a:hover {
	text-decoration: underline;
}
.footer_logo {
	display: inline-block;
	margin: 40px 0;
}
.footer_logo img {
	display: inline-block;
	vertical-align: top;
}
footer p {
	color: #FFFFFF;
	font-size: 1.2rem;
}

.pagetop {
	display: none;
	position: fixed;
	width: 40px;
	height: 40px;
	bottom: 30px;
	right: 80px;
}
.pagetop a {
	display: block;
	width: 100%;
	height: 100%;
	font-size: 3rem;
	color: #FFFFFF;
	background-color: #444444;
	border-radius: 4px;
	padding: 5px;
	opacity: 0.75;
}
.pagetop a:hover {
	opacity: 0.5;
}
