/* ================================================================
   NICKDECKER.NET / RESUME
   Shares the design tokens, reset, palette and base type with
   styles.css (loaded first). This file only adds the CV layout.

   Same language as the home page: cream field, hard color bands,
   golden-ratio type + spacing, screen-printed wordmark.
   ================================================================ */

/* A single editorial column, centred on wide screens. Colored bands
   bleed full width; their inner content aligns to this measure. */
.shell {
  max-width: 66rem;
  margin: 0 auto;
  padding-inline: var(--gutter);
}

/* --- Top utility bar: back to the site -------------------------- */
.cv-top {
  border-bottom: var(--hair);
  padding-block: var(--space-sm);
}
.cv-back {
  display: inline-flex;
  align-items: center;
  gap: 0.5ch;
  font-size: var(--type-caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--ink);
  border-bottom: 1.5px solid transparent;
  transition: gap 0.25s var(--ease), border-color 0.2s ease;
}
.cv-back:hover { gap: 1ch; border-color: var(--red); }

/* ================================================================
   MASTHEAD
   ================================================================ */
.cv-head { padding-block: var(--space-xl) var(--space-lg); }

.cv-eyebrow {
  font-size: var(--type-caption);
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--red);
}

.cv-wordmark {
  margin-top: var(--space-sm);
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  font-size: clamp(3rem, 11vw, 8.5rem);
  color: var(--red);
  /* screen-printed outline, matching the home wordmark */
  -webkit-text-stroke: 2.5px var(--brown);
  paint-order: stroke fill;
}

/* Contact line — middot-separated, tracked caps */
.cv-contact {
  margin-top: var(--space-md);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4em 0.9em;
  font-size: var(--type-fine);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.cv-contact a {
  text-decoration: none;
  color: var(--ink);
  border-bottom: 1.5px solid var(--red);
  padding-bottom: 1px;
  transition: color 0.2s ease;
}
.cv-contact a:hover { color: var(--red); }
.cv-contact .dot { opacity: 0.45; }

/* ================================================================
   SUMMARY — dark lede block (mirrors the home statement band)
   ================================================================ */
.cv-summary {
  background: var(--ink);
  color: var(--cream);
  padding-block: var(--space-lg);
}
.cv-summary__inner { display: grid; gap: var(--space-sm); }
.cv-summary p {
  max-width: 60ch;
  font-size: var(--type-label);
  line-height: 1.5;
  letter-spacing: -0.003em;
  text-wrap: pretty;
}
.cv-summary p + p {
  font-size: var(--type-body);
  opacity: 0.85;
}

/* ================================================================
   SECTION BANDS  ("01 / EXPERIENCE" …) — static, colored,
   echoing the home accordion headers.
   ================================================================ */
.cv-band { padding-block: var(--space-sm); }
.cv-band--red    { background: var(--red); }
.cv-band--blue   { background: var(--blue);  color: var(--cream); }
.cv-band--yellow { background: var(--yellow); }
.cv-band--pink   { background: var(--pink); }

.cv-band__inner {
  display: flex;
  align-items: baseline;
  gap: 0.7ch;
  font-family: var(--font-body);
  font-weight: 400;
  font-style: italic;
  font-size: var(--type-title);
  line-height: 1;
  letter-spacing: -0.01em;
  text-transform: uppercase;
}
.cv-band__num { font-variant-numeric: tabular-nums; }
.cv-band__rule { opacity: 0.5; }

/* Body region under each band */
.cv-body {
  padding-block: var(--space-lg);
  border-bottom: var(--hair);
}

/* ================================================================
   EXPERIENCE — roles
   ================================================================ */
.role + .role { margin-top: var(--space-lg); }

.role__head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.3em var(--space-sm);
  padding-bottom: var(--space-2xs);
  border-bottom: var(--hair);
}
.role__co {
  font-size: var(--type-label);
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.role__dates {
  font-variant-numeric: tabular-nums;
  font-size: var(--type-fine);
  letter-spacing: 0.1em;
  white-space: nowrap;
  opacity: 0.65;
}
.role__meta {
  margin-top: var(--space-2xs);
  font-style: italic;
  font-size: var(--type-body);
  opacity: 0.85;
}
.role__list {
  list-style: none;
  margin-top: var(--space-sm);
  display: grid;
  gap: var(--space-xs);
}
.role__list li {
  position: relative;
  max-width: 64ch;
  padding-left: 1.7em;
  font-size: var(--type-body);
  line-height: 1.5;
}
/* red turn-marker, tying to the bio links + sub-row arrows */
.role__list li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0.02em;
  color: var(--red);
  font-weight: 500;
}

/* ================================================================
   CAPABILITIES
   ================================================================ */
.caps { display: grid; gap: var(--space-md); }
.cap__label {
  font-size: var(--type-fine);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red);
}
.cap__items {
  margin-top: var(--space-2xs);
  max-width: 64ch;
  font-size: var(--type-body);
  line-height: 1.5;
}
.cap__items .dot { opacity: 0.4; padding-inline: 0.15em; }

/* ================================================================
   EDUCATION / AVAILABILITY — simple bodies
   ================================================================ */
.cv-line__top {
  font-size: var(--type-label);
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.cv-line__sub {
  margin-top: var(--space-2xs);
  font-style: italic;
  font-size: var(--type-body);
  opacity: 0.85;
}
.cv-prose {
  max-width: 64ch;
  font-size: var(--type-body);
  line-height: 1.55;
}

/* ================================================================
   FOOTER
   ================================================================ */
.cv-foot {
  padding-block: var(--space-xl) var(--space-lg);
  text-align: center;
}
.cv-foot__lead {
  max-width: 22ch;
  margin: 0 auto;
  font-size: var(--type-title);
  line-height: 1.06;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  text-wrap: balance;
}
.cv-foot__actions {
  margin-top: var(--space-lg);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-xs);
}
.cv-foot__seal {
  margin-top: var(--space-lg);
  font-size: var(--type-caption);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  opacity: 0.65;
}

/* ================================================================
   PRINT — collapse the colors to ink-on-paper for a clean PDF
   ================================================================ */
@media print {
  .cv-top, .cv-foot__actions { display: none; }
  .cv-summary { background: none; color: var(--ink); }
  .cv-band { background: none !important; color: var(--ink) !important;
             border-top: var(--hair); border-bottom: var(--hair); }
  .cv-body { padding-block: var(--space-md); }
  .role { break-inside: avoid; }
}
