/* Grip op DMARC – huisstijl (gebaseerd op gripopit.nl) */
:root{
  --groen:#a4c422;
  --groen-donker:#8aa81a;
  --groen-licht:#eef3d8;
  --groen-zacht:#f6f9e8;
  --navy:#2c3a64;
  --navy-donker:#222d4e;
  --grijs:#f0f0f0;
  --tekst:#3d4663;
  --wit:#ffffff;
  --rood:#d64545;
  --oranje:#e8a13b;
  --radius:10px;
  --schaduw:0 8px 30px rgba(44,58,100,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Roboto',Arial,sans-serif;color:var(--tekst);background:var(--wit);line-height:1.7;font-size:16px}
h1,h2,h3,h4{font-family:'Roboto Condensed','Roboto',sans-serif;color:var(--navy);line-height:1.2}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:1.25rem}
p{margin-bottom:1rem}
a{color:var(--navy);text-decoration:none}
img{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 22px}
section{padding:80px 0}
.sectie-kop{text-align:center;max-width:760px;margin:0 auto 50px}
.label{display:inline-block;background:var(--groen-licht);color:var(--navy);font-weight:700;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;padding:6px 16px;border-radius:99px;margin-bottom:14px}
.btn{display:inline-block;background:var(--groen);color:var(--wit);font-weight:700;padding:16px 34px;border-radius:6px;border:none;font-size:1rem;cursor:pointer;transition:background .2s,transform .2s;font-family:'Roboto',sans-serif}
.btn:hover{background:var(--groen-donker);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--navy);border:2px solid var(--groen)}
.btn-outline:hover{background:var(--groen);color:var(--wit)}

/* ===== NAV ===== */
header{position:sticky;top:0;z-index:100;background:var(--wit);box-shadow:0 2px 12px rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Roboto Condensed',sans-serif;font-weight:700;font-size:1.35rem;color:var(--navy);letter-spacing:.04em}
.logo svg{flex-shrink:0}
.logo span b{color:var(--groen)}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-weight:500;font-size:.95rem;transition:color .2s}
.nav-links a:hover{color:var(--groen)}
.nav-links a.actief{color:var(--groen);font-weight:700}
.nav-links .btn{padding:10px 22px;color:var(--wit);font-size:.9rem}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:3px;background:var(--navy);margin:5px 0;border-radius:2px}
@media(max-width:900px){
  .hamburger{display:block}
  .nav-links{display:none;position:absolute;top:74px;left:0;right:0;background:var(--wit);flex-direction:column;padding:24px;box-shadow:0 12px 20px rgba(0,0,0,.08);gap:18px}
  .nav-links.open{display:flex}
}

/* ===== HERO ===== */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--wit) 0%,var(--groen-zacht) 100%);padding:90px 0 70px}
.hero .container{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero-watermerk{position:absolute;right:-120px;top:-80px;width:560px;height:560px;opacity:.07;transform:rotate(12deg);pointer-events:none}
.hero h1{margin-bottom:20px}
.hero p.intro{font-size:1.1rem;max-width:540px}
.hero-usps{list-style:none;margin:22px 0 30px}
.hero-usps li{padding:5px 0;font-weight:500;color:var(--navy)}
.hero-usps li::before{content:"✓";color:var(--groen);font-weight:700;margin-right:10px;font-size:1.1rem}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
@media(max-width:900px){.hero .container{grid-template-columns:1fr}.hero-visual{order:-1;max-width:420px;margin:0 auto}}

/* hero-klein voor subpagina's */
.hero-klein{background:linear-gradient(180deg,var(--wit) 0%,var(--groen-zacht) 100%);padding:54px 0 44px}
.hero-klein h1{font-size:clamp(1.8rem,4vw,2.7rem);margin:10px 0 14px}
.hero-klein p.intro{font-size:1.08rem;max-width:760px;margin:0}
.breadcrumb{font-size:.85rem;color:#7b829c}
.breadcrumb a{color:#7b829c}
.breadcrumb a:hover{color:var(--groen)}

/* dashboard mockup */
.dash{background:var(--wit);border-radius:14px;box-shadow:var(--schaduw);padding:22px;border:1px solid #e7eadf}
.dash-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.dash-top b{font-family:'Roboto Condensed';color:var(--navy)}
.badge-ok{background:var(--groen-licht);color:#5d7414;font-weight:700;font-size:.75rem;padding:4px 12px;border-radius:99px}
.dash-rij{display:flex;align-items:center;gap:12px;padding:10px 0;border-top:1px solid #f0f2e8;font-size:.9rem}
.dash-rij .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot-g{background:var(--groen)}.dot-o{background:var(--oranje)}.dot-r{background:var(--rood)}
.dash-rij b{color:var(--navy);min-width:90px}
.dash-balk{height:8px;border-radius:99px;background:#eef0e4;flex:1;overflow:hidden}
.dash-balk i{display:block;height:100%;border-radius:99px;background:var(--groen)}
.dash-score{display:flex;align-items:center;gap:18px;background:var(--groen-zacht);border-radius:10px;padding:14px 18px;margin-top:14px}
.score-cirkel{width:64px;height:64px;border-radius:50%;background:conic-gradient(var(--groen) 0 88%,#e3e8d2 88% 100%);display:grid;place-items:center;flex-shrink:0}
.score-cirkel i{width:48px;height:48px;border-radius:50%;background:var(--wit);display:grid;place-items:center;font-style:normal;font-weight:700;color:var(--navy)}

/* ===== TRUSTBAR ===== */
.trustbar{background:var(--navy);padding:34px 0}
.trustbar .container{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.trust-item b{display:block;font-family:'Roboto Condensed';font-size:1.9rem;color:var(--groen)}
.trust-item span{color:#c6cde2;font-size:.88rem;line-height:1.4;display:block}
@media(max-width:800px){.trustbar .container{grid-template-columns:repeat(2,1fr)}}

/* ===== KAARTEN ===== */
.kaarten{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.kaart{background:var(--wit);border-radius:var(--radius);box-shadow:var(--schaduw);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s}
.kaart:hover{transform:translateY(-5px)}
.kaart-kop{background:var(--groen-licht);text-align:center;padding:18px 16px 60px;position:relative}
.kaart-kop h3{font-size:1.1rem;letter-spacing:.03em;text-transform:uppercase}
.kaart-icoon{width:84px;height:84px;border-radius:50%;background:var(--navy);border:4px solid var(--groen);display:grid;place-items:center;position:absolute;left:50%;transform:translateX(-50%);bottom:-42px}
.kaart-icoon svg{width:38px;height:38px;fill:var(--wit)}
.kaart-body{padding:60px 26px 28px;text-align:center;flex:1;display:flex;flex-direction:column}
.kaart-body h4{margin-bottom:10px;font-size:1.05rem}
.kaart-body p{font-size:.95rem;flex:1}
.kaart-body a{color:var(--groen-donker);font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}
@media(max-width:900px){.kaarten{grid-template-columns:1fr;max-width:420px;margin:0 auto}}

/* ===== CHECK TOOL ===== */
.check{background:var(--navy);color:#dde2f0}
.check h1,.check h2,.check h3{color:var(--wit)}
.check .sectie-kop p{color:#c6cde2}
.check-form{display:flex;gap:12px;max-width:620px;margin:0 auto 10px;flex-wrap:wrap}
.check-form input{flex:1;min-width:240px;padding:16px 20px;border-radius:6px;border:2px solid transparent;font-size:1rem;outline:none}
.check-form input:focus{border-color:var(--groen)}
.check-klein{text-align:center;font-size:.85rem;color:#9aa3c0}
.check-resultaat{max-width:760px;margin:34px auto 0;display:none}
.res-kaart{background:var(--wit);border-radius:10px;padding:20px 24px;margin-bottom:14px;display:flex;gap:16px;align-items:flex-start;color:var(--tekst)}
.res-status{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;font-weight:700;color:var(--wit);font-size:1.2rem}
.rs-ok{background:var(--groen)}.rs-warn{background:var(--oranje)}.rs-fail{background:var(--rood)}
.res-kaart h4{color:var(--navy);margin-bottom:4px}
.res-kaart p{margin:0;font-size:.92rem}
.res-kaart code{background:var(--grijs);padding:2px 8px;border-radius:4px;font-size:.8rem;word-break:break-all;display:inline-block;margin-top:6px;color:var(--navy-donker)}
.check-cta{text-align:center;margin-top:26px;display:none}
.spinner{display:none;margin:30px auto 0;width:42px;height:42px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--groen);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== STAPPEN ===== */
.stappen{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.stap{background:var(--wit);border-radius:var(--radius);box-shadow:var(--schaduw);padding:30px 24px;position:relative}
.stap-nr{width:46px;height:46px;border-radius:50%;background:var(--groen);color:var(--wit);font-family:'Roboto Condensed';font-weight:700;font-size:1.3rem;display:grid;place-items:center;margin-bottom:16px}
.stap h3{font-size:1.05rem;margin-bottom:8px}
.stap p{font-size:.92rem;margin:0}
@media(max-width:900px){.stappen{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.stappen{grid-template-columns:1fr}}

/* ===== WAAROM ===== */
.waarom{background:var(--grijs)}
.waarom-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.waarom-item{background:var(--wit);border-left:5px solid var(--groen);border-radius:8px;padding:26px;box-shadow:var(--schaduw)}
.waarom-item h3{font-size:1.05rem;margin-bottom:8px}
.waarom-item p{font-size:.93rem;margin:0}
@media(max-width:900px){.waarom-grid{grid-template-columns:1fr}}

/* ===== PRIJZEN ===== */
.prijzen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch}
.prijs{background:var(--wit);border-radius:var(--radius);box-shadow:var(--schaduw);padding:36px 30px;display:flex;flex-direction:column;border:2px solid transparent}
.prijs.populair{border-color:var(--groen);position:relative}
.prijs.populair::before{content:"Meest gekozen";position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--groen);color:var(--wit);font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 18px;border-radius:99px}
.prijs h3{text-transform:uppercase;letter-spacing:.04em}
.prijs .bedrag{font-family:'Roboto Condensed';font-size:2.6rem;color:var(--navy);font-weight:700;margin:14px 0 2px}
.prijs .bedrag small{font-size:1rem;color:var(--tekst);font-weight:400;font-family:'Roboto'}
.prijs .per{font-size:.85rem;color:#7b829c;margin-bottom:20px}
.prijs ul{list-style:none;margin-bottom:28px;flex:1}
.prijs li{padding:7px 0;font-size:.93rem;border-bottom:1px solid #f1f2ee}
.prijs li::before{content:"✓";color:var(--groen);font-weight:700;margin-right:10px}
.prijs .btn{text-align:center}
.prijs-disclaimer{text-align:center;font-size:.82rem;color:#7b829c;margin-top:22px}
@media(max-width:900px){.prijzen-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}}

/* ===== TESTIMONIALS ===== */
.quotes{background:var(--groen-zacht)}
.quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.quote{background:var(--wit);border-radius:var(--radius);padding:30px;box-shadow:var(--schaduw)}
.quote p{font-style:italic;font-size:.95rem}
.quote b{color:var(--navy);font-size:.9rem}
.quote span{display:block;font-size:.8rem;color:#7b829c}
@media(max-width:900px){.quotes-grid{grid-template-columns:1fr}}

/* ===== FAQ ===== */
.faq{max-width:820px;margin:0 auto}
.faq details{background:var(--wit);border:1px solid #e6e8e0;border-radius:8px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:700;color:var(--navy);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--groen);font-size:1.5rem;font-weight:400;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details div{padding:0 22px 20px;font-size:.95rem}

/* ===== CONTACT ===== */
.contact{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-donker) 100%);color:#dde2f0;text-align:center}
.contact h2{color:var(--wit)}
.contact p{max-width:560px;margin:0 auto 30px;color:#c6cde2}

/* ===== ARTIKEL (kennispagina's) ===== */
.artikel{max-width:820px;margin:0 auto;padding:60px 22px}
.artikel h2{margin:42px 0 14px;font-size:1.5rem}
.artikel h3{margin:28px 0 10px;font-size:1.15rem}
.artikel ul,.artikel ol{margin:0 0 1rem 1.4rem}
.artikel li{margin-bottom:6px}
.artikel table{width:100%;border-collapse:collapse;margin:18px 0 24px;font-size:.93rem}
.artikel th{background:var(--navy);color:var(--wit);text-align:left;padding:12px 14px;font-family:'Roboto Condensed';letter-spacing:.03em}
.artikel td{padding:11px 14px;border-bottom:1px solid #e8eadf;vertical-align:top}
.artikel tr:nth-child(even) td{background:var(--groen-zacht)}
.artikel code,.record{background:var(--grijs);padding:2px 8px;border-radius:4px;font-size:.86rem;color:var(--navy-donker);word-break:break-all}
.record{display:block;padding:14px 18px;margin:14px 0 22px;border-left:4px solid var(--groen);font-family:monospace}
.opmerking{background:var(--groen-licht);border-radius:8px;padding:16px 20px;margin:18px 0;font-size:.93rem}
.opmerking b{color:var(--navy)}
.definitie{background:var(--groen-zacht);border-left:5px solid var(--groen);border-radius:8px;padding:20px 24px;margin:0 0 26px;font-size:1.05rem}
.definitie b{color:var(--navy)}
.cta-blok{background:var(--groen-licht);border-radius:var(--radius);padding:38px 32px;text-align:center;margin:50px 0 0}
.cta-blok h2{margin:0 0 10px}
.cta-blok p{max-width:540px;margin:0 auto 22px}
.verder-lezen{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.verder-lezen a{background:var(--wit);border:1px solid #e6e8e0;border-radius:8px;padding:18px 20px;font-weight:700;color:var(--navy);transition:border-color .2s}
.verder-lezen a:hover{border-color:var(--groen)}
.verder-lezen a small{display:block;font-weight:400;color:var(--tekst);font-size:.85rem;margin-top:4px}
@media(max-width:700px){.verder-lezen{grid-template-columns:1fr}}

/* ===== FOOTER ===== */
footer{background:var(--navy-donker);color:#aab2cc;padding:56px 0 28px;font-size:.9rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.footer-grid h4{color:var(--wit);font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.footer-grid ul{list-style:none}
.footer-grid li{padding:4px 0}
.footer-grid a{color:#aab2cc}
.footer-grid a:hover{color:var(--groen)}
.footer-onder{border-top:1px solid #39456e;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem}
@media(max-width:800px){.footer-grid{grid-template-columns:1fr 1fr}}
