/*
 * under css 
 * pc width 1100px fixed
 */

@media (max-width: 599px) {
} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {
} /* end 600-959 */

@media (min-width: 960px) {
} /* 960- */


/* ---------------------------------------- common */

.red { color: red; }
.green { color: #155b43; }
.underline { border-bottom: 1px #155b43 solid; }

.align-left { text-align: left; }
.align-center { text-align: center; }
.align-right { text-align: right; }

.date {
	color: #83b6bc;
	line-height: 1;
}

@media (max-width: 599px) {

	main section,
	main .section {
		font-size: 1.3rem;
		line-height: 1.8;
		margin: 0 0 40px;
	}

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	main section,
	main .section {
		font-size: 1.4rem;
		line-height: 2.0;
		margin: 0 0 60px;
	}

} /* end 600-959 */

@media (min-width: 960px) {

	main section,
	main .section {
		font-size: 1.6rem;
		line-height: 2.0;
		margin: 0 0 80px;
	}

} /* 960- */

/* ---------------------------------------- lead, telbox */

#lead {
	background: #fdf4df;
	text-align: center;
	padding: 1.75em 1em;
}
#lead h2 { 
	color: #e67011;
	margin: 0 0 .5em;
}

.telbox {
	background: #e6f2ea;
	text-align: center;
	padding: 2em 1em 1.5em;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}
.telbox .telnum { 
	color: #55a2aa;
	line-height: 1;
	margin: 0 0 .5em;
}

@media (max-width: 599px) {

	#lead p br { display: none; }
	#lead h2 { font-size: 1.6rem; }
	.telbox .telnum { font-size: 2.0rem; }

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	#lead h2 { font-size: 1.8rem; }
	.telbox .telnum { font-size: 2.4rem; }

} /* end 600-959 */

@media (min-width: 960px) {

	#lead h2 { font-size: 2.0rem; }
	.telbox .telnum { font-size: 2.8rem; }

} /* 960- */

/* ---------------------------------------- contentbox */

@media (max-width: 599px) {

	.contentbox figure {
		text-align: center;
	}
	.contentbox > div + figure,
	.contentbox > figure + div {
	 	margin: 1.5em 0 0;
	 }

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	.contentbox > figure { width: 40%; }
	.contentbox > div { width: 55%; }

} /* end 600-959 */

@media (min-width: 960px) {

	.contentbox > figure { width: 300px; }
	.contentbox > div { width: 480px; }

} /* 960- */

/* ---------------------------------------- table-style */

.table-style-wrap table { width: 100%; }
.table-style-wrap.layoutfixed table { table-layout: fixed; }
.table-style-wrap table th { background: #f9f9f9; }

@media (max-width: 599px) {

	.table-style-wrap table { border-top: 1px #e5e5e5 solid; }
	.table-style-wrap table th,
	.table-style-wrap table td {
		display: block;
		border-bottom: 1px #e5e5e5 solid;
		text-align: left;
		padding: 0.75em;
	}
	
} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	.table-style-wrap table th,
	.table-style-wrap table td {
		border-top: 1px #e5e5e5 solid;
		border-bottom: 1px #e5e5e5 solid;
		text-align: left;
		padding: 0.75em;
	}
	.table-style-wrap:not( .layoutfixed ) table th {
		width: 25%;
	}
	.table-style-wrap table td {  }

} /* end 600-959 */

@media (min-width: 960px) {

	.table-style-wrap table th,
	.table-style-wrap table td {
		border-top: 1px #e5e5e5 solid;
		border-bottom: 1px #e5e5e5 solid;
		text-align: left;
		padding: 0.75em;
	}
	.table-style-wrap:not( .layoutfixed ) table th {
		width: 30%;
	}
	.table-style-wrap table td {  }
	
} /* 960- */

/* ---------------------------------------- contact */

#mw_wp_form_mw-wp-form-19,
#mw_wp_form_mw-wp-form-21 { margin: 2em 0 0; }

#contact input[type="text"],
#contact input[type="email"],
#contact textarea {
	border: 1px #333 solid;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

#contact input[type="text"].long,
#contact input[type="email"],
#contact textarea {
	width: 100%;
}
#contact input[type="text"].middle {
	width: 60%;
}
#contact input[type="text"].short {
	width: 4em;
}

#contact .submits { text-align: center; }
#contact input[type="submit"] {
	color: #fff;
	background: #55a2aa;
	padding: 0.75em;
}

#contact .mwform-radio-field.horizontal-item {
	display: inline-block;
	margin-right: 1em;
}
#contact .mw_wp_form .horizontal-item + .horizontal-item {
    margin-left: 0 !important;
}

span.error {
	color: #f16199;
	font-weight: 700;
}

@media (max-width: 599px) {

	#contact input[type="text"],
	#contact input[type="email"],
	#contact textarea {
		font-size: 1.3rem;
		padding: 2px;
	}
	#contact input[type="submit"] {
		width: 70%;
		font-size: 1.4rem;
	}

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	#contact input[type="text"],
	#contact input[type="email"],
	#contact textarea {
		font-size: 1.4rem;
		padding: 2px;
	}
	#contact input[type="submit"] {
		width: 70%;
		font-size: 1.6rem;
	}

} /* end 600-959 */

@media (min-width: 960px) {

	#contact input[type="text"],
	#contact input[type="email"],
	#contact textarea {
		font-size: 1.6rem;
		padding: 2px;
	}
	#contact input[type="submit"] {
		width: 200px;
		font-size: 1.8rem;
	}

} /* 960- */

/* ---------------------------------------- google map */

#googlemap { 
	height: 0;
	padding: 50% 0 0;
	position: relative;
	overflow: hidden;
}
#googlemap iframe,
#googlemap object,
#googlemapembed {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

/* ---------------------------------------- induction (link) */

.induction a {
	display: inline-block;
	color: #fff;
	line-height: 1;
	background: #957258;
	padding: 1em 1.25em;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.induction i { margin: 0 0 0 1em; }

section p + p.induction, .section p + p.induction {
    margin: 1.75em 0 0;
}

/* construction */
.induction.construction a {
	background: #976034;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}

@media (max-width: 599px) {

	.induction.construction a { 
		width: 100%; 
		font-size: 1.4rem;
		padding: 1.5em 1em;
	}

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	.induction.construction a { min-width: 307px; }

} /* end 600-959 */

@media (min-width: 960px) {

	.induction.construction a { min-width: 307px; }

} /* 960- */

/* ---------------------------------------- consultation */

#consultation-bt {
	border-top: 2px #ccc dashed;
	text-align: center;
	padding: 50px 0;
}
#consultation-bt a { display: inline-block; }

@media (max-width: 599px) {

	#consultation-bt a + a { margin: 1.5em 0 0; }

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	#consultation-bt a { margin: 0 3%; }

} /* end 600-959 */

@media (min-width: 960px) {

	#consultation-bt a { margin: 0 3%; }

} /* 960- */

/* ---------------------------------------- flow */

#flow .wrap { 
	background: #e6f2ea url( images/flow-bevel.png ) no-repeat left top;
	text-align: center; 
	padding: 2em 1em;
	position: relative;
}
#flow .inner > .wrap:not( :last-child )::after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-left: 40px solid transparent;
	border-right: 40px solid transparent;
	border-top: 30px solid #e6f2ea;
	position: absolute;
	bottom: -30px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}
#flow .wrap + .wrap { margin: 40px 0 0; }
#flow .wrap h3 { color: #76c4d7; }

/* ---------------------------------------- voice */

.voice-data {
	color: #83b6bc;
	margin: 0 0 1.25em;
}
.voice-data dt { 
	line-height: 1.2;
	margin: 0 0 .75em; 
}
.voice-data dd { line-height: 1.6; }

@media (max-width: 599px) {

	.voice-data dt { font-size: 1.6rem; }

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	.voice-data dt { font-size: 1.8rem; }

} /* end 600-959 */

@media (min-width: 960px) {

	.voice-data dt { font-size: 2.0rem; }

} /* 960- */

/* ---------------------------------------- case-single */

.case-single ul figure { margin: 0 0 .75em; }
.case-single ul h3 {
	color: #55a2aa;
	line-height: 1.4;
	margin: 0 0 .3em;
}
.case-single ul p { line-height: 1.6; }

@media (max-width: 599px) {

	.case-single ul { text-align: center; }
	.case-single ul li:not(:last-child){ margin: 0 0 1.5em; }
	.case-single ul h3 { font-size: 1.4rem; }
	.case-single figure img {
		max-width: 80%;
	}

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	/* 3 items */
	.case-single ul li { width: 31.5%; }
	/* 2 items */
	.case-single.item2 ul li { width: 47%; }
	.case-single ul h3 { font-size: 1.6rem; }

} /* end 600-959 */

@media (min-width: 960px) {

	/* 3 items */
	.case-single ul li { width: 31%; }
	/* 2 items */
	.case-single.item2 ul li { width: 47%; }
	.case-single ul h3 { font-size: 1.8rem; }

} /* 960- */

/* ---------------------------------------- business */

.section.business { text-align: center; }
.section.business a { display: inline-block; }
#business-mess { color: #42201a; }
#construction-reform { background: #e6f2ea; }

@media (max-width: 599px) {

	.section.business .inner { padding: 0 13px; }
	#business-mess { padding: 40px 0; }
	#business-mess h2 {
		font-size: 1.6rem; 
		margin: 0;
	}
	#business-mess h2 br { display: none; }
	#construction-reform { padding: 40px 0; }
	#construction-reform li + li {
		margin: 1.5em 0 0;
	}
	#construction-reform a img,
	#renovation a img {
		max-width: 80%;
		height: auto;
	}
	#renovation { padding: 40px 0; }

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	.section.business .inner { padding: 0 24px; }
	#business-mess { padding: 0 0 40px; }
	#business-mess h2 { font-size: 1.8rem; }
	#construction-reform { padding: 60px 0; }
	#construction-reform li + li {
		margin: 1.5em 0 0;
	}
	#construction-reform a img,
	#renovation a img {
		max-width: 80%;
		height: auto;
	}
	#renovation { padding: 60px 0; }

} /* end 600-959 */

@media (min-width: 960px) {

	#business-mess { padding: 30px 0 50px; }
	#business-mess h2 { font-size: 2.4rem; }
	#construction-reform { padding: 70px 0; }
	#construction-reform li {
		display: inline-block;
		margin: 0 1.5em;
	}
	#renovation { padding: 70px 0; }

} /* 960- */

/* ---------------------------------------- reform, construction, renovation */

.renovation-case h2 { margin: 0 0 2em; }
.renovation-case h3 {
	display: table;
	width: 100%;
}
.renovation-case .inside + .inside { margin: 3em 0 0; }
.renovation-case h3 { margin: 0 0 1em; }
.renovation-case h3 span {
	display: table-cell;
	vertical-align: middle;
}
.reform-mess .inner { background: url( images/reform-back.png ) left top; }
.reform-mess .inner .wrap {
	background: url( images/reform-back-corner.png ) no-repeat right bottom;
	padding: 2em;
}
.reform-mess .inner .wrap h3 {
	color: #55a2aa;
	text-align: center;
}

.reform-description li:not( :last-child ) { margin: 0 0 2em; }
.reform-description h4 {
	color: #a17922;
	background: url( images/reform-h4-icon.jpg ) no-repeat left center;
	background-size: auto 1em;
	line-height: 1.2;
	padding: 0 0 0 1.25em;
	margin: 0 0 .75em;
}

.reform-column { 
	background: #fdf4df; 
	padding: 1.5em 2em;
}
.reform-column h3 { color: #e16d12; }
.reform-column ol li {
	display: table;
	width: 100%;
}
.reform-column ol li span {
	display: table-cell;
	vertical-align: top;
}
.reform-column ol li span:first-child { width: 1.25em; }

.reform .wrap + .wrap { margin: 4em 0 0; }
.construction .wrap + .wrap { margin: 2.25em 0 0; }

@media (max-width: 599px) {

	.renovation-case h3 span:first-child {
		width: 60px;
		padding: 0 10px 0 0;
	}
	
	.reform-description li > figure {
		text-align: center;
		margin: 0 0 1.25em;
	}
	.reform-description h4 { font-size: 1.6rem; }
	
	.reform-column h3 { text-align: center; }
	.reform-column .flex-justify-space-betwee-nowrap > figure {
		text-align: center;
		margin: 1.25em 0 0;
	}

} /* end -599 */

@media (min-width: 600px) and (max-width:959px) {

	.renovation-case h3 span:first-child { width: 76px; }
	.reform-mess .inner .wrap { padding: 2em 4em; }
	
	.reform-description li > figure { width: 25%; }
	.reform-description li > div { width: 72%; }
	.reform-description h4 { font-size: 2.0rem; }
	
	.reform-column .flex-justify-space-betwee-nowrap > figure { width: 25%; }
	.reform-column .flex-justify-space-betwee-nowrap > div { width: 72%; }

} /* end 600-959 */

@media (min-width: 960px) {

	.renovation-case h3 span:first-child { width: 76px; }

	.reform-mess .inner .wrap { padding: 2em 4em; }
	.reform-mess .inner .wrap h3 { font-size: 2.0rem; }
	
	.reform-description li > figure { width: 216px; }
	.reform-description li > div { width: 570px; }
	.reform-description h4 { font-size: 2.4rem; }
	
	.reform-column .flex-justify-space-betwee-nowrap > figure { width: 216px; }
	.reform-column .flex-justify-space-betwee-nowrap > div { width: 510px; }

} /* 960- */

















