/* simple-page.css - styles for the generic SimplePage component (over/klanten/werken-bij/contact/pers + legal) */

.sec { margin-top: 56px; }
.sec:first-of-type { margin-top: 48px; }

/* prose ─────────────────────────── */
.prose-block { display: flex; flex-direction: column; gap: 14px; max-width: 80ch; }
.prose-h {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: clamp(28px, 3.4vw, 44px); letter-spacing: -.035em; line-height: 1.05;
  color: var(--ink); margin-bottom: 6px; text-wrap: balance;
}
.prose-h.sienna { color: var(--sienna); }
.prose-p {
  font-family: 'Archivo', sans-serif; font-size: 17px; line-height: 1.6;
  color: var(--ink); text-wrap: pretty;
}

/* lists ─────────────────────────── */
.list-block { max-width: 80ch; }
.list-block .prose-h { margin-bottom: 18px; }
.prose-list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--rule); }
.prose-list li {
  padding: 16px 0 16px 24px; border-bottom: 1px solid var(--rule); position: relative;
  font-family: 'Archivo', sans-serif; font-size: 16px; line-height: 1.5; color: var(--ink);
}
.prose-list li::before {
  content: '+'; position: absolute; left: 0; top: 16px;
  color: var(--sienna); font-weight: 700; font-family: 'JetBrains Mono', monospace;
}
.prose-list li b { font-weight: 700; }
.prose-list li .li-def { color: var(--ash); margin-left: 6px; }

/* definition list ────────────────── */
.def-block { max-width: 100ch; }
.def-block .prose-h { margin-bottom: 18px; }
.def-list {
  display: grid; grid-template-columns: 240px 1fr; gap: 0;
  border-top: 1px solid var(--ink); margin: 0;
}
.def-list dt {
  padding: 18px 24px 18px 0; border-bottom: 1px solid var(--rule);
  font-size: 11px; text-transform: uppercase; letter-spacing: .12em;
  color: var(--sienna); font-weight: 700; align-self: start;
}
.def-list dd {
  padding: 18px 0; border-bottom: 1px solid var(--rule); margin: 0;
  font-family: 'Archivo', sans-serif; font-size: 16px; line-height: 1.55;
  color: var(--ink); text-wrap: pretty;
}
/* clean ending - laatste rij geen border-bottom */
.def-list dt:nth-last-of-type(1),
.def-list dd:nth-last-of-type(1) {
  border-bottom: none;
}

/* contact card ──────────────────── */
.contact-card { border: 1px solid var(--ink); background: var(--ivory); }
.cc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.cc-row {
  padding: 24px 28px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 8px;
}
.cc-row:nth-child(2n) { border-right: none; }
.cc-row:nth-last-child(-n+2) { border-bottom: none; }
.cc-row:last-child:nth-child(odd) { grid-column: 1/-1; border-right: none; }
.cc-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ash); font-weight: 700;
}
.cc-val {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 600;
  font-size: 20px; letter-spacing: -.015em; line-height: 1.3; color: var(--ink);
}
.cc-link { border-bottom: 1px solid var(--rule); padding-bottom: 2px; transition: border-color .2s, color .2s; width: fit-content; }
.cc-link:hover { color: var(--sienna); border-color: var(--sienna); }

/* status ────────────────────────── */
.status-overall {
  border: 1px solid var(--ink); background: var(--ink); color: var(--ivory);
  padding: 28px 32px; display: flex; gap: 20px; align-items: center;
}
.status-state {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 28px; letter-spacing: -.025em; line-height: 1.1;
}
.status-sub { font-size: 11px; color: var(--ivory); opacity: .7; margin-top: 4px; letter-spacing: .04em; }
.status-dot { width: 14px; height: 14px; border-radius: 50%; background: #5fa979; flex-shrink: 0; box-shadow: 0 0 0 4px rgba(95,169,121,.25); }
.status-dot.degraded { background: #d9a04a; box-shadow: 0 0 0 4px rgba(217,160,74,.25); }
.status-dot.down { background: #c4503d; box-shadow: 0 0 0 4px rgba(196,80,61,.3); }
.status-dot.plan { background: var(--ash); box-shadow: 0 0 0 4px rgba(110,107,103,.25); }
.status-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border: 1px solid var(--ink); border-top: none;
}
.status-svc {
  padding: 20px 24px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  display: flex; gap: 14px; align-items: flex-start; background: var(--ivory);
}
.status-svc:nth-child(2n) { border-right: none; }
.status-svc:nth-last-child(-n+2) { border-bottom: none; }
.status-svc .status-dot { margin-top: 6px; width: 10px; height: 10px; box-shadow: 0 0 0 3px rgba(95,169,121,.25); }
.status-svc .status-dot.degraded { box-shadow: 0 0 0 3px rgba(217,160,74,.25); }
.status-svc-name {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700;
  font-size: 16px; letter-spacing: -.015em; color: var(--ink);
}
.status-svc-meta { font-size: 11px; color: var(--ash); margin-top: 4px; letter-spacing: .04em; }
.status-history { margin-top: 56px; }
.status-history .prose-h { margin-bottom: 18px; }
.status-hist-list { border-top: 1px solid var(--rule); }
.status-hist-row {
  display: grid; grid-template-columns: 180px 1fr auto; gap: 24px; align-items: center;
  padding: 16px 0; border-bottom: 1px solid var(--rule);
}
.status-hist-date { font-size: 11px; color: var(--ash); letter-spacing: .04em; }
.status-hist-msg { font-family: 'Archivo', sans-serif; font-size: 15px; color: var(--ink); }
.status-hist-tag {
  font-size: 10px; text-transform: uppercase; letter-spacing: .12em; font-weight: 700;
  padding: 4px 10px; border: 1px solid var(--rule);
}
.status-hist-tag.ok { color: #4a8463; border-color: #4a8463; }
.status-hist-tag.plan { color: var(--ash); }

/* clients ───────────────────────── */
.client-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border: 1px solid var(--ink);
}
.client-card {
  padding: 32px 32px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  background: var(--ivory); display: grid; grid-template-columns: 80px 1fr; gap: 24px;
  align-items: start;
}
.client-card:nth-child(2n) { border-right: none; }
.client-card:nth-last-child(-n+2) { border-bottom: none; }
.client-mark {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 36px; letter-spacing: -.04em; color: var(--sienna);
  border: 1px solid var(--ink); padding: 14px 0; text-align: center; background: var(--cream);
}
.client-name {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 26px; letter-spacing: -.025em; color: var(--ink); line-height: 1.05;
}
.client-tag { font-size: 11px; color: var(--ash); margin-top: 4px; letter-spacing: .04em; }
.client-quote {
  font-family: 'Archivo', sans-serif; font-size: 15px; line-height: 1.55;
  color: var(--ink); margin-top: 14px; text-wrap: pretty; font-style: italic;
}
.client-meta {
  font-size: 10px; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ash); margin-top: 14px; font-weight: 600;
}

/* founders ──────────────────────── */
.founders-block .prose-h { margin-bottom: 24px; }
.founders-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1px solid var(--ink);
}
.founder {
  padding: 28px; border-right: 1px solid var(--rule); background: var(--ivory);
  display: flex; flex-direction: column; gap: 10px;
}
.founder:last-child { border-right: none; }
.founder-portrait {
  width: 100%; aspect-ratio: 1; background: var(--cream); border: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: center; margin-bottom: 8px;
}
.founder-mark {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 64px; letter-spacing: -.04em; color: var(--sienna);
}
.founder-name {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 22px; letter-spacing: -.02em; color: var(--ink); line-height: 1.05;
}
.founder-role { font-size: 11px; color: var(--sienna); letter-spacing: .04em; font-weight: 700; }
.founder-bio { font-family: 'Archivo', sans-serif; font-size: 14px; line-height: 1.55; color: var(--ink); margin-top: 6px; text-wrap: pretty; }

/* press ─────────────────────────── */
.press-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border: 1px solid var(--ink);
}
.press-card {
  padding: 28px 32px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  background: var(--ivory); display: grid; grid-template-columns: 1fr auto;
  grid-template-rows: auto auto auto; gap: 8px 24px; align-items: center;
  transition: background .2s;
}
.press-card:nth-child(2n) { border-right: none; }
.press-card:nth-last-child(-n+2) { border-bottom: none; }
.press-card:hover { background: var(--cream); }
.press-tag {
  grid-column: 1; font-size: 10px; text-transform: uppercase;
  letter-spacing: .12em; color: var(--sienna); font-weight: 700;
}
.press-name {
  grid-column: 1; font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 22px; letter-spacing: -.02em; color: var(--ink); line-height: 1.1;
}
.press-meta {
  grid-column: 1; font-size: 11px; color: var(--ash); letter-spacing: .04em;
}
.press-arr {
  grid-column: 2; grid-row: 1/-1; font-size: 32px; color: var(--sienna);
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 600;
  align-self: center; transition: transform .2s;
}
.press-card:hover .press-arr { transform: translateY(2px); }

/* form ──────────────────────────── */
.contact-form {
  border: 1px solid var(--ink); background: var(--ivory); padding: 36px 40px;
  display: flex; flex-direction: column; gap: 24px;
}
.cf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.cf-field {
  padding: 16px 20px 18px; border-bottom: 1px solid var(--rule); border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 8px;
}
.cf-field:nth-child(2n) { border-right: none; }
.cf-field.cf-full { grid-column: 1/-1; border-right: none; }
.cf-field label {
  font-size: 10px; text-transform: uppercase; letter-spacing: .12em;
  color: var(--sienna); font-weight: 700;
}
.cf-field input, .cf-field textarea {
  border: none; background: transparent; font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 18px; letter-spacing: -.01em; color: var(--ink); outline: none;
  padding: 4px 0; resize: none;
}
.cf-field input::placeholder, .cf-field textarea::placeholder { color: var(--ash); }
.cf-field:focus-within { background: var(--cream); }
.contact-form button[type="submit"] { align-self: flex-start; }

.contact-form-done {
  border: 1px solid var(--sienna); background: rgba(196,90,61,.04); padding: 56px 48px;
  text-align: center; display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.cf-tick {
  width: 56px; height: 56px; border: 2px solid var(--sienna); color: var(--sienna);
  display: flex; align-items: center; justify-content: center; font-size: 28px; font-weight: 600;
  margin-bottom: 8px;
}
.cf-done-title {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800;
  font-size: 28px; letter-spacing: -.025em; color: var(--ink);
}
.cf-done-sub { font-family: 'Archivo', sans-serif; font-size: 15px; line-height: 1.55; color: var(--ash); max-width: 50ch; }

/* callout ───────────────────────── */
.callout-block {
  border: 1px solid var(--ink); background: var(--ink); color: var(--ivory);
  padding: 40px 48px; display: flex; flex-direction: column; gap: 18px;
}
.callout-eyebrow {
  font-size: 11px; text-transform: uppercase; letter-spacing: .14em;
  color: var(--sienna); font-weight: 700;
}
.callout-text {
  font-family: 'Bricolage Grotesque', sans-serif; font-weight: 600;
  font-size: clamp(22px, 2.6vw, 32px); letter-spacing: -.025em; line-height: 1.25;
  color: var(--ivory); text-wrap: balance; max-width: 60ch;
}
.callout-block .btn-primary {
  align-self: flex-start; margin-top: 8px;
  background: var(--sienna); color: var(--ivory); border-color: var(--sienna);
}
.callout-block .btn-primary:hover { background: var(--ivory); color: var(--ink); border-color: var(--ivory); }

/* responsive ────────────────────── */
@media (max-width: 900px) {
  .def-list { grid-template-columns: 1fr; }
  .def-list dt { padding-bottom: 4px; border-bottom: none; }
  .def-list dd { padding-top: 0; }
  .cc-grid { grid-template-columns: 1fr; }
  .cc-row { border-right: none !important; }
  .cc-row:not(:last-child) { border-bottom: 1px solid var(--rule) !important; }
  .status-grid { grid-template-columns: 1fr; }
  .status-svc { border-right: none !important; }
  .client-grid { grid-template-columns: 1fr; }
  .client-card { grid-template-columns: 60px 1fr; gap: 18px; padding: 24px; border-right: none !important; }
  .founders-grid { grid-template-columns: 1fr; }
  .founder { border-right: none; border-bottom: 1px solid var(--rule); }
  .founder:last-child { border-bottom: none; }
  .press-grid { grid-template-columns: 1fr; }
  .press-card { border-right: none !important; }
  .cf-grid { grid-template-columns: 1fr; }
  .cf-field { border-right: none !important; }
  .contact-form { padding: 24px