/*
Theme Name: shimayoshi
Author: Airily
Version: 1.01
*/

@charset "UTF-8";

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

div,
pre,
p,
blockquote,
h1,
h2,
h3,
h4,
h5,
h6,
form,
fieldset,
figure,
figcaption,
ul,
li {
	margin: 0;
	padding: 0;
}

html {
	font-size: 62.5%;
}

body {
	display: block;
	margin: 0 auto;
	padding: 0;
	background: rgb(255, 255, 255);
	font-size: 17px;
	font-size: 1.7rem;
	font-family: "メイリオ", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", sans-serif;
	color: rgb(0, 0, 0);
}

@media screen and (max-width:869px) {
	body {
		font-size: 16px;
		font-size: 1.6rem;
	}
}

@media screen and (max-width:460px) {
	body {
		font-size: 14px;
		font-size: 1.4rem;
	}
}

* {
	box-sizing: border-box;
}

img {
	vertical-align: bottom;
	border: 0;
	-ms-interpolation-mode: bicubic;
}


@media screen and (max-width:869px) {
	img {
		max-width: 100%;
		height: auto;
	}
}

a {
	color: #000000;
}




/*
---------------------------------------------------------------------------
ベース
---------------------------------------------------------------------------*/

#wrap {
	max-width: 100%;
}

.fixed {
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 10000;
}

.clear {
	clear: both;
}

.clearfix:after {
	content: "";
	clear: both;
	display: block;
}

@media screen and (max-width:869px) {
	.fixed {
		position: static;
	}
}

/*
---------------------------------------------------------------------------
ヘッダー
---------------------------------------------------------------------------*/
#header {
	width: 100%;
	margin: 0 auto;
}

#headerIn {
	margin: 0 auto;
	padding: 20px 0 0 0;
	background: rgba(255, 255, 255, 0.8);
}

#headerIn:after {
	content: "";
	display: block;
	clear: both;
}

#headerLogo {
	width: 312px;
	display: block;
	text-align: initial;
	margin:auto;
}

#headerLogo a {
	display: block;
	text-align: center;
}

#headerLogo a img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}


#headerMenu {
    position: absolute;
    width: 805.556px;
    z-index: 9;
}

@media screen and (max-width:869px) {
	#headerIn {
		width: 100%;
		text-align: center;
		padding: 0;
		height: 56px;
	}

	#headerLogo {
		float: none;
		text-align: center;
		padding: 4px 10px;
		margin: 0;
	}

	#headerLogo .logo {
		margin-right: 0;
		margin-bottom: 15px;
	}

	#headerR {
		float: none;
	}
    #headerMenu {
    position: relative;
    }
}

@media screen and (max-width:460px) {
	#headerLogo a img {
		width: 100%;
		height: auto;
		max-width: 100%;
	}
}

/*
---------------------------------------------------------------------------
グローバルナビ
---------------------------------------------------------------------------*/
#gnavi {

	top: 0;
	bottom: 0;
	margin: 0 auto;
}

#gnavi ul {
	letter-spacing: -5px;
	list-style-type: none;
}

#gnavi ul li {
	font-size: 1.8rem;
	display: inline-block;
	letter-spacing: 0.07em;
	position: relative;
	margin: 0 15px 2px;
	vertical-align: bottom;
}

#gnavi ul li::after {
	position: absolute;
	bottom: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 4px;
	background-color: rgb(0, 112, 192);
	opacity: 0;
	transition: .1s;
}

#gnavi ul li:hover::after {
	bottom: 0;
	opacity: 1;
}

#services #gnavi ul li.services::after,
#works #gnavi ul li.works::after,
#about #gnavi ul li.about::after,
#recruit #gnavi ul li.recruit::after,
#contact #gnavi ul li.contact::after {
	bottom: 0;
	opacity: 1;
}


#gnavi ul li a {
	color: rgb(0, 112, 192);
	display: block;
	padding: 20px 0;
}

#gnavi ul li a:link {
	text-decoration: none;
}

/*#btn-spnav {}*/

@media screen and (max-width:869px) {
	#gnavi {
		display: none;
		background-color: rgb(255, 255, 255, 0.8);
		z-index: 100;
		top: 56px;
		right: 0;
		width: 100%;
		height: 300px;
		padding: 0 5%;
		box-sizing: border-box;
	}

	#gnavi ul {
		float: none;
		letter-spacing: normal;
	}

	#gnavi ul li {
		font-size: 13px;
		display: block;
		margin: 0;
	}

	#gnavi ul li::after {
		font-size: 10px;
		color: rgb(0, 112, 192);
		background-color: inherit;
		margin: auto;
		top: 50%;
		left: auto;
		right: 10px;
		transform: translate(-50%, -50%);
		-webkit-transform: translate(-50%, -50%);
		width: auto;
		height: 27px;
		float: right;
		opacity: 1;
	}

	#gnavi ul li a {
		color: rgb(0, 112, 192);
		padding-top: 17px;
		padding-bottom: 17px;
		border-bottom: solid 1px rgb(0, 112, 192);
	}
}

@media screen and (max-width: 869px) {
	/*トグルボタンのスタイルを指定*/
	#spnav-toggle {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		width: 56px;
		height: 56px;
		overflow: hidden;
		transition: background 0.3s;
		-webkit-transition: background 0.3s;
		z-index: 10000;
		background-color: rgb(0, 176, 240);
	}

	#spnav-toggle span {
		display: block;
		position: absolute;
		margin: 6px;
		width: 30px;
		border-bottom: solid 3px #FFF;
		-webkit-transition: .35s ease-in-out;
		/*変化の速度を指定*/
		-moz-transition: .35s ease-in-out;
		/*変化の速度を指定*/
		transition: .35s ease-in-out;
		/*変化の速度を指定*/
		left: 6px;
	}

	#spnav-toggle span:nth-child(1) {
		top: 9px;
	}

	#spnav-toggle span:nth-child(2) {
		top: 18px;
	}

	#spnav-toggle span:nth-child(3) {
		top: 27px;
	}

	/* 最初のspanをマイナス45度に */
	#spnav-toggle.active span:nth-child(1) {
		top: 18px;
		left: 6px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}

	/* 2番目と3番目のspanを45度に */
	#spnav-toggle.active span:nth-child(2),
	#spnav-toggle.active span:nth-child(3) {
		top: 18px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}
}
@media screen and (max-width:869px) {
	/*トグルボタンのスタイルを指定*/
	#spnav-toggle {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		width: 56px;
		height: 56px;
		overflow: hidden;
		transition: background 0.3s;
		-webkit-transition: background 0.3s;
		z-index: 10000;
		background-color: rgb(0, 176, 240);
	}

	#spnav-toggle span {
		display: block;
		position: absolute;
		margin: 6px;
		width: 30px;
		border-bottom: solid 3px #FFF;
		-webkit-transition: .35s ease-in-out;
		/*変化の速度を指定*/
		-moz-transition: .35s ease-in-out;
		/*変化の速度を指定*/
		transition: .35s ease-in-out;
		/*変化の速度を指定*/
		left: 6px;
	}

	#spnav-toggle span:nth-child(1) {
		top: 9px;
	}

	#spnav-toggle span:nth-child(2) {
		top: 18px;
	}

	#spnav-toggle span:nth-child(3) {
		top: 27px;
	}

	/* 最初のspanをマイナス45度に */
	#spnav-toggle.active span:nth-child(1) {
		top: 18px;
		left: 6px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}

	/* 2番目と3番目のspanを45度に */
	#spnav-toggle.active span:nth-child(2),
	#spnav-toggle.active span:nth-child(3) {
		top: 18px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}
}

	/*
---------------------------------------------------------------------------
グローバルナビ　モバイル用トグルメニュー
---------------------------------------------------------------------------*/
	#mov_gnavi {
		display: none;
	}

	.drawer-hamburger {
		top: 90px !important;
		width: 3rem !important;
		padding: 10px .75rem 20px !important;
		background-color: rgba(242, 242, 242, 0.6) !important;
	}

	.drawer-menu li {

		border-bottom: 1px solid #F2F2F2;
		text-align: center;
	}

	.drawer-menu li a {
		display: block;
		width: 100%;
		height: 100%;
		padding: 10px 0;
		text-decoration: none;
	}

	.drawer-menu li a:hover {
		background-color: #4472C4;
		color: #FFF;
	}

	@media screen and (max-width:869px) {
		.pc_gnavi {
			display: none;
		}

		#mov_gnavi {
			display: block;
			font-size: 14px;
		}
	}

	/*
---------------------------------------------------------------------------
フッター
---------------------------------------------------------------------------*/

#footerWrap {
		width: 1220px;
		margin: 0 auto;
		padding-bottom: 50px;
}


@media screen and (max-width:869px) {
	#footerWrap {
			width: 100%;
			padding-bottom: 0;
	}
	.footerBtn {
			margin-bottom: 0;
			padding-bottom: 20px;
			border-bottom: none;
	}
	.footerBtn ul li,
	.footerBtn ul li:nth-of-type(3) {
			width: 33.3333%;
			/*height: 40px;*/
			height: 64px;
			text-align: center;
	}
	.footerBtn ul li:first-child {
			border-right: 1px solid #BFBFBF;
	}
	.footerBtn ul li:nth-of-type(3) {
			border-right: none;
	}
	.footerBtn ul li img {
			margin-right: 0;
			position: absolute;
			top: 50%;
			left: 50%;
			transform: translate(-50%, -50%);
	}
}

#footerLogo {
		margin-bottom: 15px;
}

#footerIn dl {
		display: inline-block;
		font-size: 16px;
}

#footerIn dt {
		float: left;
}

#footerIn dd {
		margin-left: 120px;
		text-align: left;
}

#footerIn dt:first-child,
#footerIn dt:first-child+dd {
		margin-bottom: 20px;
}

#fNavi {
	width: 100%;
	margin-bottom: 30px;
	padding: 0;
	text-align: center;
}

#fNavi ul {
	list-style: none;
	display: inline-block;
	font-size: 0;
}

#fNavi ul:after {
	content: "";
	display: block;
	clear: both;
}

#fNavi ul li {
	float: left;
	font-size: 19px;
}

#fNavi ul li:after {
	content: "|";
	display: inline-block;
	margin: 0 10px;
}

#fNavi ul li:last-child:after {
	display: none;
}

#fNavi ul li a {
	text-decoration: none;
	font-size: 19px;
}



@media screen and (max-width:869px) {
	#footer {
		padding-top: 20px;
	}

	#footerLogo {
		float: none;
		margin: 10px auto 10px auto;
		text-align: center;
		padding: 0 15px;
	}

	#footerIn dl {
		display: inline-block;
		margin: auto;
		font-size: 14px;
		text-align: left;
	}

	#footerIn dt {
		float: none;
		display: block;
		font-weight: bold;
		text-align: center;
	}

	#footerIn dl dt:first-child {
		margin-bottom: 10px;
	}

	#footerIn dd {
		margin-left: 0;
		display: block;
		padding-bottom: 10px;
		text-align: center;
	}

	#footerIn dt:first-child+dd {
		margin-bottom: 10px;
	}

	#footerIn dt:first-child+dd img {
		margin-bottom: 5px;
	}

	#fNavi {
		margin-bottom: 20px;
	}

	#fNavi ul {
		width: 100%;
		display: block;
		background: #10316E;
	}

	#fNavi ul li {
		width: 50%;
		border-bottom: 1px solid #F2F2F2;
	}

	#fNavi ul li:first-child {
		width: 100%;
	}

	#fNavi ul li:nth-of-type(even) {
		border-right: 1px solid #F2F2F2;
	}

	#fNavi ul li:after {
		display: none;
	}

	#fNavi ul li a {
		display: block;
		width: 100%;
		height: 100%;
		padding: 10px 5px;
		font-size: 14px;
		/*vertical-align: middle;*/
		color: #FFF;
	}

	#fNavi ul li a:hover {
		background: rgba(255, 255, 255, .3);
	}
}

@media screen and (max-width:460px) {
	#footerLogo img {
		width: 100%;
		height: auto;
	}
}

	/*
---------------------------------------------------------------------------
メイン画像 sy
---------------------------------------------------------------------------*/

.slid-childWrap {
	position: absolute;
	right: 0;
	left: 0;
	bottom: 0px;
	margin: 0 auto;
	width: 100%;
	background: -moz-linear-gradient(bottom, rgb(0, 0, 0, 0.6), transparent);
	background: -webkit-linear-gradient(bottom, rgb(0, 0, 0, 0.6), transparent);
	background: linear-gradient(bottom, rgb(0, 0, 0, 0.6), transparent);
}

.slid-child {
	width: 1220px;
	margin: auto;
	padding: 20px 0;
	font-size: 22px;
	color: #FFF;
	font-family: "游明朝", "Yu Mincho", "HGP明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", "HiraMinProN-W6", serif;
}

.slid-child .caption {
	margin-bottom: 20px;
	font-weight: bold;
	font-size: 32px;
	text-align: center;
}


@media screen and (max-width:869px) {
    .slid-childWrap{
        display: none;
    }
	.slid-child {
		padding: 15px;
		width: 100%;
		font-size: 16px;
	}
	.slid-child .caption,
	.slid-child .caption .txt40 {
		font-size: 2.8rem;
	}
	.slid-child .txt21{
		font-size: 1.6rem;
	}
}

	/*
---------------------------------------------------------------------------
パンくずリスト
---------------------------------------------------------------------------*/
#topicPath {
	margin: 0;
	padding-bottom: 30px;
}

#topicPath ol {
	margin: 0;
	padding: 0;
	list-style-type: none;
}

#topicPath ol li {
	display: inline;
	margin-left: 10px;
	margin-right: 10px;
}

#topicPath ol li:first-child {
	margin-left: 0;
}

#topicPath ol li a {
	padding-right: 20px;
	background: url(img/topicpath_arrow.png) no-repeat right center;
	text-decoration: none;
	color: #FFF;
}

#topicPath ol li a:hover {
	text-decoration: underline;
}

#pagePath {
	padding-top: 25px;
	font-size: 19px;
	position: absolute;
	bottom: 100px;
	left: 50%;
	transform: translate(-50%);
	white-space: nowrap;
}

#pagePath a {
	padding-right: 50px;
	padding-left: 15px;
	background: url(img/arrow_btn-01.png) no-repeat;
	background-position: left center;
	text-decoration: none;
	color: #FFF;
	font-weight: bold;
}

#pagePath a:hover {
	text-decoration: underline;
}

#pagePath a:last-child {
	padding-right: 0;
}

@media screen and (max-width:869px) {
	#topicPath {
		padding-bottom: 0;
	}
	#pagePath {
		display: none;
	}
}

	/*
---------------------------------------------------------------------------
コンテンツ
---------------------------------------------------------------------------*/
.inner {
	width: 1220px;
	margin: auto;
	padding-top: 20px;
	text-align: center;
	overflow: hidden;
	zoom: 1;
}

@media screen and (max-width:869px) {
	.inner {
		width: 100%;
		padding-top: 0;
		padding-right: 15px;
		padding-left: 15px;
	}
}

#inner {
	width: 100%;
}

#main {
	width: 1220px;
	margin: auto;
	padding: 70px 0 0;
}

#inner:after,
.inner:after {
	content: "";
	display: block;
	clear: both;
}

@media screen and (max-width:869px) {
	#inner {
		padding-bottom: 30px;
	}

	#main {
		width: 100%;
		padding-right: 15px;
		padding-left: 15px;
	}
}

.homeBg {
	margin-bottom: 40px;
	padding: 0 0 40px;
	background: #222A35;
	color: #FFF;
}

.homeBgIn {
	width: 1220px;
	margin: auto;
	padding-top: 30px;
}

.homeBg h2 {
	margin: 0 auto;
	padding-bottom: 20px;
	text-align: center;
	font-size: 32px;
	font-family: "游明朝", "Yu Mincho", "HGP明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", "HiraMinProN-W6", serif;
}

.homeBg .txt {
	margin: 0 auto;
	padding-bottom: 50px;
	font-size: 21px;
}

.btnWrap a {
	display: block;
	width: 100%;
	padding: 5px 30px;
	border: 1px solid #FFF;
	text-decoration: none;
	text-align: center;
	color: #FFF;
}

.btnWrap {
	margin: auto;
	margin-bottom: 60px;
	width: 340px;
	color: #FFF;
	font-size: 25px;
	font-weight: bold;
}

.btnWrap .btnTxt {
	line-height: 1;
}

.btnWrap .btnTxt::before {
	margin-right: 10px;
	content: url(./img/arrow_btn-01.png);
	vertical-align: text-top;
}

.btnWrap a:hover {
	background: rgba(255, 255, 255, .15);
}

@media all and (-ms-high-contrast:none) {
	.btnWrap a {
		padding-bottom: 10px;
	}

	.btnWrap .btnTxt::before {
		vertical-align: top;
	}
}

@media screen and (max-width:869px) {
	.homeBg {
		padding-bottom: 10px;
	}

	.homeBgIn {
		width: 100%;
		padding: 0 15px;
	}
	.btnWrap {
		width: 100%;
		font-size: 16px;
	}

	.btnWrap a {
		padding: 15px;
	}

	.homeBg h2 {
		font-size: 20px;
	}

	.homeBg .txt {
		font-size: 16px;
	}

	.btnWrap .btnTxt::before {
		margin-right: 10px;
	}
}


	/*
---------------------------------------------------------------------------
レスポンシブ枠
---------------------------------------------------------------------------*/

.box1 {
		width: 100%;
		margin: 0 auto;
		overflow: hidden;
}

.boxH3 {
		width: 100%;
		margin-bottom: 90px;
		overflow: hidden;
}

#main .box1:last-child .boxH3 {
		margin-bottom: 50px;
}


.boxH4 {
		margin-bottom: 50px;
		padding-left: 30px;
}

.pic_2col {
		width: 570px;
}

.mg-r {
		margin: 0 0 0 auto;
}

.pic_2col .boxH4 figure img {
		margin-bottom: 10px;
}

.boxH4.non {
		padding-left: 0;
}

.box1 .boxH3 .col2:last-child .boxH4 {
		margin-bottom: 0;
}

.boxH3:after,
.boxH4:after,
.col2:after {
	content: "";
	display: block;
	clear: both;
}

.boxL {
	float: left;
}

.boxR {
	padding-left: 22px;
	overflow: hidden;
	zoom: 1
}

.boxL2 {
	overflow: hidden;
	zoom: 1
}

	.boxR2 {
		float: right;
		margin-left: 24px;
	}

	.halfBox {
		float: left;
		width: 50%;
	}

	.halfBoxLR {
		float: left;
	}

	.halfBoxLR:nth-of-type(even) {
		float: right;
	}

	.halfBoxLR.between {
		width: 580px;
	}

	@media screen and (max-width:736px) {
		.box1 {
			width: 100%;
		}

		.boxH3 {
			margin-bottom: 30px;
		}

		.boxL {
			float: none;
			text-align: center;
		}

		.boxR {
			padding-left: 0px;
		}

		.boxL img {
			max-width: 100%;
			height: auto;
		}

		.boxR2 {
			float: none;
			margin-bottom: 20px;
			margin-left: 0;
			text-align: center;
		}

		.halfBox {
			width: 100%;
		}

		.halfBoxLR,
		.halfBoxLR:nth-of-type(even) {
			float: none;
		}

		.boxH4 {
			padding-left: 0;
		}

		.pic_2col {
			width: 100%;
		}

		.halfBoxLR.between {
			width: 100%;
			margin-bottom: 30px;
		}

		.col2 .halfBoxLR.between:last-child {
			margin-bottom: 0;
		}

		.box1 .boxH3 .col2:last-child .boxH4 {
			margin-bottom: 50px;
		}

		.box1 .boxH3 .col2:last-child .halfBox:last-child .boxH4 {
			margin-bottom: 0;
		}
	}

	.box1 img,
	.boxH3 img {
		height: auto;
	}

	@media screen and (max-width:460px) {
		.boxH3 {
			padding: 0;
		}
	}

	/* h
---------------------------------------------------------------------------*/
	#h1Bg {
		width: 100%;
		padding: 8px 0;
		background: #00b0f0;
	}


	h1 a {
		color: #FFF;
	}

	@media screen and (max-width:869px) {
		#h1Bg {
			padding-left: 15px;
			padding-right: 15px;
		}
	}

	.inner>h2 {
		font-size: 25px;
		position: relative;
		margin-bottom: 40px;
		padding-bottom: 10px;
	}

	.inner>h2::after {
		content: "";
		width: 80px;
		border-bottom: 2px solid #EA9700;
		position: absolute;
		right: 0;
		left: 0;
		bottom: 0;
		margin: 0 auto;
	}

	@media screen and (max-width:736px) {
		.inner {
			width: 100%;
		}
	}

	/* #main h3 {
		font-size: 27px;
		position: relative;
		margin-bottom: 40px;
		padding-bottom: 10px;
		font-family: "游明朝", "Yu Mincho", "HGP明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", "HiraMinProN-W6", serif;
		text-align: center;
	}

	#main h3::after {
		content: "";
		width: 100px;
		border-bottom: 2px solid #EA9700;
		position: absolute;
		right: 0;
		left: 0;
		bottom: 0;
		margin: 0 auto;
	} */

	h3 a {
		text-decoration: none;
	}

	#h2BgWrap {
		width: 100%;
		height: 380px;
		background-color: #F8F8F8;
		background-color: #f2f2f2;
		background-position: center top;
		background-repeat: no-repeat;
		color: #FFF;
	}

	#h2Con {
		width: 1220px;
		height: 380px;
		margin: 0 auto;
		padding-top: 10px;
		padding-left: 10px;
		position: relative;
	}

	#h2Con>h2 {
		text-align: center;
		font-size: 32px;
		font-family: "游明朝", "Yu Mincho", "HGP明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", "HiraMinProN-W6", serif;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}

	@media screen and (max-width:869px) {
		#h2BgWrap {
			height: auto !important;
			background-size: cover;
		}

		#h2Bg {
			height: auto;
			padding-left: 15px;
			padding-right: 15px;
			background-color: rgba(255, 255, 255, 0.4);
		}

		#h2Con {
			width: 100%;
			height: 200px;
			padding: 10px 15px;
		}

		#h2Con>h2 {
			width: 100%;
			font-size: 24px;
		}
	}


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

		#main h3,
		h3 {
			font-size: 20px;
			font-size: 2.0rem;
		}
	}

	h4 {
		clear: both;
		font-size: 22px;
		font-weight: bold;
		position: relative;
		margin-bottom: 25px;
		padding-left: 25px;
	}

	h4::before {
		content: url("img/h4_ico.png");
		position: absolute;
		top: 0;
		left: 0;
	}

	h4.h4_org::before {
		content: url("img/h4_ico-02.png");
		position: absolute;
		top: 0;
		left: 0;
	}

	@media screen and (max-width:869px) {
		h4 {
			margin-bottom: 15px;
			font-size: 16px;
		}

		h4::before {
			top: 3px;
		}
	}

	/*
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
サブページ
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
	.anc {
		padding-top: 200px;
		margin-top: -200px;
	}

	@media screen and (max-width:736px) {
		.txtBr {
			display: block;
		}
	}

	#newsIn {
		width: 100%;
		margin: 0 auto 70px;
		border-top: 1px solid #7F7F7F;
		border-bottom: 1px solid #7F7F7F;
	}

	.newsCon {
		width: 1150px;
		height: 400px;
		margin: 0 auto;
		padding-top: 20px;
		padding-left: 10px;
		overflow-x: hidden;
		font-size: 17px;
		font-size: 1.7rem;
		background-color: #fff;
	}

	.newsCon table {
		margin: 50px auto;
		border-style: solid;
		border-color: #fff;
	}
	@media screen and (max-width:869px) {
		.newsCon {
			height: 250px;
		}
		.newsCon table {
			margin: 0;
		}
	}



	.newsCon>.newsTbl td {
		padding: 20px 15px;
		vertical-align: top;
		text-align: left;
	}

	.newsCon>.newsTbl tr:first-child td {
		padding: 0 15px 20px;
	}

	.newsCon>.newsTbl tr td:first-child {
		width: 310px;
	}

	.newsCon>.newsTbl td img {
		margin-left: 15px;
		vertical-align: text-top;
	}

	.newsCon>.newsTbl td p:last-child {
		margin-bottom: 0;
	}

	.newsTit a {
		text-decoration: none;
	}

	.newsTit a:hover {
		text-decoration: underline;
	}

	.newsIcon {
		margin-left: 15px;
		vertical-align: middle;
	}

	@media screen and (max-width:869px) {
		.newsCon td {
			display: block;
		}

		.newsCon>.newsTbl tr td:first-child {
			width: 100%;
			border-bottom: none;
			padding-bottom: 10px;
		}

		.newsCon>.newsTbl tr td:nth-of-type(2) {
			padding: 0 35px 20px;
		}
	}

	dl.topics-list {
		margin: 0;
		padding: 0;
	}

	dl.topics-list dt {
		margin-bottom: 10px;
	}

	dl.topics-list dd {
		margin-bottom: 30px;
		margin-left: 10px;
	}

	/*
ul,dl
---------------------------------------------------------------------------*/
	ul.ul3col {
		margin: 0 0 0;
		padding: 0 !important;
		list-style: none;
	}

	ul.ul3col:after {
		content: "";
		display: block;
		clear: both;
	}

	ul.ul3col li {
		float: left;
		width: 380px;
		margin: 0;
		margin-right: 30px;
		margin-bottom: 20px;
	}

	ul.ul3col li:nth-child(3n) {
		margin-right: 0;
	}

	ul.ul3col li figure img {
		margin-bottom: 10px;
	}

	ul.ul3col li figcaption {
		text-align: center;
	}

	.homeBgIn ul.ul3col li figcaption a {
		color: #FFF;
		text-decoration: none;
		font-size: 22px;
	}

	.homeBgIn ul.ul3col li figcaption a:hover {
		text-decoration: underline;
	}

	.homeBgIn ul.ul3col li figcaption a::before {
		margin-right: 10px;
		content: url(./img/arrow_btn-01.png);
		vertical-align: text-bottom;
	}

	@media screen and (max-width:869px) {
		.homeBgIn ul.ul3col li figcaption a {
			font-size: 16px;
		}

		ul.ul3col li {
			width: 32%;
			margin-right: 2%;
		}
	}

	@media screen and (max-width:460px) {
		ul.ul3col li {
			float: none;
			width: 100%;
			margin-left: 0;
			margin-bottom: 20px;
			text-align: center;
		}

		ul.ul3col li:nth-last-of-type(1) {
			margin-bottom: 0;
		}
	}


	dl.privacy {
		margin: 0;
		padding: 0;
	}

	dl.privacy dt {
		counter-increment: title;
		font-weight: bold;
	}

	dl.privacy dt::before {
		content: counter(title)"．";
	}

	dl.privacy dd {
		margin: 0 0 30px 25px;
	}

	.sitemap {
		text-align: center;
	}

	.sitemap ul {
		margin: 0;
		padding: 0;
		list-style-type: none;
		display: inline-block;
		text-align: left;
	}

	.sitemap ul li {
		margin-left: 35px;
		margin-bottom: 15px;
		background-image: url(img/sitemap_arrow_01.png);
		background-repeat: no-repeat;
		background-position: left center;
		padding-left: 20px;
	}

	ul.sitemap li:first-child {
		margin-left: 0;
	}

	ul.ul-nom {
		margin-left: 25px;
	}

	/*
table
---------------------------------------------------------------------------*/
	table.table01 {
		border-collapse: collapse;
		width: 100%;
	}

	.tableWrap table.table01 {
		border-top: 1px solid #D9D9D9;
	}

	table.table01 th,
	table.table01 td {
		padding: 10px 20px;
		border-bottom: 1px solid #D9D9D9;
		vertical-align: top;
		text-align: left;
	}

	table.table01.brd01 th,
	table.table01.brd01 td {
		padding: 10px 40px;
	}

	table.rireki tr td:first-child {
		text-align: center;
	}

	table.table01.brd01 th {
		text-align: center;
	}

	table.table01.brd01 th:first-child {
		width: 200px;

	}

	table.table01.brd01 th:nth-of-type(3) {
		width: 200px;
	}

	.tableWrap table.table01 th {
		width: 150px;
		font-weight: normal;
	}

	.tableWrap table.table01 td p:last-child {
		margin-bottom: 0;
	}

	table.table01.sp {
		margin-bottom: 30px;
	}

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

		table.table01 th,
		table.table01 td {
			display: block;
		}

		table.table01 th {
			width: auto;
			padding-bottom: 0;
			padding-left: 20px;
			border-bottom: 0;
			font-weight: bold;
		}

		.tableWrap table.table01 th {
			font-weight: bold;
		}

		table.table01 td {
			padding-right: 20px;
		}

		table.table01.brd01 td {
			padding: 10px;
			font-size: 16px;
		}

		table.table01.brd01 td:nth-of-type(3) {
			text-align: left;
		}

		table.rireki tr td:first-child {
			text-align: left;
		}

		table.table01.rireki th {
			display: none;
		}

		table.table01.rireki td:before {
			content: attr(data-label);
			display: block;
			font-weight: bold;
			color: #333;
			font-size: 14px;
			padding: 1px 3px;
			background: rgba(112, 200, 245, .2);
		}

		table.table01.rireki tr td:first-child,
		table.table01.rireki tr td:nth-of-type(2) {
			border-bottom: none;
			padding-bottom: 0 !important;
		}
	}



	/*pagetop
---------------------------------------------------------------------------*/

	#inner .pagetop:nth-last-of-type(1) {
		border: none;
		margin-bottom: 0;
		padding-bottom: 0;
	}

	.pagetopIn {
		width: 1200px;
		margin: 0 auto;
	}

	.pagetop a {
		color: #BFBFBF;
	}

	.s2v {
		display: none;
		position: fixed;
		bottom: 20px;
		right: 20px;
	}

	.pageNum {
		margin-top: 50px;
		text-align: center;
	}

	@media screen and (max-width:869px) {
		.pagetopIn {
			width: 100%;
		}
	}

	/* pagination */
	.pagination a {
		padding: 5px 10px;
		display: inline-block;
		border: solid 1px #cccccc;
		color: #000000;
		background-color: #ffffff;
		font-size: 14px;
		text-decoration: none;
	}

	.pagination a:hover {
		background-color: #e8e8e8;
	}

	.pagination span {
		padding: 5px 10px;
		display: inline-block;
	}

	.pagination span.current {
		padding: 5px 10px;
		display: inline-block;
		border: solid 1px #cccccc;
		color: #000000;
		background-color: #ffffff;
		font-size: 14px;
		text-decoration: none;
		font-weight: bold;
	}

	.pagination {
		overflow: hidden;
		text-align: center;
		clear: both;
		background-color: transparent;
	}

	.pagination h2 {
		margin: 0;
		padding: 0;
		font-size: 0;
	}

	/*wp*/
	.alignright {
		margin: 0 0 0 auto;
		text-align: right
	}

	/* 配置位置 右 */

	.alignleft {
		display: block;
		margin: 0 auto 0 0;
	}

	/* 配置位置 左 */

	.aligncenter {
		display: block;
		margin: 0 auto;
	}

	/* 配置位置 中央 */

	img.aligncenter {
		display: block;
		margin: 0 auto;
		text-align: center;
	}

	/*text
---------------------------------------------------------------------------*/
	.txt-few_large {
		font-size: 19px;
	}


	@media screen and (max-width:736px) {
		.txt-few_large {
			font-size: 16px;
		}
	}

	.contactTelWrap {
		margin-bottom: 1em;
		text-align: center;
		color: #0070C0;
		font-family: "游明朝", "Yu Mincho", "HGP明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", "HiraMinProN-W6", serif;
		font-size: 25px;
		font-size: 2.5rem;
	}

	.contactTelWrap a {
		color: #0070C0;
	}

	.contactTelNum {
		font-size: 37px;
		font-size: 3.7rem;
	}

	/*       フォント大きさ・太さ・位置             */

	.txt14 {
		font-size: 1.4rem;
		font-size: 14px;
	}

	.txt15 {
		font-size: 1.5rem;
		font-size: 15px;
	}

	.txt16 {
		font-size: 1.6rem;
		font-size: 16px;
	}

	.txt17 {
		font-size: 1.7rem;
		font-size: 17px;
	}

	.txt18 {
		font-size: 1.8rem;
		font-size: 18px;
	}

	.txt21 {
		font-size: 2.1rem;
		font-size: 21px;
	}

	.txt28 {
		font-size: 2.8rem;
		font-size: 28px;
	}

	.txt32 {
		font-size: 3.2rem;
		font-size: 32px;
	}

	.txt40 {
		font-size: 4.0rem;
		font-size: 40px;
	}

	.bold {
		font-weight: bold;
	}

	.txtc {
		text-align: center;
	}

	.txtl {
		text-align: left;
	}

	.txtr {
		text-align: right;
	}

	.lh32 {
		line-height: 3.2rem;
	}


	/*        margin/padding   ex: top=t bottom=b        */

	.mtb20 {
		margin-top: 20px;
		margin-bottom: 20px;
	}

	.mtb30 {
		margin-top: 30px;
		margin-bottom: 30px;
	}

	.mtb40 {
		margin-top: 40px;
		margin-bottom: 40px;
	}

	.mtb60 {
		margin-top: 60px;
		margin-bottom: 60px;
	}

	.mrl80 {
		margin-right: 80px;
		margin-left: 80px;
	}

	.mb20 {
		margin-bottom: 20px;
	}

	.mb30 {
		margin-bottom: 30px;
	}

	.mb40 {
		margin-bottom: 40px;
	}

	.mb50 {
		margin-bottom: 50px;
	}

	.mb60 {
		margin-bottom: 60px;
	}

	.ptb40 {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.pr80 {
		padding-right: 80px;
	}


	/*  top  */
	.selling-point {
		background-color: rgb(248, 248, 248);
	}

	.selling-point .col3-i3__pt2 td:nth-child(1),
	.selling-point .col3-i3__pt2 td:nth-child(2){
		margin:0 10px 0 0;
		padding:0;
	}

	.news-title {
		background-image: url(./image/h2_news.png);
		text-align: center;
		margin-bottom:60px;
	}

	.news-title p {
		line-height: 270px;
		color: #fff;
	}

	@media screen and (max-width:869px) {
		h2.news-title {
			background-image: none;
			margin-bottom:10px;
		}

		.news-title p {
			line-height: initial;
			color: #000;
		}

		#top h2::before {
			content: url(./image/icon_gear.png);
			display: block;
			padding-top: 20px;
		}

		#top h2,
		.txt32 {
			font-size: 2.5rem;
		}

		#top .icon_gear-g {
			display: none;
		}

		#top .selling-point .col3-i3__pt2 td:nth-child(2n+1) {
			display: none;
		}

		#top .selling-point p {
			margin: 20px auto;

		}
		#top .selling-point .homeBgIn p:nth-of-type(1) {
			margin: 0;
			padding: 0;

		}
	}

	#News {
		background-color: rgb(248, 248, 248);
	}

	.home-menu {
		margin-bottom: 60px;
	}
	@media screen and (min-width:870px) {
		.home-menu .col3-i3__pt2 td:nth-child(1) {
			padding-right: 80px;
		}
	}

	@media screen and (max-width:869px) {
		.home-menu {
			margin: 0;
		}
	}



	/*フッター sy
--------------------------------------------------------------------*/
	#footer {
		width: 100%;
		background: rgb(248, 248, 248);
		padding-top: 40px;
	}

	@media screen and (max-width:869px) {
		#footer {
			padding-top: 20px;
		}
	}

	.footer-under_bg {
		text-align: left;
		line-height: 30px;
		background: rgb(248, 248, 248);
		padding: 0px;
		font-family: メイリオ, sans-serif;
	}

	.footer-under_bg.sitemap_bg {
		background: rgb(255, 255, 255);
		padding-top:15px;
	}


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

		.footer-under_bg,
		#footerLogo2 {
			display: none;
		}
		.footer-under_bg.sitemap_bg {
			background: rgb(255, 255, 255);
			display:block;
			padding-bottom: 50px;
		}
	}

	.footer-under {
		/*width: 1200px;*/
		max-width: 960px;
		margin: 0 auto;
		display: -webkit-flex;
		display: flex;
		width: 100%;
	}

	.footer-under.sitemap_menu {
		display: block;
	}

	.footer-under a {
		text-decoration: none;
	}

	.footer-under ul {
		list-style: none;
		text-indent: 1.3em;
	}

	.footerBtn {
		width: 100%;
		margin: 0 auto 40px auto;
		padding: 0 0 30px;
		border-bottom: 1px solid rgb(217, 217, 217);
		font-family: "游明朝", "Yu Mincho", "HGP明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", "HiraMinProN-W6", serif;
		text-align: center;
	}

	.footerBtn ul li {
		display: inline-block;
		line-height: 1.3;
		width: 48%;
	}

	.footerBtn ul li a {
		text-align: left;
	}

	.footerBtn ul li img {
		display: inline-block;
		vertical-align: middle;
		margin-right: 35px;
	}

	.footerBtn ul li p {
		display: inline-block;
		vertical-align: middle;
	}

	@media screen and (max-width:869px) {
		.footerBtn {
			margin:0;
		}
		.footerBtn ul li p {
			display: none;
		}

		.footerBtn ul li a {
			display: block;
			width: 100%;
			height: 100%;
			position: relative;
		}
	}

	.fnav01,
	.fnav02,
	.fnav03,
	.fnav04,
	.fnav05,
	.fnav06,
	.fnav07 {
		padding: 0 0 0 10px;
	}

	.fnav01 {
		width: 12.5%;
		max-width: 120px;
	}

	.fnav02 {
		/*width: 18%;*/
		width: 22.5%;
		max-width: 216px;
	}

	.fnav03 {
		width: 18.75%;
		max-width: 180px;
	}

	.fnav04 {
		width: 18.75%;
		max-width: 180px;
	}
/*
	.fnav05 {
		width: 15%;
	}
*/
	.fnav06 {
		width: 27.5%;
		max-width: 264px;
	}

	.fnav02 a:nth-of-type(1) li {
		margin-bottom: 15px;
	}

	.f-moutain-box {
		position: relative;
		color: rgb(0, 0, 0);
		padding: 0px 0px 0px 20px;
		background: url(./image/ico_arrow.png) no-repeat;
		background-position-y: center;
	}

	.f-moutain-box:hover,
	.footer-under li:hover {
		opacity: 0.6;
	}

	#footer	.sp-pr-si{
		display: none;
	}
	@media screen and (max-width:869px) {
		#footer	.sp-pr-si{
			display: block;
			margin-bottom: 40px;
			text-align: right;
		}
		#footer	.sp-pr-si a{
			display: inline;
			padding-right: 10px;
		}
	}
	

	#footerIn {
		text-align: center;
		padding-bottom: 70px;
	}

	@media screen and (max-width:869px) {
		#footerIn {
			padding-bottom: 20px;
			width: 100%;
		}
	}

	#copyright {
		width: 100%;
		background: rgb(0, 176, 240);
		padding: 6px 15px;
		text-align: center;
		color: rgb(255, 255, 255);
	}

	@media screen and (max-width:869px) {
		#copyright {
			font-size: 11px;
			font-size: 1.1rem;
		}
	}

/*スマホサイトマップ*/

.sp-sitemap {
    display: none;
}

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

    .sp-sitemap {
        display: block;
        background-color: #f7f7f7;
    }

    .sp-sitemap ul {
        display: flex;
        flex-wrap: wrap;
        text-align: center;
    }

    .sp-sitemap li {
        width: 100%;
        margin-bottom: 0;
		border-bottom: 1px solid rgb(217, 217, 217);
    }

    .sp-sitemap li a {
        padding: 2rem 0;
        color: #000;
        display: block;
        text-transform: uppercase;
    }
}

html {
	margin-top: 0 !important;
}