function cmd::group::logs() {
  local name="" limit=50

  while [[ $# -gt 0 ]]; do
    case "$1" in
      --name)  util::require_flag "--name" "${2:-}" || return 1; name="$2"; shift 2 ;;
      --limit) util::require_flag "--limit" "${2:-}" || return 1; limit="$2"; shift 2 ;;
      --help)  cmd::group::help; return ;;
      *) log::error "Unknown flag: $1"; return 1 ;;
    esac
  done

  [[ -z "$name" ]] && log::error "Missing required flag: --name" && return 1
  group::require_exists "$name" || return 1

  local peers_list=()
  mapfile -t peers_list < <(group::peers "$name")
  [[ -z "${peers_list[0]}" ]] && log::wg_warning "Group '${name}' has no peers" && return 0

  log::section "Logs: Group '${name}'"

  for peer_name in "${peers_list[@]}"; do
    [[ -z "$peer_name" ]] && continue
    # Skip if peer no longer exists
    if ! peers::require_exists "$peer_name" > /dev/null 2>&1; then
      log::wg_warning "Peer '${peer_name}' no longer exists — skipping"
      continue
    fi
    printf "\n  \033[1;37m── %s ──\033[0m\n" "$peer_name"
    load_command logs
    cmd::logs::show --name "$peer_name" --limit "$limit"
  done
}