.rl-app { max-width: 980px; margin: 0 auto; color: #333; }
.rl-header { margin-bottom: 12px; }
.rl-title { font-size: 20px; font-weight: 700; margin: 0 0 4px; }
.rl-subtitle { font-size: 13px; color: #777; margin: 0; }

/* トグルバー（モバイルのみ表示。絞り込みバーの開閉） */
.rl-toggle-bar { display: none; margin-bottom: 10px; }
.rl-toggle {
  width: 100%; background: #fff; border: 1px solid #e9608a; color: #e9608a;
  border-radius: 8px; padding: 10px; font-size: 14px; cursor: pointer;
}
.rl-toggle.rl-toggle-on { background: #e9608a; color: #fff; }

/* 操作ツールバー（コンパクト・即時反映） */
.rl-controls { margin-bottom: 14px; }
.rl-toolbar-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; flex-wrap: wrap; margin-bottom: 10px;
}
.rl-sort-inline { font-size: 13px; color: #555; display: flex; align-items: center; gap: 6px; }
.rl-sort-select { font-size: 14px; padding: 6px 10px; border: 1px solid #ccc; border-radius: 6px; }
.rl-reset-btn {
  background: #fff; color: #666; border: 1px solid #ccc; border-radius: 6px;
  padding: 7px 16px; font-size: 13px; cursor: pointer;
}
.rl-reset-btn:hover { border-color: #e9608a; color: #e9608a; }

/* 絞り込みバー: 各項目を横に並べる */
.rl-filter-bar {
  display: flex; flex-wrap: wrap; gap: 12px 18px; align-items: flex-end;
  background: #fafafa; border: 1px solid #eee; border-radius: 10px; padding: 12px 14px;
}
.rl-fitem { display: flex; flex-direction: column; gap: 4px; }
.rl-fitem-label { font-size: 12px; font-weight: 600; color: #666; }

.rl-btn-group { display: inline-flex; border: 1px solid #cfcfcf; border-radius: 999px; overflow: hidden; }
.rl-fbtn {
  border: none; background: #fff; color: #333; padding: 6px 14px;
  font-size: 13px; cursor: pointer; line-height: 1.4; border-right: 1px solid #eee;
}
.rl-fbtn:last-child { border-right: none; }
.rl-fbtn:hover { background: #fdeef3; }
.rl-fbtn.rl-on { background: #e9608a; color: #fff; }
.rl-select { font-size: 14px; padding: 6px 10px; border: 1px solid #ccc; border-radius: 6px; min-width: 150px; }

/* 絞り込みサマリー */
.rl-filter-summary { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; }
.rl-sum-item { font-size: 12px; color: #555; background: #f3f3f3; border-radius: 999px; padding: 3px 10px; }
.rl-sum-label { color: #999; }

/* 件数 */
.rl-count { font-size: 13px; color: #666; margin: 8px 0 12px; }

/* カード */
.rl-list { display: flex; flex-direction: column; gap: 14px; }
.rl-card-item {
  display: flex; gap: 14px; border: 1px solid #eee; border-radius: 12px;
  padding: 14px 16px; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.rl-card-avatar { flex: 0 0 56px; }
.rl-card-avatar img { width: 56px; height: 56px; border-radius: 50%; display: block; }
.rl-card-body { flex: 1 1 auto; min-width: 0; }

.rl-card-top { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.rl-person { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.rl-nickname { font-weight: 700; font-size: 15px; }
.rl-gender { font-size: 12px; }
.rl-male { color: #5b9bd5; }
.rl-female { color: #e9608a; }
.rl-age { font-size: 12px; color: #666; }
.rl-date { font-size: 12px; color: #999; white-space: nowrap; }

.rl-app-area { margin: 6px 0; font-size: 14px; display: flex; align-items: center; gap: 10px; }
.rl-app-icon { width: 40px; height: 40px; object-fit: contain; border-radius: 8px; flex: 0 0 40px; }
.rl-app-links { display: flex; flex-direction: column; min-width: 0; }
.rl-app-link { color: #e9608a; cursor: pointer; text-decoration: underline; font-weight: 700; }
.rl-app-plain { font-weight: 700; }
.rl-app-url-line { display: block; }
.rl-app-url { color: #3b7cc4; cursor: pointer; text-decoration: underline; font-size: 13px; word-break: break-all; }
.rl-app .jump { cursor: pointer; }

.rl-stats { display: flex; gap: 18px; flex-wrap: wrap; margin: 8px 0; }
.rl-stat { display: flex; flex-direction: column; }
.rl-stat-label { font-size: 11px; color: #999; }
.rl-stat-val { font-size: 14px; font-weight: 600; }

.rl-comment { margin-top: 6px; font-size: 14px; line-height: 1.7; color: #333; }

.rl-empty { text-align: center; color: #999; padding: 40px 0; }

/* もっと見る */
.rl-more-wrap { text-align: center; margin: 20px 0; }
.rl-more-btn {
  background: #fff; color: #e9608a; border: 1px solid #e9608a; border-radius: 999px;
  padding: 10px 40px; font-size: 15px; cursor: pointer;
}
.rl-more-btn:hover { background: #fdeef3; }

/* レスポンシブ（スマホ: 積み上げ＋絞り込みバー開閉トグル） */
@media (max-width: 720px) {
  .rl-toggle-bar { display: block; }
  /* 絞り込みバーは初期非表示。トグルで開いたときだけ表示 */
  .rl-filter-bar { display: none; }
  .rl-filter-bar.rl-open { display: flex; flex-direction: column; align-items: stretch; }
  .rl-fitem { width: 100%; }
  .rl-select { width: 100%; min-width: 0; }
  .rl-btn-group { width: 100%; }
  .rl-fbtn { flex: 1 1 auto; text-align: center; }
  .rl-card-item { flex-direction: column; }
  .rl-card-avatar { flex: 0 0 auto; }
  .rl-card-top { flex-direction: column; align-items: flex-start; }
  .rl-stats { gap: 12px; }
}
