@charset "utf-8";
/* CSS Document */

@charset "utf-8";

/*####################　共通設定　####################*/
html{
	overflow-y:scroll;
	margin: 0;
	padding: 0;
	height: 100%;
	clear: both;
}

body{
	position: relative;
	line-height:1.5;
	text-align: center;
	font-family: "游ゴシック体", 'YuGothic', "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt";
	-moz-font-feature-settings: "palt";
	-webkit-font-feature-settings: "palt";
	letter-spacing: 0.045em;
	font-size: 12px;
	font-weight: 500;
	color: #333;
}

p{
	text-align: justify;
	text-justify: inter-ideograph;
}

a { color: #F3A3AC;
}

hr { display:none;}

/* レスポンシブデザインの改行 */
@media print, screen and (min-width: 768px) {
	.pc_display{
		display: block;
	}
	
	.sp_display,
	.sp_display_inline{
		display: none;
	}

	article p{
		margin: 0 0 14px;
		line-height: 34px;
		font-size: 20px;
	}

	a[href="tel"]:hover{
		cursor: text;
	}

	a:hover {
		text-decoration: none;
	}

}

@media screen and (max-width: 767px) {
	.pc_display{
		display: none;
	}
	
	.sp_display{
		display: block;
	}
	
	.sp_display_inline{
		display: inline;
	}

	p{
		margin: 0 0 11px;
		line-height: 29px;
		font-size: 18px;
	}
}


/*####################　枠設定　####################*/
#Header {
	position: relative;
	z-index: 1;
	margin:0 auto;
	border-bottom: 1px solid #dedede;
	background-color: #fff;
	text-align:left;
}

#Header:after{
	content:"";
	display:block;
	clear:both;
}

#GlobalNav{
	margin:0 auto;
	text-align:left;
}

#Container{
	margin:0 auto;
	text-align:left;
}

#Main{
	min-height:500px;
	_height:500px;
}

#Footer{
	margin:0 auto;
	border-top: 1px solid #eaeaec;
	background-color: #f5f6f8;
	text-align: left;
}

#Container:after,
.innerBasic:after,
.wrapBox:after,
.subBox:after{
	content:"";
	display:block;
	clear:both;
}

@media print, screen and (min-width: 768px) {
	#Header {
		padding: 17px 30px 0;
		min-width: 940px;
		height: 63px;
	}

	#GlobalNav{
		float: right;
		padding-top: 12px;
		width: 650px;
	}

	#Container,
	#Footer{
		min-width: 1000px;
	}

	#PageTopics #Container{
		margin-top: 84px;
		margin-bottom: 158px;
		width: 1000px;
	}

	#PageTopics #Main{
		float: left;
		width: 740px;
	}

	#PageTopics #Sub{
		float: right;
		width: 200px;
	}

	.innerBasic{
		margin:0 auto;
		width: 1000px;
	}
}

@media screen and (max-width: 767px) {
	#Header {
		position: relative;
		z-index: 11;
		height: 64px;
	}

	#GlobalNav{
		position: absolute;
		top: -608px;
		right: 0;
		z-index: 59;
		width: 100%;
		text-align: center;
		transition: top 0.5s;
		-moz-transition: top 0.5s;
		-webkit-transition: top 0.5s;
		-o-transition: top 0.5s;
		-ms-transition: top 0.5s;
	}

	#PageTopics #Container{
		margin-top: 60px;
	}

	#PageTopics #Main{
		margin-bottom: 59px;
		padding: 0 15px 0;
	}

	#PageTopics #Sub{
		padding: 0 15px 140px;
	}

	.innerBasic{
		margin:0 auto;
		padding: 0 15px;
	}
}

/*####################　ヘッダ　####################*/
#Header h1{
	float: left;
}

#Header h1 a{
	display: block;
	text-indent: -9999px;
}

@media print, screen and (min-width: 768px) {
	#Header h1{
		width: 256px;
	}

	#Header h1 a{
		width: 256px;
		height: 49px;
		background: url(../img/logo.png) no-repeat center center;
		background-size: 256px auto;
	}
}

@media screen and (max-width: 767px) {
	#Header h1{
		position: relative;
		z-index: 60;
		box-sizing: border-box;
		padding: 13px 15px 0;
		width: 100%;
		height: 64px;
		background-color: #fff;
	}

	#Header h1 a{
		width: 192px;
		height: 37px;
		background: url(../img/logo.png) no-repeat left center;
		background-size: 192px auto;
	}
}

/*####################　グローバルナビ　####################*/
#GlobalNav ul li a{
	text-decoration: none;
	color: #000;
}

@media print, screen and (min-width: 768px) {
	#Wall,
	.menuButton{
		display: none !important;
	}

	/* ナビゲーション */
	#GlobalNav ul{
		text-align: right;
		font-size: 0;
	}

	#GlobalNav ul li{
		display: inline-block;
		margin-left: 40px;
		text-align: right;
		font-size: 16px;
	}

	#GlobalNav ul li:first-of-type{
		margin-left: 0;
	}

	#GlobalNav ul li.menu06{
		display: none;
	}

	#PageIndex #GlobalNav ul li.menu01 a,
	#PageCompany #GlobalNav ul li.menu02 a,
	#PageKojin #GlobalNav ul li.menu03 a,
	#PageHoujin #GlobalNav ul li.menu04 a,
	#PageTopics #GlobalNav ul li.menu05 a,
	#PageContact #GlobalNav ul li.menu07 a{
		color: #b0b0b0;
	}

	#GlobalNav ul li a:hover{
		opacity: 0.8;
	}
}

@media screen and (max-width: 767px) {
	#Wall{
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		min-width: 100%;
		height: 0;
		background-color: #e1e1e1;
		opacity: 0.95;
		text-indent: -9999px;
		z-index: 10;
	}

	.active #Wall{
		display: block;
		height: 100%;
	}
	
	.menuButton{
		cursor: pointer;
		padding-top: 41px;
		width: 64px;
		height: 23px;
		background: url(../img/mark_01.png) no-repeat center 15px;
		background-size: 27px auto;
		line-height: 1;
		text-align: center;
		letter-spacing: 0.01em;
		font-size: 12px;
		color: #3c4da5;
	}

	#Header > .menuButton{
		position: absolute;
		z-index: 60;
		top: 0;
		right: 0;
		border-left: 1px solid #dedede;
	}

	#GlobalNav .menuButton{
		margin: 1px auto 0;
	}
	
	.active .menuButton{
		background: url(../img/mark_02.png) no-repeat center 14px;
		background-size: 20px auto;
	}
	
	.active #GlobalNav{
		top: 65px;
		transition: top 0.5s;
		-moz-transition: top 0.5s;
		-webkit-transition: top 0.5s;
		-o-transition: top 0.5s;
		-ms-transition: top 0.5s;
	}

	#GlobalNav ul li{
		border-bottom: 1px solid #dedede;
		background-color: #fff;
		text-align: left;
	}

	#GlobalNav ul li.menu07{
		border: none;
		padding: 15px;
		text-align: center;
	}

	#GlobalNav ul li a{
		display: block;
		padding: 17px 30px 16px 15px;
		background: url(../img/contents/arrow_01.png) no-repeat right center;
		background-size: 22px auto;
		line-height: 1.3;
		text-decoration: none;
		font-size: 16px;
	}

	#GlobalNav ul li.menu07 a{
		padding: 0;
		background-color: #F3A3AC;
		line-height: 50px;
		color: #fff;
	}

	#GlobalNav ul li.menu07 a span{
		padding-left: 35px;
		background: url(../img/icon_mail.png) no-repeat left center;
		background-size: 23px auto;
	}
}

/*####################　サブメニュー　####################*/
#Sub .subMenuBox:last-of-type{
	margin-bottom: 0;
}

#Sub .subMenuBox h3{
	line-height: 1.2;
	color: #333;
}

#Sub .subMenuBox ul{
	border: 1px solid #e3e3e3;
	background-color: #f6f7f8;
}

#Sub .subMenuBox ul li{
	line-height: 1.2;
}

#Sub .subMenuBox ul li:last-of-type{
	margin-bottom: 0;
}

#Sub .subMenuBox ul li a{
	text-decoration: none;
	color: #333;
}

#Sub .subMenuBox ul li.current a{
	color: #888;
}

@media print, screen and (min-width: 768px) {
	#Sub .subMenuBox{
		margin-bottom: 28px;
	}

	#Sub .subMenuBox h3{
		margin-bottom: 9px;
		font-size: 22px;
	}

	#Sub .subMenuBox ul{
		padding: 23px 19px 24px;
	}

	#Sub .subMenuBox ul li{
		margin-bottom: 17px;
		padding-left: 14px;
		background: url(../img/arrow_05.png) no-repeat left 7px;
		background-size: 5px auto;
		font-size: 18px;
	}

	#Sub .subMenuBox ul li a:hover{
		text-decoration: underline;
	}
}

@media screen and (max-width: 767px) {
	#Sub .subMenuBox{
		margin-bottom: 30px;
	}

	#Sub .subMenuBox h3{
		margin-bottom: 12px;
		font-size: 19px;
	}

	#Sub .subMenuBox ul{
		padding: 25px 19px 28px;
	}

	#Sub .subMenuBox ul li{
		margin-bottom: 22px;
		padding-left: 16px;
		background: url(../img/arrow_05.png) no-repeat left 8px;
		background-size: 5px auto;
		font-size: 16px;
	}
}

/*####################　コンテンツ部　####################*/

/*　パンくず
-------------------------------------*/
#TopicPath{
	text-align: left;
}

#TopicPath ol{
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	-webkit-text-overflow: ellipsis;
	list-style: none;
	font-family: helvetica,'arial black',arial,sans-serif;
}

#TopicPath ol:after{
	content:"";
	display:block;
	clear:both;
}

#TopicPath ol li{
	background: url(../img/arrow_03.png) no-repeat left center;
	background-size: 8px auto;
	color: #888;
	font-family: "游ゴシック体", 'YuGothic', "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", 'Meiryo', "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
	font-weight: 500;
}

#TopicPath ol li.home{
	padding-left: 0;
	background: none;
}

#TopicPath ol li a{
	text-decoration: none;
}

/*　メイン
-------------------------------------*/
/* メインイメージ */
#MainImg{
	position: relative;
	z-index: 0;
	border-bottom: 1px solid #ececec;
	width: 100%;
	background: url(../img/mainimage.jpg) no-repeat center center;
	background-size: cover;
}

#PageCompany #MainImg {
	background-image: url(../img/bg-company.jpg);
}

#MainImg h2{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-o-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	text-align: center;
	letter-spacing: 0.05em;
	color: #FFFFFF;
}



/* ページネーション */
#Main ul#PageNation{
	text-align: center;
	font-size: 0;
}

#Main ul#PageNation li{
	display: inline;
	color: #b7b7b7;
}

#Main ul#PageNation li a{
	text-decoration: none;
}

#Main ul#PageNation li.prev,
#Main ul#PageNation li.next{
	display: inline-block;
	text-align: center;
}

#Main ul#PageNation li.prev{
	text-align: left;
}

#Main ul#PageNation li.next{
	text-align: right;
}

#Main ul#PageNation li.prev a,
#Main ul#PageNation li.next a{
	display: block;
	border: 1px solid #d9d9d9;
	background-color: #fff;
	color: #333;
}

#Main ul#PageNation li.prev a span,
#Main ul#PageNation li.next a span{
	display: inline-block;
}

#Main ul#PageNation li.prev a span{
	background: url(../img/arrow_04_l.png) no-repeat left center;
	background-size: 8px auto;
}

#Main ul#PageNation li.next a span{
	background: url(../img/arrow_04_r.png) no-repeat right center;
	background-size: 8px auto;
}

/* アコーディオン */
#Main .showBox {
    margin-bottom: 60px;
    height: 300px;
    overflow-y: auto;
    border: 1px solid #ccc;
    padding: 20px;
	text-align: left !important;
}
#Main .showBox p{
	text-align: left !important;
}
/* パーツ */
#Main h3{
	text-align: center;
	color: #000;
}

#Main .leadBox h3{
	text-align: center;
}

#Main .leadBox h3 b{
	display: inline-block;
	box-sizing: border-box;
	border-radius: 2px;
	line-height: 1;
	text-align: center;
	color: #fff;
}

#Main .leadBox p{
	text-align: center;
	letter-spacing: 0.05em;
}

#Main .leadBox p:last-of-type{
	margin-bottom: 0;
}

#Main .flowBox ol{
	counter-reset:number;
	list-style: none;
	background: url(../img/contents/dot_01.gif) repeat-x left top;
	background-size: 1px auto;
}

#Main .flowBox ol li:nth-of-type(2n+1){
	background-color: #f9f9f9 !important;
}

#Main .flowBox ol li figure img{
	width: 100%;
	height: auto;
}

#PageHoujin #Main .flowBox ol li dl dt{
	color: #ee8394;
}

#PageKojin #Main .flowBox ol li dl dt{
	color: #ffb773;
	color: #ee8394;
}

#Main .flowBox ol li dl dt:before{
	counter-increment: number;
	content: 'STEP' counter(number);
	display: block;
	line-height: 1;
	text-align: center;
	color: #fff;
}

#PageHoujin #Main .flowBox ol li dl dt:before{
	background: url(../img/shape_01_b.png) no-repeat center center;
	background-size: 62px auto;
}

#PageKojin #Main .flowBox ol li dl dt:before{
	background: url(../img/shape_01_b.png) no-repeat center center;
	background-size: 62px auto;
}

#Main .flowBox ol li dl dd p:last-of-type{
	margin: 0;
}

#Main ul#EntryList li dl dt,
#Main ul#EntryList li dl dd,
#Main #EntryBox > dl dt{
	display: inline-block;
	font-size: 14px;
}

#Main ul#EntryList li dl dd a{
	color: #000;
}

#Main ul#EntryList li dl dd.title{
	letter-spacing: 0.045em;
}

#Main ul#EntryList li > p{
	color: #666;
}

#Main ul#EntryList li a{
	text-decoration: none;
}

#Main .date{
	letter-spacing: 0.045em;
	color: #888;
}

#Main p small{
	color: #888;
}

#Main p small:before{
	content: "※";
}

@media print, screen and (min-width: 768px) {

/*　パンくず
-------------------------------------*/
	#TopicPath{
		margin: 15px auto 0;
		width: 1000px;
	}
	
	#TopicPath ol{
		line-height: 1.4;
	}
	
	#TopicPath ol li{
		display: inline;
		padding: 0 6px 0 13px;
		font-size: 14px;
	}

	#TopicPath ol li a:hover{
		text-decoration: underline;
	}

/*　メイン
-------------------------------------*/
/* メインイメージ */
	#MainImg{
		min-width: 1000px;
		height: 160px;
	}

	#MainImg h2{
		font-size: 50px;
	}

/* ページネーション */
	#Main ul#PageNation li{
		padding-right: 27px;
		font-size: 20px;
	}

	.pageEntry #Main ul#PageNation li{
		font-size: 18px;
	}

	#Main ul#PageNation li.prev,
	#Main ul#PageNation li.next{
		width: 100px;
		font-size: 18px;
	}

	#Main ul#PageNation li.prev{
		padding: 0 44px 0 0;
	}
	
	#Main ul#PageNation li.next{
		padding: 0 0 0 30px;
	}

	#Main ul#PageNation li.prev a,
	#Main ul#PageNation li.next a{
		line-height: 36px;
	}

	#Main ul#PageNation li.prev a span{
		margin-left: 11px;
		padding-left: 28px;
	}

	#Main ul#PageNation li.next a span{
		margin-right: 11px;
		padding-right: 28px;
	}

	#Main ul#PageNation li a:hover{
		text-decoration: underline;
	}

	#Main ul#PageNation li.prev a:hover,
	#Main ul#PageNation li.next a:hover{
		opacity: 0.8;
		text-decoration: none;
	}

/* パーツ */
	#Main h3{
		margin-bottom: 50px;
		line-height: 1.2;
		text-align: center;
		font-size: 38px;
	}

	#Main .leadBox .innerBasic{
		padding-top: 66px;
		padding-bottom: 92px;
	}

	#Main .leadBox h3{
		margin-bottom: 10px;
		line-height: 60px;
		letter-spacing: 0.05em;
		font-size: 44px;
	}

	#Main .leadBox h3 b{
		margin-bottom: 21px;
		padding: 5px 17px 0;
		height: 32px;
		letter-spacing: 0.12em;
		font-size: 22px;
	}

	#Main .leadBox p{
		letter-spacing: 0.05em;
	}


	#Main .flowBox .innerBasic{
		padding-top: 95px;
		padding-bottom: 137px;
	}

	#Main .flowBox ol li{
		padding: 30px 30px 0;
	}

	#PageHoujin #Main .flowBox ol li{
		background: url(../img/contents/shape_02.gif) repeat-y 128px top,
url(../img/contents/dot_01.gif) repeat-x left bottom;
		background-size: 5px auto, 1px auto;
	}

	#PageKojin #Main .flowBox ol li{
		background: url(../img/contents/shape_02_b.gif) repeat-y 128px top,
url(../img/contents/dot_01.gif) repeat-x left bottom;
		background-size: 5px auto, 1px auto;
	}

	#Main .flowBox ol li:first-of-type{
		padding-top: 32px;
	}

	#PageHoujin #Main .flowBox ol li:first-of-type{
		background: url(../img/contents/shape_02_l.gif) no-repeat 128px bottom,
url(../img/contents/dot_01.gif) repeat-x left bottom;
		background-size: 5px auto, 1px auto;
	}

	#PageKojin #Main .flowBox ol li:first-of-type{
		background: url(../img/contents/shape_02_b_l.gif) no-repeat 128px bottom,
url(../img/contents/dot_01.gif) repeat-x left bottom;
		background-size: 5px auto, 1px auto;
	}

	#PageHoujin #Main .flowBox ol li:last-of-type{
		background: url(../img/contents/shape_02_l.gif) no-repeat 128px top,
url(../img/contents/dot_01.gif) repeat-x left bottom;
		background-size: 5px auto, 1px auto;
	}

	#PageKojin #Main .flowBox ol li:last-of-type{
		background: url(../img/contents/shape_02_b_l.gif) no-repeat 128px top,
url(../img/contents/dot_01.gif) repeat-x left bottom;
		background-size: 5px auto, 1px auto;
	}

	#Main .flowBox ol li:after{
		content:"";
		display:block;
		clear:both;
	}

	#Main .flowBox ol li figure{
		float: left;
		margin-bottom: 31px;
		width: 200px;
	}

	#Main .flowBox ol li dl{
		float: right;
		width: 700px;
	}

	#Main .flowBox ol li dl dt{
		margin-bottom: 2px;
		font-size: 32px;
	}

	#Main .flowBox ol li dl dt:before{
		margin: -1px 0 6px;
		padding: 5px 0 5px;
		width: 62px;
		height: 15px;
		font-size: 13px;
	}

	#Main .flowBox ol li dl dd{
		margin-bottom: 22px;
	}

	#Main .flowBox ol li dl dd p{
		line-height: 34px;
		font-size: 20px;
	}

	#Main ul#EntryList li dl,
	#Main #EntryBox > dl{
		font-size: 0;
	}

	#Main #EntryBox > dl{
		margin: 2px 0 21px;
	}

	#Main ul#EntryList li dl dt,
	#Main ul#EntryList li dl dd,
	#Main #EntryBox > dl dt{
		display: inline-block;
		font-size: 14px;
	}

	#Main p small{
		font-size: 18px;
	}
}

@media screen and (max-width: 767px) {

/*　パンくず
-------------------------------------*/
	#TopicPath{
		margin: 5px auto 0;
		padding: 0 15px;
	}
	
	#TopicPath ol{
		line-height: 34px;
	}
	
	#TopicPath ol li{
		display: inline;
		padding: 0 8px 0 14px;
		font-size: 14px;
	}

/*　メイン
-------------------------------------*/
/* メインイメージ */
	#MainImg{
		height: 80px;
	}

	#MainImg h2{
		font-size: 36px;
		width: 290px;
	}

/* ページネーション */
	#Main ul#PageNation{
		position: relative;
		height: 86px
	}

	#Main ul#PageNation li{
		padding: 0 11px;
		font-size: 17px;
	}

	.pageEntry #Main ul#PageNation li{
		font-size: 17px;
	}

	#Main ul#PageNation li.prev,
	#Main ul#PageNation li.next{
		position: absolute;
		padding: 0;
		bottom: 0;
	}

	#Main ul#PageNation li.prev{
		left: 0;
	}
	
	#Main ul#PageNation li.next{
		right: 0;
	}

	#Main ul#PageNation li.prev a,
	#Main ul#PageNation li.next a{
		width: 90px;
		line-height: 36px;
		font-size: 15px;
	}

	#Main ul#PageNation li.prev a span{
		margin-left: 11px;
		padding-left: 25px;
	}

	#Main ul#PageNation li.next a span{
		margin-right: 11px;
		padding-right: 25px;
	}

/* パーツ */
	#Main h3{
		margin-bottom: 34px;
		line-height: 40px;
		text-align: center;
		font-size: 36px;
	}

	#Main .leadBox .innerBasic{
		padding-top: 46px;
		padding-bottom: 53px;
	}

	#Main .leadBox h3{
		margin-bottom: 13px;
		line-height: 45px;
		letter-spacing: 0.05em;
		font-size: 36px;
	}

	#Main .leadBox h3 b{
		margin-bottom: 20px;
		padding: 4px 12px 0;
		height: 28px;
		font-feature-settings: normal;
		-moz-font-feature-settings: normal;
		-webkit-font-feature-settings: normal;
		letter-spacing: 0.12em;
		font-size: 19px;
	}

	#Main .leadBox p{
		letter-spacing: 0.05em;
	}


	#Main .flowBox .innerBasic{
		padding-top: 57px;
		padding-bottom: 76px;
	}

	#Main .flowBox ol{
		margin: 0 -15px;
	}

	#Main .flowBox ol li{
		padding: 26px 15px 19px;
		background: url(../img/contents/dot_01.gif) repeat-x left bottom;
		background-size: 1px auto;
	}

	#Main .flowBox ol li:first-of-type{
		padding-top: 26px;
	}

	#Main .flowBox ol li figure{
		margin: 0 auto 15px;
		width: 200px;
	}

	#Main .flowBox ol li dl dt{
		font-size: 28px;
	}

	#Main .flowBox ol li dl dt:before{
		margin: -1px 0 3px;
		padding: 5px 0 5px;
		width: 62px;
		height: 15px;
		font-size: 14px;
	}

	#Main .flowBox ol li dl dd p{
		line-height: 29px;
		font-size: 18px;
	}

	#Main p small{
		font-size: 15px;
	}
}


/*####################　フッタ　####################*/
#Footer .pageTop{
	position: fixed;
	right: 0;
	bottom: 0;
	display: none;
	width: 50px;
	height: 50px;
	background: url(../img/arrow_01.png) no-repeat center center rgba(131, 134, 150, 0.8);
	background-size: 20px auto;
	text-indent: -9999px;
}

#Footer .wrapBox01 .textBox h2 a{
	display: block;
	text-indent: -9999px;
}

#Footer .wrapBox01 .textBox dl{
	font-size: 14px;
}

#Footer .wrapBox01 .textBox dl dt{
	font-weight: bold;
}

#Footer .wrapBox02{
	background-color: #333;
}

#Footer .wrapBox02 .subBox{
	color: #656565;
}

#Footer .wrapBox02 .subBox h2{
	display: none;
}

#Footer .wrapBox02 .subBox address,
#Footer .wrapBox02 .subBox small{
	display: inline;
}

@media print, screen and (min-width: 768px) {
	#Footer .wrapBox01{
		padding: 43px 20px 40px;
		min-width: 960px;
	}

	#Footer .wrapBox01 .textBox{
		float: left;
		width: 500px;
	}

	#Footer .wrapBox01 .textBox:after{
		content:"";
		display:block;
		clear:both;
	}

	#Footer .wrapBox01 .textBox h2{
		float: left;
		padding-top: 7px;
		width: 100px;
	}

	#Footer .wrapBox01 .textBox h2 a{
		float: left;
		width: 100px;
		height: 66px;
		background: url(../img/ft-logo.png) no-repeat center center;
		background-size: 100px auto;
	}

	#Footer .wrapBox01 .textBox dl{
		float: left;
		margin-left: 21px;
		padding-top: 8px;
		line-height: 24px;
	}

	#Footer .wrapBox01 #FooterNav{
		float: right;
		width: 650px;
	}

	#Footer .wrapBox01 #FooterNav ul{
		font-size: 0;
		line-height: 1;
		text-align: right;
	}

	#Footer .wrapBox01 #FooterNav ul li{
		display: inline-block;
		padding-right: 16px;
		font-size: 14px;
	}

	#Footer .wrapBox01 #FooterNav ul li:nth-last-child(2){
		padding-right: 0;
	}

	#Footer .wrapBox01 #FooterNav ul li.menu07{
		margin-left: 23px;
		padding: 0;
		width: 240px;
		text-align: center;
	}

	#Footer .wrapBox01 #FooterNav ul li:before{
		content: "｜";
		padding-right: 16px;
		color: #c9c9c9;
	}

	#Footer .wrapBox01 #FooterNav ul li:first-of-type:before,
	#Footer .wrapBox01 #FooterNav ul li.menu07:before{
		content: normal;
	}

	#Footer .wrapBox01 #FooterNav ul li a{
		text-decoration: none;
		color: #000;
	}

	#Footer .wrapBox01 #FooterNav ul li a:hover{
		text-decoration: underline;
	}

	#Footer .wrapBox01 #FooterNav ul li.menu07 a{
		display: block;
		background-color: #F3A3AC;
		line-height: 50px;
		font-size: 16px;
		color: #fff;
	}

	#Footer .wrapBox01 #FooterNav ul li.menu07 a:hover{
		opacity: 0.8;
		text-decoration: none;
	}

	#Footer .wrapBox01 #FooterNav ul li.menu07 a span{
		padding-left: 36px;
		background: url(../img/icon_mail.png) no-repeat left center;
		background-size: 23px auto;
	}

	#Footer .wrapBox02{
		padding: 18px 80px 0 30px;
		min-width: 890px;
		height: 32px;
	}

	#Footer .wrapBox02 .subBox{
		float: left;
		width: 500px;
		line-height: 1;
	}

	#Footer .wrapBox02 .subBox address,
	#Footer .wrapBox02 .subBox small{
		font-size: 10px;
	}
	
	#Footer .wrapBox02 ul.pc_display{
		float: right;
		width: 300px;
		text-align: right;
		font-size: 12px;
	}

	#Footer .wrapBox02 ul.pc_display li a{
		text-decoration: none;
		color: #bfbfbf;
	}

	#Footer .wrapBox02 ul.pc_display li a:hover{
		text-decoration: underline;
	}
}

@media screen and (max-width: 767px) {
	#Footer .wrapBox01{
		padding: 40px 15px 34px;
	}

	#Footer .wrapBox01 .textBox h2{
		margin: 0 auto 18px;
		width: 75px;
	}

	#Footer .wrapBox01 .textBox h2 a{
		width: 75px;
		height: 50px;
		background: url(../img/ft-logo.png) no-repeat center center;
		background-size: 75px auto;
	}

	#Footer .wrapBox01 .textBox dl{
		line-height: 21px;
		text-align: center;
	}

	#Footer .wrapBox02{
		padding: 13px 15px 0;
		height: 37px;
	}

	#Footer .wrapBox02 .subBox{
		line-height: 13px;
		letter-spacing: 0.05em;
	}

	#Footer .wrapBox02 .subBox address,
	#Footer .wrapBox02 .subBox small{
		font-size: 9px;
	}
}

.send-box {
	text-align: center;
}
.doui {
			text-align: center;
			font-size: 1rem !important;
			margin-bottom: 20px !important;
		}

/*end*/

#PageHoujin #MainImg{
	background: url(../img/s-houjin-main.jpg) no-repeat center center;
	background-size: cover;
}

#PageHoujin #MainImg h2{
	color: #000;
}

#PageHoujin #Main .leadBox h3,
#PageKojin #Main .leadBox h3 {
	color: #ee8394;
}

#PageHoujin #Main .leadBox h3 b,
#PageKojin #Main .leadBox h3 b { 
	background-color: #ee8394;
}

#PageHoujin #Main #ContBox02,
#PageHoujin #Main #ContBox05 {
	border-top: 1px solid #ededed;
	background-color: #f4b4c3;
}

/*
#PageHoujin #Main #ContBox01 {
  background: url(../img/s-houjin-main.jpg) no-repeat center center;
  background-size: cover;
  position: relative;
  z-index: 0;
  overflow: hidden;
}
*/

#PageKojin #Main #ContBox01 {
  background: url(../img/s-kojin-main.jpg) no-repeat center center;
  background-size: cover;
  position: relative;
  z-index: 0;
  overflow: hidden;
}

#PageKojin #Main #ContBox01:before,
#PageHoujin #Main #ContBox01:before {
  content: '';
  background: inherit;
  -webkit-filter: blur(5px);
  -moz-filter: blur(5px);
  -o-filter: blur(5px);
  -ms-filter: blur(5px);
  filter: blur(5px);
  position: absolute;
  top: -5px;
  left: -5px;
  right: -5px;
  bottom: -5px;
  z-index: -1;
}

#PageKojin #Main #ContBox03,
#PageKojin #Main #ContBox05 {
	border-top: 1px solid #ededed;
	background-color: #f4b4c3;
}

#PageKojin #Main #ContBox02 .innerBasic, 
#PageKojin #Main #ContBox03 .innerBasic {
  padding-top: 95px;
  padding-bottom: 92px;
}

#PageKojin #Main #ContBox05 .innerBasic {
  padding-top: 95px;
  padding-bottom: 100px;
}


#PageKojin #Main #ContBox02 ol {
  display: flex;
  justify-content: space-between;
  list-style: none;
  counter-reset: number;
}

#PageKojin #Main #ContBox02 ol li {
	width: 308px;
}

#PageKojin #Main #ContBox02 ol li figure {
	margin-bottom: 30px;
}

#PageKojin #Main #ContBox02 ol li dl dt {
  margin-bottom: 12px;
  line-height: 40px;
  font-size: 30px;
}

#PageKojin #Main #ContBox02 ol li dl dt:before {
  counter-increment: number;
  content: 'メリット' counter(number);
  display: block;
  box-sizing: border-box;
  padding: 0px 18px 24px 0px;
  height: 24px;
  font-size: 18px;
  line-height: 1;
  text-align: left;
  font-weight: bold;
  color: #f4b4c3;
  border-bottom: 3px solid;
}

#PageKojin #Main #ContBox02 ol li dl dt:before {
  margin-bottom: 15px;
}

#PageKojin #Main #ContBox02 ol li dl dd p {
  line-height: 32px;
  font-size: 18px;
}

#PageKojin #Main #ContBox02 ol li dl dd p:last-of-type {
  margin-bottom: 0;
}

#PageKojin #Main #ContBox03 .kigyo-list {
	margin: 60px auto 0;
}

#PageKojin #Main #ContBox03 .kigyo-list ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#PageKojin #Main #ContBox03 .kigyo-list ul li {
	width: 48%;
}


#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box {
  position: relative;
  padding: 20px 30px;
  background: #ffffff;
  margin-bottom: 40px;
}

#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box .textarea {
  margin-bottom: 15px;
  line-height: 1.84;
}

#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box .textarea .label {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.5;
}

#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box .textarea h3 {
  margin: 5px 0 15px;
  text-align: left;
  color: #22ac38;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.25;
}

#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box th,
#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box td {
  padding: 15px 5px 14px;
  border-top: #d5d5d5 solid 2px;
  border-bottom: #d5d5d5 solid 2px;
  line-height: 1.84;
  vertical-align: top;
}

#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box th {
  width: 90px;
  font-weight: bold;
}

#PageKojin #Main #ContBox03 .kigyo-list .kigyo-box td {
  padding: 15px 5px 14px;
  border-top: #d5d5d5 solid 2px;
  border-bottom: #d5d5d5 solid 2px;
  line-height: 1.84;
  vertical-align: top;
}


@media print, screen and (max-width: 768px) { 
#PageKojin #Main #ContBox02 .innerBasic, 
#PageKojin #Main #ContBox03 .innerBasic {
  padding-top: 57px;
  padding-bottom: 61px;
}

#PageKojin #Main #ContBox02 ol {
	flex-direction: column;
}

#PageKojin #Main #ContBox02 ol li {
	width: auto;
	margin-bottom: 20px;
}

#PageKojin #Main #ContBox02 ol li dl dt {
  margin-bottom: 12px;
  line-height: 39px;
  font-size: 28px;
}

#PageKojin #Main #ContBox02 ol li dl dt:before {
  margin-bottom: 8px;
  font-feature-settings: normal;
  -moz-font-feature-settings: normal;
  -webkit-font-feature-settings: normal;
}

#PageKojin #Main #ContBox02 ol li dl dd p {
  line-height: 29px;
  font-size: 18px;
}

#PageKojin #Main #ContBox03 .kigyo-list {
  margin: 40px auto 0;
}
#PageKojin #Main #ContBox03 .kigyo-list ul {
  flex-direction: column;
}
#PageKojin #Main #ContBox03 .kigyo-list ul li {
  width: 100%;
}
}


#PageHoujin #Main #ContBox02 ol{
	counter-reset:number;
	list-style: none;
}

#PageHoujin #Main #ContBox02 ol > li:last-of-type{
	margin: 0;
}

#PageHoujin #Main #ContBox02 ol li figure img{
	width: 100%;
	height: auto;
	box-shadow: 0px 5px 3px rgba(0,0,0,0.2);
	border: 5px solid #FFF;
}

#PageHoujin #Main #ContBox02 ol li dl dt{
	position: relative;
}

#PageHoujin #Main #ContBox02 ol li dl dt:before{
	position: absolute;
	left: 0;
	counter-increment: number;
	content: counter(number) '.';
	font-weight: bold;
	color: #ee8394;
}

#PageHoujin #Main #ContBox02 ol ul{
	border-top: 1px solid #d7deeb;
	border-bottom: 1px solid #d7deeb;
	font-size: 0;
}

#PageHoujin #Main #ContBox02 ol ul li{
	position: relative;
}

#PageHoujin #Main #ContBox02 ol ul li:before{
	content: "";
	position: absolute;
	left: 0;
	border-radius: 50%;
	width: 6px;
	height: 6px;
	background-color: #51c7fd;
}

#PageHoujin #Main #ContBox03 h3{
	text-align: left;
	color: #ffffff;
}

#PageHoujin #Main #ContBox03 p:last-of-type{
	margin-bottom: 0;
}

@media print, screen and (min-width: 768px) {
	#PageHoujin #MainImg{
		height: 380px;
	}

	#PageHoujin #Main #ContBox02 .innerBasic,
	#PageHoujin #Main #ContBox05 .innerBasic{
		padding-top: 95px;
		padding-bottom: 100px;
	}

	#PageHoujin #Main #ContBox02 ol:after{
		content:"";
		display:block;
		clear:both;
	}

	#PageHoujin #Main #ContBox02 ol > li{
		/*float: left; */
		margin-right: 40px;
		margin-bottom: 40px;
		width: 100%;
		display: flex;
	}

	#PageHoujin #Main #ContBox02 ol li figure{
		margin-bottom: 25px;
		width: 350px;
		flex-shrink: 0;
		margin-right: 40px;
	}

	#PageHoujin #Main #ContBox02 ol li dl dt{
		margin-bottom: 13px;
		padding-left: 59px;
		line-height: 48px;
		letter-spacing: 0.2em;
		font-size: 36px;
	}

	#PageHoujin #Main #ContBox02 ol li dl dt:before{
		top: -3px;
		font-size: 56px;
	}

	#PageHoujin #Main #ContBox02 ol li dl dd{
		line-height: 34px;
		font-size: 20px;
	}

	#PageHoujin #Main #ContBox02 ol ul{
		margin-top: 23px;
		padding: 15px 0 12px;
	}

	#PageHoujin #Main #ContBox02 ol ul li{
		display: inline-block;
		margin-bottom: 3px;
		padding-left: 15px;
		font-size: 18px;
	}

	#PageHoujin #Main #ContBox02 ol ul li:nth-of-type(2n+1){
		width: 255px;
	}

	#PageHoujin #Main #ContBox02 ol ul li:before{
		top: 10px;
	}

	#PageHoujin #Main #ContBox03{
		height: 382px;
		padding:0;
		background: url(../img/photo_03_wall.png) no-repeat center center #ee8394;
		background-size: cover;
	}

	#PageHoujin #Main #ContBox03 .textBox{
		float: left;
		padding: 55px 40px 0 0;
		width: 460px;
		background-color: #ee8394;
	}

	#PageHoujin #Main #ContBox03 .textBox h3{
		margin-bottom: 11px;
		line-height: 36px;
		font-size: 26px;
	}

	#PageHoujin #Main #ContBox03 .textBox p{
		line-height: 32px;
		font-size: 18px;
	}
}

@media screen and (max-width: 767px) {
	#PageHoujin #MainImg{
		height: 190px;
	}

	#PageHoujin #Main #ContBox02 .innerBasic,
	#PageHoujin #Main #ContBox05 .innerBasic{
		padding-top: 57px;
		padding-bottom: 61px;
	}

	#PageHoujin #Main #ContBox02 h3{
		margin-bottom: 39px;
	}

	#PageHoujin #Main #ContBox02 ol > li{
		margin-bottom: 33px;
	}

	#PageHoujin #Main #ContBox02 ol li figure{
		margin-bottom: 22px;
	}

	#PageHoujin #Main #ContBox02 ol li dl dt{
		margin-bottom: 13px;
		padding-left: 48px;
		line-height: 39px;
		letter-spacing: 0.2em;
		font-size: 30px;
	}

	#PageHoujin #Main #ContBox02 ol li dl dt:before{
		top: -1px;
		font-size: 45px;
	}

	#PageHoujin #Main #ContBox02 ol li dl dd{
		line-height: 29px;
		font-size: 18px;
	}

	#PageHoujin #Main #ContBox02 ol ul{
		margin-top: 17px;
		padding: 21px 0 14px;
	}

	#PageHoujin #Main #ContBox02 ol ul li{
		margin-bottom: 5px;
		padding-left: 13px;
		font-size: 17px;
	}

	#PageHoujin #Main #ContBox02 ol ul li:before{
		top: 10px;
	}

	#PageHoujin #Main #ContBox03{
		background-color: #ee8394;
	}

	#PageHoujin #Main #ContBox03 .innerBasic{
		padding-top: 45px;
	}

	#PageHoujin #Main #ContBox03 .textBox{
		margin-bottom: 36px;
	}

	#PageHoujin #Main #ContBox03 .textBox h3{
		margin-bottom: 17px;
		line-height: 37px;
		font-size: 28px;
	}

	#PageHoujin #Main #ContBox03 .textBox p{
		line-height: 28px;
		font-size: 17px;
	}

	#PageHoujin #Main #ContBox03 figure{
		margin: 0 -15px;
	}

	#PageHoujin #Main #ContBox03 figure img{
		width: 100%;
		height: auto;
	}
}

.wrapper section, #index .wrapper section.news {
  padding: 0;
}

*, *::before, *::after {
	box-sizing: inherit;
}

@media print, screen and (min-width: 768px) {
	#Main .linkList{
		margin: 84px auto 14px;
		width: 1000px;
	}
	#Main .contBox:last-of-type + .linkList{
		margin-bottom: 145px;
	}

	#Main .linkList h3{
		margin-bottom: 21px;
		font-size: 26px;
	}

	#Main .linkList ul:after{
		content:"";
		display:block;
		clear:both;
	}

	#Main .linkList ul li{
		/*float: left;*/
		margin-right: 1px;
		/*width: 249px;*/
		width: 350px;
		margin:0 auto;
		height: 60px;
		font-size: 18px;
	}

	#Main .linkList ul li a{
		padding: 17px 30px;
		  display: block;
		  text-align:center;
  text-decoration: none;
  color: #333;
	}

	#Main .linkList ul li.list01 a{
		background: #f1f1f1;
	}

	#Main .linkList ul li.list02 a{
		background: #f1f1f1;
	}

	#Main .linkList ul li.list03 a{
		background:#f1f1f1;
	}

	#Main .linkList ul li a:hover{
		opacity: 0.8;
	}

	#Main .linkList ul li.list01 a,
	#Main .linkList ul li.list02 a,
	#Main .linkList ul li.list03 a,
	#Main .linkList ul li.list04 a{
		opacity: 1;
	}
}


