role: system
task: |
  You are given LaTeX Beamer slide code as input.
  Your goal is to transform it into an **annotated version** that:
    - Preserves the original figure and text block sizes, positions, and content.
    - Adds visible annotations (red arrows + labels) indicating the width and height of each figure and text block, based on their current settings.
    - Does not change layout, scaling, or aspect ratio.
    - Removes any unrelated or unnecessary code.
    - Produces a clean, fully compilable output under `tectonic`.

  Transformation rules:

  1. **Theme and Packages**
     - Set theme to `Madrid` and color theme to `default`.
     - Add `\special{pdf:minorversion 6}` after theme setup.
     - Ensure packages: `inputenc` (utf8), `amsmath, amssymb`, `graphicx`, `booktabs`, `hyperref`, `tikz` (with `calc,positioning`), `enumitem`.
     - Add `enumitem` and configure compact list spacing:
       ```latex
       \setlist[itemize]{leftmargin=*, labelsep=0.4em, topsep=2pt, itemsep=2pt, parsep=0pt, partopsep=0pt}
       ```


  2. **Figure Handling**
     - Only apply when there are figures in the slide
     - Keep the original width and height settings of figures.
     - Wrap each figure in:
       ```latex
       \begin{center}
         \begin{tikzpicture}[remember picture]
           \node[inner sep=0] (figA/figB/...)
             {\includegraphics[<original options>]{<filename>}};
         \end{tikzpicture}
       \end{center}
       ```
     - If there are caption, it should not be a node. do not use \captionof
     - **Keep <filename> should be the same path exactly as in the original code

  3. **Text Block Handling** 
     - Only apply when there are text blocks in the slide
     - Keep the original width and alignment.
     - Wrap each bullet list or text block in:
       ```latex
       {
       \begin{tikzpicture}[remember picture]
         \node[inner sep=0, anchor=west] (txtA/txtB/...) {%
           \begin{minipage}{<original width>}
             <original content>
           \end{minipage}
         };
       \end{tikzpicture}
       }
       ```

  4. **Overlay Annotations**
     - After the main content, add:
       ```latex
       \begin{tikzpicture}[remember picture, overlay]
         % Figure width
         \draw[<->, thick, red]
           ([yshift=0.1em]figA.north west) --
           ([yshift=0.1em]figA.north east)
           node[midway, yshift=0.6em, text=red] {Width: <value>};

         % Figure height
         \draw[<->, thick, red]
           ([xshift=-0.1em]figA.south west) --
           ([xshift=-0.1em]figA.north west)
           node[midway, xshift=-0.6em, text=red, rotate=90] {Height: <value>};

         % Text width
         \draw[<->, thick, red]
           ([yshift=0.1em]txtA.north west) --
           ([yshift=0.1em]txtA.north east)
           node[midway, yshift=0.6em, text=red] {Text Width: <value>};

         % Text height
         \draw[<->, thick, red]
           ([xshift=-0.1em]txtA.south west) --
           ([xshift=-0.1em]txtA.north west)
           node[midway, xshift=-0.6em, text=red, rotate=90] {Text Height:  <value>};
       \end{tikzpicture}
       ```
     - Keep measurement values or LaTeX length macros exactly as in the original code. (e.g. \textwidth)

  5. **Output Requirements**
     - Output only the transformed LaTeX code.
     - Must compile without error.
     - No added text beyond required annotations.
     - Layout and proportions must remain unchanged.

input: |
  The provided Beamer code is:
