#office #contents h2 {
	padding: 0 0 10px 0;
	margin: 0 0 30px 0;
	font-size: 2.4rem;
	letter-spacing: 0.2em;
	border-bottom: solid 2px #6FBA2C;
	text-align: center;
}

#office .info ul li a:hover {
	text-decoration: underline;
}

#office #location {
	padding: 30px 0 0 0;
	font-size: 0;
}

#office #location section {
	padding: 0 0 40px 0;
}

#office #location h3 {
	padding: 10px;
	margin: 10px 0 0 0;
	font-size: 1.8rem;
	color: #FFFFFF;
	line-height: 1.2;
	background-color: #6FBA2C;
	border-radius: 10px;
}

#office #location dl {
	display: inline-block;
	margin: 20px 0 0 10px;
	width: calc(50% - 5px);
	vertical-align: top;
}

#office #location section dl:nth-of-type(2n+1) {
	margin-left: 0;
}

#office #location dl dt {
	position: relative;
}

#office #location dl dt span {
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
	padding: 0 5px;
	font-size: 1.5rem;
	color: #FFFFFF;
	background-color: #6FBA2C;
}

#office #location dl dt img {
	width: 100%;
	border-radius: 10px;
}

#office #location dl dd {
	position: relative;
	padding: 10px 10% 10px 4%;
	margin: 5px 0 0 0;
	font-size: 1.6rem;
	line-height: 1.2;
	text-align: right;
	background-color: #DDF5C4;
	border-radius: 10px;
}

#office #location dl dd div {
	text-align: left;
}

#office #location dl dd span {
	font-size: 0.7em;
}

#office #location dl dd a {
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

#office #location dl dd a img {
	position: absolute;
	top: 50%;
	right: 7px;
	max-width: 9%;
	transform: translateY(-50%);
}

#office #business dl {
	padding: 0 0 50px 0;
}

#office #business dl dt {
	padding: 10px;
	margin: 30px 0 10px 0;
	font-size: 1.8rem;
	background-color: #CFF7F6;
	border-radius: 10px;
}

#office #business dl dt:first-of-type {
	margin-top: 0;
}

#office #business dl dd {
	font-size: 1.6rem;
}

#office #business dl dd a:hover {
	text-decoration: underline;
}


@media print, screen and (min-width: 620px) {
	#office #contents h2 {
		font-size: 3.2rem;
	}

	#office #map {
		position: relative;
		width: calc(100% - 40px);
	}

	#office #map #bg_map {
		width: 100%;
	}

	#office #map #pin li {
		position: absolute;
		transform: translate(-50%, -50%);
	}

	#office #map #pin li:nth-of-type(1) {
		top: 39%;
		left: 40%;
	}

	#office #map #pin li:nth-of-type(2) {
		top: 39%;
		left: 47%;
	}

	#office #map #pin li:nth-of-type(3) {
		top: 64%;
		left: 27%;
	}

	#office #map #pin li:nth-of-type(4) {
		top: 57%;
		left: 46%;
	}

	#office #map #pin li:nth-of-type(5) {
		top: 40%;
		left: 69.5%;
	}

	#office #map #pin li:nth-of-type(6) {
		top: 28%;
		left: 12%;
	}

	#office #map #pin li:nth-of-type(7) {
		top: 50px;
		left: 59%;
	}

	#office #map .info {
		position: absolute;
		top: 50%;
		left: 75%;
		padding: 25px;
		width: 300px;
		height: auto;
		background-color: #FFFFFF;
		border-radius: 20px;
		box-shadow: 0 0 6px 3px #CCCCCC;
		transform: translateY(-50%);
	}

	#office #map .info_l {
		left: 10%;
	}

	#office #map .info strong {
		font-size: 2.2rem;
		font-weight: normal;
		color: #6FBA2C;
	}

	#office #map .info ul li {
		padding: 4px 0;
		font-size: 1.2rem;
	}

	#office #map .info img {
		margin: 15px 29px;
		width: 192px;
		border-radius: 10px;
	}

	#office #location {
		padding: 60px 0;
	}

	#office #location section {
		display: inline-block;
		padding: 0 1px 20px 1px;
	}

	#office #location section#kuchita {
		margin: 0 30px;
	}

	#office #location dl {
		margin: 20px 0 20px 32px;
		width: 208px;
	}

	#office #location section dl:nth-of-type(2n+1) {
		margin-left: 32px;
	}

	#office #location section dl:nth-of-type(4n+1) {
		margin-left: 0;
	}

	#office #location dl dd {
		position: relative;
		padding-right: 40px;
		min-height: 63px;
	}

	#office #location dl dd div {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
	}

	#office #business {
		padding: 0 0 60px 0;
	}

	#office #business dl dt {
		margin: 50px 0 10px 0;
	}

	#office #business #business_l, 
	#office #business #business_r {
		width: 448px;
	}

	#office #business #business_l {
		float: left;
	}

	#office #business #business_r {
		float: right;
	}
}

