/* ------------------------------------------------------------------
   Klaar · boekhoudingklaar.nl
   Dutch SMB done-for-you bookkeeping + tax. Reccon is the operator.
   Design: adapted from the Reccon editorial system into a warmer,
   distinct "Klaar" identity. Fraunces + Inter + IBM Plex Mono.
   ------------------------------------------------------------------ */

:root{
  --paper:#F7F4ED;
  --paper-2:#EFEBDF;
  --paper-3:#E5DFCF;
  --card:#FCFBF7;
  --ink:#191917;
  --ink-soft:#46463E;
  --ink-faint:#8B887C;
  --line:#D9D4C6;
  --line-soft:#E6E1D2;
  --green:#15584A;          /* primary, a touch brighter than Reccon */
  --green-soft:#2A7A65;
  --green-bright:#1E8A6C;   /* "done / klaar" accent, checkmarks */
  --green-faint:#A4C5B9;
  --gold:#C68A1E;
  --terra:#BC4B2E;
  --maxw:1140px;
  --pad-x:clamp(22px,5vw,72px);
  --pad-y:clamp(72px,10vw,140px);
  --radius:12px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);color:var(--ink);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:5;
  background-image:radial-gradient(rgba(0,0,0,.02) 1px,transparent 1px);
  background-size:3px 3px;mix-blend-mode:multiply;
}
a{color:inherit;}
a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:4px;}
img,svg{display:block;max-width:100%;}
em{font-style:italic;}

/* ---------- type ---------- */
h1,h2,h3,h4,h5{font-family:'Fraunces',Georgia,serif;font-weight:500;font-optical-sizing:auto;letter-spacing:-.014em;color:var(--ink);}
h1{font-size:clamp(38px,5.4vw,68px);line-height:1.03;}
h1 em{font-style:italic;color:var(--green);}
h2{font-size:clamp(28px,3.8vw,46px);line-height:1.1;}
h2 em{font-style:italic;color:var(--green);}
h3{font-size:clamp(20px,2.1vw,27px);line-height:1.2;}
h4{font-size:clamp(17px,1.4vw,20px);line-height:1.3;}
p{color:var(--ink-soft);}
.lead{font-size:clamp(17px,1.45vw,21px);line-height:1.5;color:var(--ink-soft);max-width:36em;}
.lead strong{color:var(--ink);font-weight:600;}
.lead em{font-style:italic;color:var(--green);font-family:'Fraunces',serif;}
.eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);display:inline-flex;align-items:center;gap:9px;}
.eyebrow b{color:var(--green);font-weight:500;}
.mono{font-family:'IBM Plex Mono',monospace;}

/* ---------- layout ---------- */
.container{max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--pad-x);}
.section{padding:var(--pad-y) 0;position:relative;scroll-margin-top:74px;}
.section + .section{border-top:1px solid var(--line-soft);}
.alt-bg{background:var(--paper-2);}
.section-head{max-width:40ch;margin-bottom:clamp(36px,4.5vw,60px);}
.section-head h2{margin-top:12px;}
.section-head .lead{margin-top:16px;}
.center{margin-left:auto;margin-right:auto;text-align:center;}
.center .lead{margin-left:auto;margin-right:auto;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:'Inter',sans-serif;font-size:15px;font-weight:600;
  padding:13px 22px;border-radius:999px;cursor:pointer;
  background:var(--green);color:#F7F4ED;border:1px solid var(--green);
  text-decoration:none;transition:background .15s ease,transform .12s ease;
}
.btn:hover{background:var(--green-soft);}
.btn:active{transform:translateY(1px);}
.btn .arr{font-family:'IBM Plex Mono',monospace;font-size:13px;opacity:.85;}
.btn.ghost{background:transparent;color:var(--green);border-color:var(--green);}
.btn.ghost:hover{background:rgba(21,88,74,.06);}
.btn.lg{padding:15px 26px;font-size:16px;}
.btn.block{width:100%;}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:rgba(247,244,237,.85);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line-soft);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:13px var(--pad-x);display:flex;align-items:center;justify-content:space-between;gap:22px;}
.brand{display:inline-flex;align-items:center;gap:9px;color:var(--ink);font-family:'Fraunces',serif;font-weight:600;font-size:21px;letter-spacing:-.01em;text-decoration:none;}
.brand .mark{width:24px;height:24px;flex:none;}
.nav-links{display:flex;gap:26px;align-items:center;}
.nav-links a{text-decoration:none;color:var(--ink-soft);font-size:14.5px;transition:color .15s ease;}
.nav-links a:hover{color:var(--ink);}
@media (max-width:820px){.nav-links{display:none;}}

/* ---------- hero ---------- */
.hero{padding:clamp(40px,6vw,76px) 0 clamp(20px,4vw,40px);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center;}
.hero h1{margin-top:18px;}
.hero h1 .l1{display:block;white-space:nowrap;}
.hero h1 em{display:block;}
.hero .lead{margin-top:22px;}
.hero-cta-row{margin-top:28px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.hero-cta-row .quiet{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.06em;color:var(--ink-faint);}
.link-quiet{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.06em;color:var(--ink-faint);background:none;border:0;cursor:pointer;padding:0;border-bottom:1px dotted var(--ink-faint);transition:color .15s ease,border-color .15s ease;}
.link-quiet:hover{color:var(--green);border-bottom-color:var(--green);}
.hero-trust{margin-top:30px;display:flex;flex-direction:column;gap:11px;font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);}
.hero-trust span{display:inline-flex;align-items:center;gap:7px;}
.hero-trust .tick{color:var(--green-bright);font-weight:700;}
@media (max-width:880px){.hero-grid{grid-template-columns:1fr;}.hero h1{max-width:18ch;}}

/* ---------- price calculator ---------- */
.calc{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,2.6vw,30px);box-shadow:0 24px 60px -34px rgba(21,88,74,.45);}
.calc .calc-kicker{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);margin-bottom:4px;}
.calc h3{font-size:clamp(19px,1.8vw,23px);margin-bottom:18px;}
.field{margin-bottom:16px;}
.field > .lbl{display:block;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:500;margin-bottom:8px;}
.seg{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:6px;background:var(--paper-2);border:1px solid var(--line);border-radius:9px;padding:4px;}
.seg button{
  font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:var(--ink-soft);
  background:transparent;border:0;border-radius:6px;padding:9px 6px;cursor:pointer;
  white-space:nowrap;
  transition:background .14s ease,color .14s ease,box-shadow .14s ease;
}
.seg button:hover{color:var(--ink);}
.seg button[aria-pressed="true"]{background:var(--card);color:var(--green);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.08);}
.calc-out{margin-top:22px;padding-top:20px;border-top:1px dashed var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:nowrap;}
.calc-out > div:first-child{min-width:0;}
.calc-out .price{flex:none;white-space:nowrap;}
.calc-out .label{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);}
.calc-out .price{font-family:'Fraunces',serif;font-size:clamp(40px,5vw,54px);font-weight:500;color:var(--green);line-height:1;letter-spacing:-.02em;}
.calc-out .price small{font-size:.42em;color:var(--ink-faint);font-weight:400;letter-spacing:0;}
.calc-out .sub{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--ink-faint);margin-top:6px;white-space:nowrap;line-height:1.5;}
.calc-out .sub strong{color:var(--ink);font-weight:600;}
.calc .btn{margin-top:18px;}
.calc .fineprint{margin-top:12px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.04em;color:var(--ink-faint);line-height:1.5;text-align:center;}

/* ---------- generic cards/grids ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.2vw,26px);}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.2vw,26px);}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,2.4vw,30px);display:flex;flex-direction:column;gap:11px;}
.card .num{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);}
.card p{font-size:15px;line-height:1.55;}
.card p strong{color:var(--ink);font-weight:600;}
@media (max-width:860px){.grid-3{grid-template-columns:1fr;}.grid-2{grid-template-columns:1fr;}}

/* ---------- steps / how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.6vw,22px);}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,2vw,26px);display:flex;flex-direction:column;gap:9px;}
.step .n{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);}
.step h4{font-size:clamp(18px,1.5vw,21px);}
.step p{font-size:14px;line-height:1.5;color:var(--ink-soft);}
.step.accent{background:var(--green);border-color:var(--green);}
.step.accent .n{color:var(--green-faint);}
.step.accent h4{color:#F7F4ED;}
.step.accent p{color:#C9DBD4;}
@media (max-width:960px){.steps{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.steps{grid-template-columns:1fr;}}

/* ---------- rebuild proof ---------- */
.rebuild{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:center;}
.rebuild .stats{display:flex;gap:clamp(18px,2.6vw,36px);margin-top:22px;flex-wrap:wrap;}
.rebuild .stat .v{font-family:'Fraunces',serif;font-size:clamp(26px,3vw,38px);color:var(--green);font-weight:500;line-height:1;}
.rebuild .stat .l{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:7px;}
.ledger{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(18px,2vw,24px);box-shadow:0 24px 60px -38px rgba(21,88,74,.4);}
.ledger .top{display:flex;justify-content:space-between;align-items:center;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--line-soft);}
.ledger .dot{width:7px;height:7px;border-radius:50%;background:var(--green-bright);box-shadow:0 0 0 0 rgba(30,138,108,.5);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(30,138,108,.45)}70%{box-shadow:0 0 0 8px rgba(30,138,108,0)}100%{box-shadow:0 0 0 0 rgba(30,138,108,0)}}
.ledger .row{display:flex;justify-content:space-between;gap:12px;font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--ink-soft);padding:8px 0;border-bottom:1px dotted var(--line);}
.ledger .row:last-child{border-bottom:none;}
.ledger .row b{color:var(--green-bright);font-weight:600;display:inline-flex;gap:6px;align-items:center;}
@media (max-width:860px){.rebuild{grid-template-columns:1fr;}}

/* ---------- overstap (switching) ---------- */
.overstap{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,56px);align-items:center;}
.checklist{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:8px;}
.checklist li{display:grid;grid-template-columns:auto 1fr;gap:13px;font-size:15.5px;line-height:1.5;color:var(--ink-soft);}
.checklist li .tick{color:var(--green-bright);font-weight:700;font-family:'IBM Plex Mono',monospace;}
.checklist li b{color:var(--ink);font-weight:600;}
@media (max-width:860px){.overstap{grid-template-columns:1fr;}}

/* ---------- pricing ---------- */
.tabs{display:inline-flex;gap:5px;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:4px;margin-bottom:30px;}
.tabs button{font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:var(--ink-soft);background:transparent;border:0;border-radius:999px;padding:9px 20px;cursor:pointer;}
.tabs button[aria-pressed="true"]{background:var(--card);color:var(--green);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.08);}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);}
.plans[hidden]{display:none;}  /* class display:grid would otherwise override the [hidden] attribute */
.plan{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,2.6vw,32px);display:flex;flex-direction:column;gap:6px;}
.plan.featured{border-color:var(--green);box-shadow:0 20px 50px -34px rgba(21,88,74,.5);position:relative;}
.plan.featured::after{content:"Meest gekozen";position:absolute;top:-11px;left:24px;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;background:var(--green);color:#F7F4ED;padding:4px 12px;border-radius:999px;}
.plan .pname{font-family:'Fraunces',serif;font-size:22px;font-weight:500;}
.plan .pprice{font-family:'Fraunces',serif;font-size:clamp(32px,3.4vw,42px);font-weight:500;color:var(--green);line-height:1.1;margin:6px 0;}
.plan .pprice small{font-size:.4em;color:var(--ink-faint);font-weight:400;}
.plan .pdesc{font-size:14px;color:var(--ink-faint);min-height:2.6em;}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin:16px 0 22px;}
.plan li{display:grid;grid-template-columns:auto 1fr;gap:10px;font-size:14.5px;color:var(--ink-soft);line-height:1.45;}
.plan li .tick{color:var(--green-bright);font-weight:700;font-family:'IBM Plex Mono',monospace;}
.plan .btn{margin-top:auto;}
.plan.featured .btn:not(.ghost){background:var(--green);}
.plan.is-match{outline:2.5px solid var(--green-bright);outline-offset:4px;box-shadow:0 22px 50px -30px rgba(30,138,108,.6);transition:outline-color .2s ease,box-shadow .2s ease;}
@media (max-width:860px){.plans{grid-template-columns:1fr;}}

/* ---------- trust band ---------- */
.trust-band{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.4vw,30px);}
/* subgrid: each card spans 2 shared rows so headers align and every paragraph
   starts on the same line, regardless of how many lines the title takes. */
.trust{grid-row:span 2;display:grid;grid-template-rows:subgrid;gap:10px;}
.trust .h{font-family:'Fraunces',serif;font-size:clamp(17px,1.5vw,20px);font-weight:500;color:var(--green);line-height:1.2;display:flex;align-items:flex-start;gap:9px;}
.trust .h .tick{line-height:1.2;}
.trust p{font-size:13.5px;line-height:1.5;color:var(--ink-soft);}
@media (max-width:860px){.trust-band{grid-template-columns:1fr 1fr;}}
@media (max-width:480px){.trust-band{grid-template-columns:1fr;}}

/* ---------- faq ---------- */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;}
.faq details{border-bottom:1px solid var(--line);padding:18px 0;}
.faq summary{cursor:pointer;list-style:none;font-family:'Fraunces',serif;font-size:clamp(18px,1.7vw,21px);font-weight:500;color:var(--ink);display:flex;justify-content:space-between;gap:16px;align-items:center;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pm{font-family:'IBM Plex Mono',monospace;color:var(--green);font-size:18px;transition:transform .2s ease;}
.faq details[open] summary .pm{transform:rotate(45deg);}
.faq details p{margin-top:12px;font-size:15.5px;line-height:1.6;color:var(--ink-soft);max-width:64ch;}

/* ---------- final CTA ---------- */
.cta-band{background:var(--green);color:#EDEAE0;border-radius:16px;padding:clamp(40px,6vw,72px) clamp(28px,4vw,56px);text-align:center;position:relative;overflow:hidden;}
.cta-band::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 2px,transparent 2px 9px);pointer-events:none;}
.cta-band h2{color:#F7F4ED;max-width:20ch;margin:0 auto;position:relative;}
.cta-band h2 em{color:var(--green-faint);}
.cta-band p{color:#C9DBD4;margin:18px auto 28px;max-width:48ch;position:relative;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;}
.cta-band .btn{background:#F7F4ED;color:var(--green);border-color:#F7F4ED;position:relative;}
.cta-band .btn:hover{background:#fff;}

/* ---------- footer ---------- */
footer{padding:clamp(44px,6vw,68px) 0 clamp(30px,4vw,44px);border-top:1px solid var(--line-soft);font-size:14px;color:var(--ink-faint);}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:32px;}
.foot-inner h6{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:12px;font-weight:500;}
.foot-inner p{font-size:13.5px;line-height:1.55;color:var(--ink-faint);max-width:32em;margin-top:12px;}
.foot-inner ul{list-style:none;display:flex;flex-direction:column;gap:8px;}
.foot-inner a{color:var(--ink-soft);text-decoration:none;font-size:13.5px;}
.foot-inner a:hover{color:var(--ink);}
.foot-legal{max-width:var(--maxw);margin:32px auto 0;padding:22px var(--pad-x) 0;border-top:1px solid var(--line-soft);font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);}
@media (max-width:760px){.foot-inner{grid-template-columns:1fr;}}

/* ---------- lead modal ---------- */
.modal{
  width:min(440px,calc(100vw - 32px));border:1px solid var(--line);border-radius:16px;
  padding:clamp(26px,3vw,36px);background:var(--card);color:var(--ink);
  box-shadow:0 40px 90px -30px rgba(21,88,74,.5);
  /* the global *{margin:0} reset cancels the UA margin:auto that centers a modal
     dialog, so restore it explicitly. inset:0 comes from the UA modal style. */
  margin:auto;max-height:calc(100dvh - 32px);overflow:auto;
  transition:width .2s ease;
}
.modal.wide{width:min(620px,calc(100vw - 32px));}
.modal::backdrop{background:rgba(25,25,23,.45);backdrop-filter:blur(3px);}
.modal[open]{animation:modalin .22s ease;}
@keyframes modalin{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:0;font-size:26px;line-height:1;color:var(--ink-faint);cursor:pointer;padding:4px;}
.modal-close:hover{color:var(--ink);}
.modal-kicker{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);margin-bottom:6px;}
.modal h3{font-size:clamp(22px,2.4vw,28px);}
.modal-ctx{margin-top:10px;font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--green);background:var(--paper-2);border:1px solid var(--line);border-radius:8px;padding:9px 12px;display:inline-block;}
.modal-ctx b{font-weight:600;}
.modal-sub{margin-top:10px;font-size:15px;color:var(--ink-soft);line-height:1.5;}
#lead-form{display:flex;flex-direction:column;gap:14px;margin-top:20px;}
#lead-form label{display:flex;flex-direction:column;gap:6px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:500;}
#lead-form label .opt{color:var(--ink-faint);text-transform:none;letter-spacing:0;}
#lead-form input,#lead-form select{
  font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:11px 13px;width:100%;
  transition:border-color .15s ease;
}
#lead-form input:focus,#lead-form select:focus{outline:none;border-color:var(--green);}
#lead-form .btn{margin-top:4px;}
.hp{position:absolute !important;left:-9999px;width:1px;height:1px;opacity:0;}
.kvk-result{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--green);margin-top:-4px;}
.kvk-result.is-err{color:var(--terra);}
.form-error{font-size:13.5px;color:var(--terra);line-height:1.4;}
.modal-fine{font-family:'IBM Plex Mono',monospace;font-size:10.5px;line-height:1.5;color:var(--ink-faint);}
.cal-embed{margin-top:16px;border:1px solid var(--line);border-radius:10px;overflow:hidden;min-height:480px;}
.cal-embed iframe{width:100%;height:560px;border:0;display:block;}
.cal-embed.calendly{height:680px;min-height:680px;border:none;}
.cal-embed.calendly iframe,.cal-embed.calendly .calendly-inline-widget{height:680px !important;min-width:0 !important;}
