/* PPMOS components — Rijksoverheid / Belastingdienst-style chrome
   Built on NL Design System component class conventions.
*/

[x-cloak] { display: none !important; }
* { box-sizing: border-box; }
html { margin: 0; padding: 0; scroll-behavior: smooth; }
body { margin: 0; padding: 0; }

/* Offset anchor targets for sticky header (rijksband 36px + header 88px + 8px breathing room) */
[id] { scroll-margin-top: 132px; }

.utrecht-document {
  background: var(--utrecht-document-background-color);
  color: var(--utrecht-document-color);
  font-family: var(--utrecht-document-font-family);
  font-size: var(--utrecht-document-font-size);
  line-height: var(--utrecht-document-line-height);
  -webkit-font-smoothing: antialiased;
}

/* ── Headings ─────────────────────────────────────────────────── */
.nl-heading {
  color: var(--utrecht-heading-color);
  font-family: var(--utrecht-heading-font-family);
  font-weight: var(--utrecht-heading-font-weight);
  letter-spacing: var(--utrecht-heading-letter-spacing);
  margin: 0;
  text-wrap: pretty;
}
.nl-heading--level-1 { font-size: var(--utrecht-heading-1-font-size); line-height: var(--utrecht-heading-1-line-height); }
.nl-heading--level-2 { font-size: var(--utrecht-heading-2-font-size); line-height: var(--utrecht-heading-2-line-height); }
.nl-heading--level-3 { font-size: var(--utrecht-heading-3-font-size); line-height: var(--utrecht-heading-3-line-height); }
.nl-heading--level-4 { font-size: var(--utrecht-heading-4-font-size); line-height: var(--utrecht-heading-4-line-height); }

/* ── Paragraph & lead ─────────────────────────────────────────── */
.utrecht-paragraph { margin: 0; color: var(--utrecht-paragraph-color); max-width: 70ch; }
.utrecht-paragraph--lead {
  font-size: var(--utrecht-paragraph-lead-font-size);
  line-height: var(--utrecht-paragraph-lead-line-height);
}

/* ── Link ─────────────────────────────────────────────────────── */
.utrecht-link {
  color: var(--utrecht-link-color);
  text-decoration: var(--utrecht-link-text-decoration);
  text-decoration-thickness: var(--utrecht-link-text-decoration-thickness);
  text-underline-offset: var(--utrecht-link-text-underline-offset);
}
.utrecht-link:hover {
  color: var(--utrecht-link-hover-color);
  text-decoration-thickness: var(--utrecht-link-hover-text-decoration-thickness);
}

:focus-visible {
  outline: var(--utrecht-focus-outline-width) solid var(--utrecht-focus-outline-color);
  outline-offset: var(--utrecht-focus-outline-offset);
}

/* ── Button ──────────────────────────────────────────────────── */
.utrecht-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--ppmos-space-xs);
  font-family: var(--utrecht-button-font-family);
  font-size: 1rem;
  font-weight: var(--utrecht-button-font-weight);
  min-height: var(--utrecht-button-min-height);
  padding: var(--utrecht-button-padding-block) var(--utrecht-button-padding-inline);
  border-radius: var(--utrecht-button-border-radius);
  border: var(--utrecht-button-border-width) solid transparent;
  cursor: pointer;
  text-decoration: none;
  line-height: 1.2;
}
.utrecht-button--primary-action {
  background: var(--utrecht-button-primary-action-background-color);
  color: var(--utrecht-button-primary-action-color);
  border-color: var(--utrecht-button-primary-action-border-color);
}
.utrecht-button--primary-action:hover {
  background: var(--utrecht-button-primary-action-hover-background-color);
  border-color: var(--utrecht-button-primary-action-hover-border-color);
}
.utrecht-button--secondary-action {
  background: var(--utrecht-button-secondary-action-background-color);
  color: var(--utrecht-button-secondary-action-color);
  border-color: var(--utrecht-button-secondary-action-border-color);
}
.utrecht-button--secondary-action:hover {
  background: var(--utrecht-button-secondary-action-hover-background-color);
}

/* ── Skip link ────────────────────────────────────────────────── */
.utrecht-skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  z-index: 100;
  padding: 12px 16px;
  background: #fed201;
  color: var(--ppmos-color-gray-90);
  text-decoration: underline;
  font-weight: 700;
}
.utrecht-skip-link:focus { top: 0; }

/* ── Top utility band (rijkshuisstijl) ────────────────────────── */
.ppmos-rijksband {
  background: var(--ppmos-color-gray-90);
  color: var(--ppmos-color-gray-00);
  font-size: 13px;
}
.ppmos-rijksband__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 8px 24px;
  display: flex;
  justify-content: space-between;
  gap: 24px;
}
.ppmos-rijksband a { color: inherit; text-decoration: underline; text-underline-offset: 2px; }

/* ── Page header ──────────────────────────────────────────────── */
.utrecht-page-header { background: var(--ppmos-color-gray-00); }
.utrecht-page-header__band {
  border-block-end: var(--utrecht-page-header-border-block-end-width) solid var(--utrecht-page-header-border-block-end-color);
}
.utrecht-page-header__content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 18px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.utrecht-page-header__nav {
  display: flex;
  gap: 4px;
  align-items: center;
}
.utrecht-page-header__nav a {
  color: var(--ppmos-color-gray-90);
  text-decoration: none;
  font-size: 16px;
  font-weight: 600;
  padding: 10px 14px;
}
.utrecht-page-header__nav a:hover { text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px; }
.utrecht-page-header__nav a[aria-current="page"] { color: var(--ppmos-color-blue-60); }
.utrecht-page-header__login {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: var(--ppmos-color-gray-90);
  color: var(--ppmos-color-gray-00) !important;
  font-weight: 700;
  text-decoration: none;
}
.utrecht-page-header__login::before {
  content: "→";
  font-weight: 700;
}

/* ── Brand mark ───────────────────────────────────────────────── */
.ppmos-brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

/* ── Hero (Belastingdienst-style) ─────────────────────────────── */
.ppmos-hero {
  background: var(--ppmos-color-blue-60);
  color: var(--ppmos-color-gray-00);
}
.ppmos-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 56px 24px 48px;
}
.ppmos-hero h1 {
  color: var(--ppmos-color-gray-00);
  font-size: 2.75rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 16px;
  max-width: 22ch;
  line-height: 1.1;
}
.ppmos-hero__lede {
  font-size: 1.125rem;
  color: var(--ppmos-color-gray-00);
  max-width: 56ch;
  margin: 0 0 24px;
  line-height: 1.5;
}
.ppmos-hero__search {
  display: flex;
  background: var(--ppmos-color-gray-00);
  max-width: 640px;
  border: 2px solid var(--ppmos-color-gray-90);
}
.ppmos-hero__search input {
  flex: 1;
  border: 0;
  padding: 14px 16px;
  font-size: 1rem;
  font-family: inherit;
  background: transparent;
  color: var(--ppmos-color-gray-90);
}
.ppmos-hero__search input:focus { outline: none; }
.ppmos-hero__search button {
  border: 0;
  background: var(--ppmos-color-gray-90);
  color: var(--ppmos-color-gray-00);
  padding: 0 24px;
  font-weight: 700;
  font-size: 1rem;
  font-family: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.ppmos-hero__search button:hover { background: #1a1a1a; }
.ppmos-hero__quick {
  margin-top: 24px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 6px;
  font-size: 0.9375rem;
}
.ppmos-hero__quick span { color: var(--ppmos-color-blue-10); }
.ppmos-hero__quick a { color: var(--ppmos-color-gray-00); text-decoration: underline; text-underline-offset: 3px; }

/* ── Container ────────────────────────────────────────────────── */
.ppmos-container { max-width: 1200px; margin: 0 auto; padding-left: 24px; padding-right: 24px; }

/* ── Uitgelicht (featured panels) ─────────────────────────────── */
.ppmos-featured {
  padding: var(--ppmos-space-2xl) 0;
  border-bottom: 1px solid var(--ppmos-rule);
}
.ppmos-featured__head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--ppmos-space-lg); }
.ppmos-featured__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.ppmos-featured__panel {
  display: block;
  background: var(--ppmos-color-blue-05);
  padding: 24px;
  text-decoration: none;
  color: inherit;
  border-left: 4px solid var(--ppmos-color-blue-60);
}
.ppmos-featured__panel:hover { background: var(--ppmos-color-blue-10); }
.ppmos-featured__panel--inverse { background: var(--ppmos-color-blue-60); color: var(--ppmos-color-gray-00); border-left-color: #fed201; }
.ppmos-featured__panel--inverse:hover { background: var(--ppmos-color-blue-70); }
.ppmos-featured__panel--inverse h3 { color: var(--ppmos-color-gray-00) !important; }
.ppmos-featured__panel--inverse p { color: var(--ppmos-color-blue-10) !important; }
.ppmos-featured__panel--inverse .ppmos-featured__more { color: var(--ppmos-color-gray-00) !important; }
.ppmos-featured__date {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ppmos-color-gray-60);
  margin-bottom: 8px;
}
.ppmos-featured__panel--inverse .ppmos-featured__date { color: var(--ppmos-color-blue-10); }
.ppmos-featured__panel h3 {
  color: var(--ppmos-color-blue-60);
  font-size: 1.125rem;
  font-weight: 700;
  margin: 0 0 8px;
  line-height: 1.3;
}
.ppmos-featured__panel p { font-size: 0.9375rem; margin: 0; color: var(--ppmos-color-gray-80); }
.ppmos-featured__more {
  display: inline-block;
  margin-top: 16px;
  font-weight: 700;
  font-size: 0.9375rem;
  color: var(--ppmos-color-blue-40);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.ppmos-featured__more::after { content: " →"; }

/* ── Themed link list (Belastingdienst-style "Belangrijke thema's") ── */
.ppmos-themes {
  padding: var(--ppmos-space-2xl) 0;
  border-bottom: 1px solid var(--ppmos-rule);
}
.ppmos-themes h2 { margin-bottom: var(--ppmos-space-lg); }
.ppmos-themes__columns {
  column-count: 3;
  column-gap: 32px;
}
.ppmos-themes ul { list-style: none; padding: 0; margin: 0; }
.ppmos-themes li { break-inside: avoid; padding: 6px 0; }
.ppmos-themes li a {
  color: var(--ppmos-color-blue-40);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-size: 1rem;
  font-weight: 600;
}
.ppmos-themes li a:hover { color: var(--ppmos-color-blue-60); text-decoration-thickness: 2px; }

/* ── Tender list (gov-style data list) ───────────────────────── */
.ppmos-tenders { padding: var(--ppmos-space-2xl) 0; border-bottom: 1px solid var(--ppmos-rule); }
.ppmos-tenders__head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: var(--ppmos-space-lg); flex-wrap: wrap; gap: 12px; }
.ppmos-tenders__list { border-top: 2px solid var(--ppmos-color-blue-60); }
.ppmos-tender {
  display: grid;
  grid-template-columns: 120px 1fr auto;
  gap: 24px;
  padding: 20px 0;
  border-bottom: 1px solid var(--ppmos-rule);
  align-items: start;
}
.ppmos-tender__date {
  font-weight: 700;
  color: var(--ppmos-color-blue-60);
}
.ppmos-tender__date strong { display: block; font-size: 1.5rem; line-height: 1; }
.ppmos-tender__date small { display: block; font-size: 0.875rem; color: var(--ppmos-color-gray-60); margin-top: 4px; font-weight: 400; }
.ppmos-tender__body h3 { margin: 0 0 4px; }
.ppmos-tender__body h3 a { color: var(--ppmos-color-blue-40); text-decoration: underline; text-underline-offset: 3px; font-weight: 700; font-size: 1.0625rem; }
.ppmos-tender__org { color: var(--ppmos-color-gray-60); font-size: 0.9375rem; }
.ppmos-tender__meta { font-size: 0.875rem; color: var(--ppmos-color-gray-80); margin-top: 6px; }
.ppmos-tender__meta strong { color: var(--ppmos-color-gray-90); }
.ppmos-tender__meta span:not(:last-child)::after { content: " · "; color: var(--ppmos-color-gray-40); }
.ppmos-tender__cta { align-self: center; }

/* ── Information panels (3 cols, gray-bordered) ──────────────── */
.ppmos-info { padding: var(--ppmos-space-2xl) 0; }
.ppmos-info__head { margin-bottom: var(--ppmos-space-lg); }
.ppmos-info__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.ppmos-info__panel { padding: 24px; background: var(--ppmos-color-gray-02); border-top: 4px solid var(--ppmos-color-blue-60); }
.ppmos-info__panel h3 { margin: 0 0 12px; }
.ppmos-info__panel ul { list-style: none; padding: 0; margin: 0; }
.ppmos-info__panel li { padding: 6px 0; border-top: 1px solid var(--ppmos-color-gray-10); }
.ppmos-info__panel li:first-child { border-top: 0; }
.ppmos-info__panel li a { color: var(--ppmos-color-blue-40); text-decoration: underline; text-underline-offset: 3px; font-size: 0.9375rem; }

/* ── Stat band ────────────────────────────────────────────────── */
.ppmos-stats {
  background: var(--ppmos-color-gray-02);
  padding: var(--ppmos-space-xl) 0;
  border-top: 1px solid var(--ppmos-rule);
  border-bottom: 1px solid var(--ppmos-rule);
}
.ppmos-stats__row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.ppmos-stats__cell { padding-left: 20px; border-left: 4px solid var(--ppmos-color-blue-60); }
.ppmos-stats__num { font-size: 2.25rem; font-weight: 700; color: var(--ppmos-color-blue-60); line-height: 1; letter-spacing: -0.01em; }
.ppmos-stats__cap { font-size: 0.9375rem; color: var(--ppmos-color-gray-80); margin-top: 6px; }

/* ── Page footer ──────────────────────────────────────────────── */
.utrecht-page-footer {
  background: var(--utrecht-page-footer-background-color);
  color: var(--utrecht-page-footer-color);
  margin-top: var(--ppmos-space-2xl);
}
.utrecht-page-footer__content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 24px 32px;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
}
.utrecht-page-footer h4 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--ppmos-color-gray-00);
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--ppmos-color-blue-40);
}
.utrecht-page-footer ul { list-style: none; padding: 0; margin: 0; }
.utrecht-page-footer li { padding: 4px 0; font-size: 0.9375rem; }
.utrecht-page-footer a { color: var(--ppmos-color-gray-00); text-decoration: underline; text-underline-offset: 3px; }
.utrecht-page-footer__legal {
  border-top: 1px solid var(--ppmos-color-blue-40);
  padding: 16px 24px;
  max-width: 1200px;
  margin: 0 auto;
  font-size: 0.875rem;
  color: var(--ppmos-color-blue-10);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

@media (max-width: 900px) {
  .ppmos-themes__columns { column-count: 2; }
  .ppmos-featured__grid, .ppmos-info__grid { grid-template-columns: 1fr; }
  .ppmos-stats__row { grid-template-columns: repeat(2, 1fr); }
  .utrecht-page-footer__content { grid-template-columns: repeat(2, 1fr); }
  .utrecht-page-header__nav { display: none; }
}

/* ═══════════════════════════════════════════════════════════════
   V2-specific components (ppmos.com content mapping)
   ═══════════════════════════════════════════════════════════════ */

/* Section header shared */
.ppmos-section { padding-top: var(--ppmos-space-2xl); padding-bottom: var(--ppmos-space-2xl); border-bottom: 1px solid var(--ppmos-rule); }
.ppmos-section--alt { background: var(--ppmos-color-gray-02); }
.ppmos-section--inverse { background: var(--ppmos-color-blue-60); color: white; }
.ppmos-section--inverse .nl-heading { color: white; }
.ppmos-section--inverse .utrecht-paragraph { color: var(--ppmos-color-blue-10); }
.ppmos-section__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: var(--ppmos-space-lg);
  flex-wrap: wrap;
}
.ppmos-section__intro {
  max-width: 60ch;
  margin: 0 0 var(--ppmos-space-xl);
  color: var(--ppmos-color-gray-80);
  font-size: 1.0625rem;
}

/* Two-column audience compare (PM vs ondernemer) */
.ppmos-compare { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.ppmos-compare__col {
  background: white;
  border-top: 4px solid var(--ppmos-color-blue-60);
  padding: 28px;
}
.ppmos-compare__col--accent { border-top-color: var(--ppmos-color-blue-40); background: var(--ppmos-color-blue-05); }
.ppmos-compare__label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ppmos-color-gray-60);
  margin-bottom: 8px;
}
.ppmos-compare h3 { color: var(--ppmos-color-blue-60); font-size: 1.375rem; margin: 0 0 8px; }
.ppmos-compare ul { list-style: none; padding: 0; margin: 16px 0 20px; }
.ppmos-compare li { padding: 8px 0 8px 28px; border-top: 1px solid var(--ppmos-rule); position: relative; font-size: 0.9375rem; }
.ppmos-compare li:first-child { border-top: 0; }
.ppmos-compare li::before {
  content: "✓";
  position: absolute; left: 0; top: 8px;
  color: var(--ppmos-color-blue-60); font-weight: 700;
}

/* Process steps (TenderScout 4 stappen) */
.ppmos-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-left: 1px solid var(--ppmos-rule); }
.ppmos-step { padding: 24px; border-right: 1px solid var(--ppmos-rule); border-top: 4px solid var(--ppmos-color-blue-60); background: white; }
.ppmos-step__num { font-size: 12px; font-weight: 700; color: var(--ppmos-color-blue-40); letter-spacing: 0.06em; text-transform: uppercase; }
.ppmos-step h3 { font-size: 1.125rem; margin: 8px 0; color: var(--ppmos-color-blue-60); }
.ppmos-step p { font-size: 0.9375rem; color: var(--ppmos-color-gray-80); margin: 0; }

/* Features grid (9 cells, 3x3) */
.ppmos-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--ppmos-rule); border: 1px solid var(--ppmos-rule); }
.ppmos-feature { background: white; padding: 24px; }
.ppmos-feature__icon {
  display: inline-grid; place-items: center;
  width: 40px; height: 40px;
  background: var(--ppmos-color-blue-60);
  color: white;
  font-weight: 700;
  font-size: 18px;
  margin-bottom: 12px;
}
.ppmos-feature h3 { font-size: 1.0625rem; color: var(--ppmos-color-blue-60); margin: 0 0 6px; }
.ppmos-feature p { font-size: 0.9375rem; color: var(--ppmos-color-gray-80); margin: 0; }

/* GROTIK 6-letter grid */
.ppmos-grotik { display: grid; grid-template-columns: repeat(6, 1fr); border: 1px solid var(--ppmos-rule); border-bottom: none; }
.ppmos-grotik__cell { padding: 20px; border-right: 1px solid var(--ppmos-rule); border-bottom: 1px solid var(--ppmos-rule); background: white; min-height: 200px; display: flex; flex-direction: column; cursor: pointer; transition: background 0.12s; }
.ppmos-grotik__cell:last-child { border-right: 0; }
.ppmos-grotik__cell:hover { background: var(--ppmos-color-gray-02); }
.ppmos-grotik__cell--selected,
.ppmos-grotik__cell--selected:hover { background: var(--ppmos-color-blue-60); color: white; }
.ppmos-grotik__cell--selected .ppmos-grotik__name,
.ppmos-grotik__cell--selected .ppmos-grotik__desc { color: white; }
.ppmos-grotik__cell--selected .ppmos-grotik__letter { color: white; }
.ppmos-grotik__cell--selected .ppmos-grotik__num { color: var(--ppmos-color-blue-10); }
.ppmos-grotik__letter { font-size: 4rem; font-weight: 700; line-height: 0.9; color: var(--ppmos-color-blue-60); letter-spacing: -0.04em; }
.ppmos-grotik__num { font-size: 11px; font-weight: 700; color: var(--ppmos-color-gray-60); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 8px; }
.ppmos-grotik__name { font-weight: 700; font-size: 1rem; margin-top: 4px; color: var(--ppmos-color-gray-90); }
.ppmos-grotik__desc { font-size: 0.8125rem; color: var(--ppmos-color-gray-80); margin-top: 6px; line-height: 1.4; }

/* GROTIK detail panel */
.ppmos-grotik__panel { border: 1px solid var(--ppmos-rule); border-top: 3px solid var(--ppmos-color-blue-60); padding: 28px 32px; display: grid; grid-template-columns: 220px 1fr; gap: 32px; background: white; }
.ppmos-grotik__panel-letter { font-size: 5rem; font-weight: 700; color: var(--ppmos-color-blue-60); line-height: 0.85; letter-spacing: -0.04em; }
.ppmos-grotik__panel-name { font-size: 1.375rem; font-weight: 700; color: var(--ppmos-color-gray-90); margin-top: 8px; }
.ppmos-grotik__panel-tag { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ppmos-color-gray-60); margin-top: 4px; }
.ppmos-grotik__panel-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; align-self: center; }
.ppmos-grotik__panel-list li { font-size: 0.9375rem; color: var(--ppmos-color-gray-80); padding-left: 20px; position: relative; }
.ppmos-grotik__panel-list li::before { content: '→'; position: absolute; left: 0; color: var(--ppmos-color-blue-60); font-weight: 700; }

/* Claude AI showcase */
.ppmos-claude { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: center; }
.ppmos-chat {
  background: white;
  border: 1px solid var(--ppmos-color-gray-10);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.ppmos-chat__header {
  background: var(--ppmos-color-blue-60);
  color: white;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 10px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.ppmos-chat__body {
  padding: 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ppmos-chat__row { display: flex; gap: 10px; align-items: flex-start; }
.ppmos-chat__row--user { justify-content: flex-end; }
.ppmos-chat__avatar {
  width: 28px;
  height: 28px;
  background: var(--ppmos-color-blue-60);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 18px;
}
.ppmos-chat__label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ppmos-color-gray-40);
  margin-bottom: 4px;
}
.ppmos-chat__bubble {
  max-width: 88%;
  padding: 12px 14px;
  font-size: 0.9rem;
  line-height: 1.55;
}
.ppmos-chat__bubble--user {
  background: var(--ppmos-color-blue-60);
  color: white;
  border-left: 3px solid #fed201;
}
.ppmos-chat__bubble--ai {
  background: var(--ppmos-color-gray-02);
  color: var(--ppmos-color-gray-90);
  border-left: 3px solid var(--ppmos-color-blue-20);
}
.ppmos-chat__inputbar {
  border-top: 1px solid var(--ppmos-color-gray-10);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--ppmos-color-gray-00);
}
.ppmos-chat__inputfield {
  flex: 1;
  font-size: 0.875rem;
  color: var(--ppmos-color-gray-30);
  padding: 7px 10px;
  border: 1px solid var(--ppmos-color-gray-10);
  background: white;
  font-family: inherit;
}
.ppmos-chat__send {
  background: var(--ppmos-color-blue-60);
  color: white;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.45;
  flex-shrink: 0;
}
.ppmos-claude ul { list-style: none; padding: 0; margin: 16px 0; }
.ppmos-claude li { padding: 8px 0 8px 28px; position: relative; border-top: 1px solid var(--ppmos-rule); font-size: 0.9375rem; color: var(--ppmos-color-blue-10); }
.ppmos-claude li:first-child { border-top: 0; }
.ppmos-claude li::before { content: "→"; position: absolute; left: 0; top: 8px; color: #fed201; font-weight: 700; }

/* Testimonials */
.ppmos-testimonials { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; background: transparent; }
.ppmos-quote { background: white; padding: 28px; margin: 0; border: 1px solid var(--ppmos-rule); border-top: 3px solid var(--ppmos-color-blue-60); display: flex; flex-direction: column; }
.ppmos-quote__text { font-size: 1rem; line-height: 1.6; color: var(--ppmos-color-gray-60); margin: 0 0 20px; flex: 1; }
.ppmos-quote__author { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--ppmos-rule); }
.ppmos-quote__avatar { width: 36px; height: 36px; background: var(--ppmos-color-blue-60); color: white; display: grid; place-items: center; font-weight: 700; font-size: 14px; flex-shrink: 0; }
.ppmos-quote__name { font-weight: 700; font-size: 0.9375rem; color: var(--ppmos-color-gray-90); }
.ppmos-quote__role { font-size: 0.8125rem; color: var(--ppmos-color-gray-60); }

/* Pricing */
.ppmos-pricing { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.ppmos-plan { background: white; border-top: 4px solid var(--ppmos-color-blue-60); padding: 28px; display: flex; flex-direction: column; }
.ppmos-plan--featured { background: var(--ppmos-color-blue-05); border-top-color: var(--ppmos-color-blue-40); position: relative; }
.ppmos-plan--featured::before {
  content: "MEEST GEKOZEN";
  position: absolute; top: -4px; right: 16px;
  background: #fed201;
  color: var(--ppmos-color-gray-90);
  font-size: 11px; font-weight: 700; padding: 4px 8px;
  letter-spacing: 0.06em;
}
.ppmos-plan__name { font-size: 12px; font-weight: 700; color: var(--ppmos-color-gray-60); letter-spacing: 0.06em; text-transform: uppercase; }
.ppmos-plan__price { font-size: 2.5rem; font-weight: 700; color: var(--ppmos-color-blue-60); line-height: 1; margin: 12px 0 4px; letter-spacing: -0.01em; white-space: nowrap; }
.ppmos-plan__price small { font-size: 1rem; font-weight: 400; color: var(--ppmos-color-gray-60); }
.ppmos-plan__desc { font-size: 0.9375rem; color: var(--ppmos-color-gray-80); margin: 8px 0 16px; }
.ppmos-plan ul { list-style: none; padding: 0; margin: 0 0 24px; flex: 1; }
.ppmos-plan li { padding: 10px 0 10px 24px; border-top: 1px solid var(--ppmos-rule); position: relative; font-size: 0.9375rem; }
.ppmos-plan li:first-child { border-top: 0; }
.ppmos-plan li::before { content: "✓"; position: absolute; left: 0; top: 10px; color: var(--ppmos-color-blue-60); font-weight: 700; }

/* FAQ */
.ppmos-faq { display: grid; grid-template-columns: 280px 1fr; gap: 32px; align-items: start; }
.ppmos-faq__list { border-top: 2px solid var(--ppmos-color-blue-60); }
.ppmos-faq details {
  border-bottom: 1px solid var(--ppmos-rule);
  padding: 0;
}
.ppmos-faq summary {
  list-style: none;
  cursor: pointer;
  padding: 16px 32px 16px 0;
  font-weight: 700;
  color: var(--ppmos-color-blue-60);
  font-size: 1.0625rem;
  position: relative;
}
.ppmos-faq summary::-webkit-details-marker { display: none; }
.ppmos-faq summary::after {
  content: "+";
  position: absolute; right: 0; top: 50%;
  transform: translateY(-50%);
  font-size: 1.5rem; font-weight: 700;
  color: var(--ppmos-color-blue-40);
}
.ppmos-faq details[open] summary::after { content: "−"; }
.ppmos-faq__answer { padding: 0 0 16px; color: var(--ppmos-color-gray-80); font-size: 0.9375rem; line-height: 1.55; }

/* Final CTA band */
.ppmos-cta-band {
  background: var(--ppmos-color-blue-60);
  color: white;
  padding: 64px 24px;
  text-align: center;
}
.ppmos-cta-band h2 { color: white; font-size: 2rem; margin: 0 0 12px; max-width: 24ch; margin-inline: auto; }
.ppmos-cta-band p { color: var(--ppmos-color-blue-10); font-size: 1.125rem; margin: 0 auto 24px; max-width: 56ch; }
.ppmos-cta-band__buttons { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.ppmos-cta-band .utrecht-button--secondary-action { background: transparent; color: white; border-color: white; }
.ppmos-cta-band .utrecht-button--secondary-action:hover { background: rgba(255,255,255,0.1); }

@media (max-width: 900px) {
  .ppmos-compare, .ppmos-claude, .ppmos-faq { grid-template-columns: 1fr; }
  .ppmos-steps { grid-template-columns: 1fr 1fr; }
  .ppmos-features, .ppmos-testimonials, .ppmos-pricing { grid-template-columns: 1fr; }
  .ppmos-grotik { grid-template-columns: repeat(2, 1fr); }
  .ppmos-grotik__cell:last-child { border-right: 1px solid var(--ppmos-rule); }
  .ppmos-grotik__panel { grid-template-columns: 1fr; }
  .ppmos-grotik__panel-letter { font-size: 3.5rem; }
  .ab-detail-grid { grid-template-columns: 1fr; }
  .ab-option-grid { grid-template-columns: 1fr; }
  .ab-form-grid { grid-template-columns: 1fr; }
  .ab-grid { grid-template-columns: 1fr; }
  .ab-hero-panel { padding: 20px; }
}

@media (max-width: 600px) {
  .ppmos-steps { grid-template-columns: 1fr; }
  .ppmos-grotik { grid-template-columns: 1fr; }
  .ppmos-grotik__cell:last-child { border-right: none; }
}

/* ── Aanbestedingen components ─────────────────────────────────── */
.ab-filters { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 16px 0; border-bottom: 2px solid var(--ppmos-rule); margin-bottom: 32px; }
.ab-filter { display: inline-block; padding: 6px 16px; font-size: 0.875rem; font-weight: 600; border: 1px solid var(--ppmos-color-gray-20); background: white; color: var(--ppmos-color-gray-70); text-decoration: none; transition: background 0.1s; }
.ab-filter:hover { background: var(--ppmos-color-gray-02); }
.ab-filter--active { background: var(--ppmos-color-blue-60); color: white; border-color: var(--ppmos-color-blue-60); }
.ab-search { padding: 8px 16px; border: 1px solid var(--ppmos-color-gray-20); font-size: 0.875rem; font-family: inherit; outline: none; min-width: 200px; flex: 1; max-width: 320px; }
.ab-search:focus { border-color: var(--ppmos-color-blue-60); }

.ab-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 1px; background: var(--ppmos-rule); border: 1px solid var(--ppmos-rule); }
.ab-card { background: white; border-top: 3px solid transparent; padding: 24px; display: flex; flex-direction: column; gap: 16px; transition: border-top-color 0.15s; }
.ab-card:hover { border-top-color: var(--ppmos-color-blue-60); }
.ab-card__num { font-size: 11px; font-weight: 700; color: var(--ppmos-color-gray-60); text-transform: uppercase; letter-spacing: 0.06em; }
.ab-card__title { font-size: 1.0625rem; font-weight: 700; color: var(--ppmos-color-gray-90); line-height: 1.3; }
.ab-card__desc { font-size: 0.875rem; color: var(--ppmos-color-gray-60); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.ab-card__meta { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.ab-meta { padding: 8px 12px; border: 1px solid var(--ppmos-rule); }
.ab-meta__label { font-size: 10px; font-weight: 700; color: var(--ppmos-color-gray-60); text-transform: uppercase; letter-spacing: 0.06em; }
.ab-meta__value { font-size: 0.875rem; font-weight: 700; color: var(--ppmos-color-gray-90); margin-top: 2px; }

.ab-badge { display: inline-flex; align-items: center; font-size: 11px; font-weight: 700; padding: 3px 8px; letter-spacing: 0.04em; text-transform: uppercase; border: 1px solid transparent; }
.ab-badge--open { background: #e8f5ee; color: #1a6e38; border-color: #b5d9c6; }
.ab-badge--planning { background: #fef9e7; color: #7a5a00; border-color: #f0d68a; }
.ab-badge--closed { background: var(--ppmos-color-gray-02); color: var(--ppmos-color-gray-60); border-color: var(--ppmos-rule); }

.ab-progress { height: 6px; background: var(--ppmos-color-gray-10); }
.ab-progress__fill { height: 100%; background: var(--ppmos-color-blue-60); }

.ab-breadcrumb { display: flex; align-items: center; gap: 8px; padding: 16px 0; font-size: 0.8125rem; color: var(--ppmos-color-gray-60); flex-wrap: wrap; }
.ab-breadcrumb a { color: var(--ppmos-color-gray-60); text-decoration: underline; text-underline-offset: 2px; }
.ab-breadcrumb a:hover { color: var(--ppmos-color-blue-60); }
.ab-breadcrumb__sep { color: var(--ppmos-color-gray-30); }

.ab-success-banner { background: #e8f5ee; border: 1px solid #b5d9c6; border-left: 4px solid #1a6e38; padding: 16px 20px; display: flex; align-items: flex-start; gap: 12px; margin-bottom: 24px; }
.ab-success-banner svg { color: #1a6e38; flex-shrink: 0; }

.ab-hero-panel { background: white; border: 1px solid var(--ppmos-rule); border-top: 4px solid var(--ppmos-color-blue-60); padding: 28px 32px; margin-bottom: 24px; }
.ab-hero-panel__meta { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 12px; }
.ab-hero-panel__title { font-size: clamp(1.375rem, 3vw, 1.875rem); font-weight: 700; color: var(--ppmos-color-gray-90); line-height: 1.2; margin-bottom: 12px; }
.ab-hero-panel__desc { font-size: 0.9375rem; color: var(--ppmos-color-gray-60); line-height: 1.7; max-width: 60ch; margin-bottom: 20px; }

.ab-stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 1px; background: var(--ppmos-rule); border: 1px solid var(--ppmos-rule); margin-bottom: 24px; }
.ab-stat { background: white; padding: 16px 20px; }
.ab-stat__val { font-size: 1.375rem; font-weight: 700; color: var(--ppmos-color-blue-60); line-height: 1; }
.ab-stat__lbl { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ppmos-color-gray-60); margin-top: 4px; }

.ab-detail-grid { display: grid; grid-template-columns: 1fr 320px; gap: 32px; align-items: start; }
.ab-sec { border: 1px solid var(--ppmos-rule); background: white; margin-bottom: 24px; }
.ab-sec__head { padding: 12px 20px; border-bottom: 1px solid var(--ppmos-rule); background: var(--ppmos-color-gray-02); display: flex; align-items: center; justify-content: space-between; }
.ab-sec__title { font-size: 0.875rem; font-weight: 700; color: var(--ppmos-color-gray-90); }
.ab-sec__body { padding: 20px; }
.ab-milestone { padding: 12px 0; border-bottom: 1px solid var(--ppmos-rule); display: flex; gap: 12px; align-items: flex-start; }
.ab-milestone:last-child { border-bottom: none; padding-bottom: 0; }
.ab-milestone__dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.ab-proj { padding: 16px; border: 1px solid var(--ppmos-rule); margin-bottom: 8px; }
.ab-proj:last-child { margin-bottom: 0; }

.ab-signup-card { background: var(--ppmos-color-blue-60); padding: 24px; margin-bottom: 24px; }
.ab-signup-card__title { font-size: 1.0625rem; font-weight: 700; color: white; margin-bottom: 8px; }
.ab-signup-card__sub { font-size: 0.875rem; color: var(--ppmos-color-blue-10); margin-bottom: 20px; line-height: 1.5; }
.ab-usp-list { list-style: none; padding: 0; margin: 0 0 20px; display: flex; flex-direction: column; gap: 8px; }
.ab-usp-list li { font-size: 0.875rem; color: var(--ppmos-color-blue-10); padding-left: 20px; position: relative; }
.ab-usp-list li::before { content: '✓'; position: absolute; left: 0; color: #fed201; font-weight: 700; }
.ab-info-card { border: 1px solid var(--ppmos-rule); background: white; }
.ab-info-card dl { padding: 16px 20px; display: flex; flex-direction: column; gap: 14px; margin: 0; }
.ab-info-card dt { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ppmos-color-gray-60); margin-bottom: 2px; }
.ab-info-card dd { font-size: 0.9rem; font-weight: 700; color: var(--ppmos-color-gray-90); margin: 0; }

.ab-modal-overlay { position: fixed; inset: 0; background: rgba(21,66,115,0.55); z-index: 200; display: flex; align-items: center; justify-content: center; padding: 24px; }
.ab-modal { background: white; width: 100%; max-width: 600px; max-height: 90vh; overflow-y: auto; }
.ab-modal__head { padding: 20px 24px; border-bottom: 3px solid var(--ppmos-color-blue-60); display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.ab-modal__title { font-size: 1.125rem; font-weight: 700; color: var(--ppmos-color-gray-90); }
.ab-modal__sub { font-size: 0.8125rem; color: var(--ppmos-color-gray-60); margin-top: 4px; }
.ab-modal__close { background: none; border: none; cursor: pointer; color: var(--ppmos-color-gray-60); padding: 4px; flex-shrink: 0; line-height: 1; }
.ab-modal__close:hover { color: var(--ppmos-color-gray-90); }
.ab-modal__body { padding: 24px; }
.ab-section-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ppmos-color-gray-60); padding-bottom: 8px; border-bottom: 1px solid var(--ppmos-rule); margin-bottom: 16px; margin-top: 24px; }
.ab-section-label:first-child { margin-top: 0; }
.ab-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ab-form-grid .full { grid-column: 1 / -1; }
.ab-form-group { display: flex; flex-direction: column; gap: 5px; }
.ab-form-label { font-size: 0.8125rem; font-weight: 700; color: var(--ppmos-color-gray-70); }
.ab-form-input { padding: 10px 14px; border: 1px solid var(--ppmos-color-gray-20); font-size: 0.875rem; font-family: inherit; outline: none; color: var(--ppmos-color-gray-90); background: white; width: 100%; }
.ab-form-input:focus { border-color: var(--ppmos-color-blue-60); }
.ab-form-input::placeholder { color: var(--ppmos-color-gray-40); }
.ab-option-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.ab-option { border: 2px solid var(--ppmos-rule); padding: 20px; cursor: pointer; transition: border-color 0.15s; }
.ab-option:hover { border-color: var(--ppmos-color-blue-60); }
.ab-option__label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ppmos-color-blue-60); margin-bottom: 6px; }
.ab-option__title { font-size: 0.9375rem; font-weight: 700; color: var(--ppmos-color-gray-90); margin-bottom: 12px; }
.ab-option__list { list-style: none; padding: 0; margin: 0 0 16px; display: flex; flex-direction: column; gap: 6px; }
.ab-option__list li { font-size: 0.8125rem; color: var(--ppmos-color-gray-70); padding-left: 18px; position: relative; }
.ab-option__list li::before { content: '✓'; position: absolute; left: 0; color: var(--ppmos-color-blue-60); font-weight: 700; }

/* ── Mobile overrides (must come after component definitions) ── */
@media (max-width: 900px) {
  /* ab-grid: single column (overrides the auto-fill definition above) */
  .ab-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  /* Tender list row: stack date+body vertically, CTA full-width below */
  .ppmos-tender {
    grid-template-columns: 80px 1fr;
    grid-template-rows: auto auto;
  }
  .ppmos-tender__cta {
    grid-column: 1 / -1;
  }
  .ppmos-tender__cta .utrecht-button {
    width: 100%;
    justify-content: center;
    display: flex;
  }
}
