/* ==========================================================================
   RENODEC  |  Design system
   Concept: de vloeropbouw als handtekening. Cool blue + technische datasheet.
   ========================================================================== */

:root {
  /* Cool blue palet */
  --rd-abyss:   #08202B;   /* diepste blauw, hero/donkere secties */
  --rd-deep:    #0C3043;   /* donker petrol */
  --rd-petrol:  #14506A;   /* merk-petrol (de teal blokken) */
  --rd-steel:   #2E7FA6;   /* mid blauw */
  --rd-azure:   #36A3D6;   /* fel accent blauw */
  --rd-sky:     #8FCDE9;   /* licht accent */

  /* Neutraal koel */
  --rd-ink:     #08202B;   /* tekst donker */
  --rd-slate:   #4A6573;   /* secundaire tekst */
  --rd-mist:    #7E97A3;   /* tertiair / labels op licht */
  --rd-line:    #DCE6EB;   /* hairlines op licht */
  --rd-ice:     #EEF4F7;   /* koele off-white achtergrond */
  --rd-paper:   #FFFFFF;

  /* Deals = merkgroen, uitsluitend hier */
  --rd-lime:    #94C21F;
  --rd-lime-dk: #739A12;

  /* Op donker */
  --rd-on-dark-1: #FFFFFF;
  --rd-on-dark-2: rgba(255,255,255,0.66);
  --rd-on-dark-3: rgba(255,255,255,0.40);
  --rd-on-dark-line: rgba(255,255,255,0.14);

  /* Typografie */
  --rd-display: "Bricolage Grotesque", "Inter", system-ui, sans-serif;
  --rd-body:    "Inter", system-ui, -apple-system, sans-serif;
  --rd-mono:    "IBM Plex Mono", ui-monospace, "SFMono-Regular", monospace;

  /* Maat */
  --rd-maxw: 1240px;
  --rd-gutter: clamp(20px, 5vw, 64px);
  --rd-radius: 14px;
  --rd-radius-sm: 8px;

  --rd-shadow: 0 1px 2px rgba(8,32,43,.04), 0 16px 40px -24px rgba(8,32,43,.28);
  --rd-shadow-lg: 0 30px 80px -40px rgba(8,32,43,.5);

  --rd-ease: cubic-bezier(.2,.7,.2,1);

  --rd-cart-ico: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.7 13.4a2 2 0 0 0 2 1.6h9.7a2 2 0 0 0 2-1.6L23 6H6'/%3E%3C/svg%3E");
}

/* ----------------------------------------------------- reset & base */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--rd-body);
  font-size: 17px;
  line-height: 1.65;
  color: var(--rd-ink);
  background: var(--rd-paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
h1,h2,h3,h4 { font-family: var(--rd-display); font-weight: 700; line-height: 1.04; letter-spacing: -.02em; margin: 0; }
p { margin: 0; }
ul { margin: 0; }

.rd-wrap { width: 100%; max-width: var(--rd-maxw); margin-inline: auto; padding-inline: var(--rd-gutter); }
.rd-eyebrow {
  font-family: var(--rd-mono);
  font-size: 12px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--rd-steel);
  display: inline-flex; align-items: center; gap: 10px; white-space: nowrap;
}
.rd-eyebrow svg { width: 15px; height: 15px; flex: 0 0 auto; }
.rd-eyebrow::before {
  content: ""; width: 22px; height: 2px; background: var(--rd-lime); display: inline-block; border-radius: 2px;
}
.on-dark .rd-eyebrow { color: var(--rd-sky); }

/* Ruler-tick hairline, terugkerend micro-motief */
.rd-ruler {
  height: 10px; width: 100%;
  background-image: repeating-linear-gradient(90deg, var(--rd-line) 0 1px, transparent 1px 16px);
  opacity: .9;
}
.on-dark .rd-ruler { background-image: repeating-linear-gradient(90deg, var(--rd-on-dark-line) 0 1px, transparent 1px 16px); }

/* a11y */
:focus-visible { outline: 3px solid var(--rd-azure); outline-offset: 2px; border-radius: 4px; }
.rd-skip {
  position: absolute; left: -9999px; top: 0; z-index: 999;
  background: var(--rd-ink); color: #fff; padding: 12px 18px; border-radius: 0 0 8px 0;
}
.rd-skip:focus { left: 0; }
.screen-reader-text {
  position: absolute !important; width: 1px; height: 1px; overflow: hidden;
  clip: rect(1px,1px,1px,1px); white-space: nowrap;
}

/* ----------------------------------------------------- buttons */
.rd-btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--rd-body); font-weight: 600; font-size: 15px;
  padding: 14px 24px; border-radius: 999px; border: 1.5px solid transparent;
  transition: transform .25s var(--rd-ease), background .25s var(--rd-ease), color .25s var(--rd-ease), border-color .25s var(--rd-ease);
  line-height: 1; white-space: nowrap;
}
.rd-btn svg { width: 16px; height: 16px; }
.rd-btn--primary { background: var(--rd-petrol); color: #fff; }
.rd-btn--primary:hover { background: var(--rd-azure); color: #fff; transform: translateY(-2px); }
.rd-btn--ghost { background: transparent; border-color: var(--rd-line); color: var(--rd-ink); }
.rd-btn--ghost:hover { border-color: var(--rd-petrol); transform: translateY(-2px); }
.rd-hero .rd-btn--ghost, .rd-cta-band .rd-btn--ghost, .on-dark .rd-btn--ghost { color: #fff; border-color: rgba(255,255,255,.35); }
.rd-hero .rd-btn--ghost:hover, .rd-cta-band .rd-btn--ghost:hover, .on-dark .rd-btn--ghost:hover { border-color: var(--rd-sky); }
.rd-btn--lime { background: var(--rd-lime-dk); color: #fff; }
.rd-btn--lime:hover { background: #5f810d; color: #fff; transform: translateY(-2px); }
.rd-btn--full { width: 100%; justify-content: center; }
.rd-link {
  font-family: var(--rd-mono); font-size: 13px; letter-spacing: .04em; font-weight: 500;
  color: var(--rd-steel); display: inline-flex; align-items: center; gap: 8px;
  border-bottom: 1px solid transparent; padding-bottom: 2px; transition: gap .2s var(--rd-ease), border-color .2s;
}
.rd-link:hover { gap: 12px; border-color: var(--rd-azure); }
.on-dark .rd-link { color: var(--rd-sky); }

/* ==========================================================================
   HEADER
   ========================================================================== */
.rd-header { position: sticky; top: 0; z-index: 200; background: var(--rd-paper); }

/* main bar */
.rd-bar { border-bottom: 1px solid var(--rd-line); }
.rd-bar .rd-wrap { display: flex; align-items: center; gap: 28px; min-height: 92px; }
.rd-brand { display: flex; align-items: center; flex: 0 0 auto; }
.rd-brand img, .rd-brand svg { height: 56px; width: auto; }   /* logo groter, opmerking klant */
.rd-brand .rd-logo-text { font-family: var(--rd-display); font-weight: 700; font-size: 30px; letter-spacing: -.03em; color: var(--rd-ink); }
.rd-brand .rd-logo-text b { color: var(--rd-azure); }

.rd-search { flex: 1 1 auto; max-width: 560px; position: relative; }
.rd-search input {
  width: 100%; height: 50px; border: 1.5px solid var(--rd-line); border-radius: 999px;
  padding: 0 20px 0 48px; font-family: var(--rd-body); font-size: 15px; color: var(--rd-ink);
  background: var(--rd-ice); transition: border-color .2s, background .2s;
}
.rd-search input:focus { outline: none; border-color: var(--rd-azure); background: #fff; }
.rd-search .rd-search-ico { position: absolute; left: 18px; top: 50%; transform: translateY(-50%); color: var(--rd-mist); width: 18px; height: 18px; }

.rd-actions { display: flex; align-items: center; gap: 6px; flex: 0 0 auto; margin-left: auto; }
.rd-action {
  display: inline-flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 8px 12px; border-radius: 12px; color: var(--rd-ink); font-size: 12px; font-weight: 500;
  transition: background .2s, color .2s;
}
.rd-action:hover { background: var(--rd-ice); color: var(--rd-petrol); }
.rd-action svg { width: 22px; height: 22px; }
.rd-action .rd-cart-wrap { position: relative; }
.rd-cart-count {
  position: absolute; top: -7px; right: -9px; background: var(--rd-azure); color: #042230;
  font-family: var(--rd-mono); font-size: 11px; font-weight: 600; min-width: 18px; height: 18px;
  border-radius: 999px; display: grid; place-items: center; padding: 0 4px;
}

/* nav row */
.rd-nav { border-bottom: 1px solid var(--rd-line); background: var(--rd-paper); }
.rd-nav .rd-wrap { display: flex; align-items: center; gap: 4px; }
.rd-menu { display: flex; align-items: center; gap: 2px; list-style: none; padding: 0; margin: 0; }
.rd-menu a {
  display: inline-flex; align-items: center; gap: 8px; padding: 16px 18px;
  font-weight: 500; font-size: 15px; color: var(--rd-slate); position: relative;
  transition: color .2s;
}
.rd-menu a:hover { color: var(--rd-ink); }
.rd-menu a::after {
  content: ""; position: absolute; left: 18px; right: 18px; bottom: 0; height: 3px;
  background: var(--rd-lime); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--rd-ease);
}
/* actief item oplicht, opmerking klant */
.rd-menu .current-menu-item > a,
.rd-menu .current-menu-ancestor > a,
.rd-menu a[aria-current="page"] { color: var(--rd-petrol); font-weight: 600; }
.rd-menu .current-menu-item > a::after,
.rd-menu .current-menu-ancestor > a::after,
.rd-menu a[aria-current="page"]::after { transform: scaleX(1); }
.rd-menu a:hover::after { transform: scaleX(1); }
/* eerste menu-item links uitlijnen met het logo */
.rd-nav .rd-menu > li:first-child > a { padding-left: 0; }
.rd-nav .rd-menu > li:first-child > a::after { left: 0; }
.rd-nav-cta { margin-left: auto; }
.rd-tag-kennis {
  font-family: var(--rd-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase;
  background: var(--rd-ice); color: var(--rd-steel); padding: 2px 7px; border-radius: 5px;
}

/* burger */
.rd-burger { display: none; margin-left: auto; width: 46px; height: 46px; border: 1.5px solid var(--rd-line); border-radius: 12px; background: #fff; align-items: center; justify-content: center; }
.rd-burger span, .rd-burger span::before, .rd-burger span::after { content: ""; display: block; width: 20px; height: 2px; background: var(--rd-ink); position: relative; transition: transform .25s var(--rd-ease), opacity .2s; }
.rd-burger span::before { position: absolute; top: -6px; } .rd-burger span::after { position: absolute; top: 6px; }
body.rd-menu-open .rd-burger span { background: transparent; }
body.rd-menu-open .rd-burger span::before { transform: translateY(6px) rotate(45deg); }
body.rd-menu-open .rd-burger span::after { transform: translateY(-6px) rotate(-45deg); }

/* ==========================================================================
   USP BAR (opmerking klant)
   ========================================================================== */
.rd-usp { background: var(--rd-petrol); color: #fff; overflow: hidden; border-bottom: 1px solid rgba(255,255,255,.08); }
.rd-usp .rd-usp-track { display: flex; align-items: center; gap: 0; }
.rd-usp ul { display: flex; align-items: center; gap: 0; list-style: none; padding: 0; margin: 0; }
.rd-usp li {
  flex: 0 0 auto; display: inline-flex; align-items: center; gap: 9px; padding: 11px 26px;
  font-family: var(--rd-mono); font-size: 12.5px; letter-spacing: .01em; color: rgba(255,255,255,.9);
  position: relative;
}
.rd-usp li:first-child { padding-left: 0; }
.rd-usp li + li { border-left: 1px solid rgba(255,255,255,.18); }
.rd-usp li svg { width: 15px; height: 15px; color: var(--rd-lime); flex: 0 0 auto; }
@media (max-width: 860px) {
  .rd-usp ul { animation: rd-marquee 18s linear infinite; width: max-content; flex: 0 0 auto; }
  .rd-usp li { flex: 0 0 auto; padding: 10px 22px; }
  .rd-usp li:first-child { padding-left: 22px; }
  .rd-usp li + li { border-left: none; }
  .rd-usp:hover ul { animation-play-state: paused; }
}
@keyframes rd-marquee { to { transform: translateX(-50%); } }

/* ==========================================================================
   HERO  |  signature: de vloeropbouw
   ========================================================================== */
.rd-hero {
  position: relative; color: #fff; overflow: hidden;
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(54,163,214,.30), transparent 55%),
    linear-gradient(160deg, var(--rd-deep) 0%, var(--rd-abyss) 70%);
}
.rd-hero::before { /* fijne blueprint grid */
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .5;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(110% 100% at 30% 30%, #000 40%, transparent 90%);
}
.rd-hero .rd-wrap { position: relative; z-index: 2; padding-block: clamp(64px, 9vw, 120px); }
.rd-hero-copy { max-width: 620px; }
.rd-hero h1 { font-size: clamp(40px, 5.6vw, 70px); margin: 22px 0 0; }
.rd-hero h1 em { font-style: normal; color: var(--rd-sky); }
.rd-hero p { color: var(--rd-on-dark-2); font-size: clamp(16px, 1.4vw, 19px); margin: 22px 0 0; max-width: 50ch; }
.rd-hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.rd-hero-meta { position: relative; display: flex; flex-wrap: wrap; gap: 30px 44px; margin-top: 46px; padding-top: 26px; border-top: 1px solid var(--rd-on-dark-line); }
.rd-hero-meta::before { content: ""; position: absolute; top: -1px; left: 0; width: 46px; height: 2px; background: var(--rd-lime); border-radius: 2px; }
.rd-hero-meta div span { display: block; }
.rd-hero-meta .m-num { font-family: var(--rd-display); font-size: 26px; font-weight: 700; color: #fff; }
.rd-hero-meta .m-lab { font-family: var(--rd-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--rd-on-dark-3); margin-top: 3px; }

/* Hero met achtergrondafbeelding */
.rd-hero-bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center; }
.rd-hero--image::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(105deg, rgba(8,32,43,.94) 0%, rgba(8,32,43,.82) 38%, rgba(8,32,43,.42) 72%, rgba(8,32,43,.30) 100%),
    linear-gradient(0deg, rgba(8,32,43,.55), transparent 45%);
}
.rd-hero--image::before { opacity: .22; z-index: 1; }
.rd-hero--image .rd-hero-meta { border-top-color: rgba(255,255,255,.22); }

@media (prefers-reduced-motion: reduce) {
  .rd-usp ul { animation: none; }
}

/* ==========================================================================
   SECTIES
   ========================================================================== */
.rd-section { padding-block: clamp(64px, 8vw, 112px); }
.rd-section.on-dark { background: var(--rd-abyss); color: #fff; }
.rd-section.bg-ice { background: var(--rd-ice); }
.rd-section.bg-petrol { background: var(--rd-petrol); color: #fff; }
.on-dark h2, .bg-petrol h2 { color: #fff; }
.rd-sec-head { max-width: 640px; margin-bottom: 48px; }
.rd-sec-head h2 { font-size: clamp(28px, 3.6vw, 44px); margin-top: 16px; }
.rd-sec-head p { color: var(--rd-slate); margin-top: 16px; font-size: 18px; }
.on-dark .rd-sec-head p, .bg-petrol .rd-sec-head p { color: var(--rd-on-dark-2); }
.rd-sec-head--row { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; max-width: none; }

/* ---- DEALS (groen, opmerking klant) ---- */
.rd-deals { display: grid; grid-template-columns: 1.15fr 1fr; gap: 22px; }
.rd-deal {
  position: relative; border-radius: var(--rd-radius); overflow: hidden;
  background: var(--rd-lime); color: #1d2b04; padding: 34px; display: flex; flex-direction: column; justify-content: space-between; min-height: 260px;
}
.rd-deal--alt { background: linear-gradient(150deg, var(--rd-petrol), var(--rd-deep)); color: #fff; }
.rd-deal-flag {
  align-self: flex-start; font-family: var(--rd-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
  background: #1d2b04; color: var(--rd-lime); padding: 5px 11px; border-radius: 6px; font-weight: 600;
}
.rd-deal--alt .rd-deal-flag { background: rgba(255,255,255,.12); color: var(--rd-sky); }
.rd-deal h3 { font-size: clamp(22px, 2.4vw, 30px); margin-top: 18px; max-width: 14ch; }
.rd-deal p { margin-top: 10px; font-size: 15px; opacity: .85; max-width: 38ch; }
.rd-deal-foot { display: flex; align-items: center; gap: 16px; margin-top: 24px; }
.rd-deal-price { font-family: var(--rd-display); font-weight: 700; font-size: 24px; }
.rd-deal-price s { font-family: var(--rd-mono); font-size: 14px; font-weight: 400; opacity: .55; margin-right: 8px; }
.rd-deal-art { position: absolute; right: -24px; bottom: -24px; width: 150px; height: 150px; opacity: .25; }

/* ---- PRODUCTKAARTEN (spec-sheet) ---- */
.rd-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.rd-card {
  position: relative; background: var(--rd-paper); border: 1px solid var(--rd-line); border-radius: var(--rd-radius);
  overflow: hidden; display: flex; flex-direction: column; transition: transform .3s var(--rd-ease), box-shadow .3s var(--rd-ease), border-color .3s;
}
.rd-card:hover { transform: translateY(-4px); box-shadow: var(--rd-shadow); border-color: var(--rd-lime); }
.rd-card-media { position: relative; aspect-ratio: 4/3; background: var(--rd-ice); overflow: hidden; }
.rd-card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--rd-ease); }
.rd-card:hover .rd-card-media img { transform: scale(1.04); }
.rd-card-media .rd-card-ph { position: absolute; inset: 0; display: grid; place-items: center; color: var(--rd-mist); }
.rd-card-code {
  position: absolute; top: 12px; left: 12px; font-family: var(--rd-mono); font-size: 11px; letter-spacing: .05em;
  background: rgba(8,32,43,.85); color: #fff; padding: 4px 9px; border-radius: 6px;
}
.rd-card-body { padding: 18px 18px 20px; display: flex; flex-direction: column; flex: 1; }
.rd-card-body h3 { font-size: 19px; }
.rd-card-specs { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.rd-card-spec {
  font-family: var(--rd-mono); font-size: 11px; color: var(--rd-steel);
  background: var(--rd-ice); border: 1px solid var(--rd-line); padding: 3px 8px; border-radius: 999px;
}
.rd-card-foot { display: flex; align-items: baseline; gap: 8px; margin-top: auto; padding-top: 18px; }
.rd-card-price { font-family: var(--rd-display); font-weight: 700; font-size: 21px; color: var(--rd-ink); }
.rd-card-price .woocommerce-Price-amount { font-family: var(--rd-display); }
.rd-card-price del { color: var(--rd-mist); font-weight: 400; font-size: 15px; margin-right: 4px; }
.rd-card-price ins { text-decoration: none; }
.rd-card-price .u { font-family: var(--rd-mono); font-size: 12px; font-weight: 400; color: var(--rd-mist); }

/* Full-width 'In winkelwagen' knop in de kaart (boven de onzichtbare kaart-link) */
.rd-card-buy { position: relative; z-index: 2; margin-top: 14px; }
.rd-card-buy .button,
.rd-card-buy .added_to_cart {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; box-sizing: border-box; text-align: center;
  font-family: var(--rd-display); font-weight: 600; font-size: 15px; line-height: 1;
  padding: 13px 16px; border-radius: 12px; border: 1.5px solid var(--rd-petrol);
  background: var(--rd-petrol); color: #fff; cursor: pointer;
  transition: background .2s var(--rd-ease), border-color .2s, transform .15s, color .2s;
}
.rd-card-buy .button::before {
  content: ""; width: 17px; height: 17px; flex: none;
  background: currentColor; -webkit-mask: var(--rd-cart-ico) center/contain no-repeat; mask: var(--rd-cart-ico) center/contain no-repeat;
}
.rd-card-buy .button:hover { background: var(--rd-azure); border-color: var(--rd-azure); color: #fff; transform: translateY(-2px); }
.rd-card-buy .button.loading { opacity: .7; }
.rd-card-buy .added_to_cart { margin-top: 8px; background: #fff; color: var(--rd-petrol); }
.rd-card-buy .added_to_cart:hover { background: var(--rd-ice); }
.rd-card-buy .button.added::before { display: none; }
.rd-card a.rd-card-link { position: absolute; inset: 0; z-index: 1; }

/* Homepage-kaart (renodec_render_product_card) hergebruikt dezelfde stijl */
.rd-card .rd-card-add {
  position: relative; z-index: 2; display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; margin-top: 14px; box-sizing: border-box;
  font-family: var(--rd-display); font-weight: 600; font-size: 15px;
  padding: 13px 16px; border-radius: 12px; border: 1.5px solid var(--rd-petrol);
  background: var(--rd-petrol); color: #fff; transition: background .2s, color .2s, border-color .2s, transform .15s;
}
.rd-card .rd-card-add:hover { background: var(--rd-azure); border-color: var(--rd-azure); color: #fff; transform: translateY(-2px); }
.rd-card .rd-card-add svg { width: 17px; height: 17px; }

/* ---- WAAROM / minerale wol (opmerking klant) ---- */
.rd-why { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(32px,5vw,64px); align-items: center; }
.rd-why-visual { position: relative; border-radius: var(--rd-radius); overflow: hidden; aspect-ratio: 4/5; background: var(--rd-deep); }
.rd-why-list { list-style: none; padding: 0; margin: 24px 0 0; }
.rd-why-list li { position: relative; padding: 18px 0 18px 40px; border-top: 1px solid var(--rd-on-dark-line); }
.rd-why-list li:first-child { border-top: none; }
.rd-why-list li strong { display: block; font-family: var(--rd-display); font-weight: 700; font-size: 18px; color: #fff; margin-bottom: 4px; }
.rd-why-list li span { color: var(--rd-on-dark-2); font-size: 15px; }
.rd-why-list li::before {
  content: ""; position: absolute; left: 0; top: 22px; width: 22px; height: 22px; border-radius: 6px;
  background: rgba(148,194,31,.16); border: 1px solid rgba(148,194,31,.5);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394C21F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center; background-size: 13px;
}

/* ---- HOE HET WERKT (3 stappen, echte sequentie) ---- */
.rd-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 4px; counter-reset: step; border: 1px solid var(--rd-line); border-radius: var(--rd-radius); overflow: hidden; background: var(--rd-line); }
.rd-step { background: var(--rd-paper); padding: 32px 30px 36px; position: relative; }
.rd-step-n { font-family: var(--rd-mono); font-size: 13px; color: var(--rd-azure); font-weight: 600; letter-spacing: .1em; }
.rd-step-bar { height: 4px; width: 100%; background: var(--rd-line); margin: 16px 0 22px; border-radius: 2px; overflow: hidden; }
.rd-step-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--rd-lime-dk), var(--rd-lime)); width: 33.33%; }
.rd-step:nth-child(2) .rd-step-bar i { width: 66.66%; }
.rd-step:nth-child(3) .rd-step-bar i { width: 100%; }
.rd-step h3 { font-size: 21px; }
.rd-step p { color: var(--rd-slate); font-size: 15px; margin-top: 10px; }
.rd-step-tag { display: inline-flex; align-items: center; gap: 7px; margin-top: 16px; font-family: var(--rd-mono); font-size: 12px; color: var(--rd-steel); border: 1px solid var(--rd-line); border-radius: 999px; padding: 5px 12px; }
.rd-step-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--rd-lime); }

/* ---- USP trio ---- */
.rd-trio { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.rd-trio-item { padding-top: 22px; border-top: 2px solid var(--rd-ink); }
.on-dark .rd-trio-item { border-color: var(--rd-azure); }
.rd-trio-item .t-ico { width: 30px; height: 30px; color: var(--rd-lime-dk); margin-bottom: 14px; }
.on-dark .rd-trio-item .t-ico { color: var(--rd-lime); }
.rd-trio-item h3 { font-size: 19px; }
.rd-trio-item p { color: var(--rd-slate); font-size: 15px; margin-top: 8px; }
.on-dark .rd-trio-item p { color: var(--rd-on-dark-2); }

/* ---- FAQ ---- */
.rd-faq { max-width: 820px; }
.rd-faq-item { border-top: 1px solid var(--rd-line); }
.rd-faq-item:last-child { border-bottom: 1px solid var(--rd-line); }
.rd-faq-q {
  width: 100%; background: none; border: 0; text-align: left; padding: 22px 0; display: flex; align-items: center;
  justify-content: space-between; gap: 20px; font-family: var(--rd-display); font-weight: 700; font-size: 19px; color: var(--rd-ink);
}
.rd-faq-q .rd-faq-ico { flex: 0 0 auto; width: 26px; height: 26px; border-radius: 8px; border: 1.5px solid var(--rd-line); display: grid; place-items: center; transition: background .2s, border-color .2s, transform .3s; position: relative; }
.rd-faq-q .rd-faq-ico::before, .rd-faq-q .rd-faq-ico::after { content: ""; position: absolute; background: var(--rd-petrol); border-radius: 2px; }
.rd-faq-q .rd-faq-ico::before { width: 12px; height: 2px; }
.rd-faq-q .rd-faq-ico::after { width: 2px; height: 12px; transition: transform .3s var(--rd-ease); }
.rd-faq-item[open] .rd-faq-ico { background: var(--rd-azure); border-color: var(--rd-azure); }
.rd-faq-item[open] .rd-faq-ico::before, .rd-faq-item[open] .rd-faq-ico::after { background: #042230; }
.rd-faq-item[open] .rd-faq-ico::after { transform: rotate(90deg); }
.rd-faq-a { padding: 0 0 24px; color: var(--rd-slate); font-size: 16px; max-width: 70ch; }
.rd-faq-q::-webkit-details-marker { display: none; }

/* ---- CTA band ---- */
.rd-cta-band { position: relative; overflow: hidden; background: linear-gradient(150deg, var(--rd-petrol), var(--rd-abyss)); color: #fff; border-radius: var(--rd-radius); padding: clamp(40px,6vw,72px); }
.rd-cta-band::after { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 40px 40px; opacity: .6; pointer-events: none; }
.rd-cta-band .rd-cta-inner { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.rd-cta-band h2 { font-size: clamp(26px,3.4vw,40px); max-width: 16ch; }
.rd-cta-band p { color: var(--rd-on-dark-2); margin-top: 12px; max-width: 40ch; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.rd-footer { background: var(--rd-abyss); color: var(--rd-on-dark-2); padding-block: 64px 0; }
.rd-footer .rd-ftr-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 40px; }
.rd-footer h4 { font-family: var(--rd-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--rd-sky); margin-bottom: 18px; font-weight: 500; }
.rd-footer .rd-ftr-brand .rd-logo-text { font-family: var(--rd-display); font-size: 26px; color: #fff; }
.rd-footer .rd-ftr-brand img { height: 44px; margin-bottom: 18px; }
.rd-footer .rd-ftr-brand p { max-width: 38ch; font-size: 15px; }
.rd-footer ul { list-style: none; padding: 0; }
.rd-footer li { margin-bottom: 11px; }
.rd-footer a { font-size: 15px; transition: color .2s; display: inline-flex; align-items: center; gap: 9px; }
.rd-footer a:hover { color: #fff; }
.rd-footer a svg { width: 16px; height: 16px; color: var(--rd-steel); flex: 0 0 auto; }
.rd-ftr-bottom { margin-top: 56px; border-top: 1px solid var(--rd-on-dark-line); padding-block: 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-family: var(--rd-mono); font-size: 12px; color: var(--rd-on-dark-3); letter-spacing: .02em; }
.rd-ftr-bottom .rd-ruler { width: 120px; }

/* ==========================================================================
   WOOCOMMERCE  |  archive + single, in stijl gebracht
   ========================================================================== */
.rd-shop-hero { background: var(--rd-abyss); color: #fff; padding-block: clamp(48px,6vw,80px); position: relative; overflow: hidden; }
.rd-shop-hero::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px); background-size: 44px 44px; mask-image: radial-gradient(100% 100% at 80% 0,#000,transparent 80%); }
.rd-shop-hero h1 { font-size: clamp(32px,4.4vw,52px); position: relative; }
.rd-shop-hero p { color: var(--rd-on-dark-2); margin-top: 14px; max-width: 56ch; position: relative; }

.woocommerce-page .rd-shop-main { padding-block: clamp(40px,5vw,72px); }
.woocommerce .rd-shop-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; margin-bottom: 28px; }
.woocommerce .woocommerce-result-count { font-family: var(--rd-mono); font-size: 13px; color: var(--rd-mist); margin: 0; }
.woocommerce .woocommerce-ordering select { font-family: var(--rd-body); border: 1.5px solid var(--rd-line); border-radius: 999px; padding: 10px 18px; background: #fff; color: var(--rd-ink); font-size: 14px; }

/* loop grid via onze cards (content-product) */
.woocommerce ul.products { display: grid !important; grid-template-columns: repeat(4,1fr); gap: 20px; margin: 0 !important; padding: 0 !important; list-style: none; }
.woocommerce ul.products::before, .woocommerce ul.products::after { content: none !important; }
.woocommerce ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; }

/* single product */
.single-product .rd-shop-main { padding-block: clamp(36px,4vw,64px); }
.single-product div.product { display: grid; grid-template-columns: minmax(0, 460px) minmax(0, 1fr); column-gap: clamp(28px,4vw,56px); row-gap: clamp(40px,5vw,72px); align-items: start; }
.single-product div.product > .woocommerce-product-gallery { grid-column: 1; float: none !important; margin: 0 !important; width: 100% !important; }
.single-product div.product > .summary { grid-column: 2; float: none !important; margin: 0 !important; width: auto !important; }
.single-product div.product > .woocommerce-tabs,
.single-product div.product > .woocommerce-product-gallery + .summary + .woocommerce-tabs,
.single-product div.product > .related,
.single-product div.product > .upsells { grid-column: 1 / -1; }
.single-product div.product .woocommerce-product-gallery__wrapper { margin: 0; }
.single-product div.product .woocommerce-product-gallery__image { width: 100%; }
.single-product div.product .woocommerce-product-gallery__image a { display: block; }
.single-product div.product .woocommerce-product-gallery__image img { width: 100%; height: auto; display: block; border-radius: var(--rd-radius); border: 1px solid var(--rd-line); }
.single-product .product_title { font-family: var(--rd-display); font-size: clamp(28px,3.4vw,42px); letter-spacing: -.02em; }
.single-product .woocommerce-breadcrumb { font-family: var(--rd-mono); font-size: 12px; color: var(--rd-mist); margin-bottom: 22px; letter-spacing: .03em; }
.single-product .woocommerce-breadcrumb a { color: var(--rd-steel); }
.single-product p.price, .single-product span.price { font-family: var(--rd-display) !important; font-weight: 700; color: var(--rd-ink) !important; font-size: 28px !important; }
.single-product .price ins { text-decoration: none; }
.single-product .price del { color: var(--rd-mist); font-size: 18px; }
.woocommerce div.product form.cart { margin-top: 22px; }
.woocommerce .quantity input.qty { border: 1.5px solid var(--rd-line); border-radius: 10px; height: 50px; width: 84px; text-align: center; font-family: var(--rd-mono); }

/* knoppen woo overschrijven naar onze stijl */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce a.button.alt, .woocommerce button.button.alt {
  background: var(--rd-petrol) !important; color: #fff !important; border-radius: 999px !important;
  font-family: var(--rd-body) !important; font-weight: 600 !important; padding: 14px 26px !important;
  border: none !important; transition: background .2s, transform .2s !important; text-shadow: none !important;
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover { background: var(--rd-azure) !important; color: #fff !important; transform: translateY(-2px); }
.woocommerce .single_add_to_cart_button { font-size: 16px !important; }

/* tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs { padding: 0 !important; border-bottom: 1px solid var(--rd-line); display: flex; gap: 6px; }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: none !important; border: none !important; border-radius: 0 !important; padding: 0; margin: 0 !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li::before, .woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { font-family: var(--rd-mono) !important; font-size: 13px; letter-spacing: .04em; color: var(--rd-mist) !important; padding: 14px 16px !important; border-bottom: 3px solid transparent; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--rd-petrol) !important; border-color: var(--rd-azure); }

/* notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error { border-top-color: var(--rd-azure) !important; border-radius: var(--rd-radius-sm); font-family: var(--rd-body); }
.woocommerce-message::before, .woocommerce-info::before { color: var(--rd-azure) !important; }

/* cart / checkout lichte opfris */
.woocommerce table.shop_table { border-radius: var(--rd-radius); border-color: var(--rd-line); }
.woocommerce-cart .rd-shop-main, .woocommerce-checkout .rd-shop-main, .woocommerce-account .rd-shop-main { padding-block: clamp(40px,5vw,72px); }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .select2-container .select2-selection { border: 1.5px solid var(--rd-line) !important; border-radius: 10px !important; }

/* paginatie */
.woocommerce nav.woocommerce-pagination ul { border: none !important; gap: 6px; display: flex; justify-content: center; }
.woocommerce nav.woocommerce-pagination ul li { border: none !important; }
.woocommerce nav.woocommerce-pagination ul li a, .woocommerce nav.woocommerce-pagination ul li span {
  border: 1.5px solid var(--rd-line) !important; border-radius: 10px; min-width: 44px; height: 44px; display: grid; place-items: center; font-family: var(--rd-mono); font-size: 14px;
}
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--rd-petrol) !important; color: #fff !important; border-color: var(--rd-petrol) !important; }

/* ==========================================================================
   GENERIEKE PAGINA (page.php)
   ========================================================================== */
.rd-page-hero { background: var(--rd-abyss); color: #fff; padding-block: clamp(56px,7vw,96px); position: relative; overflow: hidden; }
.rd-page-hero::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px); background-size: 44px 44px; mask-image: radial-gradient(100% 100% at 75% 10%,#000,transparent 80%); }
.rd-page-hero h1 { font-size: clamp(34px,4.6vw,56px); position: relative; }
.rd-page-body { padding-block: clamp(48px,6vw,80px); }
.rd-page-body .rd-prose { max-width: 760px; }
.rd-prose h2 { font-size: 28px; margin: 38px 0 14px; }
.rd-prose h3 { font-size: 21px; margin: 28px 0 10px; }
.rd-prose p { margin-bottom: 18px; color: var(--rd-slate); }
.rd-prose a { color: var(--rd-steel); border-bottom: 1px solid var(--rd-line); }
.rd-prose ul, .rd-prose ol { padding-left: 20px; margin-bottom: 18px; color: var(--rd-slate); }
.rd-prose li { margin-bottom: 8px; }
.rd-prose img { border-radius: var(--rd-radius); margin: 24px 0; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1080px) {
  .rd-grid, .woocommerce ul.products { grid-template-columns: repeat(3,1fr) !important; }
}
@media (max-width: 960px) {
  .rd-why { grid-template-columns: 1fr; }
  .rd-deals { grid-template-columns: 1fr; }
  .single-product div.product { grid-template-columns: 1fr; }
  .rd-footer .rd-ftr-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 840px) {
  .rd-bar .rd-wrap { flex-wrap: wrap; min-height: 0; padding-block: 16px; gap: 16px; }
  .rd-search { order: 3; flex-basis: 100%; max-width: none; }
  .rd-nav { display: none; position: fixed; inset: 132px 0 0; background: #fff; z-index: 190; padding: 12px var(--rd-gutter); overflow-y: auto; border-top: 1px solid var(--rd-line); }
  body.rd-menu-open .rd-nav { display: block; }
  .rd-nav .rd-wrap { flex-direction: column; align-items: stretch; padding: 0; }
  .rd-menu { flex-direction: column; align-items: stretch; }
  .rd-menu a { padding: 16px 4px; border-bottom: 1px solid var(--rd-line); }
  .rd-menu a::after { display: none; }
  .rd-nav-cta { margin: 16px 0; }
  .rd-burger { display: flex; }
}
@media (max-width: 720px) {
  .rd-grid, .woocommerce ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 14px; }
  .rd-steps { grid-template-columns: 1fr; }
  .rd-trio { grid-template-columns: 1fr; gap: 18px; }
  .rd-hero-meta { gap: 22px; }
  .rd-cta-band .rd-cta-inner { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
  body { font-size: 16px; }
  .rd-grid, .woocommerce ul.products { grid-template-columns: 1fr 1fr !important; }
  .rd-footer .rd-ftr-grid { grid-template-columns: 1fr; }
  .rd-actions .rd-action span { display: none; }
}

/* ==========================================================================
   MOTION  |  scroll reveal + header schaduw (aangestuurd door main.js)
   ========================================================================== */
[data-reveal] { opacity: 0; transform: translateY(20px); transition: opacity .7s var(--rd-ease), transform .7s var(--rd-ease); }
[data-reveal].is-in { opacity: 1; transform: none; }
[data-reveal][data-reveal-delay="1"] { transition-delay: .08s; }
[data-reveal][data-reveal-delay="2"] { transition-delay: .16s; }
[data-reveal][data-reveal-delay="3"] { transition-delay: .24s; }
[data-reveal][data-reveal-delay="4"] { transition-delay: .32s; }

.rd-header.is-scrolled { box-shadow: 0 10px 30px -18px rgba(8,32,43,.35); }

@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* ==========================================================================
   PAGINA'S, BERICHTEN, KENNISBANK, ZOEKEN & 404
   ========================================================================== */
.rd-wrap--narrow { max-width: 820px; }

/* Archief / zoek koppen */
.rd-page-head { padding: clamp(40px,5vw,72px) 0 0; }
.rd-page-head h1 { font-size: clamp(32px,4.4vw,52px); margin-top: 14px; }
.rd-page-head h1 span { color: var(--rd-steel); }
.rd-page-intro { color: var(--rd-slate); font-size: 18px; max-width: 60ch; margin-top: 14px; }

/* Berichten-grid (Kennisbank-overzicht) */
.rd-posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 40px; }
.rd-post-card { background: var(--rd-paper); border: 1px solid var(--rd-line); border-radius: var(--rd-radius); overflow: hidden; display: flex; flex-direction: column; transition: transform .3s var(--rd-ease), box-shadow .3s var(--rd-ease); }
.rd-post-card:hover { transform: translateY(-4px); box-shadow: var(--rd-shadow); }
.rd-post-thumb { display: block; aspect-ratio: 16/10; overflow: hidden; }
.rd-post-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--rd-ease); }
.rd-post-card:hover .rd-post-thumb img { transform: scale(1.04); }
.rd-post-body { padding: 22px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.rd-post-meta { font-family: var(--rd-mono); font-size: 12px; color: var(--rd-mist); letter-spacing: .03em; }
.rd-post-body h2 { font-size: 21px; line-height: 1.25; }
.rd-post-body h2 a { color: var(--rd-ink); }
.rd-post-body h2 a:hover { color: var(--rd-steel); }
.rd-post-excerpt { color: var(--rd-slate); font-size: 15px; flex: 1; }

/* Generieke tekstlink met pijl */
.rd-link { display: inline-flex; align-items: center; gap: 7px; font-family: var(--rd-mono); font-size: 13px; font-weight: 600; letter-spacing: .03em; color: var(--rd-steel); border: none; }
.rd-link svg { width: 15px; height: 15px; transition: transform .2s var(--rd-ease); }
.rd-link:hover svg { transform: translateX(4px); }

/* Paginering */
.rd-pagination { margin-top: 48px; }
.rd-pagination .nav-links { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.rd-pagination a, .rd-pagination .page-numbers { display: inline-grid; place-items: center; min-width: 44px; height: 44px; padding: 0 12px; border: 1px solid var(--rd-line); border-radius: 10px; font-family: var(--rd-mono); font-size: 14px; color: var(--rd-ink); transition: background .2s, border-color .2s, color .2s; }
.rd-pagination a:hover { border-color: var(--rd-azure); color: var(--rd-steel); }
.rd-pagination .page-numbers.current { background: var(--rd-petrol); border-color: var(--rd-petrol); color: #fff; }

/* Enkele pagina / bericht */
.rd-single { padding-bottom: clamp(56px,7vw,96px); }
.rd-single-head { padding: clamp(48px,6vw,88px) 0 clamp(28px,3vw,40px); }
.rd-single-head h1 { font-size: clamp(34px,4.8vw,56px); margin-top: 14px; }
.rd-single-meta { display: inline-block; margin-top: 16px; font-family: var(--rd-mono); font-size: 13px; color: var(--rd-mist); }
.rd-single-hero { margin-bottom: clamp(32px,4vw,56px); }
.rd-single-hero img { width: 100%; height: auto; border-radius: var(--rd-radius); display: block; }
.rd-post-nav { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 16px; margin-top: 56px; padding-top: 28px; border-top: 1px solid var(--rd-line); }
.rd-post-nav a { font-family: var(--rd-mono); font-size: 13px; color: var(--rd-steel); }
.rd-post-nav-next { margin-left: auto; text-align: right; }

/* Zoekformulier (searchform.php — buiten de header) */
.rd-searchform { position: relative; display: flex; align-items: center; max-width: 520px; }
.rd-searchform .rd-search-ico { position: absolute; left: 18px; top: 50%; transform: translateY(-50%); color: var(--rd-mist); width: 18px; height: 18px; pointer-events: none; }
.rd-searchform .rd-search-field { width: 100%; height: 54px; border: 1.5px solid var(--rd-line); border-radius: 999px; padding: 0 120px 0 48px; font-family: var(--rd-body); font-size: 16px; color: var(--rd-ink); }
.rd-searchform .rd-search-field:focus { outline: none; border-color: var(--rd-azure); }
.rd-searchform .rd-search-submit { position: absolute; right: 6px; top: 6px; bottom: 6px; padding: 0 22px; border: none; border-radius: 999px; background: var(--rd-petrol); color: #fff; font-family: var(--rd-display); font-weight: 600; font-size: 14px; cursor: pointer; transition: background .2s; }
.rd-searchform .rd-search-submit:hover { background: var(--rd-azure); color: #042230; }

/* 404 */
.rd-404 { text-align: left; }
.rd-404-inner { padding-block: clamp(56px,8vw,120px); }
.rd-404-code { font-family: var(--rd-mono); font-size: clamp(64px,12vw,140px); font-weight: 600; line-height: 1; color: var(--rd-ice); display: block; letter-spacing: -.04em; }
.rd-404 h1 { font-size: clamp(28px,4vw,46px); margin-top: 8px; }
.rd-404-search { margin: 28px 0 32px; }
.rd-404-actions { display: flex; flex-wrap: wrap; gap: 14px; }

@media (max-width: 960px) {
  .rd-posts { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .rd-posts { grid-template-columns: 1fr; }
  .rd-searchform .rd-search-field { padding-right: 48px; }
  .rd-searchform .rd-search-submit { display: none; }
}

/* ==========================================================================
   CONTACT-PAGINA
   ========================================================================== */
.rd-contact { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,56px); align-items: start; }
.rd-contact-info { display: flex; flex-direction: column; gap: 14px; }
.rd-contact-row {
  display: flex; align-items: center; gap: 18px; padding: 22px 24px;
  border: 1px solid var(--rd-line); border-radius: var(--rd-radius); background: var(--rd-paper);
  transition: border-color .2s var(--rd-ease), transform .2s var(--rd-ease), box-shadow .2s;
}
.rd-contact-row:hover { border-color: var(--rd-sky); transform: translateY(-3px); box-shadow: var(--rd-shadow); }
.rd-contact-ico { flex: none; width: 48px; height: 48px; border-radius: 12px; background: rgba(148,194,31,.14); display: grid; place-items: center; color: var(--rd-lime-dk); }
.rd-contact-ico svg { width: 22px; height: 22px; }
.rd-contact-lab { display: block; font-family: var(--rd-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--rd-mist); }
.rd-contact-val { display: block; font-family: var(--rd-display); font-weight: 700; font-size: 20px; color: var(--rd-ink); margin-top: 3px; }
.rd-contact-aside { background: var(--rd-ice); border: 1px solid var(--rd-line); border-radius: var(--rd-radius); padding: clamp(26px,3vw,38px); }
.rd-contact-aside h2 { font-size: clamp(24px,2.6vw,30px); margin-top: 10px; }
.rd-contact-steps { list-style: none; counter-reset: step; padding: 0; margin: 22px 0 0; }
.rd-contact-steps li { position: relative; padding: 14px 0 14px 44px; border-top: 1px solid var(--rd-line); color: var(--rd-slate); font-size: 15px; }
.rd-contact-steps li:first-child { border-top: none; }
.rd-contact-steps li strong { display: block; color: var(--rd-ink); font-family: var(--rd-display); }
.rd-contact-steps li::before {
  counter-increment: step; content: counter(step,decimal-leading-zero);
  position: absolute; left: 0; top: 14px; font-family: var(--rd-mono); font-size: 13px; font-weight: 600;
  color: var(--rd-steel); background: #fff; border: 1px solid var(--rd-line); width: 30px; height: 30px;
  border-radius: 8px; display: grid; place-items: center;
}
.rd-contact-form { margin-top: clamp(32px,4vw,56px); max-width: 760px; }

.rd-map-band { line-height: 0; }
.rd-map-band iframe { width: 100%; height: 420px; border: 0; display: block; filter: grayscale(.2) contrast(1.05); }

/* ==========================================================================
   KENNISBANK — documenten
   ========================================================================== */
.rd-docs { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.rd-doc {
  display: flex; align-items: center; gap: 18px; padding: 24px 26px;
  border: 1px solid var(--rd-line); border-radius: var(--rd-radius); background: var(--rd-paper);
  transition: border-color .2s var(--rd-ease), transform .2s var(--rd-ease), box-shadow .2s;
}
.rd-doc:hover { border-color: var(--rd-sky); transform: translateY(-3px); box-shadow: var(--rd-shadow); }
.rd-doc-ico { flex: none; width: 52px; height: 52px; border-radius: 12px; background: rgba(148,194,31,.14); display: grid; place-items: center; color: var(--rd-lime-dk); }
.rd-doc-ico svg { width: 24px; height: 24px; }
.rd-doc-body { flex: 1; }
.rd-doc-body strong { display: block; font-family: var(--rd-display); font-size: 18px; color: var(--rd-ink); }
.rd-doc-body span { display: block; color: var(--rd-slate); font-size: 14px; margin-top: 4px; }
.rd-doc-arrow { flex: none; color: var(--rd-steel); transition: transform .2s var(--rd-ease); }
.rd-doc-arrow svg { width: 18px; height: 18px; }
.rd-doc:hover .rd-doc-arrow { transform: translateX(4px); }

@media (max-width: 840px) {
  .rd-contact { grid-template-columns: 1fr; }
  .rd-docs { grid-template-columns: 1fr; }
}

/* ==========================================================================
   LINKS UITLIJNEN — consistent over alle pagina's en WooCommerce
   ========================================================================== */
.rd-grid, .woocommerce ul.products { justify-content: start; }
.rd-grid > *, .woocommerce ul.products li.product { text-align: left; }

/* WooCommerce-archief (mocht de shop ooit als archief draaien) links uitlijnen */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering { float: none; text-align: left; margin-left: 0; }
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .price,
.woocommerce ul.products li.product .button { text-align: left; }

/* Enkele productpagina en losse pagina's links houden */
.woocommerce div.product .product_title,
.woocommerce div.product p.price,
.woocommerce div.product .woocommerce-product-details__short-description { text-align: left; }
.rd-single-head, .rd-page-hero .rd-wrap, .rd-shop-hero .rd-wrap { text-align: left; }
.rd-prose { margin-left: 0; }

/* ==========================================================================
   SFEERBEELD + OVERLAY in paginakoppen (uitgelichte afbeelding)
   ========================================================================== */
.rd-page-hero.has-bg, .rd-shop-hero.has-bg {
  position: relative;
  background-size: cover; background-position: center; background-repeat: no-repeat;
}
.rd-shop-hero.has-bg::before { display: none; }
.rd-page-hero.has-bg::before { display: none; }
.rd-page-hero.has-bg::after, .rd-shop-hero.has-bg::after {
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(180deg, rgba(8,32,43,.70) 0%, rgba(8,32,43,.86) 100%);
}
.rd-page-hero.has-bg > .rd-wrap, .rd-shop-hero.has-bg > .rd-wrap {
  position: relative; z-index: 1;
}
