@charset "utf-8";
/* CSS Document */
.global-nav {
	position: fixed;
	right: -320px;
	top: 0;
	width: 300px;
	height: 100vh;
	padding-top: 80px;
	background-color: #FFF;
	transition: all .6s;
	z-index: 10000;
	overflow-y: auto;
	box-sizing: border-box;
}
.hamburger {
	position: fixed;
	right: 0;
	top: 0;
	width: 64px;
	height: 64px;
	cursor: pointer;
	z-index: 10001;
	background-color: #FFF;
}
.global-nav__list {
	margin: 0;
	padding: 0;
	list-style: none;
}
.global-nav__item {
	text-align: left;
	padding: 0;
	display: block;
	line-height: normal;
	margin: .5rem;
}
.global-nav__item li {
	list-style-type: none;
}
.global-nav__item.nl {
	padding: 8px 15px;
}
.global-nav__item .nl {
	display: none;
}
.global-nav__item a {
	display: block;
	padding: 15px 20px 15px 40px;
	text-decoration: none;
	color: #FFF;
	font-weight: 500;
	background-color: #005BA8;
	border-radius: 50vh;
	position: relative;
}
.global-nav__item a::before {
	position: absolute;
	content: '';
	z-index: 3;
	width: 8px;
	height: 8px;
	border-top: solid 1px #FFF;
	border-right: solid 1px #FFF;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	top: 23px;
	left: 16px;
}
.global-nav__item span.no-link {
	display: block;
	padding: 10px 20px;
}
.global-nav__item a:hover {
	background-color: #E8E8E8;
    opacity: 1;
    filter: alpha(opacity=100);
	color: #000;
}
.hamburger__line {
    position: absolute;
    left: 18px;
    width: 28px;
    height: 2px;
    background-color: #000;
    transition: all .6s;
}
.hamburger__line--1 {
	top: 19px;
}
.hamburger__line--2 {
	top: 26px;
}
.hamburger__line--3 {
	top: 33px;
}
.black-bg {
	position: fixed;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vh;
	z-index: 9999;
	background-color: rgba(0,0,0,0.5);
	filter:progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#99ffffff,EndColorStr=#99ffffff); /* IE8以下*/
	opacity: 0;
	visibility: hidden;
	transition: all .6s;
	cursor: pointer;
}
.m-tx {
	width: 100%;
	position: absolute;
	bottom: 5px;
	left: 0;
	right: 0;
	margin: auto;
	text-align: center;
	font-size: 12px;
	letter-spacing: 0;
}
.close-tx {
	display: none;
}
/* 表示された時用のCSS */
.nav-open .global-nav {
	right: 0;
}
.nav-open .black-bg {
	opacity: .8;
	visibility: visible;
}
.nav-open .hamburger__line--1 {
	transform: rotate(45deg);
	top: 27px;
}
.nav-open .hamburger__line--2 {
	width: 0;
	left: 50%;
}
.nav-open .hamburger__line--3 {
	transform: rotate(-45deg);
	top: 27px;
}
.nav-open .open-tx {
	display: none;
}
.nav-open .close-tx {
	display: block;
}
.acco {
	position: relative;
	cursor: pointer;
	font-size: 1rem;
	font-weight: normal;
	padding: 0px 23px;
	transition: all .5s ease;
	display: block;
	width: 44px;
	height: 44px;
	background-color: #1E6FC1;
}
.acco::before,
.acco::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 2px;
    background-color: #FFF;
    
}
.acco::before{
    top:48%;
    left: 15px;
    transform: rotate(0deg);
    
}
.acco::after{    
    top:48%;
    left: 15px;
    transform: rotate(90deg);

}
.btn-acco.close .acco::before{
	transform: rotate(45deg);
}

.btn-acco.close .acco::after{
	transform: rotate(-45deg);
}
.main-nav ul.menu-second {
	display: none;
	margin: 5px 20px;
	font-size: .875rem;
}
.global-nav__item.menu-single {
	position: relative;
}
.global-nav__item.menu-single .btn-acco {
	position: absolute;
	right: 0;
	top: 0;
	width: 44px;
	height: 44px;
	border: 1px solid #EEE;
	border-width: 0 0 1px 1px;
	box-sizing: border-box;
}
.main-nav .global-nav__item ul.menu-second a, .main-nav .global-nav__item ul.menu-second li span.no-l {
	font-size: .875rem;
	padding: 3px 3px 3px 16px;
	color: #333;
	position: relative;
	line-height: 1rem;
}
.main-nav .global-nav__item ul.menu-second a::before, .main-nav .global-nav__item ul.menu-second li span.no-l::before {
	content: '';
	width: 5px;
	height: 5px;
	border: 0;
	border-bottom: solid 1px #1E6FC1;
	border-right: solid 1px #1E6FC1;
	position: absolute;
	top: 13px;
	left: 4px;
	margin-top: -4px;
	transform: rotate(-45deg);
}
.main-nav .global-nav__item ul.menu-second a:hover {
	background-color: #F5F9FC;
	font-weight: 500;
}
.global-nav__item.menu-single span.parent {
	display: block;
	padding: 10px 20px;
}
.main-nav ul.menu-second li {
	margin: 3px 0;
}
/* 追加部分 */
.global-nav__list.icon-nav {
	display: flex;
	flex-wrap: wrap;
	border-top: 1px solid #CCC;
}
.global-nav__list.icon-nav li {
	width: calc(100% /3);
	box-sizing: border-box;
	margin: 0;
	border-right: 1px solid #CCC;
}
.global-nav__list.icon-nav li:last-child {
	border-right: none;
}
.global-nav__list.icon-nav li a {
	display: block;
	box-sizing: border-box;
	padding: 26px 0 2px 0;
	position: relative;
	text-align: center;
	font-size: .75rem;
	color: #000;
	background-color: #F5F9FC;
}
.global-nav__list.icon-nav li a:before {
	position: absolute;
	left: 0;
	top: 7px;
	right: 0;
	margin: auto;
	content: '';
	width: 20px;
	height: 20px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100%;
}
.global-nav__list.icon-nav li a:hover {
	opacity: 1;
	font-weight: 500;
	background-color: #DCEEF9;
}
.global-nav__list.icon-nav li.time a:before {
	background-image: url(../images/icon-time.png);
}
.global-nav__list.icon-nav li.contact a:before {
	background-image: url(../images/icon-tel.png);
}
.global-nav__list.icon-nav li.acc a:before {
	background-image: url(../images/icon-acc.png);
}
.global-nav__list.basic {
	overflow-x: hidden;
}
.global-nav__list.basic .global-nav__item {
	border-bottom: 1px solid #F5F9FC;
}
.global-nav__list.basic .global-nav__item a {
	background-color: #1E6FC1;
	color: #FFF;
	font-weight: 500;
	position: relative;
}
.global-nav__list.basic .global-nav__item a:before {
	content: '';
	width: 8px;
	height: 8px;
	border: 0;
	border-bottom: solid 2px #FFF;
	border-right: solid 2px #FFF;
	position: absolute;
	top: 24px;
	right: 20px;
	margin-top: -4px;
	transform: rotate(-45deg);
}
.global-nav__list.basic .global-nav__item a:hover {
	background-color: #00AFEC;
}
.global-nav__list.basic .global-nav__item ul li a {
	background-color: #FFF;
	font-weight: normal;
}
.global-nav__list.basic .global-nav__item ul li a :hover {
	background-color: #F5F9FC;
}
.sub-title-nav {
	margin: 0;
	box-sizing: border-box;
	padding: 5px 0;
	font-weight: 500;
}
.global-nav__list.contact-nav {
	box-sizing: border-box;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	padding: 5px 0;
	background-color: #F0F9FC;
}
.global-nav__list.contact-nav .global-nav__item {
	width: 96%;
	margin: 5px 2%;
	padding: 0;
}
.global-nav__list.contact-nav .global-nav__item a {
	box-sizing: border-box;
	display: block;
	border: 1px solid #C5DEEA;
	line-height: 1;
	font-size: 15px;
	padding: 10px 10px 10px 42px;
	position: relative;
	border-radius: 50vh;
	background-color: #FFF;
	font-weight: 500;
}
.global-nav__list.contact-nav .global-nav__item a:hover {
	background-color: #F5F9FC;	
}
.global-nav__list.contact-nav .global-nav__item a:before {
	position: absolute;
	left: 14px;
	top: 9px;
	content: '';
	width: 18px;
	height: 18px;
	background-position: center;
	background-repeat: no-repeat;
	background-size: 100%;
}
.global-nav__list.contact-nav .global-nav__item.mail a:before {
	background-image: url(../images/icon-mail.png);
}
.global-nav__list.sub-nav {
	box-sizing: border-box;
	padding: 0 10px 5px 10px;
	margin: 5px 0 0 0;
	border-bottom: 1px solid #DDD;
}
.global-nav__list.sub-nav .global-nav__item a {
	padding: 3px 5px 3px 20px;
	line-height: 1.125;
	font-size: .875rem;
	position: relative;
}
.global-nav__list.sub-nav .global-nav__item a:before {
	content: '';
	width: 5px;
	height: 5px;
	border: 0;
	border-bottom: solid 1px #1E6FC1;
	border-right: solid 1px #1E6FC1;
	position: absolute;
	top: 13px;
	left: 4px;
	margin-top: -4px;
	transform: rotate(-45deg);
}
.no-page {
	pointer-events: none;	
}
.site-header-main .hamburger {
	background-color: transparent;
	position: relative;	
}
.site-header.fixed .site-header-main .hamburger {
    position: fixed;
    right: 0;
    top: 0;
    width: 64px;
    height: 64px;
    cursor: pointer;
    z-index: 10001;
    background-color: #FFF;
	box-shadow: 0px 0px 9px 0px rgba(0, 0, 0, 0.5);
}
.nav-open .site-header.fixed .site-header-main .hamburger {
	box-shadow: none;
}


@media screen and (min-width:1025px){
	.hamburger {
		display: none;
	}
	.global-nav {
		position: static;
		width: auto;
		padding: 0;
		background-color: transparent;
		height: auto;
		overflow: visible;
		display: flex;
		align-items: center;
	}
	.global-nav__list {
		display: flex;
	}
	.global-nav__item {
		letter-spacing: normal;
		padding: 0;
		box-sizing: border-box;
		margin: 0 12px;
	}
	.global-nav__item a,.global-nav__item .no-l,.global-nav__item span.parent {
		display: block;
		border-bottom: none;
		box-sizing: border-box;
		padding: 0;
		line-height: 1.25;
		color: #000;
		text-align: center;
		position: relative;
		border: none;
		border-radius: 0;
		margin: 0;
		font-size: 1rem;
		font-weight: 500;
		background-color: transparent;
		text-shadow: 0 0 3px #FFF,0 0 3px #FFF,0 0 3px #FFF,0 0 3px #FFF,0 0 3px #FFF,0 0 3px #FFF;
	}
	.global-nav__item a.parent,.global-nav__item span.parent {
		margin: 0;
	}
	.global-nav__item a .txbr {
		display:block;
	}
	.global-nav__item a:hover {
		opacity: 1;
		filter: alpha(opacity=100);
		background-color: transparent;
	}
	.main-nav ul {
		margin: 0;
		padding: 0;
		display: flex;
		flex-wrap: wrap;
	}
	.main-nav ul.menu-second {
		display: inherit !important;
		visibility: hidden;
		opacity: 0;
		z-index: 5;
	}
	.main-nav ul.menu-second li {
		margin: 0;
	}
	.main-nav ul.menu-second li:last-child {
		border-width: 0;
	}
	.main-nav li.menu-single {
		position: relative;
	}
	li.menu-single ul.menu-second {
		position: absolute;
		-webkit-transition: all .2s ease;
		transition: all .2s ease;
		text-align: center;
		padding: 0;
		width: 100%;
		margin: 0;
		min-width: 200px;
		right: 0;
	}
	li.menu-single:hover ul.menu-second {
		top: 20px;
		visibility: visible;
		opacity: 1;
	}
	.main-nav .global-nav__item ul.menu-second a {
		padding: 12px 0 !important;
		border-width: 0 !important;
		box-sizing: border-box;
		display: block;
		height: auto;
		font-size: .875rem;
		color: #000;
		margin: 0;
		background-color: #FFF;
	}
	.main-nav .global-nav__item ul.menu-second a:hover {
		color: #005EAD;
	}
	li.menu-single ul.menu-second li {
		display: block;
		border: 1px solid #DDD;
		border-width: 0 0 1px 0;
	}
	li.menu-single ul.menu-second li:last-child {
		border-bottom: none;
	}
	.global-nav__item.menu-single span.parent {
		padding: 0;
		border-radius: initial;
		border: none;
		margin: 0;
		font-size: .9375rem;
	}
	.btn-acco {
		display: none;
	}
	.main-nav .global-nav__item ul.menu-second a, .main-nav .global-nav__item ul.menu-second li span.no-l {
		font-size: .875rem;
	}
	.main-nav .global-nav__item ul.menu-second a::before, .main-nav .global-nav__item ul.menu-second li span.no-l::before {
		left: 10px;
	}
	.global-nav__item a::before {
		display: none;
	}
}
@media screen and (min-width:1241px){
	.global-nav__item {
		margin: 0 20px;
	}
	.global-nav__item a, .global-nav__item .no-l, .global-nav__item span.parent {
		font-size: 1.125rem;
		background-color: transparent;
		color: #000;
	}
}
@media screen and (max-width:820px){
	.acco {
		height: 43px;
	}
}
@media screen and (max-width:640px){
	.hamburger {
		width: 64px;
		height: 64px;
	}
	.hamburger__line {
		left: 16px;
		width: 32px;
		height: 2px;
	}
}
@media screen and (max-width:320px){
	.global-nav {
		right: -100%;
		width: 100%;
	}
}