/* --- 背景とオーバーレイ --- */
.bg-recruit, .recruit-hero {
    position: relative;
    height: 80vh;
    min-height: 260px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }
  .recruit-bg {
    position: absolute;
    inset: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    background: url('image/recruit-bg.png') center/cover no-repeat;
    pointer-events: none;
  }
  .recruit-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    display: block;
    background: rgba(213, 130, 30, 0.59); /* 超薄いオレンジオーバーレイ */
    z-index: 2;
    pointer-events: none;
  }
  
  /* --- 中央テキスト --- */
  .recruit-hero-inner {
    position: relative;
    z-index: 3;
    text-align: center;
    color: #fff;
    width: 100%;
    max-width: 700px;
    margin: 0 auto;
  }
  .recruit-hero-inner h1 {
    font-size: 2.6rem;
    font-weight: bold;
    margin-bottom: 1.3rem;
    letter-spacing: 0.08em;
    text-shadow: 0 4px 18px rgba(0,0,0,0.22);
  }
  .recruit-hero-inner p {
    font-size: 1.22rem;
    letter-spacing: 0.04em;
    line-height: 2;
    margin: 0 auto;
    background: rgba(0,0,0,0.13);
    border-radius: 1.2em;
    padding: 0.45em 1.2em;
    display: inline-block;
    box-shadow: 0 2px 18px rgba(255,180,100,0.08);
  }
  
  /* スマホ対応 */
  @media (max-width: 700px) {
    .bg-recruit, .recruit-hero { height: 28vh; min-height: 120px;}
    .recruit-hero-inner h1 { font-size: 1.42rem; }
    .recruit-hero-inner p { font-size: 0.98rem; }
  }
/*
.recruit-highlights { background: #f6fbff; padding: 3rem 1.2rem;}
.highlight-cards {
  display: flex; gap: 2rem; max-width: 1080px; margin: 0 auto; flex-wrap: wrap; justify-content: center;
}
.highlight-card {
  background: #fff; border-radius: 1.2em; box-shadow: 0 2px 16px rgba(0,85,180,0.07);
  flex: 1 1 280px; min-width: 240px; max-width: 340px; padding: 2rem 1.2rem;
  text-align: center; transition: box-shadow .25s;
}
.highlight-card:hover { box-shadow: 0 6px 28px rgba(0,85,180,0.17);}
.highlight-card img { width: 66px; margin-bottom: 1.2em;}
.highlight-card h3 { color: #0072c9; margin-bottom: 0.5em;}
.highlight-card p { color: #444; font-size: 1.05em;}

.recruit-jobs { background: #fff; padding: 3rem 1.2rem; }
.job-cards {
  display: flex; gap: 2rem; flex-wrap: wrap; max-width: 1080px; margin: 0 auto; justify-content: center;
}
.job-card {
  background: #f2f6fa; border-radius: 1em; padding: 2rem 1.2rem; flex: 1 1 260px;
  min-width: 220px; max-width: 340px; box-shadow: 0 2px 14px rgba(0,85,180,0.06);
  text-align: center; position: relative; transition: box-shadow .25s;
}
.job-card:hover { box-shadow: 0 4px 28px rgba(0,85,180,0.16);}
.job-card h3 { color: #004c94; margin-bottom: 0.7em;}
.job-status.closed { display: block; color: #c0c0c0; font-size: 0.98em; margin-top: 0.7em; }
*/
.recruit-catch {
    display: flex;
    flex-direction: column;
    gap: 1.3em;
    background: #fff;
    border-radius: 1.5em;
    box-shadow: 0 2px 14px rgba(200,100,0,0.08);
    max-width: 620px;
    margin: -2.2em auto 2.2em auto;
    padding: 2em 1.2em;
    position: relative;
    z-index: 5;
  }
  .catch-row {
    display: flex;
    align-items: center;
    gap: 1em;
    font-size: 1.13rem;
    font-weight: 500;
    color: #874f0e;
  }
  .catch-icon { width: 100px; height: 100px;}
  @media (max-width: 600px) {
    .recruit-catch { padding: 1.2em 0.5em;}
    .catch-row { font-size: 1.0rem; }
  }

  .recruit-positions { margin: 3.5em auto; max-width: 960px; display: flex; flex-direction: column; gap: 2.8em;}
.recruit-row {
  display: flex;
  gap: 2.2em;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 1.6em;
  box-shadow: 0 2px 18px rgba(213,130,30,0.06);
  padding: 1.7em 1.2em;
}
.recruit-row.reverse { flex-direction: row-reverse;}
.recruit-img img {
  width: 180px; height: 140px; object-fit: cover; border-radius: 1.1em; box-shadow: 0 2px 12px rgba(210,120,10,0.12);
}
.recruit-desc { flex: 1; }
.recruit-desc h2 { margin: 0 0 0.7em 0; font-size: 1.3rem; color: #e67c04;}
.recruit-desc p { font-size: 1.08rem; color: #222;}
.job-status.closed { display: block; color: #b9b9b9; font-size: 0.95em; margin-top: 0.7em; }
@media (max-width: 850px) {
  .recruit-row, .recruit-row.reverse { flex-direction: column; gap: 1.1em; text-align: center;}
  .recruit-img img { width: 98vw; max-width: 370px; height: auto;}
}

.recruit-jobs {
    width: 100vw;
    max-width: 100%;
    margin: 0;
    padding: 0;
    background: #fafdff;
  }
  
  .recruit-job-row {
    display: flex;
    align-items: stretch;
    width: 100%;
    min-height: 320px;
    margin-bottom: 3rem;
    background: #fff;
    /*border-radius: 20px;*/
    box-shadow: 0 4px 18px rgba(190,190,200,0.08);
    overflow: hidden;
  }
  
  .recruit-job-row.reverse {
    flex-direction: row-reverse;
  }
  
  .recruit-job-img {
    width: 50%;
    min-width: 50%;
    background: #f3f5f8;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .recruit-job-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 4/3;
    min-height: 240px;
  }
  
  .recruit-job-desc {
    width: 50%;
    /*min-width: 50%;*/
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 3rem 2.5rem;
    color: #222;
    font-size: 1.2rem;
  }
  .recruit-job-desc h3 {
    font-size: 1.45rem;
    font-weight: bold;
    color: #ee9000;
    margin-bottom: 1rem;
  }
  .recruit-job-note {
    color: #aaa;
    font-size: 0.95em;
    display: block;
    margin-top: 0.8em;
  }
  
  @media (max-width: 900px) {
    .recruit-job-row, .recruit-job-row.reverse {
      flex-direction: column !important;
      min-height: 0;
      margin-bottom: 2rem;
      border-radius: 10px;
    }
    .recruit-job-img,
    .recruit-job-desc {
      width: 100%;
      min-width: 100%;
      padding: 0;
    }
    .recruit-job-img img {
      aspect-ratio: 16/9;
      min-height: 150px;
    }
    .recruit-job-desc {
      padding: 2rem 1.2rem;
      font-size: 1.06rem;
    }
  }