/* =====================================================================
   Kasteel Asten — website huisstijl (afgeleid van flyer & poster)
   Geen stempel, geen "Anno 1432" merkteken.
   ===================================================================== */
:root{
  --ka-blauw:#1A2E4A; --ka-blauw-mid:#243C5E; --ka-blauw-l:#2E4F7A;
  --ka-goud:#D4A847; --ka-goud-w:#C4973A;
  --ka-roest:#9E4012; --ka-roest-l:#C05018;
  --ka-steen:#1C1410; --ka-aarde:#3D2E1E; --ka-zand:#E8DCC8;
  --ka-ivoor:#F5EFE0; --ka-wit:#FAFAF7; --ka-mos:#4A5E2A;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Libre Baskerville',Georgia,serif;
  --font-label:'Raleway',sans-serif;
  --maxw:1180px;
  --header-h:78px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ka-aarde);
  background:var(--ka-ivoor);
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--ka-roest);text-decoration:none}
a:hover{color:var(--ka-roest-l)}

/* warm perkament textuur op vlakken */
.paper{
  background:
    radial-gradient(circle at 16% 8%, rgba(212,168,71,.05), transparent 56%),
    radial-gradient(circle at 88% 94%, rgba(158,64,18,.045), transparent 52%),
    var(--ka-ivoor);
}
.bg-wit{background:var(--ka-wit)}
.bg-zand{background:var(--ka-zand)}
.bg-blauw{background:var(--ka-blauw);color:var(--ka-zand)}

/* ---------- LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:78px 0}
.section.tight{padding:52px 0}

/* ---------- TYPOGRAFIE ---------- */
.eyebrow{
  font-family:var(--font-label);font-weight:600;text-transform:uppercase;
  letter-spacing:.34em;font-size:12px;color:var(--ka-goud-w);
}
.eyebrow.roest{color:var(--ka-roest)}
.eyebrow.goud{color:var(--ka-goud)}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ka-blauw);font-weight:400;line-height:1.04}
h1{font-size:clamp(2.6rem,6vw,4.4rem);font-weight:300;letter-spacing:.005em}
h2{font-size:clamp(2rem,3.6vw,2.9rem);font-weight:500}
h3{font-size:clamp(1.4rem,2.2vw,1.85rem);font-weight:600}
h4{font-size:1.3rem;font-weight:600}
.accent{font-style:italic;color:var(--ka-roest)}
.quote{font-family:var(--font-display);font-style:italic;font-weight:300;color:var(--ka-blauw);font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.4}
.quote.opdonker{color:var(--ka-goud)}
p{font-size:1.02rem;line-height:1.8;color:var(--ka-aarde);text-wrap:pretty}
p + p{margin-top:1.05em}
.lead{font-size:1.15rem;line-height:1.85}
.bg-blauw p,.bg-blauw .lead{color:#cdd7e4}
.bg-blauw h1,.bg-blauw h2,.bg-blauw h3,.bg-blauw h4{color:var(--ka-ivoor)}

/* ---------- GOUDEN REGEL ---------- */
.rule{display:flex;align-items:center;gap:12px;margin:18px 0}
.rule .ln{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--ka-goud),transparent)}
.rule .dia{width:7px;height:7px;background:var(--ka-goud);transform:rotate(45deg);flex:none}
.rule.solid .ln{background:var(--ka-goud);opacity:.6}
.rule.left{justify-content:flex-start}
.rule.left .ln{flex:none;width:64px;background:var(--ka-goud);opacity:.7}
.rule.center{max-width:320px;margin-left:auto;margin-right:auto}

/* sectiekop */
.section-head{max-width:760px}
.section-head.center{margin:0 auto;text-align:center}
.section-head .eyebrow{display:block;margin-bottom:14px}
.section-head h2{margin-bottom:4px}

/* ---------- KNOPPEN ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-label);font-weight:600;text-transform:uppercase;
  letter-spacing:.18em;font-size:.74rem;
  padding:.95em 1.7em;border:1.5px solid var(--ka-goud);
  background:var(--ka-blauw);color:var(--ka-ivoor);
  cursor:pointer;transition:all .2s ease;border-radius:2px;
}
.btn:hover{background:var(--ka-blauw-l);color:var(--ka-ivoor)}
.btn.goud{background:var(--ka-goud);color:var(--ka-blauw);border-color:var(--ka-goud)}
.btn.goud:hover{background:var(--ka-goud-w);color:var(--ka-blauw)}
.btn.ghost{background:transparent;color:var(--ka-blauw);border-color:var(--ka-blauw)}
.btn.ghost:hover{background:var(--ka-blauw);color:var(--ka-ivoor)}
.bg-blauw .btn.ghost{color:var(--ka-ivoor);border-color:var(--ka-goud)}
.bg-blauw .btn.ghost:hover{background:var(--ka-goud);color:var(--ka-blauw)}
.arrow{font-size:1.1em;line-height:0}

/* ---------- FOTO-FRAME (goud + wit, zoals poster) ---------- */
.frame{border:2px solid var(--ka-goud);background:var(--ka-wit);padding:8px}
.frame img{width:100%;height:auto;display:block}
figure.frame figcaption{
  font-family:var(--font-label);font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ka-goud-w);padding:8px 2px 2px;text-align:center
}

/* ---------- KAARTEN ---------- */
.card-blauw{background:var(--ka-blauw);color:var(--ka-zand);border:1px solid var(--ka-goud);border-radius:3px;padding:26px 26px 28px}
.card-blauw .kicker{font-family:var(--font-label);font-weight:600;letter-spacing:.22em;font-size:.66rem;color:var(--ka-goud);text-transform:uppercase}
.card-blauw h3,.card-blauw h4{color:var(--ka-ivoor);margin:8px 0 8px}
.card-blauw p{color:#cdd7e4;font-size:.95rem}
.card-blauw .tag{display:inline-block;font-family:var(--font-label);font-weight:600;letter-spacing:.16em;font-size:.62rem;color:var(--ka-goud);text-transform:uppercase;margin-top:14px}
.card-zand{background:var(--ka-zand);border-left:3px solid var(--ka-roest);padding:24px 26px}
.card-zand .kicker{font-family:var(--font-label);font-weight:600;letter-spacing:.22em;font-size:.66rem;color:var(--ka-roest);text-transform:uppercase}
.card-zand h3,.card-zand h4{color:var(--ka-blauw);margin:8px 0 8px}
.card-zand .iban{display:block;font-family:var(--font-label);font-weight:600;letter-spacing:.06em;font-size:.85rem;color:var(--ka-blauw);margin-top:12px}
.card{background:var(--ka-wit);border:1px solid var(--ka-zand);border-top:3px solid var(--ka-goud);padding:28px 26px;transition:box-shadow .2s,transform .2s}
a.card:hover{box-shadow:0 18px 40px -24px rgba(26,46,74,.5);transform:translateY(-3px)}

/* ---------- GRID HELPERS ---------- */
.grid{display:grid;gap:26px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.split.rev .pic{order:2}

/* dotted scheiding */
.dotsep{border:0;border-top:1px dotted rgba(158,64,18,.3);margin:26px 0}

/* ===================================================================
   HEADER / NAVIGATIE
   =================================================================== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--ka-blauw);
  border-bottom:2px solid var(--ka-goud);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;height:var(--header-h);max-width:var(--maxw);margin:0 auto;padding:0 28px}
.brand{display:flex;align-items:center;gap:14px;flex:none}
.brand img{height:46px;width:auto}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .org{font-family:var(--font-display);font-weight:500;letter-spacing:.13em;font-size:1.18rem;color:var(--ka-ivoor);text-transform:uppercase}
.brand .sub{font-family:var(--font-label);font-weight:500;letter-spacing:.26em;font-size:.56rem;color:var(--ka-goud);text-transform:uppercase;margin-top:3px}

.menu{display:flex;align-items:stretch;gap:2px;height:100%}
.menu > li{position:relative;display:flex;align-items:center}
.menu > li > a{
  font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.16em;
  font-size:.72rem;color:var(--ka-ivoor);padding:0 14px;height:100%;display:flex;align-items:center;gap:6px;
  border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s
}
.menu > li > a .caret{font-size:.5rem;opacity:.7;transform:translateY(1px)}
.menu > li:hover > a,.menu > li.open > a{color:var(--ka-goud)}
.menu > li[data-active] > a{color:var(--ka-goud);border-bottom-color:var(--ka-goud)}

/* dropdown */
.dropdown{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
  min-width:262px;background:var(--ka-wit);border:1px solid var(--ka-zand);
  border-top:3px solid var(--ka-goud);box-shadow:0 24px 48px -18px rgba(13,22,38,.5);
  padding:10px;opacity:0;visibility:hidden;transition:opacity .16s,transform .16s;
  z-index:120
}
.menu > li:hover .dropdown,.menu > li.open .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{
  display:block;font-family:var(--font-label);font-weight:500;letter-spacing:.04em;
  font-size:.82rem;text-transform:none;color:var(--ka-aarde);padding:9px 12px;border-radius:2px;transition:background .12s,color .12s
}
.dropdown a:hover{background:var(--ka-ivoor);color:var(--ka-blauw)}
.dropdown a[data-active]{color:var(--ka-roest)}
.dropdown a .ext{font-size:.62rem;color:var(--ka-goud-w);margin-left:4px}
.dropdown a.ddsub{padding-left:28px;font-size:.78rem;color:#6b5a44;position:relative}
.dropdown a.ddsub::before{content:"\2014";position:absolute;left:12px;color:var(--ka-goud-w)}
.dropdown a.ddsub:hover{color:var(--ka-blauw)}
.dropdown .ddhead{font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.6rem;color:var(--ka-goud-w);padding:12px 12px 5px}
.dropdown .ddsep{border:0;border-top:1px dotted rgba(158,64,18,.28);margin:6px 8px}

.nav-cta{flex:none}
.nav-cta .btn{padding:.7em 1.25em;font-size:.68rem}

/* hamburger */
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.hamb span{width:24px;height:2px;background:var(--ka-goud);transition:.2s}

/* ===================================================================
   HERO
   =================================================================== */
.hero{position:relative;min-height:min(78vh,640px);display:flex;align-items:flex-end;overflow:hidden;background:var(--ka-blauw)}
.hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.86}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,22,38,.35) 0%,rgba(13,22,38,.15) 40%,rgba(13,22,38,.82) 100%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 28px 64px;width:100%}
.hero .eyebrow{color:var(--ka-goud);margin-bottom:16px}
.hero h1{color:var(--ka-ivoor);max-width:14ch}
.hero .quote{color:var(--ka-zand);margin-top:18px;max-width:34ch}
.hero .rule{max-width:240px}

/* compacte pagina-kop (binnenpagina's) */
.page-hero{background:var(--ka-blauw);color:var(--ka-ivoor);position:relative;border-bottom:2px solid var(--ka-goud);overflow:hidden}
.page-hero.with-img .ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.32}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,46,74,.5),rgba(26,46,74,.85))}
.page-hero .wrap{position:relative;z-index:2;padding-top:64px;padding-bottom:60px}
.page-hero .eyebrow{color:var(--ka-goud);display:block;margin-bottom:14px}
.page-hero h1{color:var(--ka-ivoor);font-size:clamp(2.3rem,5vw,3.6rem)}
.page-hero .intro{color:#cdd7e4;max-width:60ch;margin-top:16px;font-size:1.1rem}
.breadcrumb{font-family:var(--font-label);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ka-goud-w);margin-bottom:20px}
.breadcrumb a{color:var(--ka-goud-w)}
.breadcrumb a:hover{color:var(--ka-goud)}
.breadcrumb span{margin:0 8px;opacity:.6}

/* ---------- HOOFDSECTIE-KAARTEN (home) ---------- */
.hubcard{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:300px;padding:28px;overflow:hidden;background:var(--ka-blauw);border:1px solid rgba(212,168,71,.4)}
.hubcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;transition:transform .5s,opacity .3s}
.hubcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,46,74,.25),rgba(26,46,74,.9))}
.hubcard:hover img{transform:scale(1.05);opacity:.6}
.hubcard > *{position:relative;z-index:2}
.hubcard .card-link{position:absolute;inset:0;z-index:2}
.hubcard .num{font-family:var(--font-display);font-style:italic;color:var(--ka-goud);font-size:1.3rem;opacity:.85}
.hubcard h3{color:var(--ka-ivoor);margin:6px 0 8px}
.hubcard p{color:#cdd7e4;font-size:.9rem;line-height:1.6}
.hubcard .links{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px}
.hubcard .links a{font-family:var(--font-label);font-weight:600;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ka-goud);background:rgba(20,34,56,.82);border:1px solid rgba(212,168,71,.4);padding:6px 11px;border-radius:2px;backdrop-filter:blur(2px);transition:background .15s,color .15s}
.hubcard .links a:hover{background:var(--ka-goud);color:var(--ka-blauw);border-color:var(--ka-goud)}

/* ---------- FOTO-GALERIJ ---------- */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.gallery a,.gallery .gitem{display:block;overflow:hidden;border:2px solid var(--ka-goud);background:var(--ka-wit);padding:5px}
.gallery img{width:100%;height:150px;object-fit:cover;transition:transform .4s}
.gallery a:hover img{transform:scale(1.06)}

/* ---------- NIEUWS ---------- */
.news-lead{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center}
.news-meta{font-family:var(--font-label);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.68rem;color:var(--ka-roest);margin-bottom:10px}

/* ---------- TIJDLIJN ---------- */
.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:grid;grid-template-columns:120px 1fr;gap:28px;padding:30px 0;border-top:1px dotted rgba(158,64,18,.3)}
.tl-item:first-child{border-top:0}
.tl-item .yr{font-family:var(--font-label);font-weight:700;letter-spacing:.04em;font-size:.95rem;color:var(--ka-ivoor);background:var(--ka-blauw);align-self:start;text-align:center;padding:8px 0;border-radius:2px;border:1px solid var(--ka-goud)}
.tl-item .yr small{display:block;color:var(--ka-goud);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;margin-top:2px}

/* prose blok (verbatim teksten) */
.prose{max-width:72ch}
.prose.wide{max-width:80ch}
.prose h2{margin:1.4em 0 .4em}
.prose h3{margin:1.3em 0 .35em;color:var(--ka-blauw)}
.prose > h2:first-child,.prose > h3:first-child{margin-top:0}
.prose ul,.prose ol{margin:.6em 0 .6em 1.3em}
.prose li{margin:.35em 0;line-height:1.75}
.prose .subhead{font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;color:var(--ka-goud-w);margin:2em 0 .6em}

/* anker-info kaart */
.infobox{background:var(--ka-zand);border-left:3px solid var(--ka-goud);padding:22px 26px}
.infobox .kicker{font-family:var(--font-label);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.66rem;color:var(--ka-roest);margin-bottom:8px}
.infobox dl{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-size:.95rem}
.infobox dt{font-family:var(--font-label);font-weight:600;letter-spacing:.04em;color:var(--ka-blauw)}

/* veelgestelde-vragen accordeon */
.faqacc{margin-top:16px}
.faqacc details{border-top:1px solid var(--ka-zand)}
.faqacc details:last-child{border-bottom:1px solid var(--ka-zand)}
.faqacc summary{cursor:pointer;list-style:none;position:relative;padding:20px 44px 20px 0;font-family:var(--font-display);font-weight:500;font-size:1.3rem;color:var(--ka-blauw);transition:color .15s}
.faqacc summary::-webkit-details-marker{display:none}
.faqacc summary:hover{color:var(--ka-roest)}
.faqacc summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--font-display);font-size:1.8rem;color:var(--ka-goud);line-height:1}
.faqacc details[open] summary::after{content:"\2013"}
.faqacc details p{padding:0 44px 22px 0;color:var(--ka-aarde);line-height:1.8;max-width:76ch}

/* let-op melding (twee Anna Ceelen pagina's) */
.notice{display:flex;gap:14px;align-items:flex-start;background:var(--ka-wit);border:1px solid var(--ka-goud);border-left:4px solid var(--ka-roest);padding:18px 22px;border-radius:2px}
.notice .nm{font-family:var(--font-label);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:.64rem;color:var(--ka-roest);margin-bottom:5px}
.notice p{font-size:.92rem;line-height:1.6}

/* ---------- KADOTIP / ZACHTE NUDGE ---------- */
.kadotip{margin-top:28px;background:rgba(212,168,71,.1);border:1px solid var(--ka-goud);border-left:4px solid var(--ka-goud);border-radius:2px;padding:16px 20px;max-width:54ch}
.kadotip .kt-label{display:inline-block;font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;color:var(--ka-goud);margin-bottom:6px}
.kadotip p{font-size:.92rem;line-height:1.6;color:#dfe6ef}
.bg-zand .kadotip p,.paper .kadotip p{color:var(--ka-aarde)}
.bg-blauw .kadotip p{color:#e7edf5}

/* ---------- FORMULIEREN ---------- */
.form-card{background:var(--ka-wit);border:1px solid var(--ka-zand);border-top:3px solid var(--ka-goud);padding:30px 30px 32px}
.ka-form .field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.ka-form label{font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--ka-goud-w)}
.ka-form input,.ka-form select,.ka-form textarea{
  font-family:var(--font-body);font-size:.95rem;color:var(--ka-aarde);
  background:var(--ka-ivoor);border:1px solid var(--ka-zand);border-radius:2px;padding:11px 13px;width:100%;transition:border-color .15s
}
.ka-form input:focus,.ka-form select:focus,.ka-form textarea:focus{outline:none;border-color:var(--ka-goud)}
.ka-form textarea{min-height:96px;resize:vertical}
.ka-form .frow{display:grid;grid-template-columns:1fr 1fr;gap:0 20px}
.ka-form .hint{font-family:var(--font-label);font-size:.66rem;letter-spacing:.04em;color:#8a7a64;text-transform:none;font-weight:400}
.ka-form .form-note{font-size:.92rem;line-height:1.6;color:var(--ka-aarde);margin:6px 0 18px}
.ka-form button{margin-top:6px}
.form-done{display:none;background:var(--ka-zand);border-left:3px solid var(--ka-mos);padding:20px 24px}
.form-done.show{display:block}
.form-done .kicker{font-family:var(--font-label);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:.66rem;color:var(--ka-mos);margin-bottom:6px}
@media (max-width:560px){.ka-form .frow{grid-template-columns:1fr}}

/* ---------- BOEKING-COMPONENTEN (herbruikbaar) ---------- */
.booking-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start}
.opt-card{background:var(--ka-wit);border:1px solid var(--ka-zand);border-top:3px solid var(--ka-goud);padding:34px 32px 32px;display:flex;flex-direction:column;box-shadow:0 18px 44px -30px rgba(26,46,74,.45)}
.opt-card .tag{display:inline-block;font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;color:var(--ka-roest);margin-bottom:8px}
.opt-card h3{margin-bottom:6px}
.facts{list-style:none;margin:14px 0 0;display:flex;flex-direction:column;gap:9px}
.facts li{position:relative;padding-left:22px;font-size:.95rem;line-height:1.6;color:var(--ka-aarde)}
.facts li::before{content:"✦";position:absolute;left:0;top:2px;color:var(--ka-goud);font-size:.66rem}
.price{font-family:var(--font-display);font-style:italic;font-weight:600;color:var(--ka-roest);font-size:1.95rem;line-height:1;margin:18px 0 0}
.price .per{font-family:var(--font-body);font-style:normal;font-size:.82rem;color:var(--ka-aarde);font-weight:400;letter-spacing:.02em}
.subblock{border-top:1px solid var(--ka-zand);margin-top:24px;padding-top:22px}
.subblock:first-of-type{border-top:none;margin-top:16px;padding-top:0}
.actions{margin-top:22px;display:flex;flex-direction:column;gap:10px}
.note{font-family:var(--font-label);font-size:.86rem;letter-spacing:.03em;color:#5a4a34}

/* prijstrappen (volwassene / kind / peuter) */
.tiers{list-style:none;margin:18px 0 0;border-top:1px solid var(--ka-zand)}
.tiers li{display:flex;align-items:baseline;gap:16px;padding:11px 2px;border-bottom:1px solid var(--ka-zand)}
.tiers .t-amt{font-family:var(--font-display);font-style:italic;font-weight:600;color:var(--ka-roest);font-size:1.5rem;line-height:1;min-width:78px}
.tiers .t-lbl{font-size:.92rem;color:var(--ka-aarde);line-height:1.4}

/* genummerde stappen (planning) */
.steps-box{background:var(--ka-zand);border-left:3px solid var(--ka-goud);padding:22px 26px;margin-top:20px}
.steps-box .kicker{font-family:var(--font-label);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:.66rem;color:var(--ka-roest);margin-bottom:14px}
.steps{list-style:none;margin:0}
.steps li{position:relative;display:flex;gap:15px;padding:13px 0;border-top:1px solid rgba(158,64,18,.16)}
.steps li:first-child{border-top:none;padding-top:0}
.steps .s-num{flex:none;width:30px;height:30px;border-radius:50%;border:1px solid var(--ka-goud);background:var(--ka-wit);color:var(--ka-roest);font-family:var(--font-label);font-weight:600;font-size:.86rem;display:flex;align-items:center;justify-content:center}
.steps strong{display:block;font-family:var(--font-display);font-style:italic;font-size:1.16rem;font-weight:600;color:var(--ka-blauw)}
.steps p{font-size:.88rem;color:var(--ka-aarde);line-height:1.55;margin-top:2px}
.note.center{text-align:center}

/* prijstabel (fotoshoot) */
.ptable{width:100%;border-collapse:collapse;margin-top:16px;font-size:.88rem}
.ptable caption{font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--ka-goud-w);text-align:left;margin-bottom:8px}
.ptable th,.ptable td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--ka-zand);vertical-align:top}
.ptable thead th{font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.62rem;color:var(--ka-blauw);border-bottom:1.5px solid var(--ka-goud)}
.ptable td.dur{font-family:var(--font-display);font-size:1.1rem;color:var(--ka-blauw);font-weight:500}
.ptable td.prc{font-family:var(--font-display);font-size:1.1rem;color:var(--ka-roest);font-weight:600;font-style:italic}
.ptable tr.incl td{background:rgba(212,168,71,.08)}
.ptable .yes{color:var(--ka-mos);font-weight:700}
.ptable .pick{display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.ptable a.add{display:inline-block;font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.62rem;color:var(--ka-roest);border-bottom:1px solid rgba(158,64,18,.4)}
.ptable a.add:hover{color:var(--ka-roest-l);border-color:var(--ka-roest-l)}
.ptable a.add::before{content:"\271A";margin-right:4px;color:var(--ka-goud-w)}
.ptable a.add.base{color:var(--ka-blauw);border-bottom-color:rgba(26,46,74,.35)}
.ptable a.add.base::before{content:"\2192";color:var(--ka-blauw)}
.ptable .inclnote{font-size:.7rem;color:var(--ka-aarde)}
@media (max-width:760px){.booking-grid{grid-template-columns:1fr}}

/* ===================================================================
   FOOTER
   =================================================================== */
.site-footer{background:var(--ka-blauw);color:var(--ka-zand);border-top:2px solid var(--ka-goud)}
.footer-slogan{text-align:center;padding:46px 28px 38px}
.footer-slogan .quote{color:var(--ka-goud);max-width:none;margin:0 auto;font-size:clamp(1.2rem,2.4vw,1.65rem)}
.footer-main{border-top:1px solid rgba(212,168,71,.25);padding:42px 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.footer-grid .fbrand{display:flex;gap:16px;align-items:flex-start}
.footer-grid .fbrand img{height:56px}
.footer-grid .org{font-family:var(--font-display);font-weight:500;letter-spacing:.13em;font-size:1.4rem;color:var(--ka-ivoor);text-transform:uppercase;line-height:1}
.footer-grid address{font-style:normal;font-family:var(--font-label);font-weight:300;font-size:.82rem;line-height:1.9;letter-spacing:.03em;color:#cdd7e4;margin-top:10px}
.footer-grid .fcol h4{font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.2em;font-size:.66rem;color:var(--ka-goud);margin-bottom:14px}
.footer-grid .fcol a{display:block;color:#cdd7e4;font-family:var(--font-label);font-weight:300;font-size:.85rem;letter-spacing:.02em;padding:4px 0}
.footer-grid .fcol a:hover{color:var(--ka-goud)}
/* ---------- PARTNERS / SPONSOREN ---------- */
.footer-partners{border-top:1px solid rgba(212,168,71,.25);padding:38px 0 42px}
.footer-partners .fp-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.footer-partners h4{font-family:var(--font-label);font-weight:600;text-transform:uppercase;letter-spacing:.26em;font-size:.66rem;color:var(--ka-goud);text-align:center;margin-bottom:6px}
.footer-partners .fp-sub{font-family:var(--font-body);font-style:italic;font-size:.92rem;color:#cdd7e4;text-align:center;margin-bottom:26px}
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.partner{
  display:flex;align-items:center;justify-content:center;text-align:center;
  min-height:88px;padding:16px 18px;
  background:var(--ka-wit);border:1px solid var(--ka-goud);border-radius:3px;
  font-family:var(--font-label);font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;font-size:.74rem;line-height:1.4;color:var(--ka-blauw);
  transition:transform .2s,box-shadow .2s;
}
.partner:hover{transform:translateY(-2px);box-shadow:0 14px 30px -18px rgba(0,0,0,.6)}
.partner span{display:block}
@media (max-width:900px){.partner-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.partner-grid{grid-template-columns:repeat(2,1fr)}.partner{min-height:76px;font-size:.68rem}}

.footer-bottom{border-top:1px solid rgba(212,168,71,.25);padding:18px 28px;text-align:center}
.footer-bottom .meta{font-family:var(--font-label);font-weight:500;letter-spacing:.18em;text-transform:uppercase;font-size:.66rem;color:var(--ka-goud-w)}
.footer-bottom .url{color:var(--ka-ivoor)}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1040px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .g4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .hamb{display:flex}
  .nav-cta{display:none}
  .menu{
    position:fixed;top:var(--header-h);right:0;bottom:0;width:min(86vw,360px);
    flex-direction:column;align-items:stretch;height:auto;gap:0;
    background:var(--ka-blauw);border-left:2px solid var(--ka-goud);
    padding:14px 0 40px;overflow-y:auto;transform:translateX(100%);transition:transform .26s ease;
    box-shadow:-20px 0 50px -20px rgba(0,0,0,.6)
  }
  body.menu-open .menu{transform:translateX(0)}
  body.menu-open{overflow:hidden}
  .menu > li{flex-direction:column;align-items:stretch}
  .menu > li > a{height:auto;padding:15px 26px;border-bottom:1px solid rgba(212,168,71,.15);margin:0;justify-content:space-between}
  .menu > li > a .caret{transition:transform .2s}
  .menu > li.open > a .caret{transform:rotate(180deg)}
  .dropdown{
    position:static;transform:none;opacity:1;visibility:visible;min-width:0;
    box-shadow:none;border:0;border-top:0;background:var(--ka-blauw-mid);
    border-radius:0;padding:4px 0;max-height:0;overflow:hidden;transition:max-height .26s ease;display:block
  }
  .menu > li.open .dropdown,.menu > li:hover .dropdown{transform:none}
  .menu > li.open .dropdown{max-height:760px}
  .menu > li:hover .dropdown{opacity:1;visibility:visible}/* override desktop hover */
  .dropdown a{color:var(--ka-zand);padding:11px 38px}
  .dropdown a:hover{background:rgba(212,168,71,.12);color:var(--ka-goud)}
  .dropdown .ddhead{color:var(--ka-goud);padding:12px 38px 4px}
  .dropdown .ddsep{margin:6px 38px}
  .dropdown a.ddsub{padding-left:54px}
  .dropdown a.ddsub::before{left:38px}
}
@media (max-width:760px){
  .section{padding:54px 0}
  .split,.news-lead{grid-template-columns:1fr;gap:28px}
  .split.rev .pic{order:0}
  .g2,.g3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .tl-item{grid-template-columns:84px 1fr;gap:18px}
  .brand .sub{display:none}
}
@media (max-width:420px){
  .brand .org{font-size:1rem}
  .brand img{height:38px}
}
