@charset "utf-8";
#h1{
	position: fixed;
	top: 21px;
	left: 0;
	font-size: 1.2rem;
	width: 100%;
	z-index: 9;
	text-align: left;
	color: #2b8a43;
	opacity: 0;
}

#visual{
	padding: 0 0 120px;
	z-index: 2;
}

#service{
	background: #fff;
	position: relative;
	padding: 0 0 130px;
	z-index: 2;
}
#service:before{
	content: '';
	width: 72%;
	height: 625px;
	background: #F3F1EB;
	position: absolute;
	top: 70px;
	right: 0;
	z-index: -1;
}
#service h2{
	font-family: 'Arial Bold', sans-serif;
	font-size: 13rem;
	line-height: 100%;
	color: #ddcdbf;
	position: absolute;
	top: 316px;
	right: 0;
	z-index: 3;
}
#service p.text{
	font-size: 5rem;
	font-weight: bold;
	line-height: 140%;
	margin: 0 auto 40px;
	text-align: left;
}
#service p.tx2{
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 180%;
	margin: 0 auto 45px;
	text-align: left;
}
#service .flexslider{
	background: none;
}
#service .flex-control-nav{
	bottom: 66px;
}
#service .flex-direction-nav a{margin-top: -90px;}
#service .flexslider .flex-direction-nav .flex-next,
#service .flexslider:hover .flex-direction-nav .flex-next{
	opacity: 1;
	right: 20px;
}
#service .flexslider .flex-direction-nav .flex-prev,
#service .flexslider:hover .flex-direction-nav .flex-prev{
	opacity: 1;
	left: 20px;
}
#service .flex-direction-nav a:before{
	color: #000;
	text-shadow: 0 0 3px #fff,0 0 3px #fff,0 0 3px #fff;
	line-height: 40px;
}
#service ul.slides{
	display: block;
	letter-spacing: -0.4em;
	text-align: center;
	line-height: 0;
	margin: 0 auto 90px;
	position: relative;
	z-index: 1;
}
#service ul.slides>li{
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	margin: 0 15px;
	width: 480px;
}
#service ul>li>a{
	text-decoration: none;
	color: #333;
}
#service ul>li p.img{
	line-height: 0;
	margin: 0 auto 23px;
	overflow: hidden;
}
#service ul>li p.img img{
	width: 100%;
	height: auto;
	transition-duration: .5s;
}
#service ul>li>a:hover p.img img{
	transform: scale(1.1);
	-webkit-filter: grayscale(100%);
	-moz-filter: grayscale(100%);
	-ms-filter: grayscale(100%);
	-o-filter: grayscale(100%);
	filter: grayscale(100%);
}
#service ul>li p.tx{
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 120%;
	position: relative;
	text-align: left;
}
#service ul>li p.tx:before{
	content: '';
	width: 150px;
	height: 1px;
	background: #333;
	position: absolute;
	top: 50%;
	right: 0;
}
#service ul>li i{
	font-size: 1.2rem;
	line-height: 100%;
	display: block;
	font-style: normal;
	position: relative;
	padding: 8px 25px 0 0;
	text-align: right;
	font-weight: bold;
}
#service ul>li i:before{
	content: '';
	width: 16px;
	height: 16px;
	position: absolute;
	bottom: -1px;
	right: 0;
	margin-top: -8px;
	background: #fff;
	border: 1px solid #333;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-radius: 100%;
	z-index: 1;
}
#service ul>li i:after{
	position: absolute;
	bottom: 4px;
	right: 7px;
	display: block;
	content: '';
	width: 4px;
	height: 4px;
	margin-top: -2px;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	z-index: 2;
}
#service>ul.images{display: none !important;}

#bg{
	width: 100vw;
	height: 100vh;
	position: relative;
	z-index: 1;
}
#bg:after{
	content: '';
	background: url(../img/bg.jpg) center top no-repeat;
	background-size: cover;
	width: 100vw;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
}

#gallery{
	background: #fff;
	position: relative;
	z-index: 2;
	padding: 127px 0 85px;
	margin: 0 auto;
	overflow: hidden;
}
#gallery:before{
	content: '';
	width: 100vw;
	height: 100vh;
	background: #f3f1eb;
	position: absolute;
	top: 160px;
	left: 0;
	z-index: -1;
}
#gallery h2{
	font-family: 'Arial Bold', sans-serif;
	font-size: 7rem;
	line-height: 100%;
	color: #ddcdbf;
	margin: 0 auto 65px;
}
#gallery ul{
	display: block;
	letter-spacing: -0.4em;
	text-align: left;
	line-height: 0;
	margin: 0 auto 85px;
}
#gallery ul>li{
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	width: 285px;
	margin: 0 20px 0 0;
}
#gallery ul>li:last-child{
	margin-right: 0;
}
#gallery ul>li>a{
	display: block;
	color: #333;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
#gallery ul>li>a:hover{
	text-decoration: none;
}
#gallery ul>li p.img{
	line-height: 0;
	margin: 0 auto 16px;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
#gallery ul>li>a:hover p.img{
	filter:alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}
#gallery ul>li p.img img{
	width: 100%;
	height: auto;
}
#gallery ul>li p.tx{
	font-size: 1.4rem;
	line-height: 180%;
	text-align: left;
	margin: 0 auto 12px;
}
#gallery ul>li>a:hover p.tx{
	text-decoration: underline;
}
#gallery ul>li p.date{
	font-size: 1.2rem;
	line-height: 120%;
	margin: 0 auto;
	font-weight: bold;
	font-family: 'Arial Bold', sans-serif;
}

#recruit{
	background: #fff;
	padding: 175px 0 120px;
	position: relative;
	z-index: 2;
}
#recruit h2{
	font-size: 7rem;
	line-height: 100%;
	color: #ddcdbf;
	text-align: left;
	padding: 0 0 10px;
	margin: 0 auto 40px;
	border-bottom: 2px solid #666;
}
#recruit h2>span{
	font-family: 'Arial Bold', sans-serif;
}
#recruit h2>small{
	display: inline-block;
	line-height: 100%;
	font-size: 1.4rem;
	padding: 0 10px;
	color: #333;
	font-weight: normal;
}
#recruit table{
	margin: 0 auto 62px;
}
#recruit table th,
#recruit table td{
	font-size: 1.4rem;
	line-height: 120%;
	padding: 17px 50px;
	border-bottom: 1px dotted #ccc;
	text-align: left;
}
#recruit table th{
	padding: 20px 50px;
}
#recruit table td{
	border-top: 1px dashed #ccc;
	border-bottom: 1px dashed #ccc;
}
#recruit table td>a{
	display: inline-block;
	vertical-align: top;
	border-radius: 10px;
	background: #EEE;
	font-size: 1.2rem;
	line-height: 44px;
	padding: 0 40px;
	color: #333;
	font-weight: bold;
	position: relative;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
#recruit table td>a:hover{
	text-decoration: none;
	filter:alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}
#recruit table td>a:before{
	content: '';
	width: 16px;
	height: 16px;
	position: absolute;
	top: 50%;
	right: 15px;
	margin-top: -8px;
	background: #fff;
	border: 1px solid #333;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-radius: 100%;
	z-index: 1;
}
#recruit table td>a:after{
	position: absolute;
	top: 50%;
	right: 22px;
	display: block;
	content: '';
	width: 4px;
	height: 4px;
	margin-top: -2px;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	z-index: 2;
}
#recruit table td>a.btns{
	margin: 0 15px 0 0;
}
#recruit table td>a.btns2{
	margin: 0 auto;
	background: #333;
	color: #fff;
}

body p.btn{
	display: block;
	letter-spacing: -0.4em;
	text-align: center;
	line-height: 0;
}
body p.btn>a{
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	position: relative;
	z-index: 2;
	overflow: visible;
	margin: 0 30px 6px;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
body p.btn>a:hover{
	margin-bottom: 0;
}
body p.btn>a>i{
	display: inline-block;
	font-style: normal;
	background: #fff;
	border: 1px solid #333;
	padding: 0 60px;
	margin: 0;
	line-height: 58px;
	font-size: 1.4rem;
	color: #333;
	position: relative;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
body p.btn>a:hover>i{
	margin-top: 6px;
	margin-left: 6px;
}
body p.btn>a>i:after{
	position: absolute;
	top: 50%;
	right: 20px;
	display: block;
	content: '';
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
body p.btn>a:before{
	content: '';
	width: 100%;
	height: 100%;
	position: absolute;
	top: 6px;
	left: 6px;
	z-index: -1;
	background: #333;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	-o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
body p.btn>a:hover:before{
	background: none;
}
@media screen and (min-width:768px){
	body{padding-top: 0;}
	#visual{padding-top: 100px;}
	
	#service h2,
	#service p.text,
	#service p.tx2,
	#service .flexslider,
	#service .btn,
	#gallery h2,
	#gallery ul>li,
	#gallery .btn,
	#recruit h2,
	#recruit table,
	#recruit .btn{
		opacity: 0;
		transition: 0.6s ease;
	}
	[data-object="active"],
	#gallery ul[data-object="active"]>li,
	#recruit table[data-object="active"] tr{
		opacity: 1 !important;
	}
	
	#service p.tx2{transition: 1.2s ease;}
	
	#service h2,
	#gallery .btn{transition: 1.8s ease;}
	
	#service .flexslider{transition: 2.4s ease;}
	
	#gallery ul>li:nth-child(1){transition: 0.6s ease;}
	#gallery ul>li:nth-child(2){transition: 1.2s ease;}
	#gallery ul>li:nth-child(3){transition: 1.8s ease;}
	#gallery ul>li:nth-child(4){transition: 2.4s ease;}
	
	#recruit table tr:nth-child(1){transition: 0.6s ease;}
	#recruit table tr:nth-child(2){transition: 1.2s ease;}
	#recruit table tr:nth-child(3){transition: 1.8s ease;}
	#recruit table tr:nth-child(4){transition: 2.4s ease;}
}

@media screen and (max-width:767px){
	#visual{padding-bottom: 80px;}
	#visual .flex-control-nav{bottom: 56px;}
	
	#service{padding-bottom: 60px;}
	#service h2{
		top: 242px;
		font-size: 7rem;
	}
	#service p.text{
		font-size: 2.4rem;
	}
	#service p.tx2{
		font-size: 1.4rem;
		margin: 0 auto 60px;
	}
	#service .flexslider{
		margin: 0 10px;
	}
	#service ul.slides>li{
		margin: 0 auto;
	}
	#service .flexslider .flex-direction-nav .flex-next,
	#service .flexslider:hover .flex-direction-nav .flex-next{
		right: 10px;
	}
	#service .flexslider .flex-direction-nav .flex-prev,
	#service .flexslider:hover .flex-direction-nav .flex-prev{
		left: 0;
	}
	#service .flex-control-nav{bottom: 46px;}
	
	#gallery{padding: 60px 0;}
	#gallery:before{top: 80px;}
	#gallery h2{
		font-size: 5rem;
	}
	#gallery ul{margin-bottom: 30px;}
	#gallery ul>li{
		width: 48%;
		margin: 0 4% 20px 0;
	}
	#gallery ul>li:nth-child(2n){
		margin-right: 0;
	}
	#gallery ul>li p.img{margin-bottom: 8px;}
	#gallery ul>li p.tx{line-height: 140%;margin-bottom: 5px;}
	
	#recruit{padding: 60px 0;}
	#recruit h2{font-size: 4rem;}
	#recruit table,
	#recruit table tbody,
	#recruit table tr,
	#recruit table td{
		display: block;
	}
	#recruit table tr{margin: 0 auto 20px;}
	#recruit table td{padding: 10px;}
	#recruit table tr>td:last-child{
		text-align: center;
		border-bottom: none;
	}
	#recruit table tr>td::before{
		content: '';
		display: block;
		width: auto;
		padding: 10px;
		background: #efefef;
		font-size: 1.4rem;
		margin: -10px -10px 10px;
		font-weight: bold;
	}
	#recruit table tr>td:nth-child(1)::before{
		content: '掲載日';
	}
	#recruit table tr>td:nth-child(2)::before{
		content: '募集職種';
	}
	#recruit table tr>td:nth-child(3)::before{
		content: '業務内容';
	}
	#recruit table tr>td:last-child::before{content: none;}
	
	body p.btn>a{
		margin: 0 10px 6px;
	}
	body p.btn>a>i{
		padding: 0 50px 0 40px;
		line-height: 48px;
	}
	#service p.btn>a>i{
		padding: 0 30px 0 20px;
	}
	#service p.btn>a>i:after{right: 15px;}
}
