/* ──────────────────────────────────────────────────────────────────────
 * ZMGP gemeente-NL design system — Phase 3 Sprint H.2
 *
 * Design tokens + componenten voor alle Interactie-laag-BFFs. Volgt
 * Rijksoverheid huisstijl (RO Sans, blauw-paars-accent), aangepast voor
 * gemeente-context. WCAG 2.1 AA-compliant (contrast, focus-visible,
 * keyboard-nav, semantic structure).
 * ────────────────────────────────────────────────────────────────────── */

/* ── Design tokens ─────────────────────────────────────────────────── */
:root {
  /* Primaire kleuren — Rijksblauw + Oranjegele accent */
  --zmgp-primary:        #154273;
  --zmgp-primary-dark:   #0a2b4a;
  --zmgp-primary-light:  #E1F0FF;
  --zmgp-accent:         #FFB612;
  --zmgp-accent-dark:    #d99c0a;

  /* Status-kleuren */
  --zmgp-success:        #39870C;
  --zmgp-success-bg:     #D4EDDA;
  --zmgp-warning:        #B05900;
  --zmgp-warning-bg:     #FFF3CD;
  --zmgp-danger:         #D52B1E;
  --zmgp-danger-bg:      #F8D7DA;
  --zmgp-info:           #2E7BB8;
  --zmgp-info-bg:        #D1ECF1;

  /* Tekst- en achtergrond */
  --zmgp-bg:             #F3F3F3;
  --zmgp-bg-card:        #FFFFFF;
  --zmgp-text:           #1A1A1A;
  --zmgp-text-muted:     #5E5E5E;
  --zmgp-border:         #CCCCCC;
  --zmgp-border-subtle:  #E5E5E5;

  /* Spacing & geometry */
  --zmgp-radius:         4px;
  --zmgp-radius-pill:    999px;
  --zmgp-shadow-sm:      0 1px 2px rgba(0, 0, 0, 0.05);
  --zmgp-shadow-md:      0 2px 6px rgba(0, 0, 0, 0.08);

  /* Typography */
  --zmgp-font-family:    "RO Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --zmgp-font-mono:      ui-monospace, SFMono-Regular, "Consolas", monospace;
  --zmgp-line-height:    1.5;
}

/* ── Reset + basis ────────────────────────────────────────────────── */
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--zmgp-font-family);
  font-size: 16px;
  line-height: var(--zmgp-line-height);
  background: var(--zmgp-bg);
  color: var(--zmgp-text);
  -webkit-font-smoothing: antialiased;
}

/* ── Skip-link voor screen-readers (WCAG 2.4.1) ────────────────────── */
.zmgp-skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--zmgp-primary);
  color: white;
  padding: 8px 16px;
  z-index: 100;
  text-decoration: none;
  font-weight: 600;
}
.zmgp-skip-link:focus { top: 0; }

/* ── Header ───────────────────────────────────────────────────────── */
.zmgp-header {
  background: var(--zmgp-primary);
  color: white;
  padding: 14px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: var(--zmgp-shadow-md);
}
.zmgp-header h1 { margin: 0; font-size: 1.2em; font-weight: 700; }
.zmgp-header a { color: white; text-decoration: none; }
.zmgp-header a:focus { outline: 3px solid var(--zmgp-accent); outline-offset: 2px; }
.zmgp-header__user { font-size: 0.85em; opacity: 0.9; }
.zmgp-header__user .zmgp-badge__name { font-weight: 500; }
.zmgp-header__user .zmgp-badge__logout,
.zmgp-header__user .zmgp-badge__login {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.zmgp-header__user .zmgp-badge__logout:hover,
.zmgp-header__user .zmgp-badge__login:hover { text-decoration: none; }
.zmgp-header__user .zmgp-badge__logout:focus-visible,
.zmgp-header__user .zmgp-badge__login:focus-visible {
  outline: 2px solid #fff; outline-offset: 2px;
}

/* ── Navigation ───────────────────────────────────────────────────── */
.zmgp-nav {
  background: var(--zmgp-primary-dark);
  padding: 0 32px;
}
.zmgp-nav ul { list-style: none; margin: 0; padding: 0; display: flex; gap: 4px; }
.zmgp-nav li { display: block; }
.zmgp-nav a {
  display: block;
  padding: 10px 16px;
  color: white;
  text-decoration: none;
  font-weight: 500;
  border-bottom: 3px solid transparent;
}
.zmgp-nav a:hover { background: rgba(255, 255, 255, 0.08); }
.zmgp-nav a:focus { outline: 3px solid var(--zmgp-accent); outline-offset: -3px; }
.zmgp-nav a[aria-current="page"] { border-bottom-color: var(--zmgp-accent); }

/* ── Main content area ────────────────────────────────────────────── */
.zmgp-main {
  max-width: 1100px;
  margin: 24px auto;
  padding: 0 24px;
}

/* ── Footer ───────────────────────────────────────────────────────── */
.zmgp-footer {
  background: white;
  border-top: 1px solid var(--zmgp-border);
  padding: 24px 32px;
  margin-top: 48px;
  font-size: 0.85em;
  color: var(--zmgp-text-muted);
}
.zmgp-footer a { color: var(--zmgp-primary); }

/* ── Card component ───────────────────────────────────────────────── */
.zmgp-card {
  background: var(--zmgp-bg-card);
  border: 1px solid var(--zmgp-border-subtle);
  padding: 20px 24px;
  margin-bottom: 16px;
  border-radius: var(--zmgp-radius);
  box-shadow: var(--zmgp-shadow-sm);
}
.zmgp-card h2 { margin: 0 0 12px 0; font-size: 1.1em; color: var(--zmgp-primary); }
.zmgp-card h3 { margin-top: 16px; font-size: 0.95em; color: var(--zmgp-text); }

/* ── Buttons ──────────────────────────────────────────────────────── */
.zmgp-btn {
  display: inline-block;
  background: var(--zmgp-primary);
  color: white;
  border: 2px solid var(--zmgp-primary);
  padding: 10px 20px;
  font-family: inherit;
  font-size: 0.95em;
  font-weight: 600;
  cursor: pointer;
  border-radius: var(--zmgp-radius);
  min-height: 44px;          /* WCAG 2.5.5 touch target */
  text-decoration: none;
  text-align: center;
  transition: background 0.15s, border-color 0.15s;
}
.zmgp-btn:hover { background: var(--zmgp-primary-dark); border-color: var(--zmgp-primary-dark); }
.zmgp-btn:focus { outline: 3px solid var(--zmgp-accent); outline-offset: 2px; }
.zmgp-btn:disabled { background: var(--zmgp-border); border-color: var(--zmgp-border); cursor: not-allowed; }

.zmgp-btn--secondary { background: white; color: var(--zmgp-primary); }
.zmgp-btn--secondary:hover { background: var(--zmgp-primary-light); }

.zmgp-btn--danger { background: var(--zmgp-danger); border-color: var(--zmgp-danger); }
.zmgp-btn--danger:hover { background: #B91C0E; }

.zmgp-btn--small { padding: 6px 12px; min-height: 36px; font-size: 0.85em; }

/* ── Forms ────────────────────────────────────────────────────────── */
.zmgp-form-group { margin-bottom: 16px; }
.zmgp-form-label { display: block; font-weight: 600; margin-bottom: 6px; font-size: 0.9em; }
.zmgp-form-input, .zmgp-form-select, .zmgp-form-textarea {
  width: 100%;
  padding: 10px;
  font-family: inherit;
  font-size: 1em;
  border: 1px solid var(--zmgp-border);
  border-radius: var(--zmgp-radius);
  min-height: 44px;
}
.zmgp-form-input:focus, .zmgp-form-select:focus, .zmgp-form-textarea:focus {
  outline: 3px solid var(--zmgp-accent);
  outline-offset: 1px;
  border-color: var(--zmgp-primary);
}
.zmgp-form-help { font-size: 0.85em; color: var(--zmgp-text-muted); margin-top: 4px; }
.zmgp-form-error { font-size: 0.9em; color: var(--zmgp-danger); margin-top: 4px; font-weight: 600; }

/* ── Status pills + chips ─────────────────────────────────────────── */
.zmgp-status {
  display: inline-block;
  padding: 3px 12px;
  border-radius: var(--zmgp-radius-pill);
  font-size: 0.82em;
  font-weight: 600;
}
.zmgp-status--success { background: var(--zmgp-success-bg); color: var(--zmgp-success); }
.zmgp-status--warning { background: var(--zmgp-warning-bg); color: var(--zmgp-warning); }
.zmgp-status--danger  { background: var(--zmgp-danger-bg);  color: var(--zmgp-danger); }
.zmgp-status--info    { background: var(--zmgp-info-bg);    color: var(--zmgp-info); }

.zmgp-chip {
  display: inline-block;
  padding: 3px 12px;
  background: var(--zmgp-primary-light);
  color: var(--zmgp-primary);
  border-radius: var(--zmgp-radius-pill);
  font-size: 0.82em;
  margin: 2px;
  font-weight: 600;
}

/* ── Alerts ───────────────────────────────────────────────────────── */
.zmgp-alert {
  padding: 12px 16px;
  border-radius: var(--zmgp-radius);
  margin-bottom: 16px;
  border-left: 4px solid;
}
.zmgp-alert--info    { background: var(--zmgp-info-bg);    border-color: var(--zmgp-info);    color: #0F4F75; }
.zmgp-alert--success { background: var(--zmgp-success-bg); border-color: var(--zmgp-success); color: #155724; }
.zmgp-alert--warning { background: var(--zmgp-warning-bg); border-color: var(--zmgp-warning); color: #6F4500; }
.zmgp-alert--danger  { background: var(--zmgp-danger-bg);  border-color: var(--zmgp-danger);  color: #721C24; }

/* ── Tables ───────────────────────────────────────────────────────── */
.zmgp-table {
  width: 100%;
  border-collapse: collapse;
  background: white;
}
.zmgp-table th, .zmgp-table td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--zmgp-border-subtle);
}
.zmgp-table th { background: var(--zmgp-primary); color: white; font-weight: 600; }
.zmgp-table tr:hover { background: var(--zmgp-bg); }

/* ── Code/preformatted blocks ─────────────────────────────────────── */
.zmgp-code {
  font-family: var(--zmgp-font-mono);
  font-size: 0.85em;
  background: #F8F9FA;
  border: 1px solid var(--zmgp-border-subtle);
  padding: 10px;
  border-radius: var(--zmgp-radius);
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

/* ── Grid + utility ───────────────────────────────────────────────── */
.zmgp-grid { display: grid; gap: 12px; }
.zmgp-grid--auto { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.zmgp-grid--2col { grid-template-columns: 1fr 1fr; }
.zmgp-grid--3col { grid-template-columns: 1fr 1fr 1fr; }

@media (max-width: 768px) {
  .zmgp-grid--2col, .zmgp-grid--3col { grid-template-columns: 1fr; }
}

.zmgp-mt-0  { margin-top: 0 !important; }
.zmgp-mt-2  { margin-top: 8px !important; }
.zmgp-mt-4  { margin-top: 16px !important; }
.zmgp-mt-6  { margin-top: 24px !important; }
.zmgp-text-muted { color: var(--zmgp-text-muted); }
.zmgp-text-small { font-size: 0.85em; }

/* ── Print-styles ─────────────────────────────────────────────────── */
@media print {
  .zmgp-header, .zmgp-nav, .zmgp-footer, .zmgp-btn { display: none !important; }
  .zmgp-card { box-shadow: none; border: 1px solid #999; page-break-inside: avoid; }
}

/* ── Reduced motion ───────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  html { scroll-behavior: auto; }
}
