@page {
  size: Letter;
  margin: 0.34in 0.38in 0.4in;
}

:root {
  --font-display: "Space Grotesk", "Arial Narrow", sans-serif;
  --font-body: "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif;
  --color-paper: #ffffff;
  --color-ink: #111111;
  --color-ink-soft: #222222;
  --color-rule: rgba(0, 0, 0, 0.18);
  --color-panel: transparent;
  --size-hero: 2.52rem;
  --size-h2: 1rem;
  --size-body: 8.95pt;
  --size-small: 7.5pt;
  --size-metric: 1.35rem;
  --space-2: 0.28rem;
  --space-3: 0.34rem;
  --space-4: 0.42rem;
  --space-5: 0.58rem;
  --space-6: 0.72rem;
  --space-7: 0.9rem;
}

html,
body {
  background: #ffffff;
}

body {
  margin: 0;
  color: var(--color-ink);
  font-size: var(--size-body);
  line-height: 1.28;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}

.screen-only,
.skip-link,
.proof-lab,
.site-footer,
.site-header,
.hero::before,
.hero::after,
.section-nav,
.print-hint,
.hero__actions,
.latest-writing-frame {
  display: none !important;
}

.page-shell {
  padding: 0;
}

.page-frame {
  width: auto;
  margin: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  backdrop-filter: none;
}

.hero,
.section {
  padding: 0;
}

.hero {
  margin-bottom: var(--space-6);
}

.hero__grid {
  display: grid;
  grid-template-columns: 1.6fr 0.9fr;
  gap: 0.6rem;
}

.eyebrow {
  margin-bottom: 0.18rem;
  font-size: 7.5pt;
  color: #3c3c3c;
}

.hero h1 {
  font-size: var(--size-hero);
  max-width: none;
  margin-bottom: 0.1rem;
}

.hero__role {
  margin: 0 0 0.06rem;
  font-size: 10.8pt;
}

.hero__focus,
.hero__summary {
  margin: 0.05rem 0 0;
  font-size: 8.05pt;
  color: var(--color-ink-soft);
}

.contact-card {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.contact-card__label {
  font-size: 7.2pt;
  color: #4d4d4d;
}

.contact-card__value {
  margin: 0 0 0.08rem;
  font-size: 9.3pt;
}

.contact-list {
  gap: 0.03rem;
  font-size: 7.8pt;
}

.resume-core {
  display: block;
}

.section + .section {
  border-top: 0;
  margin-top: 0.34rem;
}

.section-heading {
  gap: 0.35rem;
  margin-bottom: 0.18rem;
}

.section-heading__index {
  font-size: 7pt;
}

.section-heading h2 {
  font-size: var(--size-h2);
  letter-spacing: 0.01em;
}

.summary-block .lede,
.competency-card p,
.role-card__company-meta,
.role-card__bullets li,
.education-line {
  font-size: 7.8pt;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.24rem;
}

.stat-card {
  min-height: auto;
  padding: 0.3rem;
  border: 1px solid rgba(0, 0, 0, 0.14);
  border-radius: 0.16rem;
  background: transparent;
  break-inside: avoid;
}

.stat-card::after {
  display: none;
}

.stat-card__value {
  margin-bottom: 0.08rem;
  font-size: var(--size-metric);
}

.stat-card__label {
  margin-bottom: 0.08rem;
  font-size: 7.8pt;
}

.stat-card__meta {
  font-size: 7pt;
}

.competency-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.24rem 0.45rem;
}

.competency-card {
  padding: 0.16rem 0 0.16rem 0.3rem;
  border-left-width: 0.11rem;
  background: transparent;
  break-inside: avoid;
}

.competency-card h3 {
  margin-bottom: 0.05rem;
  font-size: 7.85pt;
}

.role-card {
  padding: 0.24rem 0 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  break-inside: avoid;
}

.role-card:first-of-type {
  padding-top: 0;
}

.role-card--featured::before {
  left: -0.18rem;
  width: 0.1rem;
}

.role-card__header {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 0.34rem;
}

.role-card__header h3 {
  font-size: 8.9pt;
}

.role-card__company-meta,
.role-card__title {
  margin-top: 0.04rem;
}

.role-card__title {
  font-size: 7.6pt;
}

.role-card__bullets {
  margin-top: 0.12rem;
  gap: 0.05rem;
  padding-left: 0.78rem;
}

.role-card__descriptor {
  display: none;
}

.education-line {
  margin-top: 0.05rem;
}
