.inner {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
  padding-left: 20px;
  padding-right: 20px;
  box-sizing: border-box;
}



/* ヒーロー */
.page-hero--office {
  color: #333;
  padding: 80px 0;
  position: relative;
}
.page-hero--office::before {
  content: "";
  position: absolute;
  inset: 0;
}
.page-hero--office .page-hero__inner {
  position: relative;
  z-index: 1;
}

/* 募集職種カード */
.jobs-list {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(280px,1fr));
  gap: 24px;
  margin-top: 24px;
}
.jobs-card {
  position: relative;
  padding: 20px 20px 72px;
  border-radius: 12px;
  border: 1px solid #e3e3e3;
  background: #fff;
  box-shadow: 0 8px 16px rgba(0,0,0,0.03);
}
.jobs-card__thumb img{
	width: 100%;
}
.jobs-card__label {
    display: inline-block;
    font-size: 16px;
    padding: 2px 10px;
    border-radius: 999px;
    background: #3b82f6;
    color: #fff;
    margin-bottom: 8px;
}
.jobs-card__label--green {
  background: #4caf50;
}
.jobs-card__title {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 8px;
}
.jobs-card__text {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 10px;
}
.jobs-card__meta {
  font-size: 16px;
  margin-bottom: 16px;
}
.jobs-card__meta li {
  margin-bottom: 4px;
}
.jobs-card__btn {
    position: absolute;
    left: 20px;
    right: 20px;
    bottom: 20px;
    display: block;
    text-align: center;
    padding: 10px 0;
    font-size: 18px;
    border-radius: 999px;
    background: #21891b;
    color: #fff;
    text-decoration: none;
}

/* 魅力セクション */
.merit-list {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(260px,1fr));
  gap: 24px;
  margin-top: 24px;
}
.merit-item {
  padding: 18px 20px;
  border-radius: 10px;
  background: #f7faf9;
}
.merit-item__title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 6px;
}
.merit-item__text {
  font-size: 16px;
  line-height: 1.8;
}

/* 応募フロー */
.recruit-flow{
    background: rgb(243 248 255 / 50%);
}
.flow-list {
  counter-reset: flow;
  display: grid;
  gap: 20px;
  margin-top: 24px;
	list-style: none;
}
.flow-item {
    padding: 18px 20px;
    background: #fff;
    border-bottom: 2px solid #b7cde3;
}
.flow-step {
    font-size: 20px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #0a5f4f;
    margin-bottom: 4px;
    font-weight: bold;
}
.flow-title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 6px;
}
.flow-text {
  font-size: 16px;
  line-height: 1.8;
}

/* CTA */
.recruit-jobs{
    background: rgb(243 248 255 / 50%);
}
.recruit-cta {
    background: #f2faf8;
    position: relative;
}
.recruit-cta__body {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  align-items: center;
  justify-content: space-between;
}
.recruit-cta__title {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 6px;
}
.recruit-cta__lead {
  font-size: 22px;
  line-height: 1.8;
}
.recruit-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.btn.btn-outline {
  display: inline-block;
  padding: 10px 20px;
  border-radius: 999px;
  border: 1px solid #0a5f4f;
  color: #0a5f4f;
  font-size: 14px;
}


/*******応募フォーム用****/
.job_slug{
	width: 30% !important;
}
.name{
	width: 50% !important;
}

/* SP */
@media (max-width: 768px) {
.recruit-intro{
	padding: 48px 0 !important;
}
.recruit-jobs{
	padding: 48px 0 !important;
}
	
  /* 親をフレックスにして中央揃え */
  .recruit-flow .flow-list {
    display: flex;
    flex-direction: column;
    align-items: center; /* ★中央揃えの決め手 */
    padding-left: 0;
    padding-right: 0;
  }

  /* カードの幅は固定せず、中央で広がる */
  .recruit-flow .flow-item {
    width: 100%;
    max-width: 360px;  /* 好みで調整。320〜380でOK */
    margin-left: auto;
    margin-right: auto;
  }

  /* inner の左右余白も調整 */
  .recruit-flow .inner {
    padding-left: 16px;
    padding-right: 16px;
  }
	
  .page-hero--recruit {
    padding: 56px 0;
  }
  .recruit-cta__body {
    flex-direction: column;
    align-items: flex-start;
  }
  .jobs-card {
    padding-bottom: 68px;
  }
	
/*******応募フォーム用****/
.job_slug{
	width: 100% !important;
}
.name{
	width: 100% !important;
}
.section {
    padding: 48px 0;
}
.inner_form{
	padding: 0;
}	
.p-contact-form{
	padding: 0;
}
.p-contact-form__row {
    background: #f5f7fb;
	padding: 5%;
}
.p-contact-form__row {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 20px;
    margin-top: 20px;
}
.recruit-cta__lead {
    font-size: 18px;
    line-height: 1.8;
}
.p-contact-form__note {
    margin-top: 20px;
    padding: 16px;
}
}