/* screens smaller than 640---------------------------------------------------------- */
@media only screen and (max-width:640px) {

/*layout*/
/*------------------------------------------------------------------------------*/
#contents {
	margin-bottom: 80px;
}

/*pagetitle_area*/
/*--------------------------------------------------------------------------------*/
#pagetitle_area {
	margin: 110px 0 10px;
	height: 160px;
}
.recruit #pagetitle_area {
	margin: 60px 0 10px;
}

/*locator*/
/*--------------------------------------------------------------------------------*/
#locator {
	width: 94%;
	margin: 0 auto 20px;
}

/*pagetitle*/
/*------------------------------------------------------------------------------*/
#pagetitle{
	top: 110px;
	height: 160px;
}
.recruit #pagetitle{
	top: 60px;
	height: 160px;
}
.subtitle02 {
	font-size: 26px;
	width: 94%;
}

/*subtitle*/
/*------------------------------------------------------------------------------*/
.subtitle03_01 {
	font-size: 26px;
	margin-bottom: 20px;
}
.subtitle03_02 {
	font-size: 21px;
}
.subtitle03_02.m30 {
	margin-bottom: 20px;
}
.subtitle03_03 {
	font-size: 21px;
	padding-bottom: 10px;
	margin-bottom: 20px;
}
.recruit .subtitle03_03 {
	font-size: 18px;
	padding-bottom: 20px;
}
.subtitle04  {
	font-size: 15px;
	margin-bottom: 30px;
}
.subtitle04_01 {
	font-size: 18px;
}
.subtitle04_02 {
	font-size: 18px;
	margin-bottom: 15px;
}
.subtitle05_01 {
	font-size: 16px;
}

/*table*/
/*------------------------------------------------------------------------------*/
.table_wrap {
	width: 100%;
	overflow-x: auto;
}
.table_wrap table {
	margin-bottom: 15px;
	width: 710px;
}
.table_wrap p {
	display: block;
	font-size: 87.5%;
	margin-bottom: 10px;
}
.table01 {
	width: 100%;
	border: none;
	border: 1px solid #ddd;
}
.table01 th {
	display: block;
	width: 100%;
	border: none;
	padding: 14px 3%;
	text-align: left;
}
.table01 td {
	display: block;
	padding: 14px 3%;
	width: 100%;
	border: none;
}

/*box*/
/*------------------------------------------------------------------------------*/
.box2_01 .flt_pc {
	width: 100%;
	margin-bottom: 25px;
}
.box2_01 .flr_pc {
	width: 100%;
}
.box2_02 .inner {
	justify-content: flex-start;
	flex-direction: column;
}
.box2_02 .unit {
	width: 100%;
}
.box3_01 .inner {
	justify-content: flex-start;
	flex-direction: column;
}
.box3_01 .unit {
	width: 100%;
}

/*btn link*/
/*------------------------------------------------------------------------------*/
.btn01 a {
	margin: 0 auto;
}
.btn02 {
	width: 100%;
}

/*bottom_nav*/
/*------------------------------------------------------------------------------*/
.bottom_nav01 ul {
    width: 100%;
    max-width: 460px;
    margin: 0 auto 10px;
}
.bottom_nav01 li {
    width: 100%;
    float: none;
    font-size: 15px;
}
.bottom_nav01 li:before {
	width: 70%;
	height: 3px;
	top: auto;
	bottom: 0;
	margin: 0;
	right: 0;
	left: 0;
	margin: 0 auto;
}
.bottom_nav01 a {
    height: auto;
    padding: 20px 5px;
    display: static;
}

/*bg_box*/
/*------------------------------------------------------------------------------*/
.bg_box01 {
	padding: 20px;
}
.bg_box02 {
	padding: 20px 2%;
}
.bg_box02 h3 {
	padding-top: 20px;
}

/*recruit(top)*/
/*------------------------------------------------------------------------------*/
#recruit_mainimage {
	background: url(../image/rec_mainimage.jpg) no-repeat 65% top;
	background-size: cover;
	padding-top: 60px;
	height: 80vw;
}
#recruit_mainimage h2 {
	margin-bottom: 2.5vw;
}
#recruit_mainimage h2 .text01 {
	font-size: 12vw;
	letter-spacing: 3px;
}
#recruit_mainimage h2 .text02 {
	font-size: 13vw;
	letter-spacing: 6px;
}
#recruit_mainimage p {
	font-size: 14px;
	line-height: 1.4;
}
#recruit_box01 {
	background: url(../image/recruit_box01_bg.jpg) no-repeat center bottom;
	background-size: auto;
	margin-bottom: 50px;
}
#recruit_box01_in .inner {
	flex-direction: column;
	justify-content: flex-start;
	padding-top: 20px;
	height: auto;
}
#recruit_box01_in .img100 {
	width: 100%;
	position: static;
	top: auto;
	left: auto;
	text-align: center;
	margin-bottom: 20px;
}
#recruit_box01_in .unit {
	width: 100%;
}
#recruit_box01_in h3 {
	font-size: 22px;
}
#recruit_box01_in .unit p {
	margin-bottom: 20px;
}
#recruit_box01_in .unit .name {
	bottom: -90px;
}
#recruit_box02 {
	margin-bottom: 50px;
}
#recruit_box02 .inner {
	flex-direction: column;
	justify-content: flex-start;
}
.recruit_box02_in {
	width: 100%;
	margin-bottom: 70px;
}
.recruit_box02_in:last-child {
	margin-bottom: 0;
}
#recruit_box03 {
	padding: 50px 0 30px;
	margin-bottom: 50px;
}
#recruit_box03 p {
	margin-bottom: 20px;
}
.slider-container {
	display: none;
	position: relative;
}
.slider-container.initialized {
	display:block;
}
.slider {
	margin: 0 36px;
	overflow: hidden;
}
.slider-arrow {
  position: absolute;
  top: 50%;
  height: 50px;
  margin-top: -25px;
  color: #444;
  line-height: 50px;
  font-size: 50px;
  cursor: pointer;
  z-index: 5;
}
.slider-prev {
  left: 5px;
}
.slider-next {
  right: 5px;
}
#recruit_box04 {
	background: url(../image/recruit_box04_bg.jpg) no-repeat center top;
	background-size: cover;
}
#recruit_box04 ul {
	width: 100%;
	height: auto;
	justify-content: flex-start;
	flex-direction: column;
	padding: 40px 0;
}
#recruit_box04 li {
	width: 80%;
}
#recruit_box04 li:first-child {
	margin-bottom: 20px;
}
#recruit_box04 li a {
	width: 100%;
	height: 80px;
	font-size: 18px;
}
#recruit_box05 {
	background: url(../image/recruit_box05_bg.jpg) no-repeat center top;
	background-size: cover;
}
#recruit_box05 .inner {height: 260px; }

.toptitle03 { font-size: 22px; margin-bottom: 20px;}

#recruit_news { padding: 40px 0 20px; }
#recruit_news .inner{ display: block; }
#recruit_news dt {margin-right: 30px; }

.recruit_news_block{width: 100%; }


/*company*/
/*------------------------------------------------------------------------------*/
.company_box02 p {
	font-size: 18px;
}
#company_box04 {
	flex-direction: column;
	justify-content: flex-start;
}
.company_box04_in {
	width: 100%;
	margin-bottom: 30px;
	padding: 6.25% 3.125%;
}
#company_box05 {
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
}
.company_box05_in {
	width: 100%;
	max-width: 380px;
	margin-bottom: 30px;
}
.company_box05_in:last-child {
	margin-bottom: 0;
}
.company_box05_in .img100 {
	margin-bottom: 20px;
}
.company_box05_in p {
	margin-bottom: 15px;
}
#company_box06 ul {
	flex-direction: column;
	justify-content: flex-start;
}
#company_box06 li {
	width: 100%;
}

/*business*/
/*------------------------------------------------------------------------------*/
.business_area01 {
	padding: 330px 20px 30px;
	max-width: 600px;
	width: 100%;
}
.business_area01:before {
	background-position: top center;
	width: 100%;
	height: 440px;
}
.business_area01 .unit {
	margin: 0 auto;
}
#business_box03 .unit {
	float: none;
}

/*outline*/
/*------------------------------------------------------------------------------*/
#outline_box02 th {
    padding: 20px 15px;
    text-align: left;
    width: 30%;
    border-top: 1px solid #ccc;
    display: table-cell;
}
#outline_box02 td {
    display: table-cell;
    padding: 14px 3%;
    width: 60%;
    border: 1px solid #ccc;
}

/*group*/
/*------------------------------------------------------------------------------*/
#group_box01 #unit ul {
	display: none;
}
#group_box01 li a .caption {
	font-size: 11px;
}
.group_box02 .table01 {
	border-bottom: none;
}
.group_box02 th {
	display: none;
}
.group_box02 td:first-child {
	background-color: #eee;
	font-size: 16px;
	font-weight: bold;
}
.group_box02 td:nth-child(2n) {
	background-color: #fff;
}
.group_box02 td {
	border-bottom: 1px solid #ccc;
	padding: 20px 3% 20px 5%;
}
.lightbox_box {
	background-color: #fff;
	padding: 25px 15px;
}
.lightbox_box .flt_pc {
	width: 100%;
	margin-bottom: 25px;
}
.lightbox_box .flt_pc p  {
	margin-bottom: 20px;
}
.lightbox_box .flt_pc h3 {
	padding-top: 0;
}
.lightbox_box .flr_pc {
	width: 100%;
}

/*contact*/
/*------------------------------------------------------------------------------*/
#contact_box01 dl {
	margin-right: 0;
	width: 100%;
	margin-bottom: 20px;
}
#contact_box01 dl:last-child {
	margin-bottom: 0;
}
#contact_box01 dt {
	font-size: 16px;
}
#contact_box01 dd {
	font-size: 14px;
}
#contact_box01 .tel {
	font-size: 26px;
}
#contact_box02 {
	padding: 40px 20px;
}
.btn_mail a {
    max-width: none;
}

/*about*/
/*------------------------------------------------------------------------------*/
.about_box01 .inner {
	flex-flow: column nowrap;
	justify-content: flex-start;
	padding: 0 3% 20px;
}
.about_box01_in:nth-child(1) {
	width: 100%;
	order: 2;
	margin-bottom: 30px;
}
.about_box01_in:nth-child(1) .img100 {
	text-align: center;
}
.about_box01_in:nth-child(1) img {
	margin: 0;
}
.about_box01_in:nth-child(1) .btn02 {
	margin: 0 auto;
}
.about_box01_in:nth-child(2) {
	width: 100%;
	padding: 20px 0;
	order: 1;
}
.about_box01_in:nth-child(3) {
	width: 100%;
	order: 3;
}

/*number*/
/*------------------------------------------------------------------------------*/
#number_box01 .unit,
#number_box02 .unit {
	height: 300px;
}
#number_box03 .unit,
#number_box04 .unit {
	height: 280px;
}
#number_box01 .unit:nth-child(1),
#number_box03 .unit:nth-child(1),
#number_box03 .unit:nth-child(2),
#number_box04 .unit:nth-child(1),
#number_box04 .unit:nth-child(2) {
	margin-bottom: 20px;
}
#number_box01 .unit:before,
#number_box02 .unit:before,
#number_box03 .unit:before,
#number_box04 .unit:before {
	right: 10px;
}
#number_box01 .unit .number,
#number_box03 .unit .number,
#number_box04 .unit .number {
	font-size: 13vw;
}
#number_box02 .unit .number {
	font-size: 6.67vw;
}
#number_box01 .unit .number .main {
	font-size: 27vw;
}#number_box02 .unit .number .main {
	font-size: 13.33vw;
}
#number_box03 .unit .number .main,
#number_box04 .unit .number .main {
	font-size: 22vw;
}
#number_box01 .unit p,
#number_box02 .unit p,
#number_box03 .unit p,
#number_box04 .unit p {
	padding: 0 1.67%;
}

/*history*/
/*------------------------------------------------------------------------------*/
.history_box01 {
	flex-direction: column;
	justify-content: flex-start;
}
.history_box01_in {
	flex-direction: column;
	width: 100%;
}
.timeline-date {
	width: 100%;
	margin: 0;
}
.timeline-date .main {
	font-size: 18px;
}
.timeline-date .sub {
	font-size: 14px;
}
.timeline-date .sp {
	display: inline;
}
.timeline-content {
  width: 100%;
  border-left: none;
  padding: 0;
  margin-bottom: 20px;
}
.timeline-content:before {
  content: none;
}
.timeline-content h4 {
	color: #0ACC9B;
}
.history_box01 .img100 {
	width: 100%;
	padding: 0;
	text-align: center;
	margin-bottom: 20px;
}
.history_box01 .img100 img {
	max-width: 280px;
}

/*interview*/
/*------------------------------------------------------------------------------*/
.interview_box01_in {
	width: 50%;
}

/*interview_sub*/
/*------------------------------------------------------------------------------*/
#interview_sub_box01 .flt_pc,
.interview_sub_box02 .flr_pc,
.interview_sub_box03 .flt_pc {
    width: 100%;
}
#interview_sub_box01 .flt_pc {
	margin-bottom: 25px;
}
#interview_sub_box01 .flr_pc {
    width: 100%;
    padding: 0;
}
.interview_sub_box02 .flt_pc,
.interview_sub_box03 .flr_pc {
    width: 100%;
	margin-bottom: 25px;
}
#interview_sub_box04 .unit {
	width: 100%;
	float: none;
	margin-bottom: 40px;
}
#interview_sub_box04 dl {
	display: block;
}
#interview_sub_box04 dt {
	display: block;
	vertical-align: top;
	width: 100%;
	border-right: none;
	border-bottom: 4px solid #ddd;
	padding-bottom: 10px;
}
#interview_sub_box04 dd {
	display: block;
	vertical-align: top;
	width: 100%;
	padding: 10px 0 0;
}

#interview_sub_box04 .img100 {
	width: 100%;
	float: none;
	margin-bottom: 40px;
}

.interview_sub_box05_in {
	width: auto;
	margin: 0 0 40px 0;
}
#interview_sub_box05 {
	padding: 30px 0 0;
}
#interview_sub_box05 p {
	margin-bottom: 20px;
}

/*newgraduate*/
/*------------------------------------------------------------------------------*/
.newgraduate_box02_in {
	margin: -20px auto 0;
	padding: 20px 0;
}
.newgraduate_box02_in p {
	font-size: 14px;
	line-height: 1.4;
	margin-bottom: 10px;
}
.newgraduate_box03 {
	flex-direction: column;
}
.newgraduate_box03 .step {
	width: 100%;
	height: 50px;
}
.newgraduate_box03 .step .number {
	display: inline-block;
	font-size: 24px;
}
.newgraduate_box03 .content {
	width: 100%;
	flex-direction: column;
	justify-content: flex-start;
	align-items: stretch;
	padding: 10px;
}
.newgraduate_box03 .content h5 {
	width: 100%;
	margin: 0 0 10px;
}
.newgraduate_box03 .content p {
	width: 100%;
}

/* ir */
/*------------------------------------------------------------------------*/

.ir_news_btn{
	margin-top:0;
}
.ir_news_btn li{
	display:inline-block;
	width:100%;
	max-width:calc(50% - 1px);
	font-size:13px;
	text-align:center;
}

#ir_news_box dl + dl{
	margin-top:10px;
}
#ir_news_box .rss_title{
 width:100%;
}
#ir_news_box .rss_title a{
	padding-left:0;
}
.category_label {
	display:block;
	position:static;
	width:180px;
	padding:2px 10px;
	margin:5px 0;
}

.ir_box2 > li{
	width:100%;
	float:none;
	margin-left: 0;
}
.ir_box2 > li:nth-child(odd){
	clear:both;
	margin-left:0;
}

.ir_box2_menu li{
	float:none;
	width:100%;
	margin:0 0 5px;
}


/*catalog*/
/*------------------------------------------------------------------------*/
.catalog_list li{
	float:none;
	width:100%;
	margin-left:0%;
}

.catalog_img{
	float:none;
	width:100%;
	margin-bottom:15px;
}

.catalog_in_r{
	float:none;
	width:100%;
}


/* news */
/*------------------------------------------------------------------------*/
#sub_rss_box dt{
 float:none;
 width:100%;
 margin-bottom:5px;
}
#sub_rss_box .rss_title{
 float:none;
 width:100%;
}
#sub_rss_box .rss_contents{
 clear:both;
 margin-top:5px;
 padding:5px 0 0 0;
}







#recruit_news dl {display: block;}
#recruit_news dt { margin-bottom: 5px; width: 100%;}
#recruit_news dd { margin-bottom: 20px; width: 100%;}


/*------------------------------------------------------------------------------*/
}
/*------------------------------------------------------------------------------*/


/* screens smaller than 500---------------------------------------------------------- */
@media only screen and (max-width:499px) {

/*recruit(top)*/
/*------------------------------------------------------------------------------*/
#recruit_mainimage {
	background: url(../image/rec_mainimage.jpg) no-repeat 68% top;
	background-size: cover;
	height: 430px;
}

/*interview*/
/*------------------------------------------------------------------------------*/
#interview_box01 {
	flex-wrap: column;
	justify-content: flex-start;
}
.interview_box01_in {
	width: 100%;
	max-width: 400px;
	margin: 0 auto 20px;
}
.interview_box01_in:last-child {
	margin-right: 0;
}
.interview_box01_in dl {
	min-height: auto;
	min-height: initial;
}
.interview_box01_in dt {
	font-size: 18px;
}
.interview_box01_in dd {
	font-size: 14px;
}

/*newgraduate*/
/*------------------------------------------------------------------------------*/
#tab_area ul {
	flex-wrap: wrap;
}
#tab_area li {
	-webkit-width: calc((100% - 1px) / 2);
	width: calc((100% - 1px) / 2);
}
#tab_area li:nth-child(1),
#tab_area li:nth-child(2) {
	margin-bottom: 1px;
}


/*------------------------------------------------------------------------------*/
}
/*------------------------------------------------------------------------------*/


/* screens smaller than 420---------------------------------------------------------- */
@media only screen and (max-width:419px) {

/*business*/
/*------------------------------------------------------------------------------*/
.business_area01 {
	padding: 330px 10px 30px;
}
.business_area01 .unit {
	padding: 30px 15px;
}

/*contact*/
/*------------------------------------------------------------------------------*/
#contact_box01 .time {
	padding: 0;
}
#contact_box01 .time:before,
#contact_box01 .time:after {
	content: none;
}



/*------------------------------------------------------------------------------*/
}
/*------------------------------------------------------------------------------*/
