.job-post {
  padding-top: 1.25rem;
}

@media (min-width: 768px) {
  .job-post {
    padding-top: 0;
  }
}

.job-post-head {
  margin-top: 2.5rem;
  padding-inline: var(--gutter-x);
}

.job-post-head__lead {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.6;
}

.job-post-head__title {
  margin-top: 0.75rem;
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 1.4;
}

.job-post-head__title span {
  display: inline-block;
  margin-left: 0.625rem;
  padding: 0 0.3125rem;
  color: var(--color-white);
  background: var(--color-orange);
}

.job-post-head-info {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  margin-top: 0.75rem;
}

.job-post-head-info__logo {
  flex-shrink: 0;
  width: 3.125rem;
  height: 3.125rem;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid var(--color-gray);
}

.job-post-head-info__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.job-post-head-info__name {
  font-weight: 500;
  font-size: 0.8125rem;
  line-height: 1.8;
  color: var(--color-orange);
}

.job-post-head-thumbnail {
  margin-top: 1.5rem;
}

.job-post-tags {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.625rem;
  margin-top: 1.5rem;
  padding-inline: var(--gutter-x);
}

.facility {
  position: relative;
  background: var(--color-white);
  margin-block: 6rem 3.5rem;
  padding-inline: var(--gutter-x);
}

.facility::before {
  content: "";
  position: absolute;
  top: -3.5rem;
  left: 0;
  display: block;
  width: 100%;
  height: 4.375rem;
  background: var(--color-white);
  z-index: -1;
  clip-path: url(#wave-top-clip);
}

.facility::after {
  content: "";
  position: absolute;
  bottom: -3.5rem;
  left: 0;
  display: block;
  width: 100%;
  height: 4.375rem;
  background: var(--color-white);
  z-index: -1;
  clip-path: url(#wave-bottom-clip);
}

.facility-swiper img {
  border-radius: 1rem;
}

.facility-swiper .swiper-pagination {
  --swiper-pagination-bullet-horizontal-gap: 0.375rem;
  --swiper-pagination-bullet-size: 0.75rem;
  --swiper-pagination-color: var(--color-orange);
  --swiper-pagination-bullet-inactive-color: var(--color-gray);
  --swiper-pagination-bullet-inactive-opacity: 1;

  position: static;
  display: flex;
  justify-content: center;
  margin-top: 0.75rem;
}

.facility__title {
  margin-top: 2rem;
  padding: 0.125rem 1rem;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.8;
  color: var(--color-white);
  background: var(--color-orange);
  border-radius: 0.375rem;
}

.facility__catch-copy {
  margin-top: 1.5rem;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.8;
  color: var(--color-orange);
}

.facility__philosophy {
  margin-top: 1rem;
  font-size: 0.9375rem;
}

.facility-about {
  margin-top: 2rem;
}

.facility-about-item {
  display: flex;
  flex-direction: column;
}

.facility-about-item__title {
  font-weight: 700;
  line-height: 1.8;
}

.facility-about-item__body {
  flex: 1;
  margin-top: 0.5rem;
}

.facility-about__wrapper {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
  margin-top: 2rem;
}

.facility-about-item__data {
  display: grid;
  place-items: center;
  height: 100%;
  padding: 0.75rem;
  font-weight: 500;
  font-size: 0.8125rem;
  letter-spacing: 0.1em;
  border: 1px solid var(--color-yellow);
  border-radius: 1rem;
}

.facility-message {
  margin-top: 1.5rem;
  padding-block: 1.5rem;
  border-top: 2px dashed var(--color-black);
}

.facility-message__title {
  font-weight: 600;
  color: var(--color-orange);
}

.facility-message__body {
  margin-top: 1rem;
}

.facility-message__text {
  font-size: 0.9375rem;
}

.facility-episode {
  padding-top: 1.5rem;
  border-top: 2px dashed var(--color-black);
}

.facility-episode__title {
  font-weight: 600;
  line-height: 1.8;
}

.facility-episode__image {
  margin-top: 1rem;
  border-radius: 1rem;
  overflow: hidden;
}

.facility-episode__text {
  margin-top: 1rem;
  font-size: 0.8125rem;
}

.job-info {
  padding: 5rem var(--gutter-x) 4rem;
}

.job-info-section:not(:first-child) {
  margin-top: 5rem;
}

.job-info-section__title {
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.8;
}

.job-info-section-table {
  margin-top: 1.5rem;
  border-bottom: 1px solid var(--color-black);
}

.job-info-section-table dt {
  padding-top: 1rem;
  font-weight: 700;
  color: var(--color-orange);
  border-top: 1px solid var(--color-black);
}

.job-info-section-table dd {
  margin-top: 0.5rem;
  padding-bottom: 1rem;
  font-size: 0.9375rem;
  line-height: 1.6;
}

.job-info-section-table a {
  word-break: break-all;
}

.job-info-section-map {
  margin-top: 1.25rem;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: 1rem;
}

.job-info-section-map iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.job-info-bottom {
  margin-top: 5rem;
}