

@font-face {
  font-family: "Noto Sans JP";
  src: url('/webfonts/NotoSansJP-VariableFont_wght.ttf');
}

/***************************
PRESETS AREA
****************************/
/* Apply smooth scroll behavior */
html {
  scroll-behavior: smooth;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

ul {
  list-style-type: none;
}

img {
  max-width: 100%;
  display: inline-block;
  /* vertical-align: top; */
}

a {
  text-decoration: none;
}

a:hover {
  opacity: .6;
  transition: all 0.3s ease;
}

button:hover {
  opacity: .6;
  transition: all 0.3s ease;
}

.clearfix {
  overflow: hidden;
}

hr {
  border-top: 1px solid #CCC;
}

/****************************
COMMON AREA
****************************/
.sp-only {
  display: none;
}

body {
  font-size: 1rem;
  font-family: "Noto Sans JP";
  line-height: 2;
  background: #e2effe;
  color: #333;
}

.wrapper {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.c_ttl {
  line-height: 1.2;
  font-size: 24px;
  margin: 20px 0px 20px;
  border-left: 8px solid #1D50A2;
  padding: 8px 15px;
  font-weight: 500;
}

.s_ttl {
  line-height: 1.2;
  font-size: 30px;
  margin: 20px 0px;
  padding: 10px 0px;
}

.c_btn {
  padding: 15px 0px;
  font-size: 14px;
  margin-top: 5px;
  line-height: 1em;
  border: none;
}

.s_btn {
  padding: 5px 10px;
  height: 30px;
  font-size: 15px;
  margin-top: 5px;
  margin-right: 5px;
  line-height: 1em;
  border: none;
  display: inline-block;
}

.p_btn {
  padding: 12px 20px;
  height: 40px;
  font-size: 15px;
  margin-top: 5px;
  line-height: 1em;
  font-weight: 500;
  border: none;
  display: inline-block;
}

.map_btn {
  position: absolute;
  font-size: 15px;
  padding: 5px 10px;
  top: 0;
  right: 0;
  line-height: 1em;
  background-color: #F3F3F3;
  border: none;
}

.b-none {
  border: none;
}

.b-5 {
  border-radius: 5px;
}

.b-10 {
  border-radius: 10px;
}

.b-red {
  border: 1px solid #F00;
}

.b-orange {
  border: 1px solid #ffaa00;
}

.b-dark-blue {
  border: 1px solid #1D50A2;
}

.bg-blue {
  background-color: #2196f3;
}

.bg-orange {
  background-color: #ffaa00
}

.bg-blue {
  background-color: #2196f3;
}

.bg-dark-blue {
  background-color: #1d50a2;
}

.bg-gray {
  background-color: #ABB6C6;
}

.bg-white {
  background-color: #FFF;
}

.bg-light-blue {
  background-color: #77d5ff;
}

.bg-yellow {
  background-color: #ff8400;
}

.bg-light-yellow {
  background-color: #ff8400;
}

.bg-pale-blue {
  background-color: #E2EFFE;
}

.txt-blue {
  color: #2196f3;
}

.txt-dark-blue {
  color: #1d50a2;
}

.txt-white {
  color: #FFF;
}

.txt-red {
  color: #F00;
}

.txt-black {
  color: #000;
}

.p-y-10 {
  padding: 10px;
}

.w-50 {
  width: 50%;
}

.w-100 {
  width: 100%;
}

.strong {
  font-weight: 500;
}

.txt-light-gray {
  color: #ddd;
}

.txt-gray {
  color: #666;
}

.mb-5 {
  margin-bottom: 5px;
}


.modal-body-desc-txt {
  width: 100%;
  text-align: center;
  margin-bottom: 20px;
  font-weight: 400;
}

h3 { font-size: 24px; }


/* AI Report */
.wrapper_ai-report .mid_box div {
  margin-bottom: 10px;
}

.wrapper_ai-report h3 {
  font-size: 22px;
}

.wrapper_ai-report ol li {
  line-height: 1.5em;
}

.wrapper_ai-report strong {
  font-weight: bold;
}

.moco_copyright {
  font-size: 0.8em;
  line-height: 1.3em;
}

@media only screen and (max-width: 767px) {
  .wrapper_ai-report h3 {
    font-size: 16px;
  }
}

/***************************
MAIN AREA
****************************/
main {
  width: 100%;
  max-width: 960px;
  margin: 0px auto;
  color: #666;
  font-size: 16px;

}

#main_wrapper {
  overflow-y: auto;
}

main p {
  margin-bottom: 30px;
  line-height: 1.5em;
}

#content_nav ul {
  display: flex;
  justify-content: flex-end;
  font-size: 16px;
  font-weight: 500;
  gap: 30px;
  padding: 10px;
  max-width:960px;
  margin: 20px auto 0;
}

#content_nav ul li {
  line-height: 1.5em;
}

#content_nav ul a {
  color: #32BEFC;
  display: block;
  border-bottom: 4px solid transparent;
  text-decoration: none;
  cursor: pointer;
}

#content_nav ul a:hover {
  border-bottom: 5px solid #32BEFC;
  text-decoration: none;
}

#content_nav ul a.active {
  border-bottom: 4px solid #3ebffc;
  text-decoration: none;
}

#content_nav.wrapper {
max-width: 100vw;
width: 100cqw;
margin: 0 calc(50% - 50vw);
}

#content_nav {
  position: sticky;
  top: 83px;
  z-index: 10;
  background-color: #e2effe;
}


/***************************
TOP BOX AREA
****************************/
.top_box_con {
  text-align: left;
  padding: 30px 50px;
  margin-bottom: 50px;
}

/***************************
MIDDLE BOX AREA
****************************/
.mid_box {
  margin-bottom: 50px;
  position: relative;
  /* margin-top: -150px; */
  /* padding-top: 150px; */
}

.mid_box_ttl {
  padding: 5px 50px;
  border-radius: 10px 10px 0px 0px;
  background-color: #1d50a2;
  color: #FFF;
  font-size: 18px;
  font-weight: 500;
}

.mid_box_content {
  padding: 15px 50px;
  border-radius: 0px 0px 10px 10px;
}

.num_txt {
  font-size: 24px;
  margin-right: 10px;
}

.mid_box_content .alert {
  width: 100%;
  max-width: 500px;
  background-color: #32BEFC; 
  font-size: 21px;
  border-radius: 0px;
}

.mid_box_content .hellowork_register_alert{
  color:#f00;
}

.mid_box_content .hellowork_register_alert a{
  color:#f00;
  text-decoration:underline;
}


.mid_box_content .alert h4{ margin: 0; }

.recommend_content {
  width: 100%;
  display: flex;
  justify-content: space-between;
  margin: 10px 0px;
  position: relative;
}

.recommend_content>div {
  width: 49%;
}

.recommend_content img {
  width: 100%;
}

.recommend_content a {
  color: #3ebffc;
}

.recommend_content .icon {
  width: 28px;
  height: 28px;
  background-color: #EEE;
  padding: 5px;
  margin-right: 10px;
  border-radius: 20px;
  text-align: center;
}

.recommend_content button {
  width: 70%;
}

.recommend_content .heart-icon {
  position: absolute;
  color: #ddd;
  z-index: 1;
  right: 0;
  bottom: 0;
}

.active_tab {
  display: block;
}

.anchor_link {
  margin-top: -150px;
  padding-top: 150px;
}

@media only screen and (max-width: 767px) {
  .mid_box {
      margin-bottom: 30px;
  }

  .mid_box_ttl {
      padding: 5px 20px;
  }

  .mid_box_content {
      padding: 10px 20px;
  }

  .recommend_content {
      display: block;
  }

  .recommend_content>div {
      width: 100%;
      margin-top: 10px;
  }
}

@media only screen and (max-width: 450px) {
  .mid_box_ttl {
      font-size: 16px;
  }
}

/***************************
BREADCRUMBS AREA
****************************/
.breadcrumbs {
  color: #1d50a2;
  text-align: left;
  font-size: 13px;
  padding: 0px 20px 0px;
  margin-bottom: 10px;
}

.breadcrumbs a {
  color: #1d50a2;
  margin: 0px 5px;
}

@media only screen and (max-width: 767px) {
  .breadcrumbs {
      margin-bottom: 5px;
      line-height: 1em;
      padding: 0px 10px;
  }

  .breadcrumbs a {
      font-size: 10px;
  }
}

/***************************
STICKY BUTTON
****************************/
.sticky-div {
  width: 220px;
  position: fixed;
  z-index: 11;
  bottom: 60px;
  top: auto;
  right: 20px;
  cursor: pointer;
  text-align: center;
}

.sticky-div.no_view{
  display:none !important;
}

.sticky-div .hellowork_alert{
  background-color:#fff;
  text-align:center;
  position: absolute;
  top: -40px;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto 10px;
  padding: 0px;
  font-size: 13px;
  margin-top: 10px;
  height: 34px;
  line-height: 17px;
  margin-bottom:10px;
  cursor: default;
  box-shadow: 1px 1px 3px #aaa;
}

.sticky-div .hellowork_job_detail_wrap{
  position:relative;
  margin-top:15px;
  width:100%;
}

.sticky-div .hellowork_job_detail_wrap .d-flex{
  display:block;
}

.sticky-div .hellowork_job_detail_wrap a{
  padding:0px;
  height:30px;
}

.sticky-div .hellowork_job_detail_wrap a button{
  line-height: 1.1;
  font-size: 18px;
  padding: 3px 0;
}

.sticky-div .hellowork_job_detail_wrap a button span{
  font-size: 14px;
}

.sticky-div .hellowork_job_detail_wrap a.redirect_to_apply{
  color:#333;
  text-align:center;
  text-decoration:underline;
}

.sticky-div .hellowork_job_detail_wrap a:active,
.sticky-div .hellowork_job_detail_wrap a:hover,
.sticky-div .hellowork_job_detail_wrap button:hover {
  opacity: 1 !important;
}

.sticky-div .hellowork_job_detail_wrap a.active {
  border-bottom: none;
}


@media only screen and (max-width: 1500px) {
  .sticky-div {
      right: 20px;
  }
}

.sticky_btn, .sticky_btn2 {
  width: 220px;
  height: 43px;
  font-size: 16px;
  letter-spacing: 0px;
  padding: 5px;
  margin-bottom: 10px;
  font-weight: 500;
}

/* .fave_btn {
  display:block;
} */

.call-btn {
  width: 180px;
  padding: 10px;
  margin-bottom: 10px;
  display: none;
}

/* #condition {
  position:relative;
} */

@media only screen and (max-width: 767px) {
  .sticky-div {
      width: 100%;
      padding: 10px;
      bottom: 0!important;
      top: auto!important;
      left: 0;
      background-color: rgba(192, 192, 192, 0.3);
      height: 60px;
      display: flex;
      -webkit-flex-wrap: wrap;
      flex-wrap: wrap;
      padding-right: 60px;
      gap: 10px;
  }

  .sticky-icon {
      position: fixed;
      color: rgba(192, 192, 192, 0.5);
      z-index: 10;
      right: 3%;
      bottom: 100px;
      cursor: pointer;
  }

  .sticky_btn {
      width: calc(50% - 5px);
  }

  .sticky_btn.bg-light-yellow {
      width: 100%;
  }

  .call-btn {
      width: 180px;
      padding: 15px 20px;
      margin: 0px 5px;
      display: block;
  }

  .sticky_btn2 {
      display:none;
  }

  .sticky-div a {
      text-decoration: none;
      width: calc(50% - 5px);
  }

  .sticky-div a.sticky_btn {
      width: 100%;
  }
}

/***************************
BANNER AREA
****************************/
#sub_header {
  background-color: #1f51a2;
  font-size: 14px;
}

.sub_header_con {
  max-width: 960px;
  margin: 0px auto;
  padding: 0px 20px;
  font-size: 13px;
}

#banner {
  width: 100%;
  overflow: hidden;
  height: auto;
  margin: 30px 0px;
}

.top-slider {
  width: 100%;
  margin: 0 auto;
}

.top-slider .img-wrap {
  margin: 0 auto;
  padding: 40px;
}

/* sets the inner image to 960 width(offset padding) */
.top-slider .slick-slide {
  width: 969px;
  box-sizing: border-box;
}

.top-slider img {
  width: 100%;
  height: auto;
  box-shadow: 0 5px 20px #1D50A24C;
}

/* sliderの高さ調整 */
.slick-slide img {
  display: block;
  aspect-ratio: 3 / 2;
  background: #ffffffcc;
  object-fit: contain;
}

.slick-center {
  transform: scale(1.08);
}

.slide:not(.slick-active) {
  cursor: pointer;
}

.slick-arrow {
  position: absolute;
  top: 50%;
  width: 40px;
  height: 50px;
  line-height: 50px;
  margin-top: -25px;
  border: none;
  background: transparent;
  /* color: #fff; */
  font-family: monospace;
  font-size: 7rem;
  z-index: 300;
  outline: none;
  /* -webkit-text-stroke: 1px #ccc; */
}

.top-slider .slick-prev, .top-slider .slick-prev:hover, .top-slider .slick-prev:focus {
  width: 42px;
  height: 61px;
  background-image: url('/assets/web/images/job_details/left_arrow.png');
  left: calc((100% - 1040px) / 2 + 52px);
  text-align: left;
  z-index: 90;
}

.top-slider .slick-next, .top-slider .slick-next:hover, .top-slider .slick-next:focus {
  width: 42px;
  height: 61px;
  background-image: url('/assets/web/images/job_details/right_arrow.png');
  right: calc((100% - 1040px) / 2 + 52px);
  text-align: right;
  z-index: 90;
}

.top-slider .slick-prev::before, .top-slider .slick-next::before {
  content: '';
}

@media only screen and (max-width: 1440px) {
  .top-slider .slick-prev, .top-slider .slick-prev:hover, .top-slider .slick-prev:focus {
      left: calc((100% - 1040px) / 2 + 52px);
  }

  .top-slider .slick-next, .top-slider .slick-next:hover, .top-slider .slick-next:focus {
      right: calc((100% - 1040px) / 2 + 52px);
  }
}

@media only screen and (max-width: 1000px) {
#banner{
      margin-top: 0;
  }
  .top-slider .slick-slide {
      width: 100%;
      box-sizing: border-box;
  }

  .top-slider .img-wrap{
      padding-bottom: 20px;
  }

  .slick-center {
      transform: none;
  }

}

@media only screen and (max-width: 767px) {
  #banner {
      margin: 10px 0;
  }
}

@media only screen and (min-width: 500px) {
  .slick-list{
      padding-top: 10px!important;
      padding-bottom: 10px!important;
  }
}

@media only screen and (max-width: 500px) {
  #banner {
      margin: 0;
  }

  .top-slider .img-wrap {
      padding: 0;
      margin-bottom: 10px;
  }

  .top-slider img{
      box-shadow: none;
  }
}

@media only screen and (max-width: 450px) {
  #page-top {
      display: none;
  }
}


/***************************
TAB AREA
****************************/
.tab_content_no_view {
  display: none;
}

/***************************
NAV MODAL AREA
****************************/
@media (max-width: 768px) {
  .nav-links-wrap .wrap:nth-child(1),
  .nav-links-wrap .wrap:nth-child(2) {
      margin-bottom: 10px;
  }
}

/***************************
BUTTON MODAL AREA
****************************/
.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 1000000;
}

.modal-bg {
  position: fixed;
  background: rgba(0, 0, 0, 0.7);
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
}

.modal-content {
  position: absolute;
  z-index: 3;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  width: 100%;
  max-width: 700px;
  border-radius: 10px;
  padding: 15px;
}

.modal-header {
  font-size: 25px;
  text-align: center;
  color: #000;
  padding: 35px 0 15px;
  border-bottom: 1px solid #707070;
  position: relative;
  font-weight: 500;
}

.modal-header-close {
  max-width: 25px;
  height: auto;
  position: absolute;
  top: 0;
  right: 0;
  margin: 0;
  cursor: pointer;
}

.modal-body {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin: 30px 0;
}

.modal-body-item {
  width: 50%;
  padding: 0 10px;
}

.modal .oubo_wrap {
  width: 100%;
  border: 0;
}

.modal-footer {
  text-align: center;
  padding-bottom: 30px;
  font-weight: normal;
}

.modal-footer-ttl {
  font-size: 16px;
}

.modal-footer-txt {
  font-size: 12px;
}

.no_view {
  display: none;
}

.pc-wrap {
  display: block;
}

.sp-wrap {
  display: none;
}

.fave_notice_off {
  display: none;
  position: absolute;
  width: 70%;
  font-size: 10px;
  text-align: center;
  background: #ccc;
  color: #666;
  margin: 10px 0;
  padding: 10px 5px;
  border-radius: 6px;
  line-height: 1em;
}

.fave_notice_off:after {
  content: "";
  position: absolute;
  top: -17px;
  left: 15%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-bottom: 10px solid #ccc;
}

.fave_notice_on { display: block; }

@media (max-width: 768px) {
  .sp-wrap {
      display: block;
  }

  .pc-wrap {
      display: none;
  }

  .fave_notice_off { width: 90px; right: -10px; z-index: 1000;}
  .fave_notice_off:after { left: 70%; }
}

.fave_btn_sp {
background-color: #FFF;
padding: 10px 10px 5px;
border-radius: 45px;
line-height: 12px;
}

.fave_btn_sp i {
  line-height: 32px;
}


@media only screen and (max-width: 1440px) {
  .top-slider .slick-prev, .top-slider .slick-prev:hover, .top-slider .slick-prev:focus {
      left: calc((100% - 1040px) / 2 + 52px);
  }

  .top-slider .slick-next, .top-slider .slick-next:hover, .top-slider .slick-next:focus {
      right: calc((100% - 1040px) / 2 + 52px);
  }

  .sticky-div {
      right: 20px;
  }
}

@media only screen and (max-width: 1000px) {
  #banner{
      margin-top: 0;
  }

  .top-slider .slick-slide {
      width: 100%;
      box-sizing: border-box;
  }

  .top-slider .img-wrap{
      padding-bottom: 20px;
  }

  .slick-center {
      transform: none;
  }

}

@media (max-width: 768px) {
  .sp-wrap {
      display: block;
  }

  .pc-wrap {
      display: none;
  }

  .fave_notice_off {
      width: 90px; right: -10px; z-index: 1000;
  }

  .fave_notice_off:after {
      left: 70%;
  }

  .nav-modal .nav-container {
      width: 100%;
      padding: 30px;
  }

  .nav-links-wrap .wrap:nth-child(1),
  .nav-links-wrap .wrap:nth-child(2) {
      margin-bottom: 10px;
  }

.nav-modal.logged-in .btn-wrap,
  .nav-modal .btn-wrap {
      margin-bottom: 10px;
  }

  #content_nav {
      top: 64px;
  }
}

@media only screen and (max-width: 767px) {
  .sp-only {
      display: block;
  }

  .pc-only {
      display: none;
  }

  section {
      padding: 20px 20px 30px;
  }

  h3 { font-size: 18px; }

  .c_ttl {
      margin: 20px 0px 10px;
      padding: 5px 10px;
      border-left: 6px solid #1d50a2;
  }

  #banner {
      margin: 10px 0;
  }

  .sp-only {
      display: block;
  }

  .pc-only {
      display: none;
  }

  section {
      padding: 20px 20px 30px;
  }

  h3 { font-size: 18px; }

  .c_ttl {
      margin: 20px 0 10px;
      padding: 5px 10px;
      border-left: 6px solid #1d50a2;
  }

  .top_box_con {
      padding: 20px;
  }

  main { font-size: 14px; }

  #content_nav ul {
      justify-content: center;
      gap: 20px;
      font-size: 13px;
  }

  #content_nav ul a {
      border-bottom: 2px solid transparent;
  }

  #content_nav ul a:hover {
      border-bottom: 2px solid #32BEFC;
  }

  #content_nav ul a.active {
      border-bottom: 2px solid #3ebffc;
  }

  .mid_box {
      margin-bottom: 30px;
  }

  .mid_box_ttl {
      padding: 5px 20px;
  }

  .mid_box_content {
      padding: 10px 20px;
  }

  .recommend_content {
      display: block;
  }

  .recommend_content>div {
      width: 100%;
      margin-top: 10px;
  }

  .breadcrumbs {
      margin-bottom: 5px;
line-height: 1em;
      padding: 0px 10px;
  }

  .breadcrumbs a {
      font-size: 10px;
  }

  .sticky-div {
      width: 100%;
      padding: 20px 10px;
      bottom: 0!important;
      top: auto!important;
      left: 0;
      background-color: rgba(192, 192, 192, 0.3);
      height: 80px;
      display: flex;
      -webkit-flex-wrap: wrap;
      flex-wrap: wrap;
      padding-right: 60px;
      gap: 10px;
  }

  .sticky-icon {
      position: fixed;
      color: rgba(192, 192, 192, 0.5);
      z-index: 10;
      right: 3%;
      bottom: 100px;
      cursor: pointer;
  }

  .sticky_btn {
      width: calc(50% - 5px);
  }

  .sticky_btn.bg-light-yellow {
      width: 100%;
  }

  .call-btn {
      width: 180px;
      padding: 15px 20px;
      margin: 0px 5px;
      display: block;
  }

  .sticky_btn2 {
      display:none;
  }

  .sticky-div a {
      text-decoration: none;
      width: calc(50% - 5px);
  }

  .sticky-div a.sticky_btn {
      width: 100%;
  }

  .sticky-div .hellowork_alert{
    top: 0;
    height:20px;
    padding: 2px 0;
  }

  .sticky-div .hellowork_job_detail_wrap{
    margin-top: -5px;
  }

  .sticky-div .hellowork_job_detail_wrap .d-flex{
    line-height: 1.7;
  }

  .sticky-div .hellowork_job_detail_wrap button{
    margin-top: -10px;
  }

  .sticky-div .hellowork_job_detail_wrap button.bg-color-not_login{
    margin-top: 18px;
    padding: 8px 0;
  }

  .sticky-div .hellowork_alert .br-767{
    display: none;
  }

  .djob_button .sticky_btn{
      width:100%;
  }

  .djob_button{
      width:100% !important;
  }

/* 20240619 */
table.de-job-tbl tr {
  display: flex;
  flex-direction: column;
}
table.de-job-tbl th {
  width: 100%;
}
.accordion-title.js-accordion-title {
  font-size: 18px;
}
.c_box__body {
  padding: 5px 10px !important;
}

footer.aplly_footer {
  padding-bottom: 0;
}
}

@media only screen and (min-width: 500px) {
  .slick-list{
      padding-top: 10px!important;
      padding-bottom: 10px!important;
  }
}

@media only screen and (max-width: 500px) {
  #banner {
      margin: 0;
  }

  .top-slider .img-wrap {
      padding: 0;
      margin-bottom: 10px;
  }

  .top-slider img{
      box-shadow: none;
  }
}

@media only screen and (max-width: 450px) {
  .c_ttl {
      margin: 20px 0px 10px;
      padding: 5px 10px;
      border-left: 6px solid #1d50a2;
      font-size: 16px;
  }

  #page-top {
      display: none;
  }
}

.staff_wrap .staff_name {
  font-size: 14px;
}

.staff_wrap .comment_box {
  font-size: 14px;
  background-color: #F3F3F3;
  border-radius: 14px;
  padding: 30px;
}

.staff_wrap .job_staff_comment .job_staff_comment_box {
  display: flex;
  gap: 4%;
}

.staff_wrap .job_staff_comment_box .image_box {
  width: 26%;
}

.staff_wrap .job_staff_comment_box .comment_box {
  width: 70%;
}

.staff_wrap .comment_box .balloon {
  font-size: 16px;
}

.staff_wrap .image_box .staff_name {
  position: absolute;
}

.staff_wrap .job_staff_comment_box {
  margin-bottom: 30px;
}

@media (max-width: 428px) {
  .video_wrap .embed-responsive {
      width: calc(100% + 40px);
      margin-left: -20px;
  }

  .embed-responsive-16by9 { padding-bottom: 63.25%; }

  .staff_wrap .comment_box .balloon {
      font-size: 13px;
  }

  .staff_wrap .staff_name {
      font-size: 12px;
  }
}

@media (max-width: 375px) {
  .embed-responsive-16by9 { padding-bottom: 63.80%; }
}

.job_republish_request_button_wrap button{
  border:none;
}

.division_jobs_container {
  background-color: #fff;
  padding-bottom: 45px;
  border-radius: 13px;
  margin-top: 50px;
  padding: 0;
}

.division_jobs_container .item {
  padding: 0 50px;
}

.division_jobs_container .item:last-child {
  padding-bottom: 20px;
}

.division_jobs_container hr {
  margin-left: 50px;
  margin-right: 50px;
}

.d-flex {
  display: flex;
}

.j-c-center {
  justify-content: center;
}

.flex-1 {
  flex: 1;
}

.pos-rel {
  position: relative;
}

.pos-abs {
  position: absolute;
}

.gap-20 {
  gap: 20px;
}

.division_jobs_container .item-content img {
  width: 100%;
  height: auto;
}

.division_jobs_container .item-content .description {
  margin-top: 10px;
  margin-bottom: 17px;
  font-size: 15px;
  line-height: 22px;
}

.division_jobs_container .item-content .item-description-wrap .occupation i,
.division_jobs_container .item-content .item-description-wrap .location i,
.division_jobs_container .item-content .item-description-wrap .salary i {
  background-color: #eee;
  font-size: 15px;
  padding: 8px 3px;
  border-radius: 50px;
  color: #1f51a2;
  border: 1px solid #fff;
  width: 30px;
  height: 30px;
  text-align: center;
  display: inline-block;
  position: absolute;
  left: 0;
  top: 2px;
}

.division_jobs_container .item-content .item-description-wrap .occupation,
.division_jobs_container .item-content .item-description-wrap .location,
.division_jobs_container .item-content .item-description-wrap .salary {
  font-weight: 500;
  font-size: 16px;
  color: #666666;
  position: relative;
  padding-left: 35px;
  margin-bottom: 10px;
}

.division_jobs_container .item .item-content .item-description-wrap .occupation {
  color: #32befc;
}

.text-blue {
  color: #1f51a2;
}

.text-white {
  color: #fff;
}

.w-100 {
  width: 100%;
}

.border-rad-4 {
  border-radius: 4px; 
}

.item-description-wrap .item-detail .btn-wrap button {
  width: 196px;
  height: 54px;
}

.item-description-wrap .item-detail button {
  font-size: 17px;
  background: transparent linear-gradient(90deg, #32BEFC 0%, #84D9FF 100%) 0% 0% no-repeat padding-box;
  border: none;
}

.item-description-wrap .item-detail button.disabled-link {
  background: #ABB6C6;
  text-decoration: none;
  cursor: not-allowed;
  pointer-events: none;
}

.p-15 {
  padding: 15px;
}

/* .fukidashi_on, .fukidashi_out {
  display: none;
  position: absolute;
  z-index: 100;
} */

.fukidashi_on, .fukidashi_out {
  position: absolute;
  z-index: 100;
  display: none;
  font-size: 10px;
  text-align: center;
  background: #ccc;
  margin: 10px 0;
  padding: 10px 5px;
  border-radius: 6px;
  line-height: 1em;
  width: 100px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, 40%);
}

.fukidashi_on:after, .fukidashi_out:after {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-bottom: 10px solid #ccc;
}

.font-s-large {
  font-size: 30px;
}

.division_jobs_container .item-description-wrap .heart-wrap {
  bottom: -10px;
  right: 0;
}

.heart .keep_btn1 {
  color: #ccc;
  line-height: 32px;
}

.truncated-4 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

main .modal-favorite_action p {
  margin-bottom: 0;
}

.division_jobs_container .item-description-wrap .heart-wrap .keep_on .fa-heart:before {
  color: #ff817a;
}

/* 2024-06-18 追加分 */
.mgn_btm__40 {
margin-bottom: 40px;
}
table.de-job-tbl,
table.de-job-tbl th,
table.de-job-tbl td {
border: 1px solid #e3e3e3;
padding: 3px 15px;
}

table.de-job-tbl {
width: 100%;
margin: 20px 0;
}

table.de-job-tbl th {
width: 150px;
background: #e3efff;
color: #2253a3;
}

.oubo_box__top {
border: 1px solid #32BEFC;
border-radius: 4px;
}

.accordion-content { display: none; }

.max-850 {
width: 100%;
max-width: 850px;
margin: 0 auto;
}

.note {
padding: 10px 20px;
}

.user-profile-wrap {
margin-bottom: 20px;
}

.user-profile-data.accordion-content {
border: 2px solid #1f51a2;
border-top: none;
padding: 20px;
background: #fff;
border-radius: 0 0 6px 6px;
}

.accordion-title.js-accordion-title {
padding: 10px 20px;
background: #1f51a2;
color: #fff;
border-radius: 4px;
font-size: 23px;
position:relative;
cursor: pointer;
box-shadow: 0px 3px 9px rgb(42 82 161 / 30%);
}

.accordion-title.js-accordion-title.open {
border-radius: 4px 4px 0 0;
box-shadow:none;
}

.accordion-title::after {
content: "";
position: absolute;
border-right: solid 3px #fff;
border-top: solid 3px #fff;
display: block;
height: 14px;
width: 14px;
right: 25px;
top: 38%;
transform: rotate(135deg);
transition: transform .3s ease-in-out, top .3s ease-in-out;
}
.accordion-title.open::after {
top: 45%;
transform: rotate(-45deg);
}

.user-profile-data.accordion-content .c_box__item {
border: 1px solid #e5e5e5;
}

.check-disabled {
color: #afafaf;
}

footer.aplly_footer {
text-align: center !important;
}

/* すべてのcssのbodyに入れても問題ないかと思います。footerが浮いてしまう場合、この方が調整しやすいかと思います。*/
body {
display: flex;
flex-direction: column;
overflow-x: hidden;
}

footer {
margin-top:auto;
}
/* 個人情報取扱同意書の部分です。共通化させる方が分かりやすいかと思います。*/
input[type=checkbox]#agree {
display: inline !important;
margin-right: 5px;
}
.sbt-reg-btn {
width: 370px;
max-width: 100%;
height: 50px;
background: transparent linear-gradient(90deg, #32BEFC 0%, #84D9FF 100%) 0% 0% no-repeat padding-box;
border: none;
font-weight: 500;
padding: 13px 11px;
color: #FFF;
margin: 20px auto 10px;
}

.sbt-reg-btn:disabled {
background: #ccc;
}

/* 応募完了画面 */
.complete_wrap {
max-width: 600px;
background: #fff;
margin: 0 auto 30px;
padding: 30px 20px 50px;
border-radius: 4px;
}
.complete_ttl {
text-align: center;
font-size: 16px;
}
.complete_img {
font-size: 102px;
text-align: center;
line-height: 1em;
color: #32BEFC;
margin-bottom: 30px;
}
.complete_note {
text-align: center;
}
.complete_text {
padding: 30px 0 0;
}
.complete_text p {
margin-bottom: 0;
}
.complete_text address {
margin-bottom: 30px;
}
.complete_btn_wrap {
display: flex;
flex-direction: column;
}
.complete_btn_wrap a {
display: flex;
width: 100%;
align-items: center;
justify-content: center;
margin: 0;
}
.complete_btn_wrap a:first-child {
margin-bottom: 30px;
}

/* 20241225 非会員応募form */
.select {
  width: 110px;
  height: 40px;
  background: #F6F6F6;
  border: none;
  border-radius: 4px;
  padding: 0 10px;
  appearance: none;
  outline: none;
  cursor: pointer;
  color: #666666;
  position: relative;
}

select#birth_year,select#birth_month,select#birth_day {
  width: 110px;
}

button#zip_button {
  border: 1px solid #ccc;
  margin-left: .5em;
  padding: 10px 15px;
  border-radius: 6px;
}



@media (max-width: 767px) {
/* 20240619 */
table.de-job-tbl {
  width: 100%;
  margin: 10px 0;
}
table.de-job-tbl tr {
  display: flex;
  flex-direction: column;
}
table.de-job-tbl th {
  width: 100%;
}
.accordion-title.js-accordion-title {
  font-size: 18px;
}
.user-profile-data.accordion-content {
  padding: 10px;
}
.c_box__body {
  padding: 5px 10px !important;
}

footer.aplly_footer {
  padding-bottom: 0;
}
  .main_sub {
      padding: 10px !important;
}
.mgn_btm__40 {
  margin-bottom: 20px;
}
.complete_wrap {
  padding: 15px 10px 30px;
}

.staff_wrap .comment_box {
  background-color: transparent;
}

.job_staff_comment_box .comment_box .balloon {
  width:100%;
}

.staff_wrap .job_staff_comment .job_staff_comment_box {
  flex-direction: column;
}
.staff_wrap .job_staff_comment_box .image_box {
  width: 50%;
  max-width: 150px;
}
.staff_wrap .job_staff_comment_box .comment_box {
  width: 100%;
  padding: 30px 0;
}
.job_staff_comment_box .comment_box .balloon:after {
  bottom: inherit;
  top: -15px;
  left: 20%;
  -webkit-transform: rotate(70deg);
  transform: rotate(70deg);
}
}

@media (max-width: 500px) {
  .division_jobs_container .item .item-content .item-img.flex-1 {
      margin: 0 0 15px 0;
  }

  .pos-rel .btn-rows button{
      border-radius: 7px;
  }

  .pos-rel .item-categories.d-flex {
      display: block;
  }

  .pos-rel .item-content.d-flex {
      flex-direction: column;
      margin-bottom: 0;
      gap: 0;
  }

  .division_jobs_container .item {
      padding: 0 20px;
  }

  .division_jobs_container hr {
      margin-left: 20px;
      margin-right: 20px;
  }

  .item-description-wrap .item-detail .btn-wrap button {
      width: 80%;
      height: 50px;
  }

  .division_jobs_container .item-description-wrap .btn-row-2 {
      display: block;
  }

  .division_jobs_container .item-description-wrap .heart-wrap {
      bottom: -2px;
  }

  .division_jobs_container .item-content .item-description-wrap .occupation,
  .division_jobs_container .item-content .item-description-wrap .location,
  .division_jobs_container .item-content .item-description-wrap .salary {
      margin-bottom: 0;
  }

  .division_jobs_container .item-content .description {
      font-size: 14px;
  }

  .division_jobs_container .c_ttl {
      font-size: 18px;
  }

  .item-description-wrap .item-detail button {
      font-size: 16px;
  }
}

/* 新着求人 レコメンド 20241220 suzuki */
.py-50 {
padding: 50px 0;
}

@media only screen and (min-width: 1200px) {
.new-jobs-wrap .container {
    max-width: 1200px;
    width: 100%;
}
}

@media only screen and (max-width: 500px) {
.new-jobs-label {
  height: 50px;
}
.new-jobs-label .section-label {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.42857143
}
.section-title {
  font-size: 18px;
}

.new-jobs-label .text-light-yellow {
  font-size: 18px;
  font-weight: 500;
}
.section-title {
    line-height: 27px;
}
}

/* Top new jobs */
.new-jobs-wrap {
width:100vw;
width: 100cqw;
margin: 0 calc(50% - 50vw);
padding-bottom: 50px;
}
.new-jobs-wrap > div:first-child{
margin-bottom: 20px;
}

.new-jobs-wrap .img-wrap {
height: 190px;
}

.new-jobs-wrap .img-wrap img {
width: 100%;
height: 100%;
object-fit: cover;
}

.new-jobs-slider .inner-wrap {
width: 300px;
margin: 0px 10px 10px;
align-items: stretch;
display: flex;
}

.new-jobs-slider mark {
background-color: #e3efff;
display: inline-block;
margin: 1px;
font-size: 14px;
font-weight: normal;
}

.new-jobs-slider .category {
font-size: 10px;
flex-wrap: wrap;
gap: 2px;
}

.new-jobs-wrap .slick-c-controls .wrap {
display: flex;
justify-content: center;
align-items: center;
}

.new-jobs-wrap .slick-c-controls .wrap .slick-arrow {
color: #4a75bb;
-webkit-text-stroke: 1px #4a75bb;
margin: 0;
position: unset;
font-weight: 500;
font-size: 36px;
padding: 0;
}

.new-jobs-wrap .slick-c-controls .wrap .slick-dots {
position: unset;
line-height: 0px;
}

.new-jobs-wrap .slick-c-controls .wrap .slick-dots li button::before {
line-height: 26px;
font-size: 13px;
}

.new-jobs-slider.slick-dotted {
margin-bottom: 0;
}

.new-jobs-wrap .company-names {
margin-top: 10px;
background-color: #fff;
display: flex;
justify-content: space-between;
text-align: left;
}

.new-jobs-wrap .company-names .btn-wrap {
display: flex;
justify-content: flex-end;
align-items: flex-end;
}

.new-jobs-wrap .company-names .btn-wrap button {
width: 245px;
font-size: 16px;
line-height: 22px;
font-weight: 500;
background: linear-gradient(to right, #32befc, #84d9ff);
}

.new-jobs-wrap .company-names > p {
padding: 5px;
}

.new-jobs-wrap .company-names > div {
padding: 23px;
font-size: 19px;
line-height: 32px;
/* below is used for truncating in a flexbox */
min-width: 0;
}

.new-jobs-wrap .company-names > div p {
margin-bottom: 10px;
line-height: 1.2;
}

.new-jobs-wrap .company-names > div p a {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
display: block;
}

.new-jobs-info .description.truncated {
width: 100%;
overflow: hidden;
text-overflow: ellipsis;
vertical-align: top;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
display: -webkit-box;
font-size: 16px;
line-height: 25px;
}

.new-jobs-info .description.truncated a {
color: #1F51A2;
}

.new-jobs-label {
height: 70px;
display: flex;
align-items: center;
font-weight: 500;
width:100vw;
width: 100cqw;
margin: 0 calc(50% - 50vw);
font-size: 28px;
line-height: 1.42857143;
}


.box-shadow-blue-s {
  box-shadow: 0 3px 6px rgb(31 81 162 / 0.15);
}

/* Make slick slides have the same height */
.new-jobs-wrap .slick-track
{
display: flex !important;
}

.new-jobs-wrap .slick-slide
{
height: auto !important;
}
/* End make slides have the same height */

.heart {
  bottom: 5px;
  right: 5px;
  background-color: #fff;
  font-size: 27px;
  padding: 0px 5px 0px 5px;
  border-radius: 50px;
  border: 1px solid #fff;
  position: absolute;
  line-height: 1em;
}

.new-jobs-slider .inner-wrap.bg-color-white {
  background: none;
}

.rec-wrap .heart .keep_on .fa-heart:before,
.new-jobs-wrap .heart .keep_on .fa-heart:before {
  color: #ff817a;
}

@media only screen and (max-width: 1450px) {
  .new-jobs-wrap .company-names {
    margin: 0;
  }

  .new-jobs-label .container,
  .new-jobs-wrap .container {
    max-width: 1200px;
    width: 100%;
  }
}

@media only screen and (max-width: 1000px) {
  .new-jobs-wrap .company-names {
    margin: 15px;
    margin-top: 20px;
  }

  .new-jobs-wrap .company-names > div {
    padding: 20px 15px;
  }

  .new-jobs-wrap .company-names .btn-wrap button {
    width: 100%;
  }

  .new-jobs-wrap .slick-c-controls .wrap {
    color: #4a75bb;
    -webkit-text-stroke: 1px #4a75bb;
    margin: 0;
    position: unset;
    font-weight: 500;
    font-size: 30px;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  button.slick-c-prev, button.slick-c-next {
    border: none;
    background: none;
  }

  .new-jobs-wrap .company-names > div p a {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    color: #1f51a2;
    font-size: 14px;
}
}

@media only screen and (max-width: 767px) {
  .new-jobs-label .container {
    margin: 0;
    text-align: left;
  }
  .new-jobs-wrap .company-names .btn-wrap a {
    width: 100%;
    text-align: center;
  }

  .new-jobs-wrap .company-names .w-100 {
    width: 50%;
  }

  .top .new-jobs-wrap .company-names .w-100.btn-wrap {
    width: 100%;
        align-items: center;
        justify-content: center;
  }
  .new-jobs-wrap .company-names .btn-wrap a {
    width: 100%;
    text-align: center;
  }

  .new-jobs-wrap .company-names {
    flex-wrap:wrap;
  }
  .new-jobs-wrap .company-names .btn-wrap button {
    width: 290px;
  }
}

@media only screen and (max-width: 428px) {
  .new-jobs-wrap .slick-c-controls .slick-c-prev,
  .new-jobs-wrap .slick-c-controls .slick-c-next {
    display: none;
  }

  .new-jobs-wrap .company-names {
    flex-direction: column;
    margin-top: 10px;
  }

  .new-jobs-wrap .company-names > p {
    padding: 0;
  }

  .new-jobs-wrap .company-names {
    padding: 20px;
  }

  .new-jobs-wrap .company-names .btn-wrap button {
    width: 100%;
    margin-top: 10px;
  }

  .new-jobs-slider .inner-wrap {
    width: 260px;
  }

  .new-jobs-wrap .company-names > div {
    padding: 0;
    font-size: 14px;
  }

  .new-jobs-wrap .company-names .btn-wrap {
    justify-content: center;
    align-items: center;
  }

  .new-jobs-wrap.py-50 {
    padding: 25px 0;
  }

  .new-jobs-wrap .company-names .w-100 {
    width: 100%;
  }
}

@media screen and (max-width: 480px) {
  .job_staff_comment_box .comment_box .balloon:after {
      bottom: inherit;
      top: -15px;
      left: 20%;
      -webkit-transform: rotate(70deg);
      transform: rotate(70deg);
  }
}
/* End top new jobs */