/* ============================================================
   VeluwePrint.nl — shared styles (v2)
   Kleuren: donkergroen #173D2F, zand #F4EFE6, wit #FFFFFF, oranje #D97706
   Typografie: Manrope (koppen) + Inter (body)
   ============================================================ */
:root{
  --groen: #173D2F;
  --groen-deep: #0F2A20;
  --zand: #F4EFE6;
  --zand-deep: #E9E0CF;
  --wit: #FFFFFF;
  --oranje: #D97706;
  --oranje-btn: #AD5C04;
  --oranje-deep: #8F4C08;
  --inkt: #16241D;
  --tekst-zacht: #4B5D52;
  --rule: rgba(23,61,47,0.13);
  --maxw: 1180px;
  --radius: 18px;
  --radius-sm: 12px;
  --focus: 3px solid #0F6FFF;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--wit);
  color:var(--inkt);
  font-family:'Inter', sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}

/* Accessibility: visible focus + skip link */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible,
textarea:focus-visible, [tabindex]:focus-visible{
  outline:var(--focus); outline-offset:3px; border-radius:4px;
}
.skip-link{
  position:absolute; left:-999px; top:auto;
  background:var(--groen); color:var(--wit); padding:12px 20px;
  border-radius:0 0 8px 0; z-index:200; font-weight:600;
}
.skip-link:focus{ left:0; top:0; }

.label{
  font-family:'Manrope', sans-serif;
  font-size:12.5px; font-weight:700;
  letter-spacing:0.08em; text-transform:uppercase;
  color:var(--oranje-deep);
  display:inline-flex; align-items:center; gap:6px;
}

h1,h2,h3{
  font-family:'Manrope', sans-serif;
  font-weight:800;
  line-height:1.12;
  letter-spacing:-0.015em;
  color:var(--groen-deep);
}
h2{font-size:clamp(26px,3.2vw,38px);}
h3{font-size:20px;}
p{color:var(--tekst-zacht);}

.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px; border-radius:999px;
  font-family:'Manrope', sans-serif; font-weight:700; font-size:15px;
  border:1.5px solid transparent; cursor:pointer;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--oranje-btn); color:var(--wit); box-shadow:0 6px 18px rgba(173,92,4,.28);}
.btn-primary:hover{background:var(--oranje-deep);}
.btn-ghost{border-color:rgba(255,255,255,0.55); color:var(--wit);}
.btn-ghost:hover{background:rgba(255,255,255,0.12);}
.btn-line{border-color:var(--groen); color:var(--groen); background:var(--wit);}
.btn-line:hover{background:var(--groen); color:var(--wit);}
.btn-sm{padding:9px 18px; font-size:13px;}

/* ===== HEADER ===== */
header{
  position:sticky; top:0; z-index:50;
  background:var(--wit);
  border-bottom:1px solid var(--rule);
  box-shadow:0 1px 0 rgba(23,61,47,0.04);
}
.nav{display:flex; align-items:center; justify-content:space-between; padding:14px 24px; max-width:var(--maxw); margin:0 auto; gap:20px;}
.logo-img{height:52px; width:auto; display:block;}
.navlinks{display:none; gap:28px; font-size:14.5px; font-weight:600;}
.navlinks a{color:var(--groen-deep); padding:6px 0;}
.navlinks a:hover, .navlinks a[aria-current="page"]{color:var(--oranje-deep);}
.nav-cta{display:none; gap:10px; align-items:center;}
.nav-burger{display:inline-flex; border:1.5px solid var(--rule); border-radius:10px; padding:8px 10px; background:none; cursor:pointer;}
@media(min-width:920px){
  .navlinks{display:flex;} .nav-cta{display:flex;} .nav-burger{display:none;}
}

/* ===== TRUST BAR ===== */
.trustbar{
  background:var(--groen-deep); color:var(--zand);
  padding:13px 0; font-family:'Manrope',sans-serif; font-size:13px; font-weight:600;
}
.trustbar .wrap{display:flex; flex-wrap:wrap; gap:8px 22px; justify-content:center; align-items:center;}
.trustbar span{display:flex; align-items:center; gap:7px;}
.trustbar span::before{content:"✓"; color:var(--oranje);}

/* ===== HERO ===== */
.hero{position:relative; min-height:80vh; display:flex; align-items:center; overflow:hidden; background:var(--groen-deep);}
.hero-img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.92;}
.hero-grad{position:absolute; inset:0; background:linear-gradient(120deg, rgba(15,42,32,.92) 0%, rgba(15,42,32,.65) 45%, rgba(15,42,32,.25) 100%);}
.hero-inner{position:relative; z-index:2; width:100%; padding:80px 24px; max-width:var(--maxw); margin:0 auto;}
.hero h1{color:var(--wit); font-size:clamp(36px,5.6vw,64px); max-width:16ch;}
.hero-sub{color:rgba(255,255,255,.86); max-width:54ch; font-size:17px; margin:22px 0 30px;}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap;}

/* ===== PAGE HEADER (sub-pages) ===== */
.page-hero{position:relative; min-height:38vh; display:flex; align-items:flex-end; background:var(--groen-deep); overflow:hidden;}
.page-hero img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.45;}
.page-hero .hero-grad{position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,42,32,.3) 0%, rgba(15,42,32,.65) 60%, rgba(15,42,32,.96) 100%);}
.page-hero-inner{position:relative; z-index:2; width:100%; padding:0 24px 44px; max-width:var(--maxw); margin:0 auto;}
.page-hero h1{color:var(--wit); font-size:clamp(30px,4.4vw,46px); max-width:20ch;}
.page-hero p{color:rgba(255,255,255,.85); max-width:54ch; margin-top:14px; font-size:16px;}
.crumbs{font-size:12.5px; color:var(--zand); letter-spacing:.03em; margin-bottom:16px; font-weight:600;}
.crumbs a{color:var(--zand); opacity:.75;}
.crumbs a:hover{opacity:1; text-decoration:underline;}
.crumbs span{opacity:.5; margin:0 6px;}

/* ===== USP / VOORDELEN ===== */
.voordelen{padding:80px 0;}
.vd-head{display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:40px;}
.vd-head p{max-width:46ch;}
.vd-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
@media(max-width:880px){ .vd-grid{grid-template-columns:repeat(2,1fr);} }
@media(max-width:560px){ .vd-grid{grid-template-columns:1fr;} }
.vd-item{background:var(--zand); border-radius:var(--radius); padding:28px 26px;}
.vd-item h3{font-size:18px; margin:14px 0 8px;}
.vd-item p{font-size:14.5px;}
.vd-icon{font-size:22px;}

/* ===== SECTIE: GEEN INGEWIKKELDE BESTELSTRAAT ===== */
.simpel{background:var(--zand); padding:90px 0;}
.simpel-grid{display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center;}
@media(max-width:880px){ .simpel-grid{grid-template-columns:1fr;} }
.simpel-grid img{border-radius:var(--radius); aspect-ratio:4/3; object-fit:cover;}
.usp-list{list-style:none; margin-top:24px; display:grid; grid-template-columns:1fr 1fr; gap:12px 20px;}
@media(max-width:480px){ .usp-list{grid-template-columns:1fr;} }
.usp-list li{display:flex; align-items:flex-start; gap:10px; font-size:14.5px; font-weight:600; color:var(--groen-deep);}
.usp-list li::before{content:"✓"; color:var(--oranje-deep); font-weight:800;}

/* ===== WERKWIJZE ===== */
.werkwijze{padding:90px 0;}
.ww-steps{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:44px;}
@media(max-width:880px){ .ww-steps{grid-template-columns:1fr 1fr;} }
@media(max-width:520px){ .ww-steps{grid-template-columns:1fr;} }
.ww-step{background:var(--wit); border:1.5px solid var(--rule); border-radius:var(--radius); padding:26px 22px;}
.ww-num{display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; background:var(--oranje-btn); color:var(--wit); font-family:'Manrope',sans-serif; font-weight:800; font-size:14px; margin-bottom:14px;}
.ww-step h3{font-size:16.5px; margin-bottom:6px;}
.ww-step p{font-size:13.5px;}

/* ===== FILTER PILLS ===== */
.filters{display:flex; flex-wrap:wrap; gap:10px; padding:36px 0 6px;}
.filter-pill{font-family:'Manrope',sans-serif; font-size:13px; font-weight:700; padding:10px 18px; border-radius:999px; border:1.5px solid var(--rule); background:var(--wit); cursor:pointer; transition:all .15s ease; color:var(--groen-deep);}
.filter-pill:hover{border-color:var(--oranje);}
.filter-pill.active{background:var(--groen-deep); border-color:var(--groen-deep); color:var(--wit);}

/* ===== CATEGORY HEAD ===== */
.cat-block{padding:54px 0 10px;}
.cat-head{display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center; margin-bottom:38px;}
@media(max-width:800px){ .cat-head{grid-template-columns:1fr;} }
.cat-head img{width:100%; height:auto; border-radius:var(--radius); aspect-ratio:16/9; object-fit:cover;}
.cat-head h2{margin-bottom:10px;}

/* ===== PRODUCT CARDS ===== */
.pcard-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:64px;}
@media(max-width:880px){ .pcard-grid{grid-template-columns:repeat(2,1fr);} }
@media(max-width:560px){ .pcard-grid{grid-template-columns:1fr;} }
.pcard{background:var(--wit); border:1.5px solid var(--rule); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:box-shadow .2s ease, transform .2s ease;}
.pcard:hover{box-shadow:0 14px 30px rgba(23,61,47,.12); transform:translateY(-3px);}
.pcard-img{aspect-ratio:4/3; overflow:hidden;}
.pcard-img img{width:100%; height:100%; object-fit:cover; transition:transform .4s ease;}
.pcard:hover .pcard-img img{transform:scale(1.05);}
.pcard-body{padding:20px 20px 22px; display:flex; flex-direction:column; flex:1;}
.pcard-body h3{font-size:18px; margin-bottom:7px;}
.pcard-body p{font-size:13.5px; margin-bottom:8px;}
.pcard-fit{font-size:12px; font-weight:700; color:var(--oranje-deep); margin-bottom:4px;}
.pcard-opts{font-size:12px; color:var(--tekst-zacht); margin-bottom:16px;}
.pcard-actions{display:flex; gap:8px; margin-top:auto; flex-wrap:wrap;}

/* ===== FORMS ===== */
.form-wrap{display:grid; grid-template-columns:0.85fr 1.15fr; gap:50px; padding:80px 0; align-items:start;}
@media(max-width:880px){ .form-wrap{grid-template-columns:1fr;} }
.form-side h2{margin-bottom:16px;}
.form-side p{margin-bottom:22px;}
.form-side-img{width:100%; height:auto; border-radius:var(--radius); aspect-ratio:14/9; object-fit:cover; margin-top:26px;}
.info-list{list-style:none; margin-top:26px;}
.info-list li{display:flex; gap:10px; padding:13px 0; border-top:1px solid var(--rule); font-size:14px; color:var(--tekst-zacht);}
.info-list li:last-child{border-bottom:1px solid var(--rule);}
.info-list .mk{color:var(--oranje-deep); font-weight:800;}

form{display:flex; flex-direction:column; gap:16px; background:var(--zand); border-radius:var(--radius); padding:30px;}
.frow{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
@media(max-width:560px){ .frow{grid-template-columns:1fr;} }
.field{display:flex; flex-direction:column; gap:6px;}
.field label{font-size:13px; font-weight:700; color:var(--groen-deep);}
.field .opt{font-weight:400; color:#8a988c;}
.field input, .field select, .field textarea{
  border:1.5px solid var(--rule); border-radius:var(--radius-sm); padding:12px 14px;
  font-family:'Inter',sans-serif; font-size:14.5px; background:var(--wit); color:var(--inkt);
}
.field input:focus, .field select:focus, .field textarea:focus{outline:var(--focus); outline-offset:1px; border-color:var(--oranje);}
.field textarea{resize:vertical; min-height:100px;}
.field-error{font-size:12.5px; color:#B3261E; font-weight:600; display:none;}
.field.invalid input, .field.invalid select, .field.invalid textarea{border-color:#B3261E;}
.field.invalid .field-error{display:block;}
.upload{border:1.5px dashed var(--rule); border-radius:var(--radius-sm); padding:24px; text-align:center; font-size:13.5px; color:var(--tekst-zacht); cursor:pointer; transition:border-color .15s ease; background:var(--wit);}
.upload:hover{border-color:var(--oranje);}
.upload strong{color:var(--groen-deep); display:block; margin-bottom:4px; font-size:14.5px;}
.checkfield{display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--tekst-zacht);}
.checkfield input{margin-top:3px;}
.form-submit{align-self:flex-start; margin-top:4px;}
.form-note{font-size:12.5px; color:#7a8a7d; margin-top:-4px;}
.form-success{display:none; background:var(--zand); border-radius:var(--radius); padding:40px; text-align:center;}
.form-success.show{display:block;}
.form-success h3{margin-bottom:10px;}
.form-general-error{display:none; background:#FBEAEA; border:1.5px solid #B3261E; color:#7A1812; border-radius:var(--radius-sm); padding:14px 16px; font-size:14px; font-weight:600;}
.hp-field{position:absolute; left:-9999px; top:-9999px; width:1px; height:1px; overflow:hidden;}

/* ===== CHECKLIST GRID (aanleveren) ===== */
.check-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin:44px 0 80px;}
@media(max-width:760px){ .check-grid{grid-template-columns:1fr;} }
.check-item{background:var(--zand); border-radius:var(--radius); padding:26px 24px; display:flex; gap:14px;}
.check-mark{font-size:17px; color:var(--oranje-deep); flex-shrink:0;}
.check-item h3{font-size:16px; margin-bottom:5px;}
.check-item p{font-size:13.5px;}

/* ===== FAQ ===== */
.faq{margin:24px 0 70px;}
.faq-item{border-bottom:1px solid var(--rule);}
.faq-item:first-child{border-top:1px solid var(--rule);}
.faq-q{display:flex; justify-content:space-between; align-items:center; gap:18px; padding:20px 0; cursor:pointer; font-family:'Manrope',sans-serif; font-size:17px; font-weight:700; color:var(--groen-deep); background:none; border:none; width:100%; text-align:left;}
.faq-q .plus{color:var(--oranje); font-size:20px; transition:transform .2s ease; flex-shrink:0;}
.faq-item.open .faq-q .plus{transform:rotate(45deg);}
.faq-a{max-height:0; overflow:hidden; transition:max-height .25s ease;}
.faq-a p{padding-bottom:20px; font-size:14.5px; max-width:62ch;}
.faq-item.open .faq-a{max-height:300px;}

/* ===== TEAM / OVER ONS ===== */
.story{padding:80px 0; max-width:760px;}
.story p{font-size:16.5px; color:#3c4d3f; margin-bottom:18px; line-height:1.75;}
.gallery{display:grid; grid-template-columns:1.3fr 1fr; gap:14px; margin:50px 0 80px;}
@media(max-width:700px){ .gallery{grid-template-columns:1fr;} }
.gallery img{border-radius:var(--radius); width:100%; height:100%; object-fit:cover;}
.gallery .g-tall{width:100%; height:auto; aspect-ratio:4/5;}
.gallery .g-stack{display:flex; flex-direction:column; gap:14px;}
.gallery .g-short{width:100%; height:auto; aspect-ratio:4/3; flex:1;}
.audience-strip{display:flex; flex-wrap:wrap; gap:10px; margin:30px 0 60px;}
.audience-pill{font-size:13px; font-weight:700; padding:9px 16px; border-radius:999px; background:var(--zand); color:var(--groen-deep);}

/* ===== CONTACT ===== */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:50px; padding:80px 0;}
@media(max-width:880px){ .contact-grid{grid-template-columns:1fr;} }
.contact-cards{display:flex; flex-direction:column; gap:12px; margin-top:26px;}
.contact-card{background:var(--zand); border-radius:var(--radius-sm); padding:18px 20px; display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap;}
.contact-card a, .contact-card div{font-size:14.5px; font-weight:700; color:var(--groen-deep);}
.map-img{width:100%; height:auto; border-radius:var(--radius); aspect-ratio:14/9; object-fit:cover; margin-top:26px;}

/* ===== PRODUCT DETAIL PAGE ===== */
.detail-hero{padding:50px 0 0;}
.detail-grid{display:grid; grid-template-columns:1fr 1fr; gap:50px; padding:40px 0 70px; align-items:flex-start;}
@media(max-width:880px){ .detail-grid{grid-template-columns:1fr;} }
.detail-img{width:100%; height:auto; border-radius:var(--radius); aspect-ratio:1/1; object-fit:cover; position:sticky; top:96px;}
@media(max-width:880px){ .detail-img{position:static;} }
.opt-row{display:flex; justify-content:space-between; align-items:flex-start; gap:14px; padding:15px 0; border-top:1px solid var(--rule); font-size:14.5px;}
.opt-row:last-of-type{border-bottom:1px solid var(--rule);}
.opt-row span:first-child{color:var(--groen-deep); font-weight:700; flex-shrink:0;}
.opt-row span:last-child{color:var(--tekst-zacht); text-align:right;}
.spoed-badge{display:inline-flex; align-items:center; gap:8px; margin-top:22px; padding:10px 16px; background:var(--zand); border-radius:999px; font-size:13px; font-weight:700; color:var(--groen-deep);}
.helper-blocks{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:70px;}
@media(max-width:760px){ .helper-blocks{grid-template-columns:1fr;} }
.helper-block{background:var(--zand); border-radius:var(--radius); padding:28px 26px;}
.helper-block h3{font-size:18px; margin-bottom:8px;}
.helper-block p{font-size:14px; margin-bottom:14px;}
.related-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:80px;}
@media(max-width:760px){ .related-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:480px){ .related-grid{grid-template-columns:1fr;} }
.related-card{background:var(--zand); border-radius:var(--radius-sm); padding:16px 18px; font-weight:700; font-size:14.5px; color:var(--groen-deep); display:flex; justify-content:space-between; align-items:center;}
.related-card:hover{background:var(--zand-deep);}

/* ===== BRANCH / LEGAL PAGES ===== */
.legal-body{padding:60px 0 90px; max-width:760px;}
.legal-body h2{margin:36px 0 12px; font-size:22px;}
.legal-body h2:first-child{margin-top:0;}
.legal-body p, .legal-body li{font-size:15px; margin-bottom:12px;}
.legal-body ul{padding-left:20px;}
.placeholder-note{background:var(--zand); border-radius:var(--radius-sm); padding:18px 20px; font-size:14px; color:var(--groen-deep); font-weight:600; margin:24px 0;}

.branch-focus{display:flex; flex-wrap:wrap; gap:10px; margin:30px 0 50px;}
.branch-focus span{background:var(--zand); border-radius:999px; padding:9px 16px; font-size:13px; font-weight:700; color:var(--groen-deep);}

/* ===== CTA BLOCK ===== */
.cta-block{padding:90px 0; text-align:center; background:var(--groen-deep);}
.cta-block .label{color:var(--zand);}
.cta-block h2{color:var(--wit); max-width:20ch; margin:16px auto 14px;}
.cta-block p{color:rgba(255,255,255,.78); max-width:48ch; margin:0 auto 30px;}
.cta-actions{display:flex; gap:14px; justify-content:center; flex-wrap:wrap;}

/* ===== FOOTER ===== */
footer{background:var(--zand-deep); color:var(--groen-deep); padding:60px 0 26px;}
.f-grid{display:grid; grid-template-columns:1.3fr repeat(4,1fr); gap:32px; padding-bottom:40px; border-bottom:1px solid rgba(23,61,47,.15);}
@media(max-width:880px){ .f-grid{grid-template-columns:1fr 1fr;} }
.f-logo-img{height:42px; width:auto; margin-bottom:14px;}
footer h4{font-family:'Manrope',sans-serif; font-size:12px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; color:var(--oranje-deep); margin-bottom:14px;}
footer ul{list-style:none;}
footer li{margin-bottom:9px; font-size:14px;}
footer li a:hover{color:var(--oranje-deep); text-decoration:underline;}
.f-meta{font-size:12.5px; color:#5c6e60; margin-top:18px; line-height:1.7;}
.f-bottom{display:flex; justify-content:space-between; padding-top:22px; font-size:12.5px; flex-wrap:wrap; gap:10px; color:#5c6e60;}

section{overflow:hidden;}
.wrap > *{position:relative;}

@media(max-width:600px){
  .form-wrap, .contact-grid{padding:50px 0;}
  .voordelen, .werkwijze, .simpel, .cta-block{padding:60px 0;}
  .hero-img{opacity:.28; object-position:85% 50%;}
  .hero-grad{background:linear-gradient(180deg, rgba(15,42,32,.85) 0%, rgba(15,42,32,.94) 55%, rgba(15,42,32,.98) 100%);}
  .hero{min-height:auto; padding:20px 0;}
}
