:root {
  /* Dark theme — applied on screen. Print overrides below restore light. */
  --ink: #e6e7ea;
  --muted: #9aa0a6;
  --accent: #7fb3ff;
  --rule: #2a2f3a;
  --bg: #0e1014;
  --paper: #161a22;
  --shadow: 0 2px 24px rgba(0, 0, 0, 0.55);
  --max-width: 8.5in;
  --page-padding: 0.75in;
  --serif: "Georgia", "Times New Roman", Times, serif;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.45;
}

.resume {
  background: var(--paper);
  max-width: var(--max-width);
  margin: 24px auto;
  padding: var(--page-padding);
  box-shadow: var(--shadow);
  border-radius: 3px;
}

/* Name */
.resume h1 {
  font-family: var(--serif);
  font-size: 30pt;
  letter-spacing: 0.5px;
  margin: 0 0 6px 0;
  color: var(--ink);
  font-weight: 600;
}

/* Contact line + tagline directly after H1 — first two paragraphs */
.resume h1 + p {
  margin: 0;
  color: var(--muted);
  font-size: 10.5pt;
}
.resume h1 + p + p {
  margin: 4px 0 16px 0;
  color: var(--ink);
  font-size: 10.5pt;
  font-style: italic;
}

.resume a {
  color: var(--accent);
  text-decoration: none;
}
.resume a:hover { text-decoration: underline; }

/* Section headings */
.resume h2 {
  font-family: var(--serif);
  font-size: 12pt;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--accent);
  margin: 18px 0 8px 0;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--rule);
  font-weight: 700;
}

/* Job entry headings */
.resume h3 {
  font-size: 11.5pt;
  margin: 12px 0 4px 0;
  font-weight: 700;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1em;
}

.resume h3 .dates {
  font-weight: 400;
  font-style: italic;
  color: var(--muted);
  font-size: 10.5pt;
  white-space: nowrap;
}

.resume ul {
  margin: 4px 0 8px 0;
  padding-left: 1.2em;
}

.resume li {
  margin: 3px 0;
  font-size: 10.5pt;
  line-height: 1.4;
}

.resume p { font-size: 10.5pt; }

.resume strong { color: var(--ink); }

/* Print styling — match a clean, ATS-friendly resume PDF */
@page {
  size: Letter;
  margin: 0.5in;
}

@media print {
  /* Force light palette when printing, regardless of on-screen theme. */
  :root {
    --ink: #1a1a1a;
    --muted: #555;
    --accent: #0b3d91;
    --rule: #ccc;
    --bg: #ffffff;
    --paper: #ffffff;
    --shadow: none;
  }
  html, body {
    background: #fff;
    color: var(--ink);
    font-size: 10pt;
  }
  .resume {
    background: #fff;
    color: var(--ink);
    margin: 0;
    padding: 0;
    max-width: none;
    box-shadow: none;
    border-radius: 0;
  }
  .resume a {
    color: var(--ink);
    text-decoration: none;
  }
  /* Tighten vertical rhythm so the resume lands on a single Letter page. */
  .resume h1 {
    font-size: 22pt;
    margin: 0 0 2px 0;
  }
  .resume h1 + p {
    font-size: 10pt;
  }
  .resume h1 + p + p {
    font-size: 10pt;
    margin: 2px 0 8px 0;
  }
  .resume h2 {
    font-size: 11pt;
    margin: 10px 0 4px 0;
    padding-bottom: 2px;
    letter-spacing: 1.2px;
  }
  .resume h3 {
    font-size: 10.5pt;
    margin: 6px 0 2px 0;
  }
  .resume h3 .dates {
    font-size: 10pt;
  }
  .resume ul {
    margin: 2px 0 4px 0;
  }
  .resume li,
  .resume p {
    font-size: 10pt;
    line-height: 1.3;
    margin: 1.5px 0;
  }
  .resume h2 {
    page-break-after: avoid;
    break-after: avoid;
  }
  .resume h3 {
    page-break-after: avoid;
    break-after: avoid;
  }
  .resume li, .resume p {
    page-break-inside: avoid;
    break-inside: avoid;
  }
}
