/*
Theme Name: BSC 2026
Author: Codesome
Description: Moderne, professionele B2B-website voor Business Service Centre. Focus op leadgeneratie, afspraakplanning, relatiebeheer, CRM-beheer en telefonische ondersteuning. Veel witruimte, duidelijke call-to-actions.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: bsc2026
*/

/* ============ Design tokens (volgens specificatie) ============ */
:root {
  --blue:        #0D6EFD;   /* Business Blue – CTA, links, iconen, highlights */
  --blue-dark:   #0b5ed7;
  --navy:        #0A2342;   /* Donkerblauw – headlines, CTA-secties */
  --footer:      #07172D;   /* Footer achtergrond */
  --white:       #FFFFFF;
  --grey-soft:   #F7F9FC;   /* Sectie/card achtergrond */
  --text:        #374151;   /* Reguliere tekst */
  --border:      #E5E7EB;   /* Scheidingslijnen */
  --muted:       #6b7686;
  --radius:      16px;
  --radius-sm:   12px;
  --shadow:      0 10px 30px rgba(0,0,0,.05);
  --shadow-lg:   0 24px 60px rgba(10,35,66,.16);
  --maxw:        1200px;
}

/* ============ Reset / base ============ */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Inter", "Poppins", system-ui, -apple-system, Helvetica, Arial, sans-serif;
  font-size: 18px;
  line-height: 1.7;
  color: var(--text);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--blue); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--blue-dark); }

h1,h2,h3,h4 { color: var(--navy); margin: 0 0 .5em; line-height: 1.2; }
h1 { font-size: 64px; font-weight: 800; line-height: 1.1; letter-spacing: -.02em; }
h2 { font-size: 48px; font-weight: 700; letter-spacing: -.01em; }
h3 { font-size: 28px; font-weight: 600; }
p  { margin: 0 0 1rem; }
p:last-child { margin-bottom: 0; }
.text-blue { color: var(--blue); }

/* ============ Layout ============ */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding-top: 100px; padding-bottom: 100px; }
.section--soft { background: var(--grey-soft); }
.section__head { max-width: 760px; margin: 0 auto 56px; text-align: center; }
.eyebrow { display:inline-block; font-size:.85rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--blue); margin-bottom:.75rem; }
.lead { font-size: 1.25rem; color: var(--muted); }

/* ============ Buttons ============ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.95rem 1.75rem; border-radius:12px; font-weight:600; font-size:1rem;
  border:2px solid transparent; cursor:pointer; transition:all .2s ease; line-height:1;
}
.btn--primary { background:var(--blue); color:#fff; box-shadow:0 8px 22px rgba(13,110,253,.3); }
.btn--primary:hover { background:var(--blue-dark); color:#fff; transform:translateY(-2px); }
.btn--ghost { background:#fff; color:var(--blue); border-color:var(--border); }
.btn--ghost:hover { border-color:var(--blue); color:var(--blue); }
.btn--light { background:#fff; color:var(--blue); }
.btn--light:hover { background:var(--grey-soft); color:var(--blue-dark); transform:translateY(-2px); }
.btn--lg { padding:1.1rem 2.1rem; font-size:1.05rem; }

/* ============ Header ============ */
.site-header { position:sticky; top:0; z-index:1000; height:90px; background:#fff; border-bottom:1px solid var(--border); }
.site-header__inner { height:90px; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.site-logo img { height:48px; width:auto; }
.main-nav ul { list-style:none; display:flex; gap:2.25rem; margin:0; padding:0; align-items:center; }
.main-nav a { color:var(--navy); font-weight:600; font-size:1rem; }
.main-nav a:hover, .main-nav .current-menu-item > a, .main-nav .current_page_item > a { color:var(--blue); }
.header-actions { display:flex; align-items:center; gap:1rem; }
.nav-toggle { display:none; background:none; border:0; cursor:pointer; padding:.5rem; }
.nav-toggle span { display:block; width:26px; height:2px; background:var(--navy); margin:6px 0; transition:.3s; border-radius:2px; }

/* ============ Hero ============ */
.hero { background: var(--grey-soft); overflow:hidden; }
.hero__inner { display:grid; grid-template-columns:1.05fr .95fr; gap:64px; align-items:center; padding-top:90px; padding-bottom:90px; }
.hero-slogan {
  display:inline-block; margin-bottom:1.25rem; background:rgba(13,110,253,.1); color:var(--blue);
  font-weight:800; font-size:clamp(1.05rem, 2.4vw, 1.4rem); letter-spacing:.01em;
  padding:.55rem 1.25rem; border-radius:999px;
}
.hero h1 { margin-bottom:1.25rem; }
.hero p.intro { font-size:1.2rem; color:var(--text); margin-bottom:2rem; max-width:46ch; }
.hero__cta { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:2.5rem; }
.usp-bar { display:flex; flex-wrap:wrap; gap:1.25rem 2rem; }
.usp { display:flex; align-items:center; gap:.6rem; font-weight:600; color:var(--navy); font-size:.98rem; }
.bsc-ico { display:block; width:24px; height:24px; flex:none; }

/* USP-strip onder de hero */
.usp-strip { background:#fff; border-bottom:1px solid var(--border); }
.usp-strip__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:32px; padding:44px 24px; }
.usp-item { display:flex; gap:1rem; align-items:center; }
.usp-item .ico { flex:0 0 50px; width:50px; height:50px; border-radius:13px; background:rgba(13,110,253,.1); color:var(--blue); display:grid; place-items:center; }
.usp-item .ico--num { font-weight:800; font-size:1.1rem; color:var(--blue); }
.usp-item b { color:var(--navy); display:block; font-size:1.05rem; line-height:1.3; }
.usp-item small { color:var(--muted); font-size:.92rem; }
@media (max-width:992px){
  .usp-strip__grid { grid-template-columns:repeat(2,1fr); gap:1.75rem; }
}
@media (max-width:560px){
  .usp-strip__grid { grid-template-columns:1fr; gap:2.25rem; padding:40px 24px; }
}
.hero__media { position:relative; }
.hero__media img { border-radius:var(--radius); box-shadow:var(--shadow-lg); aspect-ratio:4/3; object-fit:cover; width:100%; }

/* Hero visual (branded, zonder foto) */
.hero__visual {
  position:relative; aspect-ratio:4/3; width:100%; border-radius:var(--radius);
  background:linear-gradient(140deg, var(--navy) 0%, var(--blue) 100%);
  box-shadow:var(--shadow-lg); overflow:hidden;
}
.hero__visual::before { content:""; position:absolute; width:60%; aspect-ratio:1; border-radius:50%; right:-12%; top:-18%; background:rgba(255,255,255,.08); }
.hero__visual::after  { content:""; position:absolute; width:45%; aspect-ratio:1; border-radius:50%; left:-10%; bottom:-15%; background:rgba(255,255,255,.06); }
.hv-card {
  position:absolute; display:flex; align-items:center; gap:.75rem;
  background:#fff; border-radius:14px; padding:.85rem 1rem; box-shadow:0 16px 40px rgba(7,23,45,.25);
}
.hv-card b { color:var(--navy); display:block; font-size:.95rem; line-height:1.2; }
.hv-card small { color:var(--muted); font-size:.78rem; }
.hv-ic { flex:0 0 38px; width:38px; height:38px; border-radius:10px; background:rgba(13,110,253,.12); color:var(--blue); display:grid; place-items:center; }
.hv-card--lead { top:10%;  left:6%;  z-index:3; }
.hv-card--appt { top:42%;  right:5%; z-index:2; }
.hv-card--stat { bottom:11%; left:12%; z-index:3; }
@media (max-width:768px){
  /* Kaarten gestapeld maar speels: kleiner en links/rechts verspringend */
  .hero__visual { aspect-ratio:auto; display:flex; flex-direction:column; justify-content:center; gap:.6rem; padding:1.1rem .9rem; }
  .hv-card { position:static; width:auto; max-width:82%; padding:.55rem .8rem; gap:.6rem; }
  .hv-card--lead { align-self:flex-start; }
  .hv-card--appt { align-self:flex-end; }
  .hv-card--stat { align-self:flex-start; }
  .hv-card b { font-size:.82rem; }
  .hv-card small { font-size:.7rem; }
  .hv-ic { flex-basis:30px; width:30px; height:30px; border-radius:9px; }
  .hv-ic .bsc-ico { width:17px; height:17px; }
}
.hero__badge { position:absolute; bottom:-22px; left:-22px; background:#fff; border-radius:var(--radius-sm); box-shadow:0 16px 40px rgba(10,35,66,.18); padding:1rem 1.25rem; display:flex; align-items:center; gap:.85rem; }
.hero__badge .num { font-size:1.7rem; font-weight:800; color:var(--blue); line-height:1; }
.hero__badge small { color:var(--muted); }

/* ============ Service cards ============ */
.cards { display:grid; grid-template-columns:repeat(5,1fr); gap:24px; }
.card { background:#fff; border:1px solid var(--border); border-radius:16px; padding:32px; box-shadow:var(--shadow); transition:.3s; }
.card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:transparent; }
.card .ico { width:54px; height:54px; border-radius:14px; display:grid; place-items:center; background:rgba(13,110,253,.1); color:var(--blue); margin-bottom:1.25rem; }
.card .ico .bsc-ico { width:28px; height:28px; }
.benefit .tick .bsc-ico { width:16px; height:16px; }
.contact-list .ico .bsc-ico { width:22px; height:22px; }
.socials a .bsc-ico { width:18px; height:18px; }
.card h3 { font-size:1.25rem; margin-bottom:.5rem; }
.card p { color:var(--muted); font-size:1rem; margin:0; }

/* ============ Branchespecialisatie ============ */
.branch-list { list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }
.branch-list li {
  display:flex; align-items:center; gap:.6rem; background:#fff; border:1px solid var(--border);
  border-radius:999px; padding:.85rem 1.6rem; font-weight:600; color:var(--navy); box-shadow:var(--shadow);
}
.branch-list .bsc-ico { width:20px; height:20px; color:var(--blue); }

/* ============ Why us / split ============ */
.split { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.media-frame img { border-radius:var(--radius); box-shadow:var(--shadow); }

/* Groei-visual (Waarom BSC, zonder foto) */
.growth-visual {
  position:relative; aspect-ratio:4/3; width:100%; border-radius:var(--radius);
  background:#fff; border:1px solid var(--border); box-shadow:var(--shadow-lg);
  padding:1.75rem; display:flex; flex-direction:column;
}
.gv-head { display:flex; align-items:center; gap:.5rem; color:var(--navy); font-weight:700; font-size:.95rem; }
.gv-dot { width:10px; height:10px; border-radius:50%; background:var(--blue); box-shadow:0 0 0 4px rgba(13,110,253,.12); }
.gv-chart { flex:1; display:flex; align-items:flex-end; gap:clamp(.5rem,2.5%,1.1rem); }
.gv-chart span {
  flex:1; height:var(--h); min-height:12px; border-radius:8px 8px 4px 4px;
  background:linear-gradient(180deg, var(--blue) 0%, #4d9bff 100%);
}
.gv-chart span:last-child { background:linear-gradient(180deg, var(--navy) 0%, var(--blue) 100%); }
.gv-card {
  position:absolute; right:-10px; bottom:18%; display:flex; align-items:center; gap:.75rem;
  background:#fff; border-radius:14px; padding:.85rem 1rem; box-shadow:0 16px 40px rgba(7,23,45,.18);
}
.gv-card b { color:var(--navy); display:block; font-size:.95rem; line-height:1.2; }
.gv-card small { color:var(--muted); font-size:.78rem; }
.benefit-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:2rem; }
.benefit { display:flex; gap:1rem; align-items:flex-start; }
.benefit .tick { flex:0 0 30px; width:30px; height:30px; border-radius:50%; background:rgba(13,110,253,.12); color:var(--blue); display:grid; place-items:center; margin-top:.2rem; }
.benefit h4 { font-size:1.1rem; margin:0 0 .25rem; }
.benefit p { color:var(--muted); font-size:.98rem; margin:0; }

/* ============ Werkwijze timeline ============ */
.steps { display:grid; grid-template-columns:repeat(5,1fr); gap:24px; position:relative; }
.steps::before { content:""; position:absolute; top:27px; left:8%; right:8%; height:2px; background:var(--border); z-index:0; }
.step { position:relative; z-index:1; text-align:center; }
.step .num { width:56px; height:56px; margin:0 auto 1.25rem; border-radius:50%; background:var(--blue); color:#fff; font-weight:800; font-size:1.3rem; display:grid; place-items:center; box-shadow:0 8px 20px rgba(13,110,253,.3); }
.step h4 { font-size:1.1rem; margin-bottom:.4rem; }
.step p { color:var(--muted); font-size:.95rem; margin:0; }

/* ============ CTA banner ============ */
.cta-band { background:var(--navy); color:#fff; border-radius:24px; padding:72px 32px; text-align:center; }
.cta-band h2 { color:#fff; }
.cta-band p { color:rgba(255,255,255,.82); font-size:1.2rem; max-width:56ch; margin:0 auto; }
.cta-band .btn { margin-top:2rem; }

/* ============ Generic page ============ */
.page-hero { background:var(--grey-soft); padding:80px 0; text-align:center; border-bottom:1px solid var(--border); }
.entry { max-width:780px; margin:0 auto; }
.entry h2 { font-size:2rem; margin-top:2.5rem; }
.entry h3 { font-size:1.5rem; margin-top:2rem; }
.entry img { border-radius:var(--radius-sm); margin:1.5rem 0; }
.entry ul, .entry ol { padding-left:1.25rem; }
.entry li { margin-bottom:.5rem; }

/* ============ Contact ============ */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.contact-card { background:#fff; border:1px solid var(--border); border-radius:16px; padding:32px; box-shadow:var(--shadow); }
.contact-list { list-style:none; margin:0; padding:0; display:grid; gap:1.25rem; }
.contact-list li { display:flex; gap:1rem; align-items:flex-start; }
.contact-list .ico { flex:0 0 46px; width:46px; height:46px; border-radius:12px; background:rgba(13,110,253,.1); color:var(--blue); display:grid; place-items:center; }
.contact-list b { color:var(--navy); display:block; }
.contact-list a { color:var(--text); }
.contact-list a:hover { color:var(--blue); }
.form-row { display:grid; gap:.4rem; margin-bottom:1.1rem; }
.form-row label { font-weight:600; color:var(--navy); font-size:.95rem; }
.form-row input, .form-row textarea { width:100%; padding:.85rem 1rem; border:1px solid var(--border); border-radius:10px; font:inherit; color:var(--navy); background:#fff; }
.form-row input:focus, .form-row textarea:focus { outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(13,110,253,.14); }

/* ---- Contact Form 7 ---- */
.wpcf7-form p { margin:0; }
.wpcf7-form .bsc-form-group { margin-bottom:1.1rem; }
.wpcf7-form .wpcf7-form-control-wrap { display:block; }
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=tel],
.wpcf7-form input[type=url],
.wpcf7-form input[type=number],
.wpcf7-form textarea {
  width:100%; padding:.85rem 1rem; border:1px solid var(--border); border-radius:10px;
  font:inherit; color:var(--navy); background:#fff; transition:border-color .2s ease, box-shadow .2s ease;
}
.wpcf7-form textarea { min-height:130px; resize:vertical; }
.wpcf7-form input:focus, .wpcf7-form textarea:focus { outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(13,110,253,.14); }
.wpcf7-form input::placeholder, .wpcf7-form textarea::placeholder { color:var(--muted); opacity:1; }
.wpcf7-form .wpcf7-submit {
  width:100%; background:var(--blue); color:#fff; border:0; cursor:pointer;
  padding:1rem 2rem; border-radius:12px; font-weight:600; font-size:1rem; margin-top:.25rem;
  box-shadow:0 8px 22px rgba(13,110,253,.3); transition:all .2s ease;
}
.wpcf7-form .wpcf7-submit:hover { background:var(--blue-dark); transform:translateY(-2px); }
.wpcf7-form .wpcf7-not-valid { border-color:#e23b3b !important; }
.wpcf7-not-valid-tip { color:#e23b3b; font-size:.85rem; margin-top:.35rem; display:block; }
.wpcf7-response-output { margin:1.1rem 0 0 !important; padding:.85rem 1rem !important; border:1px solid var(--border); border-radius:10px; font-size:.95rem; }
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.unaccepted .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output { border-color:#f3c2c2; background:#fdecec; color:#a12626; }
.wpcf7-form.sent .wpcf7-response-output { border-color:#bfe6d4; background:#eafaf2; color:#177a52; }
.wpcf7-spinner { margin:.4rem auto 0; }

/* ============ Footer ============ */
.site-footer { background:var(--footer); color:#aebccd; padding:72px 0 0; }
.site-footer a { color:#aebccd; }
.site-footer a:hover { color:#fff; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:64px; }
.site-footer h4 { color:#fff; font-size:1rem; margin-bottom:1.1rem; }
.site-footer .footer-logo img { height:44px; margin-bottom:1.25rem; filter:brightness(0) invert(1); }
.footer-slogan { color:#fff; font-weight:700; font-size:1.2rem; margin:0 0 .6rem; }
.site-footer ul { list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.site-footer address { font-style:normal; line-height:2; }
.socials { display:flex; gap:.75rem; margin-top:1rem; }
.socials a { width:40px; height:40px; border-radius:10px; background:rgba(255,255,255,.08); display:grid; place-items:center; color:#fff; }
.socials a:hover { background:var(--blue); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); margin-top:56px; padding:1.5rem 0; font-size:.9rem; color:#7e90a3; }
.footer-bottom .container { display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem; }

/* ============ Zwevende WhatsApp-knop ============ */
.wa-fab {
  position:fixed; right:20px; bottom:20px; z-index:950;
  width:58px; height:58px; border-radius:50%; background:#25D366; color:#fff;
  display:grid; place-items:center; box-shadow:0 10px 30px rgba(37,211,102,.45);
  transition:transform .2s ease, box-shadow .2s ease;
}
.wa-fab:hover { transform:scale(1.08); color:#fff; box-shadow:0 14px 36px rgba(37,211,102,.55); }
.wa-fab .bsc-ico { width:32px; height:32px; }
@media (max-width:768px){ .wa-fab { right:16px; bottom:84px; } } /* boven de mobiele sticky CTA */

/* ============ Mobiele sticky CTA ============ */
.mobile-cta { display:none; }
@media (max-width:768px){
  .mobile-cta {
    display:block; position:fixed; left:0; right:0; bottom:0; z-index:900;
    padding:.7rem 16px calc(.7rem + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.95); backdrop-filter:saturate(180%) blur(8px);
    border-top:1px solid var(--border); box-shadow:0 -6px 24px rgba(7,23,45,.08);
    transition:transform .3s ease;
  }
  /* Verborgen zolang de hero (met dezelfde knop) nog in beeld is */
  .mobile-cta.is-hidden { transform:translateY(110%); }
  .mobile-cta .btn { width:100%; }
  body { padding-bottom:74px; }   /* ruimte zodat de balk de footer niet bedekt */
}

/* ============ Responsive ============ */
@media (max-width:992px){
  .cards { grid-template-columns:repeat(2,1fr); }
  .steps { grid-template-columns:repeat(2,1fr); }
  .steps::before { display:none; }
}
@media (max-width:768px){
  h1 { font-size:40px; }
  h2 { font-size:2rem; }
  .section { padding-top:60px; padding-bottom:60px; }
  .hero__inner, .split, .contact-grid { grid-template-columns:1fr; gap:40px; }
  /* Meer lucht boven (nav -> badge) en onder (cards -> USP-strip) op mobiel */
  .hero__inner { padding-top:56px; padding-bottom:60px; }
  .usp-strip__grid { padding-top:30px; padding-bottom:30px; }
  .hero__media { order:0; }
  .benefit-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:40px; }
  .main-nav { position:fixed; inset:90px 0 auto 0; background:#fff; border-bottom:1px solid var(--border); transform:translateY(-130%); transition:transform .3s ease; padding:1rem 24px 2rem; }
  .main-nav.is-open { transform:translateY(0); box-shadow:var(--shadow); }
  .main-nav ul { flex-direction:column; align-items:stretch; gap:0; }
  .main-nav li { border-bottom:1px solid var(--border); }
  .main-nav a { display:block; padding:.9rem 0; }
  .nav-toggle { display:block; }
  .header-actions .btn { display:none; }
  .hero__cta .btn, .btn--block-mobile { width:100%; }
}
@media (max-width:560px){
  .cards { grid-template-columns:1fr; gap:1.75rem; }
  /* Dienstenkaart: icoon links naast de tekst i.p.v. erboven */
  .card { display:grid; grid-template-columns:auto 1fr; column-gap:1rem; align-items:center; }
  .card .ico { margin-bottom:0; grid-row:1 / span 2; align-self:center; }
  .steps { grid-template-columns:1fr; gap:1.75rem; }
  .hero__badge { left:0; }
}

/* ============ Breadcrumbs (Yoast) ============ */
.breadcrumbs { background:#fff; border-bottom:1px solid var(--border); font-size:.85rem; }
.breadcrumbs .container { padding-top:14px; padding-bottom:14px; }
.breadcrumbs, .breadcrumbs a { color:var(--muted); }
.breadcrumbs a { text-decoration:none; }
.breadcrumbs a:hover { color:var(--blue); text-decoration:underline; }
.breadcrumbs .breadcrumb_last { color:var(--navy); font-weight:600; }

/* ============ Entry / SEO-content ============ */
.entry a { color:var(--blue); text-decoration:underline; text-underline-offset:2px; }
.entry a:hover { text-decoration:none; }
.entry h2:first-child, .entry h3:first-child { margin-top:0; }
.entry > p:first-of-type { font-size:1.15rem; color:var(--text); }

/* ============ FAQ-accordion (homepage, native <details>) ============ */
.faq { max-width:820px; margin:0 auto; }
.faq__item { background:#fff; border:1px solid var(--border); border-radius:12px; margin-bottom:.85rem; padding:0 1.25rem; box-shadow:0 1px 2px rgba(7,23,45,.04); transition:box-shadow .2s ease, border-color .2s ease; }
.faq__item[open] { border-color:rgba(13,110,253,.35); box-shadow:0 12px 32px rgba(7,23,45,.08); }
.faq__q { cursor:pointer; list-style:none; font-weight:700; color:var(--navy); font-size:1.05rem; padding:1.1rem 2.25rem 1.1rem 0; position:relative; }
.faq__q::-webkit-details-marker { display:none; }
.faq__q::after { content:"+"; position:absolute; right:0; top:50%; transform:translateY(-50%); font-size:1.6rem; font-weight:400; line-height:1; color:var(--blue); }
.faq__item[open] .faq__q::after { content:"\2212"; }
.faq__a { padding:0 0 1.2rem; color:var(--text); }
.faq__a p:first-child { margin-top:0; }
.faq__a p:last-child { margin-bottom:0; }
.faq__a a { color:var(--blue); }

/* ============ Yoast FAQ-blok (diensten-/branchepagina's) ============ */
.schema-faq { display:grid; gap:.85rem; max-width:820px; margin:2rem auto 0; }
.schema-faq-section { background:#fff; border:1px solid var(--border); border-radius:12px; padding:1.1rem 1.35rem; box-shadow:0 1px 2px rgba(7,23,45,.04); }
.schema-faq-question { display:block; font-weight:700; color:var(--navy); font-size:1.05rem; margin-bottom:.4rem; }
.schema-faq-answer { color:var(--text); margin:0; }
.schema-faq-answer a { color:var(--blue); }
