\documentclass[margin=2pt]{standalone}

\usepackage{amsmath,amsfonts}
\usepackage{booktabs}
\usepackage{xifthen}
\usepackage[dvipsnames]{xcolor}
\usepackage{tikz}
\usetikzlibrary{positioning}
\usetikzlibrary{arrows}
\usetikzlibrary{calc,fit}
\usetikzlibrary{shapes.geometric}
\usetikzlibrary{shapes.misc}
\usetikzlibrary{decorations.pathmorphing}
\usetikzlibrary{decorations.pathreplacing}
\usetikzlibrary{snakes}

\begin{document}
\begin{tikzpicture}[every node/.style={inner sep=0pt}, var/.style={draw=black, minimum size=7pt, circle, font=\small, thick, anchor=center, fill=white}, edge/.style={-latex, thick}, flowlabel/.style={midway, font=\scriptsize}, rewardlabel/.style={pos=1, font=\scriptsize, right}, gfn_edge/.style={ultra thick, -latex, draw=black!70}, gfn_node/.style={ultra thick, circle, draw, text height=3.5em}, gfn_other/.style={pos=1, anchor=west, inner sep=2pt}, adjacency/.style={minimum width=10pt, minimum height=10pt, rectangle, rounded corners=2pt, font=\bfseries\scriptsize}, y=12pt, x=50pt]

\colorlet{color1}[rgb]{NavyBlue}
\colorlet{color2}[rgb]{NavyBlue!10}

\fill[fill=gray!10] (0, 0) circle (21em) {};
\fill[fill=white] (0, 0) circle (15em) {};
\fill[fill=gray!10] (0, 0) circle (9em) {};
\fill[fill=white] (0, 0) circle (3em) {};

\colorlet{cmap}[rgb]{color1!0.00!color2}
\node[gfn_node, fill=cmap] (G0) at (0, 0) {};

\foreach \v [count=\j from 0, evaluate=\j as \i using int(\j*60)] in {
0.00, 0.00, 0.00, 0.00, 0.00, 0.00} {
    \node[gfn_node, fill=cmap] (G1_\i) at (\i:6em) {};
}

\foreach  \v [count=\j from 0, evaluate=\j as \i using int(\j*30)] in {
0.00, 0.00, 0.00, 100.00, 0.00, 0.00, 0.00, 88.18, 0.00, 0.00, 0.00, 56.10} {
    \colorlet{cmap}[rgb]{color1!\v!color2}
    \node[gfn_node, fill=cmap, font=\small] (G2_\i) at (\i:12em) {};
}

\foreach \v [count=\j from 0, evaluate=\j as \i using int(\j*60)] in {
16.29, 16.29, 16.29, 16.29, 16.29, 16.29} {
    \colorlet{cmap}[rgb]{color1!\v!color2}
    \node[gfn_node, fill=cmap] (G3_\i) at (\i:18em) {};
}

\foreach \i in {0,60,...,300} {
    \draw[gfn_edge] (G0) -- (G1_\i);
}

\foreach \i [
    evaluate=\i as \j using {int(mod(\i+60, 360))},
    evaluate=\i as \k using {int(mod(\i+300, 360))},
    evaluate=\i as \u using {int(mod(\i+30, 360))},
    evaluate=\i as \v using {int(mod(\i+330, 360))}
] in {0,60,...,300} {
    \draw[gfn_edge] (G1_\i) to[bend left=-10] (G2_\j);
    \draw[gfn_edge] (G1_\i) to[bend right=10] (G2_\k);
    \ifthenelse{
        \( \i = 60 \AND \u = 90 \) \OR
        \( \i = 180 \AND \u = 210 \) \OR
        \( \i = 300 \AND \u = 330 \)
    }{}{\draw[gfn_edge] (G1_\i) -- (G2_\u);}
    \ifthenelse{
        \( \i = 120 \AND \v = 90 \) \OR
        \( \i = 240 \AND \v = 210 \) \OR
        \( \i = 0 \AND \v = 330 \)
    }{}{\draw[gfn_edge] (G1_\i) -- (G2_\v);}
}

\foreach \i [
    evaluate=\i as \j using {int(mod(\i+30, 360))},
    evaluate=\i as \k using {int(mod(\i+330, 360))}
] in {0,60,...,300} {
    \draw[gfn_edge] (G2_\j) to[bend left=10] (G3_\i);
    \draw[gfn_edge] (G2_\k) to[bend right=10] (G3_\i);
    \draw[gfn_edge] (G2_\i) -- (G3_\i);
}

\foreach \i [
    evaluate=\i as \j using {int(mod(\i+30, 360))},
    evaluate=\i as \k using {int(mod(\i+330, 360))}
]in {90,210,330} {
    \draw[edge, draw=Red, line width=3pt] (G1_\j) -- (G2_\i);
    \draw[edge, draw=Red, line width=3pt] (G1_\k) -- (G2_\i);
}

% Level 0

\node[yshift=1pt] at (G0) {\begin{tikzpicture}
    \foreach \i in {90,210,330} {
        \node[var] (X\i) at (\i:10pt) {};
    }
\end{tikzpicture}};

% Level 1

\foreach \u/\v [
    count=\j from 0,
    evaluate=\j as \k using {int(60*\j)}
] in {210/330,210/90,330/90,330/210,90/210,90/330} {
\node[yshift=1pt] at (G1_\k) {\begin{tikzpicture}
    \foreach \i in {90,210,330} {
        \node[var] (X\i) at (\i:10pt) {};
    }
    \draw[edge] (X\u) -- (X\v);
\end{tikzpicture}};
}

% Level 2

\foreach \s/\t/\u/\v [
    count=\j from 0,
    evaluate=\j as \k using {int(30*\j)}
] in {
90/330/210/90,210/330/210/90,210/330/330/90,330/90/210/90,
210/90/330/210,330/90/330/210,90/210/330/90,330/210/90/210,
330/210/90/330,90/210/90/330,90/210/210/330,210/330/90/330} {
\node[yshift=1pt] at (G2_\k) {\begin{tikzpicture}
    \foreach \i in {90,210,330} {
        \node[var] (X\i) at (\i:10pt) {};
    }
    \draw[edge] (X\s) -- (X\t);
    \draw[edge] (X\u) -- (X\v);
\end{tikzpicture}};
}

% Level 3

\foreach \s/\t/\u/\v/\x/\y [
    count=\j from 0,
    evaluate=\j as \k using {int(60*\j)}
] in {
210/330/90/330/210/90,210/330/210/90/330/90,
330/90/210/90/330/210,330/210/330/90/90/210,
90/210/330/210/90/330,90/210/90/330/210/330} {
\node[yshift=1pt] at (G3_\k) {\begin{tikzpicture}
    \foreach \i in {90,210,330} {
        \node[var] (X\i) at (\i:10pt) {};
    }
    \draw[edge] (X\s) -- (X\t);
    \draw[edge] (X\u) -- (X\v);
    \draw[edge] (X\x) -- (X\y);
\end{tikzpicture}};
}

\node[above=5pt of G2_90, font=\Large] {$G^{\star}$};

\end{tikzpicture}
\end{document}