/*
Theme Name: My Original Theme
Description: 静的HTMLをベースにしたオリジナルテーマ
Version: 1.0
Author: 井上
*/
/* 池袋敬心苑 START*/
.facility-card__header {
  margin-bottom: var(--space-16);
  font-weight: var(--font-weight-bold);
}

.facility-card__sub-name {
  font-size: var(--font-size-md);
}

.facility-card__name {
  font-size: var(--font-size-lg);
}

ul.facility-card-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

li.facility-card__tel,
li.facility-card__fax {
  position: relative;
  padding-left: var(--space-32);
}

li.facility-card__tel::before,
li.facility-card__fax::before {
  position: absolute;
  content: "";
  width: var(--icon-size-m);
  height: var(--icon-size-m);
  background-color: var(--color-primary-main);
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}

li.facility-card__tel::before {
  -webkit-mask: url(../images/icon/call.svg) no-repeat center / contain;
  mask: url(../images/icon/call.svg) no-repeat center / contain;
}

li.facility-card__fax::before {
  -webkit-mask: url(../images/icon/fax.svg) no-repeat center / contain;
  mask: url(../images/icon/fax.svg) no-repeat center / contain;
}

.facility_map-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-40);
}

.floor-icon {
  display: inline-block;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  text-align: center;
  padding: var(--space-8) var(--space-16);
  border-radius: var(--radius-sm);
  background-color: var(--color-primary-light);
  margin-bottom: var(--space-8);
}

ul.floor-info {
  margin-bottom: var(--space-24);
}

ul.floor-info li {
  text-indent: -1em;
  padding-left: 1em;
}

.floor_map.map_border {
  padding-bottom: 12px;
  border-bottom: dashed 2px var(--color-neutral-gray);
  margin-bottom: 12px;
}

@media screen and (max-width: 1000px) {
  .facility-card {
    margin-bottom: var(--space-32);
  }
}

/* 池袋敬心苑 END*/

/* 施設情報　START */
.section__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: var(--space-32);
}

.section__top-cate {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  text-align: center;
  padding: var(--space-8) var(--space-16);
  margin-bottom: var(--space-16);
  width: 240px;
  border-radius: var(--radius-sm);
}

.section__top-title {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
}

.section__top-info {
  display: flex;
  justify-content: start;
  align-items: flex-start;
  padding: var(--space-16);
  background-color: var(--color-neutral-white);
  border: solid 1px var(--color-neutral-gray);
  border-radius: var(--radius-sm);
}

.section__top-info-icon {
  width: var(--icon-size-m);
  margin-right: var(--space-16);
}

.section__top-info-text {
  font-size: var(--font-size-md);
  text-align: left;
}

@media screen and (max-width: 1000px) {
  .section__top {
    display: block;
    padding-bottom: var(--space-32);
  }

  .section__top-cate {
    font-size: var(--font-size-sm);
    padding: var(--space-8);
    margin: 0 auto var(--space-16);
    width: 80%;
    border-radius: var(--radius-sm);
  }

  .section__top-title {
    font-size: var(--font-size-lg);
    text-align: center;
    margin-bottom: var(--space-16);
  }

  .section__top-info {
    padding: var(--space-8);
  }

  .section__top-info-text {
    font-size: var(--font-size-sm);
    text-align: left;
  }
}

/* 施設情報　END */

/* サイドナビゲーション　START */
.side-nav {
  width: 20%;
  position: sticky;
  top: 180px;
  height: fit-content;
}

.side-nav__list {
  padding: var(--space-32) var(--space-24);
  background-color: var(--color-neutral-white);
  border: solid 1px var(--color-neutral-gray);
  border-radius: var(--radius-md);
  display: grid;
  grid-template-rows: 1fr;
  gap: var(--space-24);
  margin-bottom: var(--space-24);
}

.side-nav__link {
  display: block;
  position: relative;
  color: var(--color-neutral-black);
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  padding-right: var(--space-24);
  transition: 0.5s ease-in-out;
}

.side-nav__link:hover {
  color: var(--color-primary-main);
}

.side-nav__link::before {
  position: absolute;
  content: "";
  width: var(--space-8);
  height: var(--space-8);
  background-color: var(--color-primary-main);
  border-radius: var(--radius-full);
  top: calc(50% - 4px);
  right: 0;
  transform: translate(0, 0);
  opacity: 0;
  transition: 0.3s ease-in-out;
}

.side-nav__link:hover::before {
  opacity: 1;
  transform: scale(3);
}

.side-nav__link::after {
  position: absolute;
  content: "";
  width: var(--space-24);
  height: var(--space-24);
  background-color: var(--color-neutral-black);
  -webkit-mask: url(../images/icon/arrow.svg) no-repeat center / contain;
  mask: url(../images/icon/arrow.svg) no-repeat center / contain;
  top: 50%;
  right: -8px;
  transform: translate(0, -50%);
  transition: 0.3s ease-in-out;
}

.side-nav__link:hover::after {
  background-color: var(--color-neutral-white);
}

.side-nav__btn {
  width: 90%;
  display: block;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  color: var(--color-neutral-white);
  background-color: var(--color-primary-main);
  text-align: center;
  padding: var(--space-8);
  margin: 0 auto var(--space-24);
  border-radius: var(--radius-full);
  transition: 0.3s ease-in-out;
}

.side-nav__btn:hover {
  opacity: 0.8;
}

.side-nav__link.is-active {
  color: var(--color-primary-main);
}

.side-nav__link.is-active::before {
  opacity: 1;
  transform: scale(3);
}

.side-nav__link.is-active::after {
  background-color: var(--color-neutral-white);
}

.sp-modal-nav {
  display: none;
}

[id^="cate_"] {
  scroll-margin-top: 240px;
}

@media screen and (max-width: 1000px) {
  .side-nav {
    display: block;
    width: 100%;
    position: static;
    top: 0;
    height: auto;
  }

  .side-nav__list {
    padding: var(--space-24) var(--space-16);
    border-radius: var(--radius-sm);
    display: grid;
    grid-template-rows: 1fr;
    gap: var(--space-24);
  }

  .side-nav__link {
    padding-right: var(--space-24);
    transition: 0.5s ease-in-out;
  }

  .side-nav__link::before {
    width: var(--space-24);
    height: var(--space-24);
    top: 50%;
    right: 0;
    transform: translate(0, -50%);
    opacity: 1;
  }

  .side-nav__link::after {
    width: var(--space-24);
    height: var(--space-24);
    background-color: var(--color-neutral-white);
    -webkit-mask: url(../images/icon/arrow.svg) no-repeat center / contain;
    mask: url(../images/icon/arrow.svg) no-repeat center / contain;
    top: 55%;
    right: 0;
    transform: translate(0, -50%) rotate(90deg);
  }

  .side-nav__link:hover::before,
  .side-nav__link:hover::after {
    transform: scale(1);
  }

  /* ==========================
  モーダルナビ全体
========================== */
  body.is-modal-open {
    overflow: hidden;
    touch-action: none;
  }

  .sp-modal-nav {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    z-index: 1000;
    display: none;
    /* 初期は完全非表示 */
  }

  /* モーダルモード時 */
  .sp-modal-nav.is-active {
    display: block;
  }

  /* ==========================
  トグルボタン
========================== */

  .sp-modal-nav__toggle {
    width: 100%;
    height: 60px;
    background: var(--color-primary-main);
    color: var(--color-neutral-white);
    font-weight: var(--font-weight-bold);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 var(--space-24);
    border: none;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    position: relative;
    z-index: 1000;
  }

  /* プラスアイコン */
  .sp-modal-nav__icon {
    font-size: var(--font-size-xl);
    transition: transform 0.3s;
  }

  /* ==========================
  モーダルパネル
========================== */

  .sp-modal-nav__panel {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    background: var(--color-primary-main);
    /* 追加 */
    top: var(--sp-modal-top, 0);
    height: calc(100svh - var(--sp-modal-top, 0));

    transform: translateY(100%);
    transition: transform 0.4s ease;
    overflow-y: auto;
    padding: var(--space-24);
  }

  /* 開いた状態 */
  .sp-modal-nav.is-open .sp-modal-nav__panel {
    transform: translateY(0);
  }

  /* ==========================
  開いた時のトグル見た目
========================== */

  .sp-modal-nav.is-open .sp-modal-nav__toggle {
    background: var(--color-neutral-white);
    color: var(--color-primary-main);
  }

  .sp-modal-nav.is-open .sp-modal-nav__icon {
    transform: rotate(45deg);
  }

  /* ==========================
  メニューリスト
========================== */
  h2.sp-modal-nav-title a {
    display: block;
    position: relative;
    text-align: center;
    font-size: var(--font-size-lg);
    color: var(--color-neutral-white);
    margin-bottom: var(--space-24);
  }

  h2.sp-modal-nav-title a::after {
    position: absolute;
    content: "";
    background-color: var(--color-neutral-white);
    mask: url(../images/icon/arrow.svg) no-repeat center / contain;
    -webkit-mask: url(../images/icon/arrow.svg) no-repeat center / contain;
    width: var(--icon-size-m);
    height: var(--icon-size-m);
  }

  .btn_wrap {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--space-24);
  }

  .sp-modal_btn {
    display: block;
    width: 48%;
    color: var(--color-primary-main);
    font-size: var(--font-size-md);
    background-color: var(--color-neutral-white);
    padding: var(--space-8);
    margin: var(--space-16) 0;
    border-radius: var(--radius-full);
    text-align: center;
  }

  .sp-modal-nav__list {
    /* padding: 32px 24px 120px; */
    /* 下に余白（操作しやすさ） */
    display: grid;
    gap: var(--space-16);
  }

  .sp-modal-nav__list a {
    color: var(--color-neutral-white);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-normal);
    text-decoration: none;
    padding: 0 var(--space-8) var(--space-16);
    border-bottom: solid 1px #fff;
  }

  .sp-modal-nav__list a:hover {
    color: var(--color-neutral-white);
  }

  .sp-modal-nav__list a::before,
  .sp-modal-nav__list a::after {
    content: none;
  }

  .side-nav__link::after .sp-modal-nav__list a {
    transform: translate(0, -50%) rotate(-45deg);
  }

  /* アクティブ表示（任意） */
  .sp-modal-nav__list .side-nav__link.is-active {
    color: var(--color-neutral-white);
    font-weight: var(--font-weight-normal);
  }
}

/* サイドナビゲーション　END */

/* コンテンツ　START */
.section__content-wrap {
  width: calc(80% - 60px);
  background-color: var(--color-neutral-white);
  border: solid 1px var(--color-neutral-gray);
  border-radius: var(--radius-md);
  padding: var(--space-40);
  display: grid;
  grid-template-rows: 1fr;
  gap: var(--space-64);
}

@media screen and (max-width: 1000px) {
  .section__content-wrap {
    width: 100%;
    border-radius: var(--radius-sm);
    padding: var(--space-40) var(--space-16);
    gap: var(--space-40);
  }
}

/* スライダー START*/
.slider {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}

.slider__viewport {
  overflow: hidden;
}

.slider__track {
  display: flex;
  transition: transform 1.5s ease;
  will-change: transform;
}

.slider__slide {
  min-width: 100%;
}

.slider__slide img {
  width: 100%;
  height: auto;
  display: block;
}

.slider__dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 12px;
}

.slider__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-neutral-gray);
  cursor: pointer;
}

.slider__dot.is-active {
  background: var(--color-primary-main);
}

/* スライダー END*/

.section--intro {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.section--intro p {
  width: calc((100% - var(--space-32)) / 2);
  font-size: var(--font-size-md);
}

.section__detail-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-main);
  margin-bottom: var(--space-24);
}

.section__detail-caption {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-24);
  font-weight: var(--font-weight-bold);
}

.section__detail-text {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-16);
}

.section__detail_index {
  color: var(--color-primary-main);
  font-weight: var(--font-weight-bold);
}

.section__detail-list {
  padding-left: 1em;
  text-indent: -1em;
}

ul.info-wrap {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}

li.info-item {
  width: calc((100% - var(--space-32)) / 2);
  display: grid;
  grid-template-rows: 1fr;
  gap: var(--space-24);
  border: solid 1px var(--color-neutral-gray);
  border-radius: var(--radius-sm);
  padding: var(--space-16);
}

.info-item-title {
  font-size: var(--font-size-md);
  font-weight: bold;
  text-align: center;
}

.info-item-img {
  width: 80%;
  margin: 0 auto;
}

@media screen and (max-width: 1000px) {
  .section--intro {
    display: block;
  }

  .section--intro p {
    width: 100%;
    text-align: justify;
  }

  .section__detail-title {
    font-size: var(--font-size-md);
  }

  ul.info-wrap {
    display: grid;
    grid-template-rows: 1fr;
    gap: var(--space-24);
  }

  li.info-item {
    width: 100%;
    display: grid;
    grid-template-rows: 1fr;
    gap: var(--space-24);
    border: solid 1px var(--color-neutral-gray);
    border-radius: var(--radius-sm);
    padding: var(--space-16);
  }
}

/* 表組み　START */
/* グレー罫線表 */
table.info-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-40);
}

th.info-table__head,
td.info-table__data {
  border: solid 1px var(--color-neutral-gray);
  padding: var(--space-24) var(--space-32);
  font-size: var(--font-size-md);
}

th.info-table__head {
  font-weight: var(--font-weight-bold);
  text-align: left;
  width: 25%;
}

td.info-table__data span {
  font-weight: var(--font-weight-bold);
}

@media screen and (max-width: 1000px) {
  table.info-table {
    margin-bottom: var(--space-24);
  }

  tr.info-table__row {
    display: grid;
  }

  th.info-table__head,
  td.info-table__data {
    border: none;
    padding: var(--space-8) var(--space-16);
  }

  th.info-table__head {
    width: 100%;
    background-color: var(--color-primary-light);
  }
}

/* グレー罫線表 */
/* スケジュール表 */
.schedule-table {
  margin-bottom: var(--space-24);
}

.schedule-table__head {
  font-weight: var(--font-weight-bold);
  min-width: 5rem;
  width: 10%;
  text-align: right;
}

@media screen and (max-width: 1000px) {
  .schedule-table {
    margin-bottom: var(--space-16);
  }

  tr.schedule-table__row {
    display: flex;
    align-items: baseline;
  }

  .schedule-table__head {
    min-width: 6rem;
  }
}

/* スケジュール表 */
/* 表組み　END */

/* タブ　START */
ul.tab__list {
  display: flex;
  align-items: flex-end;
}

li.tab__item {
  width: calc(100% / 2);
  background-color: var(--color-neutral-white);
  text-align: center;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  color: var(--color-neutral-black);
  border-radius: var(--font-size-md) var(--font-size-md) 0 0;
  border: solid 1px var(--color-primary-light);
  padding-block: var(--space-24);
}

li.tab__item--active {
  background-color: var(--color-primary-light);
  padding-block: var(--space-32);
}

.tab__content {
  border: solid 1px var(--color-primary-light);
  border-top: 0;
  padding: var(--space-40) var(--space-40) var(--space-16);
}

.tab__panel {
  display: none;
}

.tab__panel.tab__panel--active {
  display: block;
}

@media screen and (max-width: 1000px) {
  li.tab__item {
    border-radius: var(--font-size-sm) var(--font-size-sm) 0 0;
    padding: var(--space-8);
    font-size: var(--font-size-sm);
    border-radius: 0;
  }

  li.tab__item--active {
    padding: var(--space-16) var(--space-8);
    border-radius: var(--font-size-md) var(--font-size-md) 0 0;
  }

  .tab__content {
    padding: var(--space-16) var(--space-16) 0;
  }
}

/* タブ　END */

/* 色付きキャプション START*/
ul li.detail {
  position: relative;
  margin: 0 0 var(--space-8) var(--space-16);
}

ul li.detail::before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  top: 50%;
  left: -16px;
  transform: translate(0, -50%);
}

ul li.detail.caption_guidance::before {
  background-color: var(--color-accent-pink);
}

ul li.detail.caption_recruit::before {
  background-color: var(--color-secondary-light);
}

ul li.detail.caption_recruit_irr::before {
  background-color: var(--color-secondary-main);
}

ul li.detail.caption_community::before {
  background-color: var(--color-primary-light);
}

/* 色付きキャプション END*/

ul.apply_list {
  display: grid;
  grid-template-rows: 1fr;
  gap: var(--space-16);
}

ul.apply_list li span {
  background-color: var(--color-secondary-main);
}

ul.apply_list li a {
  color: var(--color-primary-main);
  font-weight: var(--font-weight-bold);
  transition: 0.3s ease-in-out;
}

ul.apply_list li a:hover {
  text-decoration: underline;
}

/* アクセス */
.access-wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.access-wrap-item {
  width: calc((100% - 16px) / 2);
}

.access-address,
.access-direction {
  position: relative;
  margin-left: var(--space-40);
  margin-bottom: var(--space-16);
}

.access-direction {
  display: grid;
  grid-template-rows: 1fr;
  gap: var(--space-16);
}

.access-address::before,
.access-direction::before {
  position: absolute;
  content: "";
  width: var(--icon-size-m);
  height: var(--icon-size-m);
  top: 0;
  left: -40px;
}

.access-address::before {
  background: url(../images/icon/location.svg) no-repeat center / contain;
}

.access-direction::before {
  background-color: var(--color-primary-main);
  -webkit-mask: url(../images/icon/directions.svg) no-repeat center / contain;
  mask: url(../images/icon/directions.svg) no-repeat center / contain;
}

@media screen and (max-width: 1000px) {
  .access-wrap {
    display: block;
  }

  .access-wrap-item {
    width: 100%;
  }

  .access-address,
  .access-direction {
    margin-left: var(--space-32);
  }

  .access-address::before,
  .access-direction::before {
    left: -32px;
  }
}

/* アクセス　END */
/* お問い合わせ　START */
.contact-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.contact-item {
  display: flex;
  flex-direction: column;
  height: 100%;
  font-weight: var(--font-weight-bold);
  text-align: center;
  color: var(--color-neutral-black);
  transition: 0.3s ease-in-out;
}

.contact-item.call {
  pointer-events: none;
}

.contact-item-ttl {
  padding: var(--space-8) 0;
  background-color: var(--color-primary-light);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.contact-item-text {
  padding: var(--space-16) 0;
  border: solid 1px var(--color-neutral-gray);
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  flex-grow: 1;
  transition: 0.3s ease-in-out;
}

.contact-item-text span {
  position: relative;
}

.contact-item-text:hover {
  color: var(--color-primary-main);
}

.contact-item.call .contact-item-text {
  font-size: var(--font-size-xl);
}

.contact-item.mail .contact-item-text {
  font-size: var(--font-size-lg);
}

.contact-item.call .contact-item-text span::before,
.contact-item.mail .contact-item-text span::before {
  position: absolute;
  content: "";
  background-color: var(--color-primary-main);
  width: var(--icon-size-l);
  height: var(--icon-size-l);
  top: 50%;
  left: -45px;
  transform: translate(0, -50%);
}

.contact-item.call .contact-item-text span::before {
  -webkit-mask: url(../images/icon/call.svg) no-repeat center / contain;
  mask: url(../images/icon/call.svg) no-repeat center / contain;
}

.contact-item.mail .contact-item-text span::before {
  -webkit-mask: url(../images/icon/mail.svg) no-repeat center / contain;
  mask: url(../images/icon/mail.svg) no-repeat center / contain;
}

.contact-item.mail:hover .contact-item-text span::before {
  transition: 0.3s;
  -webkit-mask: url(../images/icon/mail_open.svg) no-repeat center / contain;
  mask: url(../images/icon/mail_open.svg) no-repeat center / contain;
}

@media screen and (max-width: 1000px) {
  .contact-wrap {
    display: grid;
    grid-template-columns: 1fr;
  }

  .contact-item {
    width: 100%;
  }

  .contact-item.call {
    pointer-events: auto;
  }

  .contact-item-text {
    padding: var(--space-16) 0 var(--space-16) var(--space-32);
  }
}

/* お問い合わせ　END */
/* コンテンツ　END */

/* ページ内フッター START*/
.pre-footer {
  width: 100%;
  display: flex;
  justify-content: space-between;
}

.pre-footer-btn {
  width: calc(100% / 3);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--space-40);
  color: var(--color-neutral-black);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
}

.pre-footer-btn p {
  margin-right: var(--space-24);
}

.pre-footer-btn .mask img {
  max-width: 120px;
  transition: transform 0.4s ease-in-out;
}

.pre-footer-btn:hover .mask img {
  transform: scale(1.1);
}

@media screen and (max-width: 1000px) {
  .pre-footer {
    display: block;
  }

  .pre-footer-btn {
    width: 100%;
    padding: var(--space-16);
    font-size: var(--font-size-lg);
  }

  .pre-footer-btn .mask img {
    max-width: 80px;
  }
}

/* ページ内フッター END*/

/* 採用について */
.appeal-ttl-wrap {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: var(--space-24);
}

.appeal-item {
  margin-bottom: var(--space-32);
}

.appeal-num {
  font-size: 64px;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary-light);
  margin-right: var(--space-8);
  line-height: var(--line-height-sm);
}

.appeal-ttl {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

.appeal-ttl p {
  font-weight: var(--font-weight-regular);
  font-size: var(--font-size-md);
}

.appeal-item-txt {
  margin-bottom: var(--space-16);
}

.appeal-item-txt_bold {
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-16);
}

.section__detail-caption span.secondary-light {
  color: var(--color-secondary-light);
}

.section__detail-caption span.secondary-main {
  color: var(--color-secondary-main);
}

/* -----デイホーム　採用　START----- */
/* グリッド */
.grid-container {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 150px;
  gap: var(--space-8);
}

.grid-item {
  background-color: var(--color-neutral-white);
  padding: var(--space-16);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: left;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.05);
  border-radius: var(--radius-sm);
}

.grid-item img {
  margin-block: var(--space-16);
}

.grid-item.item-1 {
  grid-column: span 3;
  grid-row: span 1;
}

.grid-item.item-2 {
  grid-column: span 1;
  grid-row: span 1;
}

.grid-item.item-3 {
  grid-column: span 2;
  grid-row: span 1;
}

.grid-item.item-4 {
  grid-column: span 2;
  grid-row: span 2;
  flex-wrap: wrap;
}

.grid-item.item-5 {
  grid-column: span 1;
  grid-row: span 1;
}

.grid-item.item-6 {
  grid-column: span 3;
  grid-row: span 1;
}

.grid-item.item-7 {
  grid-column: span 3;
  grid-row: span 1;
}

.grid-item.item-8 {
  grid-column: span 1;
  grid-row: span 5;
  text-align: center;
  flex-wrap: wrap;
}

.grid-item.item-8 p {
  writing-mode: vertical-rl;
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.5rem;
  display: inline-block;
}

.grid-item.item-9 {
  grid-column: span 3;
  grid-row: span 1;
}

.grid-item.item-10 {
  grid-column: span 2;
  grid-row: span 4;
  flex-wrap: wrap;
}

.grid-item.item-11 {
  grid-column: span 3;
  grid-row: span 3;
  flex-wrap: wrap;
}

/* グリッド */
/* スケジュール */
.job-details__text {
  margin-bottom: var(--space-24);
}

.job-details__schedule {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.schedule__title {
  text-align: center;
  font-weight: var(--font-weight-bold);
  padding: var(--space-8) 0;
  background-color: var(--color-primary-light);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.schedule__list-wrap {
  padding: var(--space-16) 0;
  border: solid 1px var(--color-neutral-gray);
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  flex-grow: 1;
}

.schedule__list {
  display: grid;
  grid-template-columns: 1fr;
  width: 80%;
  max-width: 240px;
  margin: 0 auto;
  position: relative;
  gap: var(--space-16);
}

.schedule__list::before {
  position: absolute;
  top: 16px;
  left: 3px;
  z-index: 0;
  width: 1px;
  height: calc(100% - 24px);
  background-image: radial-gradient(circle closest-side, #e3e3e3 100%);
  background-size: 3px 8px;
  background-repeat: repeat-y;
  content: "";
}

.schedule__item {
  display: flex;
  gap: var(--space-24);
}

.schedule__time {
  position: relative;
  color: var(--color-primary-main);
  font-weight: var(--font-weight-bold);
  padding-left: var(--space-24);
  width: 70px;
}

.schedule__time::after {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary-main);
  transform: translate(0, -50%);
}

/* スケジュール */
@media screen and (max-width: 1000px) {
  /* グリッド */
  .grid-container {
    font-feature-settings: "palt";
  }

  .grid-item img {
    margin-block: 0;
  }

  .grid-item.item-1 {
    grid-column: span 6;
    grid-row: span 1;
  }

  .grid-item.item-2 {
    grid-column: span 2;
    grid-row: span 1;
  }

  .grid-item.item-3 {
    grid-column: span 4;
    grid-row: span 1;
  }

  .grid-item.item-4 {
    grid-column: span 6;
    grid-row: span 1;
    flex-wrap: nowrap;
    flex-direction: row-reverse;
  }

  .grid-item.item-4 img {
    width: 30%;
  }

  .grid-item.item-5 {
    display: none;
  }

  .grid-item.item-6 {
    grid-column: span 3;
    grid-row: span 2;
  }

  .grid-item.item-7 {
    grid-column: span 3;
    grid-row: span 2;
  }

  .grid-item.item-8 {
    grid-column: span 2;
    grid-row: span 4;
    text-align: center;
    flex-wrap: wrap;
  }

  .grid-item.item-8 p {
    font-size: var(--font-size-xl);
  }

  .grid-item.item-9 {
    grid-column: span 4;
    grid-row: span 1;
  }

  .grid-item.item-10 {
    grid-column: span 4;
    grid-row: span 3;
    flex-wrap: wrap;
  }

  .grid-item.item-11 {
    grid-column: span 6;
    grid-row: span 1;
    flex-wrap: nowrap;
  }

  .grid-item.item-11 img {
    width: 40%;
  }

  /* グリッド */
  /*  */
  .job-details {
    display: block;
  }

  .job-details-item {
    width: 100%;
  }
}

/* -----デイホーム　採用　END----- */
/* 相談センター　START */
.grid-container--recruit {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 120px;
  gap: var(--space-24);
}

.recruit-grid-item {
  background-color: var(--color-neutral-white);
  padding: var(--space-16);
  text-align: left;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.05);
  border-radius: var(--radius-sm);
}

.recruit-grid-item.item-1 {
  grid-column: span 3;
  grid-row: span 3;
  gap: var(--space-24);
  display: grid;
  align-items: center;
}

.recruit-grid-item.item-1 img {
  aspect-ratio: 16/9;
  object-fit: contain;
  margin: 0 auto;
}
.recruit-grid-item.item-2 {
  display: grid;
  grid-column: span 3;
  grid-row: span 3;
  grid-template-rows: 1fr 2fr;
  gap: var(--space-24);
  align-items: center;
}
.recruit-grid-item .split-content {
  display: flex;
  align-items: center;
  gap: var(--space-16);
}

.recruit-grid-item.item-2 img {
  width: 50%;
  aspect-ratio: 10/7;
  object-fit: contain;
}

.recruit-grid-item.item-3 {
  display: grid;
  grid-column: span 4;
  grid-row: span 3;
  grid-template-rows: 1fr 2fr;
  gap: var(--space-24);
  align-items: center;
}
.recruit-grid-item.item-3 img {
  width: 50%;
  aspect-ratio: 1/1;
  object-fit: contain;
}

.recruit-grid-item.item-4 {
  display: grid;
  grid-column: span 2;
  grid-row: span 3;
  grid-template-rows: 1fr 2fr;
  align-items: center;
}

.recruit-grid-item.item-5 {
  display: grid;
  grid-column: span 6;
  grid-row: span 1;
  grid-template-columns: 1fr 2fr 3fr;
  align-items: center;
  justify-content: center;
}
.recruit-grid-item.item-5 img {
  aspect-ratio: 3/2;
  object-fit: contain;
}
@media screen and (max-width: 1000px) {
  .grid-container--recruit {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-24);
  }
  .recruit-grid-item.item-3 {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-16);
    align-items: center;
  }
  .recruit-grid-item.item-3 .split-content {
    display: block;
  }
  .recruit-grid-item.item-3 img {
    width: 100%;
  }
  .recruit-grid-item.item-5 {
    display: block;
  }
}
/* 相談センター　END */

/* 障害者園施設雑司ヶ谷 START*/
.grid-container.only {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 150px;
}
.grid-container.only .grid-item {
  grid-column: span 6;
  grid-row: span 2;
  gap: var(--space-24);
}
.grid-container.only .grid-item p {
  width: 60%;
}
.grid-container.only .grid-item img {
  width: 30%;
}
@media screen and (max-width: 1000px) {
  .grid-container.only {
    display: block;
  }
  .grid-container.only .grid-item {
    flex-wrap: wrap;
  }
  .grid-container.only .grid-item p {
    width: 100%;
  }
  .grid-container.only .grid-item img {
    width: 100%;
  }
}
/* 障害者園施設雑司ヶ谷 END*/
/* 採用について END */

/* gridlayout　START */
.card_grid {
  display: grid;
  gap: var(--space-24);
}

.card_grid-item {
  border: solid 1px var(--color-neutral-gray);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background-color: var(--color-neutral-white);
  padding: var(--space-16);
}

/* -----「3カラム＋2カラム」型----- */
.card_grid--1 {
  grid-template-columns: repeat(6, 1fr);
}

.card_grid--1 .card_grid-item:nth-child(1),
.card_grid--1 .card_grid-item:nth-child(2),
.card_grid--1 .card_grid-item:nth-child(3) {
  grid-column: span 2;
}

.card_grid--1 .card_grid-item:nth-child(4),
.card_grid--1 .card_grid-item:nth-child(5) {
  grid-column: span 3;
}

.card_grid--1 .card_grid-item:nth-child(4) img,
.card_grid--1 .card_grid-item:nth-child(5) img {
  aspect-ratio: 16/9;
  object-fit: cover;
}

.card_grid-item-ttl {
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-8);
}

@media screen and (max-width: 1000px) {
  .card_grid--1 {
    grid-template-columns: 1fr;
  }

  .card_grid--1 .card_grid-item:nth-child(1),
  .card_grid--1 .card_grid-item:nth-child(2),
  .card_grid--1 .card_grid-item:nth-child(3),
  .card_grid--1 .card_grid-item:nth-child(4),
  .card_grid--1 .card_grid-item:nth-child(5) {
    grid-column: span 1;
  }
}

/* -----「2カラム＋1カラム」型----- */
.card_grid--2 {
  grid-template-columns: repeat(6, 1fr);
}

.card_grid--2 .card_grid-item:nth-child(1),
.card_grid--2 .card_grid-item:nth-child(2) {
  grid-column: span 3;
}

.card_grid--2 .card_grid-item:nth-child(3) {
  grid-column: span 6;
}

.card_grid--2 img {
  aspect-ratio: 16/8;
  object-fit: contain;
}

@media screen and (max-width: 1000px) {
  .card_grid--2 {
    grid-template-columns: 1fr;
  }

  .card_grid--2 .card_grid-item:nth-child(1),
  .card_grid--2 .card_grid-item:nth-child(2),
  .card_grid--2 .card_grid-item:nth-child(3) {
    grid-column: span 1;
  }
}

/* -----「2カラム」型----- */
.card_grid--3 {
  grid-template-columns: repeat(2, 1fr);
}

.card_grid--3 .card_grid-item {
  grid-column: span 1;
}

.card_grid--3 .card_grid-item img {
  aspect-ratio: 16/9;
  object-fit: contain;
}

@media screen and (max-width: 1000px) {
  .card_grid--3 {
    grid-template-columns: 1fr;
  }
}

/* gridlayout　END */

/* 情報公開　START */
.facility__container {
    margin-bottom: var(--space-64);
}
h3.facility__name {
    font-size: var(--font-size-lg);
    position: relative;
    padding-left: var(--space-16);
    margin-bottom: var(--space-40);
}
h3.facility__name::before {
    position: absolute;
    content: "";
    width: 4px;
    height: 100%;
    background-color: var(--color-primary-main);
    border-radius: var(--radius-sm);
    left: 0;
}
h4.facility__subtitle {
    font-size: var(--font-size-md);
    color: var(--color-primary-main);
    margin-bottom: var(--space-24);
}
ul.facility__container--list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-24);
    margin-bottom: var(--space-32);
}
ul.facility__container--list li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-16);
    background-color: var(--color-neutral-white);
    border: solid 1px var(--color-neutral-gray);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-md);
    color: var(--color-neutral-black);
    position: relative;
    transition: .3s ease-in-out;
}
p.facility__list__title {
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-8);
}
p.facility__list__caption {
    color: var(--color-primary-main);
}
ul.facility__container--list li a:hover{
   background-color: var(--color-primary-light);
}
@media screen and (max-width: 1000px) {
  ul.facility__container--list {
    grid-template-columns: 1fr;
}
}
/* 情報公開　END */

/* プライバシーポリシー　START */
.privay__container {
    margin-bottom: var(--space-80);
    gap: var(--space-32);
    display: grid;
    grid-template-columns: 1fr;
}
h3.privacy__name {
    text-align: center;
    font-size: var(--font-size-xl);
}
p.privay__container--start {
    text-align: center;
}
ul.privay__container--list {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-8);
}
ul.privay__container--list li.ttl {
    font-weight: var(--font-weight-bold);
    color: var(--color-primary-main);
}
ul.privay__container--list li {
    padding-left: 16px;
    text-indent: -16px;
}
ul.privay__container--list li:not(.ttl)::before {
    counter-increment: list-counter;
    content: counter(list-counter) ". ";
}
p.privay__container--sign {
    text-align: right;
}

/* プライバシーポリシー　END */