@charset "utf-8";

@import "base_layout.css";
@import "common_parts.css";

#header{
	height: 99px;
	background: url(../../img/common/header_bg.png) repeat-x;
}
#header .wrapper{
	position: relative;
	height: 40px;
	background: none;
}
#header .wrapper .logo{
	width: 197px;
	height: 29px;
	position: absolute;
	top: 15px;
	left: 0;
}
#header .wrapper #globalNav{
	position: absolute;
	top: 15px;
	right: 0;
}

@media screen and (max-width: 979px) {
#header{
	height: 130px;
	background: url(../../img/common/header_bg.png) repeat-x;
}
#header .wrapper{
	position: relative;
	height: 40px;
	background: none;
}
#header .wrapper .logo{
	width: 197px;
	height: 29px;
	position: absolute;
	top: 15px;
	left: 0;
	right: 0;
	margin: auto;
}
#header .wrapper #globalNav{
	position: absolute;
	top: 55px;
	right: 0;
	text-align: center;
	width: 100%;
}
}



/*mainPhoto*/
#mapnPhoto{
	height: 480px;
	width: 100%;
	background: url(../../img/toppage/main_photo.jpg) no-repeat center center fixed;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
}

#mapnPhoto .boxCatch{
	position: relative;
	width: 1050px;
	margin: auto;
	padding-top: 350px;
	height: 50px;
}
#mapnPhoto .boxCatch #catch01{
	position: absolute;
	width: 100%;
	text-align: right;
	left: 0;
	bottom: 150px;
	padding-right: 150px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	opacity: 0;
}
#mapnPhoto .boxCatch #catch02{
	position: absolute;
	width: 100%;
	text-align: right;
	left: 0;
	bottom: 90px;
	padding-right: 0px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	opacity: 0;
}
@media screen and (max-width: 979px) {
#mapnPhoto{
	height: 480px;
	width: 100%;
	background: url(../../img/toppage/main_photo.jpg) no-repeat center center;
	-moz-background-size: auto 100%;
	background-size: auto 100%;
}

#mapnPhoto .boxCatch{
	position: relative;
	width: 100%;
	margin: auto;
	padding-top: 350px;
	height: 50px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
#mapnPhoto .boxCatch #catch01,
#mapnPhoto .boxCatch #catch02{
	left: 0;
	right: 0;
	margin: auto;
	width: 95%;
}
#mapnPhoto .boxCatch #catch01 img,
#mapnPhoto .boxCatch #catch02 img{
	width: auto;
	height: 25px;
}
}

@media screen and (max-width: 620px) {
#mapnPhoto .boxCatch #catch01{
	padding-right: 0px;
}


#mapnPhoto .boxCatch #catch01 img,
#mapnPhoto .boxCatch #catch02 img{
	max-width: 100%;
	max-height: 18px;
	width: auto;
	height: auto;
}
}


/*topics
************************************************************************************/
#frameTopics{
}

#frameTopics .title_frame{
	margin: -40px 0 0 0;
	padding-bottom: 40px;
	float: left;
	width: 265px;
}
#frameTopics .title_frame .title{
	width: 265px;
	height: 195px;
	background: url(../../img/toppage/topics_ttl.png) no-repeat;
	display: block;
	text-indent: -9999px;
}

#frameTopics .title_frame .bn_naka{
	margin: 15px 0 0 0;
	text-align: center;
}
#frameTopics .title_frame .bn_naka img{
	max-width: 90%;
	height: auto;
}

#frameTopics .boxTopics{
	width: 760px;
	float: right;
	padding: 25px 0 0 0;
}

#frameTopics .boxTopics .note{
	background: #FFE4E4;
	padding: 20px;
	text-align: center;
	font-weight: bold;
	margin: 0 0 1em 0;
}

#frameTopics .boxTopics li{
	display: table;
	width: 100%;
	padding: 17px 0;
	border-bottom: 1px solid #009944;
}

#frameTopics .boxTopics li .date{
	font-weight: bold;
	width: 9em;
	display: table-cell;
}
#frameTopics .boxTopics li .ttl{
	display: table-cell;
	text-align: left;
}

@media screen and (max-width: 979px) {
#frameTopics .title_frame{
	margin: -1.5% 0 0 0;
	padding-bottom: 1.5%;
	float: left;
	width: 25%;
}
#frameTopics .title_frame .title{
	width: 100%;
	height: 195px;
	background: url(../../img/toppage/topics_ttl.png) no-repeat;
	-moz-background-size: 100% auto;
	background-size: 100% auto;
	display: block;
	text-indent: -9999px;
}
#frameTopics .boxTopics{
	width: 72%;
	float: right;
	padding: 0.5% 1% 0 0;
}
}

@media screen and (max-width: 620px) {
#frameTopics{
	margin: -4% 0 0 0;
	padding-bottom: 4%;
	background: url(../../img/sp/news_bg.png) no-repeat center top;
	-moz-background-size: 100% auto;
	background-size: 100% auto;
}

#frameTopics .title_frame{
	margin: auto;
	padding: 30px 0 10px 0;
	float: none;
	width: 90%;
	height: auto;
	display: block;
	text-indent: 0;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	font-size: 2.5rem;
	color: #329d1c;
	text-align: center;
	font-weight: bold;
	letter-spacing: 5px;
}
#frameTopics .title_frame .title{
	background: none;
	height: auto;
	display: block;
	text-indent: 0;
	
}

#frameTopics .title_frame .title:after{
	content: "- NEWS TOPICS -";
	font-size: 1.4rem;
	font-weight: normal;
	color: #666;
	letter-spacing: normal;
	display: block;
}

#frameTopics .boxTopics{
	width: 90%;
	margin: auto;
	float: none;
	padding: 0.5% 0 0 0;
}
#frameTopics .boxTopics li{
	display: block;
	width: 100%;
}

#frameTopics .boxTopics li .date{
	font-weight: bold;
	width: auto;
	display: block;
}
#frameTopics .boxTopics li .ttl{
	display: block;
	text-align: left;
}
}


/*frameRecruit
************************************************************************************/
#frameRecruit{
	margin: 60px 0 40px 0;
}

#frameRecruit h2{
	font-size: 3.6rem;
	text-align: center;
	margin: 0 0 35px 0;
}
#frameRecruit h2 span{
	border-bottom: 5px solid #00c353;
	padding: 0 0 5px 0;
}

#frameRecruit ul.select{
	display: table;
	width: 100%;
}
#frameRecruit ul.select li{
	display: table-cell;
	vertical-align: middle;
	width: 50%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	text-align: center;
	position: relative;
	background: #000;
	overflow: hidden;
	padding: 30px 0;
}
#frameRecruit ul.select li a{
	color: #FFF;
	text-decoration: none;
}
#frameRecruit ul.select li:before{
	padding-top: 32%;
	content: "";
	display: block;
}

#frameRecruit ul.select li .inbox{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 50;
	color: #FFF;
	width: 100%;
}

#frameRecruit ul.select li .inbox .ttl{
	position: relative;
	font-weight: 600;
	display: inline-block;
	z-index: 50;
	text-align: center;
	padding-bottom: 25px;
	margin-bottom: 25px;
}
#frameRecruit ul.select li .inbox .ttl:after {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	content: '';
	width: 32px;
	height: 3px;
	background-color: #bfe139;
}

#frameRecruit ul.select li .image{
	z-index: 10;
	position: absolute;
	top: 0;
	left: 0;
}
#frameRecruit ul.select li .image img{
	width: 100%;
	height: auto;
	opacity: 0.4;
	-webkit-transition:all 0.25s ease-in-out;
	transition:all 0.25s ease-in-out;
}

#frameRecruit ul.select li:hover .image img{
	transform: scale(1.15,1.15);
	-webkit-transform:scale(1.15,1.15);
	-moz-transform:scale(1.15,1.15);
	-ms-transform:scale(1.15,1.15);
	-o-transform:scale(1.15,1.15);
}

#frameRecruit ul.select li .inbox .sttl{
	font-weight: bold;
	font-size: 2.4rem;
}
#frameRecruit ul.select li .inbox .cmt{
	font-size: 1.8rem;
	padding-bottom: 45px;
	background: url(../../img/common/ar_green.png) no-repeat center bottom;
	-moz-background-size: 35px auto;
	background-size: 35px auto;
}

@media screen and (max-width: 979px) {
#frameRecruit{
	margin: 40px 0 40px 0;
}

#frameRecruit h2{
	font-size: 2.8rem;
	text-align: center;
	margin: 0 0 35px 0;
}
#frameRecruit h2 span{
	border-bottom: 3px solid #00c353;
	padding: 0 0 5px 0;
}

#frameRecruit ul.select{
	display: table;
	width: 100%;
}
#frameRecruit ul.select li{
	padding: 20px 0;
}

#frameRecruit ul.select li .inbox .ttl img{
	max-width: 95%;
	height: 23px;
	width: auto;
}

#frameRecruit ul.select li .inbox .sttl{
	display: none;
}
#frameRecruit ul.select li .inbox .cmt{
	display: none;
}
}

@media screen and (max-width: 620px) {
#frameRecruit ul.select{
	display: block;
	width: 100%;
}
#frameRecruit ul.select li{
	display: block;
	vertical-align: middle;
	width: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	text-align: center;
	position: relative;
	background: #000;
	overflow: hidden;
	padding: 30px 0;
	margin: 0 0 1px 0;
}
#frameRecruit ul.select li .inbox .sttl{
	display: block;
}
#frameRecruit ul.select li .inbox .cmt{
	display: block;
}

#frameRecruit ul.select li .inbox .sttl{
	font-weight: bold;
	font-size: 2.1rem;
}
#frameRecruit ul.select li .inbox .cmt{
	font-size: 1.4rem;
	padding-bottom: 35px;
	background: url(../../img/common/ar_green.png) no-repeat center bottom;
	-moz-background-size: 25px auto;
	background-size: 25px auto;
}
}

@media screen and (max-width: 480px){
#frameRecruit ul.select li{
	padding: 15px 0;
	margin: 0 0 1px 0;
}

#frameRecruit ul.select li .inbox .ttl{
	padding-bottom: 15px;
	margin-bottom: 15px;
}
#frameRecruit ul.select li .inbox .ttl:after {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	content: '';
	width: 32px;
	height: 3px;
	background-color: #bfe139;
}
#frameRecruit ul.select li .inbox .sttl{
	font-size: 1.9rem;
}
#frameRecruit ul.select li .inbox .cmt{
	font-size: 1.4rem;
	padding-bottom: 0;
	background: none;
}
}




/*about
************************************************************************************/
#frameAbout{
	margin: 0 0 50px 0;
}

/*title*/
#frameAbout .frame_title{
	background: #6cb211;
	padding: 40px 0;
	color: #FFF;
	text-align: center;
}
#frameAbout .frame_title h2{
	font-size: 3.6rem;
	background: url(../../img/common/icon_yellow.png) no-repeat center bottom;
	-moz-background-size: 7px auto;
	background-size: 7px auto;
	padding: 0 0 25px 0;
	margin: 0 0 25px 0;
}
#frameAbout .frame_title .comment{
	font-size: 1.7rem;
}

/*photo*/
#frameAbout .frame_photo{
	width: 1050px;
	display: table;
	border-spacing: 1px 0;
	margin: 1px auto 20px;
}
#frameAbout .frame_photo .photo{
	display: table-cell;
}
#frameAbout .frame_photo .photo img{
	width: 100%;
	height: auto;
}

/*informations*/
#frameAbout .frame_details{
	width: 1050px;
	margin: auto;
}
#frameAbout .frame_details .information{
	float: left;
	width: 540px;
}
#frameAbout .frame_details .information table{
	width: 100%;
	margin: 0 auto;
	border-collapse:collapse;
	border: 0;

}

#frameAbout .frame_details .information th{
	padding: 15px;
	width: 90px;
	text-align: left;
	border-bottom: 1px solid #CCC;
}

#frameAbout .frame_details .information td{
	padding: 15px;
	border-bottom: 1px solid #CCC;
}

#frameAbout .frame_details tr:last-child th,
#frameAbout .frame_details tr:last-child td{
	border: 0;
}

#frameAbout .frame_details .map{
	float: right;
	width: 480px;
	height: 440px;
}

@media screen and (max-width: 979px) {
#frameAbout .frame_title .comment{
	font-size: 1.4rem;
	padding: 0 1.5%;
}
#frameAbout .frame_title .comment br{
	display: none;
}

#frameAbout .frame_photo{
	width: 100%;
}

#frameAbout .frame_details{
	width: 100%;
}

#frameAbout .frame_details .information{
	float: none;
	width: 90%;
	margin: auto;
}
#frameAbout .frame_details .map{
	display: none;
}
}

@media screen and (max-width: 768px){
#frameAbout .frame_title h2{
	font-size: 2.8rem;
}
}

/*rinen
************************************************************************************/
#frameRinen{
	background: url(../../img/toppage/shisei_bg.jpg) no-repeat top;
	-moz-background-size: 100% auto;
	background-size: 100% auto;
	padding: 55px 0;
}

#frameRinen h2{
	font-size: 3.6rem;
	text-align: center;
}
#frameRinen h2 span{
	border-bottom: 5px solid #00c353;
	padding: 0 0 5px 0;
}
#frameRinen .subtitle{
	font-size: 3.0rem;
	color: #00c353;
	text-align: center;
	margin: 65px 0;
}

#frameRinen ol.number li{
	line-height: 2.0;
}



@media screen and (max-width: 979px) {
#frameRinen{
	padding: 55px 1.5%;
}
#frameRinen h2{
	font-size: 2.8rem;
}
#frameRinen h2 span{
	border-bottom: 3px solid #00c353;
	padding: 0 0 5px 0;
}
#frameRinen .subtitle{
	font-size: 2.5rem;
	margin: 40px 0;
}


}

@media screen and (max-width: 768px){
}

@media screen and (max-width: 620px){
#frameRinen .subtitle{
	font-size: 1.9rem;
	font-weight: bold;
	margin: 40px 0;
}
}

@media screen and (max-width: 480px){
}

@media screen and (max-width: 350px){
#frameRinen ul.boxSeido li .icon img{
	max-width: 100%;
	width: auto;
	height: auto;
}
}