@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Karla:wght@400;500;600;700&family=IBM+Plex+Mono:wght@500&display=swap');

:root{
  --bg: #FBF6EF;
  --ink: #2B2620;
  --ink-soft: #6B6358;
  --navy: #3A4A5C;
  --clay: #C9714B;
  --clay-soft: #F1DCC9;
  --sage: #94A88A;
  --line: #E9DFD0;
  --white: #FFFEFB;
  --radius: 16px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Karla', sans-serif;
  line-height:1.65;
}
h1,h2,h3{
  font-family:'Fraunces', serif;
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0 0 .5em 0;
}
a{ color:var(--navy); text-decoration:none; }
.label{
  font-family:'IBM Plex Mono', monospace;
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--clay);
}
.hint-chip{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 14px;
  font-size:.82rem;
  color:var(--navy);
  cursor:pointer;
}
.hint-chip:hover{ border-color:var(--clay); color:var(--clay); }
.icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:8px;
  border:1px solid var(--line);
  background:var(--white);
  cursor:pointer;
  font-size:1rem;
  flex-shrink:0;
}
.icon-btn:hover{ border-color:var(--clay); }
.container{ max-width:1080px; margin:0 auto; padding:0 24px; }

/* --- Nav (sticky, altijd zichtbaar) --- */
.nav-bar{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,246,239,.92);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; padding:18px 24px; max-width:1080px; margin:0 auto; flex-wrap:wrap; gap:12px; }
.nav .brand{ font-family:'Fraunces', serif; font-weight:600; font-size:1.25rem; }
.nav .brand span{ color:var(--clay); }
.nav-links{ display:flex; gap:24px; align-items:center; flex-wrap:wrap; }
.nav-links a{ color:var(--ink); font-size:.92rem; }
.nav-links a.current{ color:var(--clay); font-weight:700; }
.btn{
  display:inline-block;
  background:var(--clay);
  color:var(--white);
  padding:11px 22px;
  border-radius:var(--radius);
  border:none;
  font-size:.95rem;
  font-weight:600;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease;
}
.btn:hover{ transform:translateY(-1px); box-shadow:0 6px 16px rgba(201,113,75,.25); }
.btn.clay{ background:var(--clay); }
.btn.outline{ background:transparent; color:var(--navy); border:1.5px solid var(--line); }
.btn.outline:hover{ border-color:var(--navy); }

/* --- Hero: zachte, elegante intro --- */
.hero{ padding:56px 24px 72px; max-width:1080px; margin:0 auto; }
.hero h1{
  text-align:center;
  font-size:clamp(2.2rem, 5vw, 3.4rem);
  max-width:760px;
  margin:0 auto 20px;
  line-height:1.18;
}
.hero p.sub{
  text-align:center;
  max-width:560px;
  margin:0 auto 28px;
  color:var(--ink-soft);
  font-size:1.1rem;
}
.hero-actions{ display:flex; justify-content:center; gap:14px; margin-bottom:44px; }

.balance{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:0;
  align-items:center;
  border-radius:22px;
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--white);
  padding:6px;
}
.balance .side{ padding:30px 32px; }
.balance .side.left{ background:var(--clay-soft); border-radius:18px 0 0 18px; }
.balance .side.right{ background:#E9EEE5; border-radius:0 18px 18px 0; }
.balance .side .who{ font-family:'IBM Plex Mono', monospace; font-size:.66rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-soft); margin-bottom:10px; }
.balance .side p{ margin:0; font-family:'Fraunces', serif; font-style:italic; font-size:1.05rem; color:var(--ink); line-height:1.5; }
.balance .side.left p{ text-align:left; }
.balance .side.right p{ text-align:right; }
.balance .divider{
  width:1px;
  height:50%;
  background:var(--line);
  margin:0 6px;
}
.balance-result{
  text-align:center;
  margin-top:18px;
  font-family:'IBM Plex Mono', monospace;
  font-size:.78rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--sage);
}

@media (max-width:680px){
  .balance{ grid-template-columns:1fr; }
  .balance .divider{ display:none; }
  .balance .side.right{ text-align:left; border-radius:0 0 18px 18px; }
  .balance .side.right p{ text-align:left; }
  .balance .side.left{ border-radius:18px 18px 0 0; }
  .hero-actions{ flex-direction:column; align-items:center; }
  .nav{ justify-content:center; text-align:center; }
}

/* --- Sections --- */
.section{ padding:56px 24px; max-width:1080px; margin:0 auto; }
.section-head{ max-width:600px; margin-bottom:32px; }
.section-head .label{ margin-bottom:8px; display:block; }
.section-head h2{ font-size:2.3rem; position:relative; padding-bottom:14px; }
.section-head h2::after{
  content:'';
  position:absolute;
  left:0; bottom:0;
  width:48px; height:3px;
  background:var(--clay);
  border-radius:2px;
}

.grid-3{ display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
@media (max-width:880px){ .grid-3{ grid-template-columns:1fr; } }

.card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
}
.card h3{ font-size:1.15rem; margin-bottom:10px; }
.card p{ color:var(--ink-soft); font-size:.95rem; margin:0; }

/* --- Doelgroepen tabs --- */
.audience-tabs{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:32px; }
.audience-tab{
  padding:9px 18px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--white);
  font-size:.9rem;
  cursor:pointer;
  color:var(--ink-soft);
}
.audience-tab.active{ background:var(--navy); color:var(--white); border-color:var(--navy); }
.audience-panel{ display:none; }
.audience-panel.active{ display:block; }
.audience-panel .card{ display:flex; gap:24px; align-items:flex-start; }
.audience-panel .card .icon{ font-size:1.8rem; }

/* --- Footer --- */
.footer{ border-top:1px solid var(--line); padding:40px 24px; text-align:center; color:var(--ink-soft); font-size:.88rem; }

/* --- Forms (app pages) --- */
.app-wrap{ max-width:640px; margin:0 auto; padding:48px 24px 96px; }
.app-wrap h1{ font-size:1.8rem; }
.field{ margin-bottom:20px; }
.field label{ display:block; margin-bottom:6px; font-weight:500; font-size:.92rem; }
.field input[type=text], .field textarea, .field select{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:8px;
  font-family:'Karla', sans-serif;
  font-size:.96rem;
  background:var(--white);
  color: var(--ink);
}
.field textarea{ min-height:160px; resize:vertical; }
.editable-field{
  width:100%;
  min-height:160px;
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:8px;
  font-family:'Karla', sans-serif;
  font-size:.96rem;
  background:var(--white);
  color:var(--ink);
  line-height:1.6;
  overflow-y:auto;
}
.editable-field:empty::before{
  content:attr(data-placeholder);
  color:var(--ink-soft);
}
.editable-field strong{ color:var(--clay); }
.field .help{ color:var(--ink-soft); font-size:.85rem; margin-top:6px; }
.checkbox-row{ display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.checkbox-row input{ width:18px; height:18px; }
.status-box{
  border:1px solid var(--line);
  background:var(--white);
  border-radius:var(--radius);
  padding:24px;
  text-align:center;
  color:var(--ink-soft);
}
.error-box{
  border:1px solid #E2B9A6;
  background:#FBEFE9;
  color:#8A4222;
  border-radius:var(--radius);
  padding:16px;
  margin-bottom:20px;
  font-size:.9rem;
}

/* --- Document weergave --- */
.doc-section{ margin-bottom:36px; padding-bottom:36px; border-bottom:1px solid var(--line); }
.doc-section:last-child{ border-bottom:none; }
.doc-section .label{ margin-bottom:10px; display:block; }
.doc-section h3{ font-size:1.3rem; }
.tip-list{ padding-left:20px; }
.tip-list li{ margin-bottom:8px; }
.person-block{ background:var(--white); border:1px solid var(--line); border-radius:var(--radius); padding:24px; margin-bottom:16px; }
.person-block .who{ font-family:'IBM Plex Mono', monospace; font-size:.78rem; text-transform:uppercase; letter-spacing:.06em; color:var(--clay); margin-bottom:12px; }

/* --- Mobiel --- */
@media (max-width:480px){
  .section{ padding:40px 16px; }
  .app-wrap{ padding:32px 16px 72px; }
  .hero{ padding:40px 16px 56px; }
  .balance .side{ padding:22px 18px; }
  .nav{ padding:14px 16px; }
  .section-head h2{ font-size:1.7rem; }
}
