
/* ------------------------------------------------------------------------------
     全端末共通のCSS（1000px〜）
------------------------------------------------------------------------------ */

.pc {
	display:block;
}

.sp {
	display:none;
}

.tab {
	display:none;
}

.pcBr:after {
	content: "\A" ;
	white-space: pre ;
}

/* レイアウト
-------------------------------------*/

body {
	color: #333333;
	text-align: center;
	margin: 0 auto;
	height: 100%;
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
}

#wrap {
	width: 100%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	background: #FFF;
}

#layout {
	width: 100%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}

.width {
	width: 95%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.width50 {
	width: 50%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.fade1 {
    opacity : 0.1;
    transform : translate(0, 80px);
    transition : all 500ms;
}
 
.fade1.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}

.fade2 {
    opacity : 0.1;
    transform : translate(0, 100px);
    transition : all 500ms;
}
 
.fade2.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}

.fade3 {
    opacity : 0.1;
    transform : translate(0, 120px);
    transition : all 500ms;
}
 
.fade3.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}

/* 文字
-------------------------------------*/

h1 {
	font-size: 230%;
	margin-bottom: 50px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 35px;
	font-weight: normal;
	text-align: center;
	letter-spacing: 0.1em;
	font-family: "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-family: "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", "serif";
}

h1 span {
	display: block;
	font-size: 35%;
	margin-top: 0px;
	margin-left: auto;
	margin-right: auto;
	font-weight: normal;
	padding: 3px 0;
	text-align: center;
	text-transform: uppercase;
	color: #6D89C5;
}

.bg_title {
	background: #6D89C5;
	padding: 15px 0;
	margin-bottom: 80px;
	position: relative;
}

.bg_title:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 15px solid #6D89C5;
}

.bg_title h1,
.bg_title h1 span {
	color: #FFF;
}

h2 {
	font-size: 150%;
	margin-bottom: 20px;
	text-align: left;
	font-weight: normal;
	letter-spacing: 0.1em;
}

h2 span {
	width: 20%;
	background: #6D89C5;
	color: #FFF;
	vertical-align: middle;
	font-size: 40%;
	padding: 5px 20px;
	margin-left: 15px;
	-moz-border-radius: 50px;
	-webkit-border-radius: 50px;
	border-radius: 50px;
}

p {
	font-size: 90%;
	line-height: 200%;
	margin-bottom: 20px;
	text-align: left;
}

ul.text {
	text-align: left;
	font-size: 90%;
	padding-bottom: 20px;
}

ul.text li {
	line-height: 200%;
	padding: 0px;
	margin-left: 20px;
}

/* ヘッダー
-------------------------------------*/

#fix {
	position: fixed;
	background: #FFF;
	box-sizing: border-box;
	margin: 0 auto;
	width: 100%;
	z-index: 100000;
	box-shadow: 0 0 5px rgba(150,150,150, 0.5);
	padding: 20px 40px 30px 50px;
    transition : all 500ms;
	border-bottom: 1px solid #E5E5E5;
}

#fix.fixed2 {
	position: fixed;
	background: #FFF;
	box-sizing: border-box;
	margin: 0 auto;
	width: 100%;
	z-index: 1000;
	box-shadow: 0 0 5px rgba(150,150,150, 0.5);
	padding: 15px 20px 20px 30px;
    transition : all 500ms;
	border-bottom: 1px solid #E5E5E5;
}
/*
#fix.fixed2 #nav ul li {
	margin-left: 10px;
}
*/

#h_left {
	float: left;
}

#h_right {
	float: right;
}

/* ナビゲーション
-------------------------------------*/

#nav {
}

#nav ul {
	margin-top: 10px;
	box-sizing: border-box;
}

#nav ul li {
	font-size: 95%;
	float: right;
	text-align: left;
	box-sizing: border-box;
	margin-left: 15px;
	font-weight: bold;
}

#nav ul li a {
	display: block;
	padding: 10px 5px;
}

#nav ul li a:hover {
	display: block;
	text-decoration: none;
	transition: 0.3s;
	color: #6D89C5;
}

#nav ul li:nth-child(1) {
	margin-top: -3px;
}

#home #nav ul li #cat-nav-1 { color: #CCC; }
#clean-ag #nav ul li #cat-nav-4 { color: #CCC; }
#security #nav ul li #cat-nav-8 { color: #CCC; }

/* コンテンツ
-------------------------------------*/

#container {
	position: relative;
	z-index: 10;
	top:-50px;
}

#content_bg {
	position: relative;
	z-index: 1000;
	background: #FFF;
	padding: 25px;
	margin-bottom: 20px;
	box-sizing: border-box;
}

section {
	padding-bottom: 100px;
}

#concept {
	display: block;
    padding-top: 150px;
    margin-top:-150px;
}

#works,
#company,
#access {
	display: block;
    padding-top: 100px;
    margin-top:-100px;
}

.column2 {
	width: 48.25%;
	float: left;
	margin-right: 3.5%;
}

.column2:nth-child(2n) {
	margin-right: 0;
}

.column3 {
	width: 31%;
	float: left;
	margin-right: 3.5%;
	margin-bottom: 30px;
}

.column3:nth-child(3n) {
	margin-right: 0;
}

.column4 {
	width: 23.5%;
	float: left;
	margin-right: 2%;
}

.column4:nth-child(4n) {
	margin-right: 0;
}

.column5 {
	width: 18%;
	float: left;
	margin-right: 2.5%;
}

.column5:nth-child(5n) {
	margin-right: 0;
}

.left {
	float: left;
	width: 65%;
}

.right {
	float: right;
	width: 30%;
}

/* TOPページ
-------------------------------------*/

#main {
	position: relative;
	z-index: 1;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
}

#main #main_bg {
	position: absolute;
	bottom: 0%;
	right: 0%;
	margin: auto;
	z-index: 10;
}

#main div.passing {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	margin: auto;
	z-index: 10;
}

.title {
	font-size: 260%;
	font-weight: bold;
	text-align: center;
	font-family: "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-family: "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", "serif";
	line-height: 130%;
	text-shadow: 2px 2px 0 #FFFFFF, 2px -2px 0 #FFFFFF, -2px 2px 0 #FFFFFF, -2px -2px 0 #FFFFFF, 2px 0px 0 #FFFFFF, 0px 2px 0 #FFFFFF, -2px 0px 0 #FFFFFF, 0px -2px 0 #FFFFFF;
}

.title em {
	display: block;
	font-style: normal;
	font-size: 65%;
}

.title span {
	margin-top: 20px;
	display: block;
	font-size: 40%;
}

.bg_blue {
	background: #F3F5FA;
}

.bg_white {
	background: #FFF;
	padding: 50px;
	box-sizing: border-box;
}

/* 下階層共通
-------------------------------------*/

#prt_main {
	margin-top: 100px;
	padding: 120px 0 150px;
}

#service #prt_main {
	background: url("../img/content/service/main.jpg") center center no-repeat;
}

#clean-ag #prt_main {
	background: url("../img/content/clean-ag/main.jpg") center center no-repeat;
}

#security #prt_main {
	background: url("../img/content/security/main.jpg") center center no-repeat;
}

#prt_main h1 {
	display: none;
	margin: 0;
	padding: 0;
	text-align: left;
	text-transform: uppercase;
	color: #FFF;
	text-shadow: 1px 1px 1px #999;
}

#prt_main h1 span {
	text-align: left;
}

#listNavi {
	background: #FFF;
	font-size:70%;
	padding: 10px 0;
	-webkit-text-size-adjust: none;
}

#listNavi a {
	text-decoration: underline;
}

#listNavi div {
	text-align: left;
}

#listNavi span {
	background: url("../img/common/listNavi.png") center left no-repeat;
	padding:5px 0 5px 25px;
}

/* コンテンツ
-------------------------------------*/


/* サイドバー
-------------------------------------*/


/* フッター
-------------------------------------*/

footer {
}

#footer_top {
	background: #F3F5FA;
	margin-top: -50px;
}

#home #footer_top {
	background: #FFF;
	margin-top: -50px;
}

#footer_top p {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

#footer_main {
	margin-top: -80px;
	padding: 100px 0 50px;
	background: #15408D;
}

address {
	text-align: center;
	font-style: normal;
	font-size: 75%;
	color: #FFF;
}
	
/* その他
-------------------------------------*/

div.normalTbl input {
	font-size: 100%;
	padding: 7px;
	border: 1px solid #AAA;
}

div.normalTbl select {
	padding: 7px;
	border: 1px solid #AAA;
}

div.normalTbl textarea {
	font-weight: normal;
	font-size: 14px;
	border: 1px solid #AAA;
}

div.normalTbl input:focus,
div.normalTbl select:focus,
div.normalTbl textarea:focus {
	background: #FDF0F7;
}

.icon {
	padding-bottom: 4px;
}

.formButton {
	text-align:center;
	margin:0 auto;
	display: block;
	margin-top: 40px;
}

.formButton input {
	padding:20px 10%;
	border-style: none;
	background: #FF9326;
	color:#FFF;
	font-size:120%;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	border-radius: 4px;
}

.formButton input:hover {
	background:#333;
	background: #683900;
}

/* その他ナビゲーション
-------------------------------------*/

.btn {
	background: #FFF;
	color: #FFF;
	margin:0 auto;
	text-align:center;
	margin-top:0px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.btn a {
	color:#FFFFFF;
	background: #15408D;
	transition: 0.3s;
	text-decoration:none;
	display:block;
	padding: 15px 10px;
	margin:0 auto;
	text-align:center;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.btn a:hover {
	color: #FFFFFF;
	transition: 0.3s;
	text-decoration: underline;
	background-color: #8D1515;
}

.menu {
	background: #FFF;
	color: #FFF;
	margin:0 auto;
	text-align:center;
	margin-top:0px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.menu a {
	color:#FFFFFF;
	background: #15408D;
	transition: 0.3s;
	text-decoration:none;
	display:block;
	padding: 20px;
	margin:0 auto;
	text-align:center;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.menu a:hover {
	color: #FFFFFF;
	transition: 0.3s;
	text-decoration: underline;
	background-color: #8D1515;
}

/* ページトップへ
-------------------------------------*/

#page-top {
    position: fixed;
    bottom: 30px;
    right: 30px;
    font-size: 80%;
	z-index: 10000;
}

#page-top a {
    background: #6D89C5;
    text-decoration: none;
    color: #fff;
	padding: 20px 15px;
    text-align: center;
    display: block;
	-moz-border-radius: 50px;
	-webkit-border-radius: 50px;
	border-radius: 50px;
}

#page-top a:hover {
    text-decoration: none;
    background: #000;
}

/* ブログ
-------------------------------------*/


/* ------------------------------------------------------------------------------
     タブレット・PC端末（480px〜960px）
------------------------------------------------------------------------------ */ 
@media only screen and (max-width: 1020px) {

.pc {
	display:none;
}

.sp {
	display:block;
}

.tab {
	display:block;
}

.pcBr:after {
     content:inherit;
     white-space:nowrap;
}

.width {
	width: 90%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

/* ナビゲーション
-------------------------------------*/

#nav {
	display: none;
}


}
/* /@media */


/* ------------------------------------------------------------------------------
     小型タブレット・スマホ端末（〜480px）（〜640px）
------------------------------------------------------------------------------ */
@media only screen and (max-width: 640px) {

.pc {
	display:none;
}

.sp {
	display:block;
}

.tab {
	display:none;
}

.pcBr:after {
     content:inherit;
     white-space:nowrap;
}

.width {
	width: 90%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}
	
.width50 {
	width: 100%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}


/* 文字
-------------------------------------*/

h1 {
	font-size: 160%;
	margin-bottom: 50px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 35px;
	font-weight: normal;
	text-align: center;
	letter-spacing: 0.1em;
	font-family: "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
}

h1 span {
	display: block;
	font-size: 35%;
	margin-top: 0px;
	margin-left: auto;
	margin-right: auto;
	font-weight: normal;
	padding: 3px 0;
	text-align: center;
	text-transform: uppercase;
	color: #6D89C5;
}

h2 {
	font-size: 150%;
	margin-bottom: 20px;
	text-align: left;
	font-weight: normal;
	letter-spacing: 0.1em;
}

h2 span {
	display: block;
	width: 20%;
	background: #8CB808;
	color: #FFF;
	vertical-align: middle;
	font-size: 30%;
	padding: 2px 20px;
	margin-left: auto;
	margin-right: auto;
	-moz-border-radius: 50px;
	-webkit-border-radius: 50px;
	border-radius: 50px;
}

/* ヘッダー
-------------------------------------*/

#fix {
	position: fixed;
	background: #FFF;
	box-sizing: border-box;
	margin: 0 auto;
	width: 100%;
	z-index: 100000;
	box-shadow: 0 0 5px rgba(150,150,150, 0.5);
	padding: 20px 30px 20px 30px;
    transition : all 500ms;
	border-bottom: 1px solid #E5E5E5;
}

#fix.fixed2 {
	position: fixed;
	background: #FFF;
	box-sizing: border-box;
	margin: 0 auto;
	width: 100%;
	z-index: 1000;
	box-shadow: 0 0 5px rgba(150,150,150, 0.5);
	padding: 10px 10px 10px 10px;
    transition : all 500ms;
	border-bottom: 1px solid #E5E5E5;
}

#h_left {
	float: left;
}

#h_right {
	float: right;
}

/* ナビゲーション
-------------------------------------*/

#nav {
	display: none;
}


/* コンテンツ
-------------------------------------*/

#container {
	position: relative;
	z-index: 10;
	top:-50px;
}

#content_bg {
	position: relative;
	z-index: 1000;
	background: #FFF;
	padding: 25px;
	margin-bottom: 20px;
	box-sizing: border-box;
}

section {
	padding-bottom: 100px;
}

#concept {
	display: block;
    padding-top: 150px;
    margin-top:-150px;
}

#works,
#company,
#access {
	display: block;
    padding-top: 100px;
    margin-top:-100px;
}

.column2 {
	width: 100%;
	float: none;
	margin-right: 0%;
}

.column2:nth-child(2n) {
	margin-right: 0;
}

.column3 {
	width: 48%;
	float: left;
	margin-right: 4%;
	margin-bottom: 20px;
}

.column3:nth-child(3n) {
	margin-right: 4%;
}

.column3:nth-child(2n) {
	margin-right: 0;
}

.column4 {
	width: 23.5%;
	float: left;
	margin-right: 2%;
}

.column4:nth-child(4n) {
	margin-right: 0;
}

.column5 {
	width: 48%;
	float: left;
	margin-right: 4%;
}

.column5:nth-child(5n) {
	margin-right: 4%;
}

.column5:nth-child(2n) {
	margin-right: 0%;
}

.left {
	width: 100%;
	float: none;
}

.right {
	width: 100%;
	float: none;
}

/* TOPページ
-------------------------------------*/

#main {
	position: relative;
	z-index: 1;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
}

#main #main_bg {
	position: absolute;
	bottom: 0%;
	right: 0%;
	margin: auto;
	z-index: 10;
	width: 50%;
}
	
#main div.passing {
	position: absolute;
	top: 50%;
	left: 10%;
	right: 10%;
	transform: translateY(-50%) translateX(0%);
	margin: auto;
	z-index: 10;
	text-align: center;
}

.title {
	font-size: 200%;
	font-weight: bold;
	text-align: center;
	font-family: "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	line-height: 130%;
	text-shadow: 2px 2px 0 #FFFFFF, 2px -2px 0 #FFFFFF, -2px 2px 0 #FFFFFF, -2px -2px 0 #FFFFFF, 2px 0px 0 #FFFFFF, 0px 2px 0 #FFFFFF, -2px 0px 0 #FFFFFF, 0px -2px 0 #FFFFFF;
}

.title em {
	display: block;
	font-style: normal;
	font-size: 65%;
}

.title span {
	margin-top: 20px;
	display: block;
	font-size: 40%;
}

.bg_blue {
	background: #F3F5FA;
}

.bg_white {
	background: #FFF;
	padding: 20px;
	box-sizing: border-box;
}

/* 下階層共通
-------------------------------------*/

#prt_main {
	margin-top: 100px;
	padding: 120px 0 150px;
}

#service #prt_main {
	background: url("../img/content/service/main.jpg") center center no-repeat;
}

#clean-ag #prt_main {
	background: url("../img/content/clean-ag/main.jpg") center center no-repeat;
}

#prt_main h1 {
	display: none;
	margin: 0;
	padding: 0;
	text-align: left;
	text-transform: uppercase;
	color: #FFF;
	text-shadow: 1px 1px 1px #999;
}

#prt_main h1 span {
	text-align: left;
}

#listNavi {
	background: #FFF;
	font-size:70%;
	padding: 10px 0;
	-webkit-text-size-adjust: none;
}

#listNavi a {
	text-decoration: underline;
}

#listNavi div {
	text-align: left;
}

#listNavi span {
	background: url("../img/common/listNavi.png") center left no-repeat;
	padding:5px 0 5px 25px;
}

/* コンテンツ
-------------------------------------*/


/* サイドバー
-------------------------------------*/


/* フッター
-------------------------------------*/
/*
footer {
}

#footer_top {
	background: #F3F5FA;
	margin-top: -50px;
}

#home #footer_top {
	background: #FFF;
	margin-top: -50px;
}

#footer_top p {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

#footer_main {
	margin-top: -80px;
	padding: 100px 0 50px;
	background: #15408D;
}

address {
	text-align: center;
	font-style: normal;
	font-size: 75%;
	color: #FFF;
}
*/
	div.normalTbl table tr:nth-child(odd) th,
	div.normalTbl table tr:nth-child(odd) td {
		background: none;
	}

div.normalTbl table td {
	border-bottom: 1px dotted #6D89C5;
	padding: 20px 15px;
	text-align:left;
	display: block;
	width: auto;
}

div.normalTbl table th {
	border-bottom: 1px dotted #6D89C5;
	padding: 20px 15px;
	font-weight: bold;
	text-align: left;
	display: block;
	width: auto;
	background: #F3F5FA !important;
}
	
	.alignC {
		text-align: left;
	}

.menu {
	background: #FFF;
	color: #FFF;
	margin:0 auto;
	text-align:center;
	margin-top:0px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.menu a {
	color:#FFFFFF;
	background: #15408D;
	transition: 0.3s;
	text-decoration:none;
	display:block;
	padding: 15px;
	margin:0 auto;
	text-align:center;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}

.menu a:hover {
	color: #FFFFFF;
	transition: 0.3s;
	text-decoration: underline;
	background-color: #8D1515;
}

}
