@charset "utf-8";
/* CSS Document */

.toggleable {
  border-bottom: 2px solid lightgray;
}

.toggleable__label {
  display: flex;
  justify-content: space-between; /* 左にタイトル＋アイコン、右に矢印 */
  align-items: center;
  padding: 1rem 0.5rem 0;
  cursor: pointer;
  font-weight: bold;
  width: 100%;
}

/* タイトル＋アイコンを左寄せ */
.toggleable__label-content {
  display: flex;
  align-items: center;
  gap: 8px; /* アイコンとタイトルの間隔 */
}

/* 矢印のデフォルト（下向き） */
.toggleable__label::after {
  content: "\f078"; /* FontAwesomeの下向き矢印 */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-size: 0.8rem;
  margin-left: auto; /* 矢印を常に右端に配置 */
}

/* チェック時（開いた状態）の矢印 */
.toggleable__control:checked ~ .toggleable__label::after {
  content: "\f077"; /* 上向き矢印 */
}

/* トグルコンテンツの初期状態（非表示） */
.toggleable__content {
  max-height: 0;
  overflow: hidden;
  transition: max-height .8s cubic-bezier(0,1,0,1);
  margin-top: 1rem;
  padding: 0 0.5rem;
}

/* チェック時（開いた状態）のスタイル */
.toggleable__control:checked ~ .toggleable__content {
  transition-timing-function: ease-in-out;
  max-height: 800px;
  margin-bottom: 1rem;
}

/* 視覚的に非表示（スクリーンリーダー対応） */
.hidden--visually {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
