/* =========================================================
   Sanne Bruidsfotografie — modern, strak, zwart/wit
   ========================================================= */
:root{
  --ink:#0b0b0b;
  --paper:#ffffff;
  --muted:#737373;
  --line:#e7e7e7;
  --line-strong:#111;
  --maxw:1280px;
  --gut:clamp(20px,5vw,64px);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}

/* ---------- Typografie ---------- */
h1,h2,h3{margin:0;font-weight:800;letter-spacing:-.02em;line-height:1.02}
.kicker{
  display:inline-block;font-size:12px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);margin:0 0 18px
}
.display{font-size:clamp(2.6rem,7vw,6rem);font-weight:900;letter-spacing:-.035em;line-height:.98}
.section-title{font-size:clamp(1.9rem,4vw,3.2rem);font-weight:800}
p{margin:0 0 1.1em}
.lead{font-size:clamp(1.1rem,1.6vw,1.35rem);line-height:1.6}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--line)
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand img{height:44px;width:auto}
.site-nav{display:flex;align-items:center;gap:34px}
.site-nav a{
  font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  position:relative;padding:4px 0
}
.site-nav a:not(.nav-cta)::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--ink);
  transition:right .28s ease
}
.site-nav a:not(.nav-cta):hover::after{right:0}
.site-nav a.nav-cta{
  background:var(--ink);color:#fff;padding:11px 20px;letter-spacing:.12em
}
.site-nav a.nav-cta:hover{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1px var(--ink)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;padding:9px}
.nav-toggle span{display:block;height:2px;background:var(--ink);margin:5px 0;transition:.3s}

/* ---------- Hero ---------- */
.hero{padding:clamp(60px,11vw,140px) 0 0}
.hero .kicker{margin-bottom:24px}
.hero .display{max-width:14ch}
.hero .lead{max-width:46ch;margin-top:28px;color:#2a2a2a}
.hero-actions{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:14px;
  letter-spacing:.06em;padding:15px 28px;border:1px solid var(--ink);background:var(--ink);color:#fff;
  transition:.2s;cursor:pointer
}
.btn:hover{background:#fff;color:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.hero-figure{margin-top:clamp(48px,8vw,96px)}
.hero-figure img{width:100%;height:clamp(320px,62vh,720px);object-fit:cover;filter:grayscale(1);transition:filter .8s ease}
.hero-figure:hover img{filter:grayscale(0)}

/* ---------- Sectie-ritme ---------- */
section{padding:clamp(64px,10vw,128px) 0}
.section-head{max-width:60ch;margin-bottom:clamp(36px,5vw,64px)}
.section-head .lead{color:#444}

/* ---------- Werk / portfolio ---------- */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.work-item{position:relative;overflow:hidden;background:#f2f2f2;aspect-ratio:4/5}
.work-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.02);transition:transform .9s ease,filter .6s ease}
.work-item:hover img{filter:grayscale(0);transform:scale(1.04)}
.work-item figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:18px 20px;color:#fff;font-weight:600;
  font-size:15px;letter-spacing:.01em;background:linear-gradient(to top,rgba(0,0,0,.72),rgba(0,0,0,0));
  opacity:0;transform:translateY(8px);transition:.35s
}
.work-item:hover figcaption{opacity:1;transform:none}

/* ---------- Over Sanne ---------- */
.about{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,84px);align-items:center}
.about-portrait img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:grayscale(1)}
.about .lead{font-weight:500}
.about-note{
  margin-top:30px;padding:22px 26px;border-left:3px solid var(--ink);background:#fafafa;
  font-size:.97rem;color:#333
}

/* ---------- Werkwijze ---------- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,48px)}
.step{border-top:2px solid var(--ink);padding-top:22px}
.step::before{
  counter-increment:step;content:counter(step,decimal-leading-zero);
  display:block;font-weight:900;font-size:1.4rem;letter-spacing:-.02em;margin-bottom:14px
}
.step p{margin:0;color:#333;font-size:.98rem}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px)}
.quote{border:1px solid var(--line);padding:34px 30px}
.quote p{font-size:1.02rem;line-height:1.6;color:#1c1c1c}
.quote cite{display:block;margin-top:18px;font-style:normal;font-weight:700;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
.section--invert{background:var(--ink);color:#fff}
.section--invert .quote{border-color:#2c2c2c}
.section--invert .quote p{color:#eaeaea}
.section--invert .section-head .lead{color:#bdbdbd}

/* ---------- Blog teasers ---------- */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,38px)}
.post-card{display:block;group:card}
.post-card .thumb{overflow:hidden;aspect-ratio:3/2;background:#f2f2f2}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15);transition:transform .8s ease,filter .6s}
.post-card:hover .thumb img{transform:scale(1.05);filter:grayscale(0)}
.post-card h3{margin:18px 0 8px;font-size:1.18rem;font-weight:700;letter-spacing:-.01em;line-height:1.2}
.post-card p{color:#555;font-size:.95rem;margin:0}
.post-card .more{display:inline-block;margin-top:14px;font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-bottom:2px solid var(--ink);padding-bottom:2px}
.center-cta{text-align:center;margin-top:clamp(40px,6vw,68px)}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,80px)}
.contact-info p{color:#444}
.contact-info a{border-bottom:1px solid var(--ink)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.field input,.field textarea{
  width:100%;padding:14px 16px;border:1px solid #cfcfcf;background:#fff;font:inherit;color:var(--ink);
  transition:border-color .2s
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.field textarea{resize:vertical;min-height:150px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.85rem;color:var(--muted);margin-top:6px}
.alert{padding:16px 20px;margin-bottom:24px;border:1px solid var(--ink);font-weight:500}
.alert--ok{background:#0b0b0b;color:#fff}
.alert--err{background:#fff;border-color:#b00020;color:#b00020}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#fff;padding:clamp(56px,8vw,96px) 0 48px}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:30px;text-align:center}
.footer-brand img{height:60px;width:auto;filter:invert(0)}
.footer-nav{display:flex;flex-wrap:wrap;gap:26px;justify-content:center}
.footer-nav a{font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#cfcfcf}
.footer-nav a:hover{color:#fff}
.footer-meta{font-size:13px;color:#8a8a8a;margin:0;letter-spacing:.04em}

/* ---------- Blog-overzicht & artikel ---------- */
.page-hero{padding:clamp(54px,8vw,110px) 0 clamp(30px,4vw,48px);border-bottom:1px solid var(--line)}
.page-hero .display{font-size:clamp(2.2rem,5.5vw,4.4rem)}
.article{padding:clamp(40px,6vw,80px) 0}
.article-cover{margin:0 auto clamp(30px,5vw,56px);text-align:center}
.article-cover img{width:100%;max-height:78vh;object-fit:contain;margin:0 auto}
.article-body{max-width:68ch;margin:0 auto;font-size:1.12rem;line-height:1.8}
.article-body p{margin:0 0 1.3em}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:clamp(36px,5vw,64px)}
.gallery a{display:block;overflow:hidden;cursor:zoom-in;background:#f1f1f1;aspect-ratio:4/5}
.gallery a img{width:100%;height:100%;object-fit:cover;filter:grayscale(.12);transition:transform .7s ease,filter .5s}
.gallery a:hover img{transform:scale(1.05);filter:grayscale(0)}

/* Lightbox */
.lb{position:fixed;inset:0;z-index:1000;background:rgba(8,8,8,.97);display:none;align-items:center;justify-content:center;overscroll-behavior:contain}
.lb.open{display:flex}
.lb-stage{max-width:94vw;max-height:88vh;overflow:hidden}
.lb img{display:block;max-width:94vw;max-height:88vh;object-fit:contain;cursor:zoom-in;user-select:none;-webkit-user-drag:none;transition:transform .25s ease}
.lb.zoomed img{cursor:zoom-out;transition:none}
.lb-btn{position:absolute;background:none;border:0;color:#fff;cursor:pointer;line-height:1;opacity:.8;transition:opacity .2s;font-family:inherit}
.lb-btn:hover{opacity:1}
.lb-close{top:14px;right:18px;font-size:40px;font-weight:300}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);font-size:34px;padding:18px 22px}
.lb-prev{left:6px}.lb-next{right:6px}
.lb-count{position:absolute;bottom:16px;left:0;right:0;text-align:center;color:#9a9a9a;font-size:12px;letter-spacing:.18em}
@media(max-width:680px){
  .gallery{grid-template-columns:1fr 1fr;gap:6px}
  .lb-prev,.lb-next{font-size:26px;padding:12px 14px}
}
.back-link{display:inline-block;margin:8px 0 0;font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.article-nav{display:flex;justify-content:space-between;gap:20px;border-top:1px solid var(--line);margin-top:clamp(48px,7vw,90px);padding-top:30px}
.article-nav a{font-weight:600;max-width:45%}
.article-nav .lbl{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}

/* ---------- Responsief ---------- */
@media(max-width:900px){
  .work-grid,.steps,.quotes,.posts-grid{grid-template-columns:repeat(2,1fr)}
  .about,.contact{grid-template-columns:1fr;gap:36px}
  .about-portrait{order:-1}
}
@media(max-width:680px){
  .nav-toggle{display:block;z-index:60}
  .site-nav{
    position:fixed;inset:0 0 0 auto;width:min(78vw,320px);background:#fff;flex-direction:column;
    align-items:flex-start;justify-content:center;gap:28px;padding:0 38px;transform:translateX(100%);
    transition:transform .35s ease;box-shadow:-20px 0 60px rgba(0,0,0,.12)
  }
  body.nav-open .site-nav{transform:none}
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .work-grid{grid-template-columns:1fr 1fr;gap:8px}
  .form-row{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr}
}
