/* --- サイドメニュー本体 --- */
aside.cmp-side {
  width: 100%;
  max-width: 300px;
  padding: 0;
  background: transparent;
  border: none;
  font-size: 1.6rem;
}

/* 見出し */
aside.cmp-side h2 {
  margin: 0 0 12px 0;
  padding-bottom: 8px;
  font-size: 1.7rem;
  font-weight: 700;
  border-bottom: 2px solid #00479d;
}

aside.cmp-side h2.line_title01 {
  all: unset;
  display: block;
  font-size: 1.7rem;
  font-weight: 700;
  color: #000;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 2px solid #00479d;
}

/* リスト */
aside.cmp-side ul {
  list-style: none; /* ← 点を消す */
  margin: 0;
  padding: 0;
}

aside.cmp-side li {
  margin: 0;
  padding: 0;
}

aside.cmp-side li + li {
  margin-top: 8px;
}

/* リンク（文字リンク仕様） */
aside.cmp-side a {
  display: inline-block;
  color: #00479d;
  text-decoration: none;
  font-weight: 600;
}

aside.cmp-side a:hover {
  text-decoration: underline;
}

/* SP対応 */
@media (max-width: 768px) {
  aside.cmp-side {
    max-width: 100%;
    margin-top: 20px;
  }
}

.cmp-side {
  position: sticky;
  top: 160px; /* 固定開始位置（ヘッダー高さに合わせて調整） */
  align-self: flex-start;
  max-height: calc(100vh - 32px);
  overflow: auto; /* サイドが長くなったらサイドだけスクロール */
}
