@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,500,700,900&display=swap');
@import url('https://fonts.googleapis.com/css?family=Montserrat:300,400,500,700|Roboto:300,400,500,700&display=swap');
@import url('https://fonts.googleapis.com/css?family=Noto+Serif+JP:400,500,700&display=swap');
@import url('reset.css');
/*
font-family: 'Roboto', sans-serif;
font-family: 'Montserrat', sans-serif;
font-family: 'Noto Serif JP', serif;
*/
/*------------------------------------
　　　　　　　　　common
------------------------------------*/
body {
	font-family:"Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	color: #555;
	font-size: 100%;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	position:relative;
}
	@media screen and (max-width: 960px) {
		body{
			font-size: .8125em;
		}
	}
	@media screen and (max-width: 568px) {
		.sp-block{
			display: block;
		}
		.inline{
			display: none;
		}
		.txt_c_sp{
			text-align: center;
		}

	}
	@media screen and (max-width: 374px) {
		.sp-small-block{
			display: block;
		}

	}

a {
	color: #555;
	text-decoration: none;
}
a.link,
div.link{
	color: #008e4e;
	text-decoration: underline;
}
img{
	max-width: 100%;
	height: auto;
}

/* megamenu
--------------------------------------*/
.description{
	padding: 0.25em 1em;
	background: #af7a22;
	font-size: .8em;
	color: #fff;
}
.gnav-wrap{
	text-align: left;
	width: 100%;
	font-size: 90%;
	position: fixed;
	z-index: 777;
	background: #fff;
	box-shadow: 0 0 0.25em rgba(0,0,0,0.2);
	-moz-box-shadow: 0 0 0.25em rgba(0,0,0,0.2);
	-webkit-box-shadow: 0 0 0.25em rgba(0,0,0,0.2);
}
.gnav-wrap a{
	color: #444;
}
.meganavigation {
	margin: 0 auto;
	display: table;
}
.meganavigation > li {
	display: table-cell;
}
.meganavigation > li:hover .menu {
	display: block;
}
.meganavigation > li > a,
.meganavigation > li > span {
	display: block;
	transition: all .2s ease-in;
	position: relative;
	padding: 1.0em 1.75em;
}
.meganavigation > li > a:hover,
.meganavigation > li > span:hover {
	color: #af7a22;
}
.meganavigation > li > a:before,
.meganavigation > li > span:before{
	position: absolute;
	top: 50%;
	left: 0;
	width: 1px;
	height: 10px;
	content: "";
	background: #ddd;
	margin-top: -5px;
}
.meganavigation > li:first-child > a{
	padding-left: 0;
}

.meganavigation > li:first-child > a:before{
	position: relative;
	background: none;
}
.meganavigation > li:last-child > a:before{
	position: relative;
	background: none;
}


.meganavigation .menu {
	display: none;
	overflow: hidden;
	position: absolute;
	padding: .25em 2.25em .75em 2em;
	background:#fff;
	box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
	-moz-box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
	-webkit-box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
}

.meganavigation .menu ul{
	margin: 0 auto;
}
.meganavigation .menu li{
	padding: .75em 0;
}
.meganavigation .menu a {
	color: #444444;
	display: inline-block;
	position: relative;
	padding-left: 2em;
}
.meganavigation .menu a:before {
	content: '';
	width: 12px;
	height: 12px;
	background: #008e4e;
	border-radius: 50%;
	position: absolute;
	top: 50%;
	left: 0;
	margin-top: -5px;
}
.meganavigation .menu a:after {
	content: '';
	width: 0;
	height: 0;
	border: solid 4px transparent;
	border-left: solid 4px #fff;
	position: absolute;
	top: 50%;
	left: 4px;
	margin-top: -3px;
}
.meganavigation .recruit{
	position: relative;
}
.meganavigation .recruit a{
	background-color: #008e4e;
	color: #fff;
    
	letter-spacing: 0;
	border-bottom: none;
	display: block;
	transition: all .2s ease-in;
	
	padding: .3em 1.75em ;
	
}
.meganavigation .recruit a:hover{
	color: #af7a22;
}
.meganavigation li.recruit > a:after{
	background: none;
}

	@media screen and (max-width: 768px) {
		.gnav-wrap{
			font-size: 100%;
			position: static;
		}

		.meganavigation {
			margin: 0 auto;
			display: block;
			position: relative;
			padding-bottom: 12em;
		}
		.meganavigation > li {
			display: block;
			padding: 0;
		}
		.meganavigation > li:first-child > a{
			padding-left: 1em;
			border-top: none;
		}
		.meganavigation > li > a{
			padding: .75em;
			border-bottom: 1px solid #d0d0d0;
			display: block;
			position: relative;
		}
		.meganavigation > li> a:after{
			content: '';
			width: .3em;
			height: .3em;
			border: 0;
			border-top: solid 2px #d0d0d0;
			border-right: solid 2px #d0d0d0;
			position: absolute;
			top: 50%;
			right: .1em;
			margin-top: -3px;
			transform: rotate(45deg);
		}
		.meganavigation > li > span {
			color: #444;
			padding: .75em .75em .5em .75em;
		}
		.meganavigation > li > a:hover,
		.meganavigation > li > span:hover {
			color: #666;
		}
		.meganavigation > li > a:before,
		.meganavigation > li > span:before{
			position: static;
			top: none;
			left: none;
			width: 0;
			height: 0;
			background: none;
			margin-top: 0;
		}
		.meganavigation .recruit a{
	        background-color: #008e4e;
	        color: #fff;
    
	        letter-spacing: 0;
	        border-bottom: none;
	        display: block;
	        transition: all .2s ease-in;
	        padding: .75em .75em .5em .75em;
}

		.meganavigation .menu {
			display: block;
			overflow: hidden;
			width: 100%;
			left: none;
			position: static;
			background:#fefefe;
			box-shadow: none;
			-moz-box-shadow: none;
			-webkit-box-shadow: none;
			margin-top: 0.5em;
			font-size: 0.9em;
			padding: 0;
		}
		.meganavigation .menu ul{
			display: block;
			padding: 0;
		}
		.meganavigation .menu li{
			width: 100%;
			text-align: left;
			padding: 0.75em 1em;
			border-bottom: 1px solid #e0e0e0;
		}
		.meganavigation .menu a {
			display: block;
		}
	}
	@media screen and (max-width: 568px) {
		.description{
			height: .7em;
		}
		.description span{
			display: none;
		}
	}
/* header
--------------------------------------*/
.header{
	width: 91%;
	max-width: 1280px;
	margin: 0 auto;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: flex-end;
}
.header h1 a{
	width: 346px;
	height: 81px;
	text-indent: -9999px;
	display: block;
	background: url(../images/common/logo.svg) no-repeat top left;
	position: relative;
}
.header h2{
	width: calc(100% - 346px);
	text-align: right;
	position: relative;
	top: -3px;
}
	@media screen and (max-width: 768px) {
		.header{
			display: block;
			line-height: 1.3;
			font-size: 0.85em;
		}
		.header h1 a{
			width: 256px;
			height: 60px;
			margin: 0 auto;
			text-align: center;
			position: relative;
			top: -3px;
		}
		.header h2{
			width: 100%;
			text-align: center;
		}
	}
	@media screen and (max-width: 374px) {
		.header h1 a{
			width: 188px;
			height: 44px;
		}
	}

header h2 .teladress{
	display: inline-block;
}

.teladress{
	margin-left: 0.2em;
}
.teladress span{
	padding-left: 14px;
	background: url(../images/common/tel.svg) no-repeat center left;
	background-size: 10px auto;
	font-family: 'Roboto', sans-serif;
	font-weight: 500;
	font-size: 1.5em;
}

/* 下層　↓↓↓↓ */
#content--sub .teladress{
	display: inline-block;
}
#content--sub .teladress span{
	font-size: 1.3em;
}
.layout-sub .header{
	position: relative;
	z-index: 666;
	top: 6.25em;
	margin-bottom: 7.25em;
}
	@media screen and (max-width: 768px) {
		.layout-sub .header{
			position: static;
			top: 0;
			margin-bottom: 0;
			padding: 1em 0 .75em;
		}
	}

/*-----------------------------
　　　　　　　　　footer
------------------------------------*/
footer{
	border-top: 1px solid #e7e7e7;
	padding: 2em 0 1em 0;
	font-size: .8em;
	line-height: 1.4;
}
.footerinner{
	width: 91%;
	margin: 0 auto;
}
footer .footerbody{
	margin: 0 auto 1em;
	display: table;
	table-layout: fixed;
}
footer .logo{
	background: url("../images/common/logo-footer.svg") no-repeat center;
	width: 232px;
	height: 55px;
	text-indent: -9999px;
	display: table-cell;
}
footer .adress{
	padding-left: 2em;
	display: table-cell;
	vertical-align: middle;
}

	@media screen and (max-width: 768px) {
		footer .footerbody{
			display: block;
			width: 100%;
			text-align: center;
		}
		footer .logo{
			width: 171px;
			height: 40px;
			display: block;
			margin: 0 auto .5em auto;
		}
		footer .adress{
			width: 100%;
			padding-left: 0;
			display: block;
		}
	}

.sns {
	text-align: center;
	padding:.5em 0 2em 0;
}
.sns a{
	font-size: 0.9em;
	font-weight: bold;
	color: #fff;
	width: 192px;
	padding: 0.5em 1em;
	display: inline-block;
	text-align: left;
	border-radius: .5em;
	-moz-border-radius:.5em;
	-webkit-border-radius: .5em;
}
.sns  a.fb{
	background: #0c3e7f url("../images/common/icon-fb.png") no-repeat 95% center;
	background-size:  auto 1em;
}
.sns  a.insta{
	background: #008e4e url("../images/common/icon-insta.png") no-repeat 95% center;
	background-size: auto 1em;
}
.sns  a.trimblog{
	background: #af7a22 url("../images/common/icon-trim.png") no-repeat 95% center;
	background-size: auto 1em;
}
	@media screen and (max-width: 568px) {
		.sns {
			display: -webkit-flex;
			display: -moz-flex;
			display: -ms-flex;
			display: -o-flex;
			display: flex;
			flex-wrap:wrap;
			padding:1em 0 3em 0;
		}
		.sns a{
			width: 33.33%;
			border-radius: 0;
			-moz-border-radius:0;
			-webkit-border-radius: 0;
			padding: 2em 0 2em .75em;
			font-size: 0.75em;
		}
	}
.footer-menu{
	text-align: center;
	font-size: 0.8em;
	padding-bottom: 4em;
}
.copylight{
	color: #999;
	text-align: center;
	font-size: 0.6em;
	padding-bottom: 1em;
}


/* flex 
--------------------------------------*/
.flex{
	width: 100%;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
}
.wrap{
	flex-wrap:wrap;
}
/*中央配置*/
.item_center{
	-webkit-align-items: center;
	justify-content: center;
	align-items: center;
}
/*端は除いて、間をあける*/
.between{
	-webkit-justify-content: space-between;
	justify-content: space-between;
}



/* modal 
--------------------------------------*/
#modal{
	display: none;
}
.modal_title{
	font-size: 1.25em;
	font-weight: bold;
	margin-bottom: 1em;
	color: #008e4e;
}
.midori500{
	font-weight: 500;
	color: #008e4e;
}