/* ===== DESIGN TOKENS (V3 Magazine Edition) ===== */
:root {
  --paper: #F6EFDC;
  --paper-2: #EDE3CA;
  --paper-3: #E2D4B0;
  --ink: #0B0907;
  --ink-2: #23211D;
  --ink-3: #5F564C;
  --orange: #FFA500;
  --orange-2: #E89200;
  --orange-deep: #B57600;
  --orange-mute: #FFD299;
  --line: #0B0907;
  --line-soft: rgba(11,9,7,.14);

  --display: 'Libre Bodoni', Georgia, serif;
  --display-2: 'Anton', 'Arial Narrow', sans-serif;
  --body: 'Public Sans', system-ui, sans-serif;
  --mono: 'VT323', ui-monospace, monospace;

  --z-nav: 50;
  --ease-out: cubic-bezier(.16,.84,.3,1);
  --container: 1180px;
  --pad: 32px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  width:100%;
  max-width:100vw;
}
html{overflow-x:hidden;max-width:100vw}
body::before{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.78' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
img,svg{display:block;max-width:100%}
svg{stroke:currentColor;fill:none}
a{color:inherit;text-decoration:none;cursor:pointer}
button{font:inherit;border:0;background:0;color:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--orange);outline-offset:3px}
a:focus-visible,button:focus-visible{outline-offset:4px}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  .ticker__track{animation:none !important}
}

.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--ink);color:var(--paper);padding:12px 16px;z-index:10000;
}
.skip-link:focus{left:0}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--pad);
  position:relative;
  z-index:2;
}
.kicker{
  font-family:var(--mono);
  font-size:18px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--orange-deep);
  display:inline-block;
}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ===== ICONS ===== */
.icon{width:18px;height:18px;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.icon-lg{width:22px;height:22px}

/* ===== NAV ===== */
.site-nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:var(--z-nav);
  padding:14px 0;
  background:rgba(246,239,220,0);
  backdrop-filter:blur(0);
  transition:background .3s var(--ease-out), backdrop-filter .3s var(--ease-out), padding .3s var(--ease-out);
}
body.scrolled .site-nav{
  background:rgba(246,239,220,.94);
  backdrop-filter:blur(20px) saturate(140%);
  padding:10px 0;
  box-shadow:0 1px 0 var(--line-soft);
}
.site-nav__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.site-nav__brand{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  color:var(--ink);
}
.site-nav__brand img{height:46px;width:auto;display:block}

/* Sticky mobile CTA - subtiel, pill rechtsonder */
.sticky-cta-mobile{
  display:none;
  position:fixed;
  bottom:18px;right:18px;
  background:var(--ink);
  color:var(--paper);
  padding:12px 18px;
  border-radius:999px;
  font-family:var(--body);
  font-size:13px;
  font-weight:600;
  letter-spacing:.04em;
  z-index:90;
  box-shadow:0 8px 22px rgba(11,9,7,.32);
  align-items:center;
  gap:8px;
  transition:transform .2s var(--ease-out), background .2s var(--ease-out);
}
@media (max-width:880px){.sticky-cta-mobile{display:inline-flex}}
.sticky-cta-mobile:hover,.sticky-cta-mobile:active{background:var(--orange);transform:translateY(-2px)}

/* Mobile refinements - geen cheap feel */
@media (max-width:780px){
  .container{padding:0 20px}
  .hero{padding:30px 0 50px}
  .hero__title{font-size:42px;line-height:.95;margin-bottom:22px}
  .hero__chips span{font-size:11px;padding:5px 11px}
  .hero__lead{font-size:16px;line-height:1.55}
  .ticker{font-size:20px;padding:11px 0}
  .ticker__track{gap:30px}
  .ticker__track > span{gap:30px}
  .trust__row{font-size:13px;gap:14px;justify-content:flex-start}
  .trust__row .item{gap:6px}
  .scoreboard{padding:36px 0}
  .scoreboard__grid{gap:0}
  .stat{padding:14px 18px}
  .stat__num{font-size:48px;margin-bottom:4px}
  .stat__label{font-size:13px}
  .section{padding:46px 0}
  .section__title{font-size:36px;line-height:.95}
  .section__head{gap:14px;margin-bottom:26px}
  .section__sub{font-size:16px}
  .services{grid-template-columns:1fr;background:transparent;border:0;border-radius:0}
  .service{min-height:auto;padding:24px 22px;margin-left:0 !important;margin-bottom:8px;border:1px solid var(--line)}
  .service__big{font-size:30px}
  .service__icon{width:34px;height:34px}
  .audience-grid{gap:12px}
  .audience{padding:24px 22px}
  .audience h3{font-size:24px}
  .packages{grid-template-columns:1fr;border:0;border-radius:0;gap:8px}
  .pkg{border:1px solid var(--line);border-radius:4px}
  .section--dark .pkg{border-color:rgba(246,239,220,.18)}
  .agenda{padding:46px 0}
  .agenda__head{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:20px;padding-bottom:14px}
  .agenda__head h2{font-size:34px}
  .agenda__row{padding:14px 0;gap:8px}
  .agenda__date{display:inline-flex;align-items:baseline;gap:8px;font-size:14px}
  .agenda__date b{display:inline;font-size:32px}
  .agenda__date br{display:none}
  .agenda__event{font-size:18px}
  .agenda__loc{font-size:13px}
  .agenda__status{display:inline-block;font-size:11px;padding:6px 12px}
  .story{padding:46px 0}
  .story__body p{font-size:16px;line-height:1.7}
  .story__body p.lead{font-size:22px;margin-bottom:20px}
  .story__body p.lead::first-letter{font-size:80px;margin:6px 10px -6px 0}
  .story__img-cap{font-size:16px}
  .pull-quote{padding:50px 0}
  .pull-quote::before{font-size:160px;top:10px;left:12px}
  .pull-quote blockquote{font-size:24px;line-height:1.3;padding-top:30px}
  .pull-quote__attr{font-size:14px;margin-top:18px}
  .logos{padding:36px 0}
  .logos__title{font-size:14px;margin-bottom:18px}
  .logos__row{gap:28px}
  .logos__row img{height:36px}
  .cta-strip{padding:60px 0}
  .cta-strip::before{font-size:90px}
  .cta-strip h2{font-size:38px}
  .cta-strip p{font-size:17px}
  .site-footer{padding:42px 0 24px}
  .site-footer__grid{grid-template-columns:1fr;gap:24px;margin-bottom:32px}
  .site-footer__brand{font-size:26px}
  .breadcrumb{font-size:13px;padding:14px 0 4px}
  .info-strip{gap:10px}
  .info-strip__card{padding:16px 18px}
  .reviews-row{gap:10px}
  .review{padding:20px 18px}
  .review blockquote{font-size:16px}
}

/* Reviews row */
.reviews-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:18px;
}
.review{
  background:var(--paper);
  border:1px solid var(--line);
  padding:24px 22px;
  display:flex;flex-direction:column;gap:12px;
}
.review blockquote{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  font-size:18px;
  line-height:1.4;
  color:var(--ink);
}
.review blockquote::before{content:'\201C';font-family:var(--display);font-weight:800;font-size:50px;line-height:0;color:var(--orange);vertical-align:-18px;margin-right:6px}
.review__attr{margin-top:auto;font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase}
@media (max-width:880px){.reviews-row{grid-template-columns:1fr}}
.site-nav__links{
  display:flex;
  gap:30px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.04em;
}
.site-nav__links a{
  color:var(--ink-2);
  transition:color .25s var(--ease-out);
  padding:6px 0;
  position:relative;
}
.site-nav__links a:hover,.site-nav__links a[aria-current="page"]{color:var(--orange-2)}
.site-nav__links a::after{
  content:'';
  position:absolute;
  bottom:-3px;left:0;
  width:0;height:1px;
  background:var(--orange);
  transition:width .25s var(--ease-out);
}
.site-nav__links a:hover::after,.site-nav__links a[aria-current="page"]::after{width:100%}
.site-nav__cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--ink);
  color:var(--paper);
  padding:10px 20px;
  font-weight:600;
  font-size:13px;
  letter-spacing:.04em;
  border-radius:999px;
  transition:background .25s var(--ease-out), transform .2s var(--ease-out);
}
.site-nav__cta:hover{background:var(--orange);transform:translateY(-1px)}
.site-nav__burger{display:none;width:42px;height:42px;align-items:center;justify-content:center}
@media (max-width:980px){
  .site-nav__links{display:none}
  .site-nav__burger{display:flex}
  .site-nav__brand img{height:42px}
  .site-nav__cta{padding:8px 14px;font-size:12px}
}
@media (max-width:560px){
  /* Op smal mobile: Boek-knop weg uit nav (sticky CTA onderaan pakt 'm over) */
  .site-nav__cta{display:none}
  .site-nav__brand img{height:38px}
  .site-nav__inner{height:56px}
  html, body{overflow-x:hidden;width:100%}
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 28px;
  font-family:var(--body);
  font-size:14px;
  font-weight:600;
  letter-spacing:.03em;
  transition:background .25s var(--ease-out), color .25s var(--ease-out), transform .2s var(--ease-out), box-shadow .25s var(--ease-out);
  border:1.5px solid var(--ink);
  border-radius:999px;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 8px 0 -2px rgba(11,9,7,.18)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px);box-shadow:0 8px 0 -2px rgba(11,9,7,.18)}
.section--dark .btn-ghost{color:var(--paper);border-color:var(--paper)}
.section--dark .btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn .icon{transition:transform .2s var(--ease-out)}
.btn:hover .icon{transform:translateX(4px)}

/* ===== BREADCRUMB ===== */
.breadcrumb{
  font-family:var(--mono);
  font-size:16px;
  letter-spacing:.04em;
  color:var(--ink-3);
  padding:18px 0 4px;
  margin-top:74px;
  border-bottom:1px solid var(--line-soft);
}
.breadcrumb a:hover{color:var(--orange-2)}
.breadcrumb span{color:var(--ink)}

/* ===== HERO ===== */
.hero{
  position:relative;
  padding:50px 0 90px;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.hero--with-nav{margin-top:74px}
.hero__grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:60px;
  align-items:end;
  position:relative;
}
.hero__chips{
  display:flex;
  gap:8px;
  align-items:center;
  margin-bottom:30px;
  flex-wrap:wrap;
}
.hero__chips span{
  display:inline-flex;
  align-items:center;
  padding:6px 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.04em;
  border:1px solid var(--line);
}
.hero__chips .c-ink{background:var(--ink);color:var(--paper)}
.hero__chips .c-orange{background:var(--orange);color:var(--paper);border-color:var(--orange)}
.hero__chips .c-paper{background:transparent;color:var(--ink)}
.hero__title{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(54px,8vw,128px);
  line-height:.92;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-bottom:30px;
}
.hero__title em,.hero__title-em{
  font-style:italic;
  font-weight:500;
  color:var(--orange-2);
  letter-spacing:-.03em;
}
.hero__title-line{
  display:block;
  animation:slideUp .9s var(--ease-out) backwards;
}
.hero__title-line:nth-child(2){animation-delay:.18s}
.hero__title-line:nth-child(3){animation-delay:.32s}
@keyframes slideUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
.hero__lead{
  font-family:var(--body);
  font-size:clamp(17px,1.25vw,20px);
  line-height:1.6;
  max-width:540px;
  color:var(--ink-2);
  margin-bottom:34px;
  animation:slideUp 1s var(--ease-out) .45s backwards;
}
.hero__lead strong{font-weight:700;color:var(--ink)}
.hero__lead em{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  color:var(--ink);
  font-size:1.05em;
}
.hero__cta-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  animation:slideUp 1.1s var(--ease-out) .6s backwards;
}

/* HERO VISUAL — single photo edition */
.hero__visual{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--ink);
  animation:slideUp 1s var(--ease-out) .5s backwards;
}
.hero__visual img{
  width:100%;height:100%;
  object-fit:cover;
  filter:contrast(1.06) saturate(.95);
}
.hero__visual::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(11,9,7,.6) 100%);
  pointer-events:none;
}
.hero__visual-cap{
  position:absolute;
  bottom:18px;left:18px;right:18px;
  color:var(--paper);
  font-family:var(--display);
  font-weight:500;
  font-style:italic;
  font-size:20px;
  line-height:1.2;
  z-index:2;
}

/* COLLAGE variant (for home) */
.hero__collage{
  position:relative;
  height:540px;
  animation:slideUp 1.2s var(--ease-out) .7s backwards;
}
.photo{
  position:absolute;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 14px 0 -4px rgba(11,9,7,.18);
  transition:transform .35s var(--ease-out), box-shadow .25s var(--ease-out);
  cursor:pointer;
}
.photo img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
.photo--1{top:0;right:0;width:300px;height:380px;transform:rotate(1.5deg);z-index:3}
.photo--2{bottom:0;left:10px;width:260px;height:320px;transform:rotate(-2.5deg);z-index:2}
.photo--3{top:200px;right:160px;width:170px;height:210px;transform:rotate(-1deg);z-index:1;background:var(--orange);border-color:var(--orange);display:grid;place-items:center}
.photo--3 .yr{font-family:var(--display-2);font-size:88px;color:var(--paper);letter-spacing:-.04em;line-height:1}
.photo:hover{transform:rotate(0) scale(1.03);z-index:10}
.photo__cap{
  position:absolute;
  bottom:10px;left:10px;
  background:var(--ink);
  color:var(--paper);
  padding:4px 12px;
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.04em;
  text-transform:uppercase;
  z-index:5;
}

@media (max-width:980px){
  .hero{padding:36px 0 60px}
  .hero__grid{grid-template-columns:1fr;gap:46px}
  .hero__collage{height:420px}
  .photo--1{width:60%;height:300px;right:5%}
  .photo--2{width:52%;height:230px;left:5%}
  .photo--3{display:none}
  .hero__visual{aspect-ratio:5/4;max-height:60vh}
}

/* ===== TICKER ===== */
.ticker{
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
  padding:16px 0;
  font-family:var(--mono);
  font-size:28px;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.ticker__track{
  display:flex;
  gap:42px;
  white-space:nowrap;
  animation:tick 40s linear infinite;
  width:max-content;
}
.ticker__track > span{display:inline-flex;align-items:center;gap:42px}
.ticker__track > span b{color:var(--orange);font-weight:normal}
.ticker__track > span::after{content:'';display:inline-block;width:9px;height:9px;background:var(--orange);border-radius:50%}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== TRUST BAR ===== */
.trust{
  background:var(--orange);
  color:var(--paper);
  padding:16px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.trust__row{
  display:flex;
  justify-content:space-around;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
  font-family:var(--mono);
  font-size:20px;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.trust__row .item{display:flex;align-items:center;gap:10px}
.trust__row .item .icon{stroke-width:2.5}

/* ===== SECTION ===== */
.section{
  padding:90px 0;
  border-bottom:1px solid var(--line);
  position:relative;
}
.section--paper-2{background:var(--paper-2)}
.section--dark{background:var(--ink);color:var(--paper)}
.section--dark .section__sub{color:rgba(246,239,220,.78)}
.section--dark .section__title{color:var(--paper)}
.section__head{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  gap:50px;
  align-items:end;
  margin-bottom:54px;
}
.section__title{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(44px,6vw,100px);
  line-height:.92;
  letter-spacing:-.02em;
  color:var(--ink);
}
.section__title em{font-style:italic;font-weight:500;color:var(--orange-2)}
.section--dark .section__title em{color:var(--orange-mute)}
.section__sub{
  font-family:var(--body);
  font-size:clamp(17px,1.25vw,19px);
  line-height:1.65;
  max-width:480px;
  color:var(--ink-2);
}
@media (max-width:780px){
  .section{padding:60px 0}
  .section__head{grid-template-columns:1fr;gap:20px;margin-bottom:36px}
}

/* ===== SCOREBOARD (when used) ===== */
.scoreboard{
  background:var(--paper-2);
  border-bottom:1px solid var(--line);
  padding:46px 0;
}
.scoreboard__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
}
.stat{padding:8px 28px;border-left:1px solid var(--line)}
.stat:last-child{border-right:1px solid var(--line)}
.stat__num{
  font-family:var(--display-2);
  font-size:clamp(56px,6vw,92px);
  line-height:.9;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-bottom:6px;
}
.stat__num small{font-size:.42em;vertical-align:.5em;color:var(--orange-deep);font-family:var(--display);font-style:italic}
.stat__num .dash{font-size:.7em;color:var(--orange-deep)}
.stat__label{
  font-family:var(--mono);
  font-size:17px;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--ink-2);
  line-height:1.2;
}
@media (max-width:780px){
  .scoreboard__grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:1px solid var(--line)}
}

/* ===== SERVICES (4 cards) ===== */
.services{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border:1px solid var(--line);
  background:var(--line);
  border-radius:4px;
  overflow:hidden;
}
.service{
  background:var(--paper);
  padding:30px 22px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:300px;
  transition:background .3s var(--ease-out);
  text-decoration:none;
  color:var(--ink);
}
.service + .service{margin-left:1px}
.service:hover{background:var(--ink);color:var(--paper)}
.service:hover .service__big{color:var(--paper)}
.service:hover .service__icon{background:var(--orange);color:var(--paper);border-color:var(--orange)}
.service:hover .service__arrow{transform:translateX(8px)}
.service__icon{
  width:40px;height:40px;
  border-radius:50%;
  border:1.5px solid currentColor;
  display:grid;place-items:center;
  transition:background .25s var(--ease-out), color .25s var(--ease-out), border-color .25s var(--ease-out);
}
.service__big{
  font-family:var(--display);
  font-weight:700;
  font-size:36px;
  line-height:.9;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-top:auto;
  transition:color .25s var(--ease-out);
}
.service__big em{font-style:italic;font-weight:500}
.service__desc{font-size:14px;line-height:1.55;color:inherit;opacity:.88}
.service__arrow{
  font-family:var(--display);
  font-size:22px;
  transition:transform .25s var(--ease-out);
  margin-top:4px;
}
@media (max-width:900px){.services{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.services{grid-template-columns:1fr}.service + .service{margin-left:0;margin-top:1px}}

/* ===== AUDIENCE GRID ===== */
.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.audience{
  padding:28px 24px;
  background:var(--paper);
  border:1px solid var(--line);
  position:relative;
  transition:transform .3s var(--ease-out);
}
.audience:hover{transform:translateY(-4px)}
.audience::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--orange)}
.audience h3{
  font-family:var(--display);
  font-weight:700;
  font-size:28px;
  line-height:.95;
  letter-spacing:-.01em;
  margin:14px 0 10px;
  color:var(--ink);
}
.audience h3 em{font-style:italic;font-weight:500;color:var(--orange-2)}
.audience .label{
  font-family:var(--mono);
  font-size:14px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--orange-deep);
}
.audience p{font-size:15px;line-height:1.55;color:var(--ink-2);margin-bottom:14px}
.audience ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.audience li{font-size:14px;color:var(--ink-2);padding-left:18px;position:relative}
.audience li::before{content:'';position:absolute;left:0;top:.6em;width:12px;height:1px;background:var(--orange-deep)}
@media (max-width:900px){.audience-grid{grid-template-columns:1fr}}

/* ===== PACKAGES (no prices, just inhoud) ===== */
.packages{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  border:1px solid var(--line);
  overflow:hidden;
  border-radius:4px;
}
.pkg{
  padding:34px 26px;
  background:var(--paper);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:14px;
}
.pkg:last-child{border-right:0}
.section--dark .pkg{background:transparent;border-color:rgba(246,239,220,.15)}
.pkg__tag{
  font-family:var(--mono);
  font-size:14px;
  letter-spacing:.06em;
  color:var(--orange-deep);
  text-transform:uppercase;
}
.section--dark .pkg__tag{color:var(--orange-mute)}
.pkg__name{
  font-family:var(--display);
  font-weight:700;
  font-size:34px;
  line-height:.95;
  letter-spacing:-.02em;
}
.pkg__name em{font-style:italic;font-weight:500;color:var(--orange-2)}
.section--dark .pkg__name em{color:var(--orange-mute)}
.pkg__price{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  font-size:20px;
  color:var(--orange-2);
  margin-top:-4px;
}
.section--dark .pkg__price{color:var(--orange-mute)}
.pkg ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:10px}
.pkg li{font-size:14px;line-height:1.55;padding-left:20px;position:relative;opacity:.92}
.pkg li::before{content:'';position:absolute;left:0;top:.6em;width:12px;height:1px;background:var(--orange)}
@media (max-width:880px){
  .packages{grid-template-columns:1fr}
  .pkg{border-right:0;border-bottom:1px solid var(--line)}
  .pkg:last-child{border-bottom:0}
}

/* ===== TIMELINE / ERVARINGEN ===== */
.timeline{border-top:1px solid var(--line)}
.timeline__group{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:30px;
  padding:24px 0;
  border-bottom:1px solid var(--line-soft);
}
.timeline__year{
  font-family:var(--display-2);
  font-size:48px;
  color:var(--orange-2);
  line-height:1;
  letter-spacing:-.02em;
}
.timeline__year small{display:block;font-size:.4em;color:var(--ink-3);font-family:var(--mono);letter-spacing:.06em;margin-top:6px}
.timeline__items{display:flex;flex-direction:column;gap:6px}
.timeline__items li{
  font-size:15px;
  line-height:1.55;
  color:var(--ink-2);
  list-style:none;
  padding-left:18px;
  position:relative;
}
.timeline__items li::before{content:'';position:absolute;left:0;top:.7em;width:10px;height:1px;background:var(--orange)}
@media (max-width:780px){.timeline__group{grid-template-columns:1fr;gap:8px}}

/* ===== AGENDA ===== */
.agenda{padding:80px 0;border-bottom:1px solid var(--line)}
.agenda__head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  margin-bottom:30px;
  padding-bottom:22px;
  border-bottom:1px solid var(--line);
}
.agenda__head h2{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(36px,4.5vw,68px);
  letter-spacing:-.02em;
  color:var(--ink);
}
.agenda__head h2 em{font-style:italic;font-weight:500;color:var(--orange-2)}
.agenda__row{
  display:grid;
  grid-template-columns:130px 1fr 170px 160px;
  gap:24px;
  align-items:center;
  padding:18px 0;
  border-bottom:1px dashed rgba(11,9,7,.18);
  transition:padding .25s var(--ease-out), background .25s var(--ease-out);
}
.agenda__row:hover{padding-left:18px;background:rgba(255,165,0,.05)}
.agenda__date{
  font-family:var(--display-2);
  font-size:28px;
  line-height:1;
  letter-spacing:-.01em;
  text-transform:uppercase;
}
.agenda__date b{display:block;font-size:48px;color:var(--orange-2);letter-spacing:-.03em}
.agenda__event{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  font-size:22px;
  line-height:1.3;
  letter-spacing:-.01em;
}
.agenda__event small{
  display:block;
  font-family:var(--mono);
  font-style:normal;
  font-size:14px;
  color:var(--ink-3);
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-top:4px;
}
.agenda__loc{
  font-family:var(--mono);
  font-size:15px;
  color:var(--ink-2);
  text-transform:uppercase;
  letter-spacing:.04em;
}
.agenda__status{
  font-family:var(--body);
  font-size:12px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:9px 16px;
  text-align:center;
  justify-self:end;
  background:var(--orange);
  color:var(--paper);
  border-radius:999px;
  transition:background .25s var(--ease-out), transform .2s var(--ease-out);
}
.agenda__status:hover{background:var(--ink);transform:translateY(-2px)}
.agenda__status.full{background:var(--ink-3);cursor:default}
@media (max-width:880px){
  .agenda__row{grid-template-columns:1fr;gap:6px}
  .agenda__status{justify-self:start;display:inline-block}
}

/* ===== STORY / OVER ===== */
.story{
  background:var(--paper-2);
  padding:90px 0;
  border-bottom:1px solid var(--line);
  position:relative;
  overflow:hidden;
}
.story__year-bg{
  position:absolute;
  bottom:-80px;right:-30px;
  font-family:var(--display);
  font-weight:800;
  font-style:italic;
  font-size:clamp(260px,38vw,520px);
  color:var(--orange);
  opacity:.06;
  letter-spacing:-.06em;
  line-height:.8;
  pointer-events:none;
  z-index:0;
  user-select:none;
}
.story__grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:60px;
  align-items:center;
  position:relative;
  z-index:1;
}
.story__img{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  border:1px solid var(--line);
}
.story__img img{width:100%;height:100%;object-fit:cover;filter:contrast(1.06) saturate(.95)}
.story__img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg, transparent 55%, rgba(11,9,7,.45) 100%);pointer-events:none}
.story__img-cap{
  position:absolute;
  bottom:18px;left:18px;right:18px;
  color:var(--paper);
  font-family:var(--display);
  font-weight:600;
  font-style:italic;
  font-size:20px;
  line-height:1.2;
  z-index:2;
}
.story__body p{font-size:17px;line-height:1.75;color:var(--ink-2);margin-bottom:18px}
.story__body p.lead{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  font-size:26px;
  line-height:1.4;
  color:var(--ink);
  margin-bottom:26px;
  letter-spacing:-.01em;
}
.story__body p.lead::first-letter{
  font-family:var(--display);
  font-weight:800;
  font-size:110px;
  line-height:.85;
  float:left;
  margin:8px 14px -8px 0;
  color:var(--orange-2);
  font-style:normal;
}
.story__body strong{
  color:var(--ink);
  font-weight:600;
  background:linear-gradient(transparent 60%, rgba(255,165,0,.2) 60%);
  padding:0 2px;
}
@media (max-width:880px){.story__grid{grid-template-columns:1fr;gap:36px}}

/* ===== PULL QUOTE ===== */
.pull-quote{background:var(--ink);color:var(--paper);padding:90px 0;border-bottom:1px solid var(--line);position:relative}
.pull-quote::before{
  content:'\201C';
  position:absolute;
  top:20px;left:40px;
  font-family:var(--display);
  font-weight:800;
  font-size:240px;
  color:var(--orange);
  line-height:1;
  opacity:.6;
}
.pull-quote blockquote{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  font-size:clamp(28px,4vw,54px);
  line-height:1.25;
  max-width:1000px;
  margin:0 auto;
  position:relative;
  letter-spacing:-.01em;
}
.pull-quote blockquote em{font-style:italic;color:var(--orange-mute);background:linear-gradient(transparent 80%, rgba(255,165,0,.4) 80%)}
.pull-quote__attr{
  margin:30px auto 0;
  max-width:1000px;
  font-family:var(--mono);
  font-size:18px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(246,239,220,.6);
  text-align:right;
}
.pull-quote__attr::before{content:'— '}

/* ===== QUOTES GRID ===== */
.quotes-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  border-left:1px solid var(--line);
  border-top:1px solid var(--line);
}
.quote{
  padding:32px 28px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--paper);
  display:flex;flex-direction:column;gap:14px;min-height:200px;
}
.quote blockquote{
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  font-size:clamp(17px,1.6vw,22px);
  line-height:1.4;
  color:var(--ink);
}
.quote blockquote::before{content:'\201C';font-family:var(--display);font-weight:800;font-size:64px;line-height:0;color:var(--orange);vertical-align:-22px;margin-right:6px}
.quote__attr{margin-top:auto;padding-top:12px;border-top:1px solid var(--line-soft);font-family:var(--mono);font-size:14px;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase}
@media (max-width:780px){.quotes-grid{grid-template-columns:1fr}}

/* ===== LOGOS - statische rij (geen scrollen, 1 marquee per pagina = showreel) ===== */
.logos{background:var(--paper-2);padding:50px 0;border-bottom:1px solid var(--line)}
.logos__title{
  font-family:var(--mono);
  font-size:16px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--orange-deep);
  text-align:center;
  margin-bottom:28px;
}
.logos__row{
  display:flex;
  justify-content:space-around;
  align-items:center;
  flex-wrap:wrap;
  gap:40px 50px;
  max-width:1100px;
  margin:0 auto;
  padding:0 24px;
}
.logos__row img{height:54px;width:auto;opacity:.78;filter:saturate(.92);transition:opacity .25s var(--ease-out), transform .25s var(--ease-out)}
.logos__row img:hover{opacity:1;transform:scale(1.06)}
@media (max-width:780px){.logos__row{gap:24px 32px}.logos__row img{height:38px}}

/* ===== SHOWREEL - horizontale foto-strip ===== */
.showreel{
  background:var(--ink);
  padding:60px 0 40px;
  overflow:hidden;
  border-bottom:1px solid var(--line);
  position:relative;
}
.showreel__head{padding:0 32px;margin-bottom:28px;display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:14px}
.showreel__head h2{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(34px,4.5vw,64px);
  letter-spacing:-.02em;
  color:var(--paper);
  line-height:.95;
}
.showreel__head h2 em{font-style:italic;font-weight:500;color:var(--orange-mute)}
.showreel__head p{color:rgba(246,239,220,.7);font-size:15px;max-width:380px;font-family:var(--display);font-style:italic}
.showreel__strip{
  display:flex;
  gap:18px;
  width:max-content;
  animation:photo-tick 60s linear infinite;
}
.showreel__strip > div{display:inline-flex;gap:18px}
.showreel__strip figure{
  width:240px;
  height:300px;
  position:relative;
  overflow:hidden;
  border:1px solid rgba(246,239,220,.18);
  flex-shrink:0;
  background:var(--ink-2);
  transition:transform .35s var(--ease-out);
}
.showreel__strip figure:nth-child(odd){transform:rotate(-1deg)}
.showreel__strip figure:nth-child(even){transform:rotate(1deg)}
.showreel__strip figure:hover{transform:rotate(0) scale(1.04);z-index:5}
.showreel__strip img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(.95)}
.showreel__strip figcaption{
  position:absolute;
  bottom:8px;left:8px;
  background:var(--paper);
  color:var(--ink);
  padding:3px 9px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.04em;
  text-transform:uppercase;
}
@keyframes photo-tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.showreel__strip{animation:none}}
@media (max-width:780px){
  .showreel{padding:40px 0 30px}
  .showreel__head{padding:0 20px;margin-bottom:20px}
  .showreel__strip figure{width:170px;height:220px}
}

/* ===== FAQ ===== */
.faq__list{border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line-soft)}
.faq__q{
  width:100%;
  text-align:left;
  padding:22px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(19px,2vw,26px);
  line-height:1.15;
  letter-spacing:-.01em;
  cursor:pointer;
  list-style:none;
}
.faq__q::-webkit-details-marker{display:none}
.faq__q em{font-style:italic;font-weight:500;color:var(--orange-2)}
.faq__q:hover{color:var(--orange-2)}
.faq__q .plus{
  flex-shrink:0;
  width:30px;height:30px;
  border:1.5px solid var(--ink);
  border-radius:50%;
  display:grid;place-items:center;
  font-size:18px;
  font-weight:400;
  transition:all .3s var(--ease-out);
  font-family:var(--body);
}
.faq__item[open] .faq__q .plus{transform:rotate(45deg);background:var(--orange-2);color:var(--paper);border-color:var(--orange-2)}
.faq__a{padding:0 0 24px;font-size:16px;line-height:1.7;color:var(--ink-2);max-width:780px}
.faq__a strong{color:var(--ink);font-weight:600}

/* ===== INFO STRIP ===== */
.info-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
.info-strip__card{
  padding:20px 22px;
  background:var(--paper);
  border:1px solid var(--line);
  font-size:14px;
  line-height:1.55;
  color:var(--ink-2);
}
.info-strip__card b{
  display:block;
  font-family:var(--display);
  font-weight:700;
  font-size:19px;
  letter-spacing:-.01em;
  color:var(--ink);
  margin-bottom:6px;
}
.section--dark .info-strip__card{background:rgba(246,239,220,.06);border-color:rgba(246,239,220,.15);color:rgba(246,239,220,.78)}
.section--dark .info-strip__card b{color:var(--orange-mute)}
@media (max-width:780px){.info-strip{grid-template-columns:1fr}}

/* ===== FINAL CTA ===== */
.cta-strip{
  background:var(--orange);
  color:var(--paper);
  padding:90px 0;
  text-align:center;
  border-bottom:1px solid var(--line);
  position:relative;
  overflow:hidden;
}
.cta-strip::before{
  content:'Boek nu';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--display);
  font-style:italic;
  font-weight:500;
  font-size:clamp(120px,18vw,320px);
  color:rgba(11,9,7,.08);
  letter-spacing:-.03em;
  pointer-events:none;
  z-index:0;
  white-space:nowrap;
}
.cta-strip__inner{position:relative;z-index:1}
.cta-strip h2{
  font-family:var(--display);
  font-weight:700;
  font-size:clamp(40px,6vw,98px);
  letter-spacing:-.03em;
  line-height:.92;
  margin:14px 0 20px;
}
.cta-strip h2 em{font-style:italic;font-weight:500;color:var(--ink)}
.cta-strip p{
  font-family:var(--display);
  font-style:italic;
  font-size:20px;
  max-width:580px;
  margin:0 auto 30px;
  line-height:1.45;
}
.cta-strip .btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink);font-size:14px;padding:20px 36px}
.cta-strip .btn-primary:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}

/* ===== FORM ===== */
.form{
  background:var(--paper);
  border:1px solid var(--line);
  padding:34px;
  display:flex;flex-direction:column;gap:18px;
}
.form__label{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--orange-deep);
  margin-bottom:6px;
  display:block;
}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form input,.form textarea,.form select{
  width:100%;
  padding:12px 0;
  border:0;
  border-bottom:1px solid var(--line);
  background:transparent;
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  outline:0;
  transition:border-color .2s var(--ease-out);
}
.form input:focus,.form textarea:focus,.form select:focus{border-bottom-color:var(--orange-2)}
.form textarea{resize:vertical;min-height:80px}
.form__submit{
  margin-top:8px;
  background:var(--ink);
  color:var(--paper);
  padding:18px 28px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  transition:background .25s var(--ease-out);
}
.form__submit:hover{background:var(--orange)}
.form__note{font-size:12px;color:var(--ink-3);line-height:1.5}
@media (max-width:700px){.form{padding:24px}.form__row{grid-template-columns:1fr}}

/* ===== FOOTER ===== */
.site-footer{
  background:var(--ink);
  color:var(--paper);
  padding:60px 0 26px;
}
.site-footer__grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:44px;
  margin-bottom:46px;
}
.site-footer__brand{
  font-family:var(--display);
  font-weight:700;
  font-style:italic;
  font-size:32px;
  letter-spacing:-.01em;
  margin-bottom:14px;
  color:var(--orange-mute);
}
.site-footer p{opacity:.78;font-size:14px;line-height:1.6;max-width:320px}
.site-footer h4{
  font-family:var(--mono);
  font-size:16px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--orange-mute);
  margin-bottom:14px;
  font-weight:normal;
}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:14px}
.site-footer li a{opacity:.78;transition:opacity .2s var(--ease-out), color .2s var(--ease-out)}
.site-footer li a:hover{opacity:1;color:var(--orange-mute)}
.site-footer__bottom{
  padding-top:22px;
  border-top:1px solid rgba(246,239,220,.15);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:14px;
  font-family:var(--mono);
  font-size:14px;
  letter-spacing:.04em;
  color:rgba(246,239,220,.5);
}
@media (max-width:780px){.site-footer__grid{grid-template-columns:1fr 1fr;gap:28px}}
