@charset "UTF-8";
html {
  height: 100%;
  position: relative; }

body {
  width: 100%;
  font-size: 12px;
  line-height: 2em;
  letter-spacing: 0.05em;
  color: #385eab;
  position: relative; }

body, input, textarea, select {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; }

a:link {
  color: #00a0b8;
  text-decoration: underline; }

a:visited {
  color: #00a0b8;
  text-decoration: none; }

a:hover {
  color: #00a0b8;
  text-decoration: none; }

/*=====================================================================================================
*******************************************************************************************************

	header
	
*******************************************************************************************************
=====================================================================================================*/
header {
  width: 100%;
  height: 90px;
  background: #fff;
  display: block; }
  @media screen and (max-width: 1060px) {
    header {
      height: 47px; } }

header div {
  width: 100%;
  max-width: 980px;
  height: 90px;
  margin: 0 auto;
  overflow: hidden;
  position: relative; }
  @media screen and (max-width: 1060px) {
    header div {
      max-width: none;
      width: 100%;
      position: relative;
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
      padding: 0 2em;
      height: 47px; } }

header h1 {
  width: 156px;
  height: 37px;
  margin: 29px 0 0 0;
  display: block;
  position: absolute; }
  @media screen and (max-width: 1060px) {
    header h1 {
      margin: 5px 0; } }

header h1 a {
  width: 156px;
  height: 0;
  padding: 37px 0 0 0;
  display: block;
  overflow: hidden;
  background: url(../../../img/recruit/common/h1.gif) left top no-repeat; }

.rgnav {
  width: 786px;
  height: 90px;
  border-left: 1px solid #e0e0e0;
  display: block;
  overflow: hidden;
  float: right; }

.rgnav > li {
  width: 131px;
  height: 90px;
  display: block;
  float: left; }

.rgnav > li > a {
  width: 131px;
  height: 90px;
  display: block;
  position: relative; }

.rgnav > li > a > span {
  width: 131px;
  height: 0;
  padding: 90px 0 0 0;
  display: block;
  overflow: hidden;
  background-image: url(../../../img/recruit/common/globalmenu.gif);
  background-repeat: no-repeat;
  position: absolute; }

.rgnav > li.li0 > a > span {
  background-position: 0px 0px; }

.rgnav > li.li1 > a > span {
  background-position: -131px 0px; }

.rgnav > li.li2 > a > span {
  background-position: -262px 0px; }

.rgnav > li.li3 > a > span {
  background-position: -393px 0px; }

.rgnav > li.li4 > a > span {
  background-position: -524px 0px; }

.rgnav > li.li5 > a > span {
  background-position: -655px 0px; }

.rgnav > li.li0 > a.now > span {
  background-position: 0px -90px; }

.rgnav > li.li1 > a.now > span {
  background-position: -131px -90px; }

.rgnav > li.li2 > a.now > span {
  background-position: -262px -90px; }

.rgnav > li.li3 > a.now > span {
  background-position: -393px -90px; }

.rgnav > li.li4 > a.now > span {
  background-position: -524px -90px; }

.rgnav > li.li5 > a.now > span {
  background-position: -655px -90px; }

.rgnav > li > a > b {
  width: 131px;
  height: 0;
  padding: 90px 0 0 0;
  display: block;
  overflow: hidden;
  background-image: url(../../../img/recruit/common/globalmenu.gif);
  background-repeat: no-repeat;
  filter: alpha(opacity=0);
  -moz-opacity: 0;
  opacity: 0;
  position: absolute;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -ms-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out; }

.rgnav > li > a:hover > b {
  filter: alpha(opacity=100);
  -moz-opacity: 1.0;
  opacity: 1.0; }

.rgnav > li.li0 > a > b {
  background-position: 0px -90px; }

.rgnav > li.li1 > a > b {
  background-position: -131px -90px; }

.rgnav > li.li2 > a > b {
  background-position: -262px -90px; }

.rgnav > li.li3 > a > b {
  background-position: -393px -90px; }

.rgnav > li.li4 > a > b {
  background-position: -524px -90px; }

.rgnav > li.li5 > a > b {
  background-position: -655px -90px; }

.rgnav > li > p {
  width: 131px;
  height: 0;
  padding: 90px 0 0 0;
  display: block;
  overflow: hidden;
  background-image: url(../../../img/recruit/common/globalmenu.gif);
  background-repeat: no-repeat;
  position: absolute; }

.rgnav > li.li0 > p {
  background-position: 0px -180px; }

.rgnav > li.li1 > p {
  background-position: -131px -180px; }

.rgnav > li.li2 > p {
  background-position: -262px -180px; }

.rgnav > li.li3 > p {
  background-position: -393px -180px; }

.rgnav > li.li4 > p {
  background-position: -524px -180px; }

.rgnav > li.li5 > p {
  background-position: -655px -180px; }

/*=====================================================================================================
*******************************************************************************************************

	header.sp
	
*******************************************************************************************************
=====================================================================================================*/
header.sp {
  width: 100%;
  height: auto;
  background: #fff;
  display: block; }

header.sp > h1 {
  width: 320px;
  height: 80px;
  margin: 60px 0 0 60px;
  display: block;
  position: static;
  float: left; }

header.sp > h1 > a {
  width: 320px;
  height: 0;
  padding: 80px 0 0 0;
  display: block;
  overflow: hidden;
  background: url(../../../img/recruit/common/sp_h1.gif) left top no-repeat; }

header.sp > a {
  width: 80px;
  height: 80px;
  padding: 60px;
  border-left: #e0e0e0 2px solid;
  display: block;
  overflow: hidden;
  position: static;
  float: right; }

header.sp > a > span {
  width: 80px;
  height: 0;
  padding: 80px 0 0 0;
  background: url(../../../img/recruit/common/sp_menu_btn.gif) left 0px no-repeat;
  display: block;
  overflow: hidden;
  position: static; }

header.sp > a.close > span {
  background-position: left -80px; }

header.sp > div {
  width: 100%;
  height: 0px;
  border-top: #e0e0e0 1px solid;
  clear: both;
  overflow: hidden; }

/*=================================================================================
	menu
=================================================================================*/
header.sp > div > menu {
  width: 100%;
  height: auto;
  border-left: none;
  border-bottom: 2px #e0e0e0 solid;
  display: block;
  overflow: hidden;
  float: none; }

header.sp > div > menu > li {
  width: 50%;
  height: 268px;
  display: block;
  float: left; }

header.sp > div > menu > li > a,
header.sp > div > menu > li > p {
  width: auto;
  height: 148px;
  padding: 60px 0 60px 0;
  border-top: #e0e0e0 1px solid;
  border-bottom: #e0e0e0 1px solid;
  display: block;
  position: static; }

header.sp > div > menu > li.li0 > a,
header.sp > div > menu > li.li2 > a,
header.sp > div > menu > li.li4 > a,
header.sp > div > menu > li.li0 > p,
header.sp > div > menu > li.li2 > p,
header.sp > div > menu > li.li4 > p {
  border-right: #e0e0e0 1px solid; }

header.sp > div > menu > li.li1 > a,
header.sp > div > menu > li.li3 > a,
header.sp > div > menu > li.li5 > a,
header.sp > div > menu > li.li1 > p,
header.sp > div > menu > li.li3 > p,
header.sp > div > menu > li.li5 > p {
  border-left: #e0e0e0 1px solid; }

header.sp > div > menu > li.li5 > a,
header.sp > div > menu > li.li5 > p {
  background-color: #385eab; }

header.sp > div > menu > li > a > b,
header.sp > div > menu > li > p > b {
  display: none; }

header.sp > div > menu > li > a > span,
header.sp > div > menu > li > p > span {
  width: auto;
  height: 0;
  padding: 148px 0 0 0;
  display: block;
  overflow: hidden;
  background-image: url(../../../img/recruit/common/sp_globalmenu.gif);
  background-repeat: no-repeat;
  filter: alpha(opacity=100);
  -moz-opacity: 1;
  opacity: 1;
  position: static; }

header.sp > div > menu > li > a > span {
  background-image: url(../../../img/recruit/common/sp_globalmenu.gif); }

header.sp > div > menu > li > p > span {
  /* background-image: url(../../../img/recruit/common/sp_globalmenu_close.gif); */ }

header.sp > div > menu > li.li0 > a > span {
  background-position: center 0px; }

header.sp > div > menu > li.li1 > a > span {
  background-position: center -148px; }

header.sp > div > menu > li.li2 > a > span {
  background-position: center -296px; }

header.sp > div > menu > li.li3 > a > span {
  background-position: center -444px; }

header.sp > div > menu > li.li4 > a > span {
  background-position: center -592px; }

header.sp > div > menu > li.li5 > a > span {
  background-position: center -740px; }

header.sp > div > menu > li.li0 > p > span {
  background-position: center 0px; }

header.sp > div > menu > li.li1 > p > span {
  background-position: center -148px; }

header.sp > div > menu > li.li2 > p > span {
  background-position: center -296px; }

header.sp > div > menu > li.li3 > p > span {
  background-position: center -444px; }

header.sp > div > menu > li.li4 > p > span {
  background-position: center -592px; }

header.sp > div > menu > li.li5 > p > span {
  background-position: center -740px; }

/*=================================================================================
	dl
=================================================================================*/
header.sp > div > dl {
  width: 100%;
  height: auto;
  border-bottom: 2px #e0e0e0 solid;
  display: block;
  overflow: hidden; }

header.sp > div > dl > dt {
  display: none; }

header.sp > div > dl > dd {
  width: 50%;
  padding: 134px 0 20px;
  display: block;
  float: left; }

header.sp > div > dl > dd.dd0 {
  background: #2eb9ee url(../../../img/recruit/common/sp_footer_menu_bg_0.gif) center 58px no-repeat; }

header.sp > div > dl > dd.dd1 {
  background: #fe2d63 url(../../../img/recruit/common/sp_footer_menu_bg_1.gif) center 58px no-repeat; }

header.sp > div > dl > dd > ul {
  width: auto;
  padding: 0 30px 0 30px;
  display: block; }

header.sp > div > dl > dd > ul > li {
  width: auto;
  padding: 0 0 20px 0;
  display: block; }

header.sp > div > dl > dd > ul > li > a {
  width: auto;
  height: 0;
  padding: 148px 0 0 0;
  background: url(../../../img/recruit/common/sp_footer_menu_btn.gif) #fff no-repeat;
  display: block;
  overflow: hidden;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px; }

header.sp > div > dl > dd.dd0 > ul > li.li0 > a {
  background-position: center 0px; }

header.sp > div > dl > dd.dd0 > ul > li.li1 > a {
  background-position: center -148px; }

header.sp > div > dl > dd.dd1 > ul > li.li0 > a {
  background-position: center -296px; }

header.sp > div > dl > dd.dd1 > ul > li.li1 > a {
  background-position: center -444px; }

/*=================================================================================
	ul
=================================================================================*/
header.sp > div > ul {
  width: auto;
  height: auto;
  padding: 30px 30px 10px 30px;
  background: #999;
  display: block;
  overflow: hidden; }

header.sp > div > ul > li {
  padding: 0 0 20px 0; }

header.sp > div > ul > li > a {
  width: auto;
  margin: 0 auto 0 auto;
  background: #fff;
  display: block;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px; }

header.sp > div > ul > li > a > span {
  padding: 0 61px 0 0;
  display: block; }

header.sp > div > ul > li > a > span > span {
  height: 0;
  padding: 114px 0 0 0;
  display: block;
  overflow: hidden; }

header.sp > div > ul > li.li0 > a > span {
  background: url(../../../img/recruit/common/sp_header_btn_right.gif) no-repeat right top; }

header.sp > div > ul > li.li0 > a > span > span {
  background: url(../../../img/recruit/common/sp_header_btn_access.gif) no-repeat left top; }

header.sp > div > ul > li.li1 > a > span {
  background: url(../../../img/recruit/common/sp_header_btn_right.gif) no-repeat right top; }

header.sp > div > ul > li.li1 > a > span > span {
  background: url(../../../img/recruit/common/sp_header_btn_main.gif) no-repeat left top; }

/*=====================================================================================================
*******************************************************************************************************

	header.tb
	
*******************************************************************************************************
=====================================================================================================*/
header.tb {
  width: 100%;
  height: auto;
  background: #fff;
  display: block; }

header.tb > h1 {
  width: 210px;
  height: 50px;
  margin: 35px 0 0 35px;
  display: block;
  position: static;
  float: left; }

header.tb > h1 > a {
  width: 250px;
  height: 0;
  padding: 70px 0 0 0;
  display: block;
  overflow: hidden;
  background: url(../../../img/recruit/common/h1.gif) left top no-repeat; }

header.tb > a {
  width: 50px;
  height: 50px;
  padding: 28px;
  border-left: #e0e0e0 2px solid;
  display: block;
  overflow: hidden;
  position: static;
  float: right; }

header.tb > a > span {
  width: 50px;
  height: 0;
  padding: 50px 0 0 0;
  background: url(../../../img/recruit/common/tb_menu_btn.gif) left 0px no-repeat;
  display: block;
  overflow: hidden;
  position: static; }

header.tb > a.close > span {
  background-position: left -50px; }

header.tb > div {
  width: 100%;
  height: 0px;
  border-top: #e0e0e0 1px solid;
  clear: both;
  overflow: hidden; }

/*=================================================================================
	menu
=================================================================================*/
header.tb > div > menu {
  width: 100%;
  height: auto;
  border-left: none;
  border-bottom: 2px #e0e0e0 solid;
  display: block;
  overflow: hidden;
  float: none; }

header.tb > div > menu > li {
  width: 33%;
  height: 166px;
  display: block;
  float: left; }

header.tb > div > menu > li.li1,
header.tb > div > menu > li.li4 {
  width: 34%; }

header.tb > div > menu > li > a,
header.tb > div > menu > li > p {
  width: auto;
  height: 106px;
  padding: 30px 0 30px 0;
  border-top: #e0e0e0 1px solid;
  border-left: #e0e0e0 1px solid;
  border-right: #e0e0e0 1px solid;
  border-bottom: #e0e0e0 1px solid;
  display: block;
  position: static; }

header.tb > div > menu > li.li0 > a,
header.tb > div > menu > li.li3 > a,
header.tb > div > menu > li.li0 > p,
header.tb > div > menu > li.li3 > p {
  border-left: none; }

header.tb > div > menu > li.li2 > a,
header.tb > div > menu > li.li5 > a,
header.tb > div > menu > li.li2 > p,
header.tb > div > menu > li.li5 > p {
  border-right: none; }

header.tb > div > menu > li.li5 > a,
header.tb > div > menu > li.li5 > p {
  background-color: #385eab; }

header.tb > div > menu > li > a > b,
header.tb > div > menu > li > p > b {
  display: none; }

header.tb > div > menu > li > a > span,
header.tb > div > menu > li > p > span {
  width: auto;
  height: 0;
  padding: 106px 0 0 0;
  display: block;
  overflow: hidden;
  background-image: url(../../../img/recruit/common/tb_globalmenu.gif);
  background-repeat: no-repeat;
  filter: alpha(opacity=100);
  -moz-opacity: 1;
  opacity: 1;
  position: static; }

header.tb > div > menu > li > a > span {
  background-image: url(../../../img/recruit/common/tb_globalmenu.gif); }

header.tb > div > menu > li > p > span {
  /* background-image: url(../../../img/recruit/common/tb_globalmenu_close.gif); */ }

header.tb > div > menu > li.li0 > a > span {
  background-position: center 0px; }

header.tb > div > menu > li.li1 > a > span {
  background-position: center -106px; }

header.tb > div > menu > li.li2 > a > span {
  background-position: center -212px; }

header.tb > div > menu > li.li3 > a > span {
  background-position: center -318px; }

header.tb > div > menu > li.li4 > a > span {
  background-position: center -424px; }

header.tb > div > menu > li.li5 > a > span {
  background-position: center -530px; }

header.tb > div > menu > li.li0 > p > span {
  background-position: center 0px; }

header.tb > div > menu > li.li1 > p > span {
  background-position: center -106px; }

header.tb > div > menu > li.li2 > p > span {
  background-position: center -212px; }

header.tb > div > menu > li.li3 > p > span {
  background-position: center -318px; }

header.tb > div > menu > li.li4 > p > span {
  background-position: center -424px; }

header.tb > div > menu > li.li5 > p > span {
  background-position: center -530px; }

/*=================================================================================
	dl
=================================================================================*/
header.tb > div > dl {
  width: 100%;
  height: auto;
  border-bottom: 2px #e0e0e0 solid;
  display: block;
  overflow: hidden; }

header.tb > div > dl > dt {
  display: none; }

header.tb > div > dl > dd {
  width: 50%;
  padding: 83px 0 20px;
  display: block;
  float: left; }

header.tb > div > dl > dd.dd0 {
  background: #2eb9ee url(../../../img/recruit/common/tb_footer_menu_bg_0.gif) center 32px no-repeat; }

header.tb > div > dl > dd.dd1 {
  background: #fe2d63 url(../../../img/recruit/common/tb_footer_menu_bg_1.gif) center 32px no-repeat; }

header.tb > div > dl > dd > ul {
  width: auto;
  padding: 0 15px 0 15px;
  display: block;
  overflow: hidden; }

header.tb > div > dl > dd > ul > li {
  width: 50%;
  padding: 0 0 0 0;
  display: block;
  float: left; }

header.tb > div > dl > dd > ul > li > a {
  width: auto;
  height: 0;
  padding: 74px 0 0 0;
  margin: 0 5px 0 5px;
  background: url(../../../img/recruit/common/tb_footer_menu_btn.gif) #fff no-repeat;
  display: block;
  overflow: hidden;
  border-radius: 6px;
  -webkit-border-radius: 6px;
  -moz-border-radius: 6px; }

header.tb > div > dl > dd.dd0 > ul > li.li0 > a {
  background-position: center 0px; }

header.tb > div > dl > dd.dd0 > ul > li.li1 > a {
  background-position: center -74px; }

header.tb > div > dl > dd.dd1 > ul > li.li0 > a {
  background-position: center -148px; }

header.tb > div > dl > dd.dd1 > ul > li.li1 > a {
  background-position: center -222px; }

/*=================================================================================
	ul
=================================================================================*/
header.tb > div > ul {
  width: auto;
  height: auto;
  padding: 20px 15px 20px 15px;
  background: #999;
  display: block;
  overflow: hidden; }

header.tb > div > ul > li {
  width: 50%;
  float: left; }

header.tb > div > ul > li > a {
  width: auto;
  margin: 0 5px 0 5px;
  background: #fff;
  display: block;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px; }

header.tb > div > ul > li > a > span {
  padding: 0 28px 0 0;
  display: block; }

header.tb > div > ul > li > a > span > span {
  height: 0;
  padding: 54px 0 0 0;
  display: block;
  overflow: hidden; }

header.tb > div > ul > li.li0 > a > span {
  background: url(../../../img/recruit/common/tb_header_btn_right.gif) no-repeat right top; }

header.tb > div > ul > li.li0 > a > span > span {
  background: url(../../../img/recruit/common/tb_header_btn_access.gif) no-repeat left top; }

header.tb > div > ul > li.li1 > a > span {
  background: url(../../../img/recruit/common/tb_header_btn_right.gif) no-repeat right top; }

header.tb > div > ul > li.li1 > a > span > span {
  background: url(../../../img/recruit/common/tb_header_btn_main.gif) no-repeat left top; }

/*=====================================================================================================
*******************************************************************************************************

	.main_container
	
*******************************************************************************************************
=====================================================================================================*/
.main_container {
  width: 100%;
  background: #ddd;
  display: block;
  overflow: hidden;
  position: relative; }
  @media screen and (max-width: 1060px) {
    .main_container {
      padding-top: 47px; } }

/*=====================================================================================================
*******************************************************************************************************

	footer
	
*******************************************************************************************************
=====================================================================================================*/
footer {
  width: 100%;
  height: 116px;
  background: #fff;
  display: block;
  position: relative;
  z-index: 99; }
  @media screen and (max-width: 1060px) {
    footer {
      height: auto;
      padding-bottom: 1em; } }
  @media screen and (max-width: 820px) {
    footer {
      padding-bottom: 0; } }

footer nav {
  width: 100%;
  height: 46px;
  padding: 10px 0;
  background: url(../../../img/recruit/common/footer_bg.gif) center top;
  display: block; }
  @media screen and (max-width: 1060px) {
    footer nav {
      height: auto;
      padding: 1em 0; } }
  @media screen and (max-width: 480px) {
    footer nav {
      padding-bottom: 0; } }

footer nav div {
  width: 100%;
  max-width: 980px;
  height: 46px;
  margin: 0 auto 0 auto;
  display: block; }
  @media screen and (max-width: 1060px) {
    footer nav div {
      height: auto; } }

footer nav div a.in,
footer nav div a.fb {
  height: 0;
  padding: 46px 0 0 0;
  margin: 0;
  background: no-repeat left top;
  display: block;
  overflow: hidden;
  float: left; }
  @media screen and (max-width: 1060px) {
    footer nav div a.in,
    footer nav div a.fb {
      margin: 0 auto; } }

footer nav div a.in {
  width: 150px;
  background: url(../../../img/recruit/common/footer_btn_in.png) no-repeat 50% 50%; }
  @media screen and (max-width: 1060px) {
    footer nav div a.in {
      float: none; } }

footer nav div a.fb {
  width: 170px;
  background-image: url(../../../img/recruit/common/footer_btn_fb.png); }

footer nav div dl {
  width: 792px;
  height: 36px;
  padding: 0 0 0 0;
  display: block;
  float: right; }
  @media screen and (max-width: 1060px) {
    footer nav div dl {
      width: 782px;
      float: none;
      margin: 1em auto; } }
  @media screen and (max-width: 820px) {
    footer nav div dl {
      width: 100%;
      height: auto;
      margin-bottom: 0;
      overflow: hidden; } }

footer nav div dl dt {
  display: none; }

footer nav div dl dd {
  width: 315px;
  height: 36px;
  padding: 5px 0 5px 71px;
  margin: 0 0 0 10px;
  background: url(../../../img/recruit/common/footer_menu_bg.png) no-repeat;
  display: block;
  float: left; }
  @media screen and (max-width: 1060px) {
    footer nav div dl dd.dd0 {
      margin-left: 0; } }
  @media screen and (max-width: 820px) {
    footer nav div dl dd {
      float: none;
      margin: 1em auto 0 auto; }
      footer nav div dl dd.dd0 {
        margin: 0 auto 0 auto; } }
  @media screen and (max-width: 480px) {
    footer nav div dl dd {
      margin: 0;
      width: 100%;
      position: relative;
      padding-left: 0; } }

footer nav div dl dd.dd0 {
  background-position: 0px 0px; }
  @media screen and (min-width: 481px) {
    footer nav div dl dd.dd0 {
      width: 160px; } }
  @media screen and (max-width: 480px) {
    footer nav div dl dd.dd0 {
      background-color: #2EB9EE;
      background-position: 1em 0px; } }

footer nav div dl dd.dd1 {
  background-position: 0px -46px; }
  @media screen and (max-width: 480px) {
    footer nav div dl dd.dd1 {
      background-color: #FE2D63;
      background-position: 1em -46px; } }

footer nav div dl dd ul {
  display: block; }
  @media screen and (max-width: 480px) {
    footer nav div dl dd ul {
      -webkit-transform: scale(0.7);
      -moz-transform: scale(0.7);
      -ms-transform: scale(0.7);
      -o-transform: scale(0.7);
      transform: scale(0.7);
      -webkit-transform-origin: 0% 100%;
      -moz-transform-origin: 0% 100%;
      -ms-transform-origin: 0% 100%;
      -o-transform-origin: 0% 100%;
      transform-origin: 0% 100%;
      position: absolute;
      top: 0;
      left: 50%;
      right: auto;
      bottom: auto;
      margin-left: -70px;
      width: 315px; } }

footer nav div dl dd ul li {
  width: 150px;
  height: 36px;
  padding: 0 0 0 5px;
  display: block;
  float: left; }

footer nav div dl dd ul li p,
footer nav div dl dd ul li a {
  width: 150px;
  height: 0;
  padding: 36px 0 0 0;
  background: url(../../../img/recruit/common/footer_menu_btn.png) no-repeat;
  overflow: hidden;
  display: block; }

footer nav div dl dd.dd0 ul li.li0 a {
  background-position: 0px 0px; }

footer nav div dl dd.dd0 ul li.li1 a {
  background-position: -150px 0px; }

footer nav div dl dd.dd1 ul li.li0 a {
  background-position: -300px 0px; }

footer nav div dl dd.dd1 ul li.li1 a {
  background-position: -450px 0px; }

footer nav div dl dd.dd1 ul li.li0 p {
  background-position: -300px -72px; }

footer nav div dl dd.dd1 ul li.li1 p {
  background-position: -450px -72px; }

footer div.inner {
  width: 100%;
  max-width: 980px;
  height: 30px;
  padding: 10px 0 10px 0;
  margin: 0 auto 0 auto;
  display: block; }
  @media screen and (max-width: 1060px) {
    footer div.inner {
      width: 100%;
      position: relative;
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
      padding: 0 2em;
      margin-top: 1em;
      overflow: hidden;
      zoom: 1; } }
  @media screen and (max-width: 820px) {
    footer div.inner {
      height: auto;
      width: 100%;
      display: -ms-flexbox;
      display: -webkit-box;
      display: -webkit-flex;
      display: flex;
      -webkit-flex-wrap: wrap;
      flex-wrap: wrap;
      -webkit-box-pack: center;
      -webkit-justify-content: center;
      -moz-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center; } }

footer div.inner h2 {
  width: 163px;
  height: 24px;
  margin: 3px 14px 0 0;
  display: block;
  float: left; }
  @media screen and (max-width: 820px) {
    footer div.inner h2 {
      float: none; } }
  @media screen and (max-width: 480px) {
    footer div.inner h2 {
      width: 100%;
      float: none;
      margin-bottom: 1em; } }

footer div.inner h2 a {
  width: 163px;
  height: 0;
  padding: 24px 0 0 0;
  margin: 0;
  background: url(../../../img/recruit/common/footer_logo.gif) left top no-repeat;
  display: block;
  overflow: hidden;
  float: none; }
  @media screen and (max-width: 480px) {
    footer div.inner h2 a {
      margin: 0 auto; } }

footer div.inner a {
  width: 220px;
  height: 0;
  padding: 30px 0 0 0;
  margin: 0 0 0 0;
  background: url(../../../img/recruit/common/footer_btn_main.gif) left top no-repeat;
  display: block;
  overflow: hidden;
  float: left; }
  @media screen and (max-width: 820px) {
    footer div.inner a {
      float: none; } }
  @media screen and (max-width: 480px) {
    footer div.inner a {
      margin: 0 auto;
      float: none; } }

footer div.inner small {
  width: 306px;
  height: 0;
  padding: 20px 0 0 0;
  margin: 6px 0 0 0;
  background: url(../../../img/recruit/common/footer_copyright.gif) left top no-repeat;
  display: block;
  overflow: hidden;
  float: right; }
  @media screen and (max-width: 820px) {
    footer div.inner small {
      float: none;
      width: 100%;
      background: url(../../../img/recruit/common/footer_copyright.gif) 50% 50% no-repeat;
      background-size: contain;
      margin: 2em 0 1em 0; } }

/*=====================================================================================================
*******************************************************************************************************

	div#pagetop
	
*******************************************************************************************************
=====================================================================================================*/
div#pagetop {
  width: 60px;
  height: 60px;
  position: fixed !important;
  position: absolute;
  display: block;
  bottom: 0px;
  right: 30px;
  z-index: 9; }

div#pagetop a {
  width: 60px;
  height: 0;
  padding: 60px 0 0 0;
  background: url(../../../img/recruit/common/pagetop.png) no-repeat left top;
  position: absolute;
  display: block;
  overflow: hidden;
  bottom: -60px;
  -webkit-transition: 0.7s ease-in-out;
  -moz-transition: 0.7s ease-in-out;
  -ms-transition: 0.7s ease-in-out;
  -o-transition: 0.7s ease-in-out;
  transition: 0.7s ease-in-out; }

div#pagetop.on a {
  bottom: 0; }

/* =======================================================================================================================
　　　　　　　　　格納ナビゲーション
======================================================================================================================= */
.hm_btn, .hm_menu_wrap {
  display: none; }
  @media screen and (max-width: 1060px) {
    .hm_btn, .hm_menu_wrap {
      display: block; } }

/* ヘッダー固定・通常のナビを隠す */
@media screen and (max-width: 1060px) {
  #header {
    position: fixed;
    top: 0;
    left: 0;
    right: auto;
    bottom: auto;
    z-index: 99999; }
    #header .rgnav {
      display: none; } }

.hm_menu_check {
  /* チェックボックスを隠す */
  display: none; }

/* メニューボタン */
.hm_btn {
  font-size: 15px;
  position: fixed;
  width: 1.33em;
  height: 1.2em;
  cursor: pointer;
  z-index: 2;
  top: 0;
  right: 1em;
  border: rgba(255, 255, 255, 0) solid 1.067em;
  z-index: 9999999999991; }
  @media screen and (max-width: 480px) {
    .hm_btn {
      right: 1em; } }

.triple .hm_btn {
  position: fixed; }

.hm_btn::before {
  -webkit-box-shadow: #385eab 0 0.532em 0;
  box-shadow: #385eab 0 0.532em 0; }

.hm_btn::after {
  bottom: 0; }

.hm_btn::before,
.hm_btn::after {
  width: 1.33em;
  height: 0.13em;
  background: #385eab;
  display: block;
  content: '';
  position: absolute;
  -webkit-transition: -webkit-box-shadow 0.2s linear, -webkit-transform 0.2s 0.2s;
  transition: box-shadow 0.2s linear, transform 0.2s 0.2s; }

/* =============== 格納領域 ========================================================= */
.hm_menu_wrap {
  width: 100%;
  background: rgba(0, 0, 0, 0.5);
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  opacity: 0;
  filter: alpha(opacity=0);
  -webkit-transition: 0.7s;
  transition: 0.7s;
  box-sizing: border-box;
  overflow: hidden;
  visibility: hidden;
  z-index: 9999; }

.hm_inner {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: -19px;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch; }

.hm_inner:before {
  content: "";
  display: block; }

.menucontent {
  box-sizing: border-box;
  width: 100%;
  position: absolute;
  top: -100%;
  left: 0;
  -webkit-transition: top 1.0s;
  transition: top 1.0s;
  padding-top: 47px;
  background: rgba(255, 255, 255, 0.5);
  /* メニュー中身デザイン */ }
  .menucontent .spnav {
    width: 100%;
    position: relative;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    background: #fff;
    border-top: #385eab solid 3px; }
    .menucontent .spnav .rgnav {
      width: 100%;
      margin: 0 auto;
      float: none;
      overflow: hidden;
      max-width: 786px;
      border-left: none; }
      .menucontent .spnav .rgnav li {
        position: relative;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        box-sizing: border-box; }
        .menucontent .spnav .rgnav li:first-child {
          border-left: 1px solid #e0e0e0; }
      @media screen and (max-width: 813px) {
        .menucontent .spnav .rgnav {
          height: auto; }
          .menucontent .spnav .rgnav li {
            width: 16.66%;
            height: auto;
            position: relative;
            -webkit-box-sizing: border-box;
            -moz-box-sizing: border-box;
            box-sizing: border-box; }
            .menucontent .spnav .rgnav li a {
              width: 100%;
              position: relative;
              -webkit-box-sizing: border-box;
              -moz-box-sizing: border-box;
              box-sizing: border-box;
              padding-top: 60%;
              height: auto;
              border-right: #849FD5 solid 1px; }
              .menucontent .spnav .rgnav li a b, .menucontent .spnav .rgnav li a span {
                display: none; }
            .menucontent .spnav .rgnav li:nth-child(1) a {
              background: url("../../../img/recruit/common/spnav01.jpg") no-repeat 50% 50%;
              background-size: 90% auto; }
            .menucontent .spnav .rgnav li:nth-child(2) a {
              background: url("../../../img/recruit/common/spnav02.jpg") no-repeat 50% 50%;
              background-size: 90% auto; }
            .menucontent .spnav .rgnav li:nth-child(3) a {
              background: url("../../../img/recruit/common/spnav03.jpg") no-repeat 50% 50%;
              background-size: 90% auto; }
            .menucontent .spnav .rgnav li:nth-child(4) a {
              background: url("../../../img/recruit/common/spnav04.jpg") no-repeat 50% 50%;
              background-size: 90% auto; }
            .menucontent .spnav .rgnav li:nth-child(5) a {
              background: url("../../../img/recruit/common/spnav05.jpg") no-repeat 50% 50%;
              background-size: 90% auto; }
            .menucontent .spnav .rgnav li:nth-child(6) a {
              background: #385eab url("../../../img/recruit/common/spnav06.jpg") no-repeat 50% 50%;
              background-size: 90% auto; } }
      @media screen and (max-width: 768px) {
        .menucontent .spnav .rgnav li {
          width: 33.33%; }
          .menucontent .spnav .rgnav li a {
            border-top: #849FD5 solid 1px; } }
      @media screen and (max-width: 480px) {
        .menucontent .spnav .rgnav li {
          width: 50%; } }

/* 開閉時のアニメーション */
.hm_menu_check:checked ~ .hm_menu_wrap {
  opacity: 1.0;
  filter: alpha(opacity=100);
  visibility: visible; }

.hm_menu_check:checked ~ .hm_menu_wrap .menucontent {
  opacity: 1;
  filter: alpha(opacity=100);
  top: 0;
  height: auto; }

.hm_menu_check:checked ~ .hm_btn {
  position: fixed; }

.hm_menu_check:checked ~ .hm_btn::before {
  -webkit-box-shadow: transparent 0 0 0;
  box-shadow: transparent 0 0 0;
  -webkit-transform: rotate(45deg) translate3d(0.266em, 0.49em, 0);
  transform: rotate(45deg) translate3d(0.266em, 0.49em, 0); }

.hm_menu_check:checked ~ .hm_btn::after {
  -webkit-transform: rotate(-45deg) translate3d(0.266em, -0.49em, 0);
  transform: rotate(-45deg) translate3d(0.266em, -0.49em, 0); }

/*=====================================================================================================
*******************************************************************************************************

	各ページヘッダー
	
*******************************************************************************************************
=====================================================================================================*/
.main_container > div > h2 {
  width: 280px;
  height: 0;
  padding: 280px 0 0 0;
  margin: 2.5em auto;
  display: block;
  overflow: hidden; }

#work .main_container > div > h2, #mobile .main_container > div > h2, #accessory .main_container > div > h2, #sales .main_container > div > h2, #call .main_container > div > h2, #management .main_container > div > h2 {
  background: url(../../../img/recruit/h2_work.gif) no-repeat left top;
  background-size: contain; }

#environment .main_container > div > h2 {
  background: url(../../../img/recruit/h2_environment.gif) no-repeat left top;
  background-size: contain; }

#person .main_container > div > h2 {
  background: url(../../../img/recruit/h2_person.gif) no-repeat left top;
  background-size: contain; }

#qa .main_container > div > h2 {
  background: url(../../../img/recruit/h2_qa.gif) no-repeat left top;
  background-size: contain; }

#parents .main_container > div > h2 {
  background: url(../../../img/recruit/h2_parents.gif) no-repeat left top;
  background-size: contain; }

#job .main_container > div > h2 {
  background: url(../../../img/recruit/h2_job.gif) no-repeat left top;
  background-size: contain; }

#entry .main_container > div > h2, #thanks .main_container > div > h2 {
  background: url(../../../img/recruit/h2_entry.gif) no-repeat left top;
  background-size: contain; }

#kanto .main_container > div > h2 {
  background: url(../../../img/recruit/h2_kanto.gif) no-repeat left top;
  background-size: contain; }

#kyushu .main_container > div > h2 {
  background: url(../../../img/recruit/h2_kyushu.gif) no-repeat left top;
  background-size: contain; }

div#pagetop {
  display: none; }

@media screen and (max-width: 1060px) {
  #wrapper {
    width: 100%;
    min-height: 100vh;
    position: relative;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; } }

/*=====================================================================================================
*******************************************************************************************************

	header
	
*******************************************************************************************************
=====================================================================================================*/
header {
  position: fixed !important;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9999; }

/*=====================================================================================================
*******************************************************************************************************

	main_container
	
*******************************************************************************************************
=====================================================================================================*/
.main_container {
  width: 100%;
  min-height: 100vh;
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }
  .main_container #mov {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto; }
    @media screen and (max-aspect-ratio: 3 / 2) {
      .main_container #mov {
        display: -ms-flexbox;
        display: -webkit-box;
        display: -webkit-flex;
        display: flex;
        -ms-flex-align: center;
        -webkit-box-align: center;
        -webkit-align-items: center;
        align-items: center;
        -ms-flex-pack: center;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        justify-content: center; }
        .main_container #mov video.img_max100 {
          object-fit: contain;
          height: auto; } }
    @media screen and (max-width: 1060px) {
      .main_container #mov {
        position: absolute;
        top: 47px;
        left: 0;
        right: 0;
        bottom: 210px; } }
  @media screen and (max-width: 1060px) and (min-aspect-ratio: 4 / 3) {
    .main_container #mov {
      display: -ms-flexbox;
      display: -webkit-box;
      display: -webkit-flex;
      display: flex;
      -ms-flex-align: center;
      -webkit-box-align: center;
      -webkit-align-items: center;
      align-items: center;
      -ms-flex-pack: center;
      -webkit-box-pack: center;
      -webkit-justify-content: center;
      justify-content: center; }
      .main_container #mov video.img_max100 {
        object-fit: contain;
        width: auto; } }
  @media screen and (max-width: 1060px) and (min-aspect-ratio: 2 / 1) {
    .main_container #mov {
      position: relative;
      top: 0;
      bottom: 0; }
      .main_container #mov video.img_max100 {
        width: 100%;
        height: auto; } }

    @media screen and (max-width: 820px) {
      .main_container #mov {
        position: absolute;
        top: 47px;
        left: 0;
        right: 0;
        bottom: 285px; } }
  @media screen and (max-width: 820px) and (min-aspect-ratio: 1 / 1) {
    .main_container #mov {
      position: relative;
      top: 0;
      bottom: 0; }
      .main_container #mov video.img_max100 {
        width: 100%;
        height: auto; } }

    @media screen and (max-width: 480px) {
      .main_container #mov {
        position: absolute;
        top: 47px;
        left: 0;
        right: 0;
        bottom: 300px; } }
  @media screen and (max-width: 480px) and (min-aspect-ratio: 2 / 3) {
    .main_container #mov {
      position: relative;
      top: 0;
      bottom: 0; }
      .main_container #mov video.img_max100 {
        width: 100%;
        height: auto; } }

@media screen and (max-width: 1060px) and (min-aspect-ratio: 2 / 1) {
  .main_container {
    height: auto;
    padding-top: 47px; } }

@media screen and (max-width: 820px) and (min-aspect-ratio: 1 / 1) {
  .main_container {
    height: auto;
    padding-top: 47px;
    min-height: 0; } }

@media screen and (max-width: 480px) and (min-aspect-ratio: 2 / 3) {
  .main_container {
    height: auto;
    padding-top: 47px;
    min-height: 0; } }

/*=====================================================================================================
*******************************************************************************************************

	footer
	
*******************************************************************************************************
=====================================================================================================*/
footer {
  position: fixed !important;
  position: absolute;
  bottom: 0;
  z-index: 99; }
@media screen and (max-width: 1060px) and (min-aspect-ratio: 2 / 1) {
  footer {
    position: relative !important; } }

@media screen and (max-width: 820px) and (min-aspect-ratio: 1 / 1) {
  footer {
    position: relative !important; } }

@media screen and (max-width: 480px) and (min-aspect-ratio: 2 / 3) {
  footer {
    position: relative !important; } }

@font-face {
  font-family: "Yu Gothic M";
  src: local("Yu Gothic Medium"); }
@font-face {
  font-family: "Yu Gothic M";
  src: local("Yu Gothic Bold");
  font-weight: bold; }
* {
  margin: 0;
  padding: 0; }
  @media screen and (max-width: 1060px) {
    * {
      font-size: 2vw; } }
  @media screen and (max-width: 768px) {
    * {
      font-size: 2.5vw; } }
  @media screen and (max-width: 480px) {
    * {
      font-size: 4vw; } }

body, html {
  scroll-behavior: smooth; }

/* =======================================================================================================================
　　　　　　　　　全体
======================================================================================================================= */
@media screen and (max-width: 1060px) {
  body {
    font-size: 2vw; } }
@media screen and (max-width: 768px) {
  body {
    font-size: 2.5vw; } }
@media screen and (max-width: 480px) {
  body {
    font-size: 4vw; } }

/* =======================================================================================================================
　　　　　　　　　レイアウト
======================================================================================================================= */
#container {
  min-height: -webkit-calc(100vh - 118px);
  min-height: -moz-calc(100vh - 118px);
  min-height: calc(100vh - 118px); }
  @media screen and (max-width: 1060px) {
    #container {
      min-height: -webkit-calc(100vh - 131px);
      min-height: -moz-calc(100vh - 131px);
      min-height: calc(100vh - 131px); } }
  @media screen and (max-width: 768px) {
    #container {
      min-height: -webkit-calc(100vh - 160px);
      min-height: -moz-calc(100vh - 160px);
      min-height: calc(100vh - 160px); } }
  @media screen and (max-width: 480px) {
    #container {
      min-height: -webkit-calc(100vh - 136vw);
      min-height: -moz-calc(100vh - 136vw);
      min-height: calc(100vh - 136vw); } }

/* フレキシブルボックス */
.flexbox {
  width: 100%;
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap; }
  .flexbox.box2 li {
    width: 50%; }
  .flexbox.box3 li {
    width: 33.33%; }

/* 画像・動画 */
img {
  vertical-align: bottom; }
  img.img_max100 {
    object-fit: cover;
    object-position: 50% 50%;
    width: 100%;
    height: 100%;
    font-family: "object-fit: cover; object-position: 50% 50%;"; }

video.img_max100 {
  object-fit: cover;
  object-position: 50% 50%;
  width: 100%;
  height: 100%;
  font-family: "object-fit: cover; object-position: 50% 50%;"; }

/* 画像リンク */
a img {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -ms-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out; }
a:hover img {
  opacity: 0.7;
  filter: alpha(opacity=70); }

/*# sourceMappingURL=recruit-front.css.map */
