/* ========================================================================
   募集要項（recruitment.php）
   - PC: --u = 100vw/1920 を寸法の基準単位に使用
   - SP(≤768px): ラベル上・本文下に積み替え
   ======================================================================== */

.p-recruitment {
  --u: calc(100vw / 1920);
  overflow: clip;
  background: #fff;
  padding-bottom: calc(var(--u) * 150);
}

/* このページはヘッダー直下が水色の帯のため、ヘッダー下端の小さな白波装飾を消す
   （帯側の大きなうねり1本に統一） */
.page-recruitment .l-header::after {
  display: none;
}

/* ============================================================
   タイトル帯 — 帯ベタ・上端さざ波・下端の濃淡2層の波をSVG1枚で描画
   ============================================================ */
.p-recruitment-hero {
  position: relative;
  height: calc(var(--u) * 466);
  padding: calc(7.109vw + 40px) 16px 0;   /* 旧固定ヘッダー(高さ7.109vw)に被らない位置までタイトルを下げる */
  background: url("../../images/recruitment/band-pc.svg") no-repeat top center / 100% 100%;
  text-align: center;
}
.p-recruitment-hero-heading {
  margin: 0;
  line-height: 1;
}
.p-recruitment-hero-en {
  display: block;
  font-family: "Archivo Black", "Noto Sans JP", sans-serif;
  font-size: max(30px, calc(var(--u) * 81));
  letter-spacing: 0.02em;
  color: transparent;
  -webkit-text-stroke: 2px #4dd4da;         /* シアンの縁取り（白ではない） */
}
.p-recruitment-hero-jp {
  display: block;
  margin-top: calc(var(--u) * 10);
  transform: translateX(calc(var(--u) * 213));   /* 中央より右寄り */
  color: #4dd4da;
  font-size: max(15px, calc(var(--u) * 39));
  font-weight: 700;
}

/* ============================================================
   水滴（帯の下・左寄り）
   ============================================================ */
.p-recruitment-drops {
  display: block;
  position: relative;
  height: 0;
  pointer-events: none;
}
.p-recruitment-drop-l {
  position: absolute;
  top: calc(var(--u) * -52);   /* 帯の淡い波尾に少し重なる */
  left: calc(var(--u) * 165);
  width: calc(var(--u) * 64);
  aspect-ratio: 55.171 / 94.198;   /* SVG は preserveAspectRatio=none のため比率を明示 */
}
.p-recruitment-drop-s {
  position: absolute;
  top: calc(var(--u) * -60);
  left: calc(var(--u) * 248);
  width: calc(var(--u) * 42);
  opacity: 0.85;
  transform: rotate(40deg);
}

/* ============================================================
   本文（タイトル＋カード）
   ============================================================ */
.p-recruitment-main {
  width: min(calc(var(--u) * 1375), calc(100% - 32px));
  margin: 0 auto;
}
.p-recruitment-title {
  margin: calc(var(--u) * 77) 0 calc(var(--u) * 105);
  color: var(--color-blue);
  font-size: max(16px, calc(var(--u) * 33));
  font-weight: 700;
  text-align: center;
  line-height: 1;
}

/* カード（角丸の枠。表＋ENTRYを内包） */
.p-recruitment-card {
  padding: calc(var(--u) * 100) calc(var(--u) * 114) calc(var(--u) * 114);
  border: 2px solid var(--color-wave);
  border-radius: calc(var(--u) * 42);
  background: #fff;
}
.p-recruitment-table {
  margin: 0;
}
.p-recruitment-row {
  display: grid;
  grid-template-columns: calc(var(--u) * 240) 1fr;  /* ラベル列（短い見出しに合わせ本文幅を確保し1行に収める） */
  align-items: start;
  padding: calc(var(--u) * 52) 0 calc(var(--u) * 52) calc(var(--u) * 90);
}
.p-recruitment-row:first-child {
  padding-top: 0;
}
.p-recruitment-row:last-child {
  padding-bottom: 0;
}
.p-recruitment-row + .p-recruitment-row {
  border-top: 1px solid var(--color-blue);
}
.p-recruitment-label {
  color: var(--color-blue);
  font-size: max(14px, calc(var(--u) * 27));
  font-weight: 700;
  line-height: 1.625;
}
.p-recruitment-body {
  margin: 0;
  color: #000;
  font-size: max(13px, calc(var(--u) * 24));
  font-weight: 400;
  line-height: 1.625;
}

/* 採用資料などの別タブリンク */
.p-recruitment-link {
  color: var(--color-blue);
  text-decoration: underline;
  text-underline-offset: 0.15em;
  transition: opacity 0.2s;
}
@media (hover: hover) and (pointer: fine) {
  .p-recruitment-link:hover {
    opacity: 0.7;
  }
}

/* ENTRY（紺の水しぶき形ブロブ・カード内） */
.p-recruitment-entry-wrap {
  margin: calc(var(--u) * 160) 0 0;
  text-align: center;
}
.p-recruitment-entry {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: calc(var(--u) * 390);
  height: calc(var(--u) * 174);
  background: url("../../images/recruitment/entry-blob.svg") no-repeat center / 100% 100%;
  color: #fff;
  font-family: Arial, "Noto Sans JP", sans-serif;
  font-style: italic;
  font-size: max(18px, calc(var(--u) * 66));
  font-weight: 700;
  letter-spacing: 0.047em;
  text-decoration: none;
  transition: transform 0.2s;
}
@media (hover: hover) and (pointer: fine) {
  .p-recruitment-entry:hover {
    transform: scale(1.05);
  }
}
.p-recruitment-entry:focus-visible {
  transform: scale(1.05);
}

/* ============================================================
   SP（≤768px）: ラベル上・本文下に積み替え
   ============================================================ */
@media (max-width: 768px) {
  .p-recruitment {
    padding-bottom: 64px;
  }
  .p-recruitment-hero {
    height: 230px;
    padding: 95px 16px 0;   /* 旧固定ヘッダー(高さ71px)に被らない位置まで下げる */
  }
  .p-recruitment-hero-en {
    font-size: 30px;
    -webkit-text-stroke-width: 1.4px;
  }
  .p-recruitment-hero-jp {
    margin-top: 6px;
    transform: translateX(72px);
    font-size: 16px;
  }

  .p-recruitment-drop-l {
    top: -18px;
    left: 24px;
    width: 26px;
  }
  .p-recruitment-drop-s {
    top: -22px;
    left: 58px;
    width: 17px;
  }

  .p-recruitment-main {
    width: calc(100% - 32px);
  }
  .p-recruitment-title {
    margin: 56px 0 28px;
    font-size: 16px;
  }

  .p-recruitment-card {
    padding: 28px 20px 36px;
    border-radius: 16px;
  }
  .p-recruitment-row {
    grid-template-columns: 1fr;             /* ラベル上・本文下に積む */
    padding: 22px 0;
  }
  .p-recruitment-label {
    margin-bottom: 6px;
    font-size: 14px;
  }
  .p-recruitment-body {
    font-size: 14px;
    line-height: 1.7;
  }

  .p-recruitment-entry-wrap {
    margin-top: 40px;
  }
  .p-recruitment-entry {
    width: 170px;
    height: 75px;
    font-size: 24px;
  }
}
