*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:#111521;line-height:1.65;background:#fff;-webkit-font-smoothing:antialiased}
a{color:var(--acc);text-decoration:none}
img{max-width:100%}
h1,h2,h3{font-family:var(--head);line-height:1.08;letter-spacing:-.02em;margin:0}
.g-wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.g-narrow{max-width:780px;margin-inline:auto}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.g-eyebrow{display:inline-block;font-family:var(--body);font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--acc);margin-bottom:14px}
.g-head{max-width:720px;margin:0 auto 46px;text-align:center}
.g-head h2,.g-sec>.g-wrap>.g-narrow h2{margin:0}
h2{font-size:clamp(28px,4vw,44px)}
.g-btn{display:inline-flex;align-items:center;gap:.5em;background:var(--acc);color:#fff;font-family:var(--body);font-weight:700;font-size:16px;padding:15px 30px;border-radius:999px;transition:.18s;box-shadow:0 14px 30px -8px color-mix(in srgb,var(--acc) 60%,transparent)}
.g-btn:hover{transform:translateY(-3px);box-shadow:0 20px 40px -10px color-mix(in srgb,var(--acc) 70%,transparent)}
.g-btn-ghost{background:rgba(255,255,255,.12);color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.g-btn-ghost:hover{background:rgba(255,255,255,.2)}
.g-btn-light{background:#fff;color:var(--acc)}
.g-btns{display:flex;gap:14px;flex-wrap:wrap}
.g-pill{display:inline-flex;align-items:center;gap:.5em;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.32);color:#fff;font-weight:600;font-size:13.5px;padding:7px 16px;border-radius:999px;margin-bottom:20px;backdrop-filter:blur(6px)}
/* nav */
.g-nav{position:sticky;top:0;z-index:40;transition:.25s}
.g-nav.scrolled{background:rgba(255,255,255,.82);backdrop-filter:saturate(150%) blur(14px);box-shadow:0 1px 0 rgba(17,21,33,.07)}
body.has-hero .g-nav:not(.scrolled){background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,0))}
.g-nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}
.g-brand{font-family:var(--head);font-weight:800;font-size:23px;color:#111521;letter-spacing:-.03em}
body.has-hero .g-nav:not(.scrolled) .g-brand,body.has-hero .g-nav:not(.scrolled) .g-menu a{color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.25)}
.g-logo-img{height:42px;width:auto;display:block}
.g-logo{display:inline-flex;align-items:center;gap:10px}
.g-logo-mark{display:block;flex:0 0 auto}
.g-logo-tx{font-family:var(--head);font-weight:800;font-size:21px;letter-spacing:-.03em}
.g-logo-ul .g-logo-tx{box-shadow:inset 0 -3px 0 var(--acc);padding-bottom:2px}
/* nav-varianten: gecentreerd logo / zijbalk links */
body[data-nav=center] .g-nav-in{flex-direction:column;height:auto;gap:12px;padding:16px 0}
body[data-nav=center] .g-menu{gap:24px}
body[data-nav=sidebar] .g-nav{position:fixed;top:0;left:0;bottom:0;right:auto;width:212px;background:#fff;border-right:1px solid #ecedf3;backdrop-filter:none}
body[data-nav=sidebar] .g-nav-in{flex-direction:column;align-items:flex-start;justify-content:flex-start;height:100%;gap:22px;padding:32px 26px}
body[data-nav=sidebar] .g-menu{flex-direction:column;align-items:flex-start;gap:14px}
body[data-nav=sidebar] main,body[data-nav=sidebar] .g-foot{margin-left:212px}
.g-menu{display:flex;align-items:center;gap:28px}
.g-menu a{color:#1b2031;font-weight:600;font-size:15px}
.g-menu a:hover,.g-menu a.is-current{color:var(--acc)}
body.has-hero .g-nav:not(.scrolled) .g-menu a.is-current{text-decoration:underline;text-underline-offset:6px}
.g-nav-cta{background:var(--acc);color:#fff!important;padding:10px 20px;border-radius:999px;text-shadow:none!important}
.g-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:2}
.g-burger span{width:26px;height:2px;background:currentColor;color:#111521;border-radius:2px}
body.has-hero .g-nav:not(.scrolled) .g-burger span{color:#fff}
/* hero — 3 archetypes (overlay / split / editorial) */
.g-hero{position:relative;color:#fff;overflow:hidden}
.g-hero-media{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.g-hero-media.g-grad{background:linear-gradient(135deg,var(--acc),var(--acc-d))}
.g-hero-shade{position:absolute;inset:0;z-index:1}
.g-hero-in{position:relative;z-index:2}
.g-hero h1{font-family:var(--head);font-weight:800;margin:0 0 22px;letter-spacing:-.02em}
.g-lead{line-height:1.55;margin:0 0 30px}
.g-lead-dark{color:#444b60;opacity:1}
/* OVERLAY — foto full-bleed, witte tekst over de foto */
body[data-hero=overlay] .g-hero{min-height:88vh;display:flex;align-items:center;margin-top:-74px;padding:122px 0 90px}
body[data-hero=overlay] .g-hero-shade{background:linear-gradient(100deg,rgba(7,9,18,.8),rgba(7,9,18,.5) 45%,rgba(7,9,18,.2))}
body[data-hero=overlay] .g-hero-in{max-width:760px}
body[data-hero=overlay] .g-hero h1{font-size:clamp(40px,6.4vw,78px)}
body[data-hero=overlay] .g-lead{font-size:clamp(17px,1.8vw,21px);opacity:.96;max-width:600px}
/* SPLIT — foto links, tekstpaneel rechts op lichte achtergrond */
body[data-hero=split] .g-hero{display:grid;grid-template-columns:1fr 1fr;min-height:76vh;color:#15172b;background:var(--acc-soft)}
body[data-hero=split] .g-hero-media{position:relative;inset:auto;min-height:320px}
body[data-hero=split] .g-hero-shade{display:none}
body[data-hero=split] .g-hero-in{max-width:none;margin:0;padding:clamp(40px,5vw,72px) clamp(26px,4vw,60px);display:flex;flex-direction:column;justify-content:center}
body[data-hero=split] .g-hero h1{font-size:clamp(32px,4vw,54px)}
body[data-hero=split] .g-lead{font-size:clamp(16px,1.5vw,20px);color:#444b60;max-width:500px}
/* EDITORIAL — geen foto, grote tekst op getinte achtergrond */
body[data-hero=editorial] .g-hero{min-height:auto;padding:clamp(96px,13vw,176px) 0 clamp(60px,8vw,104px);color:#15172b;background:var(--acc-soft)}
body[data-hero=editorial] .g-hero-media,body[data-hero=editorial] .g-hero-shade{display:none}
body[data-hero=editorial] .g-hero-in{max-width:940px}
body[data-hero=editorial] .g-hero h1{font-size:clamp(44px,7.5vw,100px);line-height:1.02;margin-bottom:26px}
body[data-hero=editorial] .g-lead{font-size:clamp(18px,2vw,25px);color:#444b60;max-width:640px}
/* badge + ghost-knop leesbaar op lichte hero's */
body:not([data-hero=overlay]) .g-pill{background:var(--acc-soft);border-color:color-mix(in srgb,var(--acc) 40%,transparent);color:var(--acc);text-shadow:none}
body:not([data-hero=overlay]) .g-btn-ghost{background:#fff;color:var(--acc);box-shadow:inset 0 0 0 1.5px var(--acc)}
/* BOXED — foto full-bleed met zwevend tekstkaartje */
body[data-hero=boxed] .g-hero{min-height:88vh;display:flex;align-items:center;margin-top:-74px;padding:122px 0 90px}
body[data-hero=boxed] .g-hero-shade{background:rgba(7,9,18,.3)}
body[data-hero=boxed] .g-hero-in{max-width:540px;background:#fff;color:#15172b;border-radius:calc(var(--radius) + 10px);padding:clamp(30px,4vw,48px);box-shadow:0 40px 90px -30px rgba(0,0,0,.55)}
body[data-hero=boxed] .g-hero h1{font-size:clamp(32px,4vw,52px);color:#15172b}
body[data-hero=boxed] .g-hero .g-lead{font-size:clamp(16px,1.6vw,20px);color:#444b60;opacity:1}
/* BANNER — massieve kleurband, witte tekst, geen foto */
body[data-hero=banner] .g-hero{min-height:auto;margin-top:-74px;padding:clamp(130px,15vw,210px) 0 clamp(56px,7vw,90px);color:#fff}
body[data-hero=banner] .g-hero-shade{background:linear-gradient(120deg,color-mix(in srgb,var(--acc) 80%,transparent),color-mix(in srgb,var(--acc-d) 58%,transparent))}
body[data-hero=banner] .g-hero-in{max-width:820px}
body[data-hero=banner] .g-hero h1{font-size:clamp(40px,6.5vw,84px);text-transform:uppercase}
body[data-hero=banner] .g-hero .g-lead{font-size:clamp(17px,1.9vw,22px);opacity:.95;max-width:600px}
body[data-hero=banner] .g-pill{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.4);color:#fff}
body[data-hero=banner] .g-hero .g-btn{background:#fff;color:var(--acc)}
/* sections */
.g-sec{padding:clamp(60px,8vw,110px) 0}
.g-alt{background:var(--acc-soft)}
.g-prose p{font-size:17px;color:#444b60;margin:0 0 16px}
/* split */
.g-split-in{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.g-split-left .g-split-media{order:-1}
.g-split-media{position:relative}
.g-split-media::before{content:"";position:absolute;inset:auto -18px -18px auto;width:62%;height:62%;background:var(--acc);opacity:.12;border-radius:calc(var(--radius) + 14px);z-index:0}
.g-split-img{position:relative;z-index:1;aspect-ratio:5/4;border-radius:calc(var(--radius) + 8px);background-size:cover;background-position:center;box-shadow:0 30px 60px -22px rgba(20,24,50,.4)}
.g-split-txt h2{margin:0 0 18px}
.g-bullets{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:12px}
.g-bullets li{position:relative;padding-left:34px;font-size:16px;color:#2a3045;font-weight:500}
.g-bullets li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--acc-soft);box-shadow:inset 0 0 0 2px var(--acc)}
.g-bullets li::after{content:"✓";position:absolute;left:5px;top:1px;color:var(--acc);font-weight:800;font-size:13px}
.g-grad{background:linear-gradient(135deg,var(--acc),var(--acc-d))}
/* cards */
.g-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.g-card{position:relative;background:#fff;border:1px solid #eef0f6;border-radius:var(--radius);padding:34px 28px 28px;box-shadow:0 18px 40px -28px rgba(20,24,50,.4);transition:.2s;overflow:hidden}
.g-card:hover{transform:translateY(-6px);box-shadow:0 30px 56px -26px rgba(20,24,50,.45)}
.g-card-ix{font-family:var(--head);font-size:15px;font-weight:800;color:var(--acc);background:var(--acc-soft);width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px}
.g-card h3{font-size:20px;margin:0 0 8px}
.g-card p{margin:0;color:#566;font-size:15.5px}
/* stats */
.g-statsband{padding:0}
.g-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;background:linear-gradient(120deg,var(--acc),var(--acc-d));border-radius:calc(var(--radius) + 8px);padding:44px 30px;color:#fff;margin-top:-40px}
.g-stat{text-align:center}
.g-stat-n{display:block;font-family:var(--head);font-size:clamp(30px,4vw,46px);font-weight:800;line-height:1}
.g-stat-l{display:block;font-size:14px;opacity:.9;margin-top:6px}
/* steps */
.g-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.g-step{display:flex;gap:16px;align-items:flex-start}
.g-num{flex:0 0 auto;width:46px;height:46px;border-radius:14px;background:var(--acc);color:#fff;font-family:var(--head);font-weight:800;font-size:18px;display:grid;place-items:center;box-shadow:0 10px 22px -8px var(--acc)}
.g-step h3{font-size:18px;margin:0 0 5px}.g-step p{margin:0;color:#566;font-size:15px}
/* services */
.g-servs{display:grid;gap:14px;max-width:860px;margin:0 auto}
.g-serv{display:flex;justify-content:space-between;align-items:center;gap:20px;background:#fff;border:1px solid #eef0f6;border-radius:var(--radius);padding:22px 28px;transition:.18s;box-shadow:0 10px 30px -24px rgba(20,24,50,.5)}
.g-serv:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--acc) 40%,#eef0f6)}
.g-serv h3{font-size:18px;margin:0 0 4px}.g-serv p{margin:0;color:#566;font-size:15px}
.g-price{flex:0 0 auto;font-family:var(--head);font-weight:800;color:var(--acc);white-space:nowrap;font-size:18px}
/* bento gallery */
.g-bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px}
.g-tile{position:relative;margin:0;border-radius:var(--radius);overflow:hidden;background-size:cover;background-position:center;display:flex;align-items:flex-end;box-shadow:0 16px 36px -24px rgba(20,24,50,.5);transition:.25s}
.g-tile:hover{transform:scale(1.015)}
.g-tile:first-child{grid-column:span 2;grid-row:span 2}
.g-tile:nth-child(6){grid-column:span 2}
.g-tile figcaption{width:100%;background:linear-gradient(transparent,rgba(0,0,0,.66));color:#fff;font-size:14px;font-weight:600;padding:26px 16px 14px}
/* testimonials */
.g-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.g-quote{margin:0;background:#fff;border:1px solid #eef0f6;border-radius:var(--radius);padding:28px 26px;box-shadow:0 18px 40px -30px rgba(20,24,50,.5)}
.g-stars{color:#f5b301;font-size:15px;letter-spacing:2px;margin-bottom:12px}
.g-quote p{margin:0 0 18px;font-size:16px;line-height:1.6;color:#2a3045}
.g-quote footer{display:flex;align-items:center;gap:12px}
.g-av{width:42px;height:42px;border-radius:50%;background:var(--acc);color:#fff;font-family:var(--head);font-weight:800;display:grid;place-items:center}
.g-quote cite{display:block;font-style:normal;font-weight:700;font-size:15px;color:#111521}
.g-tm-role{font-size:13px;color:#8a90a8}
/* cta card */
.g-ctacard{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--acc),var(--acc-d));color:#fff;text-align:center;border-radius:calc(var(--radius) + 12px);padding:clamp(48px,7vw,84px) 30px;box-shadow:0 40px 80px -40px var(--acc)}
.g-ctacard h2{font-size:clamp(26px,3.4vw,40px);margin:0 0 12px}
.g-ctacard p{margin:0 0 6px;font-size:18px;opacity:.95;max-width:560px;margin-inline:auto}
/* contact */
.g-contact{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:0}
.g-contact li{display:flex;gap:16px;font-size:16.5px;border-bottom:1px solid #eef0f6;padding:16px 0}
.g-contact span{flex:0 0 96px;color:#8a90a8;font-weight:600}
.g-map{margin-top:24px;border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 40px -26px rgba(20,24,50,.45);border:1px solid #eef0f6}
.g-map iframe{display:block;width:100%;height:340px;border:0}
/* footer */
.g-foot{background:#0d1018;color:#aeb4cc;padding:42px 0}
.g-foot-in{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.g-foot strong{font-family:var(--head);font-size:20px;color:#fff;display:block}
.g-foot span{font-size:14px;color:#8c92ad}
.g-foot small{font-size:12.5px;color:#6b7290}
.g-foot a{color:#aab2e6}
.g-foot-legal{display:flex;gap:18px;flex-wrap:wrap}
.g-foot-legal a{font-size:13.5px;color:#c2c7e0}
.g-foot-legal a:hover{color:#fff}
/* juridische pagina's */
.g-legal{padding-top:clamp(48px,7vw,90px)}
.g-legal h1{font-size:clamp(30px,4.4vw,46px);margin:0 0 14px}
.g-legal .g-prose h2{font-size:21px;margin:30px 0 8px}
.g-legal-note{margin-top:30px;padding:14px 18px;background:var(--acc-soft);border-radius:var(--radius);font-size:13.5px;color:#555a72}
/* cookiebanner */
.g-cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:60;max-width:560px;margin:0 auto;background:#fff;border:1px solid #e7e8f0;border-radius:16px;box-shadow:0 24px 60px -20px rgba(20,24,50,.45);padding:18px 20px;display:flex;flex-wrap:wrap;gap:12px 18px;align-items:center;justify-content:space-between}
.g-cookie[hidden]{display:none}
.g-cookie p{margin:0;font-size:14px;color:#444b60;flex:1 1 260px;line-height:1.5}
.g-cookie a{color:var(--acc);font-weight:600}
.g-cookie-btns{display:flex;gap:10px}
.g-ck-no,.g-ck-yes{font:inherit;font-weight:700;font-size:14px;padding:10px 18px;border-radius:999px;cursor:pointer;border:0}
.g-ck-no{background:#eef0f6;color:#444b60}
.g-ck-yes{background:var(--acc);color:#fff}
.g-ck-yes:hover{filter:brightness(.96)}

/* ===== 10 thema's — elk een eigen look & feel ===== */
/* BOLD (overlay) — hoofdletters, scherp, omrande kaarten */
body[data-theme=bold] h1,body[data-theme=bold] h2{letter-spacing:-.04em;text-transform:uppercase}
body[data-theme=bold] .g-brand{text-transform:uppercase}
body[data-theme=bold] .g-head{text-align:left;margin-left:0;max-width:760px}
body[data-theme=bold] .g-card{box-shadow:none;border:2px solid #15172b}
body[data-theme=bold] .g-card-ix{background:#15172b;color:#fff}
body[data-theme=bold] .g-btn{text-transform:uppercase;letter-spacing:.03em;font-weight:800}

/* VIBRANT (overlay) — kleurrijk, gekleurde kaarttop, gradient-hero */
body[data-theme=vibrant][data-hero=overlay] .g-hero-shade{background:linear-gradient(120deg,color-mix(in srgb,var(--acc) 82%,#000),color-mix(in srgb,var(--acc-d) 60%,transparent))}
body[data-theme=vibrant] .g-card{border-top:4px solid var(--acc);box-shadow:0 22px 46px -24px color-mix(in srgb,var(--acc) 55%,transparent)}
body[data-theme=vibrant] .g-eyebrow{background:var(--acc-soft);padding:5px 12px;border-radius:999px}

/* DARK (overlay) — volledig donker thema */
body[data-theme=dark]{background:#0d0f17;color:#e7e9f3}
body[data-theme=dark] .g-alt{background:#141826}
body[data-theme=dark] h1,body[data-theme=dark] h2,body[data-theme=dark] .g-brand,body[data-theme=dark] .g-card h3,body[data-theme=dark] .g-quote cite,body[data-theme=dark] .g-stat-n{color:#fff}
body[data-theme=dark] .g-prose p,body[data-theme=dark] .g-card p,body[data-theme=dark] .g-serv p,body[data-theme=dark] .g-step p,body[data-theme=dark] .g-quote p{color:#aab0c6}
body[data-theme=dark] .g-card,body[data-theme=dark] .g-serv,body[data-theme=dark] .g-quote{background:#161b2b;border-color:#252b40;box-shadow:none}
body[data-theme=dark] .g-nav.scrolled{background:rgba(13,15,23,.88);box-shadow:0 1px 0 #252b40}
body[data-theme=dark] .g-nav.scrolled .g-brand,body[data-theme=dark] .g-nav.scrolled .g-menu a{color:#e7e9f3}
body[data-theme=dark] .g-contact li{border-color:#252b40}

/* ELEGANT (split) — serif, crème, hairline kaarten */
body[data-theme=elegant]{background:#fffdf9}
body[data-theme=elegant] h1,body[data-theme=elegant] h2{font-weight:600}
body[data-theme=elegant] .g-alt{background:#f7f1e8}
body[data-theme=elegant] .g-card,body[data-theme=elegant] .g-serv,body[data-theme=elegant] .g-quote{box-shadow:none;border:1px solid #e7ddcd;background:#fffdf9}
body[data-theme=elegant] .g-eyebrow{font-style:italic;text-transform:none;letter-spacing:.04em}

/* FRESH (split) — clean, lichtblauw, outline-kaarten */
body[data-theme=fresh] .g-alt{background:#eef4fb}
body[data-theme=fresh][data-hero=split] .g-hero{background:#eef4fb}
body[data-theme=fresh] .g-card,body[data-theme=fresh] .g-serv,body[data-theme=fresh] .g-quote{box-shadow:none;border:1.5px solid #dbe6f3}

/* WARM (boxed) — sterk afgerond, perzik */
body[data-theme=warm]{background:#fffdfb}
body[data-theme=warm] .g-alt{background:#fff3ea}
body[data-theme=warm] .g-card,body[data-theme=warm] .g-serv,body[data-theme=warm] .g-quote{box-shadow:0 20px 44px -24px rgba(150,90,30,.4)}
body[data-theme=warm] .g-card-ix,body[data-theme=warm] .g-num{border-radius:50%}

/* MINIMAL (editorial) — wit, links, veel witruimte */
body[data-theme=minimal] .g-sec{padding:clamp(72px,10vw,140px) 0}
body[data-theme=minimal] .g-head{text-align:left;margin-left:0}
body[data-theme=minimal] .g-head h2::after{content:"";display:block;width:46px;height:3px;background:var(--acc);margin:16px 0 0;border-radius:2px}
body[data-theme=minimal] .g-card,body[data-theme=minimal] .g-serv,body[data-theme=minimal] .g-quote{box-shadow:none;border:1px solid #e6e7ee}

/* CLASSIC (editorial) — serif, warm-grijs, gecentreerd */
body[data-theme=classic]{background:#fbfaf7}
body[data-theme=classic] h1,body[data-theme=classic] h2{font-weight:600}
body[data-theme=classic] .g-hero-in{margin-inline:auto;text-align:center}
body[data-theme=classic] .g-alt{background:#f2efe9}
body[data-theme=classic] .g-card,body[data-theme=classic] .g-serv{border:1px solid #e6e1d6;box-shadow:none}

/* MONO (editorial) — zwart-wit, monospace, scherp */
body[data-theme=mono]{--acc:#15172b;--acc-d:#000;--acc-soft:#f2f2f5}
body[data-theme=mono] .g-head{text-align:left;margin-left:0}
body[data-theme=mono] .g-eyebrow{font-family:var(--head);letter-spacing:.18em}
body[data-theme=mono] .g-card,body[data-theme=mono] .g-serv,body[data-theme=mono] .g-quote{box-shadow:none;border:1px solid #1a1a1a}
body[data-theme=mono] .g-btn,body[data-theme=mono] .g-nav-cta{border-radius:0}

/* BANNER — sans bold, kleurband-hero */
body[data-theme=banner] h1,body[data-theme=banner] h2{letter-spacing:-.02em}
body[data-theme=banner] .g-card{border:1px solid #e7e8f0;box-shadow:none}

/* ===== component-variatie per thema ===== */
/* kaart-nummering (01/02/03) niet overal */
body[data-theme=elegant] .g-card-ix,body[data-theme=classic] .g-card-ix,body[data-theme=warm] .g-card-ix,body[data-theme=banner] .g-card-ix,body[data-theme=fresh] .g-card-ix{display:none}
/* stats-balk: vlakke rij (geen gekleurde band) bij lichte/serif-thema's */
body[data-theme=minimal] .g-stats,body[data-theme=mono] .g-stats,body[data-theme=classic] .g-stats,body[data-theme=elegant] .g-stats,body[data-theme=fresh] .g-stats{background:none;color:inherit;border-top:1px solid #e6e7ee;border-bottom:1px solid #e6e7ee;border-radius:0;margin-top:0;padding:44px 0}
body[data-theme=minimal] .g-stat-n,body[data-theme=mono] .g-stat-n,body[data-theme=classic] .g-stat-n,body[data-theme=elegant] .g-stat-n,body[data-theme=fresh] .g-stat-n{color:var(--acc)}
body[data-theme=minimal] .g-stat-l,body[data-theme=mono] .g-stat-l,body[data-theme=classic] .g-stat-l,body[data-theme=elegant] .g-stat-l,body[data-theme=fresh] .g-stat-l{color:#8a90a8}
body[data-theme=dark] .g-stats{background:#161b2b}

/* ===== persoonlijkheids-divergentie per thema (lay-out-DNA, niet enkel kleur) ===== */
/* koppen links bij stoere/redactionele thema's */
body[data-theme=bold] .g-head,body[data-theme=banner] .g-head,body[data-theme=fresh] .g-head{text-align:left;margin-left:0;max-width:780px}
body[data-theme=bold] .g-head h2::after{content:"";display:block;width:64px;height:5px;background:var(--acc);margin:18px 0 0}
/* knopvormen: scherp (bold/mono), zacht-hoekig (elegant/classic), rond (fresh), pil (rest) */
body[data-theme=bold] .g-btn,body[data-theme=bold] .g-nav-cta{border-radius:3px}
body[data-theme=elegant] .g-btn,body[data-theme=classic] .g-btn,body[data-theme=elegant] .g-nav-cta,body[data-theme=classic] .g-nav-cta{border-radius:6px;box-shadow:none;font-weight:600}
body[data-theme=fresh] .g-btn,body[data-theme=fresh] .g-nav-cta{border-radius:12px}
body[data-theme=minimal] .g-btn,body[data-theme=mono] .g-btn{box-shadow:none}
/* eyebrow-stijl per persoonlijkheid */
body[data-theme=classic] .g-eyebrow{font-variant:small-caps;text-transform:none;letter-spacing:.12em;font-weight:600}
body[data-theme=warm] .g-eyebrow{background:var(--acc-soft);padding:5px 14px;border-radius:999px}
body[data-theme=banner] .g-eyebrow,body[data-theme=bold] .g-eyebrow{letter-spacing:.2em}
/* vibrant: speelse onderlijn onder gecentreerde koppen */
body[data-theme=vibrant] .g-head h2::after{content:"";display:block;width:54px;height:4px;background:var(--acc);border-radius:3px;margin:14px auto 0}
/* strak/lucht: redactionele & serif-thema's krijgen meer witruimte, scherpe kaarten */
body[data-theme=elegant] .g-sec,body[data-theme=classic] .g-sec{padding:clamp(72px,9.5vw,132px) 0}
body[data-theme=minimal] .g-card,body[data-theme=mono] .g-card,body[data-theme=minimal] .g-serv,body[data-theme=mono] .g-serv{border-radius:0}
/* dark: subtiele gloed op de hoofdknop */
body[data-theme=dark] .g-btn{box-shadow:0 0 0 1px color-mix(in srgb,var(--acc) 45%,transparent),0 16px 44px -12px color-mix(in srgb,var(--acc) 65%,transparent)}

@media(max-width:980px){
  .g-cards,.g-quotes,.g-steps{grid-template-columns:1fr 1fr}
  .g-stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  body[data-nav=sidebar] .g-nav{position:sticky;width:auto;inset:auto;top:0;border-right:0;border-bottom:1px solid #ecedf3}
  body[data-nav=sidebar] .g-nav-in{flex-direction:row;height:64px;padding:0 22px;align-items:center;justify-content:space-between}
  body[data-nav=sidebar] main,body[data-nav=sidebar] .g-foot{margin-left:0}
  body[data-nav=center] .g-nav-in{flex-direction:row;height:64px;padding:0}
  .g-split-in{grid-template-columns:1fr;gap:32px}
  .g-split-left .g-split-media{order:0}
  .g-cards,.g-quotes,.g-steps{grid-template-columns:1fr}
  .g-bento{grid-template-columns:1fr 1fr;grid-auto-rows:170px}
  .g-tile:first-child,.g-tile:nth-child(6){grid-column:span 2;grid-row:auto}
  body[data-hero=split] .g-hero{grid-template-columns:1fr;min-height:auto}
  body[data-hero=split] .g-hero-media{min-height:230px}
  body[data-hero=overlay] .g-hero,body[data-hero=boxed] .g-hero{min-height:74vh}
  .g-burger{display:flex}
  .g-menu{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:#fff;flex-direction:column;align-items:flex-start;justify-content:center;gap:6px;padding:40px;transform:translateX(100%);transition:transform .3s;box-shadow:-20px 0 60px rgba(0,0,0,.2)}
  .g-menu.open{transform:none}
  .g-menu a,.g-nav:not(.scrolled) .g-menu a{color:#111521;text-shadow:none;font-size:18px;padding:8px 0}
  .g-nav-cta,.g-nav:not(.scrolled) .g-nav-cta{color:#fff!important}
}