@charset "UTF-8";
/* CSS Document */

/* ----- about ----- */
body.index section.about .inner {
	display: flex;
	flex-direction: row-reverse;
}
body.index section.about .about_texts {
	width: 494px;
}
body.index section.about .about_texts h2.section_title {
	font-size: 60px;
	text-align: left;
	margin-bottom: 16px;
	margin-top: -11px;
}
body.index section.about .about_texts .sub_title {
	font-size: 48px;
	font-weight: bold;
	margin-bottom: 40px;
}
body.index section.about .about_texts .sub_title span.technology {
	color: #00baff;
}
body.index section.about .about_texts p {
	font-size: 18px;
	line-height: 26px;
}
body.index section.about .about_photo {
	width: 400px;
	margin-right: 45px;
}
body.index section.about .about_photo img {
	width: 100%;
}

@media (max-width: 640px) {
body.index section.about .inner {
	display: block;
}
body.index section.about .about_texts {
	width: auto;
}
body.index section.about .about_texts h2.section_title {
	font-size: 34px;
	margin-bottom: 10px;
	margin-top: 0;
	text-align: center;
}
body.index section.about .about_texts .sub_title {
	font-size: 26px;
	font-weight: bold;
	margin-bottom: 20px;
	text-align: center;
}
body.index section.about .about_texts .image_sp {
	margin: 0 auto;
}
body.index section.about .about_texts p {
	font-size: 15px;
	line-height: 1.4;
}
}
/* ----- ここまで ----- */

/* ----- service ----- */
body.index section.service .job_list ul {
	display: flex;
}
body.index section.service .job_list ul li.list_item {
	width: 290px;
	height: 264px;
	margin-right: 35px;
	text-align: center;
	font-size: 24px;
	line-height: 36px;
	color: #fff;
	font-weight: bold;
	background-color: #000;
	display: flex;
  align-items: center;
  justify-content: center;
}
body.index section.service .job_list ul li.list_item:last-child {
	margin-right: 0;
}
body.index section.service .job_list ul li.list_item.kako {
	background: url(../img/img_service_01.jpg) top center no-repeat;
  background-size: 100% auto;
}
body.index section.service .job_list ul li.list_item.seizo {
	background: url(../img/img_service_02.jpg) top center no-repeat;
  background-size: 100% auto;
}
body.index section.service .job_list ul li.list_item.kaitori {
	background: url(../img/img_service_03.jpg) top center no-repeat;
  background-size: 100% auto;
}

@media (max-width: 640px) {
body.index section.service .job_list ul {
	display: block;
}
body.index section.service .job_list ul li.list_item {
	width: 100%;
	height: 250px;
	margin:  0 auto 20px;
	line-height: 1.5;
}
body.index section.service .job_list ul li.list_item:last-child {
	margin-right: auto;
	margin-bottom: 0;
}
}
/* ----- ここまで ----- */


/* ----- company ----- */
body.index section.company .inner {
	display: flex;
	flex-wrap: wrap;
}
body.index section.company .inner h2 {
	line-height: 65px;
	text-align: left;
	width: 388px;
	margin-top: -15px;
}
body.index section.company .inner .profile {
	width: 552px;
	margin-bottom: 40px;
}
body.index section.company .inner .profile dl {
	display: flex;
	flex-wrap: wrap;
}
body.index section.company .inner .profile dl dt {
	width: 140px;
	margin-right: 97px;
	font-size: 16px;
	font-weight: bold;
	padding: 14px 0 12px;
	border-bottom: 1px solid #000;
	line-height: 27px;
}
body.index section.company .inner .profile dl dt:first-child,
body.index section.company .inner .profile dl dd.first {
	border-top: 1px solid #000;
}
body.index section.company .inner .profile dl dd {
	width: 315px;
	padding: 14px 0 12px;
	border-bottom: 1px solid #000;
	line-height: 27px;
}
body.index section.company .map {
	margin-bottom: 20px;
}
body.index section.company .google_map {
	width: 100%;
}
body.index section.company .google_map iframe {
	width: 100%;
}
@media (max-width: 640px) {
body.index section.company .inner {
	display: block;
}
body.index section.company .inner h2 {
	line-height: 1.4;
	width: auto;
	margin-top: 0;
	text-align: center;
}
body.index section.company .inner .profile {
	width: auto;
	margin-bottom: 40px;
}
body.index section.company .inner .profile dl {
	display: block;
}
body.index section.company .inner .profile dl dt {
	width: auto;
	margin-right: 0;
	font-size: 14px;
	padding: 15px 0 5px;
	border-bottom: none;
	line-height: 1.6;
}
body.index section.company .inner .profile dl dd {
	width: auto;
	padding: 5px 0 15px;
	border-bottom: 1px solid #000;
	line-height: 1.6;
	font-size: 14px;
}
body.index section.company .inner .profile dl dd.first {
	border-top: none;
}
}
/* ----- ここまで ----- */

/* ----- contact ----- */
body.index section.contact {
	width: 100%;
	margin: 0 auto;
	padding: 0 0 20px;
}
body.index section.contact .inner {
	padding-bottom: 60px;
	margin-bottom: 0;
}
body.index section.contact .inquiry_text {
	text-align: center;
	font-size: 26px;
  line-height: 1.4;
  font-weight: bold;
	margin-bottom: 25px;
}
body.index section.contact .inquiry_list {
	margin: 0 auto;
	text-align: center;
}
body.index section.contact .inquiry_list > li.tel {
	margin-bottom: 18px;
}
body.index section.contact .inquiry_list > li a{
	color: #000;
  font-size: 35px;
  font-weight: bold;
}
body.index section.contact .inquiry_list > li.fax {
	font-size: 28px;
}
@media (max-width: 640px) {
body.index section.contact {
	padding: 0;
}
body.index section.contact .inner {
	width: auto;
}
body.index section.contact .inquiry_list {
	width: auto;
}
body.index section.contact .inquiry_text {
	font-size: 20px;
	line-height: 1.6;
	margin-bottom: 20px;
}
body.index section.contact .inquiry_list > li.tel {
}
body.index section.contact .inquiry_list > li a{
  font-size: 24px;
	padding-left: 34px;
}
body.index section.contact .inquiry_list > li.tel a {
	padding-left: 0;
}
body.index section.contact .inquiry_list > li.fax {
	font-size: 20px;
}
}
/* ----- ここまで ----- */

/* ----- recruit ----- */
body.index.recruit section.recruit h2.section_title {
	text-align: left;
}
body.index.recruit section.recruit h3.h3_title {
	font-size: 30px;
	line-height: 50px;
	font-weight: bold;
	margin-bottom: 40px;
}
body.index.recruit section.recruit ul.photo_list {
	margin-bottom: 45px;
}
body.index.recruit section.recruit ul.photo_list li.list_item {
	width: 460px;
	float: left;
}
body.index.recruit section.recruit ul.photo_list li.list_item.p1 {
	margin-right: 20px;
}
body.index.recruit section.recruit ul.photo_list li.list_item.p2 {
	margin-bottom: 16px;
}
body.index.recruit section.recruit ul.photo_list li.list_item img {
	width: 100%;
}
body.index.recruit section.recruit .points {
	background: url(../img/bg_s.jpg) center center no-repeat;
  background-size: 60% auto;
}
body.index.recruit section.recruit .points .point_box {
	display: flex;
	margin-bottom: 55px;
}
body.index.recruit section.recruit .points .point_box.p2 {
	flex-direction: row-reverse;
}
body.index.recruit section.recruit .points .point_box .point_image {
	width: 440px;
	margin-right: 60px;
}
body.index.recruit section.recruit .points .point_box.p2 .point_image {
	margin-right: 0;
	margin-left: 60px;
}
body.index.recruit section.recruit .points .point_box .point_image img {
	width: 100%;
}
body.index.recruit section.recruit .points .point_box .point_texts {
	width: 440px;
}
body.index.recruit section.recruit .points .point_box .point_texts .title {
	font-size: 24px;
	text-align: center;
	font-weight: bold;
	letter-spacing: 2px;
	margin: -10px 0 3px;
}
body.index.recruit section.recruit .points .point_box .point_texts .title span.num {
	font-size: 64px;
	color: #00baff;
}
body.index.recruit section.recruit .points .point_box .point_texts .sub_title {
	font-size: 34px;
	text-align: center;
	font-weight: bold;
	margin-bottom: 14px;
}
body.index.recruit section.recruit .points .point_box .point_texts .sub_title span.forte {
	color: #00baff;
} 
body.index.recruit section.recruit .points .point_box .point_texts p {
	font-size: 18px;
	line-height: 40px;
	font-weight: bold;
	margin: 0;
}
@media (max-width: 640px) {
body.index.recruit section.recruit h2.section_title {
	text-align: center;
}
body.index.recruit section.recruit h3.h3_title {
	font-size: 24px;
	line-height: 1.5;
	margin-bottom: 30px;
	text-align: center;
}
body.index.recruit section.recruit ul.photo_list {
	margin-bottom: 30px;
}
body.index.recruit section.recruit ul.photo_list li.list_item {
	width: 49%;
}
body.index.recruit section.recruit ul.photo_list li.list_item.p1 {
	margin-right: 2%;
}
body.index.recruit section.recruit ul.photo_list li.list_item.p2 {
	margin-bottom: 1%;
}
body.index.recruit section.recruit .points {
	background: none;
}
body.index.recruit section.recruit .points .point_box {
	display: block;
	margin-bottom: 40px;
}
body.index.recruit section.recruit .points .point_box .point_image {
	width: auto;
	margin-right: auto;
	margin-bottom: 15px;
}
body.index.recruit section.recruit .points .point_box.p2 .point_image {
	margin-right: auto;
	margin-left: auto;
}
body.index.recruit section.recruit .points .point_box .point_texts {
	width: auto;
}
body.index.recruit section.recruit .points .point_box .point_texts .title {
	font-size: 20px;
	letter-spacing: 0;
	margin: -10px 0 7px;
}
body.index.recruit section.recruit .points .point_box .point_texts .title span.num {
	font-size: 34px;
}
body.index.recruit section.recruit .points .point_box .point_texts .sub_title {
	font-size: 24px;
	margin-bottom: 14px;
}
body.index.recruit section.recruit .points .point_box .point_texts p {
	font-size: 15px;
	line-height: 1.8;
	font-weight: normal;
	margin: 0;
}
}
/* ----- ここまで ----- */

/* ----- recruit_info ----- */
body.index.recruit section.recruit_info .inner h2.section_title {
	line-height: 65px;
	letter-spacing: 4px;
}
body.index.recruit section.recruit_info .inner .information {
	width: 720px;
	margin: 0 auto 60px;
}
body.index.recruit section.recruit_info .inner .information dl {
	display: flex;
	flex-wrap: wrap;
}
body.index.recruit section.recruit_info .inner .information dl dt {
	width: 166px;
	font-size: 16px;
	font-weight: bold;
	padding: 15px 0 13px 14px;
	border-bottom: 1px solid #cacaca;
	line-height: 27px;
}
body.index.recruit section.recruit_info .inner .information dl dt:first-child,
body.index.recruit section.recruit_info .inner .information dl dd.first {
	border-top: 1px solid #cacaca;
}
body.index.recruit section.recruit_info .inner .information dl dd {
	width: 540px;
	padding: 15px 0 13px;
	border-bottom: 1px solid #cacaca;
	line-height: 27px;
	font-weight: normal;
}
body.index.recruit section.recruit_info .inner .information dl dt.odd,
body.index.recruit section.recruit_info .inner .information dl dd.odd {
	background-color: #e5f8ff;
}
body.index.recruit section.recruit_info .map {
	margin-bottom: 20px;
}
body.index.recruit section.recruit_info .google_map {
	width: 100%;
	margin-top: 6px;
}
body.index.recruit section.recruit_info .google_map iframe {
	width: 100%;
}
body.index.recruit section.recruit_info .btns {
	display: flex;
	justify-content: center;
}
body.index.recruit section.recruit_info .btns .btn.back {
	margin-right: 60px;
}
body.index.recruit section.recruit_info .btns .btn a {
	font-size: 20px;
	font-weight: bold;
	border: 5px solid #00baff;
	border-radius: 8px;
	display: block;
	width: 275px;
	text-align: center;
	padding: 15px 0;
	box-shadow: 0px 2px 10px 0px rgba(0, 0, 0, 0.2);
	background: url("../img/icon_arrow_blue.png") right 20px center no-repeat;
	background-size: 10px 17px;
}
body.index.recruit section.recruit_info .btns .btn.back a {
	color: #cacaca;
	border: 5px solid #cacaca;
	background: url("../img/icon_arrow_gray.png") right 20px center no-repeat;
	background-size: 10px 17px;
}
@media (max-width: 640px) {
body.index.recruit section.recruit_info .inner h2.section_title {
	line-height: 1.4;
	letter-spacing: 0;
}
body.index.recruit section.recruit_info .inner .information {
	width: auto;
	margin: 0 auto 40px;
}
body.index.recruit section.recruit_info .inner .information dl {
	display: block;
}
body.index.recruit section.recruit_info .inner .information dl dt {
	width: auto;
	font-size: 14px;
	padding: 15px 10px 5px;
	border-bottom: none;
	line-height: 1.6;
}
body.index.recruit section.recruit_info .inner .information dl dd {
	width: auto;
	font-size: 14px;
	padding: 5px 10px 15px;
	line-height: 1.6;
	font-weight: normal;
}
body.index.recruit section.recruit_info .inner .information dl dd.first {
	border-top: none;
}
body.index.recruit section.recruit_info .btns {
	display: block;
}
body.index.recruit section.recruit_info .btns .btn.back {
	margin-right: auto;
}
body.index.recruit section.recruit_info .btns .btn a {
	font-size: 18px;
	border: 3px solid #00baff;
	border-radius: 8px;
	width: 80%;
	padding: 10px 0;
	margin: 0 auto 20px;
}
}
/* ----- ここまで ----- */



/*ゆっくりスクロールさせて表示(animationのクラスを付ければ動く)*/
.animation{
	opacity : 0;
	visibility: hidden;
	transition: 1s;
	transform: translateY(30px);
}
/*アニメーション要素までスクロールした時のスタイル*/
.slow_scroll{
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
/* ----- ここまで ----- */
