html,body{
	height: 100%;
}
#wrapper{
	height: 100%;
}

/*
main-img
----------------------------------------*/
#main-img {
	height: 100%;
	background: url(../img/top/bg_top.jpg) no-repeat center center fixed;
	background-size: cover;
	text-align: left;
	letter-spacing: 0.1em;
}
#main-img .frame {
	width: auto;
	margin: 0 auto;
	padding: 25% 0 0;
	position: relative;
	text-align: center;
}
#main-img .frame h1 {
	color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 84px;
  line-height: 1.3;
  font-weight: 100;
  text-shadow: 0 0px 3px rgba(0,0,0,0.3);
}
#main-img .frame h2.catch {
  margin: -6px 0 0 5px;
  font-size: 24px;
  font-weight: 300;
  letter-spacing: 0.3em;
  color: #fff;
  line-height: 1.8;
  text-shadow: 0 0px 3px rgba(0,0,0,0.3);
}
#main-img .frame .btn {
	display: inline-block;
	width: 300px;
	height: 64px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;
}
#main-img .frame .btn::before,
#main-img .frame .btn::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
#main-img .frame .btn,
#main-img .frame .btn::before,
#main-img .frame .btn::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .25s;
	transition: all .25s;
}
#main-img .frame .btn {
	position: relative;
	margin-top: 15px;
	z-index: 2;
	background: none;
	border: 4px solid #fff;
	color: #fff;
	line-height: 60px;
	overflow: hidden;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.14em;
	display: inline-block;
	/*padding:0px 50px;*/
}
#main-img .frame .btn:hover {
	color: #36699E;
}
#main-img .frame .btn::after {
	top: 0;
	left:-100%;
	width: 100%;
	height: 100%;
}
#main-img .frame .btn:hover::after {
	/*top: 0;*/
	left: 0;
	background-color: #fff;
}
#main-img .scroll {
	position: absolute;
	bottom: 15px;
	left: 50%;
	margin-left: -28px;
}
#main-img .copy {
	position: absolute;
	top: 200px;
	right: 20px;
}

/*
content
----------------------------------------*/
#content{
	  background: #fff;
}

/* lead */

.lead {
	overflow:hidden;
	width:920px;
	margin:50px auto;
}
.lead .cp { float:left;}
.lead .cp p span {
	font-size: 24px;
	margin-bottom: 20px;
	font-family: "Josefin Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
    font-weight: 600;
	color: #1379ff;
	font-style: italic;
	display:block;
}
.lead .cp p {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 46px;
	line-height: 1.6;
	font-weight: 800;
	font-style: italic;
	text-align:left;
}
.lead .text {
	float:right;
	text-align:left;
	letter-spacing: 0.02em;
	font-weight: bold;
	line-height: 2.4;
}

/* about */
.about {
    background: #fff693;
	background-position-x: 0%;
	background-position-y: 0%;
	background-size: auto;
    background-position: center bottom -40px;
    background-size: 102% auto;
}
.about .container {
	position: relative;
	padding: 50px 0 200px;
	max-width: 1740px;
	margin-right: auto;
	margin-left: auto;
}
.about-content {
	position: relative;
	z-index: 1;
	background:#fff;
	width: 45%;
	margin: 10% auto 0;
}
.about-header {
	padding: 0;
	position: absolute;
	top: -40px;
	left: -100px;
}
.about-header h2 {
	font-family: "Josefin Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	color: #1379ff;
	font-size: 60px;
	font-weight: 600;
	font-style: italic;
	text-align:left;
	text-transform: uppercase;
	margin-bottom:50px;
	line-height:1;
}
.about-header h2 span.jp {
	font-size:14px !important;
	color:inherit !important;
	display:block;
}
.about-header h3 {
	font-size: 32px;
	text-align:left;
	font-family: 'Noto Sans JP', sans-serif;
	line-height: 1.6;
	font-weight: 800;
	font-style: italic;
	padding:0;
	height:auto;
}
.about-text {
    font-size: 14px;
    padding: 270px 100px 20px;
	line-height: 2.4;
	font-weight: bold;
	text-align:left;
}
.about-img01 {
	position: absolute;
	top: -5%;
	right: 0;
	width: 46%;
	z-index: 2;
}
.about-img01 img {
	width:560px;
}
.about-img02 {
	position: absolute;
	left: 5%;
    width: 25%;
	bottom: 10%;
	z-index: 1;
}
.about-img02 img {
	width:360px;
}


/* service */
.service {
	overflow:hidden;
}
.service li {
	width:50%;
	float:left;
}

.service-item01,
.service-item02,
.service-item03,
.service-item04 {
    position: relative;
    overflow: hidden;
    text-align: center;
    text-shadow: 0 0 12px #7b7a35;
    padding:0;
	height:420px;
}
.service-item01:after {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    background: url(../img/top/outsourcing_img.jpg) no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -ms-background-size: cover;
    background-size: cover;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;
}
.service-item01:hover:after {
    opacity: .8;
    -moz-transform: scale(1.2);
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
}
.service-item02:after {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    background: url(../img/top/temporary_img.jpg) no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -ms-background-size: cover;
    background-size: cover;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;
}
.service-item02:hover:after {
    opacity: .8;
    -moz-transform: scale(1.2);
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
}
.service-item03:after {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    background: url(../img/top/cleaning_img.jpg) no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -ms-background-size: cover;
    background-size: cover;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;
}
.service-item03:hover:after {
    opacity: .8;
    -moz-transform: scale(1.2);
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
}
.service-item04:after {
    position: absolute;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    background: url(../img/top/private_img.jpg) no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -ms-background-size: cover;
    background-size: cover;
    -webkit-transition: all .3s ease-out;
    -moz-transition: all .3s ease-out;
    -ms-transition: all .3s ease-out;
    transition: all .3s ease-out;
}
.service-item04:hover:after {
    opacity: .8;
	-moz-transform: scale(1.2);
    -webkit-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
}
.service-item-title {
	position: absolute;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	z-index:1;
	width:100%;
}
.service-item-title h3 {
	padding:0;
	color:#fff;
	text-align: center;
	font-family: "Josefin Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	font-style: italic;
	font-weight: 600;
	font-size: 38px;
	line-height: 1.2;
	height:auto;
}
.service-item-title h3 span {
	font-size:14px;
	display:block;
}
.service-item-title h3 img {
	width:80px;
	display:block;
	margin:0 auto 10px;
}

/* news */
#content #news {
	width: 100%;
	display: table;
}
#content #news .left {
	width: 25%;
	background: #eee;
	display: table-cell;
	vertical-align: middle;
}
#content #news .right {
	width: 75%;
	padding: 46px 0 60px;
	display: table-cell;
}
#content #news .left h3 {
	font-family: "Josefin Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	margin: 0 auto;
	padding: 0;
	background: none;
	text-align: center;
	color: #000;
	font-size: 40px;
	font-weight: 600;
}
#content #news .left p {
	margin: 16px 0 24px;
	color: #666;
}
#content #news .right article a {
	width: 735px;
	margin: 0 auto;
	padding: 14px 0;
	border-bottom: 1px solid #eee;
	color: #444;
	display: block;
	text-decoration: none;
	text-align: left;
}
#content #news .right article a:hover {
	color: #5992F8;
}
#content #news .right article a .top {
	margin: 0 0 14px;
}
#content #news .right article a .top .day {
	color: #bbb;
	font-size: 16px;
}
#content #news .right article a .top .day i{
	color:#649CE5;
	margin-right: 20px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .1s;
	transition: all .1s;
	line-height:1;
}
#content #news .right article a:hover .top .day i{
	margin-right: 5px;
	margin-left: 15px;
}
#content #news .right article a:hover .top .day {
	/*background: url(../img/common/icon_arrow_blue.png) no-repeat 12px center;*/
}
#content #news .right article a .bottom .icon {
	width: 73px;
	padding: 6px 0 6px;
	color: #fff;
	display: table-cell;
	font-size: 11px;
	text-align: center;
	line-height:1;
}
#content #news .right article a .bottom .icon.blue {
	background: #0ca2e6;
}
#content #news .right article a .bottom .icon.green {
	background: #34b5be;
}
#content #news .right article a .bottom .icon.lightblue {
	background: #08c6e4;
}
#content #news .right article a .bottom .title {
	padding: 0 0 0 10px;
	font-weight: bold;
	display: table-cell;
	vertical-align: middle;
	line-height:1;
}


@media screen and (max-width: 768px) {
#main-img {
	padding-top: 90px;
	margin-bottom:0;
	background-size: cover !important;
	background: url(../img/top/bg_top.jpg) no-repeat top center;
	height:450px;
}
#main-img .frame {
	width: auto;
	margin: 0;
	padding: 0;
}
#main-img .frame h1 {
	  margin: 0;
  padding: 0 0 0 20px;
  font-size: 40px;
  text-align: left;
	margin-top: 160px;
}
#main-img .frame h2.catch {
	margin: 0;
  padding: 10px 0 0 25px;
  font-size: 14px;
  text-align: left;
}
#main-img .frame h2.catch img {
	width: 200px;
	height: 29px;
}
#main-img .frame .btn {
	width: 260px;
  margin: 20px auto;
  display: block;
  line-height: 42px;
  font-size: 16px;
  height: 50px;
  border-width: 3px;
}
#main-img .frame .btn a {
	width: 263px;
	height: 55px;
}
#main-img .scroll{
	display: none;
}
#main-img .copy {
	display: none;
}

/* lead */
.lead {
	overflow:hidden;
	width:90%;
	margin:50px auto;
}
.lead .cp { float:none;}
.lead .cp p span {
	font-size: 24px;
	margin-bottom: 20px;
	font-family: "Josefin Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
    font-weight: 600;
	color: #1379ff;
	font-style: italic;
	display:block;
}
.lead .cp p {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 28px;
	line-height: 1.6;
	font-weight: 800;
	font-style: italic;
	text-align:left;
	margin-bottom:20px;
}
.lead .text {
	float:none;
	text-align:left;
	letter-spacing: 0.02em;
	font-weight: bold;
	line-height: 2.4;
}

/* about */
.about {
    background: #fff693;
}
.about .container {
	position: relative;
	padding: 50px 0;
	max-width: 100%;
	margin-right: auto;
	margin-left: auto;
}
.about-content {
	position: relative;
	z-index: 5;
	background:#fff;
	width: 90%;
	margin: 45% auto 0;
}
.about-header {
	position: inherit;
	top: 0;
	left: 0;
	padding:20px 20px 0;
}
.about-header h2 {
	font-family: "Josefin Sans", -apple-system, BlinkMacSystemFont, "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	font-size: 40px;
	text-align:left;
	margin-bottom:20px;
}
.about-header h2 span.jp {
	font-size:14px !important;
	color:inherit !important;
	display:block;
}
.about-header h3 {
	font-size: 20px;
	text-align:left;
	font-family: 'Noto Sans JP', sans-serif;
	line-height: 1.6;
	font-weight: 800;
	font-style: italic;
	padding:0;
	height:auto;
}
.about-text {
    font-size: 14px;
    padding:20px;
	line-height: 2.4;
	font-weight: bold;
	text-align:left;
}
.about-img01 {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	z-index: 2;
}
.about-img01 img {
	width:100%;
}
.about-img02 {
	position: inherit;
	left: 0;
    width:90%;
	bottom:0;
	z-index: 1;
	margin:0 auto;
}
.about-img02 img {
	width:100%;
}
/* service */
.service li {
	width:100%;
	float: none;
}
.service-item01,
.service-item02,
.service-item03,
.service-item04 {
	height:280px;
}
.service-item-title h3 {
	font-size: 24px;
}
.service-item-title h3 img {
	width:50px;
	display:block;
	margin:0 auto 10px;
}


/* news */
#content #news {
	width: 100%;
	display: block;
}
#content #news .left {
	width: auto;
	display: block;
	padding:20px;
}
#content #news .right {
	width: 100%;
	padding: 0;
	display: block;
}
#content #news .left .title {
	margin: 10px 0 0 20px;
	float: left;
	text-align: left;
}
#content #news .left h3 {
	width: auto;
	margin: 0;
	padding: 0;
	background: none;
	text-align: left;
	font-size: 24px;
	margin-bottom: 2px;
}
#content #news .left h3 img {
	width: 72px;
	height: 19px;
}
#content #news .left p {
	margin:0;
	color: #666;
}
#content #news .left .btn {
	margin: 28px 20px 0 0;
	float: right;
	font-size: 12px;
	width: 160px;
}
#content #news .right article a {
	width: auto;
	margin: 0 15px;
	padding: 20px 0;
}
#content #news .right article a:hover {
	color: #5992F8;
}
#content #news .right article a .top {
	margin: 0 0 14px;
}
#content #news .right article a .top .day {
	color: #bbb;
	font-size: 16px;
}
#content #news .right article a .bottom .icon {
	width: 73px;
	height: 10px;
	padding: 8px 0 7px;
	color: #fff;
	float: left;
	display: table-cell;
	font-size: 11px;
	text-align: center;
}
#content #news .right article a .bottom .icon.blue {
	background: #0ca2e6;
}
#content #news .right article a .bottom .icon.green {
	background: #34b5be;
}
#content #news .right article a .bottom .icon.lightblue {
	background: #08c6e4;
}
#content #news .right article a .bottom .title {
	padding: 0 0 0 10px;
	font-weight: bold;
	display: table-cell;
	vertical-align: middle;
}

}

footer {
	position: static;
	bottom: inherit;
}


.button {
  display: inline-block;
  width: 200px;
  height: 54px;
  text-align: center;
  text-decoration: none;
  line-height: 54px;
  outline: none;
  vertical-align:bottom;
}
.button::before,
.button::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.button,
.button::before,
.button::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  transition: all .3s;
}
.button01 {
  position: relative;
  z-index: 2;
  background-color: #fff;
  border: 2px solid #333;
  color: #333;
  line-height: 50px;
  overflow: hidden;
}
.button01:hover {
  color: #fff;
}
.button01::after {
  top: -100%;
  width: 100%;
  height: 100%;
}
.button01:hover::after {
  top: 0;
  background-color: #333;
}