@charset "UTF-8";

/* 同一のtransition指定を集約 */
.close-menu,
.menu-link,
.notice-link {
  transition: transform 0.22s ease, background-color 0.22s ease, color 0.22s ease;
}

/* hover時の共通transformを集約 */
.menu-link:hover,
.notice-link:hover {
  transform: translateX(4px);
}

/* notice と important のホバー配色を集約 */
.notice-link:hover,
.menu-link.important:hover {
  background: var(--hover-color);
  color: var(--bg-color);
}

.notice-link:hover i,
.menu-link.important:hover i {
  color: var(--bg-color);
}

/* メニューの基本スタイル */
.setting-menu {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 320px;
  height: auto;
  background: var(--bg-color);
  box-shadow: 2px 0 5px var(--shadow-color);
  overflow-y: auto;
  box-sizing: border-box;
  /* iOSでスクロール領域の挙動が不安定になるのを抑える */
  -webkit-overflow-scrolling: touch;
  padding-bottom: calc(150px + env(safe-area-inset-bottom, 0px));
}

/* メニューヘッダー */
.menu-header {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-color);
  background: var(--bg-color);
  position: sticky;
  top: 0;
}

.close-menu {
  display: block;
  padding: 10px 8px;
  color: var(--text-color);
  text-decoration: none;
  cursor: pointer;
  font-weight: 600;
  font-size: 16px;
  border-bottom: 1px solid transparent;
}

.close-menu:hover {
  color: var(--hover-color);
}

/* メニュー項目のコンテナ */
.menu-items {
  padding: 6px 10px;
}

/* セクション区切りスタイル */
.menu-section {
  margin-bottom: 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border-color);
}

.menu-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

/* メニューリンク */
.menu-link,
.notice-link {
  display: flex;
  align-items: center;
  padding: 6px 4px;
  color: var(--text-color);
  text-decoration: none;
  font-size: 14px;
  font-weight: 400;
  border-radius: 4px;
  margin: 1px 0;
  position: relative;
  min-height: 32px;
}

.notice-link {
  color: var(--hover-color);
  font-weight: 600;
}

.menu-link:hover {
  background: var(--menu-hover-bg, #f5f5f5);
  color: var(--hover-color);
}

/* アイコン共通 */
.menu-link i,
.notice-link i {
  width: 16px;
  height: 16px;
  margin-right: 8px;
  color: var(--hover-color);
  font-size: 14px;
  text-align: center;
  flex-shrink: 0;
}

/* 重要項目の強調 */
.menu-link.important {
  font-weight: 600;
}

/* オーバーレイ */
.menu-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  transition: opacity 180ms ease, visibility 0s linear 180ms;
}

/* お知らせスペース */
.menu-notice {
  padding: 6px 10px;
  margin-bottom: 8px;
  border-bottom: 1px solid var(--border-color);
  background: linear-gradient(135deg, #f8f9ff 0%, #fff5f5 100%);
}

/* モバイル用調整 */
@media (max-width: 600px) {
  .close-menu {
    padding: 12px 8px;
    font-size: 18px;
    font-weight: 600;
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  .menu-header {
    padding: 8px 14px;
  }

  .menu-link,
  .notice-link {
    font-size: 16px;
    padding: 8px 6px;
    min-height: 40px;
  }

  .menu-link i,
  .notice-link i {
    font-size: 16px;
    width: 18px;
    height: 18px;
    margin-right: 10px;
  }

  .menu-items {
    padding: 4px 8px;
  }

  .menu-notice {
    padding: 4px 8px;
    margin-bottom: 8px;
  }
}