/**
 * Edwin Selij Theme — main.css
 * Navy / Gold / Ivory design system
 * Fonts: Cormorant (serif) + DM Sans (sans-serif)
 */

/* ══════════ DESIGN TOKENS ══════════ */
:root {
  --navy:   #0B1F3B;
  --navy-l: #122848;
  --gold:   #C8A75B;
  --gold-l: #dbbe80;
  --gold-d: #9a7a38;
  --ivory:  #F7F5EF;
  --black:  #111111;
  --sand:   #D8CFC0;
  --sand-l: #ede8e0;
  --white:  #ffffff;
  --body:   #333333;
  --r: 4px;
}

/* ══════════ RESET ══════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:18px; }
body { background:var(--ivory); color:var(--body); font-family:'DM Sans',sans-serif; font-weight:300; line-height:1.7; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }

/* ══════════ UTILITY CLASSES ══════════ */
.label { font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:1rem; }
.display { font-family:'Cormorant',serif; font-weight:600; line-height:1.05; }
.display-xl { font-size:clamp(3rem,5.5vw,5rem); }
.display-lg { font-size:clamp(2rem,3.8vw,3.5rem); }
.divider-gold { width:3rem; height:2px; background:var(--gold); margin:1.5rem 0; opacity:.8; }

/* ══════════ BUTTONS ══════════ */
.btn { display:inline-flex; align-items:center; gap:.6rem; font-family:'DM Sans',sans-serif; font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; padding:.95rem 2rem; border-radius:var(--r); transition:all .25s; white-space:nowrap; cursor:pointer; border:none; }
.btn-gold { background:var(--gold); color:var(--black); }
.btn-gold:hover { background:var(--gold-l); transform:translateY(-2px); box-shadow:0 8px 24px rgba(200,167,91,.3); }
.btn-navy { background:var(--navy); color:var(--ivory); }
.btn-navy:hover { background:var(--navy-l); transform:translateY(-2px); }
.btn-outline-ivory { border:1.5px solid rgba(247,245,239,.4); color:var(--ivory); background:transparent; }
.btn-outline-ivory:hover { border-color:var(--ivory); background:rgba(247,245,239,.08); }

/* ══════════ PAGE CONTAINER ══════════ */
.page-container { max-width:900px; margin:0 auto; padding:6rem 3.5rem; }
.page-body { font-size:1rem; line-height:1.85; }
.page-body p+p { margin-top:1.1rem; }
.page-body h2,.page-body h3,.page-body h4 { font-family:'Cormorant',serif; font-weight:600; color:var(--black); margin:2rem 0 1rem; }
.page-body h2 { font-size:1.8rem; }
.page-body h3 { font-size:1.4rem; }
.page-body ul,.page-body ol { margin:1rem 0 1rem 1.5rem; }
.page-body blockquote { border-left:3px solid var(--gold); padding-left:1.5rem; font-family:'Cormorant',serif; font-style:italic; font-size:1.15rem; color:var(--navy); margin:1.5rem 0; }

/* ══════════ NAV ══════════ */
nav { position:fixed; inset:0 0 auto; z-index:300; height:72px; display:flex; align-items:center; padding:0 3.5rem; justify-content:space-between; background:rgba(11,31,59,.97); backdrop-filter:blur(20px); border-bottom:1px solid rgba(200,167,91,.15); transition:box-shadow .3s; }
nav.scrolled { box-shadow:0 4px 40px rgba(0,0,0,.35); }
.nav-logo { display:flex; align-items:center; gap:.75rem; }
.nav-mark { width:38px; height:38px; border-radius:50%; background:var(--gold); display:flex; align-items:center; justify-content:center; font-family:'Cormorant',serif; font-size:1.3rem; font-style:italic; font-weight:700; color:var(--navy); flex-shrink:0; }
.nav-name { font-family:'DM Sans',sans-serif; font-weight:600; font-size:.95rem; letter-spacing:.08em; color:var(--ivory); line-height:1.15; }
.nav-sub { font-family:'Cormorant',serif; font-style:italic; font-size:.75rem; color:var(--gold); }
.nav-links { display:flex; align-items:center; gap:2.5rem; list-style:none; }
.nav-links a { font-family:'DM Sans',sans-serif; font-size:.68rem; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:rgba(247,245,239,.65); transition:color .2s; }
.nav-links a:hover { color:var(--gold); }
.nav-burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.nav-burger span { display:block; width:24px; height:2px; background:var(--ivory); border-radius:2px; }

/* ══════════ HERO ══════════ */
.hero {
  min-height:100vh; padding-top:72px;
  position:relative; overflow:hidden;
  display:flex; align-items:center;
}
.hero-bg { position:absolute; inset:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; object-position:center 30%; }
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(
    105deg,
    rgba(11,31,59,.92) 0%,
    rgba(11,31,59,.75) 45%,
    rgba(11,31,59,.2) 100%
  );
}
.hero-content {
  position:relative; z-index:2;
  padding:0 3.5rem;
  max-width:780px;
}
.hero-content .label { color:var(--gold); }
.hero-headline { font-family:'Cormorant',serif; font-size:clamp(3.2rem,6vw,5.5rem); font-weight:600; line-height:1.02; color:var(--ivory); }
.hero-headline em { font-style:italic; color:var(--gold); display:block; }
.hero-divider { width:3.5rem; height:2px; background:var(--gold); margin:2rem 0; opacity:.8; }
.hero-sub { font-family:'DM Sans',sans-serif; font-size:1.1rem; line-height:1.85; color:rgba(247,245,239,.75); max-width:520px; font-weight:300; }
.hero-chips { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:2rem; }
.chip { font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:500; letter-spacing:.15em; text-transform:uppercase; padding:.45rem 1.1rem; border-radius:100px; border:1px solid rgba(200,167,91,.4); color:rgba(200,167,91,.85); background:rgba(200,167,91,.06); }
.hero-cta { margin-top:2.5rem; display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.hero-ghost { font-family:'Cormorant',serif; font-style:italic; font-size:1.05rem; color:rgba(247,245,239,.5); border-bottom:1px solid rgba(247,245,239,.2); padding-bottom:2px; transition:color .2s,border-color .2s; }
.hero-ghost:hover { color:var(--gold); border-color:var(--gold); }

/* ══════════ PROOF BAR ══════════ */
.proof-bar { background:var(--black); padding:1.5rem 3.5rem; }
.proof-items { max-width:1280px; margin:0 auto; display:flex; align-items:center; gap:3rem; flex-wrap:wrap; justify-content:center; }
.proof-item { display:flex; align-items:center; gap:1rem; }
.proof-num { font-family:'Cormorant',serif; font-size:2.2rem; font-weight:600; color:var(--gold); line-height:1; }
.proof-txt { font-family:'DM Sans',sans-serif; font-size:.72rem; line-height:1.4; color:rgba(247,245,239,.5); font-weight:300; }
.proof-sep { width:1px; height:2.5rem; background:rgba(247,245,239,.1); }

/* ══════════ ABOUT ══════════ */
.about { display:grid; grid-template-columns:1fr 1fr; min-height:640px; background:var(--ivory); }
.about-photo { position:relative; overflow:hidden; }
.about-photo img { width:100%; height:100%; object-fit:cover; object-position:center 20%; }
.about-photo::after { content:''; position:absolute; top:0; right:0; width:4px; height:100%; background:linear-gradient(180deg,transparent 10%,var(--gold) 50%,transparent 90%); opacity:.5; }
.about-content { padding:6rem 4rem 6rem 4.5rem; display:flex; flex-direction:column; justify-content:center; }
.about-headline em { font-style:italic; color:var(--navy); }
.about-body { margin-top:1.5rem; font-size:1rem; line-height:1.85; font-weight:300; }
.about-body p+p { margin-top:1.1rem; }
.about-body strong { font-weight:500; color:var(--black); }
.value-list { margin-top:2.5rem; }
.value-item { display:flex; gap:1.2rem; align-items:flex-start; padding:1.4rem 0; border-bottom:1px solid rgba(216,207,192,.5); transition:padding-left .25s; }
.value-item:last-child { border-bottom:none; }
.value-item:hover { padding-left:.4rem; }
.vi-num { font-family:'Cormorant',serif; font-size:2rem; font-style:italic; font-weight:600; color:var(--gold); line-height:1; flex-shrink:0; width:1.8rem; opacity:.55; }
.vi-title { font-family:'DM Sans',sans-serif; font-size:.8rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--black); margin-bottom:.3rem; }
.vi-body { font-family:'DM Sans',sans-serif; font-size:.88rem; line-height:1.75; color:var(--body); font-weight:300; }

/* ══════════ METHODE ══════════ */
.methode { background:var(--navy); padding:8rem 3.5rem; position:relative; overflow:hidden; }
.methode-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:7rem; align-items:start; position:relative; z-index:2; }
.methode .label { color:var(--gold); }
.methode-headline { color:var(--ivory); }
.methode-headline em { font-style:italic; color:var(--gold); }
.methode-body { margin-top:1.5rem; font-size:1rem; line-height:1.85; font-weight:300; color:rgba(247,245,239,.68); }
.methode-body p+p { margin-top:1rem; }
.methode-cta { margin-top:2.5rem; display:flex; gap:1rem; flex-wrap:wrap; }
.methode-photo-wrap { position:relative; border-radius:8px; overflow:hidden; box-shadow:0 24px 64px rgba(0,0,0,.55); }
.methode-photo-wrap img { width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center top; }
.methode-photo-wrap::before { content:''; position:absolute; inset:-1px; border-radius:8px; background:linear-gradient(135deg,rgba(200,167,91,.3) 0%,transparent 55%); pointer-events:none; z-index:1; }
.methode-photo-caption { position:absolute; bottom:0; left:0; right:0; z-index:2; padding:3rem 2rem 1.8rem; background:linear-gradient(0deg,rgba(11,31,59,.9) 0%,transparent 100%); font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.step { display:flex; gap:1.5rem; padding:1.8rem 0; border-bottom:1px solid rgba(200,167,91,.1); align-items:flex-start; transition:padding-left .25s; }
.step:last-child { border-bottom:none; }
.step:hover { padding-left:.4rem; }
.step-num { width:44px; height:44px; border-radius:50%; border:1.5px solid rgba(200,167,91,.3); display:flex; align-items:center; justify-content:center; font-family:'Cormorant',serif; font-style:italic; font-size:1.2rem; font-weight:600; color:var(--gold); flex-shrink:0; }
.step-title { font-family:'DM Sans',sans-serif; font-size:.82rem; font-weight:600; letter-spacing:.05em; color:var(--ivory); margin-bottom:.35rem; }
.step-body { font-family:'DM Sans',sans-serif; font-size:.88rem; line-height:1.75; color:rgba(247,245,239,.52); font-weight:300; }

/* ══════════ EVENTS ══════════ */
.events { background:var(--black); padding:8rem 3.5rem; }
.events-inner { max-width:1280px; margin:0 auto; }
.events-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:3rem; gap:2rem; flex-wrap:wrap; }
.events-headline { color:var(--ivory); }
.events-headline em { font-style:italic; color:var(--gold); }

.event-hero-img {
  width:100%; aspect-ratio:21/9; object-fit:cover;
  object-position:center 40%;
  border-radius:6px; display:block;
  filter:brightness(.9) saturate(.95);
  margin-bottom:3px;
}

.events-grid { display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:3px; border-radius:0 0 6px 6px; overflow:hidden; }
.eg { position:relative; overflow:hidden; aspect-ratio:16/9; }
.eg img { width:100%; height:100%; object-fit:cover; filter:brightness(.8) saturate(.85); transition:filter .4s, transform .5s; display:block; }
.eg:hover img { filter:brightness(.95) saturate(1.05); transform:scale(1.04); }
.eg-label { position:absolute; bottom:0; left:0; right:0; padding:2.5rem 1.4rem .9rem; background:linear-gradient(0deg,rgba(11,31,59,.9) 0%,transparent 100%); font-family:'DM Sans',sans-serif; font-size:.58rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }

.event-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; margin-top:3rem; background:rgba(247,245,239,.05); border-radius:6px; overflow:hidden; }
.estat { background:rgba(247,245,239,.03); padding:2rem 1.5rem; text-align:center; }
.estat-num { font-family:'Cormorant',serif; font-size:2.5rem; font-weight:600; color:var(--gold); line-height:1; }
.estat-label { font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:rgba(247,245,239,.38); margin-top:.5rem; }

/* ══════════ BOEKEN ══════════ */
.books { padding:8rem 3.5rem; background:var(--sand-l); }
.books-inner { max-width:1280px; margin:0 auto; }
.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:4rem; gap:2rem; flex-wrap:wrap; }
.books-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.bc { border-radius:6px; overflow:hidden; display:flex; flex-direction:column; box-shadow:0 4px 20px rgba(17,17,17,.1); transition:transform .3s,box-shadow .3s; }
.bc:hover { transform:translateY(-6px); box-shadow:0 16px 48px rgba(17,17,17,.18); }
.bc-stripe { height:6px; }
.bc-top-img { height:140px; overflow:hidden; }
.bc-top-img img { width:100%; height:100%; object-fit:cover; display:block; }
.bc-body { padding:1.8rem; flex:1; display:flex; flex-direction:column; }
.bc-label { font-family:'DM Sans',sans-serif; font-size:.58rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; margin-bottom:.7rem; }
.bc-title { font-family:'Cormorant',serif; font-size:1.45rem; font-weight:600; line-height:1.15; flex:1; }
.bc-title em { font-style:italic; }
.bc-desc { font-family:'DM Sans',sans-serif; font-size:.82rem; line-height:1.8; margin-top:.9rem; font-weight:300; }
.bc-link { margin-top:1.3rem; font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; }

/* ══════════ QUOTE ══════════ */
.quote-full { background:var(--navy); padding:6rem 3.5rem; text-align:center; position:relative; overflow:hidden; }
.quote-full::before { content:'\201C'; position:absolute; top:-5rem; left:50%; transform:translateX(-50%); font-family:'Cormorant',serif; font-size:22rem; font-style:italic; color:rgba(200,167,91,.04); line-height:1; pointer-events:none; }
.quote-text { font-family:'Cormorant',serif; font-style:italic; font-size:clamp(1.5rem,3.5vw,2.6rem); font-weight:500; color:var(--ivory); max-width:860px; margin:0 auto; line-height:1.55; position:relative; z-index:2; }
.quote-text em { color:var(--gold); font-style:normal; }
.quote-attr { margin-top:2rem; font-family:'DM Sans',sans-serif; font-size:.65rem; font-weight:500; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); opacity:.65; }

/* ══════════ TESTIMONIALS ══════════ */
.testimonials { padding:8rem 3.5rem; background:var(--ivory); }
.testimonials-inner { max-width:1280px; margin:0 auto; }
.tgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:4rem; }
.tcard { background:var(--white); border-radius:6px; padding:2.2rem 2rem; box-shadow:0 2px 16px rgba(17,17,17,.06); display:flex; flex-direction:column; border-top:3px solid var(--gold); transition:transform .25s,box-shadow .25s; }
.tcard:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(17,17,17,.1); }
.tcard-stars { font-size:.85rem; letter-spacing:.1em; color:var(--gold); margin-bottom:1.2rem; }
.tcard-text { font-family:'Cormorant',serif; font-style:italic; font-size:1.12rem; line-height:1.7; color:var(--black); flex:1; }
.tcard-footer { margin-top:1.8rem; padding-top:1.2rem; border-top:1px solid var(--sand); }
.tcard-name { font-family:'DM Sans',sans-serif; font-size:.75rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--navy); }
.tcard-role { font-family:'DM Sans',sans-serif; font-size:.75rem; color:#888; margin-top:.2rem; font-weight:300; }

/* ══════════ OPLEIDING ══════════ */
.opleiding { position:relative; overflow:hidden; padding:10rem 3.5rem; }
.opleiding-bg { position:absolute; inset:0; }
.opleiding-bg img { width:100%; height:100%; object-fit:cover; object-position:center 40%; filter:brightness(.25) saturate(.45); }
.opleiding-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,rgba(11,31,59,.9) 0%,rgba(11,31,59,.6) 55%,rgba(11,31,59,.25) 100%); }
.opleiding-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr auto; gap:6rem; align-items:center; position:relative; z-index:2; }
.opleiding .label { color:var(--gold); }
.opleiding-headline { color:var(--ivory); }
.opleiding-headline em { font-style:italic; color:var(--gold); }
.opleiding-sub { margin-top:1.5rem; font-family:'DM Sans',sans-serif; font-size:1rem; line-height:1.85; color:rgba(247,245,239,.7); font-weight:300; max-width:520px; }
.opleiding-stats { display:flex; gap:1.5rem; margin-top:2.5rem; flex-wrap:wrap; }
.ostat { background:rgba(200,167,91,.1); border:1px solid rgba(200,167,91,.22); border-radius:6px; padding:1.1rem 1.8rem; text-align:center; }
.ostat-num { font-family:'Cormorant',serif; font-size:2rem; font-weight:600; color:var(--gold); line-height:1; }
.ostat-label { font-family:'DM Sans',sans-serif; font-size:.6rem; font-weight:500; letter-spacing:.15em; text-transform:uppercase; color:rgba(247,245,239,.55); margin-top:.3rem; }
.opleiding-right { display:flex; flex-direction:column; gap:1rem; flex-shrink:0; }

/* ══════════ CONTACT ══════════ */
.contact { padding:8rem 3.5rem; background:var(--sand-l); }
.contact-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:7rem; align-items:start; }
.contact-headline em { font-style:italic; color:var(--navy); }
.contact-sub { margin-top:1.5rem; color:var(--body); line-height:1.85; font-size:1rem; font-weight:300; }
.contact-links { margin-top:2.5rem; display:flex; flex-direction:column; gap:1rem; }
.clink { display:flex; align-items:center; gap:1rem; padding:1.1rem 1.4rem; background:var(--white); border-radius:6px; box-shadow:0 2px 8px rgba(17,17,17,.05); transition:transform .2s,box-shadow .2s; }
.clink:hover { transform:translateX(4px); box-shadow:0 4px 20px rgba(17,17,17,.1); }
.clink-icon { width:40px; height:40px; background:rgba(11,31,59,.07); border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.clink-label { font-family:'DM Sans',sans-serif; font-size:.6rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-d); margin-bottom:.2rem; }
.clink-val { font-family:'DM Sans',sans-serif; font-size:.88rem; color:var(--black); font-weight:400; }
.contact-form { display:flex; flex-direction:column; gap:1.2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.fg { display:flex; flex-direction:column; gap:.5rem; }
.fl { font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:#888; }
.fi,.fta { background:var(--white); border:1.5px solid rgba(216,207,192,.8); border-radius:var(--r); padding:.85rem 1.1rem; font-family:'DM Sans',sans-serif; font-size:.95rem; color:var(--black); font-weight:300; outline:none; transition:border-color .2s,box-shadow .2s; width:100%; }
.fi:focus,.fta:focus { border-color:var(--navy); box-shadow:0 0 0 3px rgba(11,31,59,.08); }
.fi::placeholder,.fta::placeholder { color:#bbb; }
.fta { min-height:130px; resize:vertical; }

/* CF7 form integration */
.contact-form .wpcf7-form { display:flex; flex-direction:column; gap:1.2rem; }
.contact-form .wpcf7-form input[type="text"],
.contact-form .wpcf7-form input[type="email"] { background:var(--white); border:1.5px solid rgba(216,207,192,.8); border-radius:var(--r); padding:.85rem 1.1rem; font-family:'DM Sans',sans-serif; font-size:.95rem; color:var(--black); font-weight:300; outline:none; transition:border-color .2s,box-shadow .2s; width:100%; }
.contact-form .wpcf7-form textarea { background:var(--white); border:1.5px solid rgba(216,207,192,.8); border-radius:var(--r); padding:.85rem 1.1rem; font-family:'DM Sans',sans-serif; font-size:.95rem; color:var(--black); font-weight:300; outline:none; transition:border-color .2s,box-shadow .2s; width:100%; min-height:130px; resize:vertical; }
.contact-form .wpcf7-form input:focus,
.contact-form .wpcf7-form textarea:focus { border-color:var(--navy); box-shadow:0 0 0 3px rgba(11,31,59,.08); }
.contact-form .wpcf7-form input[type="submit"] { display:inline-flex; align-items:center; gap:.6rem; font-family:'DM Sans',sans-serif; font-size:.68rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; padding:.95rem 2rem; border-radius:var(--r); background:var(--navy); color:var(--ivory); border:none; cursor:pointer; transition:all .25s; width:fit-content; }
.contact-form .wpcf7-form input[type="submit"]:hover { background:var(--navy-l); transform:translateY(-2px); }

/* ══════════ BOEK HERO (single-boek) ══════════ */
.boek-hero { padding:6rem 3.5rem; }
.boek-hero-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr auto; gap:5rem; align-items:center; }
.boek-hero-content { max-width:600px; }
.boek-hero-desc { margin-top:1.5rem; font-size:1.1rem; line-height:1.85; font-weight:300; }
.boek-isbn { margin-top:1rem; font-family:'DM Sans',sans-serif; font-size:.75rem; letter-spacing:.1em; opacity:.6; }
.boek-hero-cover { max-width:320px; }
.boek-hero-cover img { width:100%; height:auto; border-radius:6px; box-shadow:0 24px 64px rgba(0,0,0,.4); }

/* ══════════ FOOTER ══════════ */
footer { background:var(--black); padding:5rem 3.5rem 2.5rem; }
.footer-top { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:4rem; padding-bottom:4rem; border-bottom:1px solid rgba(247,245,239,.08); }
.footer-brand-name { font-family:'DM Sans',sans-serif; font-size:1rem; font-weight:600; letter-spacing:.08em; color:var(--ivory); }
.footer-brand-sub { font-family:'Cormorant',serif; font-style:italic; font-size:.85rem; color:var(--gold); margin-top:.3rem; }
.footer-tagline { margin-top:1.5rem; font-family:'Cormorant',serif; font-style:italic; font-size:1.15rem; color:rgba(247,245,239,.28); line-height:1.5; }
.footer-col-title { font-family:'DM Sans',sans-serif; font-size:.6rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:1.4rem; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:.7rem; }
.footer-links a { font-family:'DM Sans',sans-serif; font-size:.83rem; color:rgba(247,245,239,.38); transition:color .2s; font-weight:300; }
.footer-links a:hover { color:var(--gold); }
.footer-bottom { max-width:1280px; margin:2rem auto 0; display:flex; justify-content:space-between; align-items:center; }
.footer-copy { font-family:'DM Sans',sans-serif; font-size:.7rem; color:rgba(247,245,239,.2); font-weight:300; }
.footer-socials { display:flex; gap:.7rem; }
.social-link { width:34px; height:34px; border-radius:50%; border:1px solid rgba(247,245,239,.12); display:flex; align-items:center; justify-content:center; font-size:.62rem; font-weight:600; color:rgba(247,245,239,.38); transition:border-color .2s,color .2s; }
.social-link:hover { border-color:var(--gold); color:var(--gold); }

/* ══════════ ANIMATIONS ══════════ */
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
.hero-content > * { opacity:0; animation:fadeUp .7s ease forwards; }
.hero-content .label        { animation-delay:.1s }
.hero-content h1            { animation-delay:.25s }
.hero-content .hero-divider { animation-delay:.35s }
.hero-content .hero-sub     { animation-delay:.42s }
.hero-content .hero-chips   { animation-delay:.55s }
.hero-content .hero-cta     { animation-delay:.68s }

/* ══════════ WP SPECIFIC ══════════ */
.wp-block-image img { border-radius:6px; }
.alignwide { max-width:1100px; margin-left:auto; margin-right:auto; }
.alignfull { width:100vw; position:relative; left:50%; transform:translateX(-50%); }

/* WP navigation */
.nav-links.wp-nav-menu { display:flex; align-items:center; gap:2.5rem; list-style:none; }
.nav-links.wp-nav-menu li { list-style:none; }
.nav-links.wp-nav-menu a { font-family:'DM Sans',sans-serif; font-size:.68rem; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:rgba(247,245,239,.65); transition:color .2s; }
.nav-links.wp-nav-menu a:hover { color:var(--gold); }

/* WP pagination */
.nav-links { display:flex; gap:1rem; justify-content:center; }
.page-numbers { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:var(--r); font-family:'DM Sans',sans-serif; font-size:.8rem; font-weight:500; color:var(--navy); background:var(--white); box-shadow:0 2px 8px rgba(17,17,17,.05); transition:all .2s; }
.page-numbers.current { background:var(--navy); color:var(--ivory); }
.page-numbers:hover { background:var(--navy); color:var(--ivory); }

/* ══════════ RESPONSIVE ══════════ */
@media(max-width:1100px){
  .about{grid-template-columns:1fr;min-height:auto}
  .about-photo{height:440px}
  .methode-inner{grid-template-columns:1fr;gap:4rem}
  .books-grid{grid-template-columns:1fr 1fr}
  .events-grid{grid-template-columns:1fr 1fr}
  .event-stats{grid-template-columns:1fr 1fr}
  .tgrid{grid-template-columns:1fr 1fr}
  .opleiding-inner{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr;gap:4rem}
  .footer-top{grid-template-columns:1fr 1fr}
  .boek-hero-inner{grid-template-columns:1fr;gap:3rem}
}
@media(max-width:768px){
  html{font-size:16px}
  nav{padding:0 1.5rem}
  .nav-links{display:none;position:absolute;top:72px;left:0;right:0;background:rgba(11,31,59,.98);flex-direction:column;padding:2rem 1.5rem;gap:1.5rem;border-bottom:1px solid rgba(200,167,91,.15)}
  .nav-links.open{display:flex}
  .nav-burger{display:flex}
  .hero-content{padding:0 1.5rem}
  .about-content{padding:4rem 1.5rem}
  .methode,.books,.testimonials,.contact,.events{padding:5rem 1.5rem}
  .opleiding{padding:5rem 1.5rem}
  .proof-bar{padding:1.5rem}
  .books-grid,.tgrid{grid-template-columns:1fr}
  .events-grid{grid-template-columns:1fr}
  .event-stats{grid-template-columns:1fr 1fr}
  .event-hero-img{aspect-ratio:4/3}
  .form-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;padding:0 0 3rem}
  footer{padding:4rem 1.5rem 2rem}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .opleiding-inner{grid-template-columns:1fr}
  .opleiding-right{flex-direction:row;flex-wrap:wrap}
  .page-container{padding:4rem 1.5rem}
  .boek-hero{padding:4rem 1.5rem}
  .boek-hero-inner{grid-template-columns:1fr}
  .quote-full{padding:4rem 1.5rem}
  .hp-hero-content{padding:0 1.5rem}
  .hp-curriculum-grid,.hp-value-grid{grid-template-columns:1fr}
  .hp-pricing-inner{grid-template-columns:1fr;gap:3rem;padding:5rem 1.5rem}
  .hp-dates-grid{grid-template-columns:1fr}
  .hp-format-grid{grid-template-columns:1fr}
  .hp-accred-grid{grid-template-columns:repeat(2,1fr)}
  .hp-section{padding:5rem 1.5rem}
}

/* ══════════ HYPNO PRINCIPLES SALESPAGINA ══════════ */
.hp-hero { min-height:100vh; padding-top:72px; position:relative; overflow:hidden; display:flex; align-items:center; }
.hp-hero-bg { position:absolute; inset:0; }
.hp-hero-bg img { width:100%; height:100%; object-fit:cover; object-position:center 30%; }
.hp-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(105deg,rgba(11,31,59,.92) 0%,rgba(11,31,59,.75) 45%,rgba(11,31,59,.2) 100%); }
.hp-hero-content { position:relative; z-index:2; padding:0 3.5rem; max-width:780px; }
.hp-hero-content > * { opacity:0; animation:fadeUp .7s ease forwards; }
.hp-hero-content .label { animation-delay:.1s }
.hp-hero-content h1 { animation-delay:.25s }
.hp-hero-content .hero-divider { animation-delay:.35s }
.hp-hero-content .hero-sub { animation-delay:.42s }
.hp-hero-content .hero-chips { animation-delay:.55s }
.hp-hero-content .hero-cta { animation-delay:.68s }

.hp-section { padding:8rem 3.5rem; }
.hp-section--ivory { background:var(--ivory); }
.hp-section--sand { background:var(--sand-l); }
.hp-section--navy { background:var(--navy); }
.hp-narrow { max-width:780px; margin:0 auto; }
.hp-wide { max-width:1280px; margin:0 auto; }
.hp-body { margin-top:1.5rem; font-size:1rem; line-height:1.85; font-weight:300; }
.hp-body p+p { margin-top:1.1rem; }
.hp-body strong { font-weight:500; color:var(--black); }

/* Curriculum grid */
.hp-curriculum-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.hp-cur-card { background:var(--white); border-radius:6px; padding:2.2rem 2rem; box-shadow:0 2px 16px rgba(17,17,17,.06); border-top:3px solid var(--gold); }
.hp-cur-badge { font-family:'DM Sans',sans-serif; font-size:.58rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; background:rgba(200,167,91,.08); display:inline-block; padding:.3rem .8rem; border-radius:100px; }
.hp-cur-title { font-family:'Cormorant',serif; font-size:1.4rem; font-weight:600; color:var(--black); margin-bottom:1.2rem; }
.hp-cur-list { list-style:none; }
.hp-cur-list li { padding:.55rem 0; border-bottom:1px solid rgba(216,207,192,.3); font-family:'DM Sans',sans-serif; font-size:.85rem; line-height:1.6; color:var(--body); font-weight:300; }
.hp-cur-list li:last-child { border-bottom:none; }
.hp-cur-list li::before { content:'\2022'; color:var(--gold); font-weight:700; margin-right:.6rem; }

/* Value/bonus grid */
.hp-value-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.hp-value-card { background:rgba(247,245,239,.06); border:1px solid rgba(200,167,91,.15); border-radius:6px; padding:2rem; text-align:center; transition:transform .25s,border-color .25s; }
.hp-value-card:hover { transform:translateY(-4px); border-color:rgba(200,167,91,.4); }
.hp-value-icon { font-size:2rem; margin-bottom:1rem; }
.hp-value-title { font-family:'DM Sans',sans-serif; font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--ivory); margin-bottom:.7rem; }
.hp-value-desc { font-family:'DM Sans',sans-serif; font-size:.85rem; line-height:1.75; color:rgba(247,245,239,.55); font-weight:300; }

/* Pricing box */
.hp-pricing-inner { max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1fr auto; gap:6rem; align-items:center; position:relative; z-index:2; padding:0 3.5rem; }
.hp-price-box { background:rgba(247,245,239,.06); border:1.5px solid rgba(200,167,91,.3); border-radius:8px; padding:2.5rem; max-width:380px; flex-shrink:0; }
.hp-price-label { font-family:'DM Sans',sans-serif; font-size:.62rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.8rem; }
.hp-price-amount { font-family:'Cormorant',serif; font-size:3.5rem; font-weight:700; color:var(--ivory); line-height:1; }
.hp-price-vat { font-family:'DM Sans',sans-serif; font-size:.72rem; color:rgba(247,245,239,.5); margin-top:.4rem; font-weight:300; }
.hp-price-divider { height:1px; background:rgba(200,167,91,.2); margin:1.5rem 0; }
.hp-price-features { list-style:none; }
.hp-price-features li { font-family:'DM Sans',sans-serif; font-size:.82rem; color:rgba(247,245,239,.7); padding:.4rem 0; font-weight:300; }
.hp-price-payments { font-family:'DM Sans',sans-serif; font-size:.78rem; color:rgba(247,245,239,.5); font-weight:300; text-align:center; }

/* Date cards */
.hp-dates-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; max-width:700px; margin:0 auto; }
.hp-date-card { background:var(--white); border-radius:6px; padding:2rem; box-shadow:0 2px 16px rgba(17,17,17,.06); border-top:3px solid var(--gold); text-align:center; }
.hp-date-month { font-family:'Cormorant',serif; font-size:1.6rem; font-weight:600; color:var(--navy); margin-bottom:.5rem; }
.hp-date-range { font-family:'DM Sans',sans-serif; font-size:.85rem; color:var(--body); font-weight:400; }
.hp-date-exam { font-family:'DM Sans',sans-serif; font-size:.75rem; color:var(--gold-d); margin-top:.3rem; font-weight:500; }
.hp-date-location { font-family:'DM Sans',sans-serif; font-size:.68rem; color:#888; margin-top:.3rem; letter-spacing:.08em; text-transform:uppercase; font-weight:500; }

/* Format cards */
.hp-format-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-top:2.5rem; }
.hp-format-card { background:var(--white); border-radius:6px; padding:2rem; box-shadow:0 2px 16px rgba(17,17,17,.06); text-align:center; }
.hp-format-icon { font-size:2rem; margin-bottom:.8rem; }
.hp-format-title { font-family:'DM Sans',sans-serif; font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--black); margin-bottom:.5rem; }
.hp-format-desc { font-family:'DM Sans',sans-serif; font-size:.85rem; line-height:1.75; color:var(--body); font-weight:300; }

/* Accreditation grid */
.hp-accred-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; max-width:700px; margin:0 auto; }
.hp-accred-item { background:var(--white); border-radius:6px; padding:1rem; font-family:'DM Sans',sans-serif; font-size:.78rem; font-weight:600; letter-spacing:.1em; color:var(--navy); box-shadow:0 2px 8px rgba(17,17,17,.05); text-align:center; }

/* FAQ */
.hp-faq-list { display:flex; flex-direction:column; gap:0; }
.hp-faq-item { padding:1.6rem 0; border-bottom:1px solid rgba(216,207,192,.5); }
.hp-faq-item:last-child { border-bottom:none; }
.hp-faq-q { font-family:'DM Sans',sans-serif; font-size:.9rem; font-weight:600; color:var(--black); margin-bottom:.5rem; }
.hp-faq-a { font-family:'DM Sans',sans-serif; font-size:.88rem; line-height:1.8; color:var(--body); font-weight:300; }

/* Responsive — sales page */
@media(max-width:1100px){
  .hp-curriculum-grid,.hp-value-grid{grid-template-columns:1fr 1fr}
  .hp-pricing-inner{grid-template-columns:1fr;gap:4rem}
  .hp-price-box{max-width:100%}
}
