/* =========================================================================
   Vacature-configurator — "Plaats je vacature"
   Build-up inspired by a step wizard, in the Bredasevacatures huisstijl.
   ========================================================================= */

/* hero (compact) */
.cfg-hero{padding:60px 0 34px;}
.cfg-hero .lead{font-size:1.15rem;max-width:54ch;margin-top:18px;}
.cfg-bullets{display:grid;grid-template-columns:1fr 1fr;gap:12px 30px;margin-top:28px;max-width:760px;}
.cfg-bullets li{display:flex;gap:11px;align-items:flex-start;font-weight:500;color:var(--ink);
  list-style:none;}
.cfg-bullets{padding:0;}
.cfg-bullets li svg{width:21px;height:21px;color:var(--primary);flex-shrink:0;margin-top:2px;}

/* layout: builder + sticky summary */
.cfg-wrap{display:grid;grid-template-columns:1fr 372px;gap:32px;align-items:start;
  padding-bottom:90px;}

/* steps */
.cfg-step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 30px 26px;margin-bottom:20px;}
.cfg-step-head{display:flex;align-items:center;gap:14px;margin-bottom:6px;}
.cfg-step-no{width:38px;height:38px;border-radius:50% 50% 50% 0;background:var(--green-tint);
  color:var(--primary-strong);font-family:var(--font-head);font-weight:800;font-size:1.05rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;transform:rotate(0);}
.cfg-step h2{font-size:1.4rem;}
.cfg-step .step-sub{color:var(--muted);font-size:.96rem;margin:2px 0 22px 52px;}

/* progressive disclosure: hide steps until the previous one is completed */
.cfg-step.locked{display:none;}
.cfg-step-foot{display:flex;justify-content:flex-end;margin-top:20px;}
.cfg-step-foot.used{display:none;}
.cfg-next{padding:13px 22px;}
.cfg-step-no.is-done{background:var(--primary);color:#fff;position:relative;}
.cfg-step-no.is-done::after{content:"";position:absolute;inset:0;border-radius:inherit;
  background:var(--primary);}
.cfg-step-no.is-done svg{position:relative;z-index:1;width:20px;height:20px;}
@media (prefers-reduced-motion: no-preference){
  .cfg-step.revealing{animation:cfgReveal .42s cubic-bezier(.2,.7,.3,1) both;}
}
@keyframes cfgReveal{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

/* option rows */
.opt{display:flex;gap:16px;align-items:flex-start;padding:18px;border:1.5px solid var(--line);
  border-radius:14px;cursor:pointer;transition:.15s;margin-top:12px;background:#fff;position:relative;}
.opt:hover{border-color:var(--primary);background:var(--green-tint);}
.opt.on{border-color:var(--primary);background:var(--green-tint);
  box-shadow:0 0 0 1.5px var(--primary) inset;}
.opt input{position:absolute;opacity:0;pointer-events:none;}
.opt .box{width:26px;height:26px;border-radius:8px;border:2px solid var(--line);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;background:#fff;transition:.15s;margin-top:1px;}
.opt.kind-radio .box{border-radius:50%;}
.opt .box svg{width:16px;height:16px;color:#fff;opacity:0;transition:.15s;}
.opt.on .box{background:var(--primary);border-color:var(--primary);}
.opt.on .box svg{opacity:1;}
.opt .opt-body{flex:1;min-width:0;}
.opt .opt-top{display:flex;justify-content:space-between;gap:14px;align-items:baseline;}
.opt .opt-name{font-weight:700;color:var(--ink);font-size:1.05rem;}
.opt .opt-price{font-family:var(--font-head);font-weight:800;color:var(--ink);white-space:nowrap;}
.opt .opt-price .per{font-size:.78rem;color:var(--muted);font-weight:600;}
.opt .opt-price s{color:var(--muted);font-weight:600;font-size:.82rem;margin-right:5px;}
.opt .opt-desc{color:var(--body);font-size:.92rem;margin-top:5px;line-height:1.5;}
.opt .tagm{display:inline-block;margin-top:8px;font-size:.76rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.05em;color:#8a6500;background:var(--amber-tint);
  padding:4px 10px;border-radius:999px;}

/* summary */
.cfg-summary{position:sticky;top:96px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden;}
.cfg-summary .sum-head{background:var(--green-900);color:#fff;padding:22px 24px;}
.cfg-summary .sum-head .t{font-family:var(--font-head);font-weight:800;font-size:1.2rem;}
.cfg-summary .sum-head .s{color:#9fccb4;font-size:.88rem;margin-top:3px;}
.sum-body{padding:20px 24px 24px;}
.sum-lines{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;}
.sum-lines li{display:flex;justify-content:space-between;gap:12px;padding:11px 0;
  border-bottom:1px solid var(--line-2);font-size:.95rem;}
.sum-lines li .ln{color:var(--ink);font-weight:500;}
.sum-lines li .lp{font-family:var(--font-head);font-weight:700;color:var(--ink);white-space:nowrap;}
.sum-lines li.is-base .ln{font-weight:700;}
.sum-empty{color:var(--muted);font-size:.92rem;padding:8px 0 4px;}
.sum-total{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px;
  padding-top:18px;border-top:2px solid var(--ink);}
.sum-total .tl{font-weight:700;color:var(--ink);}
.sum-total .tl small{display:block;color:var(--muted);font-weight:500;font-size:.78rem;}
.sum-total .tv{font-family:var(--font-head);font-weight:800;font-size:2rem;color:var(--ink);}
.sum-save{display:flex;align-items:center;gap:7px;margin-top:14px;background:var(--amber-tint);
  color:#8a6500;font-weight:700;font-size:.86rem;padding:9px 13px;border-radius:10px;}
.sum-save[hidden]{display:none;}

/* ===================== AANVRAAGFORMULIER ===================== */
.aanvraag-form{max-width:1000px;margin:0 auto;}
.af-grid{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start;}
.af-block{border:0;margin:0 0 22px;padding:0;}
.af-block legend{font-family:var(--font-head);font-weight:800;color:var(--ink);font-size:1.2rem;
  padding:0;margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.af-block legend::before{content:"";width:11px;height:11px;border-radius:50% 50% 50% 0;
  background:var(--accent);transform:rotate(45deg);}
.af-field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px;}
.af-field label{font-size:.82rem;font-weight:700;letter-spacing:.02em;color:var(--ink);}
.af-field input,.af-field textarea{font:inherit;border:1.5px solid var(--line);border-radius:12px;
  padding:13px 15px;background:#fff;color:var(--ink);transition:.15s;width:100%;resize:vertical;}
.af-field input:focus,.af-field textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px var(--green-tint);}
.af-field input:user-invalid{border-color:#c8472b;}
.af-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.af-or{display:flex;align-items:center;gap:14px;color:var(--muted);font-weight:700;font-size:.84rem;
  text-transform:uppercase;letter-spacing:.08em;margin:4px 0 14px;}
.af-or::before,.af-or::after{content:"";flex:1;height:1px;background:var(--line);}
.af-file{display:flex;align-items:center;gap:12px;border:1.5px dashed var(--line);border-radius:12px;
  padding:16px;cursor:pointer;transition:.15s;background:#fff;}
.af-file:hover{border-color:var(--primary);background:var(--green-tint);}
.af-file.has-file{border-style:solid;border-color:var(--primary);background:var(--green-tint);}
.af-file input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;}
.af-file svg{width:24px;height:24px;color:var(--primary-strong);flex-shrink:0;}
.af-file-text{font-weight:600;color:var(--body);font-size:.92rem;}
.af-hint{font-size:.78rem;color:var(--muted);margin-top:7px;}
.af-side{position:sticky;top:96px;display:flex;flex-direction:column;gap:14px;}
.af-recap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);}
.af-recap-head{background:var(--green-900);color:#fff;font-family:var(--font-head);font-weight:800;
  padding:15px 18px;font-size:1.05rem;}
.af-recap ul{list-style:none;margin:0;padding:14px 18px;display:flex;flex-direction:column;gap:9px;}
.af-recap li{display:flex;justify-content:space-between;gap:12px;font-size:.88rem;color:var(--body);}
.af-recap li .l{color:var(--ink);}
.af-recap-total{display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:14px 18px;border-top:1px solid var(--line-2);}
.af-recap-total span{font-weight:600;color:var(--muted);font-size:.86rem;}
.af-recap-total strong{font-family:var(--font-head);font-weight:800;font-size:1.3rem;color:var(--ink);}
.af-consent{font-size:.78rem;color:var(--muted);text-align:center;line-height:1.5;}
.af-error{background:#fdecea;color:#a3371f;border-radius:10px;padding:11px 14px;font-size:.88rem;
  font-weight:600;}
.af-error[hidden]{display:none;}
.af-submitting{opacity:.7;pointer-events:none;}

.af-success{max-width:620px;margin:0 auto;text-align:center;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:54px 36px;box-shadow:var(--shadow-md);}
.af-success[hidden]{display:none;}
.af-success .chk{width:74px;height:74px;border-radius:50%;background:var(--green-tint);margin:0 auto 24px;
  display:flex;align-items:center;justify-content:center;}
.af-success .chk svg{width:38px;height:38px;color:var(--primary-strong);}
.af-success h2{margin-bottom:12px;}
.af-success p{color:var(--body);margin:0 auto 8px;max-width:46ch;}
.af-success .em{color:var(--primary-strong);font-weight:700;}

@media(max-width:820px){
  .af-grid{grid-template-columns:1fr;}
  .af-side{position:static;}
  .af-row{grid-template-columns:1fr;}
}
.sum-save svg{width:16px;height:16px;flex-shrink:0;}
.cfg-summary .btn{margin-top:18px;}
.sum-note{text-align:center;font-size:.82rem;color:var(--muted);margin-top:12px;}
.sum-contact{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;
  font-size:.88rem;color:var(--body);}
.sum-contact a{color:var(--primary-strong);font-weight:700;}

/* cross-sell */
.xsell{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.xsell-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  display:flex;flex-direction:column;gap:10px;transition:.16s;}
.xsell-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--line-2);}
.xsell-ic{width:46px;height:46px;border-radius:12px;background:var(--green-tint);
  display:flex;align-items:center;justify-content:center;color:var(--primary-strong);margin-bottom:4px;}
.xsell-ic svg{width:23px;height:23px;}
.xsell-card h3{font-size:1.18rem;}
.xsell-card p{font-size:.95rem;color:var(--body);}
.xsell-card .link-arrow{margin-top:auto;font-size:.93rem;}

/* mobile price bar */
.cfg-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:40;background:#fff;
  border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(20,40,28,.1);
  padding:13px 18px;align-items:center;gap:14px;}
.cfg-bar .bt{flex:1;}
.cfg-bar .bt .bl{font-size:.76rem;color:var(--muted);}
.cfg-bar .bt .bv{font-family:var(--font-head);font-weight:800;font-size:1.35rem;color:var(--ink);}

@media(max-width:920px){
  .cfg-wrap{grid-template-columns:1fr;}
  .cfg-summary{display:none;}
  .cfg-bar{display:flex;}
  .cfg-bullets{grid-template-columns:1fr;}
  .xsell{grid-template-columns:1fr;}
  .cfg-wrap{padding-bottom:30px;}
}
