/* =============================================
   Recruit Banner — 下層フッター直上共通
   ============================================= */

.recruit-banner {
  background: var(--color-recruit-bg);
  padding: 100px 0 130px;
}

.recruit-banner__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-side);
}

.recruit-banner__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.recruit-banner__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--page-title-size);
  line-height: 1.11;
  letter-spacing: 0.11em;
  color: var(--color-gray);
  margin: 0;
}

.recruit-banner__view-all {
  font-family: var(--font-sub);
  font-weight: 500;
  font-size: 16px;
  line-height: 19px;
  letter-spacing: 0.19em;
  color: var(--color-text-muted);
  opacity: 0.66;
}

.recruit-banner__content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 60px;
  margin-top: 48px;
}

.recruit-banner__text {
  font-family: var(--font-ja);
  font-weight: 500;
  font-size: 18px;
  line-height: 35px;
  letter-spacing: 0.04em;
  color: var(--color-black);
  margin: 0;
  max-width: 548px;
}

@media (max-width: 1024px) {
  .recruit-banner { padding: 80px 0 100px; }
  .recruit-banner__text { font-size: 16px; line-height: 30px; }
}

@media (max-width: 768px) {
  .recruit-banner { padding: 60px 0 80px; }
  .recruit-banner__content {
    flex-direction: column;
    align-items: stretch;
    gap: 32px;
    margin-top: 32px;
  }
  .recruit-banner__text { font-size: 14px; line-height: 26px; }
  .recruit-banner__view-all { font-size: 13px; }
}
