/* =====================================================================
   AFVAL EXPRESS — main.css
   Industrial Express: iron black + steel, molten amber signal accent.
   Fonts: Anton (display), Hanken Grotesk (body), IBM Plex Mono (labels)
   ===================================================================== */

/* ---------- 1. TOKENS ---------- */
:root{
  /* palette */
  --ink:#0D1114;
  --steel:#1B2226;
  --steel-2:#232C31;
  --steel-3:#2E393F;
  --brushed:#5C666D;
  --amber:#F26A1B;
  --amber-2:#FF8A3D;
  --amber-deep:#D9550F;
  --zinc:#A7B0B5;
  --concrete:#ECE8DF;
  --concrete-dim:#C9C4B8;

  /* semantic */
  --bg:var(--ink);
  --surface:var(--steel);
  --surface-2:var(--steel-2);
  --text:var(--concrete);
  --text-dim:var(--concrete-dim);
  --line:rgba(167,176,181,.16);
  --line-strong:rgba(167,176,181,.28);

  /* type */
  --f-display:'Anton',Impact,sans-serif;
  --f-body:'Hanken Grotesk',system-ui,sans-serif;
  --f-mono:'IBM Plex Mono',ui-monospace,monospace;

  /* shadows */
  --shadow-sm:0 1px 2px rgba(0,0,0,.25);
  --shadow-md:0 8px 24px rgba(0,0,0,.35);
  --shadow-lg:0 20px 60px rgba(0,0,0,.5);
  --shadow-amber:0 12px 34px rgba(242,106,27,.32);

  /* metrics */
  --nav-h:76px;
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:22px;
  --maxw:1240px;
  --gutter:clamp(1.2rem,4vw,3rem);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- 2. RESET / BASE ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.no-scroll{overflow:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{line-height:1.05;font-weight:800;letter-spacing:-.01em;text-wrap:balance}

::selection{background:var(--amber);color:var(--ink)}
::-webkit-scrollbar{width:12px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--steel-3);border-radius:8px;border:3px solid var(--ink)}
::-webkit-scrollbar-thumb:hover{background:var(--brushed)}

/* grain overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- 3. LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4rem,9vw,7.5rem);position:relative}
.section--tight{padding-block:clamp(3rem,6vw,5rem)}
.section--steel{background:var(--steel)}
.section--ink{background:var(--ink)}
.grid{display:grid;gap:clamp(1.2rem,3vw,2rem)}
.center{text-align:center}
.stack-sm{display:flex;flex-direction:column;gap:.6rem}

/* ---------- 4. TYPOGRAPHY HELPERS ---------- */
.kicker{
  font-family:var(--f-mono);font-size:.8rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--amber);font-weight:500;
  display:inline-flex;align-items:center;gap:.7rem;
}
.kicker::before{content:"";width:26px;height:2px;background:var(--amber);display:inline-block}
.kicker--center::before{display:none}

.display{
  font-family:var(--f-display);font-weight:400;text-transform:uppercase;
  line-height:.92;letter-spacing:0;
}
.h-xl{font-size:clamp(2.6rem,7vw,5.6rem)}
.h-lg{font-size:clamp(2rem,5vw,3.6rem)}
.h-md{font-size:clamp(1.5rem,3.2vw,2.3rem)}
.amber{color:var(--amber)}
.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--text-dim);max-width:60ch}
.muted{color:var(--zinc)}
.mono{font-family:var(--f-mono)}

.section-head{max-width:64ch;margin-bottom:clamp(2rem,4vw,3.2rem)}
.section-head.center{margin-inline:auto}
.section-head .lead{margin-top:1rem}

/* ---------- 5. BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--f-body);font-weight:700;font-size:1rem;letter-spacing:.01em;
  padding:.95rem 1.7rem;border-radius:999px;min-height:52px;
  transition:transform .25s var(--ease),background .25s,box-shadow .25s,color .25s;
  will-change:transform;text-align:center;
}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn--primary{background:var(--amber);color:var(--ink);box-shadow:var(--shadow-amber)}
.btn--primary:hover{background:var(--amber-2);transform:translateY(-2px)}
.btn--ghost{border:1.5px solid var(--line-strong);color:var(--text)}
.btn--ghost:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-2px)}
.btn--dark{background:var(--steel-3);color:var(--text)}
.btn--dark:hover{background:var(--brushed);transform:translateY(-2px)}
.btn--wa{background:#25D366;color:#0a2e17}
.btn--wa:hover{background:#2ee878;transform:translateY(-2px)}
.btn--lg{font-size:1.08rem;padding:1.1rem 2.1rem;min-height:58px}
.btn--block{width:100%}

.cta-row{display:flex;flex-wrap:wrap;gap:.9rem}
.cta-row--center{justify-content:center}

/* ---------- 6. CHIPS / TAGS ---------- */
.chips{display:flex;flex-wrap:wrap;gap:.55rem}
.chip{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--zinc);border:1px solid var(--line-strong);border-radius:999px;padding:.5rem 1rem;
}
.chip--hot{background:var(--amber);color:var(--ink);border-color:var(--amber);font-weight:600}

/* ---------- 7. HEADER / NAV ---------- */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .3s,box-shadow .3s,height .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.header.scrolled{
  background:rgba(13,17,20,.82);backdrop-filter:blur(14px);
  border-bottom-color:var(--line);box-shadow:var(--shadow-sm);height:66px;
}
.header .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}

.brand{display:flex;align-items:center;gap:.7rem;z-index:1002}
.brand-tile{
  width:42px;height:42px;border-radius:11px;flex:none;
  background:linear-gradient(145deg,var(--amber),var(--amber-deep));
  display:grid;place-items:center;box-shadow:var(--shadow-amber);
  transition:transform .3s var(--ease);
}
.brand:hover .brand-tile{transform:rotate(-6deg) scale(1.05)}
.brand-tile svg{width:22px;height:22px}
.brand-word{font-family:var(--f-display);font-size:1.55rem;text-transform:uppercase;line-height:.85;letter-spacing:0}
.brand-word em{font-style:normal;color:var(--amber)}

.nav{display:flex;align-items:center;gap:.35rem}
.nav a{
  font-weight:600;font-size:.97rem;padding:.55rem .9rem;border-radius:8px;position:relative;
  color:var(--concrete-dim);transition:color .2s;
}
.nav a::after{
  content:"";position:absolute;left:.9rem;right:.9rem;bottom:.35rem;height:2px;
  background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);
}
.nav a:hover,.nav a[aria-current="page"]{color:var(--text)}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}
.nav .btn{margin-left:.6rem;color:var(--ink)}
.nav .btn::after{display:none}

/* hamburger */
.burger{
  display:none;width:46px;height:46px;border-radius:10px;z-index:1002;
  border:1px solid var(--line-strong);position:relative;flex:none;
}
.burger span{
  position:absolute;left:12px;right:12px;height:2.5px;background:var(--concrete);border-radius:2px;
  transition:transform .3s var(--ease),opacity .2s;
}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:22px}
.burger span:nth-child(3){top:29px}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile panel */
.mobile-nav{
  position:fixed;inset:0;z-index:1001;
  background:linear-gradient(160deg,#12181B,#0D1114);
  padding:calc(var(--nav-h) + 1.5rem) var(--gutter) 2rem;
  display:flex;flex-direction:column;gap:.3rem;
  transform:translateX(100%);transition:transform .38s var(--ease);
  overflow-y:auto;
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{
  font-family:var(--f-display);text-transform:uppercase;font-size:1.9rem;
  padding:.7rem 0;border-bottom:1px solid var(--line);color:var(--concrete-dim);
  transition:color .2s,padding-left .25s;
}
.mobile-nav a:hover,.mobile-nav a[aria-current="page"]{color:var(--amber);padding-left:.5rem}
.mobile-nav .btn{
  margin-top:1.4rem;font-family:var(--f-body);text-transform:none;font-size:1.05rem;color:var(--ink);
}
.mobile-nav .m-contact{margin-top:auto;padding-top:2rem;font-family:var(--f-mono);font-size:.85rem;color:var(--zinc);display:flex;flex-direction:column;gap:.5rem}
.mobile-nav .m-contact a{font-family:var(--f-mono);font-size:.9rem;border:none;padding:0;color:var(--zinc)}
.mobile-nav .m-contact a:hover{color:var(--amber);padding-left:0}

/* ---------- 8. HERO ---------- */
.hero{
  position:relative;min-height:min(92vh,860px);display:flex;align-items:center;
  padding-top:var(--nav-h);overflow:hidden;
  background:
    radial-gradient(1100px 720px at 78% -6%,rgba(242,106,27,.16),transparent 60%),
    linear-gradient(155deg,#12181B 0%,#1B2226 48%,#0D1114 100%);
}
.hero__bg{
  position:absolute;inset:0;z-index:0;object-fit:cover;width:100%;height:100%;
  opacity:.24;filter:saturate(.8) contrast(1.05) grayscale(.15);
  mask-image:linear-gradient(90deg,transparent,#000 60%);
}
.hero::before{ /* diagonal grid */
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:58px 58px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.8),rgba(0,0,0,.1));
}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero__inner{max-width:820px}
.hero h1{font-family:var(--f-display);font-weight:400;text-transform:uppercase;
  font-size:clamp(2.8rem,8.5vw,6.2rem);line-height:.9;margin:1.3rem 0 1.2rem}
.hero h1 em{font-style:normal;color:var(--amber);display:inline-block}
.hero .lead{font-size:clamp(1.1rem,2vw,1.4rem);color:var(--concrete-dim);max-width:52ch}
.hero .cta-row{margin-top:2.2rem}
.hero__trust{
  display:flex;flex-wrap:wrap;gap:1.6rem;margin-top:2.6rem;padding-top:1.8rem;
  border-top:1px solid var(--line);
}
.hero__trust .t{display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:.95rem;color:var(--text)}
.hero__trust .t svg{width:22px;height:22px;color:var(--amber);flex:none}

/* hazard divider */
.hazard{height:14px;background:repeating-linear-gradient(45deg,var(--amber) 0 22px,var(--ink) 22px 44px);position:relative;z-index:3}
.hazard--thin{height:8px;background-size:auto;background:repeating-linear-gradient(45deg,var(--amber) 0 14px,var(--steel) 14px 28px)}

/* ---------- 9. STAT STRIP ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.stat{background:var(--steel);padding:clamp(1.4rem,3vw,2.2rem);text-align:center}
.stat__n{font-family:var(--f-display);font-size:clamp(2.2rem,5vw,3.4rem);color:var(--amber);line-height:1}
.stat__l{font-family:var(--f-mono);font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--zinc);margin-top:.5rem}

/* ---------- 10. CARDS ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(1rem,2vw,1.5rem)}
.card{
  background:var(--steel-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(1.5rem,3vw,2rem);position:relative;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
}
.card::before{content:"";position:absolute;inset:0;height:3px;background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:var(--shadow-md)}
.card:hover::before{transform:scaleX(1)}
.card__ico{width:52px;height:52px;border-radius:12px;background:var(--steel-3);display:grid;place-items:center;margin-bottom:1.1rem;transition:background .3s}
.card__ico svg{width:26px;height:26px;color:var(--amber)}
.card:hover .card__ico{background:rgba(242,106,27,.14)}
.card h3{font-size:1.3rem;margin-bottom:.6rem}
.card p{color:var(--text-dim);font-size:.98rem}
.card__link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.1rem;color:var(--amber);font-weight:700;font-size:.95rem}
.card__link svg{width:1em;height:1em;transition:transform .25s}
.card__link:hover svg{transform:translateX(4px)}

/* numbered step cards */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(1rem,2vw,1.4rem)}
.step{background:var(--steel-2);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.4rem,3vw,1.9rem);position:relative}
.step__n{font-family:var(--f-mono);font-size:.8rem;letter-spacing:.14em;color:var(--amber);text-transform:uppercase}
.step h3{font-size:1.2rem;margin:.7rem 0 .5rem}
.step p{color:var(--text-dim);font-size:.95rem}

/* ---------- 11. SPLIT / MEDIA ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split--reverse .split__media{order:-1}
.split__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3}
.split__media img{width:100%;height:100%;object-fit:cover;filter:saturate(.85) contrast(1.05)}
.split__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(13,17,20,.45))}
.media-tag{position:absolute;left:1rem;bottom:1rem;z-index:2;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--concrete);background:rgba(13,17,20,.6);padding:.4rem .7rem;border-radius:6px}

/* feature list with ticks */
.ticks{display:flex;flex-direction:column;gap:1rem;margin-top:1.6rem}
.ticks li{display:flex;gap:.9rem;align-items:flex-start}
.ticks .tick{width:26px;height:26px;border-radius:7px;background:rgba(242,106,27,.14);display:grid;place-items:center;flex:none;margin-top:2px}
.ticks .tick svg{width:15px;height:15px;color:var(--amber)}
.ticks b{display:block;font-weight:700;margin-bottom:.15rem}
.ticks span{color:var(--text-dim);font-size:.95rem}

/* ---------- 12. GALLERY ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:12px}
.gallery figure{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--line)}
.gallery img{width:100%;height:100%;object-fit:cover;filter:saturate(.82) contrast(1.06);transition:transform .6s var(--ease)}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(13,17,20,.55))}
.gallery figcaption{position:absolute;left:.8rem;bottom:.7rem;z-index:2;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--concrete)}
.gallery .g-big{grid-column:span 2;grid-row:span 2}
.gallery .g-wide{grid-column:span 2}

/* ---------- 13. CTA BANNER ---------- */
.cta-banner{position:relative;overflow:hidden;border-radius:var(--radius-lg);
  background:linear-gradient(140deg,var(--amber),var(--amber-deep));
  color:var(--ink);padding:clamp(2.4rem,6vw,4rem);text-align:center}
.cta-banner::before{content:"";position:absolute;inset:0;opacity:.16;
  background:repeating-linear-gradient(45deg,rgba(13,17,20,.9) 0 20px,transparent 20px 40px);
  mask-image:radial-gradient(circle at 50% 50%,transparent 40%,#000)}
.cta-banner *{position:relative;z-index:1}
.cta-banner h2{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(2rem,5vw,3.4rem);line-height:.95}
.cta-banner p{max-width:52ch;margin:1rem auto 0;font-size:1.1rem;font-weight:500;color:#2a1808}
.cta-banner .btn--primary{background:var(--ink);color:var(--concrete);box-shadow:var(--shadow-md)}
.cta-banner .btn--primary:hover{background:var(--steel)}
.cta-banner .btn--ghost{border-color:rgba(13,17,20,.35);color:var(--ink)}
.cta-banner .btn--ghost:hover{border-color:var(--ink);color:var(--ink);background:rgba(13,17,20,.06)}

/* ---------- 14. FOOTER ---------- */
.footer{background:var(--ink);border-top:1px solid var(--line);padding-top:clamp(3rem,6vw,4.5rem);position:relative}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:repeating-linear-gradient(45deg,var(--amber) 0 18px,transparent 18px 36px)}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:clamp(2rem,4vw,3.5rem);padding-bottom:3rem}
.footer .brand-word{font-size:1.7rem}
.footer__about{color:var(--zinc);max-width:38ch;margin-top:1.1rem;font-size:.95rem}
.footer h4{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);margin-bottom:1.1rem;font-weight:500}
.footer__links{display:flex;flex-direction:column;gap:.65rem}
.footer__links a{color:var(--concrete-dim);font-size:.97rem;width:fit-content;transition:color .2s,padding-left .2s}
.footer__links a:hover{color:var(--amber);padding-left:.35rem}
.footer__contact{display:flex;flex-direction:column;gap:.75rem;font-size:.95rem;color:var(--concrete-dim)}
.footer__contact a{display:flex;gap:.6rem;align-items:flex-start;transition:color .2s}
.footer__contact a:hover{color:var(--amber)}
.footer__contact svg{width:18px;height:18px;color:var(--amber);flex:none;margin-top:3px}
.footer__contact .vat{font-family:var(--f-mono);font-size:.85rem;color:var(--zinc)}
.footer__bar{border-top:1px solid var(--line);padding-block:1.5rem;display:flex;flex-wrap:wrap;gap:.8rem 1.5rem;justify-content:space-between;align-items:center}
.footer__bar,.footer__bar a{font-size:.85rem;color:var(--brushed)}
.footer__bar a{color:var(--zinc)}
.footer__bar a:hover{color:var(--amber)}
.footer__legal{display:flex;gap:1.2rem;flex-wrap:wrap}

/* ---------- 15. WHATSAPP FLOAT ---------- */
.wa-float{
  position:fixed;right:20px;bottom:20px;z-index:900;width:58px;height:58px;border-radius:50%;
  background:#25D366;display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.4);
  transition:transform .25s var(--ease);
}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;color:#0a2e17}

/* ---------- 16. PAGE HEADER (inner pages) ---------- */
.page-hero{
  position:relative;padding:calc(var(--nav-h) + clamp(3rem,7vw,5.5rem)) 0 clamp(2.5rem,5vw,4rem);
  background:radial-gradient(900px 500px at 85% -20%,rgba(242,106,27,.14),transparent 60%),linear-gradient(160deg,#12181B,#0D1114);
  overflow:hidden;
}
.page-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:56px 56px;mask-image:linear-gradient(180deg,rgba(0,0,0,.7),transparent)}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-family:var(--f-display);font-weight:400;text-transform:uppercase;font-size:clamp(2.4rem,6vw,4.4rem);line-height:.92;margin:1rem 0 .8rem}
.page-hero .lead{max-width:56ch}
.breadcrumb{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.1em;color:var(--brushed);display:flex;gap:.5rem;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--amber)}
.breadcrumb span{color:var(--amber)}

/* ---------- 17. INFO / CONTACT BLOCKS ---------- */
.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.info-card{background:var(--steel-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem}
.info-card h3{font-size:1.05rem;margin-bottom:.4rem;display:flex;align-items:center;gap:.6rem}
.info-card h3 svg{width:20px;height:20px;color:var(--amber)}
.info-card a,.info-card p{color:var(--text-dim);font-size:1rem}
.info-card a:hover{color:var(--amber)}
.info-card .big{font-size:1.25rem;font-weight:700;color:var(--text)}

#map{width:100%;height:clamp(320px,45vh,480px);border-radius:var(--radius-lg);border:1px solid var(--line);z-index:1;background:var(--steel-2)}
#werkgebied-map{width:100%;height:clamp(440px,64vh,660px);border-radius:var(--radius-lg);border:1px solid var(--line);z-index:1;background:var(--steel-2)}
.leaflet-container{font-family:var(--f-body)}
.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:var(--steel-2);color:var(--text)}
.leaflet-popup-content-wrapper{border:1px solid var(--line-strong);border-radius:var(--radius-sm)}
.area-label{background:var(--amber);color:var(--ink);font-family:var(--f-mono);font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.25rem .55rem;border-radius:99px;white-space:nowrap;box-shadow:var(--shadow-sm)}
.area-label--muted{background:var(--steel-3);color:var(--concrete)}

/* opening hours table */
.hours{width:100%;border-collapse:collapse}
.hours td{padding:.7rem 0;border-bottom:1px solid var(--line);font-size:.98rem}
.hours td:last-child{text-align:right;color:var(--text);font-weight:600}
.hours td:first-child{color:var(--text-dim)}
.hours tr.closed td:last-child{color:var(--brushed)}

/* QR block */
.qr-block{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;background:var(--steel-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem}
.qr-block .qr{width:120px;height:120px;background:var(--concrete);border-radius:12px;padding:8px;flex:none}
.qr-block .qr img,.qr-block .qr svg{width:100%;height:100%}

/* ---------- 18. AANVRAAG MODULE ---------- */
.form-shell{max-width:820px;margin-inline:auto}
.progress{display:flex;gap:.4rem;margin-bottom:2rem}
.progress__seg{flex:1;height:5px;border-radius:99px;background:var(--steel-3);overflow:hidden;position:relative}
.progress__seg::after{content:"";position:absolute;inset:0;background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.progress__seg.done::after{transform:scaleX(1)}
.progress__labels{display:flex;justify-content:space-between;margin-bottom:2.2rem;gap:.3rem}
.progress__labels span{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--brushed);flex:1;text-align:center;transition:color .3s}
.progress__labels span.active{color:var(--amber)}
.progress__labels span.done{color:var(--zinc)}

.fstep{display:none;animation:fadeUp .4s var(--ease)}
.fstep.active{display:block}
.fstep__head{margin-bottom:1.6rem}
.fstep__n{font-family:var(--f-mono);font-size:.8rem;letter-spacing:.14em;color:var(--amber);text-transform:uppercase}
.fstep__head h2{font-size:clamp(1.4rem,3vw,2rem);margin-top:.4rem}
.fstep__head p{color:var(--text-dim);margin-top:.5rem}

.field{margin-bottom:1.3rem}
.field > label{display:block;font-weight:600;margin-bottom:.5rem;font-size:.95rem}
.field .hint{font-size:.85rem;color:var(--brushed);font-weight:400}
.field input[type=text],.field input[type=email],.field input[type=tel],.field textarea,.field select{
  width:100%;background:var(--ink);border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);
  padding:.9rem 1rem;color:var(--text);font-family:var(--f-body);font-size:1rem;transition:border-color .2s,background .2s;
}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--amber);background:#0a0e11}
.field input.invalid,.field textarea.invalid{border-color:#e5484d}
.field .error{color:#ff7b7f;font-size:.82rem;margin-top:.4rem;display:none}
.field .error.show{display:block}

/* option grid (radio cards) */
.opt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem}
.opt{position:relative;cursor:pointer}
.opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.opt__box{
  border:1.5px solid var(--line-strong);border-radius:var(--radius-sm);padding:1.1rem;height:100%;
  display:flex;flex-direction:column;gap:.4rem;transition:border-color .2s,background .2s,transform .2s;
}
.opt__box svg{width:28px;height:28px;color:var(--zinc);transition:color .2s}
.opt__box b{font-size:1rem}
.opt__box small{color:var(--text-dim);font-size:.85rem;line-height:1.4}
.opt:hover .opt__box{border-color:var(--brushed)}
.opt input:checked + .opt__box{border-color:var(--amber);background:rgba(242,106,27,.08);transform:translateY(-2px)}
.opt input:checked + .opt__box svg{color:var(--amber)}
.opt input:focus-visible + .opt__box{outline:2px solid var(--amber);outline-offset:2px}

/* photo upload */
.dropzone{
  border:2px dashed var(--line-strong);border-radius:var(--radius);padding:2.2rem 1.5rem;text-align:center;
  cursor:pointer;transition:border-color .2s,background .2s;background:var(--steel-2);
}
.dropzone:hover,.dropzone.drag{border-color:var(--amber);background:rgba(242,106,27,.06)}
.dropzone svg{width:40px;height:40px;color:var(--amber);margin-bottom:.7rem}
.dropzone b{display:block;font-size:1.05rem}
.dropzone small{color:var(--brushed);display:block;margin-top:.3rem}
.previews{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.7rem;margin-top:1.1rem}
.preview{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.preview img{width:100%;height:100%;object-fit:cover}
.preview button{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:6px;background:rgba(13,17,20,.8);color:#fff;display:grid;place-items:center;font-size:14px;line-height:1}
.preview button:hover{background:#e5484d}

/* form nav */
.fnav{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.fnav .btn--back{visibility:hidden}
.fnav.show-back .btn--back{visibility:visible}

/* review summary */
.review{background:var(--steel-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}
.review dl{display:grid;grid-template-columns:auto 1fr;gap:.7rem 1.5rem}
.review dt{font-family:var(--f-mono);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brushed);padding-top:2px}
.review dd{color:var(--text);font-weight:600}
.review .rev-thumbs{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.3rem}
.review .rev-thumbs img{width:52px;height:52px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}

/* success / notice */
.form-success{display:none;text-align:center;padding:2rem 0;animation:fadeUp .4s var(--ease)}
.form-success.show{display:block}
.form-success .ok{width:80px;height:80px;border-radius:50%;background:rgba(242,106,27,.14);display:grid;place-items:center;margin:0 auto 1.5rem}
.form-success .ok svg{width:40px;height:40px;color:var(--amber)}
.notice{background:rgba(242,106,27,.08);border:1px solid rgba(242,106,27,.3);border-left:3px solid var(--amber);border-radius:var(--radius-sm);padding:1rem 1.2rem;font-size:.9rem;color:var(--text-dim);margin-top:1.5rem}
.notice b{color:var(--amber)}

/* aside contact rail */
.form-aside{background:var(--steel-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;position:sticky;top:calc(var(--nav-h) + 1rem)}
.form-aside h3{font-size:1.1rem;margin-bottom:.4rem}
.form-aside p{color:var(--text-dim);font-size:.92rem;margin-bottom:1.2rem}

/* ---------- 19. FAQ ---------- */
.faq{max-width:820px;margin-inline:auto;display:flex;flex-direction:column;gap:.7rem}
.faq details{background:var(--steel-2);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.faq summary{padding:1.2rem 1.4rem;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;list-style:none;font-size:1.05rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--f-mono);font-size:1.5rem;color:var(--amber);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 1.4rem 1.3rem;color:var(--text-dim)}

/* ---------- 20. COOKIE BANNER ---------- */
.cookie{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:1100;max-width:520px;
  background:var(--steel-2);border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:1.3rem 1.4rem;box-shadow:var(--shadow-lg);transform:translateY(150%);transition:transform .45s var(--ease);
}
.cookie.show{transform:translateY(0)}
.cookie p{font-size:.9rem;color:var(--text-dim);margin-bottom:1rem}
.cookie p a{color:var(--amber);text-decoration:underline}
.cookie__row{display:flex;gap:.7rem;flex-wrap:wrap}
.cookie .btn{min-height:44px;padding:.7rem 1.3rem;font-size:.92rem}

/* ---------- 21. ANIMATIONS ---------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.4s}

.hero .anim{opacity:0;transform:translateY(22px);animation:fadeUp .8s var(--ease) forwards}
.hero .anim.d1{animation-delay:.1s}
.hero .anim.d2{animation-delay:.25s}
.hero .anim.d3{animation-delay:.4s}
.hero .anim.d4{animation-delay:.55s}
.hero .anim.d5{animation-delay:.7s}

/* ---------- 22. RESPONSIVE ---------- */
@media (max-width:1024px){
  .footer__grid{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1 / -1}
}
@media (max-width:900px){
  .nav{display:none}
  .burger{display:block}
  .split{grid-template-columns:1fr}
  .split--reverse .split__media{order:0}
  .stats{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}
  .gallery .g-big{grid-column:span 2;grid-row:span 1}
  .form-layout{grid-template-columns:1fr !important}
  .form-aside{position:static}
}
@media (max-width:560px){
  body{font-size:16px}
  .stats{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr;grid-auto-rows:200px}
  .gallery .g-big,.gallery .g-wide{grid-column:span 1;grid-row:span 1}
  .footer__grid{grid-template-columns:1fr}
  .cta-row .btn{width:100%}
  .progress__labels span{font-size:.6rem}
  .wa-float{width:52px;height:52px}
}

/* ---------- 23. REDUCED MOTION ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
  .hero .anim{opacity:1;transform:none}
}

/* ---------- 24. PROSE (policy / text pages) ---------- */
.prose{max-width:76ch;margin-inline:auto}
.prose h2{font-size:clamp(1.3rem,2.6vw,1.8rem);margin:2.4rem 0 .8rem;color:var(--text)}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.15rem;margin:1.6rem 0 .5rem}
.prose p{color:var(--text-dim);margin-bottom:1rem}
.prose ul{margin:0 0 1.2rem 1.2rem;list-style:disc}
.prose ul li{color:var(--text-dim);margin-bottom:.5rem;padding-left:.3rem}
.prose a{color:var(--amber);text-decoration:underline}
.prose strong{color:var(--text)}
.prose .updated{font-family:var(--f-mono);font-size:.8rem;color:var(--brushed);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2rem}

/* utils */
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mb-0{margin-bottom:0}
.hide{display:none !important}
.form-layout{display:grid;grid-template-columns:1fr 320px;gap:2.5rem;align-items:start}
