/*
Theme Name: Verduursamen
Theme URI: https://www.verduursamen.nl
Author: Verduursamen
Description: Maatwerk WordPress-thema voor Verduursamen met WooCommerce-ondersteuning. Huisstijl petrol-teal (#286e6d), fotohero en offerte-aanvraagblok.
Version: 1.3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: verduursamen
WC requires at least: 6.0
WC tested up to: 8.9
*/

/* ============================================================
   VERDUURSAMEN — gedeelde stijl
   ============================================================ */
:root{
  /* >>> HUISKLEUREN (Verduursamen) — hier aanpassen <<< */
  --green:#286e6d;        /* hoofdkleur petrol-teal (logo) */
  --green-700:#205756;    /* iets donkerder teal */
  --green-900:#143b3a;    /* diep teal (footer, panelen) */
  --lime:#6fb0ae;         /* fris licht-teal accent / highlight */
  --sun:#ffb43f;          /* warm accent (zon) */
  --bg:#f5faf9;
  --surface:#ffffff;
  --ink:#1c2b2a;
  --muted:#5a6b6a;
  --line:#e0ebea;
  --radius:18px;
  --shadow:0 10px 30px rgba(20,70,45,.08);
  --shadow-lg:0 24px 60px rgba(20,70,45,.14);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{padding:80px 0}
h1,h2,h3{line-height:1.15;letter-spacing:-.02em;font-weight:800}
h2{font-size:clamp(1.7rem,3.6vw,2.5rem)}
.eyebrow{display:inline-block;font-weight:700;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.lead{color:var(--muted);font-size:1.06rem;max-width:600px}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:1rem;padding:13px 24px;border-radius:999px;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;cursor:pointer;border:0;font-family:inherit}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 8px 20px rgba(40,110,109,.30)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(40,110,109,.42)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-sm{padding:10px 18px;font-size:.92rem}

/* Header / nav */
header.site{position:sticky;top:0;z-index:50;background:rgba(246,250,246,.88);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.2rem;flex:none}
.brand .mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--green),#3c8c8b);display:grid;place-items:center;color:#fff}
.brand img.logo{height:42px;width:auto}
.foot-brand img.logo{height:40px;width:auto;filter:brightness(0) invert(1)}
.navlinks{display:flex;align-items:center;gap:6px;margin-left:auto}
.navlinks > a, .has-sub > button{color:var(--muted);font-weight:600;font-size:.96rem;padding:10px 12px;border-radius:10px;background:none;border:0;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:5px}
.navlinks > a:hover,.has-sub > button:hover{color:var(--green);background:#e6f1f0}
.navlinks a.active{color:var(--green)}
.has-sub{position:relative}
.submenu{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;min-width:230px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s ease}
.has-sub:hover .submenu,.has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--ink);font-weight:600;font-size:.94rem}
.submenu a:hover{background:#e6f1f0;color:var(--green)}
.submenu a small{display:block;color:var(--muted);font-weight:500;font-size:.8rem}
.nav-cta{display:flex;align-items:center;gap:12px;flex:none}
.cart-link{position:relative;display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--ink);padding:8px 10px;border-radius:10px;background:none;border:0;cursor:pointer;font-family:inherit;font-size:.96rem}
.cart-link:hover{color:var(--green);background:#e6f1f0}
.cart-count{position:absolute;top:-4px;right:-6px;background:var(--green);color:#fff;font-size:.68rem;font-weight:800;min-width:18px;height:18px;border-radius:999px;display:grid;place-items:center;padding:0 4px}
.cart-count[data-empty="true"]{display:none}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:8px}
.menu-btn span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.25s}

/* Page hero */
.page-hero{background:linear-gradient(160deg,#e4f1f0,#cfe7e6);padding:60px 0}
.page-hero .crumbs{color:var(--muted);font-size:.9rem;font-weight:600;margin-bottom:10px}
.page-hero .crumbs a:hover{color:var(--green)}
.page-hero h1{font-size:clamp(2rem,4.5vw,3rem)}
.page-hero p{margin-top:14px;max-width:620px;color:#234443;font-size:1.08rem}

/* Home hero */
.hero{padding:70px 0 60px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.1rem,5vw,3.4rem)}
.hero h1 .accent{color:var(--green)}
.hero p.lead{margin:22px 0 30px;font-size:1.12rem}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.trust{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.trust div{display:flex;align-items:center;gap:9px;color:var(--muted);font-weight:600;font-size:.92rem}
.trust svg{color:var(--green);flex:none}
.hero-card{background:linear-gradient(160deg,#e4f1f0,#cfe7e6);border-radius:26px;padding:34px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.hero-card .sun{position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle at 40% 40%,#ffe27a,var(--sun))}
.hero-card h3{font-size:1.15rem;margin-bottom:18px;position:relative}
.stat{position:relative;background:#fff;border-radius:14px;padding:16px 18px;margin-bottom:12px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}
.stat .num{font-size:1.5rem;font-weight:800;color:var(--green)}
.stat .lbl{color:var(--muted);font-size:.9rem;font-weight:600}

/* Cards / grids */
.grid{display:grid;gap:22px}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.mt{margin-top:46px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card .ico{width:50px;height:50px;border-radius:13px;background:#e2efef;color:var(--green);display:grid;place-items:center;margin-bottom:16px}
.card h3{font-size:1.18rem;margin-bottom:8px}
.card p{color:var(--muted);font-size:.97rem}
.card .more{margin-top:auto;padding-top:14px;color:var(--green);font-weight:700;font-size:.95rem;display:inline-flex;align-items:center;gap:6px}

/* Steps */
.steps{background:var(--green-900);color:#e4f1f0;border-radius:30px;padding:56px 40px}
.steps .eyebrow{color:var(--lime)}
.steps h2{color:#fff}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:38px}
.step .n{width:42px;height:42px;border-radius:50%;background:var(--lime);color:var(--green-900);font-weight:800;display:grid;place-items:center;margin-bottom:14px}
.step h3{font-size:1.08rem;color:#fff;margin-bottom:6px}
.step p{color:#b3d3d2;font-size:.95rem}

/* Why */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.checklist{list-style:none;margin-top:22px;display:grid;gap:16px}
.checklist li{display:flex;gap:13px;align-items:flex-start}
.checklist .tick{flex:none;width:26px;height:26px;border-radius:50%;background:#e2efef;color:var(--green);display:grid;place-items:center;margin-top:2px}
.checklist b{display:block}
.checklist span{color:var(--muted);font-size:.96rem}
.why-panel{background:linear-gradient(160deg,var(--green),var(--green-900));border-radius:26px;padding:40px;color:#fff;box-shadow:var(--shadow-lg)}
.why-panel .quote{font-size:1.2rem;font-weight:600;line-height:1.5}
.why-panel .by{margin-top:20px;color:#b3d3d2;font-weight:600}

/* Content (subpagina's) */
.prose{max-width:760px}
.prose p{color:var(--muted);margin-bottom:16px}
.prose h2{margin:34px 0 12px}
.prose h3{margin:24px 0 8px;font-size:1.2rem}
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.media{border-radius:22px;background:linear-gradient(160deg,#e4f1f0,#cfe7e6);min-height:320px;display:grid;place-items:center;color:var(--green);box-shadow:var(--shadow)}
.pricebar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px 26px;box-shadow:var(--shadow);margin-top:30px}
.pricebar .from{color:var(--muted);font-weight:600;font-size:.92rem}
.pricebar .amt{font-size:1.6rem;font-weight:800;color:var(--green)}

/* CTA */
.cta{background:linear-gradient(135deg,var(--lime),var(--green));border-radius:30px;padding:56px 40px;text-align:center;color:#fff}
.cta h2{color:#fff;max-width:680px;margin:0 auto}
.cta p{margin:14px auto 28px;max-width:540px;color:#e4f1f0}
.cta .btn-primary{background:#fff;color:var(--green)}
.cta .btn-primary:hover{background:#f3fff8}

/* Forms */
.form{display:grid;gap:16px;max-width:560px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.form label{font-weight:600;font-size:.92rem;display:block;margin-bottom:6px}
.form input,.form textarea,.form select{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:1rem;background:#fbfdfb}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--green)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-info{display:grid;gap:18px}
.contact-info .item{display:flex;gap:14px;align-items:flex-start}
.contact-info .ico{flex:none;width:44px;height:44px;border-radius:12px;background:#e2efef;color:var(--green);display:grid;place-items:center}
.contact-info b{display:block}
.contact-info a,.contact-info span{color:var(--muted)}
.contact-info a:hover{color:var(--green)}

/* Webshop (statisch — vervangen door WooCommerce) */
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.product{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.product:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product .thumb{height:160px;background:linear-gradient(160deg,#e4f1f0,#cfe7e6);display:grid;place-items:center;color:var(--green)}
.product .body{padding:20px;display:flex;flex-direction:column;flex:1}
.product .cat{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green);margin-bottom:6px}
.product h3{font-size:1.08rem;margin-bottom:6px}
.product p{color:var(--muted);font-size:.9rem;margin-bottom:14px}
.product .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px}
.product .price{font-size:1.2rem;font-weight:800;color:var(--ink)}

/* Footer */
footer.site{background:var(--green-900);color:#b3d3d2;padding:56px 0 26px;margin-top:84px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:36px}
footer.site h4{color:#fff;margin-bottom:14px;font-size:1rem}
footer.site a{color:#b3d3d2;display:block;margin-bottom:9px;font-size:.95rem}
footer.site a:hover{color:#fff}
.foot-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.2rem;color:#fff;margin-bottom:14px}
.foot-brand .mark{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,var(--lime),#3c8c8b);display:grid;place-items:center;color:var(--green-900)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.88rem}

/* Responsive */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:38px}
  .cols-3,.shop-grid{grid-template-columns:1fr 1fr}
  .steps-grid{grid-template-columns:1fr 1fr}
  .why-grid,.split,.contact-grid{grid-template-columns:1fr;gap:34px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  section{padding:56px 0}
  .navlinks{display:none;position:absolute;top:74px;left:0;right:0;background:var(--surface);flex-direction:column;align-items:stretch;gap:0;padding:8px 16px 16px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);margin-left:0}
  .navlinks.open{display:flex}
  .navlinks > a,.has-sub > button{padding:13px 8px;width:100%;border-bottom:1px solid var(--line);justify-content:space-between}
  .has-sub .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:0 0 6px 12px;min-width:0}
  .nav-cta .btn-ghost{display:none}
  .menu-btn{display:block}
  .cols-3,.cols-2,.shop-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .steps,.cta{padding:40px 22px}
  .why-panel{padding:30px}
}

/* ============================================================
   VISUELE VARIANT — fotohero + offerteblok
   ============================================================ */
.photo-hero{position:relative;display:flex;align-items:center;overflow:hidden;background:var(--green-900)}
.photo-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,40,39,.86) 0%,rgba(15,40,39,.55) 45%,rgba(15,40,39,.25) 100%),var(--hero,url('assets/hero-bg.jpg')) center/cover no-repeat}
.photo-hero .container{position:relative;z-index:1;width:100%}
.photo-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:78px 0}
.ph-copy .eyebrow{color:var(--lime)}
.ph-copy h1{color:#fff;font-size:clamp(2.1rem,4.8vw,3.4rem)}
.ph-copy p{color:#d7e9e8;font-size:1.12rem;max-width:540px;margin:20px 0 28px}
.ph-trust{display:flex;gap:22px;margin-top:30px;flex-wrap:wrap}
.ph-trust div{display:flex;align-items:center;gap:8px;color:#cfe4e3;font-weight:600;font-size:.92rem}
.ph-trust svg{color:var(--lime);flex:none}
.offer-card{background:#fff;border-radius:20px;padding:30px;box-shadow:0 30px 70px rgba(10,34,33,.4);color:var(--ink)}
.offer-card h3{font-size:1.32rem;margin-bottom:4px}
.offer-card .sub{color:var(--muted);font-size:.95rem;margin-bottom:18px}
.offer-card .field{margin-bottom:13px}
.offer-card label{display:block;font-weight:600;font-size:.86rem;margin-bottom:5px}
.offer-card input,.offer-card select,.offer-card textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;font-family:inherit;font-size:.98rem;background:#fbfdfd}
.offer-card input:focus,.offer-card select:focus,.offer-card textarea:focus{outline:none;border-color:var(--green)}
.offer-card .two{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.offer-card .btn{width:100%;justify-content:center;margin-top:4px}
.offer-card .smallprint{font-size:.76rem;color:var(--muted);text-align:center;margin-top:10px}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.feature{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.feature .pic{aspect-ratio:3/2;overflow:hidden}
.feature .pic img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.feature:hover .pic img{transform:scale(1.05)}
.feature .fbody{padding:22px;display:flex;flex-direction:column;flex:1}
.feature h3{font-size:1.18rem;margin-bottom:7px}
.feature p{color:var(--muted);font-size:.96rem}
.feature .more{margin-top:auto;padding-top:14px;color:var(--green);font-weight:700;font-size:.95rem}
.split .photo{border-radius:22px;overflow:hidden;box-shadow:var(--shadow-lg)}
.split .photo img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:960px){
  .photo-hero-grid{grid-template-columns:1fr;gap:34px;padding:56px 0}
  .feature-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .feature-grid{grid-template-columns:1fr}
  .offer-card .two{grid-template-columns:1fr}
  .photo-hero::before{background:linear-gradient(180deg,rgba(15,40,39,.8),rgba(15,40,39,.6)),var(--hero,url('assets/hero-bg.jpg')) center/cover no-repeat}
}


/* ---------- WordPress-menu (wp_nav_menu) ---------- */
.brand img,.brand img.logo,.brand .custom-logo{height:42px;width:auto}
.brand .brand-name{font-weight:800;font-size:1.2rem}
.navlinks ul,.navlinks .menu{list-style:none;display:flex;align-items:center;gap:6px;margin:0;padding:0}
.navlinks li{position:relative}
.navlinks li a{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-weight:600;font-size:.96rem;padding:10px 12px;border-radius:10px}
.navlinks li a:hover{color:var(--green);background:#e6f1f0}
.navlinks .current-menu-item>a,.navlinks .current_page_item>a{color:var(--green)}
.navlinks .sub-menu{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;min-width:230px;list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s ease}
.navlinks .menu-item-has-children:hover .sub-menu,.navlinks .menu-item-has-children:focus-within .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.navlinks .sub-menu a{white-space:nowrap;color:var(--ink)}
.navlinks .sub-menu a:hover{background:#e6f1f0;color:var(--green)}
@media(max-width:640px){
  .navlinks ul,.navlinks .menu{flex-direction:column;align-items:stretch;width:100%}
  .navlinks .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding:0 0 6px 12px;min-width:0}
}

/* ---------- WooCommerce afstemming op huisstijl ---------- */
.woocommerce-page .container{padding-top:10px}
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;transition:transform .18s ease,box-shadow .18s ease}
.woocommerce ul.products li.product:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.woocommerce ul.products li.product .price{color:var(--ink);font-weight:800}
.woocommerce span.onsale{background:var(--green);border-radius:999px}
.woocommerce a.button,.woocommerce button.button,.woocommerce #respond input#submit,.woocommerce input.button,.woocommerce .button.alt,.woocommerce-page .button{background:var(--green) !important;color:#fff !important;border-radius:999px !important;font-weight:700 !important;padding:12px 22px !important;border:0 !important}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce .button.alt:hover{background:var(--green-700) !important}
.woocommerce .woocommerce-message,.woocommerce .woocommerce-info{border-top-color:var(--green)}
.woocommerce .woocommerce-message::before,.woocommerce .woocommerce-info::before{color:var(--green)}
.woocommerce-breadcrumb{color:var(--muted);font-weight:600;font-size:.9rem}
.woocommerce-breadcrumb a:hover{color:var(--green)}


/* ---------- Samenwerkingen + projecten ---------- */
.partners{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.partner-logos{display:flex;flex-wrap:wrap;gap:26px 40px;align-items:center;justify-content:center;margin-top:26px}
.partner-logos img{height:60px;width:auto;opacity:.9;transition:.2s ease}
.partner-logos img:hover{opacity:1;transform:translateY(-2px)}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.project{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.project:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.project .pic{aspect-ratio:4/3;overflow:hidden}
.project .pic img{width:100%;height:100%;object-fit:cover;display:block}
.project .pbody{padding:20px}
.project .tag{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green);margin-bottom:6px}
.project h3{font-size:1.1rem;margin-bottom:6px}
.project p{color:var(--muted);font-size:.94rem}
.foot-grid-4{grid-template-columns:1.6fr 1fr 1fr 1.3fr}
.vds-edit{opacity:.75}
@media(max-width:960px){.projects-grid{grid-template-columns:1fr 1fr}.foot-grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.projects-grid{grid-template-columns:1fr}.foot-grid-4{grid-template-columns:1fr}}

.media img,.media-img{width:100%;height:100%;min-height:320px;max-height:430px;object-fit:cover;border-radius:22px;display:block}


/* ============================================================
   WEBSHOP-UPGRADE v1.1 — USP-balk, vertrouwen, dienst-links, reviews
   ============================================================ */
:root{--cta:#e0670f;--cta-700:#b9540b}

/* Oranje bestelknop (hogere conversie) — alleen 'toevoegen aan winkelwagen' */
.woocommerce a.button.add_to_cart_button,
.woocommerce button.single_add_to_cart_button,
.woocommerce .products a.button.add_to_cart_button{background:var(--cta) !important}
.woocommerce a.button.add_to_cart_button:hover,
.woocommerce button.single_add_to_cart_button:hover{background:var(--cta-700) !important}

/* USP-balk boven shop/categorie/product */
.vds-usp{display:flex;flex-wrap:wrap;gap:10px 26px;align-items:center;justify-content:center;background:var(--green-900);color:#dff0ef;border-radius:14px;padding:12px 18px;margin:0 0 24px;font-size:.9rem;font-weight:600}
.vds-usp span{display:inline-flex;align-items:center;gap:7px}
.vds-usp span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--lime)}

/* Vertrouwensregel onder de bestelknop */
.vds-trust{display:flex;flex-wrap:wrap;gap:8px 18px;margin:16px 0 6px;font-size:.9rem;font-weight:600;color:var(--green-700)}
.vds-pay{font-size:.84rem;color:var(--muted)}
.vds-pay b{color:var(--ink);font-weight:700}

/* "Hoort bij onze dienst"-blok op productpagina */
.vds-dienstbox{border:1.5px solid var(--green);background:#eef6f5;border-radius:14px;padding:14px 16px;margin:18px 0;font-size:.94rem;color:var(--ink)}
.vds-dienstbox strong{color:var(--green)}
.vds-dienstbox a{color:var(--green);font-weight:700;white-space:nowrap}
.vds-dienstbox a:hover{color:var(--green-700)}

/* Dienst-balk op de webshop/categoriepagina */
.vds-dienstbar{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;justify-content:space-between;background:#eef6f5;border:1px solid var(--line);border-radius:14px;padding:12px 18px;margin:0 0 24px;font-size:.94rem}
.vds-dienstbar a{color:var(--green);font-weight:700}
.vds-dienstbar a:hover{color:var(--green-700)}

/* Reviews-band in de footer (Trustoo) */
.vds-reviews-band{background:var(--green-700);padding:40px 0 8px;text-align:center}
.vds-reviews-title{color:#fff;font-size:1.4rem;margin:0 0 22px}
.vds-reviews-hint{color:#cfe7e6;font-size:.92rem;max-width:560px;margin:0 auto 18px}
.vds-reviews-band .container{max-width:var(--maxw)}

/* v1.2 — productfoto-label op dienstpagina's */
.media{position:relative}
.vds-media-tag{position:absolute;left:14px;bottom:14px;background:rgba(20,59,58,.92);color:#fff;font-size:.82rem;font-weight:700;padding:8px 13px;border-radius:999px;text-decoration:none;max-width:calc(100% - 28px);display:inline-flex;align-items:center;gap:6px}
.vds-media-tag:hover{background:var(--green)}
