/* ===========================================================
   Boxxpro — Gedeelde stijlen voor losse (statische) feature-pagina's
   Bovenop kit.css + landing.css. De homepage laadt dit NIET.
   Hergebruik op elke /functies/<naam>/ pagina.
   =========================================================== */

/* ---- Skip-link (toegankelijkheid): onzichtbaar tot focus ---- */
.lp-skip{
  position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--bx-blue); color:#fff; font-weight:700; font-size:14px;
  padding:10px 18px; border-radius:0 0 10px 0;
}
.lp-skip:focus{ left:0; }

/* ---- Breadcrumb ---- */
.bc{
  display:flex; flex-wrap:wrap; align-items:center; gap:8px; justify-content:center;
  font-size:13.5px; font-weight:600; color:var(--bx-muted); margin-bottom:20px;
}
.bc a{ color:var(--bx-muted); }
.bc a:hover{ color:var(--bx-blue); }
.bc__sep{ color:var(--bx-faint); }
.bc [aria-current="page"]{ color:var(--bx-ink-2); font-weight:700; }

/* ---- Hero mockup-kaart (statisch, hergebruikt de kit-tokens) ---- */
.fp-art{ max-width:720px; margin:52px auto 72px; position:relative; }

/* ---- Rijke scene (vast canvas, geschaald naar containerbreedte) ---- */
.lp-scene{ max-width:940px; margin:52px auto 72px; }
.lp-scene__frame{
  position:relative; width:100%; overflow:hidden;
  border-radius:24px; box-shadow:var(--bx-shadow-lg); border:1px solid rgba(255,255,255,.6);
}
.lp-scene__inner{ transform-origin:top left; }
/* Frame-achtergrond (bare scenes zijn transparant en leunen hierop) */
.lp-scene--light .lp-scene__frame{ background:radial-gradient(90% 70% at 80% 0%, #EAF4FD 0%, transparent 55%), linear-gradient(160deg,#F8FAFD 0%,#EEF3F9 100%); }
.lp-scene--sky .lp-scene__frame{ background:radial-gradient(100% 80% at 15% 10%, #E9F5FE 0%, transparent 60%), linear-gradient(155deg,#DCEEFB 0%,#C7E2F6 100%); }
@media (max-width:560px){ .lp-scene{ margin:34px auto 56px; } }

/* Zwevende popups die over de mockup-kaart hangen (zoals op de homepage) */
.fp-pop{ position:absolute; z-index:5; animation:fp-pop-in .6s cubic-bezier(.16,.84,.28,1) both; }
.fp-pop--a{ top:-26px; right:-22px; animation-delay:.15s; }
.fp-pop--b{ bottom:-26px; left:-22px; animation-delay:.32s; }
@keyframes fp-pop-in{ from{ opacity:0; transform:translateY(16px) scale(.96); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .fp-pop{ animation:none; } }
.fp-inv__head{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:6px; }
/* Tabelrijen met VASTE kolommen → bedragen en statuslabels lijnen altijd uit,
   ongeacht de tekstlengte. (Elke rij is een eigen grid, dus px i.p.v. auto.) */
.fp-inv__row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) 104px 116px;   /* avatar | naam+meta | bedrag | status */
  align-items:center; column-gap:14px;
  padding:14px 4px; border-bottom:1px solid var(--bx-line-2);
}
.fp-inv__row:last-child{ border-bottom:0; }
.fp-inv__who{ display:flex; align-items:baseline; gap:8px; min-width:0; }
.fp-inv__name{ font-weight:700; color:var(--bx-ink); white-space:nowrap; }
.fp-inv__sub{ font-size:12.5px; color:var(--bx-muted); font-weight:500; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.fp-inv__amt{ text-align:right; font-weight:800; font-variant-numeric:tabular-nums; letter-spacing:-.01em; white-space:nowrap; }
.fp-inv__row > .bx-pill{ justify-self:end; }

/* ---- Stappen: "hoe het werkt" ---- */
.fp-steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:50px; }
.fp-step{
  background:#fff; border:1px solid var(--bx-line); border-radius:20px; padding:30px 28px;
  box-shadow:var(--bx-shadow);
}
.fp-step__n{
  width:46px; height:46px; border-radius:13px; display:grid; place-items:center;
  background:var(--bx-blue); color:#fff; font-weight:800; font-size:19px; margin-bottom:18px;
  box-shadow:0 10px 22px -8px rgba(0,144,223,.6);
}
.fp-step h3{ font-size:19px; font-weight:800; letter-spacing:-.01em; margin:0 0 8px; }
.fp-step p{ font-size:15.5px; line-height:1.6; color:var(--bx-muted); margin:0; }

/* ---- FAQ: native accordion (<details>) — content staat in de DOM voor SEO ---- */
.fp-faq{ max-width:780px; margin:46px auto 0; }
.fp-faq__item{
  border:1px solid var(--bx-line); border-radius:16px; background:#fff;
  margin-bottom:14px; box-shadow:var(--bx-shadow); overflow:hidden;
}
.fp-faq__item summary{
  list-style:none; cursor:pointer; padding:22px 24px;
  font-size:17px; font-weight:700; color:var(--bx-ink);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.fp-faq__item summary::-webkit-details-marker{ display:none; }
.fp-faq__item summary::after{
  content:'+'; font-size:26px; font-weight:600; color:var(--bx-blue); line-height:1; flex:0 0 auto;
  transition:transform .2s ease;
}
.fp-faq__item[open] summary::after{ transform:rotate(45deg); }
.fp-faq__a{ padding:0 24px 22px; font-size:15.5px; line-height:1.65; color:var(--bx-ink-2); }
.fp-faq__a p{ margin:0; }

/* ---- Hero: rating + risk-bar (vertrouwen vlak bij de CTA) ---- */
.fp-rating{ display:inline-flex; align-items:center; gap:9px; margin-top:20px; font-size:14.5px; font-weight:600; color:var(--bx-ink-2); }
.fp-stars{ color:#F5A623; letter-spacing:1px; font-size:16px; }
.fp-rating b{ color:var(--bx-ink); }
.fp-risk{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px 24px; margin:24px 0 0; padding:0; }
.fp-risk li{ display:flex; align-items:center; gap:8px; font-size:14.5px; font-weight:600; color:var(--bx-ink-2); list-style:none; }
.fp-risk .ck{ width:20px; height:20px; border-radius:50%; background:var(--bx-green-tint); color:var(--bx-green); display:grid; place-items:center; flex:0 0 auto; }
.fp-risk .ck svg{ width:13px; height:13px; }

/* ---- Trust-badges ---- */
.fp-badges{ display:flex; flex-wrap:wrap; justify-content:center; gap:12px; margin-top:24px; }
.fp-badge{ display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:var(--bx-ink-2); background:#fff; border:1px solid var(--bx-line); border-radius:999px; padding:9px 15px; box-shadow:var(--bx-shadow); }
.fp-badge svg{ width:16px; height:16px; color:var(--bx-green); flex:0 0 auto; }

/* ---- Testimonials ---- */
.fp-quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:46px; }
.fp-quote{ background:#fff; border:1px solid var(--bx-line); border-radius:20px; padding:28px; box-shadow:var(--bx-shadow); display:flex; flex-direction:column; }
.fp-quote__stars{ color:#F5A623; letter-spacing:1px; margin-bottom:14px; }
.fp-quote blockquote{ margin:0; font-size:16px; line-height:1.6; color:var(--bx-ink); font-weight:600; text-wrap:pretty; }
.fp-quote__who{ display:flex; align-items:center; gap:12px; margin-top:auto; padding-top:22px; }
.fp-quote__av{ width:44px; height:44px; border-radius:50%; flex:0 0 auto; display:grid; place-items:center; color:#fff; font-weight:800; font-size:14px; }
.fp-quote__who b{ display:block; font-size:14.5px; color:var(--bx-ink); }
.fp-quote__who span{ font-size:13px; color:var(--bx-muted); }

/* ---- Prijs-anker ---- */
.fp-pricing{ text-align:center; }
.fp-price-tag{ display:inline-flex; align-items:baseline; gap:8px; margin:6px 0 4px; }
.fp-price-tag b{ font-size:clamp(38px,3vw,48px); font-weight:800; letter-spacing:-.03em; }
.fp-price-tag span{ font-size:16px; color:var(--bx-muted); font-weight:600; }
.fp-price-note{ font-size:15px; color:var(--bx-muted); font-weight:600; margin:0 0 26px; }

/* ---- SEO-inhoud (informatief: voor wie + factuur-eisen) ---- */
.fp-prose{ max-width:780px; margin:0 auto; }
.fp-prose p{ font-size:16.5px; line-height:1.7; color:var(--bx-ink-2); margin:0 0 18px; text-wrap:pretty; }
.fp-checklist{ list-style:none; padding:0; margin:24px 0 0; display:grid; grid-template-columns:repeat(2,1fr); gap:14px 28px; }
.fp-checklist li{ display:flex; align-items:flex-start; gap:11px; font-size:15.5px; font-weight:600; color:var(--bx-ink); }
.fp-checklist .ck{ width:22px; height:22px; border-radius:50%; flex:0 0 auto; margin-top:1px; background:var(--bx-blue-tint); color:var(--bx-blue); display:grid; place-items:center; }
.fp-checklist .ck svg{ width:13px; height:13px; }

/* ---- Verwante modules (interne links) ---- */
.fp-related{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; }
.fp-related a{ display:flex; align-items:center; gap:14px; background:#fff; border:1px solid var(--bx-line); border-radius:16px; padding:20px 22px; box-shadow:var(--bx-shadow); transition:transform .18s, box-shadow .18s; }
.fp-related a:hover{ transform:translateY(-2px); box-shadow:var(--bx-shadow-lg); }
.fp-related__ic{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; flex:0 0 auto; background:var(--bx-blue-tint); color:var(--bx-blue); }
.fp-related__ic svg{ width:21px; height:21px; }
.fp-related b{ font-size:16px; color:var(--bx-ink); display:block; }
.fp-related span{ font-size:13.5px; color:var(--bx-muted); }

/* ---- Legal / lange tekst ---- */
.fp-legal h2{ font-size:24px; font-weight:800; letter-spacing:-.01em; color:var(--bx-ink); margin:34px 0 12px; }
.fp-legal h3{ font-size:18px; font-weight:800; color:var(--bx-ink); margin:24px 0 8px; }
.fp-legal h2:first-child{ margin-top:0; }
.fp-legal ul{ margin:0 0 18px; padding-left:22px; }
.fp-legal li{ font-size:16px; line-height:1.7; color:var(--bx-ink-2); margin-bottom:6px; }
.fp-legal a{ color:var(--bx-blue); font-weight:700; }

/* ---- Vergelijkingstabel ---- */
.fp-cmp{ max-width:780px; margin:44px auto 0; border:1px solid var(--bx-line); border-radius:18px; overflow:hidden; box-shadow:var(--bx-shadow); background:#fff; }
.fp-cmp__row{ display:grid; grid-template-columns:1.6fr 1fr 1fr; align-items:center; border-bottom:1px solid var(--bx-line-2); }
.fp-cmp__row:last-child{ border-bottom:0; }
.fp-cmp__row--head{ background:var(--bx-page); }
.fp-cmp__feat{ padding:16px 22px; font-size:15px; font-weight:600; color:var(--bx-ink-2); }
.fp-cmp__row--head .fp-cmp__feat{ font-weight:700; }
.fp-cmp__col{ padding:16px 12px; text-align:center; font-size:14.5px; font-weight:700; color:var(--bx-muted); }
.fp-cmp__row--head .fp-cmp__col{ font-size:15.5px; font-weight:800; color:var(--bx-ink); }
.fp-cmp__col--ours{ background:var(--bx-blue-tint); color:var(--bx-blue-700); position:relative; }
.fp-cmp__row--head .fp-cmp__col--ours{ color:var(--bx-blue); }
.fp-cmp__yes{ display:inline-grid; place-items:center; width:26px; height:26px; border-radius:50%; background:var(--bx-green-tint); color:var(--bx-green); }
.fp-cmp__no{ display:inline-grid; place-items:center; width:26px; height:26px; border-radius:50%; background:var(--bx-line-2); color:var(--bx-faint); }
.fp-cmp__txt{ font-size:13.5px; }
@media (max-width:560px){
  .fp-cmp__feat{ padding:13px 14px; font-size:13.5px; }
  .fp-cmp__col{ padding:13px 6px; font-size:13px; }
  .fp-cmp__row--head .fp-cmp__col{ font-size:13.5px; }
}

/* ---- Sticky CTA-balk (alleen mobiel) ---- */
.fp-sticky{ display:none; }

/* ---- Kleine helpers ---- */
.fp-lead-narrow{ max-width:760px; }

@media (max-width:860px){
  .fp-quotes{ grid-template-columns:1fr; }
  .fp-related{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .fp-checklist{ grid-template-columns:1fr; }
}
/* Sticky mobiele CTA-balk — altijd binnen duimbereik */
@media (max-width:768px){
  .fp-sticky{
    display:flex; position:fixed; left:0; right:0; bottom:0; z-index:60;
    align-items:center; gap:12px; padding:11px 16px;
    background:rgba(255,255,255,.96); backdrop-filter:saturate(160%) blur(12px);
    border-top:1px solid var(--bx-line); box-shadow:0 -6px 20px -10px rgba(8,30,60,.25);
  }
  .fp-sticky__txt{ font-size:13.5px; font-weight:700; color:var(--bx-ink); line-height:1.2; flex:1 1 auto; }
  .fp-sticky__txt small{ display:block; font-size:12px; font-weight:600; color:var(--bx-muted); }
  .fp-sticky .lp-btn{ flex:0 0 auto; }
  body{ padding-bottom:70px; }   /* ruimte zodat de balk niets bedekt */
  .cc-banner{ bottom:80px; }     /* cookiebanner boven de sticky CTA */
}

/* ---- Responsive ---- */
@media (max-width:860px){ .fp-steps{ grid-template-columns:1fr; gap:18px; } }
@media (max-width:600px){
  .fp-art{ margin-top:34px; }
  .fp-faq__item summary{ font-size:16px; padding:18px 20px; }
  .fp-faq__a{ padding:0 20px 18px; }
  /* Smalle kaart: meta + status verbergen, bedrag lijnt uit aan de rechterrand */
  .fp-inv__row{ grid-template-columns:auto minmax(0,1fr) auto; column-gap:12px; }
  .fp-inv__sub{ display:none; }
  .fp-inv__row > .bx-pill{ display:none; }
  .fp-pop{ display:none; }   /* popups te krap op kleine kaart */
}
