@charset "UTF-8";

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
DATA
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

#mainText {
	font-weight: bold;
	text-align: center;
}

.groups {
	font-size: 14px;
	line-height: 21px;
}
.groups .main {
	margin: 0 15px;
	position: relative;
}
.groups .main h2,
.groups >h2 {
	height: 30px;
	font-size: 16px;
	line-height: 30px;
	font-weight: bold;
	text-align: center;
	position: relative;
	margin-bottom: 30px;
	background: rgba(0,0,0,.3);
}
.groups > h2 {
	margin: 30px 15px 0;
}
.groups .main:before,
.groups .main:after,
.groups .main h2:before,
.groups .main h2:after,
.groups > h2:before,
.groups > h2:after {
	content: "";
	width: 30px;
	height: 30px;
	display: block;
	position: absolute;
	background: url(../images/common/icon_corner.svg) no-repeat center center;
	background-size: 100% 100%;
	-moz-background-size: 100% 100%;
	-webkit-background-size: 100% 100%;
}
.groups .main:before,
.groups .main:after {
	bottom: 0;
}
.groups .main h2:before,
.groups .main h2:after,
.groups > h2:before,
.groups > h2:after {
	top: 0;
}
.groups .main:before,
.groups .main h2:before,
.groups > h2:before {
	left: -15px;
}
.groups .main:after,
.groups .main h2:after,
.groups > h2:after {
	right: -15px;
}

.groups .main figure {
	text-align: center;
}
.groups .main th {
	text-align: center;
	border: 1px solid #fff;
}
.groups ul li {
	margin-top: 30px;
	padding-top: 15px;
	padding-bottom: 15px;
}
.groups ul li > div {
	text-align: center;
	padding: 27px 0 30px;
	background: rgba(255,255,255,0.3);
}
.groups ul li a {
	color: #fff;
}
.groups ul li h2 {
	color: #000;
	font-size: 16px;
	font-weight: bold;
}
.groups ul li .logo {
	padding: 26px 0 27px;
}
.groups ul li h2 + dl {
	margin-top: 35px;
}
.groups ul li dt {
	color: #fff;
	width: 185px;
	background: #000;
	line-height: 18px;
	margin: 0 auto 6px;
	border: 1px solid #000;
}
.groups ul li dt.johnson{
	width: 242px;
}
.groups ul li dt.white {
	color: #000;
	background: #fff;
	border-color: #fff;
}
.groups ul li dd {
	margin-bottom: 18px;
}
.groups ul li .tel,
.groups ul li .fax {
	font-style: 18px;
	font-weight: bold;
	margin-top: 3px;
	display: inline-block;
}
.groups ul li .tel:before {
	content: "";
	width: 20px;
	height: 15px;
	margin-right: 10px;
	display: inline-block;
	vertical-align: baseline;
	background: url(../images/common/icon_tel.svg) no-repeat center center;
	background-size: 100% 100%;
	-moz-background-size: 100% 100%;
	-webkit-background-size: 100% 100%;
}
.groups ul li .tel a {
	color: #fff;
}
.groups ul li .site img {
	height: 37px;
	margin-top: 18px;
}

@media screen and (min-width:1001px){
	#mainText {
		font-size: 14px;
		line-height: 28px;
		margin-bottom: 50px;
	}
	.groups .main table {
		width: calc(100% + 20px);
		margin: 0 -10px;
		table-layout: fixed;
		border-spacing: 10px;
		border-collapse: separate;
	}
	.groups .main th {
		width: 140px;
	}
	.groups .main td {
		letter-spacing: -0.5px;
	}
	.groups .main p {
		font-size: 12px;
		padding: 15px 0 45px;
		letter-spacing: -0.5px;
	}

	.groups ul li dt {
		letter-spacing: -1px;
	}
}

@media screen and (max-width:1000px){
	#mainText {
		font-size: 11px;
		line-height: 22px;
		margin-bottom: 40px;
	}
	.groups .main {
		margin: 0;
		padding-bottom: 40px;
	}
	.groups .main table,
	.groups .main table * {
		display: block;
		text-align: center;
	}
	.groups .main td {
		padding-bottom: 10px;
	}
	.groups ul li > div {
		letter-spacing: 0;
		padding-bottom: 10px;
	}
	.groups ul li .site {
		padding-bottom: 20px;
	}
}