@charset "utf-8";

/* header
------------------------------------------------------------------------------------ */
header {
	width:100%;
	padding: 30px 30px;
	box-sizing: border-box;
	background-color: rgba(0,49,93,0.85);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 998;
	transition: all 0.3s ease;
}
.is-animation {
	padding: 20px 30px;
	background-color: rgba(0,49,93,0.85);
}
header div {
	position: relative;
}
header>div {
    max-width: 980px;
    margin: auto;
}
header div h1 {
	float: left;
}
header div h1 img {
	height:40px;
}
header div p.reserveBtn {
	float: right;
	position: relative;
	right: 78px;
	margin-left:-1px;
}
header div p.reserveBtn a {
	color: #FFF;
	display: block;
	font-size: 14px;
	line-height: 100%;
	padding: 11px 25px 11px 45px;
	border: 1px solid #FFF;
	background:url(/common/images/reservebtn_bg_white.png) 10px center no-repeat;
	background-size: 18px 18px;
	transition: all  0.7s ease;
}
header div p.reserveBtn.faq a {
	background:url(/common/images/icon_question_wh@3x.png) 10px center no-repeat;
	background-size: 16px;
}
header div p.reserveBtn a:hover {
	color: #00315d;
	border: 1px solid #FFF;
	background:url(/common/images/reservebtn_bg_blue.png) 10px center no-repeat #FFF;
	background-size: 18px 18px;
}
header div p.reserveBtn.faq a:hover {
	background:url(/common/images/icon_question_nv@3x.png) 10px center no-repeat #FFF;
	background-size: 16px;
}
.menusection {
	display:block;
	width:100%;
	font-family: Georgia, "游明朝体", "YuMincho", "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
	font-size: 20px;
	line-height: 100%;
	text-align: center;
	margin-bottom: 30px;
	padding: 20px 0;
	border-top: 1px solid #999;
	border-bottom: 1px solid #999;
}


/* gnav
------------------------------------------------------------------------------------ */
div#gnav {}
div#gnav div {
	position: fixed;
	top: 40px;
	left: 0;
	right: 0;
	max-width: 980px;
	margin: auto;
	text-align: right;
	z-index: 999;
	transition: all  0.3s ease;
}
.is-animation div#gnav div {
	top: 35px;
}
div#gnav div a.gnavTrigger {
}
div#gnav div a.gnavTrigger img {
	max-width: 40px;
	height:unset;
}


/* ====================================================================================
SP
==================================================================================== */
@media screen and (max-width:960px) {


/* header
------------------------------------------------------------------------------------ */
header {
	padding: 20px 15px;
	background-color: rgba(0,49,93,0.85);
}
.is-animation {
    height: 50px;
	padding: /*15px 15px*/0;
	background-color: rgba(0,49,93,0.85);
}
header div {position: relative;height: unset;}
header div h1 {
	float: left;
	margin-top: 2px;
	padding: 0;
}
header div h1 img {
    width: 37.87vw;
	height: auto;
    max-width: 142px;
}
header div p.reserveBtn {
	float: right;
	margin:0 0 0 -1px;
	width:46%;
	right: unset;
}
header div p.reserveBtn a {
	font-size:min(3.4vw,18px);
	padding: 8px 12px 8px 32px;
	background:url(/common/images/reservebtn_bg_white.png) 10px center no-repeat;
	background-size: 14px 14px;
	margin-left: 0;
	height: unset;
	text-align: left;
	text-indent: unset;
}
header div p.reserveBtn a:hover {
	background:url(/common/images/reservebtn_bg_blue.png) 10px center no-repeat #FFF;
	background-size: 14px 14px;
}
header div p.reserveBtn.faq{width: 46%;}
header .headban {
	width:100%;
	clear:both;
	padding-top:12px;
	position: unset;
}
header.is-animation>div{height: 50px;overflow: hidden;}
header.is-animation div h1{float: none;padding: 15px 0 0 10px;}
header.is-animation div h1 img {width: 24vw;max-width: 110px;}
header.is-animation .headban {
	display: flex;
	flex-direction : row-reverse;
    position: absolute;
    top: 0;
    left: unset;
	right: 56px;
    width: 56%;
	padding: 0;
}
header.is-animation div p.reserveBtn {
    float: none;
    margin: 0;
    width: 46%;
    right: unset;
}
header.is-animation div p.reserveBtn.faq {
	width: 54%;
}
header.is-animation div p.reserveBtn a {
	margin-left: -1px;
    padding: 0;
    background-size: 14px 14px;
    height: 50px;
	border: 1px solid #09182d;
    border-top: 0;
    border-bottom: 0;
	line-height: 50px;
    text-align: center;
    text-indent: 15px;
	font-size:2.4vw;
}

/* gnav
------------------------------------------------------------------------------------ */
div#gnav {}
div#gnav div {
	position: fixed;
	top: 28px;
	left: unset;
	right: 15px;
	width: 40px;
	z-index: 999;
	transition: all  0.3s ease;
}
.is-animation div#gnav div {
	top: 20px;
}
div#gnav div a.gnavTrigger {
	display: inline-block;
	height: 5vw;
}
div#gnav div a.gnavTrigger img {
	height:8px;
}

}/* max-width:960px end */