/* Scss Document */
#slide {
	overflow: hidden;
	border-bottom: #FFF 10px solid;
}

#slide .inner {
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

#slide .inner img {
	width: 100%;
	height: auto;
}

#slide .bx-viewport {
	overflow: visible !important;
	border: none;
	box-shadow: none;
	left: 0;
}

#slide .bx-wrapper {
	margin-bottom: 0;
	position: relative;
}

.bx-viewport {
	z-index: 0;
}

.bx-controls {
	z-index: 1;
	top: ;
}

.bx-pager {
	position: absolute;
	bottom: .5em;
	left: 0;
	right: 0;
	width: 50%;
	margin: 0 auto;
	text-align: center;
}

.bx-pager-item {
	padding: 0 .25em;
	display: inline-block;
	text-align: center;
}

.bx-pager-item .bx-pager-link {
	border-radius: 6px;
	background: #fff;
	display: block;
	width: 12px;
	height: 12px;
	overflow: hidden;
	text-indent: -1em;
}

.bx-pager-item .bx-pager-link.active {
	background: #006835;
}

.bx-wrapper .bx-prev {
	left: -1px;
	background: url(../images/ico_prev.png) no-repeat;
}

.bx-wrapper .bx-next {
	right: 0;
	background: url(../images/ico_next.png) no-repeat;
}

.bx-wrapper .bx-controls-direction a {
	position: absolute;
	top: 50%;
	margin-top: -22px;
	outline: 0;
	width: 45px;
	height: 45px;
	text-indent: -9999px;
	z-index: 9999;
}

.contents_list {
	display: flex;
	justify-content: center;
}

.contents_list li {
	width: 273px;
	padding-left: 16px;
	text-align: center;
}

.contents_list li:nth-child(4n+1) {
	padding-left: 0;
}

.contents_list li a:hover {
	opacity: 0.6;
}

.contents_list h3 {
	margin-bottom: 10px;
	font-size: 1.8rem;
}

.contents_list img {
	margin-bottom: 15px;
}

.contents_list p {
	font-size: 1.5rem;
	letter-spacing: 0;
	line-height: 1.6;
}

.top_contets {
	padding: 40px 0;
	border-bottom: #FFF 10px solid;
	box-shadow: 0 7px 15px #CCC inset;
}

.top_contets h2 {
	margin-bottom: 40px;
	text-align: center;
}

.title_underline {
	padding-bottom: 1.5em;
	font-size: 2.2rem;
	font-weight: bold;
	background: url(../images/line_title.png) no-repeat center bottom;
	letter-spacing: .1em;
	line-height: 1.3;

}

.title_underline.-white {
	color: #fff;
	background: url(../images/line_title_w.png) no-repeat center bottom;
}


.btn {
	margin-right: auto;
	margin-left: auto;
	width: 308px;
	text-align: center;
}

#advantage {
	background: url(../images/bg_advantage.jpg) center repeat-y;
}

#advantage .contents_list {}

.content_list_img {
	position: relative;

}

.content_list_img .en {
	font-family: "Oswald", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 2.4rem;
	color: #fff;
	position: absolute;
	bottom: 3em;
	width: 100%;
	text-align: center;
	letter-spacing: .1em;
}

#information {
	background: url(../images/bg_advantage.jpg) no-repeat center top;

}

#information .flex_wrap {
	justify-content: space-between;
}

#information .facebook {
	width: 470px;
	height: 400px;
	background: #CCC;
}

#information .info {
	width: 640px;
}

#information .title_info {
	border: solid 1px #b7121b;
	border-radius: 2em;
	color: #b7121b;
	font-size: 2rem;
	font-weight: medium;
	letter-spacing: .2em;
	margin: 0 auto 1em;
	width: 50%;

}

#information .info h3 {
	margin-bottom: 10px;
	text-align: center;
}

#information .info dl {
	margin-bottom: 2em;
}

#information .info dt,
#information .info dd {
	display: inline-block;
	padding: 1em 0;
	border-bottom: #CCC 1px dotted;
	font-size: 1.4rem;
	letter-spacing: 0;
}

#information .info dt {
	width: 110px;
	color: #D0111B;
	background-size: 4px auto;
}

#information .info dd {
	width: 524px;
}

#information .info dd a {
	padding-right: 70px;
	min-height: 26px;
	display: block;
	background: url(../images/btn_more.png) no-repeat right center;
}

#information .info .btn a {
	display: inline-block;
	padding: .5em 2em;
	background: #D0111B;
	color: #FFF;
}

#information .info dd a:hover,
#information .info .btn a:hover {
	opacity: .6;
}

#media {
	background: url(../images/bg_media.jpg) center repeat-y;
	box-shadow: 0 5px 15px #000 inset;
}

#media .contents_list {
	margin-bottom: 20px;
}

#media .contents_list a {
	color: #FFF;
}

#media .contents_list p {
	color: #FFF;
	line-height: 1.3;
}

#works {
	background: url(../images/bg_works.jpg) center repeat-y;
	box-shadow: 0 5px 15px #000 inset;
}

#works .contents_list {
	margin-bottom: 20px;
}

#works .contents_list a {
	color: #FFF;
}

#works .contents_list a .area {
	margin-right: 1em;
	padding: .2em .5em;
	border: #FFF 1px solid;
	font-size: 1.3rem;
}

#company {
	padding-bottom: 0;
}

#company .company_list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 30px;
}

#company .company_list li {
	width: 562px;
}

#company .company_list a {
	display: block;
	height: 100%;
}

#company .company_list a:hover {
	opacity: 0.6;
}

#company .company_list h3 {
	padding: .25em;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	letter-spacing: .1em;
}

#company .company_list p {
	line-height: 1.3;
	font-size: 1.7rem;
}

#company .company_list .btn_company {
	margin-top: 1em;
	text-align: right;
	color: #00471d;
	letter-spacing: .2em;
	font-size: 1.8rem;
}

#company .company_list .btn_company span {
	padding-left: 1.5em;
	display: inline-block;
	background: url(../common/images/ico_green_right.png) no-repeat left center;
}

.company_list .company_wrap {
	padding: 20px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.company_list .company_wrap figure {
	width: 180px;
}

.company_list .company_wrap div {
	width: 300px;
}

.company_list .greeting a {
	border: solid 1px #ccc;

}

.company_list .greeting h3 {
	border-bottom: solid 1px #ccc;

}

.company_list .greeting figure img {
	margin-left: 10px;
	width: 65%;

}

.company_list .greeting .company_wrap div {
	width: 340px;
}

.company_list .staff a {
	color: #fff;
	background: #00471d;
}

.company_list .staff h3 {
	border-bottom: solid 1px rgba(255, 255, 255, .5);

}

#company .staff .btn_company {
	margin-top: 1em;
	text-align: right;
	color: #fff;
	letter-spacing: .2em;
	font-size: 1.8rem;
}

#company .staff .btn_company span {
	padding-left: 1.5em;
	display: inline-block;
	background: url(../common/images/ico_white_right.png) no-repeat left center;
}

#company .bnr_list {
	display: flex;
	justify-content: center;
}

#company .bnr_list li {
	width: 274px;
	margin: 0 10px 20px 10px;
}

.company-items {
	display: flex;
	background: #ECEBE6;
}

.company-item {
	padding: 1.5em 0;
	width: calc(100% / 3);
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1.3;
}

.company-item>div {
	padding: 1em 0;
	width: 360px;
	position: relative;
}

.company-item>div:before,
.company-item>div:after {
	border: solid 1px #2E2623;
	content: '';
	position: absolute;
	top: 0;
	width: 10px;
	height: 100%;

}

.company-item>div:before {
	border-right: none;
	left: 0;
}

.company-item>div:after {
	border-left: none;
	right: 0;
}

.company-item h3 {
	margin-bottom: .5em;
	font-size: 2rem;
	font-weight: bold;
}

.company-item:nth-child(even) {
	background: rgba(255, 255, 255, .5);
}

#googlemap {
	height: 600px;
	margin-bottom: 40px;
}

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

	#slide .inner {
		max-width: 100%;
	}

	.contents_list {
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.contents_list li {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		width: 48%;
		margin-bottom: 10px;
		padding: 10px;
		border: #EEE 1px solid;
	}

	.contents_list li:nth-child(4n+1) {
		padding: 10px;
	}

	.contents_list h3 {
		font-size: 4.2vw;
		font-weight: 600;
	}

	.contents_list p {
		font-size: 3.6vw;
		text-align: left;
	}

	.btn {
		width: 90%;
	}

	.title_underline {
		font-size: 4.4vw;
	}

	#advantage {
		background: url(../images/bg_advantage_sp.png) no-repeat center top;
		background-size: 100% auto;
	}

	#advantage .contents_list {
		display: block;
	}

	#advantage .contents_list li {
		margin-bottom: 4vw;
		width: 100%;
		border: none;
	}

	#advantage .content_list_img img {
		position: relative;
		z-index: 0;

	}

	#advantage .content_list_img h3 {
		position: absolute;
		bottom: 4em;
		left: 0;
		width: 100%;
		font-weight: bold;
		color: #fff;
		font-size: 4vw;
		z-index: 1;
		letter-spacing: .1em;
	}

	#advantage .content_list_img .en {
		font-size: 6.5vw;
		bottom: 3.75em;
		z-index: 1;
	}

	#advantage .contents_list p {
		font-size: 3.5vw;
		text-align: center;
	}

	#information {
		background: url(../images/bg_info_sp.png) no-repeat center bottom;
		background-size: 100% auto;

	}

	#information .flex_wrap {
		display: block;
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	#information .facebook {
		width: 100%;
		height: 300px;
		margin-bottom: 50px;
		background: #CCC;
	}

	#information .facebook iframe {
		width: 100%;
		height: 100%;
	}

	#information .info {
		width: 100%;
	}

	#information .title_info {
		font-size: 4vw;
		width: 75%;

	}

	#information .info dl {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
		/*margin-bottom: 2em;*/
	}

	#information .info dt,
	#information .info dd {
		font-size: 3.6vw;
	}

	#information .info dt {
		padding: .75em 0 0;
		border: none;
		width: 100%;
		/*color: #D0111B;*/
	}

	#information .info dd {
		padding: 0 0 .75em;
		width: 100%;
		line-height: 1.3;
	}

	#information .info dd a {
		padding-right: 0;
		min-height: auto;
		display: block;
		background: none;
	}

	#information .info .btn {
		width: 90%;
	}

	#information .info .btn a {
		display: block;
		padding: .5em 2em;
		font-size: 3.6vw;
		letter-spacing: .2em;
		font-weight: medium;

		background: #D0111B url(../images/arw_s_w_r.png) no-repeat right .75em center;
		background-size: auto 30%;
	}


	#media {
		background: url(../images/bg_media_sp.jpg) no-repeat center top;
		background-size: cover;
	}

	#media .contents_list {
		display: block;
	}

	#media .contents_list li {
		padding: 0;
		margin-bottom: 5vw;
		border: none;
		width: 100%;
	}

	#media .contents_list a {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	#media .contents_list li figure {
		width: 36%;
	}

	#media .contents_list img {
		margin: 0;
	}

	#media .contents_list li div {
		width: 60%;
	}

	#media .contents_list a span {
		display: inline-block;
		margin-bottom: 1em;
	}

	#works {
		background: url(../images/bg_works_sp.jpg) no-repeat center top;
	}

	#works .contents_list {
		display: block;
	}

	#works .contents_list li {
		margin: 0;
		padding: 0;
		border: none;
		width: 70%;
	}

	#works .contents_list li a {
		padding: 0 2vw;
		display: block;
	}

	#works .contents_list li img {
		max-width: auto;
		width: 100%;
	}

	#works .contents_list a span {
		display: inline-block;
		margin-bottom: 1em;
		/*margin-right: 1em;
	padding: .2em .5em;
	border: #FFF 1px solid;
	font-size: 1.3rem;*/
	}


	.works_list_wrapper {
		padding-bottom: 6vw;
		margin-bottom: 4vw;
		max-width: 80% !important;
		/*スライドの幅に合わせて変更*/
		margin-left: auto;
		margin-right: auto;
		background: none;
		border: none;
		box-shadow: none;
		position: relative;

	}

	.works_list_wrapper .bx-viewport {
		overflow: visible !important;
	}

	.works_list_wrapper .bx-pager {
		bottom: 0;
	}

	.works_list_wrapper .bx-pager-item .bx-pager-link.active {
		background: #b8121b;
	}

	.works_list_wrapper .bx-wrapper .bx-prev {
		left: -2.5vw;
		background: url(../images/arw_s_w_l.png) no-repeat center center;
		background-size: auto 100%;
	}

	.works_list_wrapper .bx-wrapper .bx-next {
		right: -2.5vw;
		background: url(../images/arw_s_w_r.png) no-repeat center center;
		background-size: auto 100%;
	}

	.works_list_wrapper .bx-wrapper .bx-controls-direction a {
		position: absolute;
		top: 18vw;
		outline: 0;
		width: 5vw;
		height: 5vw;
	}

	#company {
		border-bottom: 0;
	}

	#company .company_list {
		/*display: flex;
	justify-content: space-between;
	margin-bottom: 30px;*/
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		-o-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	#company .company_list li {
		width: 100%;
		margin-bottom: 4vw;
	}


	#company .company_list a {
		display: block;
		height: 100%;
	}

	#company .company_list h3 {
		margin: 0 4vw;
		padding: .25em;
		font-size: 4vw;
		font-weight: bold;
		text-align: center;
		letter-spacing: .1em;
	}

	#company .company_list p {
		line-height: 1.3;
		font-size: 3.6vw;
	}

	#company .company_list .btn_company {
		margin-top: 1em;
		text-align: center;
		letter-spacing: .2em;
		font-size: 3.6vw;
	}

	#company .company_list .btn_company span {
		padding: .75em;
		padding-left: 1.5em;
		border: solid 1px #00471d;
		display: inline-block;
		width: 80%;
		background: url(../common/images/ico_green_right.png) no-repeat right 1em center;
	}

	.company_list .company_wrap {
		padding: 4vw;
		display: block;
		text-align: center;
	}

	.company_list .company_wrap figure {
		margin-bottom: 4vw;
		width: 100%;
	}

	.company_list .company_wrap div {
		width: 100%;
	}

	.company_list .greeting figure img {
		margin-left: 0;
		width: 35%;
	}

	.company_list .greeting .company_wrap div {
		width: 100%;
	}

	#company .staff .btn_company {
		margin-top: 1em;
		text-align: center;
		letter-spacing: .2em;
		font-size: 3.6vw;

	}

	#company .staff .btn_company span {
		padding: .75em;
		padding-left: 1.5em;
		border: solid 1px rgba(255, 255, 255, .8);
		display: inline-block;
		width: 80%;
		background: url(../common/images/ico_white_right.png) no-repeat right 1em center;
	}

	#company .bnr_list {
		padding-bottom: 3vw;
		justify-content: center;
		flex-wrap: wrap;
	}

	#company .bnr_list li {
		width: 50%;
		margin: 0 0 4vw;
	}

	#company .bnr_list li a {
		padding: 0 2vw;
		display: block;
	}

	.company-items {
		display: block;
	}

	.company-item {
		width: 100%;
		text-align: left;
		display: block;
	}

	.company-item>div {
		margin: 0 auto;
		padding: 1em 2em;
		width: 80%;
		position: relative;
		font-size: 3.4vw;
	}

	.company-item h3 {
		margin-bottom: .5em;
		font-size: 4.2vw;
	}

	#googlemap {
		height: 300px;
	}
}