/* Print-first CV. Source for cv.pdf — regenerate with:
   chromium --headless --print-to-pdf=cv.pdf --no-pdf-header-footer cv.html */
/* screen: dark, matching the site — print flips to light (see @media print) */
:root {
  --text:   #e6e9ef;
  --muted:  #9aa3b2;
  --accent: #4ade80;
  --border: #232936;
  --bg:     #0c0e12;
  --mono: "SF Mono", "JetBrains Mono", "Fira Code", ui-monospace, Menlo, Consolas, monospace;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}
@media print {
  :root {
    --text:   #1a2030;
    --muted:  #5a6474;
    --accent: #16a34a;
    --border: #d8dde6;
    --bg:     #fff;
  }
}
@page { size: A4; margin: 0; }
* { box-sizing: border-box; }
body {
  margin: 0 auto;
  max-width: 210mm;
  padding: 9mm 17mm;
  font-family: var(--font);
  font-size: 10pt;
  line-height: 1.45;
  color: var(--text);
  background: var(--bg);
}
/* the page canvas around the CV column stays dark on screen too */
html { background: var(--bg); }
a { color: inherit; text-decoration: none; }
.placeholder { color: #b45309; font-style: italic; }

header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  border-bottom: 2px solid var(--accent);
  padding-bottom: 5mm;
  margin-bottom: 6mm;
}
h1 { margin: 0; font-size: 20pt; letter-spacing: -0.02em; }
.handle { font-family: var(--mono); color: var(--accent); font-size: 11pt; }
.subtitle { margin: 1mm 0 0; color: var(--muted); }
.contact {
  text-align: right;
  font-family: var(--mono);
  font-size: 8.5pt;
  color: var(--muted);
  line-height: 1.7;
}
.contact a { color: var(--text); }

h2 {
  font-family: var(--mono);
  font-size: 10pt;
  font-weight: 600;
  color: var(--accent);
  margin: 3.2mm 0 1.5mm;
  letter-spacing: 0.02em;
}
h2::before { content: "~/"; opacity: 0.6; }

p { margin: 0 0 2mm; }

.entry { display: flex; gap: 5mm; margin-bottom: 1.6mm; }
.entry-when {
  flex: 0 0 26mm;
  font-family: var(--mono);
  font-size: 8.5pt;
  color: var(--muted);
  padding-top: 0.8mm;
}
.entry-what strong { display: block; }
.entry-what span { color: var(--muted); }

.project { margin-bottom: 2mm; }
.project strong { font-weight: 600; }
.project .link { font-family: var(--mono); font-size: 8.5pt; color: var(--accent); margin-left: 2mm; }
.project p { color: var(--muted); margin: 0; }

.stack-row { display: flex; gap: 4mm; margin-bottom: 1.2mm; }
.stack-label {
  flex: 0 0 26mm;
  font-family: var(--mono);
  font-size: 8.5pt;
  color: var(--muted);
  padding-top: 0.6mm;
}

footer {
  margin-top: 2mm;
  padding-top: 1.8mm;
  border-top: 1px solid var(--border);
  font-family: var(--mono);
  font-size: 8pt;
  color: var(--muted);
  display: flex;
  justify-content: space-between;
}

/* screen-only toolbar; hidden in print/PDF */
.cv-toolbar {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 12px;
  margin-bottom: 8mm;
}
.cv-toolbar a { color: var(--accent); }
@media print { .cv-toolbar { display: none; } }

/* responsive screen view; print keeps the A4 layout above */
@media screen and (max-width: 640px) {
  body { padding: 18px 16px; font-size: 14px; }
  header { flex-direction: column; align-items: flex-start; gap: 6px; }
  h1 { font-size: 22px; }
  .contact { text-align: left; }
  .cv-toolbar { margin-bottom: 20px; }
  .entry { flex-direction: column; gap: 1px; margin-bottom: 10px; }
  .entry-when, .stack-label { flex: none; }
  .stack-row { flex-direction: column; gap: 1px; margin-bottom: 8px; }
  footer { flex-direction: column; gap: 3px; }
}
