Files
claude-resume-kit/resume_builder/templates/resume_template.tex
T
Akhil Reddy Peeketi c51b49882f Initial release — claude-resume-kit v1.0
Complete AI-assisted resume/CV generation framework:
- 6 Claude Code skills (setup-extract, setup-build-kb, make-resume, make-cl, edit-resume, critique)
- LaTeX templates (resume, CV, cover letter) with .cls class files
- 6 reference docs (shared_ops, resume_reference, cl_reference, critical_rules, session_file_template, critique_framework)
- Fictional Dr. Jordan Chen examples (extraction, experience, bundle, config, session, JD)
- Knowledge base scaffolding and config template
- README with setup guide and workflow documentation
2026-03-09 02:42:10 -06:00

237 lines
10 KiB
TeX

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% TEMPLATE: Resume (resume.cls) -- structural reference for Claude generation
% Copy this structure exactly. Replace [GENERATE: ...] placeholders with JD-tailored content.
% FIXED sections: contain actual data -- never modify during generation
% GENERATE sections: Claude fills in per JD using the uploaded bundle
%
% SETUP INSTRUCTIONS:
% 1. Fill [CONFIG: ...] markers with values from your config.md
% 2. Fill FIXED sections (Education, Awards, etc.) with your actual content
% 3. Leave [GENERATE: ...] markers -- Claude fills these per JD
% 4. Calibrate page budget after filling FIXED content (compile + count lines)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\documentclass{resume}
\usepackage{hyperref}
\usepackage{enumitem}
\usepackage{fontawesome}
\usepackage{tikz}
\usepackage{graphicx}
\hypersetup{
colorlinks = true,
linkcolor = [rgb]{0.9,0.4,0.4},
anchorcolor = [rgb]{0.9,0.4,0.4},
citecolor = [rgb]{0.4,0.4,0.4},
filecolor = [rgb]{0.4,0.4,0.4},
urlcolor = [rgb]{0.0,0.0,0.99},
}
\usepackage{xcolor}
\usepackage[version=4,arrows=pgf-filled]{mhchem}
\usepackage[includefoot,left=0.5in,top=0.5in,right=0.5in,bottom=0.2in,textwidth=7.5in,textheight=10.8in]{geometry}
\usepackage{fancyhdr}
\pagestyle{fancy}
\fancyhf{}
\renewcommand{\headrulewidth}{0pt}
\fancyfoot[R]{\hfill \thepage/\pageref{LastPage}}
\newcommand{\tab}[1]{\hspace{.2667\textwidth}\rlap{#1}}
\newcommand{\itab}[1]{\hspace{0em}\rlap{#1}}
%----------------------------------------------------------------------------------------
% HEADER — FIXED (fill from config.md)
%----------------------------------------------------------------------------------------
% FIXED: Name -- from config.md
\name{[CONFIG: Full Name, Degree]}
% FIXED: Links -- include whichever you have; delete unused lines
\address{\href{[CONFIG: website URL]}{[CONFIG: site display]} \\ \href{[CONFIG: LinkedIn URL]}{LinkedIn} \\ \href{[CONFIG: Google Scholar URL]}{Google Scholar}}
% FIXED: Contact
\address{[CONFIG: email] \\ [CONFIG: phone]}
% GENERATE: Relocation target per JD
\address{[CONFIG: City, State] (Open to relocation to [Target City])}
% GENERATE: Tagline -- rewrite per JD using bundle Section 2 building blocks
% Use $\vert$ as separator between tagline phrases
\address{{[GENERATE: Role Title $\vert$ Domain Specialty $\vert$ Key Method or Impact]}}
\begin{document}
%----------------------------------------------------------------------------------------
% GENERATION REFERENCE (for Claude -- not rendered in PDF)
%----------------------------------------------------------------------------------------
% CHARACTER LIMITS (rendered chars — strip \textbf{}, \textit{}, \ce{}, $..$ before counting):
% Chars per line (CPL): ~111-115 at 10pt (varies with char width distribution)
%
% Resume-1L bullet: target 105-111 chars | HARD MAX 117
% Resume-2L bullet: target 189-205 chars | HARD MAX 218 | orphan >= 78 chars
%
% AIM FOR TARGET MIDDLE (200 for 2L) — NOT the hard max.
% Em-dash (---) counts as 1 char but renders ~2x wide. Budget 2 extra per em-dash.
% Bold in bullets: ~0.42 penalty/bold char (10 bold chars ≈ lose 4 chars capacity).
%
% PAGE FILL BUDGET:
% After filling FIXED sections, compile and count rendered lines per page.
% Remaining lines = your variable bullet budget.
% Example for 2-page resume with 5 skill groups:
% Skills 4-3-2-2-2 (13 lines): ~21 variable bullets (2L each)
% Skills 4-4-2-2-2 (14 lines): ~20 variable bullets
% Variable bullets = sum of all GENERATE position bullets
% FIXED position bullets are NOT counted in the variable budget.
%
% POSITION FORMAT (FLIPPED):
% Bold line = JD-customized domain theme (strongest customization lever)
% Subtitle (italic) = formal role + institution
% FIXED positions keep the same theme in every resume.
\vspace{-0.15cm}
%----------------------------------------------------------------------------------------
% SUMMARY — GENERATE per JD
%----------------------------------------------------------------------------------------
% GENERATE: Rewrite per JD using bundle Section 2 building blocks
% 5 body lines (4-5 sentences). Lead with years of experience + primary methods.
% End with publication/citation metrics if applicable.
% Max 1 paragraph -- no line breaks.
\begin{rSection}{Summary}
[GENERATE: [Domain] scientist with [N]+ years combining \textbf{[primary method]} and \textbf{[secondary method]} for [application domain]. [1-2 sentences on key accomplishments tailored to JD]. [Metrics: publications, citations, awards if applicable].]
\end{rSection}
\vspace{-0.15cm}
%----------------------------------------------------------------------------------------
% TECHNICAL SKILLS — GENERATE per JD (Format C)
%----------------------------------------------------------------------------------------
% GENERATE: 5 groups in Format C (categorized dash sub-items)
% Default config from config.md (e.g. 4-3-2-2-2 = 13 content lines)
% Load skills_taxonomy.md to map JD keywords to skill entries
% Group names are JD-customizable; order most JD-relevant first
% Bold 6-8 tools that most directly match JD keywords
% Each dash item = exactly 1 rendered line (~105-111 chars), no wrapping
\begin{rSection}{Technical Skills}
% FORMAT C: Use \skillgroup{} and \skilldash{} commands from resume.cls
% Each \skilldash = exactly 1 rendered line. Char limit: 119 - (0.5 x bold_chars)
\begin{skillgroup}{[GENERATE: Most JD-Relevant Domain]}
\skilldash{[GENERATE: tools, methods — max ~105-111 chars with bold penalty]}
\skilldash{[GENERATE]}
\skilldash{[GENERATE]}
\end{skillgroup}
\begin{skillgroup}{[GENERATE: Second Domain]}
\skilldash{[GENERATE]}
\skilldash{[GENERATE]}
\end{skillgroup}
\begin{skillgroup}{[GENERATE: Third Domain]}
\skilldash{[GENERATE]}
\end{skillgroup}
\begin{skillgroup}{[GENERATE: Fourth Domain]}
\skilldash{[GENERATE]}
\end{skillgroup}
\begin{skillgroup}{[GENERATE: Programming \& Tools]}
\skilldash{[GENERATE]}
\end{skillgroup}
\end{rSection}
\vspace{-0.15cm}
%----------------------------------------------------------------------------------------
% EXPERIENCE — GENERATE bullets per JD; position headers are FIXED
%----------------------------------------------------------------------------------------
% Add one rSubsection per position. Most recent first.
% FLIPPED format: Bold line = JD-customized theme; italic = formal role + institution.
% Mark any position as FIXED if its bullets never change across JDs.
\begin{rSection}{Research Experience}
% --- Position 1 (most recent) ---
% GENERATE: Select bullets from bundle; bold theme line customized to JD
\begin{rSubsection}{[GENERATE: JD-Customized Theme]}{\textcolor{black!60}{[FIXED: Start -- End]}}{[FIXED: Title, Institution]}{}
\item [GENERATE: Bullet 1 -- strongest JD-relevant accomplishment]
\item [GENERATE: Bullet 2]
\item [GENERATE: ...]
\end{rSubsection}
% --- Position 2 ---
\begin{rSubsection}{[GENERATE: JD-Customized Theme]}{\textcolor{black!60}{[FIXED: Start -- End]}}{[FIXED: Title, Institution]}{}
\item [GENERATE: Bullet 1]
\item [GENERATE: ...]
\end{rSubsection}
% --- Position 3 ---
\begin{rSubsection}{[GENERATE: JD-Customized Theme]}{\textcolor{black!60}{[FIXED: Start -- End]}}{[FIXED: Title, Institution]}{}
\item [GENERATE: Bullet 1]
\item [GENERATE: ...]
\end{rSubsection}
% --- Optional: FIXED position (e.g. early-career internship that never changes) ---
% Uncomment and fill if you have a short position whose bullets are always the same:
% \begin{rSubsection}{[FIXED: Theme]}{\textcolor{black!60}{[FIXED: Dates]}}{[FIXED: Title, Institution]}{}
% \item [FIXED: Bullet — same in every resume]
% \item [FIXED: Bullet — same in every resume]
% \end{rSubsection}
\end{rSection}
\vspace{-0.15cm}
%----------------------------------------------------------------------------------------
% EDUCATION — FIXED: Fill with your actual education
%----------------------------------------------------------------------------------------
% Each entry: {Degree (honors)} \hfill {Years} \\ {Institution}, Location \hfill GPA
\begin{rSection}{Education}
{[FIXED: Degree Title]} \hfill {\textcolor{black!60}{[FIXED: Start -- End]}}\\
{[FIXED: Institution]}, [FIXED: Location] \hfill GPA: \textbf{[FIXED]}/[FIXED]
{[FIXED: Degree Title]} \hfill {\textcolor{black!60}{[FIXED: Start -- End]}}\\
{[FIXED: Institution]}, [FIXED: Location] \hfill GPA: \textbf{[FIXED]}/[FIXED]
\end{rSection}
\vspace{-0.15cm}
%----------------------------------------------------------------------------------------
% SELECTED PUBLICATIONS — GENERATE: Claude picks 5 per JD relevance
%----------------------------------------------------------------------------------------
% GENERATE: Score publications per JD relevance using pub_metadata.md
% Copy-paste FIXED author + journal LaTeX blocks from pub_metadata.md
% GENERATE JD-shortened title + JD-relevant keyword tags at runtime
% 2-line hard limit per entry, last line >= 70% filled
% Prioritize: first-author > co-first > contributing; high-impact > standard
\begin{rSection2}{Selected Publications (\href{[CONFIG: Google Scholar URL]}{Google Scholar}: [FIXED: N] papers $\vert$ [FIXED: N]+ citations)}
\item [GENERATE: Publication 1 -- most JD-relevant, short format]
\item [GENERATE: Publication 2]
\item [GENERATE: Publication 3]
\item [GENERATE: Publication 4]
\item [GENERATE: Publication 5]
\end{rSection2}
\vspace{-0.15cm}
%----------------------------------------------------------------------------------------
% HONORS & AWARDS — FIXED: Fill with your actual awards
%----------------------------------------------------------------------------------------
% Format: \item \textbf{Award}, Granting Body (Year)---brief context.
% Aim for 1 rendered line each. Adjust count to fit page budget.
\begin{rSection2}{Honors \& Awards}
\item \textbf{[FIXED: Award]}, [FIXED: Body] ([FIXED: Year])---[FIXED: context].
\item \textbf{[FIXED: Award]}, [FIXED: Body] ([FIXED: Year])---[FIXED: context].
\item \textbf{[FIXED: Award]}, [FIXED: Body] ([FIXED: Year])---[FIXED: context].
\end{rSection2}
\vspace{-0.1cm}
%----------------------------------------------------------------------------------------
% IMMIGRATION — FIXED content, include/exclude per JD
% USA JD: keep this block | Non-USA JD: delete (frees ~2 lines)
%----------------------------------------------------------------------------------------
\begin{center}
\vspace{0.15cm}
\textit{[CONFIG: Immigration status line from config.md]}
\end{center}
\end{document}