import collections,sys,math,functools,operator,itertools,bisect,heapq,decimal,string,time,random #sys.setrecursionlimit(10**9) #sys.set_int_max_str_digits(0) #input = sys.stdin.readline n = int(input()) se = [set() for i in range(n)] a = [] for i in range(n): check = [0 for j in range(26)] s = input().rstrip() a.append(s) for j in s: check[ord(j) - ord('a')] += 1 for j in range(26): check[j] += 1 se[i].add(tuple(check)) check[j] -= 1 dist = [[10**18 for i in range(n)] for j in range(n)] for i in range(n): for j in range(n): if len(a[i]) != len(a[j]): continue dist[i][j] = 0 for k in range(len(a[i])): dist[i][j] += 1 if a[i][k] != a[j][k] else 0 for i in range(n): for j in se[i]: cnt = 0 for k in range(n): if k == i: continue if len(a[i]) != len(a[k]) or dist[i][k] >= 2: continue if j in se[k]: cnt += 1 if cnt == 0: for k in range(26): for l in range(j[k]): print(chr(ord('a') + k),end='') print() exit() print(-1)