/* ================================================================
   Groepspraktijk Uitzicht — designsysteem
   Cinematografisch · uitnodigend · verhelderend
   Kleuren staan als CSS-variabelen: pas ze hier één keer aan.
   ================================================================ */

/* ---------------- lettertypes (zelf gehost — privacyvriendelijk) ---------------- */
@font-face{font-family:"Inter";font-style:normal;font-weight:100 900;font-display:swap;src:url("../fonts/inter-latin-wght-normal.woff2") format("woff2");}
@font-face{font-family:"Inter";font-style:italic;font-weight:100 900;font-display:swap;src:url("../fonts/inter-latin-wght-italic.woff2") format("woff2");}
@font-face{font-family:"Fraunces";font-style:normal;font-weight:100 900;font-display:swap;src:url("../fonts/fraunces-latin-opsz-normal.woff2") format("woff2");}
@font-face{font-family:"Fraunces";font-style:italic;font-weight:100 900;font-display:swap;src:url("../fonts/fraunces-latin-opsz-italic.woff2") format("woff2");}

:root{
  /* --- Praktijkkleuren (navy-petrol uit logo & uithangbord) --- */
  --petrol:       #1f3a52;
  --petrol-700:   #172c3f;
  --petrol-900:   #0f1f30;
  --petrol-300:   #5d7d92;
  --petrol-100:   #d3dee2;

  /* --- Warme terracotta (accent & afspraak-knop) --- */
  --clay:         #bf6f43;
  --clay-cta:     #b05c30;
  --clay-600:     #97481f;
  --clay-100:     #ecccb4;

  /* --- Zacht salie-groen (knoppen & planten) --- */
  --sage:         #8ba78f;
  --sage-cta:     #7d9a82;
  --sage-100:     #d8e1d6;

  /* --- Poederblauw (zachte themapanelen) --- */
  --mistblue:     #c4d6d8;
  --mistblue-100: #dde8e7;

  /* --- Warme neutralen --- */
  --sand:         #f4efe4;
  --sand-2:       #ebe2d0;
  --mist:         #fbf9f3;
  --white:        #ffffff;

  /* --- Tekst --- */
  --ink:          #2a2723;
  --ink-soft:     #5b554c;
  --gold:         #c79f54;

  /* --- Vorm --- */
  --radius:       16px;
  --radius-lg:    26px;
  --radius-sm:    9px;
  --shadow:       0 18px 50px -24px rgba(14,39,45,.45);
  --shadow-soft:  0 10px 34px -20px rgba(14,39,45,.40);
  --maxw:         1220px;
  --ease:         cubic-bezier(.22,.61,.36,1);

  --ff-serif: "Fraunces", Georgia, "Times New Roman", serif;
  --ff-sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* ---------------- reset ---------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--ff-sans);
  color:var(--ink);
  background:var(--sand);
  line-height:1.68;
  font-size:1.0625rem;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
ul{list-style:none;}

/* ---------------- typografie ---------------- */
h1,h2,h3,h4{
  font-family:var(--ff-serif);
  font-weight:430;
  line-height:1.12;
  letter-spacing:-.015em;
  color:var(--petrol-900);
}
.display{
  font-size:clamp(2.7rem,6.2vw,5rem);
  font-weight:430;
  line-height:1.04;
}
h2{font-size:clamp(2rem,3.8vw,3.05rem);}
h3{font-size:clamp(1.35rem,2.2vw,1.7rem);}
p{margin-bottom:1rem;}
p:last-child{margin-bottom:0;}

.eyebrow{
  font-family:var(--ff-sans);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--clay);
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  margin-bottom:1.1rem;
}
.eyebrow::before{
  content:"";
  width:26px;height:1.5px;
  background:var(--clay);
  display:inline-block;
}
.eyebrow.center{justify-content:center;}
.lead{
  font-size:clamp(1.1rem,1.6vw,1.32rem);
  color:var(--ink-soft);
  line-height:1.6;
}
em,.serif-em{font-family:var(--ff-serif);font-style:italic;}

/* ---------------- layout ---------------- */
.container{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:clamp(1.2rem,4vw,2.6rem);
}
.section{padding:clamp(4.2rem,9vw,8rem) 0;}
.section.tight{padding:clamp(3rem,6vw,5rem) 0;}
.bg-sand{background:var(--sand);}
.bg-sand-2{background:var(--sand-2);}
.bg-mist{background:var(--mist);}
.bg-petrol{background:var(--petrol);color:var(--sand);}
.bg-petrol h1,.bg-petrol h2,.bg-petrol h3{color:var(--mist);}
.bg-petrol .lead{color:var(--petrol-100);}
.center{text-align:center;}
.measure{max-width:62ch;}
.measure.center{margin-inline:auto;}

/* ---------------- knoppen ---------------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-weight:600;font-size:.97rem;
  padding:.95rem 1.7rem;
  border-radius:100px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease);
  white-space:nowrap;
}
.btn svg{width:17px;height:17px;flex-shrink:0;}
.btn-primary{background:var(--clay-cta);color:var(--mist);box-shadow:0 12px 26px -14px rgba(171,79,43,.9);}
.btn-primary:hover{background:var(--clay-600);transform:translateY(-3px);box-shadow:0 18px 32px -14px rgba(171,79,43,.95);}
.btn-petrol{background:var(--petrol);color:var(--mist);}
.btn-petrol:hover{background:var(--petrol-700);transform:translateY(-3px);}
.btn-ghost{background:transparent;color:var(--petrol-900);border:1.5px solid rgba(29,74,85,.30);}
.btn-ghost:hover{border-color:var(--petrol);background:rgba(29,74,85,.06);transform:translateY(-3px);}
.btn-light{background:var(--mist);color:var(--petrol-900);}
.btn-light:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);}
.btn-outline-light{background:transparent;color:var(--mist);border:1.5px solid rgba(251,249,243,.4);}
.btn-outline-light:hover{background:rgba(251,249,243,.12);transform:translateY(-3px);}
.btn-lg{padding:1.1rem 2.1rem;font-size:1.02rem;}

.textlink{
  display:inline-flex;align-items:center;gap:.45rem;
  font-weight:600;color:var(--clay);
  border-bottom:1.5px solid transparent;
  transition:gap .25s var(--ease),border-color .25s var(--ease);
}
.textlink:hover{gap:.8rem;border-color:var(--clay);}
.textlink svg{width:15px;height:15px;}

/* ---------------- header ---------------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:90;
  transition:background .35s var(--ease),box-shadow .35s var(--ease),padding .35s var(--ease);
  padding:.55rem 0;
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;}
.site-header.scrolled{
  background:rgba(251,249,243,.93);
  backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(29,74,85,.10);
}

.brand{display:flex;align-items:center;gap:.7rem;}
.brand .mark{width:46px;height:46px;flex-shrink:0;transition:transform .4s var(--ease);}
.brand:hover .mark{transform:rotate(-6deg);}
.brand .logo{height:clamp(44px,6.5vw,58px);width:auto;display:block;transition:transform .4s var(--ease);}
.brand:hover .logo{transform:scale(1.03);}
.brand .logo-donker{display:none;}
.site-header.scrolled .brand .logo-licht{display:none;}
.site-header.scrolled .brand .logo-donker{display:block;}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-text .kicker{
  font-size:.62rem;font-weight:600;letter-spacing:.27em;text-transform:uppercase;
  color:var(--clay);margin-bottom:.22rem;
}
.brand-text .name{
  font-family:var(--ff-serif);font-size:1.5rem;font-weight:500;
  color:var(--petrol-900);letter-spacing:-.01em;
}
/* lichte variant boven donkere hero */
.site-header:not(.scrolled) .brand-text .name{color:var(--mist);}
.site-header:not(.scrolled) .brand-text .kicker{color:var(--clay-100);}
.site-header:not(.scrolled) .nav-links a{color:var(--mist);}
.site-header:not(.scrolled) .nav-links a:hover{color:var(--clay-100);}
.site-header:not(.scrolled) .nav-toggle span{background:var(--mist);}
.site-header.light-nav:not(.scrolled) .brand-text .name{color:var(--petrol-900);}
.site-header.light-nav:not(.scrolled) .brand-text .kicker{color:var(--clay);}
.site-header.light-nav:not(.scrolled) .nav-links a{color:var(--petrol-900);}
.site-header.light-nav:not(.scrolled) .nav-toggle span{background:var(--petrol-900);}

.main-nav{display:flex;align-items:center;gap:2rem;}
.nav-links{display:flex;align-items:center;gap:1.7rem;}
.nav-links a{
  font-size:.95rem;font-weight:500;color:var(--petrol-900);
  position:relative;padding:.3rem 0;transition:color .2s var(--ease);
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--clay);transition:width .28s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:var(--clay);}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;z-index:120;}
.nav-toggle span{width:25px;height:2px;background:var(--petrol-900);border-radius:2px;transition:.3s var(--ease);}
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);}

/* dropdownmenu */
.has-drop{position:relative;}
.drop-trigger{cursor:pointer;}
.drop-trigger .car{
  display:inline-block;width:6px;height:6px;margin-left:.4rem;vertical-align:2px;
  border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;
  transform:rotate(45deg);transition:transform .25s var(--ease);
}
.drop{
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(14px);
  background:var(--mist);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:.55rem;min-width:230px;display:flex;flex-direction:column;gap:.12rem;
  opacity:0;visibility:hidden;transition:opacity .26s var(--ease),transform .26s var(--ease);
  border:1px solid rgba(31,58,82,.09);
}
.drop::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(8px);}
.drop li a{
  display:block;padding:.6rem .9rem;border-radius:9px;
  font-size:.93rem;color:var(--petrol-900)!important;
}
.drop li a::after{display:none;}
.drop li a:hover{background:var(--sand-2);color:var(--clay)!important;}

/* ---------------- hero ---------------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  padding:8rem 0 clamp(3rem,6vw,5.5rem);
  overflow:hidden;
}
.hero-media{position:absolute;inset:0;z-index:-2;}
.hero-media img{width:100%;height:100%;object-fit:cover;}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(14,39,45,.55) 0%,rgba(14,39,45,.05) 32%,rgba(14,39,45,.30) 62%,rgba(14,39,45,.93) 100%);
}
.hero-inner{max-width:50rem;position:relative;}
.hero h1{color:var(--mist);margin-bottom:1.4rem;}
.hero .lead{color:rgba(251,249,243,.92);max-width:40ch;margin-bottom:2rem;}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;}
.hero-scroll{
  position:absolute;bottom:1.7rem;left:50%;transform:translateX(-50%);
  color:rgba(251,249,243,.7);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
}
.hero-scroll .line{width:1.5px;height:46px;background:linear-gradient(rgba(251,249,243,.7),transparent);animation:scrolldrop 2.4s var(--ease) infinite;}
@keyframes scrolldrop{0%{transform:scaleY(0);transform-origin:top;}45%{transform:scaleY(1);transform-origin:top;}55%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

.hero-trust{
  display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:2.3rem;
  padding-top:1.6rem;border-top:1px solid rgba(251,249,243,.22);
}
.hero-trust span{
  display:flex;align-items:center;gap:.5rem;
  font-size:.88rem;color:rgba(251,249,243,.9);font-weight:500;
}
.hero-trust svg{width:18px;height:18px;color:var(--clay-100);}

/* compacte paginahero */
.pagehero{
  position:relative;
  padding:11rem 0 clamp(3.4rem,7vw,6rem);
  background:var(--petrol);overflow:hidden;
}
.pagehero.has-img .pagehero-media{position:absolute;inset:0;z-index:0;}
.pagehero.has-img .pagehero-media img{width:100%;height:100%;object-fit:cover;}
.pagehero.has-img .pagehero-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(14,39,45,.92) 38%,rgba(14,39,45,.55) 100%);
}
.pagehero .container{position:relative;z-index:1;}
.pagehero h1{color:var(--mist);margin-bottom:1.1rem;max-width:20ch;}
.pagehero .lead{color:var(--petrol-100);max-width:54ch;}
.pagehero .display{font-size:clamp(2.4rem,5vw,4rem);}
.crumb{
  font-size:.82rem;color:var(--petrol-300);margin-bottom:1.4rem;
  display:flex;gap:.5rem;align-items:center;
}
.crumb a:hover{color:var(--clay-100);}
.pagehero::before{
  content:"";position:absolute;right:-90px;top:-90px;width:340px;height:340px;
  border:1.5px solid rgba(92,138,148,.30);border-radius:50%;
}

/* ---------------- horizon-motief ---------------- */
.horizon{display:block;width:120px;height:auto;color:var(--clay);margin:0 0 1.6rem;}
.horizon.center{margin-inline:auto;}

/* ---------------- grids ---------------- */
.grid{display:grid;gap:1.6rem;}
.split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,4.5rem);align-items:center;
}
.split.wide-text{grid-template-columns:1.05fr .95fr;}

/* ---------------- intro / tekstblok ---------------- */
.section-head{max-width:60ch;margin-bottom:3rem;}
.section-head.center{margin-inline:auto;text-align:center;}

/* ---------------- beeldframe ---------------- */
.framed{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);position:relative;
}
.framed img{width:100%;height:100%;object-fit:cover;}
.img-tall{aspect-ratio:4/5;}
.img-wide{aspect-ratio:3/2;}
.img-square{aspect-ratio:1/1;}
.stack-imgs{position:relative;}
.stack-imgs .badge-note{
  position:absolute;bottom:-26px;left:-26px;
  background:var(--clay);color:var(--mist);
  padding:1.2rem 1.5rem;border-radius:var(--radius);
  max-width:230px;box-shadow:var(--shadow);
}
.badge-note .big{font-family:var(--ff-serif);font-size:2.2rem;line-height:1;display:block;margin-bottom:.2rem;}
.badge-note .sub{font-size:.85rem;line-height:1.4;}

/* ---------------- discipline-/aanbodkaarten ---------------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.5rem;}
.card{
  background:var(--mist);border-radius:var(--radius);
  padding:2rem 1.9rem;box-shadow:var(--shadow-soft);
  border:1px solid rgba(29,74,85,.07);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
  display:flex;flex-direction:column;height:100%;
}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow);}
.card .ico{
  width:52px;height:52px;border-radius:13px;
  background:var(--petrol-100);color:var(--petrol);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem;
}
.card .ico svg{width:25px;height:25px;}
.card h3{margin-bottom:.6rem;font-size:1.28rem;}
.card p{font-size:.96rem;color:var(--ink-soft);margin-bottom:1.1rem;}
.card .textlink{margin-top:auto;}
.card.accent .ico{background:var(--clay-100);color:var(--clay-600);}
.card.sage .ico{background:var(--sage-100);color:var(--petrol-700);}

/* ---------------- thema-grid (klachten) ---------------- */
.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:1.1rem;}
.theme{
  background:var(--mist);border-radius:var(--radius-sm);
  padding:1.5rem 1.5rem 1.4rem;
  border:1px solid rgba(29,74,85,.08);
  border-left:3px solid var(--sage);
  transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.theme:hover{transform:translateY(-4px);border-left-color:var(--clay);box-shadow:var(--shadow-soft);}
.theme h3{font-size:1.12rem;margin-bottom:.45rem;}
.theme p{font-size:.9rem;color:var(--ink-soft);margin:0;}

/* ---------------- aanbod-rij (discipline detail) ---------------- */
.offer-row{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,4rem);
  align-items:center;padding:clamp(2.4rem,5vw,4rem) 0;
  border-bottom:1px solid rgba(29,74,85,.13);
}
.offer-row:last-child{border-bottom:none;}
.offer-row.flip .offer-media{order:2;}
.offer-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;}
.offer-media img{width:100%;height:100%;object-fit:cover;}
.offer-body .num{
  font-family:var(--ff-serif);font-size:1rem;color:var(--clay);
  display:block;margin-bottom:.5rem;font-style:italic;
}
.offer-body h2{margin-bottom:.9rem;}
.tag-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.2rem 0;}
.tag{
  font-size:.8rem;font-weight:600;color:var(--petrol-700);
  background:var(--petrol-100);padding:.4rem .85rem;border-radius:100px;
}

/* ---------------- team ---------------- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:1.7rem;align-items:stretch;}
.member{
  background:var(--mist);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-soft);border:1px solid rgba(29,74,85,.07);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
  display:flex;flex-direction:column;height:100%;
}
.member:hover{transform:translateY(-7px);box-shadow:var(--shadow);}
.member-photo{aspect-ratio:1/1;overflow:hidden;background:var(--petrol-100);}
.member-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.member:hover .member-photo img{transform:scale(1.05);}
.member-photo.mono{
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(140deg,var(--mistblue) 0%,var(--mistblue-100) 100%);
}
.member-photo.mono span{font-family:var(--ff-serif);font-size:3.6rem;color:var(--petrol);font-style:italic;}
.team-group-title{
  font-family:var(--ff-serif);font-size:clamp(1.5rem,2.6vw,2.1rem);
  color:var(--petrol-900);margin-bottom:1.6rem;
  display:flex;align-items:center;gap:1rem;
}
.team-group-title::after{content:"";flex:1;height:1px;background:rgba(31,58,82,.16);}
.member-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1;min-width:0;}
.member-body h3{font-size:1.3rem;margin-bottom:.15rem;}
.member-body .role{font-size:.85rem;font-weight:600;color:var(--clay);margin-bottom:.7rem;text-transform:uppercase;letter-spacing:.06em;}
.member-body p{font-size:.93rem;color:var(--ink-soft);}
.member-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem;}
.member-tags span{font-size:.74rem;background:var(--sand-2);padding:.28rem .65rem;border-radius:100px;color:var(--petrol-700);}

/* uitgebreid teamprofiel */
.profile{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.6rem,4vw,3.4rem);
  align-items:start;padding:clamp(2.4rem,5vw,3.8rem) 0;
  border-bottom:1px solid rgba(29,74,85,.13);
}
.profile:last-child{border-bottom:none;}
.profile.flip .profile-photo{order:2;}
.profile-photo{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5;position:sticky;top:6rem;}
.profile-photo img{width:100%;height:100%;object-fit:cover;}
.profile h2{font-size:clamp(1.8rem,3vw,2.5rem);margin-bottom:.2rem;}
.profile .role{color:var(--clay);font-weight:600;margin-bottom:1.2rem;}
.quote-line{
  font-family:var(--ff-serif);font-style:italic;font-size:1.15rem;
  color:var(--petrol);border-left:3px solid var(--clay);
  padding-left:1.1rem;margin:1.3rem 0;
}
.profile-contact{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.4rem;}
.chip{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.88rem;font-weight:500;
  background:var(--sand);border:1px solid rgba(29,74,85,.13);
  padding:.55rem 1rem;border-radius:100px;transition:.25s var(--ease);
}
.chip:hover{background:var(--petrol);color:var(--mist);border-color:var(--petrol);}
.chip svg{width:15px;height:15px;}

/* ---------------- proces / stappen ---------------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;counter-reset:step;}
.step{position:relative;padding-top:1rem;}
.step .n{
  font-family:var(--ff-serif);font-size:3.2rem;color:var(--clay);
  line-height:1;display:block;margin-bottom:.6rem;opacity:.9;
}
.step h3{font-size:1.2rem;margin-bottom:.45rem;}
.step p{font-size:.95rem;color:var(--ink-soft);}
.bg-petrol .step .n{color:var(--gold);}
.bg-petrol .step p{color:var(--petrol-100);}

/* ---------------- statistiek ---------------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem;}
.stat{text-align:center;}
.stat .big{font-family:var(--ff-serif);font-size:clamp(2.6rem,5vw,3.8rem);color:var(--clay);line-height:1;}
.bg-petrol .stat .big{color:var(--gold);}
.stat .lbl{font-size:.92rem;color:var(--ink-soft);margin-top:.4rem;}
.bg-petrol .stat .lbl{color:var(--petrol-100);}

/* ---------------- quote / getuigenis ---------------- */
.pullquote{max-width:50rem;margin-inline:auto;text-align:center;}
.pullquote .mark{font-family:var(--ff-serif);font-size:5rem;color:var(--clay);line-height:.4;display:block;height:2.3rem;}
.pullquote blockquote{
  font-family:var(--ff-serif);font-size:clamp(1.5rem,3vw,2.3rem);
  line-height:1.34;color:var(--petrol-900);font-style:italic;margin:1rem 0 1.4rem;
}
.bg-petrol .pullquote blockquote{color:var(--mist);}
.pullquote cite{font-style:normal;font-weight:600;color:var(--clay);font-size:.95rem;}

/* ---------------- CTA-band ---------------- */
.cta-band{position:relative;overflow:hidden;background:var(--petrol-900);color:var(--mist);}
.cta-band .cta-media{position:absolute;inset:0;opacity:.20;}
.cta-band .cta-media img{width:100%;height:100%;object-fit:cover;}
.cta-band .container{position:relative;z-index:1;text-align:center;}
.cta-band h2{color:var(--mist);margin-bottom:1rem;}
.cta-band .lead{color:var(--petrol-100);max-width:48ch;margin-inline:auto;margin-bottom:2rem;}
.cta-actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;}
.cta-reassure{margin-top:1.4rem;font-size:.86rem;color:var(--petrol-300);}

/* ---------------- groepssessies ---------------- */
.session{
  background:var(--mist);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-soft);border:1px solid rgba(29,74,85,.08);
  display:flex;flex-direction:column;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.session:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.session-top{
  background:var(--petrol);color:var(--mist);
  padding:1.5rem 1.7rem 1.3rem;position:relative;
}
.session-top .kind{
  font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--clay-100);margin-bottom:.5rem;display:block;
}
.session-top h3{color:var(--mist);font-size:1.4rem;}
.session-body{padding:1.5rem 1.7rem;display:flex;flex-direction:column;gap:.85rem;flex:1;}
.session-body p{font-size:.95rem;color:var(--ink-soft);}
.session-meta{display:flex;flex-direction:column;gap:.55rem;margin-top:.2rem;}
.session-meta li{display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem;}
.session-meta svg{width:16px;height:16px;color:var(--clay);flex-shrink:0;margin-top:.18rem;}
.session-meta strong{color:var(--petrol-900);}
.session-foot{
  margin-top:auto;padding:1.2rem 1.7rem;
  border-top:1px solid rgba(29,74,85,.10);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
}
.session-price{font-family:var(--ff-serif);font-size:1.45rem;color:var(--petrol-900);}
.session-price small{font-family:var(--ff-sans);font-size:.78rem;color:var(--ink-soft);display:block;font-weight:500;}

.info-callout{
  background:var(--sand-2);border:1px dashed var(--petrol-300);
  border-radius:var(--radius);padding:1.5rem 1.7rem;
  display:flex;gap:1rem;align-items:flex-start;
}
.info-callout svg{width:22px;height:22px;color:var(--petrol);flex-shrink:0;margin-top:.15rem;}
.info-callout p{font-size:.93rem;color:var(--ink-soft);margin:0;}
.info-callout strong{color:var(--petrol-900);}

/* ---------------- blog ---------------- */
.filter-bar{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.4rem;}
.filter-bar button{
  font-size:.88rem;font-weight:600;padding:.55rem 1.15rem;border-radius:100px;
  background:var(--mist);border:1px solid rgba(29,74,85,.15);color:var(--ink-soft);
  transition:.25s var(--ease);
}
.filter-bar button:hover{border-color:var(--petrol);color:var(--petrol);}
.filter-bar button.active{background:var(--petrol);color:var(--mist);border-color:var(--petrol);}

.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:1.8rem;}
.post{
  background:var(--mist);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-soft);border:1px solid rgba(29,74,85,.07);
  display:flex;flex-direction:column;position:relative;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.post:hover{transform:translateY(-7px);box-shadow:var(--shadow);}
/* hele kaart klikbaar via post-link in de titel — de ::after-overlay vangt
   alle klikken; de tekstlink onderaan blijft hierboven liggen voor focus.   */
.post-link{
  color:inherit;text-decoration:none;
  transition:color .2s var(--ease);
}
.post-link::after{
  content:"";position:absolute;inset:0;z-index:1;
  border-radius:inherit;
}
.post:hover .post-link,
.post-link:focus-visible{color:var(--petrol);}
.post-link:focus-visible{outline:none;}
.post:has(.post-link:focus-visible){
  outline:2px solid var(--clay);outline-offset:3px;
}
/* zorg dat de tekstlink in de meta zelfstandig klikbaar blijft (en focusable) */
.post-meta a{position:relative;z-index:2;}
.post-img{aspect-ratio:16/10;overflow:hidden;background:var(--petrol-100);}
.post-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.post:hover .post-img img{transform:scale(1.06);}
/* tekstuele cover (geen collega-foto's voor algemene berichten) */
.post-cover{
  aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;
  position:relative;
}
.post-cover svg{width:54px;height:54px;}
.cover-sessie{background:linear-gradient(140deg,#ecccb4,#d98f66);color:#8a4524;}
.cover-nieuws{background:linear-gradient(140deg,#d3dee2,#9db4bb);color:#1f3a52;}
.cover-inzicht{background:linear-gradient(140deg,#dde3d8,#a9bca5);color:#3b5340;}

/* lege staat */
.empty-state{
  text-align:center;max-width:46rem;margin-inline:auto;
  padding:clamp(2.4rem,5vw,3.6rem);background:var(--mist);
  border:1.5px dashed var(--petrol-300);border-radius:var(--radius-lg);
}
.empty-state .es-ico{
  width:74px;height:74px;border-radius:50%;background:var(--mistblue-100);
  display:flex;align-items:center;justify-content:center;margin:0 auto 1.3rem;color:var(--petrol);
}
.empty-state .es-ico svg{width:34px;height:34px;}
.empty-state h3{margin-bottom:.6rem;}
.empty-state p{color:var(--ink-soft);margin:0 auto;max-width:40ch;}
.post-body{padding:1.5rem 1.6rem 1.7rem;display:flex;flex-direction:column;flex:1;}
.post-cat{
  font-size:.73rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:.6rem;display:inline-flex;align-items:center;gap:.4rem;
}
.post-cat::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor;}
.cat-sessie{color:var(--clay);}
.cat-nieuws{color:var(--petrol);}
.cat-inzicht{color:var(--sage);}
.post-body h3{font-size:1.27rem;margin-bottom:.55rem;line-height:1.22;}
.post-body p{font-size:.94rem;color:var(--ink-soft);margin-bottom:1.1rem;}
.post-meta{
  margin-top:auto;display:flex;align-items:center;justify-content:space-between;
  font-size:.82rem;color:var(--ink-soft);padding-top:.9rem;
}
.post.featured{grid-column:1/-1;}
@media(min-width:760px){
  .post.featured{display:grid;grid-template-columns:1.15fr 1fr;}
  .post.featured .post-img{aspect-ratio:auto;}
  .post.featured .post-body{padding:clamp(2rem,4vw,3.2rem);justify-content:center;}
  .post.featured .post-body h3{font-size:clamp(1.6rem,2.6vw,2.2rem);}
}

/* artikel */
.article{max-width:48rem;margin-inline:auto;}
.article h2{font-size:clamp(1.6rem,2.6vw,2.1rem);margin:2.4rem 0 .9rem;}
.article h3{font-size:1.3rem;margin:1.8rem 0 .6rem;}
.article p{margin-bottom:1.15rem;color:var(--ink);}
.article ul.bul{margin:0 0 1.3rem 0;display:flex;flex-direction:column;gap:.6rem;}
.article ul.bul li{position:relative;padding-left:1.7rem;color:var(--ink);}
.article ul.bul li::before{
  content:"";position:absolute;left:0;top:.62em;width:9px;height:9px;
  border-radius:50%;background:var(--clay);
}
.article .figure{border-radius:var(--radius);overflow:hidden;margin:2rem 0;box-shadow:var(--shadow-soft);}
.article blockquote{
  font-family:var(--ff-serif);font-style:italic;font-size:1.35rem;line-height:1.4;
  color:var(--petrol);border-left:3px solid var(--clay);padding-left:1.4rem;margin:1.8rem 0;
}

/* ---------------- thema-explorer ---------------- */
.explorer{
  background:var(--mist);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);overflow:hidden;border:1px solid rgba(31,58,82,.08);
}
.aud-toggle{display:flex;gap:.5rem;padding:1rem;background:var(--petrol);}
.aud-toggle button{
  flex:1;padding:.85rem 1rem;border-radius:100px;
  font-weight:600;font-size:.95rem;color:var(--petrol-100);
  transition:background .25s var(--ease),color .25s var(--ease);
}
.aud-toggle button:hover{color:var(--mist);}
.aud-toggle button.active{background:var(--mist);color:var(--petrol-900);}
.explorer-body{display:grid;grid-template-columns:296px 1fr;}
.ex-nav{
  background:var(--sand);border-right:1px solid rgba(31,58,82,.1);
  padding:1rem;max-height:660px;overflow-y:auto;
}
.ex-cat{margin-bottom:.25rem;}
.ex-cat-head{
  width:100%;text-align:left;cursor:pointer;
  font-family:var(--ff-serif);font-size:1.05rem;color:var(--petrol-900);
  padding:.72rem .8rem;border-radius:10px;
  display:flex;justify-content:space-between;align-items:center;gap:.6rem;
  transition:background .2s var(--ease),color .2s var(--ease);
}
.ex-cat-head:hover{background:var(--sand-2);}
.ex-cat.open > .ex-cat-head{color:var(--clay);background:var(--sand-2);}
.ex-cat-head .pm{font-size:1.2rem;line-height:1;color:var(--clay);transition:transform .25s var(--ease);}
.ex-cat.open .ex-cat-head .pm{transform:rotate(45deg);}
.ex-themes{display:none;flex-direction:column;gap:.12rem;padding:.25rem 0 .5rem .45rem;}
.ex-cat.open .ex-themes{display:flex;}
.ex-theme{
  text-align:left;cursor:pointer;padding:.52rem .8rem;border-radius:8px;
  font-size:.91rem;color:var(--ink-soft);border-left:2px solid transparent;
  transition:.2s var(--ease);
}
.ex-theme:hover{background:var(--sand-2);color:var(--petrol-900);}
.ex-theme.active{
  background:var(--mistblue-100);color:var(--petrol-900);
  font-weight:600;border-left-color:var(--clay);
}
.ex-detail{padding:clamp(1.7rem,4vw,3rem);min-height:560px;}
.ex-detail .ex-cat-label{
  font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--clay);margin-bottom:.7rem;
}
.ex-detail h3{font-size:clamp(1.55rem,2.7vw,2.25rem);margin-bottom:.4rem;}
.ex-variants{display:flex;flex-wrap:wrap;gap:.5rem;margin:1.4rem 0 1.6rem;}
.ex-variants button{
  font-size:.84rem;font-weight:600;padding:.5rem 1rem;border-radius:100px;
  background:var(--sand-2);color:var(--petrol-700);transition:.2s var(--ease);
}
.ex-variants button:hover{background:var(--mistblue);}
.ex-variants button.active{background:var(--clay);color:var(--mist);}
.ex-text p{margin-bottom:.9rem;color:var(--ink);}
.ex-text{margin-bottom:1.8rem;}
.ex-cta-row{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;
  padding-top:1.5rem;border-top:1px solid rgba(31,58,82,.12);}
.ex-cta-note{font-size:.86rem;color:var(--ink-soft);}
@media(max-width:780px){
  .explorer-body{grid-template-columns:1fr;}
  .ex-nav{border-right:none;border-bottom:1px solid rgba(31,58,82,.1);max-height:340px;}
  .ex-detail{min-height:0;}
}

/* ---------------- FAQ ---------------- */
.faq{max-width:48rem;margin-inline:auto;}
.faq-item{border-bottom:1px solid rgba(29,74,85,.16);}
.faq-q{
  width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.35rem 0;font-family:var(--ff-serif);font-size:1.2rem;color:var(--petrol-900);
}
.faq-q .pm{
  width:30px;height:30px;flex-shrink:0;border-radius:50%;
  border:1.5px solid var(--clay);color:var(--clay);
  display:flex;align-items:center;justify-content:center;transition:.3s var(--ease);
}
.faq-item.open .faq-q .pm{background:var(--clay);color:var(--mist);transform:rotate(135deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);}
.faq-a-inner{padding:0 0 1.4rem;color:var(--ink-soft);font-size:.98rem;}

/* ---------------- contactblok ---------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3.5rem);}
.contact-cards{display:flex;flex-direction:column;gap:1rem;}
.contact-line{
  display:flex;gap:1rem;align-items:flex-start;
  background:var(--mist);border:1px solid rgba(29,74,85,.09);
  border-radius:var(--radius);padding:1.3rem 1.5rem;transition:.3s var(--ease);
}
.contact-line:hover{box-shadow:var(--shadow-soft);transform:translateY(-3px);}
.contact-line .ico{
  width:44px;height:44px;border-radius:11px;flex-shrink:0;
  background:var(--petrol-100);color:var(--petrol);
  display:flex;align-items:center;justify-content:center;
}
.contact-line .ico svg{width:21px;height:21px;}
.contact-line h3{font-size:1.1rem;margin-bottom:.15rem;}
.contact-line p,.contact-line a{font-size:.94rem;color:var(--ink-soft);}
.contact-line a:hover{color:var(--clay);}
.map-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);min-height:340px;border:none;}
.map-frame iframe{width:100%;height:100%;min-height:340px;border:0;display:block;}

/* eenvoudig formulier (verwijst door) */
.mini-form{background:var(--mist);border-radius:var(--radius-lg);padding:clamp(1.8rem,4vw,2.8rem);box-shadow:var(--shadow-soft);}
.field{margin-bottom:1.1rem;}
.field label{display:block;font-size:.86rem;font-weight:600;margin-bottom:.4rem;color:var(--petrol-900);}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:.97rem;
  padding:.8rem 1rem;border-radius:var(--radius-sm);
  border:1.5px solid rgba(29,74,85,.18);background:var(--sand);color:var(--ink);
  transition:border-color .25s var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--petrol);}
.field textarea{resize:vertical;min-height:120px;}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-section{margin-bottom:1.9rem;}
.fs-label{
  font-size:.76rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--clay);margin-bottom:1rem;padding-bottom:.5rem;
  border-bottom:1px solid rgba(31,58,82,.13);
}
.opt-row{display:flex;flex-wrap:wrap;gap:.55rem;}
.opt{
  display:flex;align-items:center;gap:.5rem;cursor:pointer;
  padding:.65rem 1rem;border:1.5px solid rgba(31,58,82,.18);border-radius:10px;
  font-size:.91rem;background:var(--sand);transition:border-color .2s var(--ease),background .2s var(--ease);
}
.opt:hover{border-color:var(--petrol-300);}
.opt input{accent-color:var(--clay-cta);width:17px;height:17px;flex-shrink:0;}
.opt.full{width:100%;}
@media(max-width:520px){.field-2{grid-template-columns:1fr;}}

/* ---------------- pijlers / waarden ---------------- */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.6rem;}
.pillar{padding:1.8rem;background:var(--mist);border-radius:var(--radius);box-shadow:var(--shadow-soft);}
.pillar .ico{width:48px;height:48px;border-radius:12px;background:var(--clay-100);color:var(--clay-600);display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;}
.pillar .ico svg{width:24px;height:24px;}
.pillar h3{font-size:1.2rem;margin-bottom:.5rem;}
.pillar p{font-size:.95rem;color:var(--ink-soft);}

/* ---------------- footer ---------------- */
.site-footer{background:var(--petrol-900);color:var(--petrol-100);padding:clamp(3.5rem,7vw,5.5rem) 0 2rem;}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;
  gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(92,138,148,.25);
}
.footer-brand .name{font-family:var(--ff-serif);font-size:1.7rem;color:var(--mist);margin-bottom:.7rem;}
.footer-brand p{font-size:.93rem;color:var(--petrol-300);max-width:30ch;}
.footer-col h4{
  font-family:var(--ff-sans);font-size:.78rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--clay-100);margin-bottom:1.1rem;
}
.footer-col ul{display:flex;flex-direction:column;gap:.6rem;}
.footer-col a,.footer-col p{font-size:.93rem;color:var(--petrol-100);transition:color .2s var(--ease);}
.footer-col a:hover{color:var(--mist);}
.footer-cta .btn{margin-top:.4rem;}
.footer-bottom{
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;
  padding-top:1.8rem;font-size:.82rem;color:var(--petrol-300);
}
.footer-bottom a:hover{color:var(--mist);}

/* ---------------- reveal-animatie ---------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}
.reveal.d4{transition-delay:.32s;}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
  .hero-scroll .line{animation:none;}
}

/* ---------------- responsive ---------------- */
@media(max-width:980px){
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem;}
}
@media(max-width:860px){
  .nav-toggle{display:flex;}
  .main-nav{
    position:fixed;inset:0 0 0 auto;width:min(82vw,360px);
    background:var(--petrol-900);flex-direction:column;justify-content:center;
    gap:2.2rem;padding:3rem;transform:translateX(105%);
    transition:transform .4s var(--ease);z-index:100;
  }
  body.nav-open .main-nav{transform:translateX(0);}
  .nav-links{flex-direction:column;gap:1.4rem;align-items:flex-start;}
  .nav-links a{font-size:1.2rem;font-family:var(--ff-serif);color:var(--mist)!important;}
  .site-header:not(.scrolled) .nav-links a{color:var(--mist);}
  .main-nav .btn{align-self:flex-start;}
  .drop{
    position:static;transform:none;opacity:1;visibility:visible;
    box-shadow:none;background:transparent;border:none;
    padding:.3rem 0 .3rem 1.1rem;min-width:0;display:none;
  }
  .has-drop.drop-open .drop{display:flex;}
  .has-drop.drop-open .drop-trigger .car{transform:rotate(-135deg);}
  .drop li a{
    font-family:var(--ff-sans)!important;font-size:1rem!important;
    color:var(--petrol-100)!important;padding:.45rem .2rem;
  }
  .drop li a:hover{background:transparent;color:var(--clay-100)!important;}
  .split,.contact-grid{grid-template-columns:1fr;}
  .offer-row,.offer-row.flip{grid-template-columns:1fr;}
  .offer-row.flip .offer-media{order:0;}
  .profile,.profile.flip{grid-template-columns:1fr;gap:1.6rem;}
  .profile.flip .profile-photo{order:0;}
  .profile-photo{position:relative;top:0;max-width:420px;}
  .post.featured{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .footer-top{grid-template-columns:1fr;}
  .hero{min-height:92svh;}
  .stack-imgs .badge-note{position:relative;bottom:0;left:0;margin-top:1rem;max-width:none;}
  .session-foot{flex-direction:column;align-items:flex-start;}
  .btn{width:100%;justify-content:center;}
  .hero-actions .btn,.cta-actions .btn{width:auto;}
  .hero-actions{flex-direction:column;}
  .hero-actions .btn{width:100%;}
}

/* skip-link */
.skip{position:absolute;left:-999px;}
.skip:focus{
  left:1rem;top:1rem;z-index:200;background:var(--clay-cta);color:#fff;
  padding:.7rem 1.2rem;border-radius:8px;
}

/* ================================================================
   Cinematografische verfijning — mei 2026
   ================================================================ */

/* ---------------- Verfijnde reveal-varianten ---------------- */
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal-left.in{opacity:1;transform:none;}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.reveal-right.in{opacity:1;transform:none;}
.reveal-scale{opacity:0;transform:scale(.96);transition:opacity 1s var(--ease),transform 1s var(--ease);}
.reveal-scale.in{opacity:1;transform:none;}
.reveal-blur{opacity:0;filter:blur(8px);transition:opacity 1.1s var(--ease),filter 1.1s var(--ease);}
.reveal-blur.in{opacity:1;filter:none;}
/* will-change bewust weggelaten: transform+opacity worden door moderne browsers
   automatisch GPU-gecomposed bij de transition; een globale will-change-hint op
   tientallen .reveal-elementen overschreed Firefox' "3× document"-budget waardoor
   de hint sowieso genegeerd werd. */

/* langere stagger-cascade */
.reveal.d5{transition-delay:.40s;}
.reveal.d6{transition-delay:.48s;}

@media(prefers-reduced-motion:reduce){
  .reveal-left,.reveal-right,.reveal-scale,.reveal-blur{opacity:1;transform:none;filter:none;transition:none;}
}

/* ---------------- Hero — diepere cinematic gradient ---------------- */
.hero-media::before{
  /* subtiele vignette voor extra diepte */
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at 50% 40%,transparent 0%,transparent 55%,rgba(8,18,26,.45) 100%);
}
.hero-media::after{
  /* rijkere gelaagde verloop — donker boven & onder + extra links-scrim onder de tekst */
  background:
    linear-gradient(95deg,
      rgba(8,18,26,.72) 0%,
      rgba(8,18,26,.55) 22%,
      rgba(8,18,26,.30) 45%,
      rgba(8,18,26,.08) 70%,
      rgba(8,18,26,0) 100%),
    linear-gradient(180deg,
      rgba(8,18,26,.78) 0%,
      rgba(8,18,26,.42) 18%,
      rgba(8,18,26,.28) 42%,
      rgba(8,18,26,.36) 62%,
      rgba(8,18,26,.82) 88%,
      rgba(8,18,26,.96) 100%);
}
/* heel trage Ken Burns op de hero — geeft cinematic ademen */
.hero-media img{
  animation:slow-zoom 26s var(--ease) forwards;
  will-change:transform;
}
@keyframes slow-zoom{
  from{transform:scale(1.0);}
  to{transform:scale(1.07);}
}
@media(prefers-reduced-motion:reduce){
  .hero-media img{animation:none;}
}

/* hero-titel: subtielere serif tracking + sterkere shadow voor leesbaarheid op lichte beeldzones */
.hero h1{
  letter-spacing:-.022em;
  text-shadow:
    0 1px 2px rgba(0,0,0,.45),
    0 2px 24px rgba(0,0,0,.55),
    0 0 60px rgba(8,18,26,.35);
}
.hero .lead{
  text-shadow:
    0 1px 2px rgba(0,0,0,.55),
    0 1px 18px rgba(0,0,0,.45);
}
.hero-trust span{text-shadow:0 1px 2px rgba(0,0,0,.45);}

/* pagehero — rijkere gradient */
.pagehero.has-img .pagehero-media::after{
  background:linear-gradient(
    105deg,
    rgba(10,28,40,.94) 30%,
    rgba(14,39,52,.72) 70%,
    rgba(14,39,52,.42) 100%);
}
.pagehero.has-img .pagehero-media::before{
  /* extra vignette */
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 70%,transparent 0%,rgba(8,18,26,.35) 100%);
  z-index:0;
}

/* ---------------- Cards — verfijndere micro-interactie ---------------- */
.card,.member,.post,.session,.pillar{
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);
}
.card:hover,.pillar:hover{
  transform:translateY(-9px);
  box-shadow:0 28px 60px -30px rgba(14,39,45,.55);
  border-color:rgba(31,58,82,.16);
}
.member:hover,.post:hover,.session:hover{
  box-shadow:0 32px 70px -32px rgba(14,39,45,.60);
}
.pillar .ico,.card .ico{
  transition:transform .5s var(--ease),background .35s var(--ease);
}
.pillar:hover .ico,.card:hover .ico{
  transform:scale(1.08) rotate(-3deg);
}

/* member-photo: licht zachte overlay + verfijnde zoom */
.member-photo{position:relative;}
.member-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(14,39,45,.18));
  opacity:0;transition:opacity .45s var(--ease);pointer-events:none;
}
.member:hover .member-photo::after{opacity:1;}

/* ---------------- Stappen — accentlijn + nummer-glow ---------------- */
.step{padding-top:1.4rem;position:relative;}
.step .n{
  font-feature-settings:"liga","calt";
  text-shadow:0 6px 24px rgba(176,92,48,.22);
}
.steps.connected{position:relative;}
.steps.connected::before{
  content:"";position:absolute;top:2.2rem;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(176,92,48,.25),transparent);
  z-index:0;
}
@media(max-width:760px){.steps.connected::before{display:none;}}

/* ---------------- Pullquote — versmald + zachte glow ---------------- */
.quote-line{
  position:relative;padding:.4rem 0 .4rem 1.3rem;
}
.quote-line::before{
  content:"";position:absolute;left:0;top:.2em;bottom:.2em;width:3px;
  background:linear-gradient(180deg,var(--clay),var(--clay-100));
  border-radius:2px;
}
.quote-line{border-left:none;}

/* ---------------- Sectiekop — subtiele decoratie ---------------- */
.section-head h2 + .lead{margin-top:1.1rem;}

/* ---------------- Footer — subtielere afsluiting ---------------- */
.site-footer{
  background:linear-gradient(180deg,var(--petrol-900) 0%,#0a1825 100%);
  position:relative;
}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(199,159,84,.30),transparent);
}

/* ---------------- Knoppen — subtielere ring bij focus ---------------- */
.btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(176,92,48,.35),0 12px 26px -14px rgba(171,79,43,.9);
}
.textlink:focus-visible{
  outline:2px solid rgba(176,92,48,.45);outline-offset:4px;border-radius:3px;
}

/* ---------------- Beelden — subtiele zoom-on-scroll ready ---------------- */
/* will-change weggelaten om dezelfde budget-reden als bij .reveal — transform
   wordt door de browser bij hover/scroll-animatie automatisch GPU-gecomposed. */

/* ---------------- Selectie + scrollbar ---------------- */
::selection{background:var(--clay-100);color:var(--petrol-900);}
@supports (scrollbar-color:auto){
  html{scrollbar-color:var(--petrol-300) var(--sand);}
}

/* ---------------- Hoe-werkt-het / journey ---------------- */
.journey{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.4rem;counter-reset:jstep;position:relative;
}
.journey-step{
  background:var(--mist);border:1px solid rgba(31,58,82,.08);
  border-radius:var(--radius);padding:1.8rem 1.6rem 1.7rem;
  position:relative;overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.journey-step:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft);}
.journey-step::before{
  counter-increment:jstep;
  content:counter(jstep,decimal-leading-zero);
  position:absolute;top:-.4rem;right:1rem;
  font-family:var(--ff-serif);font-size:5.5rem;color:rgba(176,92,48,.12);
  line-height:1;font-style:italic;
}
.journey-step .ico{
  width:44px;height:44px;border-radius:12px;background:var(--mistblue-100);
  color:var(--petrol);display:flex;align-items:center;justify-content:center;
  margin-bottom:1rem;position:relative;
}
.journey-step .ico svg{width:22px;height:22px;}
.journey-step h3{font-size:1.15rem;margin-bottom:.5rem;position:relative;}
.journey-step p{font-size:.93rem;color:var(--ink-soft);margin:0;position:relative;}

/* ---------------- Verhaalbalk (over-ons) ---------------- */
.timeline{
  position:relative;max-width:48rem;margin:0 auto;
  padding-left:2rem;
}
.timeline::before{
  content:"";position:absolute;left:.4rem;top:.5rem;bottom:.5rem;width:2px;
  background:linear-gradient(180deg,var(--clay),var(--sage));
  border-radius:2px;
}
.tl-item{position:relative;padding-bottom:2.4rem;}
.tl-item:last-child{padding-bottom:0;}
.tl-item::before{
  content:"";position:absolute;left:-1.65rem;top:.5rem;width:14px;height:14px;
  border-radius:50%;background:var(--clay);
  box-shadow:0 0 0 4px var(--sand),0 0 0 5px rgba(176,92,48,.30);
}
.tl-year{
  font-family:var(--ff-serif);font-size:.95rem;font-style:italic;color:var(--clay);
  display:block;margin-bottom:.3rem;
}
.tl-item h3{font-size:1.2rem;margin-bottom:.4rem;}
.tl-item p{color:var(--ink-soft);margin:0;}

/* ---------------- Mobiele verfijning ---------------- */
@media(max-width:560px){
  .display{font-size:clamp(2.3rem,9vw,3.2rem);line-height:1.06;}
  h2{font-size:clamp(1.7rem,6vw,2.3rem);}
  .section{padding:clamp(3.4rem,9vw,5rem) 0;}
  .pagehero{padding:9rem 0 clamp(2.8rem,7vw,4rem);}
  .pagehero h1{max-width:none;}
  .hero{align-items:center;padding-top:7rem;}
  .hero-inner{padding-bottom:3rem;}
  .hero-trust{gap:.9rem;margin-top:1.8rem;padding-top:1.2rem;}
  .hero-trust span{font-size:.82rem;}
  .hero-scroll{display:none;}
  .lead{font-size:1.02rem;}
  .container{padding-inline:1.2rem;}
  .nav-toggle{padding:10px;}
  .cards,.team-grid,.post-grid,.pillars,.journey{gap:1.1rem;}
  .card,.pillar,.journey-step{padding:1.5rem 1.3rem;}
  .badge-note{position:relative!important;bottom:auto!important;left:auto!important;margin-top:.8rem;max-width:none!important;}
  .footer-cta .btn{width:100%;justify-content:center;}
  .pullquote blockquote{font-size:1.3rem;}
}
@media(max-width:380px){
  .display{font-size:2.1rem;}
  .hero-actions{gap:.6rem;}
  .hero h1{margin-bottom:1rem;}
}

/* ---------------- iOS safe-area ---------------- */
@supports(padding:max(0px)){
  body{padding-bottom:env(safe-area-inset-bottom);}
  .site-header{padding-top:max(.55rem,env(safe-area-inset-top));}
}

/* ---------------- Contactlijntjes in team-kaart ---------------- */
.member-contacts{
  display:flex;flex-direction:column;align-items:stretch;gap:.4rem;
  margin-top:auto;padding-top:.95rem;
  border-top:1px solid rgba(31,58,82,.10);
}
.member-contacts a{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.8rem;font-weight:500;color:var(--petrol-700);
  padding:.45rem .8rem;border-radius:100px;
  background:var(--sand);border:1px solid rgba(31,58,82,.10);
  max-width:100%;min-width:0;word-break:break-word;line-height:1.25;
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease);
}
.member-contacts a:hover{
  background:var(--petrol);color:var(--mist);border-color:var(--petrol);
  transform:translateY(-1px);
}
.member-contacts a svg{width:14px;height:14px;flex-shrink:0;}

/* ---------------- Social-iconen in footer ---------------- */
.footer-social{
  display:flex;justify-content:center;align-items:center;gap:.9rem;
  padding:1.6rem 0 1.2rem;
  border-bottom:1px solid rgba(92,138,148,.18);
  margin-bottom:1.8rem;
}
.footer-social a{
  width:42px;height:42px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(251,249,243,.06);
  border:1px solid rgba(251,249,243,.16);
  color:var(--petrol-100);
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease),border-color .3s var(--ease);
}
.footer-social a:hover{
  background:var(--clay-cta);color:var(--mist);
  border-color:var(--clay-cta);transform:translateY(-3px);
}
.footer-social a svg{width:19px;height:19px;}
