@charset "UTF-8";
/*----------------------------------------

	#company about
	- mv
	- content
		+ map
		+ about_table

-----------------------------------------*/

/*----------------------------------------
	mv
-----------------------------------------*/
#mv {
	background: #62b1d9 url("../img/c_mv_bg01.jpg") no-repeat right top;
	background-size: 1320px auto;
}
@media screen and (max-width: 767px) {
	#mv {
		background-size: auto 100%;
	}
}

/*----------------------------------------
	content
-----------------------------------------*/
/* commons */
.sp {display: none;}
#content .about_table h2,h3 {color: #000;}
#content .about_table h2>span {font-weight: normal;display: inline-block;}
#content .about_table a {text-decoration: underline;}
#content .about_table a:hover {text-decoration: none;}
#content .about_table a[href^="tel"] {
	display: inline-block;
	pointer-events: none;
	text-decoration: none;
}
#content .about_table a.blank::after {
	margin: 0 0 0 7px;
}
@media screen and (max-width:767px) {
	.sp {display: block;}
	.pc {display: none;}
	#content .about_table a:hover {text-decoration: underline;}
	#content .about_table a[href^="tel"] {
		pointer-events: auto;
		border-bottom: none;
	}
}

/* map */
.map_wapper{
    position : relative;
    height : 0;
    padding-bottom : 56.25%;
    overflow : hidden;
}
.map_wapper iframe {
    position : absolute;
    top : 0;
    left : 0;
    width : 100%;
    height : 100%;
}
/* 比率参考 */
/* 16：9 */
/*padding-bottom : 56.25%;*/
/* 4：3 */
/*padding-bottom : 75%;*/
/* 5：5 */
/*padding-bottom : 100%;*/

/* about_table */
.about_table dl {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	border-bottom: 1px solid #ddd;
}
.about_table dl:first-child {
	border-top: 1px solid #ddd;
}
.about_table dl dt {
	width: 25%;
	max-width: 280px;
	-webkit-box-flex: 1;
	    -ms-flex: 1 1 280px;
	        flex: 1 1 280px;
	padding: 14px 20px 12px;
	background-color: #fafafa;
}
.about_table dl dd {
	width: 75%;
	max-width: 840px;
	-webkit-box-flex: 1;
	    -ms-flex: 1 1 840px;
	        flex: 1 1 840px;
	padding: 14px 0 14px 26px;
	background-color: #fff;
}
.about_table .box + .box {
	margin-top: 40px;
}
.about_table .box:nth-of-type(2) {
	margin-bottom: 60px;
}
.about_table .box.column2 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.about_table .box.column2>div,
.about_table .box.column2>figure {
	width: 50%;
	max-width: 420px;
	-webkit-box-flex: 1;
	    -ms-flex: 1 1 420px;
	        flex: 1 1 420px;
}
.about_table .box>.text {
	padding: 0 1.0em 0 0;
}

/* row2 */
.about_table dl:nth-child(2) dd {
	padding-bottom: 20px;
}
.about_table dl:nth-child(2) .box>.text h3 {
	margin: 0 0 3px 0;
}
.about_table dl:nth-child(2) .box>figure {
	margin-top: 6px;
}

/* row6 */
.about_table dl:nth-child(6) dd ul li>span {
	display: inline-block;
}
.about_table dl:nth-child(6) dd ul li>span:first-child {
	width: 20em;
}

/* row8 */
.about_table dl:nth-child(8) dd {
	padding: 15px 0 14px 29px;
}
.about_table dl:nth-child(8) dd ul li>p {
	margin-bottom: 7px;
}
.about_table dl:nth-child(8) dd ul li {
	margin-bottom: 29px;
}
.about_table dl:nth-child(8) dd ul li:last-child {
	margin-bottom: 0;
}
.about_table dl:nth-child(8) a::before {
	content: "";
	display: inline-block;
	margin: 0 0.5em 0 0;
	border-top: 0.3em solid rgba(255,255,255,0.0);
	border-left: 0.4em solid #666;
	border-bottom: 0.3em solid rgba(255,255,255,0.0);
}
@media screen and (max-width: 767px) {
	/* about_table */
	.about_table {
		line-height: 1.5;
	}
	.about_table dl dt {
		width: 35.6%;
		max-width: 35.6%;
		-webkit-box-flex: 1;
		    -ms-flex: 1 1 35.6%;
		        flex: 1 1 35.6%;
		padding: 11px 14px 10px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
	.about_table dl dd {
		width: 64.4%;
		max-width: 64.4%;
		-webkit-box-flex: 1;
		    -ms-flex: 1 1 64.4%;
		        flex: 1 1 64.4%;
		padding: 12px 0 10px 16px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
	
	/* row2 */
	.about_table dl:nth-child(2) dd {
		padding-bottom: 15px;
	}
	.about_table dl:nth-child(2) .box.column2 {
		display: block;
	}
	.about_table dl:nth-child(2) .box>.text {
		width: 100%;
		max-width: 100%;
		padding: 0;
	}
	.about_table dl:nth-child(2) .box>.text h3 {
		margin: -2px 0 7px 0;
	}
	.about_table dl:nth-child(2) .box>.text .sp {
		padding: 5px 0 0 0;
	}
	.about_table dl:nth-child(2) .box>figure {
		width: 92%;
		max-width: 92%;
		margin-top: 13px;
	}
	.about_table .box:nth-of-type(3) {
		margin-top: 37px;
	}
	/* row6 */
	.about_table dl:nth-child(6) dd ul li {
		margin-bottom: 7px;
	}
	.about_table dl:nth-child(6) dd ul li>span:first-child {
		width: auto;
		margin-right: 1.0em;
	}
	.about_table dl:nth-child(6) dd ul li:last-child {
		margin-bottom: 0;
	}
	/* row8 */
	.about_table dl:nth-child(8) dd {
		padding: 12px 0 10px 16px;
	}
}

/* bnr */
.bnr {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	margin: 60px auto 70px;
	padding-top: 60px;
	border-top: 1px solid #ddd;
}
.bnr a {
	width: calc((100% - 35px)/2);
}
.bnr a:first-child {
	margin-right: 40px;
}
.bnr figure img {
	-webkit-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
}
.bnr figure img {
	max-width: none;
	margin-bottom: 13px;
}
.bnr a:hover figure img {
	opacity: 0.8;
}
/*----------------------------------------
	会社概要 バナー部
-----------------------------------------*/
.bnr.company__aboutBnr > a:not(:last-child) {
	margin-right: 40px;
}


/*----------------------------------------
	事業内容（グループ連結）
-----------------------------------------*/

.segment_table_wrap {
	overflow-x: auto;
}
.segment_table {
	min-width: 600px;
	width: 100%;
	border-collapse: collapse;
	border-bottom: 1px solid #ddd;
	margin: 30px 0 0;
}
.segment_table caption {
	text-align: left;
	margin-bottom: 5px;
	font-weight: bold;
}
.segment_table .cap {
	background-color: #fafafa;
}
.segment_table th,
.segment_table td {
	padding: 14px 20px 12px;
	border: 1px solid #ddd;
}
.segment_table thead th {
	text-align: center;
}
a.segment_table_link::before {
    content: "";
    display: inline-block;
    width: 0;
    height: 0;
    border-top: 6.5px solid transparent;
    border-bottom: 6.5px solid transparent;
    border-left: 9px solid #333;
    margin-right: 2px;
}


@media screen and (max-width: 767px) {
	.bnr {
		margin: 40px 0 50px;
		padding-top: 40px;
	}
	.bnr,
	.bnr a {
		display: block;
	}
	.bnr a {
		width: 100%;
	}
	.bnr a:first-child {
		margin: 0 0 24px 0;
	}
	.bnr figure img {
		margin-bottom: 8px;
	}
}