.ranking-section {
  margin-top: 40px;
}

.ranking-section--page {
  margin: 0 !important;
}

.ranking-tabs {
  display: flex;
  gap: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-bottom: 1px solid #e5e5e5;
}

.ranking-tabs::-webkit-scrollbar {
  display: none;
}

.ranking-tab {
  flex-shrink: 0;
  padding: 10px 16px;
  border: none;
  background: none;
  font-size: 13px;
  color: #888;
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color 0.2s, border-color 0.2s;
}

.ranking-tab--active {
  color: #be907c;
  font-weight: 700;
  border-bottom-color: #be907c;
}

.ranking-panel {
  display: none;
}

.ranking-panel--active {
  display: block;
}

.ranking-empty {
  padding: 32px 0;
  text-align: center;
  color: #888;
  font-size: 14px;
}

/* ランキング専用ページ */
.ranking-section--page {
  margin-top: 0;
  padding-bottom: 40px;
}
