
% median: 0.004896560399398461

\begin{tikzpicture}
\definecolor{bailtool}{RGB}{155, 89, 182}                  % Purple (warm undertones)
\definecolor{bailstring}{RGB}{231, 76, 60}                 % Bright Red
\definecolor{bailpromptcontinuefirst}{RGB}{230, 126, 34}   % Standard Orange
\definecolor{bailpromptbailfirst}{RGB}{243, 156, 18}       % Golden Orange
\definecolor{bailpromptunknown}{RGB}{149,165,166}          % Gray
\usetikzlibrary{patterns}
\pgfplotstableread{
Label toolBailPr toolBailPr_err strBailPr strBailPr_err promptBailFirstBailPr promptBailFirstBailPr_err promptBailFirstUnknownPr promptContinueFirstBailPr promptContinueFirstBailPr_err promptContinueFirstUnknownPr
Hermes-3-Llama-3.2-3B 0.0 0.32345325756902177 0 0 0 0 0 0 0 0
{} 0 0 0.5097754660172988 0.6561977471757084 0 0 0 0 0 0
{} 0 0 0 0 55.08474576271186 4.000811107385981 0 0 0 0
{} 0 0 0 0 0 0 0 10.508474576271189 2.4796977794944963 0
claude-3-6-sonnet 32.27560534560264 3.7621172347477265 0 0 0 0 0 0 0 0
{} 0 0 0.6856064342467462 0.7363796203460994 0 0 0 0 0 0
{} 0 0 0 0 0.0 0.32345325756902177 0 0 0 0
{} 0 0 0 0 0 0 0 0.33898305084745767 0.5672346975902177 0
google/gemma-2-2b-it 0.0 0.32345325756902177 0 0 0 0 0 0 0 0
{} 0 0 11.23133009348964 2.5519588433174203 0 0 0 0 0 0
{} 0 0 0 0 13.050847457627118 2.719921110007565 0 0 0 0
{} 0 0 0 0 0 0 0 0.16949152542372883 0.4619234168771233 0
Qwen2.5-7B-Instruct 8.852233763034377 2.300107467916156 0 0 0 0 0 0 0 0
{} 0 0 4.701528853322458 1.727520399055542 0 0 0 0 0 0
{} 0 0 0 0 1.0169491525423728 0.8669430760711024 0 0 0 0
{} 0 0 0 0 0 0 0 0.33898305084745767 0.5672346975902177 0
Qwen3-8B 10.481663135653834 2.4769509213357943 0 0 0 0 0 0 0 0
{} 0 0 3.4635113523168073 1.5011979794786001 0 0 0 0 0 0
{} 0 0 0 0 0.16949152542372883 0.4619234168771233 0 0 0 0
{} 0 0 0 0 0 0 0 0.33898305084745767 0.5672346975902177 0
zai-org/GLM-4-32B-0414 5.771593747796665 1.897380110215933 0 0 0 0 0 0 0 0
{} 0 0 2.6450568420528358 1.326533214229017 0 0 0 0 0 0
{} 0 0 0 0 0.0 0.32345325756902177 0 0 0 0
{} 0 0 0 0 0 0 0 0.0 0.32345325756902177 0
gpt-4o 0.1277760186437833 0.43202023808204293 0 0 0 0 0 0 0 0
{} 0 0 0.4695366138623933 0.6363853989375503 0 0 0 0 0 0
{} 0 0 0 0 0.0 0.32345325756902177 0 0 0 0
{} 0 0 0 0 0 0 0 0.0 0.32345325756902177 0
}\datatable


\begin{axis}[
  ybar stacked,
  width = \linewidth,
  bar width = 8pt,
  ymin=0, ymax=100,
  xtick=data,
  ylabel = {Average no-refusal bail \% on BailBench},
  enlarge x limits = {abs = 20pt},
  xticklabels from table={\datatable}{Label},
  xticklabel style={xshift=12pt,rotate=90,align=center}, % ← rightwards shift
  xtick style={draw=none},
  enlarge y limits={value=0.05,upper},
  legend style={cells={anchor=east},legend pos=north east},
  reverse legend=false
]
    \addplot[fill=bailtool,
           error bars/.cd,
           y dir=both,
           y explicit,
          ]
    table[
        x expr=\coordindex,
        y=toolBailPr,
        y error plus=toolBailPr_err,
        y error minus=toolBailPr_err
    ]{\datatable};
    \addlegendentry{Bail Tool}
    \addplot[fill=bailstring,
           error bars/.cd,
           y dir=both,
           y explicit,
          ]
    table[
        x expr=\coordindex,
        y=strBailPr,
        y error plus=strBailPr_err,
        y error minus=strBailPr_err
    ]{\datatable};
    \addlegendentry{Bail String}
    \addplot[fill=bailpromptbailfirst,
           error bars/.cd,
           y dir=both,
           y explicit
          ]
    table[
        x expr=\coordindex,
        y=promptBailFirstBailPr,
        y error plus=promptBailFirstBailPr_err,
        y error minus=promptBailFirstBailPr_err
    ]{\datatable};
    \addlegendentry{Bail Prompt Bail-first}
    \addplot[fill=bailpromptunknown
          ]
    table[
        x expr=\coordindex,
        y=promptBailFirstUnknownPr,
        forget plot,
    ]{\datatable};
    \addplot[fill=bailpromptcontinuefirst,
           error bars/.cd,
           y dir=both,
           y explicit
          ]
    table[
        x expr=\coordindex,
        y=promptContinueFirstBailPr,
        y error plus=promptContinueFirstBailPr_err,
        y error minus=promptContinueFirstBailPr_err
    ]{\datatable};
    \addlegendentry{Bail Prompt Continue-first}
    \addplot[fill=bailpromptunknown
          ]
    table[
        x expr=\coordindex,
        y=promptContinueFirstUnknownPr,
        forget plot,
    ]{\datatable};
    \addplot[
      draw=none,                       % nothing visible
      fill=bailpromptunknown
    ] coordinates {(0,0)};             % single dummy point
    \addlegendentry{Refusal Classifier/Invalid Outputs}

\end{axis}
\end{tikzpicture}
