/* cv uses a narrower max-width */
:root { --max: 820px; }

.page-hero { padding: 9rem 2.5rem 5rem; max-width: var(--max); margin: 0 auto; }
.page-eyebrow { font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--clay); margin-bottom: 1rem; }
h1.page-title { font-family: var(--serif); font-size: clamp(2.5rem, 5vw, 4rem); line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 1.25rem; }
.page-sub { font-size: 1.0625rem; font-weight: 300; color: var(--ink-mid); line-height: 1.75; max-width: 50ch; margin-bottom: 2rem; }
.download-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.625rem 1.5rem; border: 1px solid var(--sand);
  border-radius: 2rem; font-size: 0.875rem; color: var(--ink-mid);
  background: white; transition: border-color 0.2s, color 0.2s;
}
.download-btn:hover { border-color: var(--moss); color: var(--moss); }

hr.section-rule { border: none; border-top: 1px solid var(--paper-warm); margin: 0 2.5rem; }

.cv-body { max-width: var(--max); margin: 0 auto; padding: 4rem 2.5rem 6rem; }
.cv-section { margin-bottom: 4rem; }
.cv-section-label {
  font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--clay); margin-bottom: 1.75rem; padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--paper-warm);
}
.cv-entry {
  display: grid; grid-template-columns: 8rem 1fr; gap: 0 2rem;
  margin-bottom: 2.5rem; padding-bottom: 2.5rem;
  border-bottom: 1px solid var(--paper-warm);
}
.cv-entry:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.cv-period { font-size: 0.8125rem; color: var(--ink-soft); padding-top: 0.25rem; font-weight: 300; }
.cv-role { font-family: var(--serif); font-size: 1.3125rem; line-height: 1.2; margin-bottom: 0.25rem; }
.cv-company { font-size: 0.9375rem; color: var(--moss); font-weight: 400; margin-bottom: 0.875rem; }
.cv-entry-body { font-size: 0.9375rem; font-weight: 300; color: var(--ink-mid); line-height: 1.75; margin-bottom: 0.875rem; }
.cv-bullets { list-style: none; display: flex; flex-direction: column; gap: 0.375rem; font-size: 0.9375rem; font-weight: 300; color: var(--ink-mid); line-height: 1.65; }
.cv-bullets li::before { content: '→ '; color: var(--clay); margin-right: 0.25rem; }

.edu-entry { display: grid; grid-template-columns: 8rem 1fr; gap: 0 2rem; margin-bottom: 2rem; }

.skills-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.skills-group-label { font-size: 0.8125rem; font-weight: 500; letter-spacing: 0.04em; margin-bottom: 0.625rem; }
.skills-list { display: flex; flex-direction: column; gap: 0.25rem; font-size: 0.9rem; font-weight: 300; color: var(--ink-mid); }

.rec-entry { display: flex; align-items: baseline; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid var(--paper-warm); }
.rec-entry:first-child { border-top: 1px solid var(--paper-warm); }
.rec-year { font-size: 0.8125rem; color: var(--ink-soft); width: 4rem; flex-shrink: 0; }
.rec-name { font-size: 0.9375rem; font-weight: 400; flex: 1; }
.rec-org { font-size: 0.875rem; color: var(--ink-soft); font-weight: 300; }

@media (max-width: 640px) {
  .page-hero { padding: 7rem 1.25rem 3rem; }
  .cv-body { padding: 2.5rem 1.25rem 5rem; }
  .cv-entry, .edu-entry { grid-template-columns: 1fr; gap: 0.25rem; }
  .skills-grid { grid-template-columns: 1fr 1fr; }
  hr.section-rule { margin-inline: 1.25rem; }
}