/* Solum Signal — marketingsite. Hergebruikt de design tokens uit /tokens.css. */

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--font-ui);
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--ink);
  background: var(--paper);
}

a { color: var(--ink); }

.wrap { max-width: 1080px; margin: 0 auto; padding: 0 var(--s-6); }

/* --- Topbar --- */

.topbar {
  position: sticky; top: 0; z-index: 10;
  background: rgba(247, 246, 242, 0.86);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--hairline);
}
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brandmark { display: flex; align-items: center; gap: var(--s-2); text-decoration: none; color: var(--ink); }
.brandmark .name { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); letter-spacing: var(--tracking-display); }
.nav { display: flex; align-items: center; gap: var(--s-5); }
.nav a { font-size: var(--text-sm); text-decoration: none; color: var(--muted); }
.nav a:hover, .nav a.active { color: var(--ink); }

/* --- Knoppen --- */

.btn {
  display: inline-block;
  font-family: var(--font-ui); font-size: var(--text-base); font-weight: 600;
  text-decoration: none; cursor: pointer;
  padding: 10px var(--s-5); border-radius: var(--r-sm);
  border: 1px solid var(--hairline-strong); background: var(--surface); color: var(--ink);
  transition: background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.btn:hover { background: var(--surface-sunken); }
.btn:active { transform: scale(0.98); }
.btn.primary { background: var(--ink); border-color: var(--ink); color: var(--surface); }
.btn.primary:hover { background: #33312C; }
.btn.lg { padding: 14px var(--s-6); font-size: var(--text-md); }

/* --- Hero --- */

.hero { padding: var(--s-12) 0 var(--s-10); }
.hero h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(32px, 5vw, 52px); line-height: 1.08;
  letter-spacing: var(--tracking-display); margin: 0 0 var(--s-4); max-width: 16ch;
}
.hero .lead { font-size: var(--text-lg); color: var(--muted); max-width: 52ch; margin: 0 0 var(--s-6); }
.hero .cta-row { display: flex; gap: var(--s-3); flex-wrap: wrap; align-items: center; }
.hero .reassure { font-size: var(--text-sm); color: var(--faint); margin: var(--s-4) 0 0; }

/* --- Teaser-kaart (statische SVG, geen echte data) --- */

.teaser { margin-top: var(--s-10); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-panel); background: var(--surface-sunken); }
.teaser svg { display: block; width: 100%; height: auto; }

/* --- Secties --- */

section { padding: var(--s-12) 0; }
section.alt { background: var(--surface); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.eyebrow { font-size: var(--text-xs); font-weight: 600; text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--muted); margin: 0 0 var(--s-2); }
h2.section-title { font-family: var(--font-display); font-weight: 700; font-size: clamp(24px, 3.5vw, 34px); letter-spacing: var(--tracking-display); margin: 0 0 var(--s-6); max-width: 22ch; }

/* stappen / kaarten-grid */
.grid { display: grid; gap: var(--s-4); }
.grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 860px) { .grid.cols-4, .grid.cols-3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .grid.cols-4, .grid.cols-3 { grid-template-columns: 1fr; } }

.card { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--r-md); padding: var(--s-5); }
section.alt .card { background: var(--paper); }
.card .step-no { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xl); color: var(--hairline-strong); letter-spacing: var(--tracking-display); }
.card h3 { font-size: var(--text-md); font-weight: 600; margin: var(--s-2) 0 var(--s-1); }
.card p { font-size: var(--text-sm); color: var(--muted); margin: 0; }

/* --- Prijzen --- */

.price-table { width: 100%; border-collapse: collapse; background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--r-md); overflow: hidden; }
.price-table th, .price-table td { text-align: left; padding: 12px var(--s-4); border-bottom: 1px solid var(--hairline); font-size: var(--text-base); }
.price-table th { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--muted); font-weight: 600; }
.price-table td:last-child, .price-table th:last-child { text-align: right; font-variant-numeric: tabular-nums; }
.price-table tr:last-child td { border-bottom: none; }
.price-note { display: flex; gap: var(--s-4); flex-wrap: wrap; margin-top: var(--s-5); }
.price-note .chip { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--r-full); padding: 6px var(--s-4); font-size: var(--text-sm); color: var(--ink); }

/* --- Doelgroepen --- */
.audience .card h3 { font-size: var(--text-lg); font-family: var(--font-display); letter-spacing: var(--tracking-display); }

/* --- CTA-blok --- */
.cta-band { text-align: center; }
.cta-band h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(24px, 3.5vw, 36px); letter-spacing: var(--tracking-display); margin: 0 0 var(--s-3); }
.cta-band p { color: var(--muted); margin: 0 0 var(--s-6); }

/* --- Formulieren --- */

.form-card { background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: var(--s-6); max-width: 560px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }
@media (max-width: 560px) { .form-row { grid-template-columns: 1fr; } }
.field-block { margin-bottom: var(--s-3); }
.field-block label { display: block; font-size: var(--text-xs); font-weight: 600; text-transform: uppercase; letter-spacing: var(--tracking-caps); color: var(--muted); margin-bottom: var(--s-1); }
.field-block input, .field-block textarea {
  width: 100%; font-family: var(--font-ui); font-size: var(--text-base); color: var(--ink);
  background: var(--paper); border: 1px solid var(--hairline-strong); border-radius: var(--r-sm); padding: 10px var(--s-3);
}
.field-block textarea { min-height: 110px; resize: vertical; }
.field-block input:focus-visible, .field-block textarea:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.form-status { font-size: var(--text-sm); margin-top: var(--s-3); min-height: 18px; }

/* nieuwsbrief in footer */
.newsletter { background: var(--surface); border-top: 1px solid var(--hairline); padding: var(--s-8) 0; }
.newsletter h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); letter-spacing: var(--tracking-display); margin: 0 0 var(--s-1); }
.newsletter p { color: var(--muted); font-size: var(--text-sm); margin: 0 0 var(--s-4); }
.newsletter form { display: flex; gap: var(--s-2); max-width: 460px; }
.newsletter input { flex: 1; font-family: var(--font-ui); font-size: var(--text-base); color: var(--ink); background: var(--paper); border: 1px solid var(--hairline-strong); border-radius: var(--r-sm); padding: 10px var(--s-3); }
.newsletter input:focus-visible { outline: none; box-shadow: var(--focus-ring); }

/* --- Footer --- */
footer { border-top: 1px solid var(--hairline); padding: var(--s-8) 0; color: var(--muted); font-size: var(--text-sm); }
footer .wrap { display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--s-4); }
footer a { color: var(--muted); text-decoration: none; }
footer a:hover { color: var(--ink); }

@media (max-width: 560px) { .nav .navlinks { display: none; } }
