/* Editorial CV — Material Design 3 layout (8dp grid, breakpoints, window insets) */

/*
 * M3 window size classes (reference):
 * compact: 0–599px | medium: 600–839 | expanded: 840–1199 | large: 1200–1599 | extra-large: ≥1600
 */

:root {
  --text: #1a1a1a;
  --bg: #f9f9f9;
  --border: #e8e8e8;

  /* M3 spacing scale — 4dp base, 8dp rhythm (1rem = 16px) */
  --md-sys-spacing-1: 0.25rem; /* 4 */
  --md-sys-spacing-2: 0.5rem; /* 8 */
  --md-sys-spacing-3: 0.75rem; /* 12 */
  --md-sys-spacing-4: 1rem; /* 16 */
  --md-sys-spacing-5: 1.25rem; /* 20 */
  --md-sys-spacing-6: 1.5rem; /* 24 */
  --md-sys-spacing-8: 2rem; /* 32 */
  --md-sys-spacing-10: 2.5rem; /* 40 */
  --md-sys-spacing-12: 3rem; /* 48 */
  --md-sys-spacing-16: 4rem; /* 64 */
  --md-sys-spacing-20: 5rem; /* 80 */

  /* Window horizontal insets (screen edge → content) */
  --md-sys-layout-margin-inline: var(--md-sys-spacing-4);
  /* Max content width on large viewports */
  --md-sys-layout-max-width-content: min(900px, 100%);
  /* Vertical rhythm between major sections */
  --md-sys-layout-section-gap: clamp(
    var(--md-sys-spacing-16),
    var(--md-sys-spacing-16) + 1.25vw,
    var(--md-sys-spacing-20)
  );
}

/* medium */
@media (min-width: 600px) {
  :root {
    --md-sys-layout-margin-inline: var(--md-sys-spacing-6);
  }
}

/* expanded */
@media (min-width: 840px) {
  :root {
    --md-sys-layout-margin-inline: var(--md-sys-spacing-8);
  }
}

/* large */
@media (min-width: 1200px) {
  :root {
    --md-sys-layout-margin-inline: var(--md-sys-spacing-10);
  }
}

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

html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  padding: var(--md-sys-spacing-6) var(--md-sys-layout-margin-inline)
    var(--md-sys-spacing-16);
  font-family: Inter, system-ui, -apple-system, sans-serif;
  font-size: 1.0625rem;
  font-weight: 400;
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
  text-align: left;
}

.layout-surface {
  width: 100%;
  min-height: 100%;
}

/* Content column: max 900px, links uitgelijnd binnen venstermarges */
.layout-container {
  width: 100%;
  max-width: var(--md-sys-layout-max-width-content);
  margin-inline: 0;
  text-align: left;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 100;
  padding: var(--md-sys-spacing-2) var(--md-sys-spacing-4);
  background: var(--text);
  color: #fff;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 400;
}

.skip-link:focus {
  left: var(--md-sys-spacing-2);
  top: var(--md-sys-spacing-2);
}

.site-header {
  padding-bottom: var(--md-sys-spacing-5);
  margin-bottom: var(--md-sys-spacing-8);
  border-bottom: 1px solid var(--border);
}

.site-title {
  margin: 0 0 var(--md-sys-spacing-2);
  font-size: clamp(1.75rem, 4vw, 2.125rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--text);
}

.tagline {
  margin: 0 0 var(--md-sys-spacing-5);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.6;
  color: var(--text);
}

.tagline strong {
  font-weight: 700;
}

.tagline-location {
  font-style: italic;
  font-weight: 400;
}

.contact-links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--md-sys-spacing-2) var(--md-sys-spacing-3);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.6;
}

.contact-links a {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.contact-links a:hover,
.contact-links a:focus {
  text-decoration-thickness: 2px;
}

.contact-links__sep {
  color: var(--text);
  user-select: none;
}

main section {
  margin: 0;
  padding: 0;
  text-align: left;
}

main section + section {
  margin-top: var(--md-sys-layout-section-gap);
}

main h2 {
  margin: 0 0 var(--md-sys-spacing-5);
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: 0;
  color: var(--text);
}

main p {
  margin: 0 0 var(--md-sys-spacing-5);
  max-width: none;
}

main p:last-child {
  margin-bottom: 0;
}

.section-kicker {
  margin: 0 0 var(--md-sys-spacing-3);
  font-size: 1rem;
  font-weight: 400;
  font-style: italic;
  color: var(--text);
}

.role {
  margin: 0 0 var(--md-sys-spacing-3);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.6;
  color: var(--text);
}

.role strong {
  font-weight: 700;
}

.role--spaced {
  margin-top: var(--md-sys-spacing-10);
}

.role-meta {
  display: block;
  margin-top: var(--md-sys-spacing-1);
}

@media (min-width: 600px) {
  .role-meta {
    display: inline;
    margin-top: 0;
  }

  .role-meta::before {
    content: " ";
  }
}

.role-lede {
  margin: 0 0 var(--md-sys-spacing-5);
}

.bullet-list {
  margin: 0;
  padding-left: var(--md-sys-spacing-5);
  list-style-type: disc;
}

.bullet-list li {
  margin-bottom: var(--md-sys-spacing-3);
  padding-left: 0.15em;
}

.bullet-list li:last-child {
  margin-bottom: 0;
}

.bullet-list strong {
  font-weight: 700;
}

.bullet-list--plain {
  list-style-type: disc;
}
