/* allroof-dakwerken.be — pine + brass, werkgebied-gestuurd */
:root{
  --ink:#12302c;        /* pine, diep */
  --pine:#234f46;       /* secundair groen */
  --pine-soft:#e4ece7;  /* zacht groenvlak */
  --brass:#c1852b;      /* enig accent, warm metallic */
  --brass-dark:#9c6a1f;
  --paper:#eef1ed;      /* koele off-white, geen crème */
  --card:#ffffff;
  --line:#d2dbd4;
  --muted:#586a62;
  --ink-70:rgba(18,48,44,.72);
  --maxw:1120px;
  --r:4px;
  --shadow:0 1px 0 rgba(18,48,44,.05), 0 10px 30px -18px rgba(18,48,44,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Fraunces","Georgia",serif;font-weight:600;line-height:1.1;letter-spacing:-.01em;color:var(--ink)}
a{color:var(--pine);text-decoration:none}
a:hover{color:var(--brass-dark)}
img,svg{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.mono{font-family:"Space Mono","SFMono-Regular",monospace}
.eyebrow{font-family:"Space Mono",monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-dark)}

/* ---------- skiplink + focus ---------- */
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:100}
.skip:focus{left:8px;top:8px}
a:focus-visible,button:focus-visible{outline:2px solid var(--brass);outline-offset:2px;border-radius:2px}

/* ---------- header ---------- */
.topline{height:3px;background:linear-gradient(90deg,var(--brass),var(--pine))}
header.site{position:sticky;top:0;z-index:40;background:rgba(238,241,237,.9);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line)}
.head{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:10px;font-family:"Fraunces",serif;font-weight:600;font-size:21px;color:var(--ink)}
.brand .be{font-family:"Space Mono",monospace;font-size:12px;color:var(--brass-dark);letter-spacing:.05em;background:var(--pine-soft);padding:2px 6px;border-radius:3px;align-self:center}
.brand svg{width:30px;height:30px;flex:none}
nav.main{display:flex;align-items:center;gap:26px}
nav.main a{color:var(--ink);font-size:15px;font-weight:500;position:relative;padding:4px 0}
nav.main a.active{color:var(--pine)}
nav.main a:not(.btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--brass);transition:right .25s ease}
nav.main a:not(.btn):hover::after,nav.main a.active::after{right:0}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;padding:11px 18px;border-radius:var(--r);font-weight:600;font-size:15px;border:1px solid var(--ink);cursor:pointer}
.btn:hover{background:var(--pine);color:#fff}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--pine-soft);color:var(--ink)}
.btn.brass{background:var(--brass);border-color:var(--brass);color:#1c1305}
.btn.brass:hover{background:var(--brass-dark);color:#fff}
.navtoggle{display:none;background:none;border:1px solid var(--line);border-radius:var(--r);padding:8px 10px;cursor:pointer;color:var(--ink)}

/* ---------- hero ---------- */
.hero{padding:72px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.4rem,5vw,4rem);margin:14px 0 18px}
.hero h1 em{font-style:italic;color:var(--pine)}
.hero p.lead{font-size:1.15rem;color:var(--ink-70);max-width:34ch;margin:0 0 26px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-art{position:relative}
.provstrip{margin-top:34px;display:flex;flex-wrap:wrap;gap:8px 10px;border-top:1px solid var(--line);padding-top:18px}
.provstrip .eyebrow{width:100%;margin-bottom:4px}
.prov-chip{font-family:"Space Mono",monospace;font-size:12.5px;color:var(--pine);background:var(--card);border:1px solid var(--line);border-radius:20px;padding:5px 12px}

/* ---------- generic section ---------- */
section.band{padding:60px 0}
section.band.alt{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
section.band.pine{background:var(--ink);color:#e8efe9}
section.band.pine h2,section.band.pine h3{color:#fff}
section.band.pine .eyebrow{color:var(--brass)}
.sec-head{max-width:60ch;margin-bottom:34px}
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin:8px 0 10px}
.sec-head p{color:var(--muted);margin:0}
section.band.pine .sec-head p{color:#b8c8c1}

/* ---------- diensten list ---------- */
.svc-list{display:grid;grid-template-columns:1fr 1fr;gap:0 48px}
.svc{display:grid;grid-template-columns:38px 1fr;gap:16px;padding:22px 0;border-top:1px solid var(--line)}
.svc:nth-child(-n+2){border-top:none}
.svc .ic{color:var(--brass-dark)}
.svc h3{font-size:1.2rem;margin:0 0 6px}
.svc p{margin:0;color:var(--muted);font-size:15.5px}
.svc a.more{font-size:14px;font-weight:600;color:var(--pine);display:inline-block;margin-top:8px}

/* ---------- werkgebied ---------- */
.province{border:1px solid var(--line);border-radius:6px;background:var(--card);padding:24px;margin-bottom:18px}
.province-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:14px;flex-wrap:wrap}
.province-head h3{font-size:1.4rem;margin:0}
.province-head .count{font-family:"Space Mono",monospace;font-size:12px;color:var(--muted)}
.province p.pintro{margin:0 0 16px;color:var(--muted);font-size:15.5px;max-width:70ch}
.cities{display:flex;flex-wrap:wrap;gap:10px}
.city{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:24px;padding:8px 14px 8px 12px;background:#fff;transition:border-color .18s,box-shadow .18s,transform .18s;color:var(--ink)}
.city:hover{border-color:var(--brass);box-shadow:var(--shadow);transform:translateY(-1px);color:var(--ink)}
.city .pin{color:var(--brass-dark);flex:none}
.city .pc{font-family:"Space Mono",monospace;font-size:11.5px;color:var(--muted)}
.city.feat{background:var(--ink);color:#fff;border-color:var(--ink);padding-right:16px}
.city.feat .pc{color:#a9c1b7}
.city.feat .pin{color:var(--brass)}
.city.feat:hover{border-color:var(--brass)}
.verified{font-family:"Space Mono",monospace;font-size:10px;color:var(--pine);border:1px solid var(--pine-soft);background:var(--pine-soft);border-radius:3px;padding:1px 5px;margin-left:2px}

/* ---------- cards (gids/home) ---------- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:24px;display:flex;flex-direction:column;transition:border-color .18s,box-shadow .18s,transform .18s}
.card:hover{border-color:var(--brass);box-shadow:var(--shadow);transform:translateY(-2px)}
.card .k{font-family:"Space Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--brass-dark);margin-bottom:10px}
.card h3{font-size:1.28rem;margin:0 0 8px}
.card p{margin:0 0 16px;color:var(--muted);font-size:15.5px;flex:1}
.card .go{font-weight:600;color:var(--pine);font-size:14.5px}

/* ---------- refer / cta block ---------- */
.refer{display:grid;grid-template-columns:1.4fr .6fr;gap:24px;align-items:center;background:var(--card);border:1px solid var(--line);border-left:4px solid var(--brass);border-radius:6px;padding:26px}
.refer h3{margin:0 0 6px;font-size:1.35rem}
.refer p{margin:0;color:var(--muted);font-size:15.5px}
.refer .actions{display:flex;flex-direction:column;gap:10px}
section.band.pine .refer{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.14);border-left-color:var(--brass)}
section.band.pine .refer p{color:#b8c8c1}

/* ---------- article ---------- */
.article{max-width:720px;margin:0 auto;padding:48px 24px 20px}
.crumbs{font-family:"Space Mono",monospace;font-size:12px;color:var(--muted);margin-bottom:18px}
.crumbs a{color:var(--muted)}
.article h1{font-size:clamp(2rem,4vw,2.9rem);margin:6px 0 18px}
.article .meta{font-family:"Space Mono",monospace;font-size:12px;color:var(--brass-dark);text-transform:uppercase;letter-spacing:.1em}
.prose{font-size:17.5px}
.prose h2{font-size:1.55rem;margin:2em 0 .5em}
.prose h3{font-size:1.22rem;margin:1.6em 0 .4em}
.prose p{margin:0 0 1.1em}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.25em}
.prose li{margin:.35em 0}
.prose strong{color:var(--ink)}
.prose blockquote{margin:1.5em 0;padding:6px 0 6px 20px;border-left:3px solid var(--brass);color:var(--pine);font-style:italic}
.prose a{border-bottom:1px solid rgba(35,79,70,.35)}
.prose a:hover{border-color:var(--brass)}

/* video facade */
.video{margin:1.8em 0}
.vframe{position:relative;width:100%;aspect-ratio:16/9;border:0;border-radius:6px;cursor:pointer;overflow:hidden;
  background:linear-gradient(135deg,#173a34,#0d211d)}
.vframe::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 45%,rgba(193,133,43,.22),transparent 60%)}
.vframe-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:70px;height:70px;border-radius:50%;background:var(--brass);color:#1c1305;display:grid;place-items:center;transition:transform .2s}
.vframe:hover .vframe-play{transform:translate(-50%,-50%) scale(1.06)}
.video figcaption{font-family:"Space Mono",monospace;font-size:12px;color:var(--muted);margin-top:8px}
.video iframe{width:100%;aspect-ratio:16/9;border:0;border-radius:6px}

.article-cta{margin:2.4em 0 1em;background:var(--pine-soft);border-radius:6px;padding:22px 24px}
.article-cta .eyebrow{margin-bottom:6px}
.article-cta h3{margin:0 0 6px;font-size:1.25rem}
.article-cta p{margin:0 0 14px;color:var(--pine)}
.article-nav{display:flex;justify-content:space-between;gap:16px;border-top:1px solid var(--line);margin-top:36px;padding-top:20px;font-size:14.5px}
.article-nav .mono{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.related{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}
.related a{font-size:13.5px;border:1px solid var(--line);border-radius:20px;padding:6px 12px;color:var(--pine);background:#fff}
.related a:hover{border-color:var(--brass)}

/* ---------- footer ---------- */
footer.site{background:var(--ink);color:#cdd9d2;padding:52px 0 30px;margin-top:20px}
footer.site .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:32px}
footer.site h4{color:#fff;font-family:"Space Mono",monospace;font-weight:400;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 14px}
footer.site a{color:#cdd9d2;display:block;padding:3px 0;font-size:14.5px}
footer.site a:hover{color:var(--brass)}
footer.site .brand{color:#fff;margin-bottom:10px}
footer.site .fbrand-txt{font-size:14px;color:#9db3aa;max-width:34ch}
footer.site .legal{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:16px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:#8ba79d}
footer.site .legal a{display:inline;color:#8ba79d}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-art{order:-1;max-width:440px}
  .svc-list{grid-template-columns:1fr}
  .svc:nth-child(2){border-top:1px solid var(--line)}
  .cards,.province .cities{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .refer{grid-template-columns:1fr}
  footer.site .cols{grid-template-columns:1fr 1fr}
  nav.main{position:fixed;inset:70px 0 auto 0;background:var(--paper);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:8px 24px 18px;display:none}
  nav.main.open{display:flex}
  nav.main a{width:100%;padding:12px 0;border-bottom:1px solid var(--line)}
  nav.main a:not(.btn)::after{display:none}
  nav.main .btn{margin-top:10px;width:100%;justify-content:center}
  .navtoggle{display:inline-flex;align-items:center;gap:8px}
}
@media (max-width:520px){
  body{font-size:16px}
  .hero{padding:44px 0 30px}
  footer.site .cols{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  *{scroll-behavior:auto!important}
}
