@charset "utf-8";
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;

	font-size: 1em;
}

body {
	font-size: 62.5%;
}

body,
table,
input, textarea, select, option {
	font-family: Meiryo, "メイリオ", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

:focus {
	outline: 0;
}

ins {
	text-decoration: none;
}

del {
	text-decoration: line-through;
}

img {
	vertical-align: top;
}

a:link {
	color: #0091D7;
	text-decoration: none;
}

a:visited {
	color: #0091D7;
	text-decoration: none;
}

a:hover {
	color: #7fc2e5;
	text-decoration: underline;
}

a:active {
	color: #7fc2e5;
	text-decoration: underline;
}


/*---------------------------------------------------  SP版  */

@media all and (min-width: 835px) {
	.sp {
		display: none !important;
	}
}
@media all and (max-width: 834px) {
	body {
		min-width: inherit;
	}
	body.open {
		overflow: hidden;
	}
	a:hover,
	a:hover img {
		opacity: 1 !important;
	}
	.pc {
		display: none !important;
	}
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
}


/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	min-width: 1280px;
	color: #333;
	font-size: 14px;
	text-align: center;
	line-height: 1.5;
	background-color: #FFF;
}

#container{
    position: relative;
	text-align: left;
}

#main {
	margin: 0 auto 61px;
	padding-right: 10px;
	width: 990px;
}

	* html #main {
		zoom: 1;
	}

	*+html #main {
		zoom: 1;
	}

#main:after {
	height: 0;
	visibility: hidden;
	content: ".";
	display: block;
	clear: both;
}

.bgLink .banner {
	display: block;
	margin: -30px auto 30px;
}


@media all and (max-width: 834px) {
	body {
		min-width: auto;
	}
	#main {
		margin: 0 auto 61px;
		padding-right: 10px;
		width: auto;
	}

		* html #main {
			zoom: 1;
		}

		*+html #main {
			zoom: 1;
		}

	#main:after {
		height: 0;
		visibility: hidden;
		content: ".";
		display: block;
		clear: both;
	}

	.bgLink .banner {
		display: block;
		margin: -30px auto 30px;
	}
}


/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#header .hBox {
	margin: 0 auto;
	padding: 33px 0 27px;
	width: 1200px;
	position: relative;
}

#header .hBox .logo {
	float: left;
	margin-top: 5px;
}

#header .hBox .hLink {
	margin-top: 3px;
	float: right;
    display: flex;
}

#header .hBox .hLink .hLinkLang {
    display: flex;
		align-items: center;
	margin-bottom: 0;
	overflow: hidden;
}

#header .hBox .hLink .hLinkLang li {
	height: 30px;
}

#header .hBox .hLink .logo_h02 {
	clear: both;
    display: flex;
		align-items: center;
    margin-right: 26px;
	text-align: right;
}

#header .hBox .hLink .logo_h02 li {
	padding-left: 15px;
	display: inline-block;
	vertical-align: top;
}
#header .hBox .hLink .logo_h02 li img {
}

/*
#header .hBox .hLink .sns {
	clear: both;
    display: flex;
    margin-right: 26px;
	text-align: right;
}

#header .hBox .hLink .sns li {
	width: 28px;
	padding-left: 15px;
	display: inline-block;
	vertical-align: top;
}*/

@media all and (max-width: 834px) {

	#header .hBox {
		display: flex;
		align-items: center;
		justify-content: space-between;
		margin: 0 auto;
		padding: 19px 0 17px;
		width: 100%;
		z-index: 100;
	}
	#header .hBox.clearfix:after {
		display: none;
	}
	#header .hBox .logo {
		width: 50%;
		margin-top: 0;
		padding-left: 3%;
	}
	#header .hBox .logo img {
		width: 100%;
		height: auto;
	}

	#header .hBox .hLink {
		margin-top: 3px;
		float: none;
			display: flex;
		padding-left: 4%;
	}

	#header .hBox .hLink .hLinkLang {
			display: flex;
			align-items: center;
		margin-bottom: 0;
		overflow: hidden;
	}

	#header .hBox .hLink .hLinkLang li {
		height: 30px;
	}


	#header .hBox .sns {
		display: none;
	}

	#header .hBox  .menuBtn {
		display: flex;
		flex-direction: column;
		justify-content: center;
		padding-right: 5%;
	}
	#header .hBox .menuBtn .bar {
		display: block;
		width: 40px;
		height: 2px;
		background: rgba(40,36,17,0.8);
		margin: 4px 0;
		transition: all .3s;
	}
	#header .hBox .menuBtn.close .bar01 {
		transform: rotate(45deg);
		margin-bottom: -5.5px;
	}
	#header .hBox .menuBtn.close .bar02 {
		transform: rotate(-45deg);
	}


	.hm_nav {
		position: fixed;
		top: -20px;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 90;
		background: #fff;
		opacity: 0;
		visibility: hidden;
		transition: all .5s;
		box-sizing: border-box;
		padding: 75px 0 30px;
	}
	.hm_nav.nav_open {
		top: 0;
		opacity: 1;
		visibility: visible;
		overflow-y: scroll;
	}
	.hm_nav .spmUl {
		display: block;
		margin-top: 17px;
	}
	.hm_nav .spmUl li {
		width: auto;
	}
	.hm_nav .spmUl li a {
		font-weight: 700;
		font-size: 15px;
		letter-spacing: 0.7px;
		display: block;
		text-align: left;
		padding: 12px 30px 12px 16px;
		border-bottom: 1px solid #dedede;
		margin: 0 7%;
		position: relative;
		color: #333;
	}
	.hm_nav .spmUl li a:before {
		position: absolute;
		content: "";
		width: 10px;
		height: 10px;
		border-right: 1px solid #333;
		border-top: 1px solid #333;
		transform: rotate(45deg)translateY(-50%);
		right: 12px;
		top: 50%;
	}

	.hm_nav .spmUl li.inUl a {
	}
	.hm_nav .spmUl li.inUl a:before {
		content: "";
    width: 1px;
    height: 13px;
    border: none;
		background: #333;
    transform: rotate(0)translateY(-50%);
    right: 12px;
    top: 50%;
	}
	.hm_nav .spmUl li.inUl a:after {
		content: "";
    position: absolute;
    width: 13px;
    height: 1px;
		background: #333;
    transform: rotate(0)translateY(-50%);
    right: 6px;
    top: 50%;
	}
	.hm_nav .spmUl li.inUl.open a:before {
		display: none;
	}
	.hm_nav .spmUl li.inUl .in_spmUl {
		display: none;
	}
	.hm_nav .spmUl li.inUl.open .in_spmUl {
		display: block;
	}
	.hm_nav .spmUl li.inUl.open .in_spmUl a {
		display: block;
		padding-left: 33px;
	}
	.hm_nav .spmUl li.inUl .in_spmUl li a:before {
		position: absolute;
		display: block;
		content: "";
		width: 10px;
		height: 10px;
		border-right: 1px solid #333;
		border-top: 1px solid #333;
		background: transparent;
		transform: rotate(45deg)translateY(-50%);
		right: 12px;
		top: 50%;
	}
	.hm_nav .spmUl li.inUl .in_spmUl li a:after {
		display: none;
	}

	.hm_nav .underUl {
		display: flex;
		justify-content: center;
		margin: 20px 7% 0;
	}
	.hm_nav .underUl li a {
		color: #333;
	}

}

/*------------------------------------------------------------
	グローバルナビ
------------------------------------------------------------*/
#gNavi {
    margin: 0 auto 45px;
    background: #F1EDE1;
}

#gNavi ul {
    margin: 0 auto;
    width: 1030px;
}

#gNavi ul li {
	float: left;
    width: 142px;
}
#gNavi ul li a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 70px !important;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    font-weight: 400;
    color: #fff;
    text-align: center;
    text-decoration: none;
    transition: 0.5s;
}
#gNavi ul li a:hover {
    background: #dfc56f;
    transition: 0.5s ;
}
#gNavi #gNav01 {
    width: 170px;
}
#gNavi #gNav01 a,
#gNavi #gNav07 a {
    font-size: 15px;
    letter-spacing: -1px;
	display: flex;
	justify-content: center;
	align-items: center;
}

#gNavi li ul {
    height: 300px;
    overflow: hidden;
    position: absolute;
    visibility: hidden;
    width: 142px;
    z-index: 100000;
}

#gNavi li .hovUl {
	width: 142px;
}

#gNavi li ul li {
    padding-top: 1px;
    width: 100%;
	height: 0;
	float: none;
    overflow: hidden;
    transition: all 0.5s ease 0s;
	-webkit-transition: all 0.5s ease 0s;
    visibility: hidden;
	line-height: 64px;
}

#gNavi li ul li a {
	color: #4c4948;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 16px;
	font-weight: 400;
	text-align: center;
	font-family: 'Noto Sans JP', sans-serif;
  border: 1px solid #4c4948;
	text-decoration: none;
	background-color: #fff;
}
#gNavi > ul > li:nth-child(4) ul li a {
	letter-spacing: -1.5px;
}
#gNavi li:hover ul {
	visibility: visible;
}

#gNavi li:hover ul li {
	height: 64px;
	visibility: visible;
	overflow: visible;
}

#gNavi li:hover ul li a {
	height: 64px;
}

#gNavi li:hover ul li a:hover {
	opacity: 0.7;
}

@media all and (max-width: 834px) {
	#gNavi {
		display: none;
	}

	#gNavi ul {
			margin: 0 auto;
			width: 1030px;
	}

	#gNavi ul li {
		float: left;
			width: 142px;
	}
	#gNavi ul li a {
			display: flex;
			justify-content: center;
			align-items: center;
			height: 70px !important;
			font-family: 'Noto Sans JP', sans-serif;
			font-size: 16px;
			font-weight: 400;
			color: #fff;
			text-align: center;
			text-decoration: none;
			transition: 0.5s;
	}
	#gNavi ul li a:hover {
			background: #dfc56f;
			transition: 0.5s ;
	}
	#gNavi #gNav01 {
			width: 170px;
	}
	#gNavi #gNav01 a,
	#gNavi #gNav07 a {
			font-size: 15px;
			letter-spacing: -1px;
		display: flex;
		justify-content: center;
		align-items: center;
	}

	#gNavi li ul {
			height: 300px;
			overflow: hidden;
			position: absolute;
			visibility: hidden;
			width: 142px;
			z-index: 100000;
	}

	#gNavi li .hovUl {
		width: 142px;
	}

	#gNavi li ul li {
			padding-top: 1px;
			width: 100%;
		height: 0;
		float: none;
			overflow: hidden;
			transition: all 0.5s ease 0s;
		-webkit-transition: all 0.5s ease 0s;
			visibility: hidden;
		line-height: 64px;
	}

	#gNavi li ul li a {
		color: #4c4948;
		display: flex;
		justify-content: center;
		align-items: center;
		font-size: 16px;
		font-weight: 400;
		text-align: center;
		font-family: 'Noto Sans JP', sans-serif;
		border: 1px solid #4c4948;
		text-decoration: none;
		background-color: #fff;
	}
	#gNavi > ul > li:nth-child(4) ul li a {
		letter-spacing: -1.5px;
	}
	#gNavi li:hover ul {
		visibility: visible;
	}

	#gNavi li:hover ul li {
		height: 64px;
		visibility: visible;
		overflow: visible;
	}

	#gNavi li:hover ul li a {
		height: 64px;
	}

	#gNavi li:hover ul li a:hover {
		opacity: 0.7;
	}
}


/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
/*#footer {
	background: url(../../img/index/line_bg.gif) repeat-x left top;
}*/

#footer .fBox {
	margin: 0 auto;
	padding: 48px 0;
	width: 100%;
}

#footer .fBox .fNavi {
	float: left;
}

#footer .fBox .fNavi li {
	margin-right: 47px;
	float: left;
}
#footer .fBox .fNavi li a {
    color: #231815;
}

#footer .fBox p {
	float: right;
}
#footer .fBox p a {
    color: #231815;
}

#footer .fBox p a:hover img {
	opacity: 0.5;
	transition: all 0.5s ease 0s;
	-webkit-transition: all 0.5s ease 0s;
}

#pagetop {
	position: fixed;
	right: 130px;
	bottom: 16px;
}

#pagetop a:hover img {
	transition: all 0.3s ease-in-out 0s;
	-webkit-transition: all 0.3s ease-in-out 0s;
	opacity: 0.5;
}

.sns {
    position: fixed;
    top: 50%;
    right: 30px;
	clear: both;
    display: flex;
    flex-flow: column;
}

.sns li {
	width: 28px;
	padding-bottom: 15px;
	display: inline-block;
	vertical-align: top;
}


@media all and (max-width: 834px) {
	#footer .fBox {
		margin: 0 auto;
		padding: 48px 0;
		width: 100%;
	}

	#footer .fBox .fNavi {
		float: left;
	}

	#footer .fBox .fNavi li {
		margin-right: 47px;
		float: left;
	}
	#footer .fBox .fNavi li a {
			color: #231815;
	}

	#footer .fBox p {
		float: none;
		font-size: 11px;
		text-align: center;
	}

	#footer .fBox p a:hover img {
		opacity: 0.5;
		transition: all 0.5s ease 0s;
		-webkit-transition: all 0.5s ease 0s;
	}
	
	#footer .footBox {
		padding: 24px 0 14px;
		background: #f1f1f1;
		text-align: center;
	}
	#footer .footBox .logo_h02 {
	}
	#footer .footBox .logo_h02 li {
		margin-bottom: 11px;
	}
	#footer .footBox .logo_h02 li img {
		width: 54%;
	}
	#footer .footBox .fNavi {
		display: flex;
		justify-content: center;
		align-items: center;
		margin-top: 35px;
	}
	#footer .footBox .fNavi a {
		color: #333333;
	}

	#pagetop {
		right: 5%;
		bottom: 16px;
		width: 50px;
		height: 50px;
	}
	#pagetop a {
	}
	#pagetop img {
		width: 100%;
	}

	#pagetop a:hover img {
		transition: all 0.3s ease-in-out 0s;
		-webkit-transition: all 0.3s ease-in-out 0s;
		opacity: 0.5;
	}

	.sns {
		display: none;
	}
}

