#include <cstdio>
#include <iostream>
#include <cstring>
#include <queue>
#include <utility>
#define mp(A,B) make_pair(A,B)
using namespace std;
typedef pair<int,int> pii;
int n,m,k,kk,cnt,ans;
int to[400010],next[400010],val[400010],head[20010],r[21],rr[21];
int dis[20010],v[25][25],vis[20010],f[(1<<20)+10][21],g[20010];
priority_queue<pii> q;
inline int rd()
{
int ret=0,f=1; char gc=getchar();
while(gc<‘0‘||gc>‘9‘) {if(gc==‘-‘)f=-f; gc=getchar();}
while(gc>=‘0‘&&gc<=‘9‘) ret=ret*10+gc-‘0‘,gc=getchar();
return ret*f;
}
void add(int a,int b,int c)
{
to[++cnt]=b,val[cnt]=c,next[cnt]=head[a],head[a]=cnt;
}
void dijkstra(int S)
{
memset(dis,0x3f,sizeof(dis));
memset(vis,0,sizeof(vis));
while(!q.empty()) q.pop();
q.push(mp(0,S)),dis[S]=0;
int i,u,tmp=0;
while(!q.empty())
{
u=q.top().second,q.pop();
if(vis[u]) continue;
vis[u]=1;
if(u<=k+1||u==n) tmp++;
if(tmp==k+2) break;
for(i=head[u];i;i=next[i]) if(dis[to[i]]>dis[u]+val[i])
dis[to[i]]=dis[u]+val[i],q.push(mp(-dis[to[i]],to[i]));
}
for(i=1;i<=k;i++) v[S-1][i]=dis[i+1];
if(!r[S-1]) f[1<<S-2][S-1]=dis[1];
g[S-1]=dis[n];
}
int main()
{
n=rd(),m=rd(),k=rd();
int i,j,h,a,b,c;
for(i=1;i<=m;i++) a=rd(),b=rd(),c=rd(),add(a,b,c),add(b,a,c);
if(!k)
{
dijkstra(1);
printf("%d\n",dis[n]);
return 0;
}
kk=rd();
for(i=1;i<=kk;i++) a=rd()-1,b=rd()-1,r[b]|=(1<<a-1);
memset(f,0x3f,sizeof(f));
for(i=2;i<=k+1;i++) dijkstra(i);
for(i=1;i<(1<<k);i++)
{
for(j=1;j<=k;j++) if(i&(1<<j-1)) for(h=1;h<=k;h++) if(!(i&(1<<h-1))&&(i&r[h])==r[h])
f[i|(1<<h-1)][h]=min(f[i|(1<<h-1)][h],f[i][j]+v[j][h]);
}
for(ans=1<<30,i=1;i<=k;i++) ans=min(ans,f[(1<<k)-1][i]+g[i]);
printf("%d",ans);
return 0;
}