/* =====================================================================
   Résumé — standalone page (resume.html does NOT load the site styles).
   Pure black & white, flips with the site's data-view-mode theme.
   ===================================================================== */

.resume-page {
  --bg: #ffffff;
  --fg: #111111;
  --muted: #666666;
  --rule: #e6e6e6;
  --rule-strong: #111111;

  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
html[data-view-mode="dark"] .resume-page {
  --bg: #0c0c0c;
  --fg: #f2f2f2;
  --muted: #9a9a9a;
  --rule: #262626;
  --rule-strong: #f2f2f2;
}

.resume-page *,
.resume-page *::before,
.resume-page *::after { box-sizing: border-box; }

.resume-page a { color: inherit; }

/* ---- Top bar: logo + actions only ---- */
.cv-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 900px;
  margin: 0 auto;
  padding: 1.4rem 1.6rem;
}
.cv-logo { display: inline-flex; }
.cv-logo img { height: 28px; width: auto; display: block; }
.cv-logo .cv-logo-dark { display: none; }
html[data-view-mode="dark"] .cv-logo .cv-logo-light { display: none; }
html[data-view-mode="dark"] .cv-logo .cv-logo-dark { display: block; }

.cv-topbar-actions { display: flex; align-items: center; gap: .6rem; }
.cv-btn {
  font: inherit;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .01em;
  padding: .5rem 1rem;
  border: 1px solid var(--fg);
  border-radius: 999px;
  background: transparent;
  color: var(--fg);
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.cv-btn:hover { background: var(--fg); color: var(--bg); }
.cv-mode {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  border: 1px solid var(--rule);
  border-radius: 999px;
  background: transparent;
  color: var(--fg);
  cursor: pointer;
}
.cv-mode:hover { border-color: var(--fg); }
.cv-mode svg { width: 18px; height: 18px; }
.cv-mode .moon { display: none; }
html[data-view-mode="dark"] .cv-mode .sun { display: none; }
html[data-view-mode="dark"] .cv-mode .moon { display: block; }

/* ---- Document ---- */
.cv {
  max-width: 820px;
  margin: 0 auto;
  padding: 1.5rem 1.6rem 6rem;
}

.cv-head {
  padding-bottom: 1.6rem;
  margin-bottom: 2.2rem;
  border-bottom: 1.5px solid var(--rule-strong);
}
.cv-name {
  margin: 0;
  font-size: clamp(2rem, 5.5vw, 2.9rem);
  font-weight: 800;
  letter-spacing: -.025em;
  line-height: 1.02;
}
.cv-title {
  margin: .5rem 0 0;
  font-size: 1.12rem;
  font-weight: 600;
}
.cv-tagline {
  margin: .7rem 0 0;
  max-width: 50ch;
  color: var(--muted);
  font-size: 1.02rem;
}
.cv-contact {
  margin: 1.1rem 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: .3rem 1.2rem;
  font-size: .9rem;
}
.cv-contact a {
  text-decoration: none;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 1px;
}
.cv-contact a:hover { border-color: var(--fg); }
.cv-facts {
  margin: 1rem 0 0;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .015em;
  color: var(--muted);
}

.cv-section { margin: 0 0 2.5rem; }
.cv-section > h2 {
  margin: 0 0 1.2rem;
  font-size: .74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--muted);
  padding-bottom: .55rem;
  border-bottom: 1px solid var(--rule);
}
.cv-summary { margin: 0; font-size: 1.02rem; max-width: 72ch; }

/* Experience */
.cv-job { margin: 0 0 1.9rem; }
.cv-job:last-child { margin-bottom: 0; }
.cv-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1.2rem;
  flex-wrap: wrap;
}
.cv-job h3 { margin: 0; font-size: 1.14rem; font-weight: 700; letter-spacing: -.01em; }
.cv-org { margin: .15rem 0 0; color: var(--muted); font-size: .92rem; }
.cv-dot { opacity: .55; }
.cv-dates {
  font-size: .8rem;
  color: var(--muted);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.cv-lead { margin: .6rem 0 .5rem; }
.cv-bullets { margin: .45rem 0 0; padding: 0; list-style: none; }
.cv-bullets li { position: relative; padding-left: 1.15rem; margin: .32rem 0; }
.cv-bullets li::before {
  content: "";
  position: absolute;
  left: 2px;
  top: .62em;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--fg);
}

/* ThoughtWorks client engagements: nested under the role */
.cv-clients {
  margin: 1rem 0 0;
  padding-left: 1.2rem;
  border-left: 1px solid var(--rule);
  display: grid;
  gap: 1.25rem;
}
.cv-client h4 { margin: 0; font-size: .98rem; font-weight: 600; }
.cv-loc { color: var(--muted); font-weight: 400; }

/* Earlier experience */
.cv-earlier { list-style: none; margin: 0; padding: 0; }
.cv-earlier li {
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: 1.2rem;
  padding: .6rem 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.cv-earlier li:last-child { border-bottom: 0; }
.cv-earlier-role { grid-column: 1; grid-row: 1; font-weight: 600; }
.cv-earlier-org { grid-column: 1; grid-row: 2; color: var(--muted); font-size: .9rem; }
.cv-earlier .cv-dates { grid-column: 2; grid-row: 1 / span 2; align-self: center; }

/* Skills */
.cv-skills { margin: 0; display: grid; gap: 1rem; }
.cv-skills > div {
  display: grid;
  grid-template-columns: 190px 1fr;
  gap: .4rem 1.6rem;
  align-items: baseline;
}
.cv-skills dt { margin: 0; font-weight: 600; font-size: .92rem; }
.cv-skills dd { margin: 0; font-size: .96rem; }

/* Education + Certifications */
.cv-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 2.6rem; }
.cv-plain { list-style: none; margin: 0; padding: 0; }
.cv-plain li { margin: 0 0 .7rem; }
.cv-muted { color: var(--muted); font-size: .9rem; }

@media (max-width: 640px) {
  .cv-skills > div { grid-template-columns: 1fr; gap: .15rem; }
  .cv-two-col { grid-template-columns: 1fr; gap: 1.8rem; }
  .cv-topbar, .cv { padding-left: 1.1rem; padding-right: 1.1rem; }
}

/* Basic print pass (polish comes later): drop the toolbar, ink-friendly. */
@media print {
  .resume-page { --bg: #fff; --fg: #000; --muted: #444; --rule: #ccc; --rule-strong: #000; font-size: 10.5pt; }
  .cv-topbar { display: none !important; }
  .cv { max-width: none; margin: 0; padding: 0; }
  .cv-section, .cv-job, .cv-client { page-break-inside: avoid; }
  .cv-section > h2 { page-break-after: avoid; }
  .cv-contact a { border: 0; }
}

/* =====================================================================
   Cover letter generator (extends base.html; uses the site theme).
   ===================================================================== */
.resume-doc { line-height: 1.5; }
.resume-meta { font-size: .85rem; opacity: .72; margin: .1rem 0 .4rem; }

.cover-tool {
  max-width: 980px;
  margin: 0 auto;
  padding: 1.5rem 1.25rem 4rem;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 2rem;
  align-items: start;
}
.cover-form h1 { margin: 0 0 .25rem; font-size: 1.5rem; }
.cover-form label {
  display: block;
  margin: .9rem 0 0;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .02em;
}
.cover-form input,
.cover-form textarea {
  display: block;
  width: 100%;
  margin-top: .3rem;
  padding: .5rem .6rem;
  font: inherit;
  font-weight: 400;
  border: 1px solid rgba(128, 128, 128, .4);
  border-radius: 6px;
  background: transparent;
  color: inherit;
}
.cover-form textarea { resize: vertical; }
.cover-actions { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; margin-top: 1.1rem; }

.cover-letter {
  max-width: none;
  padding: 2.25rem 2rem;
  border: 1px solid rgba(128, 128, 128, .25);
  border-radius: 10px;
}
.cover-letter p { margin: 0 0 1rem; }
.cover-sender { line-height: 1.4; }
.cover-date { opacity: .8; }
.cover-sign { margin-top: 1.5rem; }

@media (max-width: 760px) {
  .cover-tool { grid-template-columns: 1fr; }
}

@media print {
  .cover-form, .cover-actions { display: none !important; }
  .cover-tool { display: block; max-width: none; padding: 0; }
  .cover-letter { border: none; border-radius: 0; padding: 0; max-width: none; color: #000; }
  .cover-letter a { color: #000; text-decoration: none; }
  #header, .header-container, .availability-pill { display: none !important; }
}
