/* ====================================
   Recruitページ専用スタイル
==================================== */
.sub-hero{
  position:relative;z-index:2;
  padding:200px 0 140px;
  min-height:600px;
  display:flex;align-items:center;
  background-color:var(--bg-deep);
  border-bottom:1px solid var(--line-soft);
  overflow:hidden;
}
.sub-hero-bg{
  position:absolute;inset:0;z-index:0;
  background-color:var(--bg-deep);
  overflow:hidden;
}
/* ヒーロー背景：白手袋で時計を扱う鑑定スタッフの画像 */
.sub-hero-bg::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    /* テキスト可読性のためのダークオーバーレイ */
    linear-gradient(180deg, rgba(10,8,7,.65) 0%, rgba(10,8,7,.5) 40%, rgba(10,8,7,.75) 100%),
    /* 中央放射状のビネットで主役を明確に */
    radial-gradient(ellipse at center, transparent 30%, rgba(10,8,7,.5) 80%),
    /* 元画像 */
    url("../images/hero-recruit.jpg") center/cover no-repeat;
  filter:saturate(.65) contrast(1.05) brightness(.88) sepia(.18);
}
.sub-hero-bg::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:
    /* 金色のスポットライト効果 */
    radial-gradient(ellipse at 50% 40%, rgba(201,164,92,.22), transparent 55%),
    /* 下部のフェード */
    linear-gradient(180deg, transparent 0%, transparent 50%, rgba(10,8,7,.45) 100%);
  pointer-events:none;
}
.sub-hero-inner{position:relative;z-index:2;text-align:center;max-width:880px;margin:0 auto}
.sub-hero-eyebrow{
  font-family:var(--serif-en);
  font-size:13px;letter-spacing:.4em;
  color:var(--gold);
  margin-bottom:24px;
  text-transform:uppercase;
}
.sub-hero h1{
  font-family:var(--serif);
  font-size:clamp(36px, 5vw, 60px);
  font-weight:700;line-height:1.3;
  margin-bottom:28px;
  color:var(--ink);
}
.sub-hero h1 .accent{color:var(--gold-bright);font-style:italic}
.sub-hero-lead{
  font-size:16px;line-height:2;color:var(--ink-soft);
  max-width:680px;margin:0 auto;
}
.sub-hero-divider{
  width:60px;height:1px;background:var(--gold);
  margin:40px auto 0;
}

/* セクション共通 */
.rec-section{padding:120px 0;position:relative;z-index:2;background:var(--bg)}
.rec-section.alt{background:var(--bg-elev)}
.rec-section-head{text-align:center;margin-bottom:70px}
.rec-section-eyebrow{
  font-family:var(--serif-en);
  font-size:12px;letter-spacing:.4em;
  color:var(--gold);margin-bottom:16px;text-transform:uppercase;
}
.rec-section-title{
  font-family:var(--serif);
  font-size:clamp(28px, 4vw, 42px);
  font-weight:700;line-height:1.4;
  color:var(--ink);
}
.rec-section-title .accent{color:var(--gold-bright);font-style:italic}
.rec-section-lead{
  margin-top:24px;font-size:15px;line-height:2;
  color:var(--ink-soft);max-width:680px;margin-left:auto;margin-right:auto;
}

/* メッセージセクション */
.rec-message{
  max-width:820px;margin:0 auto;text-align:center;
}
.rec-message h2{
  font-family:var(--serif);
  font-size:clamp(28px, 4vw, 40px);
  font-weight:700;line-height:1.5;
  margin-bottom:36px;color:var(--ink);
}
.rec-message h2 .accent{color:var(--gold-bright);font-style:italic}
.rec-message p{
  font-size:15px;line-height:2.2;color:var(--ink-soft);
  margin-bottom:20px;
}

/* 仕事内容 */
.rec-jobs{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
}
.rec-job-card{
  background:var(--bg);
  border:1px solid var(--line);
  padding:48px 36px;
  text-align:center;
  transition:all .4s;
}
.rec-job-card:hover{
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:0 30px 60px -20px rgba(201,164,92,.15);
}
.rec-job-icon{
  width:64px;height:64px;
  border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 28px;
  color:var(--gold-bright);
}
.rec-job-num{
  font-family:var(--serif-en);
  font-size:13px;letter-spacing:.3em;
  color:var(--gold);text-transform:uppercase;margin-bottom:12px;
}
.rec-job-card h3{
  font-family:var(--serif);
  font-size:20px;font-weight:600;
  margin-bottom:16px;color:var(--ink);
  letter-spacing:.04em;
}
.rec-job-card p{
  font-size:14px;line-height:1.95;color:var(--ink-soft);
}

/* 募集要項テーブル */
.rec-details{max-width:880px;margin:0 auto}
.rec-details-table{
  width:100%;border-collapse:collapse;
  background:var(--bg);
  border:1px solid var(--line);
}
.rec-details-table tr{border-bottom:1px solid var(--line-soft)}
.rec-details-table tr:last-child{border-bottom:none}
.rec-details-table th, .rec-details-table td{
  padding:28px 32px;
  text-align:left;
  vertical-align:top;
}
.rec-details-table th{
  width:30%;
  font-family:var(--serif);
  font-size:14px;font-weight:600;
  color:var(--gold-bright);
  letter-spacing:.08em;
  background:var(--bg-deep);
  border-right:1px solid var(--line-soft);
}
.rec-details-table td{
  font-size:15px;line-height:1.95;
  color:var(--ink);
}
.rec-details-table td .note{
  display:block;
  margin-top:8px;
  font-size:13px;color:var(--ink-mute);
  line-height:1.7;
}
.rec-details-table td .highlight{
  color:var(--gold-bright);
  font-weight:600;
}
.rec-details-table td ul{list-style:none;padding:0;margin:0}
.rec-details-table td ul li{
  padding-left:18px;position:relative;
  margin-bottom:8px;
}
.rec-details-table td ul li:last-child{margin-bottom:0}
.rec-details-table td ul li::before{
  content:"";position:absolute;
  left:0;top:11px;
  width:6px;height:1px;
  background:var(--gold);
}

/* 求める人物像 */
.rec-target{max-width:920px;margin:0 auto}
.rec-target-list{
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
}
.rec-target-item{
  display:flex;align-items:flex-start;gap:18px;
  padding:24px 28px;
  background:var(--bg);
  border:1px solid var(--line);
  transition:all .3s;
}
.rec-target-item:hover{
  border-color:var(--gold-deep);
  background:var(--bg-elev);
}
.rec-target-check{
  flex-shrink:0;width:26px;height:26px;
  border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-bright);
  margin-top:1px;
}
.rec-target-text{
  font-size:15px;line-height:1.7;color:var(--ink);
  font-family:var(--serif);
}
.rec-target-note{
  margin-top:36px;padding:28px 32px;
  background:var(--bg-deep);
  border-left:2px solid var(--gold);
  font-size:14px;line-height:2;color:var(--ink-soft);
}

/* アクセス */
.rec-access{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
  align-items:center;max-width:1100px;margin:0 auto;
}
.rec-access-info h3{
  font-family:var(--serif);
  font-size:22px;font-weight:600;
  margin-bottom:8px;color:var(--ink);
}
.rec-access-info .address{
  font-size:15px;color:var(--ink-soft);
  margin-bottom:32px;line-height:1.8;
}
.rec-access-info .access-label{
  font-family:var(--serif-en);
  font-size:11px;letter-spacing:.4em;
  color:var(--gold);text-transform:uppercase;
  margin-bottom:16px;
}
.rec-access-list{list-style:none;padding:0;margin:0}
.rec-access-list li{
  padding:14px 0;
  border-bottom:1px solid var(--line-soft);
  font-size:14px;color:var(--ink-soft);
  display:flex;justify-content:space-between;align-items:center;gap:20px;
}
.rec-access-list li:last-child{border-bottom:none}
.rec-access-list .station{color:var(--ink)}
.rec-access-list .walk{
  font-family:var(--serif-en);font-size:13px;
  color:var(--gold-bright);letter-spacing:.05em;
  white-space:nowrap;
}
.rec-access-map{
  position:relative;aspect-ratio:4/3;
  background:var(--bg-elev);
  border:1px solid var(--line);
  overflow:hidden;
}
.rec-access-map img{
  width:100%;height:100%;
  object-fit:cover;
  filter:saturate(.55) contrast(1.05) brightness(.7) sepia(.2);
  transition:transform 1.2s ease;
  display:block;
}
.rec-access-map:hover img{transform:scale(1.04)}
.rec-access-map::before{
  content:"";position:absolute;inset:20px;
  border:1px solid rgba(201,164,92,.4);
  pointer-events:none;z-index:3;
}
.rec-access-map::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 50% 50%, transparent 30%, rgba(10,8,7,.5) 90%),
    linear-gradient(180deg, transparent 50%, rgba(10,8,7,.7) 100%);
  pointer-events:none;z-index:1;
}
.rec-access-map-label{
  position:absolute;left:32px;bottom:32px;z-index:2;
  font-family:var(--serif-en);font-size:11px;
  letter-spacing:.4em;color:var(--gold-bright);
  text-transform:uppercase;
}
.rec-access-map-label::before{
  content:"";display:inline-block;
  width:24px;height:1px;background:var(--gold);
  vertical-align:middle;margin-right:12px;
}

/* 選考フロー */
.rec-flow{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  max-width:1100px;margin:0 auto;
}
.rec-flow-step{
  text-align:center;padding:30px 20px;
  position:relative;
}
.rec-flow-step:not(:last-child)::after{
  content:"";position:absolute;
  top:64px;right:-12px;
  width:24px;height:1px;background:var(--gold);
  opacity:.5;
}
.rec-flow-num{
  font-family:var(--serif-en);
  font-size:11px;letter-spacing:.4em;
  color:var(--gold);text-transform:uppercase;
  margin-bottom:18px;
}
.rec-flow-circle{
  width:90px;height:90px;
  background:var(--bg);
  border:1px solid var(--gold-deep);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 24px;
  font-family:var(--serif-en);
  font-size:34px;font-weight:300;
  color:var(--gold-bright);
}
.rec-flow-step h3{
  font-family:var(--serif);
  font-size:18px;font-weight:600;
  margin-bottom:14px;color:var(--ink);
  line-height:1.5;
}
.rec-flow-step p{
  font-size:13px;line-height:1.9;
  color:var(--ink-soft);
}

/* CTA */
.rec-cta{
  padding:120px 0;position:relative;z-index:2;
  background:
    radial-gradient(circle at 50% 0%, rgba(201,164,92,.12), transparent 60%),
    var(--bg-deep);
  text-align:center;border-top:1px solid var(--line-soft);
}
.rec-cta-eyebrow{
  font-family:var(--serif-en);
  font-size:12px;letter-spacing:.4em;
  color:var(--gold);margin-bottom:20px;text-transform:uppercase;
}
.rec-cta h2{
  font-family:var(--serif);
  font-size:clamp(28px, 4vw, 44px);
  font-weight:700;margin-bottom:24px;
  line-height:1.5;color:var(--ink);
}
.rec-cta h2 .accent{color:var(--gold-bright);font-style:italic}
.rec-cta-lead{
  font-size:15px;line-height:2;color:var(--ink-soft);
  max-width:600px;margin:0 auto 40px;
}
.rec-cta-btn{
  display:inline-flex;align-items:center;gap:14px;
  background:#06c755;color:#fff !important;
  padding:20px 56px;
  font-family:var(--serif);font-size:16px;font-weight:700;
  letter-spacing:.05em;border-radius:50px;
  box-shadow:0 12px 36px rgba(6,199,85,.4);
  transition:all .3s;
}
.rec-cta-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 48px rgba(6,199,85,.55);
}
.rec-cta-note{
  margin-top:28px;font-size:13px;color:var(--ink-mute);
  letter-spacing:.05em;
}

/* レスポンシブ */
@media (max-width:1024px){
  .rec-jobs{grid-template-columns:1fr 1fr}
  .rec-flow{grid-template-columns:1fr 1fr;gap:50px 24px}
  .rec-flow-step:not(:last-child)::after{display:none}
  .rec-access{grid-template-columns:1fr;gap:40px}
  .rec-access-map{max-width:500px;margin:0 auto;width:100%}
}
@media (max-width:680px){
  .sub-hero{padding:130px 0 70px;min-height:auto}
  .rec-section{padding:80px 0}
  .rec-section-head{margin-bottom:50px}
  .rec-jobs{grid-template-columns:1fr;gap:20px}
  .rec-job-card{padding:36px 28px}
  .rec-details-table th, .rec-details-table td{padding:20px 22px;display:block;width:100%}
  .rec-details-table th{border-right:none;border-bottom:1px solid var(--line-soft);padding-bottom:12px;padding-top:24px;font-size:13px}
  .rec-details-table tr:first-child th{padding-top:24px}
  .rec-details-table td{padding-top:14px;padding-bottom:24px}
  .rec-target-list{grid-template-columns:1fr;gap:14px}
  .rec-target-item{padding:20px 22px}
  .rec-target-note{padding:22px 24px;font-size:13px}
  .rec-flow{grid-template-columns:1fr;gap:36px}
  .rec-flow-step{padding:0}
  .rec-cta{padding:80px 0}
  .rec-cta-btn{padding:18px 32px;font-size:15px;width:100%;justify-content:center;max-width:340px}
}
