@charset "UTF-8";

#mainimg,
.contents {
	width: 1200px;
	margin: 0 auto 30px;
	letter-spacing: -0.3em;
}
#mainimg > div,
.contents > div {
	display: inline-block;
	vertical-align: top;
	letter-spacing: normal;
}
#mainimg .mainimg {
	width: 860px;
	margin-right: 30px;
	overflow: hidden;
	position: relative;
}
#mainimg .mainimg span,
#mainimg .mainimg span {
	font-size: 14px;
	color:#666;
	display: block;
	line-height: 1.2;
}

#mainimg .mainimg span.icon-arrow-l {
	position: absolute;
    top: calc(50% - 20px);
    left: 0px;
    font-size: 40px;
    cursor: pointer;
    transition: 0.3s;
    background: rgba(255,255,255,0.6);
    line-height: 1;
    padding: 3px;
    text-align: center;
}
#mainimg .mainimg span.icon-arrow-r {
	position: absolute;
    top: calc(50% - 20px);
    right: 0px;
    font-size: 40px;
    cursor: pointer;
    transition: 0.3s;
    background: rgba(255,255,255,0.6);
    line-height: 1;
    padding: 3px;
    text-align: center;
}
#mainimg .mainimg span:hover.icon-arrow-l {
	transform: translateX(-3px);
}
#mainimg .mainimg span:hover.icon-arrow-r {
	transform: translateX(3px);
}
#mainimg .recruit {
	width: 310px;
}
#mainimg .recruit .sp {
	display: none;
}


.contents .info {
	width: 790px;
	margin-right: 30px;
}
.contents .info2 {
	width: 380px;
}
.contents .info .news {
	margin-bottom: 30px;
}
.contents .info .news h2 {
	font-size: 16px;
	line-height: 1;
	color: #70ad19;
	margin-bottom: 10px;
}
.contents .info .news dl {
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	letter-spacing: -0.3em;
}
.contents .info .news dt {
	display:inline-block;
	vertical-align: top;
	letter-spacing: normal;
	font-size: 14px;
	line-height: 1.2;
	color: #70ad19;
	border-top: 1px solid #CCC;
	width: 10em;
	padding:10px 1em;
	box-sizing: border-box;
}
.contents .info .news dd {
	display:inline-block;
	vertical-align: top;
	letter-spacing: normal;
	font-size: 14px;
	line-height: 1.2;
	border-top: 1px solid #CCC;
	width: calc(100% - 10em);
	box-sizing: border-box;
	padding: 10px 1em 10px 0;
}
.contents .info .news dt:nth-child(1),
.contents .info .news dd:nth-child(2) {
	border: none;
}

.contents .area {
	padding: 0 0 30px 20px;
	background-color: #f2f2f2;
	background-image: url(../img/top/map.png);
	background-size: contain;
	background-position: top right;
	background-repeat: no-repeat;
}
.contents .area h2 {
	font-size: 20px;
	line-height: 1;
	color: #FFF;
	background: #70ad19;
	width: 7em;
	text-align: center;
	padding: 15px 0;
	margin-bottom: 20px;
}
.contents .area p.body {
	font-size: 24px;
	line-height: 1.3;
	font-weight: 600;
	padding-left: 30px;
	margin-bottom: 20px;
}
.contents .area p.body span {
	display: block;
	font-size: 13px;
	font-weight: normal;
	line-height: 1.3;
}
.contents .area p {
	font-size: 16px;
	line-height: 1.4;
	padding-left: 30px;
	margin-bottom: 20px;
}
.contents .area a,
.contents .area a:link,
.contents .area a:visited {
	display: block;
	width: 15em;
	font-size: 14px;
	box-sizing: border-box;
	color: #70ad19;
	background: #FFF;
	margin-left: 30px;
	text-decoration: none;
	padding: 1em;
	position: relative;
	transition: 0.3s;
}
.contents .area a:hover {
	color: #FFF;
	background: #70ad19;
}
.contents .area a i {
	font-size: 16px;
	position: absolute;
	top: calc(50% - 8px);
	right: 1em;
}
.contents .info2 .line {
	letter-spacing: -0.3em;
	margin-bottom: 20px;
}
.contents .info2 .line a,
.contents .info2 .line a:link,
.contents .info2 .line a:visited {
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	width: 230px;
	margin-right: 10px;
	transition: 0.3s;
}
.contents .info2 .line a:hover {
	opacity: 0.8;
	-moz-opacity: 0.8;
	-webkit-opacity: 0.8;
}
.contents .info2 .line p {
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	width: calc(100% - 230px - 10px);
	border-top: 1px solid #0b0;
	border-bottom: 1px solid #0b0;
	color: #0b0;
	height: 71px;
	font-size: 18px;
	text-align: center;
	line-height: 1.2;
	box-sizing: border-box;
	padding-top: 14px;
	margin: 0;
}
.contents .info2 .maker {
	border: 1px solid #CCC;
	padding: 20px;
}
.contents .info2 .maker h2 {
	font-size: 16px;
	font-weight: normal;
	line-height: 1;
	margin-bottom: 10px;
}
.contents .info2 .maker ul {
	letter-spacing: -0.3em;
	margin: 0 -5px;
}
.contents .info2 .maker li {
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	width: calc(50% - 10px);
	margin: 0 5px 10px;
	box-sizing: border-box;
	border: 1px solid #CCC;
}

@media only screen and (max-width: 1200px) {

#mainimg,
.contents {
	width: 96%
}
#mainimg .mainimg {
	width: calc(74.2% - 30px);
}
#mainimg .recruit {
	width: 25.8%;
}

.contents .info {
	width: calc(65.8% - 30px);
}
.contents .info2 {
	width: 34.2%;
}
.contents .area h2 {
	font-size: 18px;
}
.contents .area p.body {
	font-size: 20px;
	padding-left: 20px;
}
.contents .area p {
	font-size: 15px;
	padding-left: 20px;
}
.contents .area a,
.contents .area a:link,
.contents .area a:visited {
	margin-left: 20px;
}
.contents .info2 .line {
	letter-spacing: -0.3em;
	margin-bottom: 20px;
}
.contents .info2 .line a,
.contents .info2 .line a:link,
.contents .info2 .line a:visited {
	width: calc(60.5% - 10px);
}
.contents .info2 .line p {
	width: 39.5%;
	height: auto;
	line-height: 1;
	padding:3% 0;
}
	
}

@media only screen and (max-width: 1024px) {


.contents .area {
	background-image: url(../img/top/map2.png);
}
.contents .area p.body {
	font-size: 18x;
}
.contents .area p {
	font-size: 14px;
}
.contents .info2 .line p {
	font-size: 16px;
}

}

@media only screen and (max-width: 768px) {

#mainimg {
	width: 100%;
	margin-bottom: 15px;
}
#mainimg > div,
.contents > div {
	display:block;
}
#mainimg .mainimg {
	width: 100%;
	margin-bottom: 10px;
}
#mainimg .mainimg span,
#mainimg .mainimg span {
	font-size: 13px;
}

#mainimg .mainimg span.icon-arrow-l {
    top: calc(50% - 15px);
    font-size: 30px;
}
#mainimg .mainimg span.icon-arrow-r {
    top: calc(50% - 15px);
    font-size: 30px;
}
#mainimg .recruit {
	width: 96%;
	margin: 0 auto;
}
#mainimg .recruit .pc {
	display: none;
}
#mainimg .recruit .sp {
	display: block;
	text-align: center;
}
#mainimg .recruit .sp > a {
	max-width: 400px;
	display: block;
	margin: 0 auto 10px
}
#mainimg .recruit .line {
	letter-spacing: -0.3em;
	margin: 0 auto;
}
#mainimg .recruit .line a,
#mainimg .recruit .line a:link,
#mainimg .recruit .line a:visited {
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	width: 170px;
	margin-right: 5px;
	transition: 0.3s;
}
#mainimg .recruit .line p {
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	width: calc(100% - 170px - 5px);
	max-width: 125px;
	border-top: 1px solid #0b0;
	border-bottom: 1px solid #0b0;
	color: #0b0;
	height: auto;
	font-size: 16px;
	text-align: center;
	line-height: 1.2;
	box-sizing: border-box;
	padding:7px 0;
	margin: 0;
}	
.contents .info {
	width: 100%;
}
.contents .info2 {
	width: 100%;
}
.contents .info .news {
	margin-bottom: 20px;
}
.contents .info .news h2 {
	font-size: 16px;
}
.contents .info .news dt {
	font-size: 13px;
	padding:10px 1%;
	width: 8em
}
.contents .info .news dd {
	font-size: 13px;
	padding-right: 1%;
	width: calc(100% - 8em);
}

.contents .area {
	padding: 0 0 20px 0;
	margin-bottom: 20px;
}
.contents .area h2 {
	font-size: 16px;
	padding: 10px 0;
	margin-bottom: 15px;
}
.contents .area p.body {
	font-size: 18px;
	padding: 0 10px;
	margin-bottom: 15px;
}
.contents .area p {
	font-size: 13px;
	padding: 0 10px;
	margin-bottom: 15px;
}
.contents .area a,
.contents .area a:link,
.contents .area a:visited {
	margin: 0 auto;
}
.contents .info2 .line {
	display: none;
}
.contents .info2 .maker {
	border: 1px solid #CCC;
	padding: 10px;
}
.contents .info2 .maker ul {
	letter-spacing: -0.3em;
	margin: 0 -5px;
}
.contents .info2 .maker li {
	display: inline-block;
	letter-spacing: normal;
	vertical-align: top;
	width: calc(50% - 10px);
	margin: 0 5px 10px;
	box-sizing: border-box;
	border: 1px solid #CCC;
}
	
}

@media only screen and (max-width: 480px) {

	
}