/* ===== TPP Bos – Blocks Section ===== */
.bs-section{position:relative;padding:48px 0}
.bs-section.bg-light{background:#ffffff}
.bs-section.bg-subtle-gradient{    background: #fafbfd;}
.bs-wrap{width:min(1400px,92vw);margin:0 auto}
.bs-header{text-align:center;margin-bottom:18px}
.bs-title{font-size:clamp(24px,3.5vw,32px);margin:0;color:#0e2038}
.bs-intro{color:#5b6770;max-width:720px;margin:8px auto 0}
.bs-grid{display:grid;gap:18px;margin-top:16px}
.bs-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.bs-grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1024px){.bs-grid.cols-3,.bs-grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.bs-grid.cols-3,.bs-grid.cols-4{grid-template-columns:1fr}}
.bs-card{overflow: hidden;display:flex;flex-direction:column;gap:10px;position:relative;background:#fff;border:1px solid #e6eef6;border-radius:20px;padding:18px;box-shadow:0 8px 24px rgba(16,32,48,.06);text-decoration:none;color:#0d1b2a;transition:transform .2s, box-shadow .2s, border-color .2s;isolation:isolate}
.bs-card::before{    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, #6a4fd3, #8a5adf);
    opacity: .9;
    top: 0px;}
.bs-card:hover,.bs-card:focus-visible{transform:translateY(-3px);box-shadow:0 14px 38px rgba(16,32,48,.12);border-color:#d7e6ff;outline:none}
.bs-card:active{transform:translateY(-1px)}
.bs-card .cap{display:flex;align-items:center;gap:12px}
.bs-card:first-child .badge{    color: white !important;display:inline-flex;align-items:center;gap:6px;background:rgba(106,79,211,.1);border:1px solid #e6e2fb;padding:6px 8px;border-radius:999px;font-size:12px;color:#6a4fd3}
.bs-card .badge{    display:inline-flex;align-items:center;gap:6px;background:rgba(106,79,211,.1);border:1px solid #e6e2fb;padding:6px 8px;border-radius:999px;font-size:12px;color:#6a4fd3}
.bs-card .bs-icon{width:28px;height:28px;color:#6a4fd3;flex:0 0 auto}
.bs-card .bs-thumb{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:12px;border:1px solid #eef2f7}
.bs-card h3{font-size:18px;margin:0;color:#0e2038}
.bs-card p{margin:0;color:#5b6770;line-height:1.65}
.bs-card .more{margin-top:6px;font-weight:600;color:#6a4fd3}
@media (min-width:1100px){.bs-card.featured{grid-column:span 1}}
.bs-card.style-soft{background:#fbfbfe;}
.bs-card.style-cta{background:linear-gradient(135deg,#6a4fd3,#8a5adf);color:#fff;border-color:transparent}
.bs-card.style-cta::before{background:transparent}
.bs-card.style-cta .badge{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.25);color:#fff}
.bs-card.style-cta .more,.bs-card--cta .btn{color:#2a1b5a}
.bs-card--cta{display:flex;flex-direction:column;gap:10px;background:linear-gradient(135deg,#6a4fd3,#8a5adf);color:#fff;border:0}
.bs-card--cta h3{color:#fff}
.bs-card--cta p{color:#fff;opacity:.95}
.bs-card--cta .btn{align-self:flex-start;background:#fff;color:#2a1b5a;border-radius:999px;padding:8px 12px;font-weight:700}
.bs-rows{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.bs-row{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid #e6eef6;border-radius:16px;padding:14px 16px;text-decoration:none;color:#0d1b2a;transition:transform .2s, box-shadow .2s, border-color .2s}
.bs-row .bs-icon{width:26px;height:26px;color:#6a4fd3;margin-top:2px}
.bs-row .t{font-weight:800;color:#0e2038}
.bs-row p{margin:.2em 0 0;color:#5b6770}
.bs-row .more{display:inline-block;margin-top:6px;font-weight:600;color:#6a4fd3}
.bs-row:hover,.bs-row:focus-visible{transform:translateY(-2px);box-shadow:0 10px 28px rgba(16,32,48,.08);border-color:#d7e6ff;outline:none}
.bs-section .ocean{position:absolute;left:0;right:0;bottom:-1px;height:80px;overflow:hidden;pointer-events:none}
.bs-section .wave{position:absolute;left:0;right:0;bottom:0;height:100%;
  background:radial-gradient(120px 20px at 20% 90%, rgba(106,79,211,.08), transparent 60%),
             radial-gradient(160px 26px at 60% 80%, rgba(138,90,223,.08), transparent 60%),
             linear-gradient(to bottom, transparent, rgba(106,79,211,.06));
  animation:wave 8s ease-in-out infinite alternate}
.bs-section .wave:nth-child(2){opacity:.6;animation-duration:11s}
@keyframes wave{from{transform:translateX(-2%)}to{transform:translateX(2%)}}
.bs-card:focus-visible,.bs-row:focus-visible{box-shadow:0 0 0 3px rgba(106,79,211,.25)}
@media (prefers-reduced-motion: reduce){.bs-card,.bs-row{transition:none}.bs-section .wave{animation:none}}
/* PNG icon support */
.bs-icon-png{
  width:28px;
  height:28px;
  object-fit:contain;
  flex:0 0 auto;
  image-rendering:-webkit-optimize-contrast;
}
.bs-row .bs-icon-png{ margin-top:2px; }      /* optisch lijnt mooi met tekst */
.bs-card .bs-icon-png{ margin:0; }           /* binnen cards geen extra marge */