@charset "UTF-8";
/* -------------------- reset start -------------------- */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent
}
body {
	line-height: 1
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block
}
nav ul {
	list-style: none
}
blockquote, q {
	quotes: none
}
blockquote:before, blockquote:after, q:before, q:after {
	content: none
}
a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent
}
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none
}
mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold
}
del {
	text-decoration: line-through
}
abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help
}
table {
	border-collapse: collapse;
	border-spacing: 0
}
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #ccc;
	margin: 1em 0;
	padding: 0
}
input, select {
	vertical-align: middle
}
.clearfix:after {
	visibility: hidden;
	height: 0;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
}
* html .clearfix {
	zoom: 1;
} /* IE6 */
*:first-child+html .clearfix {
	zoom: 1;
} /* IE7 */
/* -------------------- reset end -------------------- */


/*共通　ここから*/
body {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-size: 15px;
	line-height:1;
	color: #333;
	background-color: #fff;
	-webkit-text-size-adjust: 100%;
}
@media only print {
body {
	color:#000;
}
}
a:link {
	text-decoration: none;
	color: #006666;
}
a:visited {
	text-decoration: none;
	color: #5a6299;
}
a:hover {
	text-decoration: underline;
	color: #ff9900;
	-webkit-transition: all 0.1s linear;
	-moz-transition: all 0.1s linear;
	-ms-transition: all 0.1s linear;
	-o-transition: all 0.1s linear;
	transition: all 0.1s linear;
}
strong {
	font-weight: bold;
}
img {
	border: none;
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
a img:hover {
	opacity: 0.9;
	transition: all 0.2s ease;
}
embed,object {
	max-width: 100%;
}
.fa:after {
	content: "\00a0\00a0";
}
.floatLeft {
	float: left;
}
.floatRight {
	float: right;
}
.center {
	text-align: center;
}
.right {
	text-align: right;
}
.bold {
	font-weight: bold;
}
.clearfix:after {
	visibility: hidden;
	height: 0;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
}
* html .clearfix {
	zoom: 1;
} /* IE6 */
*:first-child+html .clearfix {
	zoom: 1;
} /* IE7 */
.inner {
	max-width: 960px;
	margin-left: auto;
	margin-right: auto;
}

#container {
	border-top: 8px solid #00A8AF;
	background-image: url(../images/background.jpg);
	background-repeat: no-repeat;
	background-position: center bottom;
	background-size: contain;
    padding-bottom: 60px;
}
@media only print {
#container {
	background-image: none;
}
}
#header {
	padding-top: 10px;
	padding-bottom: 30px;
	overflow: hidden;
}
#description {
	font-size:12px;
	line-height:1.2;
	margin-bottom:30px;
}
#headerLogo {
	float: left;
}
#headerCopy {
	float: left;
	margin-left:30px;
}
#headerCopy p {
	line-height: 1.3;
	font-size: 13px;
	color: #ff6c00;
}
#headerContact {
	float: right;
	margin-top: 10px;
	height: 44px;
	line-height: 44px;
	box-sizing: border-box;
	border-radius: 2px;
	border: 1px solid #ff6c00;
	box-shadow: 0px 1px 1px rgba(0,0,0,0.2);
	text-align:center;
}
#headerContact a {
	display: block;
	text-decoration: none;
	letter-spacing: 1px;
	font-size:16px;
	font-weight:normal;
	padding-left: 20px;
	padding-right: 20px;
	color:#ff6c00;
	
}
#headerContact a:hover,#contactPage #headerContact a {
	background-color:#ff6c00;
	color:#fff;
	text-shadow: 0px 1px 0px #666;
	-webkit-transition: all 0.1s linear;
	-moz-transition: all 0.1s linear;
	-ms-transition: all 0.1s linear;
	-o-transition: all 0.1s linear;
	transition: all 0.1s linear;
}

#gnav {
	margin-bottom: 30px;
}
#gnav ul {
	overflow: hidden;
}
#gnav ul li {
	width: 25%;
	/*width: 240px;*/
	float: left;
	list-style: none;
}
#gnav ul li a {
	display: block;
	border-top: 1px solid #00A8AF;
	border-bottom: 1px solid #00A8AF;
	padding-top: 12px;
	padding-bottom: 12px;
	font-size: 16px;
	color: #00A8AF;
	background-color: #fff;
	text-align: center;
	text-decoration: none;
}
#gnav li a:hover, #homePage #gnav #gnavHome a, #companyPage #gnav #gnavCompany a, #businessPage #gnav #gnavBusiness a, #examplePage #gnav #gnavExample a, #contactPage #gnav #gnavContact a {
	color: #fff;
	background-color: #00A8AF;
	text-shadow: 0px 1px 0 rgba(0, 0, 0, 0.3);
	transition: all 0.1s linear;
}
#contents {
	padding-left: 15px;
	padding-right: 15px;
	background-color:#fff;
	overflow: hidden;
    margin-top: 30px;
}
#contents #main {
	width: 62.5%;
	/*width: 600px;*/
	float: left;
	margin-bottom:60px;
}
#contents #main #introduction,#contents #main section {
	margin-bottom: 40px;
	line-height: 1.5;
}
#contents #main section h2 {
	margin-bottom: 15px;
	border-bottom: 2px solid #00A8AF;
	font-size: 20px;
	font-weight: bold;
}
#contents #main section h2 i {
color:#00A8AF;
}
#contents #main section p {
	margin-bottom: 15px;
}
#contents #main section .right {
	text-align: right;
}
#contents #side {
	width: 31.25%;
	/*width: 300px;*/
	float: right;
	margin-bottom:60px;
}
#contents #side section {
	margin-bottom: 60px;
	line-height: 1.5;
}
#contents #side section h3 {
	margin-bottom: 15px;
	padding-left: 8px;
	border-left: 5px solid #00A8AF;
	font-size: 18px;
	font-weight: bold;
	line-height:1;
}
#contents #side section p {
	margin-bottom: 15px;
	font-size: 15px;
	line-height:1.5;
}
#contents #side #news {
	line-height: 1.5;
}
#contents #side #news dt {
	font-weight: bold;
	color: #00A8AF;
}
#contents #side #news dd {
	margin-bottom: 15px;
}
#contents #side #banner {
	margin-bottom: 30px;
}
#contents #side #banner li {
	list-style-type:none;
	margin-top: 30px;
}
#footer {
	padding-top: 30px;
	padding-bottom: 30px;
	background-color:#00A8AF;
	color:#fff;
}
#footer #footerNav {
	margin-bottom: 20px;
	text-align: center;
	line-height:1.5;
}
#footer #footerNav li {
	display: inline-block;
	margin-right: 20px;
	list-style: none;
}
#footer #footerNav li a {
	color:#fff;
}
#footer #footerNav li:last-child {
	margin-right: 0px;
}
#footer #copyright {
	font-size: 12px;
	text-align: center;
}
.pagetop {
	display: none;
	position: fixed;
	bottom: 20px;
	right: 20px;
    z-index: 999;
}
.pagetop a {
	display: block;
	background-color: #666;
	text-align: center;
	color: #fff;
	font-size: 20px;
	text-decoration: none;
	padding: 5px 10px;
}
.pagetop a:hover {
	display: block;
	background-color: #888;
	text-align: center;
	color: #fff;
	font-size: 20px;
	text-decoration: none;
	padding: 5px 10px;
	-webkit-transition: all 0.1s linear;
	-moz-transition: all 0.1s linear;
	-ms-transition: all 0.1s linear;
	-o-transition: all 0.1s linear;
	transition: all 0.1s linear;
}
.pagetop .fa:after {
	content: "";
}
 @media only screen and (max-width : 959px) {
#header {
	padding-left: 15px;
	padding-right: 15px;
}
#headerCopy {
	display:none;
}
}
@media only screen and (max-width : 767px) {
#container {
	background-image: none;
	padding-bottom: 30px;
}
#headerLogo,#headerContact {
	float: none;
	text-align: center;
}
#contents #side #banner {
	text-align: center;
}
#headerContact {
	margin-top: 30px;
}
#gnav ul li {
	width: auto;
	float: none;
}
#gnav ul li a {
	border-bottom: none;
}
#gnav ul li:last-child {
	border-bottom: 1px solid #00A8AF;
}
#header #headerRight {
	text-align: left;
}
}
@media only screen and (max-width : 479px) {

}
/*共通　ここまで*/

/*ホーム　ここから*/
#homeImg {
	max-width: 960px;
	margin-left: auto;
	margin-right: auto;
	list-style: none;
	margin-bottom: 10px;
}
.rslides {
	position: relative;
	list-style: none;
	overflow: hidden;
	width: 100%;
	padding: 0;
	margin: 0;
}
.rslides li {
	-webkit-backface-visibility: hidden;
	position: absolute;
	display: none;
	width: 100%;
	left: 0;
	top: 0;
}
.rslides li:first-child {
	position: relative;
	display: block;
	float: left;
}
.rslides img {
	display: block;
	height: auto;
	float: left;
	width: 100%;
	border: 0;
}
.rslides_tabs {
	margin-top: 5px;
	text-align: center;
	line-height: 1;
	margin-bottom: 20px;
}
.rslides_tabs li {
	display: inline;
	margin-right: 15px;
}
.rslides_tabs li:last-child {
	margin-right: 0px;
}
.rslides_tabs a {
	display: inline-block;
	overflow: hidden;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: #ccc;
	text-indent: -9999px;
}
.rslides_tabs a:hover {
	filter: alpha(opacity=80);
	opacity: 0.8;
	transition: all 0.2s linear;
}
.rslides_tabs .rslides_here a {
	background-color: #00A8AF;
}
#indexAbout {
	margin-left: auto;
	margin-right: auto;
	max-width: 560px;
	padding: 15px;
	border:dotted 1px #ff9900;
	border-radius: 4px;
	color:#00A8AF;
	font-size: 16px;
}
#indexAbout li {
	list-style: none;
	background-image: url(../images/index/home_aboutlist.jpg);
	background-size: 50px 27px;
	background-position: left center;
	background-repeat: no-repeat;
	padding-left: 60px;
	margin-bottom: 20px;
	min-height: 27px;
	line-height: 1.2;
}
#indexAbout li:last-child {
	margin-bottom: 0px;
}


@media only screen and (max-width : 959px) {
}
@media only screen and (max-width : 767px) {
}
@media only screen and (max-width : 479px) {
}
/*ホーム　ここまで*/

/*下層ページ共通　ここから*/
#pageTitle {
	margin-bottom: 20px;
	padding-top: 30px;
	padding-bottom: 30px;
	border: 1px solid #00A8AF;
}
#pageTitle h1 {
	color: #00A8AF;
	font-size: 24px;
	font-weight: bold;
	margin-left: 15px;
}
#contents #main h3 {
	margin-top: 25px;
	margin-bottom: 15px;
	padding-left: 5px;
	border-left: 5px solid #00A8AF;
	font-size: 16px;
	font-weight: bold;
	line-height: 1.2;
}
#contents #side #sideNav {
	margin-bottom: 60px;
}
#contents #side #sideNav li {
	list-style: none;
}
#contents #side #sideNav li:first-child {
	border-top: 1px dotted #ccc;
}
#contents #side #sideNav li a {
	display: block;
	border-bottom: 1px dotted #ccc;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-left: 5px;
	color: #00A8AF;
	background-color: #fff;
	text-decoration: none;
}
#contents #side #sideNav li a:before {
	content: "≫\00a0";
}
#contents #side #sideNav li a:hover {
	color: #fff;
	background-color: #00A8AF;
	-webkit-transition: all 0.1s linear;
	-moz-transition: all 0.1s linear;
	-ms-transition: all 0.1s linear;
	-o-transition: all 0.1s linear;
	transition: all 0.1s linear;
}
@media only screen and (max-width : 959px) {
#pageTitle {
	border: hidden;
	padding-top: 0px;
	padding-bottom: 0px;
}
}
@media only screen and (max-width : 767px) {
#contents #main, #contents #side {
	width: auto;
	float: none;
}
#contents #side #sideNav {
	margin-top: 60px;
}
}
 @media only screen and (max-width : 479px) {
}
/*下層ページ共通　ここまで*/

/*会社情報　ここから*/
#companyPage #contents #main section .companyDatalist dt {
	background-color: #f1f1f1;
	line-height: 1.5;
	margin-bottom: 10px;
	padding: 3px;
	font-weight: bold;
}
#companyPage #contents #main section .companyDatalist dd {
	line-height: 1.5;
	margin-bottom: 20px;
}
@media only screen and (max-width : 959px) {
}
@media only screen and (max-width : 767px) {
}
@media only screen and (max-width : 479px) {
}
/*会社情報　ここまで*/

/*事業内容　ここから*/
#businessPage #contents #main section .imgLeft {
	float: left;
	margin-right: 10px;
	margin-bottom: 10px;
	padding: 3px;
	border: 1px solid #ccc;
	font-size: 13px;
	text-align: center;
}
#businessPage #contents #main section .imgRight {
	float: right;
	margin-left: 10px;
	margin-bottom: 10px;
	padding: 3px;
	border: 1px solid #ccc;
	font-size: 13px;
	text-align: center;
}
@media only screen and (max-width : 959px) {
}
@media only screen and (max-width : 767px) {
}
@media only screen and (max-width : 479px) {
}
/*事業内容　ここまで*/

/*施工事例　ここまで*/
#examplePage .photo {
	text-align:center;
	font-size:13px;
}
#examplePage #contents #main section a img:hover{
	-webkit-transform: scale(1.02, 1.02);
	-moz-transform: scale(1.02, 1.02);
	-ms-transform: scale(1.02, 1.02);
	-o-transform: scale(1.02, 1.02);
	transform: scale(1.02, 1.02);
	-webkit-transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	-ms-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	transition: all 0.2s ease;
}
/*施工事例　ここまで*/

/*お問い合わせ　ここから*/
#contactForm {
	width: 400px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 20px;
}
#contactForm dt {
	margin-bottom: 5px;
	font-family: "Shin Go Medium", sans-serif;
	font-weight:bold;
}
#contactForm dd {
	margin-bottom: 20px;
}
#name,#company,#email,#tel {
	width: 400px;
}
#txtform {
	width: 400px;
	height: 200px;
}
#submit {
	width:90px;
	height:30px;
	background-color:#ff6c00;
	color:#fff;
	font-size:16px;
}
#contents #side #privacy p {
    font-size: 12px;
}
@media only screen and (max-width : 959px) {
}
@media only screen and (max-width : 767px) {
    #contactForm {
	width: 250px;
}
#name,#company,#email,#tel {
	width: 250px;
}
#txtform {
	width: 250px;
}
}
@media only screen and (max-width : 479px) {
}

/*お問い合わせ　ここまで*/