@charset "utf-8";
/*---------------------------------------------------------

  共通

---------------------------------------------------------*/
.mainWidth-rec {
  max-width: 1176px;
  margin-left: auto;
  margin-right: auto;
}

/* bg */
.bg_grey {
  background: #fff;
  /* padding-bottom: 110px; */
  padding-bottom: 0px;
}


/* pagettl */
.p_ttl {
  text-align: center;
  padding: 126px 0 67px;
  border-bottom: 1px solid #d0d0d0;
  max-width: 728px;
  margin: 0 auto;
}
.p_ttl > span {
  display: inline-block;
  vertical-align: middle;
  color: #000;
  letter-spacing: 0.2em;
}
.p_ttl .ja {
  font-size: 3.6rem;
  font-weight: 400;
  font-weight: bold;
}
.p_ttl .en {
  font-size: 2rem;
  padding-left: 30px;
  font-weight: bold;
}


/* content_area */
.content_area {
  background: #fff;
  padding: 50px 200px;
}


/*---------------------------------------------------------

  index list

---------------------------------------------------------*/
.rec_list {

}
.rec_list li {
  border-bottom: 1px solid #d0d0d0;
}
.rec_list li:last-child {
  border-bottom: none;
}
.rec_list a {
  display: block;
  padding: 25px 1em;
  padding-left: 120px;
  position: relative;
}
.rec_date {
  position: absolute;
  top: 25px;
  left: 0;
  color: #000000;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
.rec_cat {
  color: #0056a7;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  margin-bottom: 15px;
}
.rec_ttl {
  font-size: 1.8rem;
  letter-spacing: 0.1em;
}

/* hover */
.rec_list a:hover {
  opacity: 1;
  background-color: #e8ebec;
}




/*---------------------------------------------------------



  詳細



---------------------------------------------------------*/
/* 募集要項 */
.requirements {
  width: 100%;
  margin-bottom: 144px;
}
.requirements tr {
  border-bottom: #acacac solid 1px;
}
.requirements tr:first-child th,
.requirements tr:first-child td {
  padding-top: 0;
}
.requirements th {
  font-weight: bold;
  width: 24%;
}
.requirements th,
.requirements td {
  padding: 30px 0;
}


/* ttl */
.form_ttl {
  text-align: center;
  font-size: 2.8rem;
  font-weight: 400;
  margin-bottom: 60px;
}


/* form_step */
.form_step {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  max-width: 728px;
  margin: 0 auto 80px;
}
.form_step li {
  text-align: center;
/*  margin-right: 5%;
*/  width: 100%;
  color: #dcdcdc;
  position: relative;
}
.form_step li:nth-child(2) {
  width: 114%;
}
.form_step li:last-child {
  margin-right: 0;
}
.form_step li::after {
  content: "";
  display: block;
  height: 50px;
  width: 27px;
  background: #fff;
  transform: rotate(-21deg);
  position: absolute;
  top: -21px;
  right: -19px;
  z-index: 2;
}
.form_step li:last-child::after {
  display: none;
}


.form_step-border {
  display: block;
  width: 100%;
  height: 8px;
  background: #d0d0d0;
  margin-bottom: 15px;
}

/* step-current */
.form_step .current {
  color: #000000;
}
.current .form_step-border {
  background: #3056a3;
}



/* lead */
.form_lead {
  text-align: center;
  line-height: 2.2;
  letter-spacing: 0.03em;
  margin-bottom: 60px;
}
.finish-ttl {
  font-size: 2rem;
  text-align: center;
  margin-bottom: 35px;
}

/* hissu */
.hissu {
  display: inline-block;
  background: #000;
  font-size: 1.3rem;
  color: #fff;
  vertical-align: middle;
  padding: 1px 10px 0px;
  margin-right: 6px;
}



/* 募集要項なし */
.noth-ttl {
  font-size: 2.8rem;
  text-align: center;
  font-weight: 400;
  color: #0056a7;
  position: relative;
  letter-spacing: 0.2em;
  margin: 40px 0 80px;
}
.noth-ttl::after {
  content: "";
  position: absolute;
  display: block;
  width: 42px;
  height: 3px;
  background: #0056a7;
  left: 0;
  right: 0;
  margin: 40px auto 0;
}
.noth-txt {
  font-size: 1.8rem;
  text-align: center;
  letter-spacing: 0.2em;
  line-height: 2.5;
  margin-bottom: 40px;
}

/*---------------------------------------------------------

  index list

---------------------------------------------------------*/
/* スタイル */
input, button, textarea, select {
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 15px;
  font-size: 1.6rem;
  color: #000;
  border: solid 1px #000000;
  margin: 0 0 20px;
  width: 100%;
}
select {
  width: 30%;
  padding-left: 30px;
}
select:hover {
  cursor: pointer;
}
input::placeholder {
  color: #aaaaaa;
}
/* IE */
input:-ms-input-placeholder {
  color: #aaaaaa;
}
/* Edge */
input::-ms-input-placeholder {
  color: #aaaaaa;
}


.form_input {
  width: 100%;
  margin-bottom: 60px;
}
.form_input .hissu {
  margin-left: 21px;
  padding: 4px 10px 3px;
}
.form_input dt {
  margin-bottom: 20px;
}
.form_input dd {
  font-size: 2rem;
  margin-bottom: 0px;
}
.form_input .f-birth input {
  margin: 0 15px;
  width: 23%;
}
.form_input .f-zip input {
  width: 15%;
}
.form_input .f-zip input:nth-child(1) {
  margin-right: 14px;
}
.form_input .f-zip input:nth-child(2) {
  margin-left: 8px;
}


/* チェック */
.form_privacy {
  border-top: solid 1px #a0a0a0;
  border-bottom: solid 1px #a0a0a0;
  padding: 45px 0;
  margin-bottom: 80px;
}

/* プライバシー */
.form_privacy dt,
.form_privacy dd {
  display: table-cell;
  vertical-align: middle;
}
.form_privacy a {
  color: #0056a7;
  font-weight: bold;
}
.form_privacy dd {
  padding-left: 80px;
}

.form_privacy label {
  position: relative;
}
.form_privacy label:hover {
  cursor: pointer;
}
.form_privacy input[type="checkbox"] {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}
.form_privacy span {
    display: inline-block;
    position: relative;
    padding-left: 43px;
}
.form_privacy span::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: -2px;
    left: 0;
    z-index: 0;
    background-color: transparent;
    width: 26px;
    height: 26px;
    border: 1px #000000 solid;
}
.form_privacy input[type="checkbox"]:checked + span::after {
    content: '';
    display: inline-block;
    position: absolute;
    top: 4px;
    left: 11px;
    z-index: 1;
    width: 6px;
    height: 11px;
        border: 1px solid #000000;
    border-top: none;
    border-left: none;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}



/*送信ボタン*/
.arrowBtn {
  display: block;
  width: 280px;
  margin: 0 auto;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  padding: 18px 8px 18px 0;
  position: relative;
  border: solid 1px #000000;
  text-align: center;
}
.arrowBtn::before {
  content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: 62px;
    margin: auto;
    width: 12px;
    height: 12px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.arrowBtn::after {
  content: "";
    position: absolute;
    top: 50%;
    right: 61px;
    border-top: 1px solid #000;
    margin: auto;
    width: 0;
}
.arrowBtn::before,
.arrowBtn::after {
  -webkit-transition: all .45s ease;
    -moz-transition: all .45s ease;
    transition: all .45s ease;
}
.arrowBtn:hover::before {
  -webkit-transform: rotate(45deg) translate3d(5px,-5px,0);
    transform: rotate(45deg) translate3d(5px,-5px,0);
}
.arrowBtn:hover::after {
    width: 22px;
    -webkit-transform: translate3d(8px,0,0);
    transform: translate3d(8px,0,0);
}

.disabled .arrowBtn {
  border-color: #000;
  color: #000;
  cursor: pointer;
}

.disabled .arrowBtn::before {
  border-color: #000;
}

/* 確認画面 */
.submit-conf {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
}
.submit-conf .arrowBtn {
  margin: 0;
}
.submit-conf .arrowBtn::after {
  top: calc(50% - 1px);
}
/* 戻るボタン */
.submit-conf .backBtn::before {
  left: -62px;
  -webkit-transform: rotate(-136deg);
    transform: rotate(-136deg);
}
.submit-conf .backBtn::after {
  left: -82px;
}
.submit-conf .backBtn:hover::before {
  -webkit-transform: rotate(-136deg) translate3d(5px,-5px,0);
    transform: rotate(-136deg) translate3d(5px,-5px,0);
}
.submit-conf .backBtn:hover::after {
}

.frm_last {
  margin-bottom: 0 !important;
}

/*---------------------------------------------------------

  フォーム 内容確認

---------------------------------------------------------*/
.entry_check {
    margin-bottom: 80px;
}
.entry_check .p01 {
    padding: 15px;
    font-size: 1.6rem;
    color: #000;
    border: solid 1px #000000;
    margin: 0 0 20px;
    width: 100%;
    min-height: 57px;
}
.entry_check .span01 {
    padding: 15px;
    font-size: 1.6rem;
    color: #000;
    border: solid 1px #000000;
    /* margin: 0 0 20px; */
    margin: 0 1em;
    /* width: 100%; */
    min-width: 4em;
    min-height: 57px;
    display: inline-block;
    vertical-align: middle;
}
.entry_check .span01.ml0 {
    margin-left: 0 !important;
}
.entry_check .form_input .hissu {
    display: none;
}



@media screen and (max-width: 1032px) {}

/*---------------------------------------------------------
	スマホ
---------------------------------------------------------*/
@media screen and (max-width: 680px) ,screen and (max-width: 737px) and (orientation: landscape) {
	/*---------------------------------------------------------

    共通

  ---------------------------------------------------------*/
  .mainWidth-rec {
    max-width: initial;
    margin: 0 3%;
  }

  /* bg */
  .bg_grey {
    padding-bottom: 20px;
  }


  /* pagettl */
  .p_ttl {
    text-align: center;
    padding: 67px 0 20px;
    width: 78%;
  }
  .p_ttl > span {
    display: block;
  }
  .p_ttl .ja {
    font-size: 2.2rem;
  }
  .p_ttl .en {
    font-size: 1.2rem;
    padding-left: 0;
  }


  /* content_area */
  .content_area {
    padding: 40px 8%;
  }


  /*---------------------------------------------------------

    index list

  ---------------------------------------------------------*/
  .rec_list {

  }
  .rec_list li {
  }
  .rec_list li:last-child {
  }
  .rec_list a {
    padding: 20px 0 14px;
  }
  .rec_date {
    top: 20px;
    left: 0;
    font-size: 1.4rem;
    line-height: 1;
  }
  .rec_cat {
    padding-left: 94px;
    font-size: 1.4rem;
    line-height: 1;
    margin-bottom: 8px;
  }
  .rec_ttl {
    font-size: 1.4rem;
    line-height: 2;
  }

  /* hover */
  .rec_list a:hover {
  }



  /*---------------------------------------------------------



    詳細



  ---------------------------------------------------------*/
  /* 募集要項 */
  .requirements {
    margin-bottom: 80px;
  }
  .requirements tr {
  }
  .requirements tr:first-child th,
  .requirements tr:first-child td {
  }
  .requirements th {
    width: 100%;
  }
  .requirements th,
  .requirements td {
    padding: 30px 0;
    display: block;
  }
  .requirements th {
    padding: 15px 0 5px;
  }
  .requirements td {
    padding: 0 0 15px;
  }

  /* ttl */
  .form_ttl {
    font-size: 1.8rem;
    margin-bottom: 30px;
  }


  /* form_step */
  .form_step {
    max-width: initial;
    margin: 0 auto 30px;
  }
  .form_step li {
    font-size: 1.2rem;
  }
  .form_step li:nth-child(2) {
    width: 114%;
  }
  .form_step li:last-child {
  }
  .form_step li::after {
    height: 35px;
    width: 10px;
    top: -17px;
    right: -4px;
  }
  .form_step li:last-child::after {
  }


  .form_step-border {
    height: 5px;
    margin-bottom: 8px;
  }

  /* step-current */
  .form_step .current {
  }
  .current .form_step-border {
  }



  /* lead */
  .form_lead {
    text-align: left;
    margin-bottom: 50px;
  }
  .finish-ttl {
    font-size: 1.7rem;
    margin-bottom: 20px;
  }


  /* hissu */
  .hissu {
    font-size: 1.2rem;
    padding: 1px 10px 0px;
  }

  /* 募集要項なし */
  .noth-ttl {
    font-size: 1.6rem;
    margin: 20px 0 40px;
  }
  .noth-ttl::after {
    width: 22px;
    height: 2px;
    margin: 20px auto 0;
  }
  .noth-txt {
    font-size: 1.3rem;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
  }




  /*---------------------------------------------------------

    form

  ---------------------------------------------------------*/
  /* スタイル */
  input, button, textarea, select {
    padding: 8px 15px;
  }
  textarea {
    height: 180px;
  }
  select {
    width: 100%;
  }
  select:hover {
  }
  input::placeholder {
  }
  /* IE */
  input:-ms-input-placeholder {
  }
  /* Edge */
  input::-ms-input-placeholder {
  }


  .form_input {
    margin-bottom: 20px;
  }
  .form_input .hissu {
    margin-left: 15px;
    padding: 2px 8px 2px;
  }
  .form_input dt {
    margin-bottom: 15px;
  }
  .form_input dd {
    font-size: 1.4rem;
    margin-bottom: 40px;
  }
  .form_input .f-birth input {
    margin: 0 2%;
    width: 19%;
  }
  .form_input .f-zip input {
    width: 43%;
  }
  .form_input .f-zip input:nth-child(1) {
    margin-right: 4%;
  }
  .form_input .f-zip input:nth-child(2) {
    margin-left: 4%;
  }


  /* チェック */
  .form_privacy {
    padding: 20px 0;
    margin-bottom: 40px;
  }

  .form_privacy dt,
  .form_privacy dd {
  }
  .form_privacy dt {
    font-size: 1.4rem;
  }
  .form_privacy dd {
    padding-left: 10%;
    width: 58%;
  }

  .form_privacy label {
    position: relative;
  }
  .form_privacy label:hover {
    cursor: pointer;
  }
  .form_privacy input[type="checkbox"] {
      position: absolute;
      top: 0;
      left: 0;
      opacity: 0;
  }
  .form_privacy span {
      display: inline-block;
      position: relative;
      padding-left: 43px;
  }
  .form_privacy span::before {
      content: '';
      display: inline-block;
      position: absolute;
      top: -2px;
      left: 0;
      z-index: 0;
      background-color: transparent;
      width: 26px;
      height: 26px;
      border: 1px #000000 solid;
  }
  .form_privacy input[type="checkbox"]:checked + span::after {
      content: '';
      display: inline-block;
      position: absolute;
      top: 4px;
      left: 11px;
      z-index: 1;
      width: 6px;
      height: 11px;
          border: 1px solid #000000;
      border-top: none;
      border-left: none;
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg);
  }



  /*送信ボタン*/
  .arrowBtn {
    width: 100%;
    margin: 0 auto 40px;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    padding: 18px 8px 18px 0;
    position: relative;
  }
  .arrowBtn::before {
    content: "";
      position: absolute;
      top: 0;
      bottom: 0;
      right: 62px;
      margin: auto;
      width: 12px;
      height: 12px;
      border-top: 1px solid #000;
      border-right: 1px solid #000;
      -webkit-transform: rotate(45deg);
      transform: rotate(45deg);
  }
  .arrowBtn::after {
    content: "";
      position: absolute;
      top: 50%;
      right: 61px;
      border-top: 1px solid #000;
      margin: auto;
      width: 0;
  }
  .arrowBtn::before,
  .arrowBtn::after {
    -webkit-transition: all .45s ease;
      -moz-transition: all .45s ease;
      transition: all .45s ease;
  }
  .arrowBtn:hover::before {
    -webkit-transform: rotate(45deg) translate3d(5px,-5px,0);
      transform: rotate(45deg) translate3d(5px,-5px,0);
  }
  .arrowBtn:hover::after {
      width: 22px;
      -webkit-transform: translate3d(8px,0,0);
      transform: translate3d(8px,0,0);
  }

  .disabled .arrowBtn {
    border-color: #cccccc;
    color: #cccccc;
    pointer-events: none;
  }
  .disabled .arrowBtn::before {
    border-color: #cccccc;
  }



  /* 確認画面 */
  .submit-conf {
  }
  .submit-conf .arrowBtn {
    width: 42%;
  }
  .submit-conf .arrowBtn::before  {
    right: 30px;
  }
  .submit-conf .arrowBtn::after {
  }
  /* 戻るボタン */
  .submit-conf .backBtn::before {
    left: -35px;
  }
  .submit-conf .backBtn::after {
    left: -82px;
}




  .frm_last {
    margin-bottom: 0 !important;
  }

/*---------------------------------------------------------

    フォーム 内容確認

  ---------------------------------------------------------*/
  .entry_check {
    margin-bottom: 40px;
  }
  .entry_check .p01 {
    padding: 8px 15px;
    min-height: 42px;
  }
  .entry_check .span01 {
    padding: 8px 15px;
    margin: 0 2%;
    /* width: 19%; */
    min-width: 3em;
    min-height: 42px;
  }
  .entry_check .form_input .hissu {}

}

@media screen and (max-width: 414px) {
   /*---------------------------------------------------------
    詳細
  ---------------------------------------------------------*/
  /* lead */
  .form_lead {}
  .form_lead .sp_display_block {
}
  .finish-ttl {}
}

@media screen and (max-width: 374px) {
   /*---------------------------------------------------------
    詳細
  ---------------------------------------------------------*/
  /* lead */
  .form_lead {
    font-size: 1.2rem;
}
  .form_lead .sp_display_block {}
  .finish-ttl {}
}
