@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: "游ゴシック","Yu Gothic","游ゴシック体","YuGothic","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","Meiryo UI","メイリオ",Meiryo,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
}

article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary {
	display: block;
}

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,
a:link {
	color: #040404;
	text-decoration: none;
}

a:visited {
	color: #040404;
}

a:hover {
	color: #040404;
}

a:active {
	color: #040404;
}

/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	min-width: 1200px;
	color: #221814;
	font-size: 15px;
	line-height: 1.5;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #FFF;
}

#container {
	text-align: left;
}

a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}

.sp {
	display: none !important;
}

@media screen and (max-width: 767px) {
	body {
		min-width: inherit;
		font-size: 14px;
	}

	a:hover,
	a:hover img {
		opacity: 1 !important;
	}

	.sp {
		display: block !important;
	}
	
	.pc {
		display: none !important;
	}
	
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}

}

/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader {
	margin-bottom: 8px;
	position: relative;
}

#gHeader:before {
	width: 100%;
	height: 27px;
	background: #000;
	position: absolute;
	top: 36px;
	left: 0;

	content: "";
}

#gHeader:after {
	width: 100%;
	height: 1px;
	background: #000;
	position: absolute;
	bottom: 0;
	left: 0;

	content: "";
}

#gHeader .hBox {
	margin: 0 auto;
	width: 1000px;
	position: relative;
}

#gHeader .logo {
	padding-left: 29px;
	float: left;
}

#gHeader .rBox {
	padding-top: 41px;
	width: 787px;
	float: right;
}

#gHeader .rBox h1 {
	margin-bottom: 18px;
}

#gHeader .rBox .textImg {
	margin-top: 3px;
	float: left;
}

#gHeader .rBox .subBox02 {
	width: 250px;
	float: right;
}

#gHeader .rBox .search {
	padding: 3px 7px 2px;
	position: relative;
	width: 149px;
	float: left;
	border: 1px solid #C8C8C8;
	border-radius: 4px;
}

#gHeader .rBox .search img {
	margin-right: 10px;
	vertical-align: -4px;
}

#gHeader .rBox .search input {
	padding: 0;
	width: 115px;
	color: #6c6b6c;
	font-size: 13px;
	line-height: 1.2;
	border: none;
}

#gHeader .rBox .search #searchsubmit {
	position: absolute;
	top: 5px;
	left: 7px;
	width: 18px;
	height: 17px;
	background: none;
	border: none;
	opacity: 0;
	cursor: pointer;
	background: url(img/common/h_img01.png) no-repeat left top;
}

#gHeader .rBox .linkList {
	width: 74px;
	float: right;
}

#gHeader .rBox .linkList li {
	margin-top: 5px;
	float: right;
}

#gHeader .rBox .linkList li:first-child {
	margin-top: 0;
	float: left;
}

#gHeader .rBox .linkList li a:hover img {
	opacity: 0.7;
}

@media all and (min-width: 768px) {
	.spMenuBox {
		display: none !important;
	}
}

@media screen and (max-width: 767px) {
	#gHeader:before {
		display: none;
	}

	#gHeader:after {
		display: none;
	}

	#gHeader .hBox {
		width: auto;
	}

	#gHeader .hBox img {
		margin: 0 auto;
	}

	#gHeader .logo {
		padding: 0 0 15px;
		float: none;
		text-align: center;
	}

	#gHeader .logo a {
		display: inline-block;
		vertical-align: top;
	}

	#gHeader .rBox {
		padding-top: 0;
		width: auto;
		float: none;
	}

	#gHeader .rBox h1 {
		margin-bottom: 16px;
		padding: 7px 0;
		background-color: #000;
		text-align: center;
		font-size: 13px;
	}

	#gHeader .rBox h1 img {
		width: 100%;
		max-width: 317px;
	}

	#gHeader .rBox .textImg {
		margin-top: 0;
		float: none;
	}

	#gHeader .rBox .subBox02 {
		display: none;
	}

	.spMenu {
		position: absolute;
		right: 12px;
		top: 42px;
		z-index: 600;
	}

	.spMenu .close {
		display: none;
	}

	.spMenu .on img {
		display: none;
	}

	.spMenu .on .close {
		display: block;
	}

	/*------------------------------------------------------------
		spMenuBox
	------------------------------------------------------------*/
	.spMenuBox {
		display: none;
		padding: 87px 0 27px;
		width: 100%;
		position: absolute;
		left: 0;
		top: 0;
		background-color: #EEEEEF;
		z-index: 500;
	}

	.spMenuBox .list01 {
		margin-bottom: 25px;
		border-bottom: 1px solid #777;
	}

	.spMenuBox .list01 > li {
		line-height: 2;
		border-top: 1px solid #777;
	}

	.spMenuBox .list01 > li > a {
		padding: 4px 50px 3px;
		display: block;
		font-size: 15px;
		text-decoration: none;
		background: url(img/common/sp_icon01.png) no-repeat 28px center;
		background-size: 13px 13px;
	}

	.spMenuBox .list01 > li > span {
		padding: 8px 29px 0;
		display: block;
	}

	.spMenuBox .list01 li ul {
		margin: 0 35px 10px 54px;
		line-height: 1.7;
	}

	.spMenuBox .list01 li li {
		margin-right: 20px;
		display: inline-block;
		font-size: 12px;
	}

	.spMenuBox .list01 li li a {
		text-decoration: none;
	}

	.spMenuBox .list02 {
		margin-bottom: 21px;
		text-align: center;
	}

	.spMenuBox .list02 li {
		margin: 0 5px;
		display: inline-block;
		font-size: 12px;
	}

	.spMenuBox .list02 li a {
		text-decoration: none;
	}

	.spMenuBox .faceImg {
		margin: 0 28px;
		text-align: right;
	}

	.spMenuBox #searchform {
		position: absolute;
		right: 69px;
		bottom: 27px;
	}

	.spMenuBox .search {
		padding: 3px 7px 2px;
		position: relative;
		width: 172px;
		float: left;
		border: 1px solid #C8C8C8;
		border-radius: 1px;
		background: #FFF;
	}

	.spMenuBox .search img {
		margin-right: 10px;
		vertical-align: -4px;
	}

	.spMenuBox .search .sp {
		display: inline-block !important;
	}

	.spMenuBox .search input {
		padding: 0;
		width: 136px;
		color: #6c6b6c;
		font-size: 16px;
		line-height: 1.5;
		border: none;
	}

	.spMenuBox .search #searchsubmit {
		position: absolute;
		top: 5px;
		left: 7px;
		width: 20px;
		height: 20px;
		background: none;
		border: none;
		opacity: 0;
		cursor: pointer;
		background: url(img/common/sp_h_img01.png) no-repeat left top;
		background-size: 20px 20px;
	}
}

/*------------------------------------------------------------
	gNavi
------------------------------------------------------------*/
#gNavi {
	margin: 0 auto;
	width: 1001px;
}

#gNavi > li {
	margin-right: 1px;
	width: 166px;
	position: relative;
	float: left;
	font-size: 16px;
	line-height: 1.75;
	text-align: center;
}

#gNavi > li > a {
	padding: 12px 2px 15px;
	display: block;
	position: relative;
	text-decoration: none;
	letter-spacing: -1px;
}

#gNavi > li:last-child {
	margin-right: 0;
}

#gNavi > li > a:before {
	display: none;
	width: 100%;
	height: 1px;
	background: #000;
	position: absolute;
	bottom: 0;
	left: 0;

	content: "";
}

#gNavi > li > a:hover:before,
#gNavi > .on > a:before {
	display: block;
}

#gNavi li ul {
	display: none;
	width: 100%;
	position: absolute;
	left: 0;
	top: auto;
	z-index: 200;
}

#gNavi li:hover ul {
	display: block;
}

#gNavi li ul li {
	font-size: 16px;
	line-height: 1.75;
	border-bottom: 1px solid #FFF;
}

#gNavi li ul li:last-child {
	border-bottom: none;
}

#gNavi li ul a {
	padding: 14px 1px 12px;
	display: block;
	color: #FFF;
	text-decoration: none;
	background-color: #A0A0A0;
}

#gNavi li ul a:hover {
	background-color: #BBB;
}

#gNavi li ul .liStyle a {
	letter-spacing: -1.5px;
}

#gNavi li ul .liStyle02 a {
	letter-spacing: -2px;
}

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

/*------------------------------------------------------------
	pagePath
------------------------------------------------------------*/
.pagePath {
	width: 860px;
	margin: 0 auto 37px;
	font-family: "Hiragino Kaku Gothic Pro", Meiryo, "メイリオ", "ヒラギノ角ゴ Pro W3", sans-serif;
}

.pagePath li {
	margin-right: 5px;
	display: inline-block;
	color: #221714;
	font-size: 12px;
}

.pagePath li a {
	margin-right: 5px;
	color: #221714;
	font-size: 12px;
}

.pagePath li a:hover {
	text-decoration: underline;
}

@media screen and (max-width: 767px) {
	.pagePath {
		width: auto;
		margin: 6px 14px 22px;
	}
	
	.pagePath li {
		margin-right: 2px;
		font-size: 10px;
	}
	
	.pagePath li a {
		margin-right: 2px;
		font-size: 10px;
	}
	
	.pagePath li a:hover {
		text-decoration: none;
	}
	
}

/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
	padding: 28px 0 11px;
	text-align: center;
	background-color: #F8F8F6;
}

#gFooter .fNavi {
	margin-bottom: 26px;
}

#gFooter .fNavi li {
	margin: 0 20px;
	display: inline-block;
}

#gFooter .fNavi li span {
	display: none;
}

#gFooter .fNavi li a {
	font-size: 15px;
	color: #221814;
}

#gFooter .fNavi li a:hover {
	text-decoration: underline;
}

#gFooter .fTxt {
	margin-bottom: 14px;
	font-size: 12px;
}

#gFooter .copyright {
	font-size: 12px;
}

@media screen and (max-width: 767px) {
	#gFooter {
		position: relative;
		padding: 25px 0 11px;
	}
	
	#gFooter .fNavi {
		margin-bottom: 20px;
	}
	
	#gFooter .fNavi li {
		margin: 0;
	}
	
	#gFooter .fNavi li a {
		margin: 0 3px;
	}
	
	#gFooter .fNavi li span {
		display: inline-block;
	}
	
	#gFooter .fNavi li a {
		font-size: 13.5px;
	}
	
	#gFooter .fNavi li a:hover {
		text-decoration: none;
	}
	
	#gFooter .fTxt {
		width: 210px;
		margin: 0 auto 20px;
		line-height: 1.75;
		text-indent: -1em;
		padding-left: 1em;
		text-align: left;
		box-sizing: border-box;
	}
	
	#gFooter .copyright {
		font-size: 12.5px;
	}
	
	#gFooter .pageTop {
		position: absolute;
		display: none;
		top: -56px;
		right: 26px;
		z-index: 100;
	}
	
	#gFooter .pageTop.fix {
		display: none;
		position: fixed;
		bottom: 20px;
		right: 26px;
		top: inherit;
	}

}