@charset "utf-8";

/*=======*/
/* ヘッダ */
/*=======*/
header {
	position: fixed;
	width: 100%;
	background: #FFF;
	z-index: 50;
}

header .inner {
	position: relative;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	width: 1200px;
	margin: 0 auto;
	padding: 0 10px 28px;
}

header .h-logo {
	width: 155px;
	padding-top: 28px;
}

header .h-logo a {
	display: block;
}

header .utility-wrap {
	width: 980px;
}

header .menu {
	display: none;
}

header .nv-wrap {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}

header .g-nv ul {
	display: flex;
}

header .g-nv li {
	margin-right: 25px;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: .15em;
}

header .g-nv li:last-child {
	margin-right: 0;
}

header .g-nv li a {
	position: relative;
	display: block;
	padding-bottom: 12px;
	color: #025C90;
	text-decoration: none;
}

header .g-nv li a:hover {
	color: #0096AE;
}

header .g-nv li a::after {
	content: "";
	position: absolute;
	bottom: 2px;
	left: 0;
	width: 100%;
	height: 1px;
	background: #0096AE;
	opacity: 0;
}

header .g-nv li a:hover::after {
	-webkit-animation: scale-in-center 1s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
	animation: scale-in-center 1s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}

@-webkit-keyframes scale-in-center {
0% {
	-webkit-transform: scale(0);
			transform: scale(0);
	opacity: 1;
}
100% {
	-webkit-transform: scale(1);
			transform: scale(1);
	opacity: 1;
}
}
@keyframes scale-in-center {
0% {
	-webkit-transform: scale(0);
			transform: scale(0);
	opacity: 1;
}
100% {
	-webkit-transform: scale(1);
			transform: scale(1);
	opacity: 1;
}
}
header .sub-menu {
	position: absolute;
	top: 0;
	right: 40px;
	width: 277px;
	display: flex;
	justify-content: space-between;
}

header .site-search {
	padding: 0 30px 8px 0;
}

header .site-search form {
	position: relative;
	width: 180px;
	height: 22px;
	padding: 0 5px;
	border: solid 1px #B8B8B8;
	background: #FFF;
	overflow: hidden;
}

header .site-search input[type="text"] {
	padding: 0;
	border: none;
	background: #FFF;
	height: 20px;
	font-size: 10px;
}

header .site-search input[type="text"]:focus {
	outline: 0;
}

header .site-search input[type="image"] {
	position: absolute;
	top: 2px;
	right: 5px;
}

header .site-lang {
	width: 74px;
    /* display: none; */
}

header .site-lang ul {
	display: flex;
	justify-content: space-between;
}

header .site-lang li {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .15em;
}

header .site-lang a {
	display: block;
	padding: 14px 8px 14px;
	color: #025C90;
	text-decoration: none;
}

header .site-lang a:hover {
	color: #009DAC;
}

header .site-lang .active {
	background: #009DAC;
	color: #FFF;
}

header .site-lang .active:hover {
	color: #FFF;
}

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

	header .inner {
		display: block;
		width: 100%;
		margin: 0 auto;
		padding: 10px 0 10px 22.5px;
	}

	header .h-logo {
		width: 111px;
		padding-top: 0;
	}

	header .h-logo img {
		height: 35px;
	}

	header .utility-wrap {
		position: absolute;
		top: 0;
		right: 0;
		width: 100%;
	}

	header .navi-wrap {
		position: absolute;
		top: 0;
		right: -100%;
		display: block;
		width: 100%;
		transition: all .5s;
	}

	header .navi-wrap .menu.open {
		left: 0;
		right: auto;
	}

	header .navi-wrap.open {
		right: 0;
	}

	header .nv-wrap {
		display: block;
		width: calc(100% - 55px);
		margin: 0 0 0 auto;
		background: #E8F0F5;
	}

	header .g-nv ul {
		display: block;
	}

	header .g-nv li {
		margin-right: 0;
		border-bottom: solid 1px #FFF;
		font-size: 15px;
		letter-spacing: .2em;
	}

	header .g-nv li a {
		padding: 16px 35px;
	}

	header .g-nv li a:hover {
		color: #FFF;
		background: #0096AE;
	}

	header .g-nv li a:hover::after {
		content: "";
		position: static;
		bottom: auto;
		left: auto;
		width: auto;
		height: auto;
		background: none;
	}

	header .sub-menu {
		position: unset;
		width: auto;
		display: block;
	}

	header .site-search {
		padding: 16px 35px;
	}

	header .site-search form {
		width: 100%;
		height: 35px;
	}

	header .site-search input[type="text"] {
		padding: 0;
		border: none;
		background: #FFF;
		height: 33px;
		font-size: 12px;
	}

	header .site-search input[type="image"] {
		position: absolute;
		top: 7px;
		right: 10px;
		height: 20px;
	}

	header .site-lang {
		display: none;
	}

	header .menu {
		display: block;
		position: absolute;
		width: 55px;
		height: 55px;
		top: 0;
		right: 0;
		background: #FFF;
		transition: all .5s;
	}

	header .menu .menu-inner {
		position: relative;
		margin: 18px auto 0;
		width: 24px;
	}

	header .menu .menu-inner span {
		position: absolute;
		left: 0px;
		display: block;
		width: 100%;
		height: 1px;
		background: #025C90;
		transition: all .5s;
	}

	header .menu .menu-inner span:first-child {
		top: 0;
	}

	header .menu .menu-inner span:nth-child(2) {
		top: 9px;
	}

	header .menu .menu-inner span:last-child {
		top: 18px;
	}

	header .menu.open .menu-inner span:first-child {
		top: 9px;
		transform: rotate(45deg);
	}

	header .menu.open .menu-inner span:last-child {
		top: 9px;
		transform: rotate(-45deg);
	}

	header .menu.open .menu-inner span:nth-child(2) {
		opacity: 0;
	}
}

header .mf-search-box {
	text-align: center;
}

header .mf-search-box .mf-search-bar {
	position: relative;
	display: inline-block;
}

header .mf-search-box .mf-search-bar .mf-search-bar_input-wrapper {
	padding: 3px 2px 0;
	width: 170px;
	height: 30px;
	position: relative;
	background: #FFF;
	border: solid 1px #B8B8B8;
	overflow: hidden;
	margin: 10px 3px 8px 0;
	flex-grow: unset;
}

header .mf-search-box .mf-search-bar .mf-search-bar_input {
	border: unset !important;
	border-radius: unset !important;
	font-size: 14px;
	background-color: #fff;
	padding: 0;
	height: 25px;
}

header .mf-search-box .mf-search-bar .mf-search-bar_button {
	display: block;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	white-space: nowrap;
	border-radius: unset;
	background-color: unset;
	border: none;
	cursor: pointer;
	width: 25px;
	height: 25px;
	position: absolute;
	top: 14px;
	right: 2px;
	background-image: url(../svg/com_ic01.svg);
	background-repeat: no-repeat;
	background-size: 15px auto;
	background-position: center;
}

header .mf-search-box .mf-search-bar .mf-search-bar_button:hover {
	background-color: unset;
}

header .mf-search-box .mf-search-bar .mf-search-bar_button span,
header .mf-search-box .mf-search-bar .mf-search-bar_button svg {
	display: none;
}
