
  :root{
    --sage:#3D796C;
    --sage-deep:#273532;
    --sage-soft:#6d9a8f;
    --cream:#F8F2E8;
    --cream-deep:#EFE6D3;
    --bronze:#584524;
    --ink:#2a2a2a;
    --mute:#4a4a4a;
    --line:#EAEAEA;
    --bg:#ffffff;
    --shadow:0 20px 60px -20px rgba(39,53,50,.12), 0 2px 8px rgba(0,0,0,.04);
    --shadow-lift:0 30px 80px -20px rgba(39,53,50,.2), 0 4px 14px rgba(0,0,0,.06);
    --ease:cubic-bezier(.2,.7,.2,1);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0;overflow-x:clip}
  html{scroll-behavior:smooth}
  body{
    font-family:'Red Hat Display',system-ui,sans-serif;
    font-size:17px;
    line-height:1.65;
    color:var(--mute);
    background:var(--bg);
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,h4{font-family:'Abhaya Libre',Georgia,serif;color:var(--sage-deep);font-weight:500;letter-spacing:-.01em;margin:0}
  h1{font-size:clamp(48px,6.2vw,88px);line-height:1.02;font-weight:500}
  h2{font-size:clamp(36px,4vw,54px);line-height:1.05}
  h3{font-size:clamp(24px,2vw,30px);line-height:1.2}
  p{margin:0 0 1em 0;text-wrap:pretty}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}

  .script{font-family:'Square Peg',cursive;color:var(--sage);letter-spacing:.01em;line-height:1}

  .container{max-width:1280px;margin:0 auto;padding:0 40px}
  @media (max-width:780px){.container{padding:0 22px}}

  /* ───── NAV ───── */
  .nav{
    position:sticky;top:0;z-index:60;
    background:rgba(255,255,255,.82);
    backdrop-filter:saturate(1.2) blur(16px);
    -webkit-backdrop-filter:saturate(1.2) blur(16px);
    border-bottom:1px solid transparent;
    transition:border-color .3s var(--ease), padding .3s var(--ease);
  }
  body.nav-open .nav{background:#fff}
  .nav.scrolled{border-color:rgba(234,234,234,.8)}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;padding:22px 0;transition:padding .3s var(--ease)}
  .nav.scrolled .nav-inner{padding:14px 0}
  .brand{display:flex;align-items:center;gap:12px;font-family:'Abhaya Libre',serif;color:var(--sage-deep);font-size:20px;font-weight:500}
  .brand-mark{width:34px;height:34px;background:url(assets/logo-mark.png) center/contain no-repeat;transition:transform .5s var(--ease)}
  .brand:hover .brand-mark{transform:rotate(-8deg) scale(1.08)}
  .nav-links{display:flex;gap:6px;align-items:center}
  .nav-links a{
    position:relative;padding:10px 16px;font-size:15px;color:var(--sage-deep);font-weight:500;
    border-radius:999px;transition:color .2s, background .3s var(--ease);
  }
  .nav-links a::after{
    content:"";position:absolute;left:50%;bottom:4px;transform:translateX(-50%) scaleX(0);
    width:18px;height:1px;background:var(--sage);transition:transform .3s var(--ease);
  }
  .nav-links a:hover::after,.nav-links a.active::after{transform:translateX(-50%) scaleX(1)}
  .nav-links a:hover{color:var(--sage)}
  .nav-cta{
    background:var(--sage-deep);color:#fff !important;padding:12px 22px !important;border-radius:999px;
    font-size:14px;letter-spacing:.02em;transition:background .3s var(--ease), transform .3s var(--ease);
  }
  .nav-cta:hover{background:var(--sage);transform:translateY(-1px)}
  .nav-cta::after{display:none}

  /* ───── HERO ───── */
  .hero{position:relative;padding:90px 0 60px;overflow:hidden}
  .hero-bg{
    position:absolute;inset:0;pointer-events:none;
    background:
      radial-gradient(60% 50% at 85% 20%, rgba(248,242,232,.9), transparent 60%),
      radial-gradient(40% 40% at 10% 80%, rgba(61,121,108,.05), transparent 60%);
  }
  .hero-grid{position:relative;display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
  @media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:40px}}

  .eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);font-weight:500;
    margin-bottom:22px;
  }
  .eyebrow::before{content:"";width:32px;height:1px;background:var(--sage);display:inline-block}

  .hero h1 .w{display:inline-block;overflow:hidden;vertical-align:bottom}
  .hero h1 .w span{display:inline-block;transform:translateY(105%);animation:rise .9s var(--ease) forwards}
  .hero h1 .w:nth-child(1) span{animation-delay:.05s}
  .hero h1 .w:nth-child(2) span{animation-delay:.15s}
  .hero h1 .w:nth-child(3) span{animation-delay:.25s}
  .hero h1 em{font-style:italic;font-family:'Abhaya Libre',serif;color:var(--sage)}
  @keyframes rise{to{transform:translateY(0)}}

  .hero-script{font-size:54px;color:var(--sage);opacity:0;animation:fade 1s var(--ease) .6s forwards;margin:8px 0 0}
  @keyframes fade{to{opacity:.9}}

  .hero-lede{font-size:19px;line-height:1.6;color:var(--mute);max-width:480px;margin:28px 0 36px;opacity:0;animation:fade 1s var(--ease) .75s forwards}

  .hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:fade 1s var(--ease) .9s forwards}
  .btn{
    display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:999px;
    font-size:15px;font-weight:500;letter-spacing:.01em;cursor:pointer;border:0;
    transition:transform .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);
  }
  .btn-primary{background:var(--sage-deep);color:#fff}
  .btn-primary:hover{background:var(--sage);transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(39,53,50,.4)}
  .btn-ghost{background:transparent;color:var(--sage-deep);border:1px solid var(--line)}
  .btn-ghost:hover{border-color:var(--sage);color:var(--sage);transform:translateY(-2px)}
  .btn .arr{display:inline-block;transition:transform .3s var(--ease)}
  .btn:hover .arr{transform:translateX(4px)}

  .hero-meta{display:flex;gap:40px;margin-top:60px;opacity:0;animation:fade 1s var(--ease) 1.1s forwards}
  .hero-meta div{border-left:1px solid var(--line);padding-left:18px}
  .hero-meta strong{font-family:'Abhaya Libre',serif;color:var(--sage-deep);font-size:28px;font-weight:500;display:block;line-height:1}
  .hero-meta span{font-size:13px;color:var(--mute);letter-spacing:.06em;text-transform:uppercase;margin-top:4px;display:block}

  /* hero image assembly */
  .hero-visual{position:relative;width:100%;aspect-ratio:4/5;max-width:560px;margin-left:auto;justify-self:end}
  .hv-shape{
    position:absolute;inset:0;border-radius:50% / 48%;overflow:hidden;
    background:url(assets/hero-chantal.jpg) center/cover;
    box-shadow:0 40px 80px -30px rgba(39,53,50,.3);
    transform:translateY(20px);opacity:0;animation:heroRise 1.2s var(--ease) .3s forwards;
  }
  @keyframes heroRise{to{transform:translateY(0);opacity:1}}
  .hv-ring{
    position:absolute;width:58%;aspect-ratio:1;border:1px solid var(--sage);border-radius:50%;
    right:-4%;bottom:-4%;opacity:0;animation:fade 1.2s var(--ease) 1s forwards;
    animation-fill-mode:forwards;
  }
  .hv-ring.drift{animation:fade 1.2s var(--ease) 1s forwards, drift 14s ease-in-out 2s infinite}
  @keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(-6px,-10px)}}
  .hv-dot{
    position:absolute;left:-24px;top:30%;width:64px;height:64px;border-radius:50%;
    background:var(--cream);opacity:0;animation:fade 1s var(--ease) 1.1s forwards;
  }
  .hv-script{
    position:absolute;left:-30px;bottom:-20px;font-family:'Square Peg',cursive;color:var(--sage);
    font-size:40px;line-height:1.1;max-width:220px;opacity:0;animation:fade 1s var(--ease) 1.3s forwards;
  }
  /* mirrored variant when hero photo is on the left */
  .hero-visual--left .hv-ring{right:auto;left:-4%;bottom:-4%}
  .hero-visual--left .hv-dot{left:auto;right:-24px;top:30%}
  .hero-visual--left .hv-script{left:auto;right:-30px;bottom:-20px;text-align:right}

  /* ───── SECTION STYLING ───── */
  section{padding:120px 0;position:relative;overflow:hidden}
  .section-head{display:flex;flex-direction:column;max-width:720px;margin-bottom:60px}
  .section-head .script{font-size:36px;margin-bottom:8px}

  /* reveal on scroll */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease), transform .9s var(--ease)}
  .reveal.in{opacity:1;transform:translateY(0)}
  .reveal.d1{transition-delay:.08s}
  .reveal.d2{transition-delay:.16s}
  .reveal.d3{transition-delay:.24s}
  .reveal.d4{transition-delay:.32s}

  /* ───── PHILOSOPHY / ABOUT ───── */
  .about{background:linear-gradient(180deg,#fff, #fff 60%, var(--cream) 60%)}
  .about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
  @media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:48px}}
  .about-imgs{position:relative;aspect-ratio:1/1.05}
  .about-imgs .i1{
    position:absolute;left:0;top:0;width:72%;aspect-ratio:3/4;
    background:url(assets/room-main.jpg) center/cover;box-shadow:var(--shadow);
  }
  .about-imgs .i2{
    position:absolute;right:0;bottom:0;width:44%;aspect-ratio:1/1.05;
    background:url(assets/room-detail.jpg) center/cover;box-shadow:var(--shadow);
  }
  .about-imgs .i-ring{
    position:absolute;width:180px;aspect-ratio:1;border:1px solid var(--sage);border-radius:50%;
    right:-30px;top:30%;opacity:.5;
  }
  .about-text p{font-size:17.5px;line-height:1.75}
  .about-text p + p{margin-top:14px}
  .about-quote{
    margin-top:32px;padding:24px 28px;border-left:2px solid var(--sage);
    font-family:'Abhaya Libre',serif;font-size:22px;color:var(--sage-deep);font-style:italic;line-height:1.4;
  }

  /* ───── METHODS ───── */
  .methods{background:var(--cream);padding:140px 0}
  .methods-head{text-align:center;max-width:720px;margin:0 auto 64px}
  .methods-head .script{font-size:40px;display:block;margin-bottom:8px}
  .methods-intro{font-size:17.5px;line-height:1.75;margin-top:22px}
  .method-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  }
  @media(max-width:900px){.method-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:600px){.method-grid{grid-template-columns:1fr}}
  .method-card{
    background:#fff;border-radius:22px;padding:32px 28px;position:relative;overflow:hidden;
    transition:transform .4s var(--ease), box-shadow .4s var(--ease);
    border:1px solid transparent;
  }
  .method-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift);border-color:rgba(61,121,108,.1)}
  .method-card .num{
    font-family:'Abhaya Libre',serif;font-size:14px;color:var(--sage);letter-spacing:.1em;
    display:block;margin-bottom:18px;
  }
  .method-card h3{font-size:22px;line-height:1.2;margin-bottom:10px}
  .method-card p{font-size:15px;line-height:1.6;color:var(--mute);margin:0}
  .method-card .glyph{
    position:absolute;right:-12px;top:-12px;width:72px;height:72px;border-radius:50%;
    background:rgba(61,121,108,.06);transition:transform .5s var(--ease);
  }
  .method-card:hover .glyph{transform:scale(1.3) rotate(25deg)}

  /* ───── PROCESS TIMELINE ───── */
  .process{padding:140px 0;background:#fff}
  .process-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start}
  @media(max-width:900px){.process-grid{grid-template-columns:1fr;gap:40px}}
  .process-steps{display:flex;flex-direction:column;gap:4px;position:relative}
  .step{
    display:grid;grid-template-columns:44px 1fr;gap:24px;padding:28px 0;
    border-top:1px solid var(--line);cursor:pointer;
    transition:padding .4s var(--ease);
  }
  .step:last-child{border-bottom:1px solid var(--line)}
  .step-num{
    width:44px;height:44px;border-radius:50%;border:1px solid var(--sage);color:var(--sage);
    display:flex;align-items:center;justify-content:center;font-family:'Abhaya Libre',serif;font-size:20px;
    transition:background .3s var(--ease), color .3s var(--ease), transform .4s var(--ease);
  }
  .step:hover .step-num, .step.active .step-num{background:var(--sage);color:#fff;transform:scale(1.08)}
  .step h4{font-size:20px;color:var(--sage-deep);margin-bottom:6px;transition:color .3s var(--ease)}
  .step:hover h4{color:var(--sage)}
  .step p{font-size:15px;color:var(--mute);margin:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--ease),opacity .4s var(--ease),margin .4s var(--ease)}
  .step.active p{max-height:200px;opacity:1;margin-top:8px}

  /* ───── REVIEWS MARQUEE ───── */
  .reviews{padding:140px 0;background:var(--cream);overflow:hidden}
  .reviews-head{max-width:720px;margin:0 auto 60px;text-align:center}
  .reviews-head .script{font-size:36px;display:block;margin-bottom:8px}
  .marquee{display:flex;gap:24px;width:max-content;animation:slide 50s linear infinite}
  .marquee:hover{animation-play-state:paused}
  @keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  .review-card{
    width:380px;flex-shrink:0;background:#fff;border-radius:18px;padding:32px 30px;
    box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px;
  }
  .review-card .stars{color:var(--sage);letter-spacing:4px;font-size:14px}
  .review-card blockquote{
    margin:0;font-family:'Abhaya Libre',serif;font-size:19px;line-height:1.5;color:var(--sage-deep);font-weight:400;
  }
  .review-card .cite{font-size:13px;color:var(--mute);letter-spacing:.08em;text-transform:uppercase;margin-top:auto}

  /* ───── BANNER CTA ───── */
  .banner{
    padding:120px 0;text-align:center;position:relative;overflow:hidden;
    background:
      radial-gradient(60% 100% at 50% 0%, rgba(248,242,232,.6), transparent 70%),
      #fff;
  }
  .banner .script{font-size:clamp(52px,6vw,84px);line-height:1.1;display:block;margin-bottom:24px;color:var(--sage)}
  .banner h2{max-width:760px;margin:0 auto 24px}
  .banner p{font-size:18px;max-width:520px;margin:0 auto 40px}
  .banner::before,.banner::after{
    content:"";position:absolute;border:1px solid rgba(61,121,108,.2);border-radius:50%;pointer-events:none;
  }
  .banner::before{width:320px;height:320px;left:-60px;top:30%;animation:drift 18s ease-in-out infinite}
  .banner::after{width:220px;height:220px;right:-40px;bottom:10%;animation:drift 22s ease-in-out 3s infinite}

  /* ───── CONTACT ───── */
  .contact{background:var(--cream);padding:120px 0 80px}
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff;border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
  @media(max-width:900px){.contact-grid{grid-template-columns:1fr}}
  .contact-form{padding:56px 56px}
  @media(max-width:780px){.contact-form{padding:36px 28px}}
  .contact-form h2{margin-bottom:8px}
  .contact-form .sub{color:var(--mute);margin-bottom:32px}
  .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  @media(max-width:600px){.form-row{grid-template-columns:1fr}}
  .field{margin-bottom:14px}
  .field input,.field textarea{
    width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:12px;
    font-family:inherit;font-size:15px;background:#fff;color:var(--ink);
    transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
  }
  .field textarea{min-height:120px;resize:vertical}
  .field input:focus,.field textarea:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 4px rgba(61,121,108,.08)}
  .contact-photo{background:url(assets/contact-photo.jpg) center/cover;min-height:360px;position:relative}
  .contact-photo .overlay{
    position:absolute;inset:0;background:linear-gradient(135deg,rgba(39,53,50,.2),transparent 60%);
  }
  .contact-photo .info{
    position:absolute;left:32px;bottom:32px;right:32px;color:#fff;
    background:rgba(39,53,50,.65);backdrop-filter:blur(10px);padding:22px 24px;border-radius:16px;
  }
  .contact-photo .info strong{font-family:'Abhaya Libre',serif;font-size:22px;display:block;margin-bottom:6px;color:#fff}
  .contact-photo .info span{display:block;font-size:14px;opacity:.9}

  /* ───── FOOTER ───── */
  footer{padding:60px 0 40px;border-top:1px solid var(--line);background:#fff}
  .foot{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:40px}
  @media(max-width:780px){.foot{grid-template-columns:1fr 1fr;gap:28px}}
  .foot h4{font-family:'Red Hat Display',sans-serif;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-deep);margin-bottom:16px;font-weight:600}
  .foot ul{list-style:none;padding:0;margin:0}
  .foot li{margin-bottom:8px}
  .foot a{font-size:15px;color:var(--mute);transition:color .2s}
  .foot a:hover{color:var(--sage)}
  .foot-brand .brand{margin-bottom:14px}
  .foot-brand p{font-size:14px;max-width:280px}
  .foot-bottom{display:flex;justify-content:space-between;padding-top:24px;border-top:1px solid var(--line);font-size:13px;color:var(--mute);opacity:.7}
  @media(max-width:600px){.foot-bottom{flex-direction:column;gap:6px}}

  /* ───── Tweaks panel ───── */
  .tweaks{
    position:fixed;right:24px;bottom:24px;width:280px;background:#fff;border:1px solid var(--line);
    border-radius:18px;box-shadow:var(--shadow-lift);padding:18px;z-index:100;display:none;
    font-size:14px;
  }
  .tweaks.on{display:block;animation:fade .3s var(--ease)}
  .tweaks h5{font-family:'Abhaya Libre',serif;font-size:18px;color:var(--sage-deep);margin:0 0 14px;font-weight:500}
  .tweak-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-top:1px solid var(--line)}
  .tweak-row:first-of-type{border-top:0}
  .tweak-row label{color:var(--mute)}
  .tweak-swatches{display:flex;gap:6px}
  .swatch{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .2s}
  .swatch:hover{transform:scale(1.15)}
  .swatch.active{border-color:var(--sage-deep)}
  .toggle{position:relative;width:36px;height:20px;background:var(--line);border-radius:999px;cursor:pointer;transition:background .2s}
  .toggle::after{content:"";position:absolute;left:2px;top:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s}
  .toggle.on{background:var(--sage)}
  .toggle.on::after{transform:translateX(16px)}

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

  /* ───── PAGE HEADER (for subpages) ───── */
  .page-head{
    position:relative;padding:120px 0 80px;overflow:hidden;
    background:
      radial-gradient(70% 60% at 80% 20%, rgba(248,242,232,.9), transparent 60%),
      radial-gradient(40% 40% at 10% 90%, rgba(61,121,108,.04), transparent 60%),
      #fff;
  }
  .page-head .container{position:relative;z-index:2}
  .page-head h1{font-size:clamp(54px,7vw,96px);line-height:1;max-width:900px}
  .page-head h1 em{font-style:italic;color:var(--sage)}
  .page-head .script{font-size:clamp(40px,4vw,56px);display:block;margin-bottom:12px}
  .page-head .lede{max-width:560px;font-size:19px;line-height:1.65;margin-top:26px}
  .page-head::after{
    content:"";position:absolute;right:-120px;top:10%;width:360px;height:360px;border-radius:50%;
    border:1px solid rgba(61,121,108,.18);pointer-events:none;animation:drift 22s ease-in-out infinite;
  }

  /* breadcrumb */
  .crumbs{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);margin-bottom:26px}
  .crumbs a{color:var(--sage)}
  .crumbs a:hover{text-decoration:underline}
  .crumbs span{opacity:.4;margin:0 10px}

  /* ───── OVER MIJ ───── */
  .bio{padding:120px 0;background:#fff}
  .bio-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start}
  @media(max-width:900px){.bio-grid{grid-template-columns:1fr}}
  .bio-portrait{
    position:sticky;top:120px;aspect-ratio:4/5;border-radius:24px 24px 200px 200px;
    overflow:hidden;box-shadow:var(--shadow);
  }
  .bio-portrait img{
    display:block;width:100%;height:100%;object-fit:cover;object-position:center;
  }
  .bio-portrait::after{
    content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%, rgba(39,53,50,.15));pointer-events:none;
  }
  .bio-body h3{font-size:26px;margin:40px 0 12px;color:var(--sage-deep)}
  .bio-body h3:first-child{margin-top:0}
  .bio-body p{font-size:17.5px;line-height:1.75;margin-bottom:14px}
  .bio-body .pull{
    margin:32px 0;padding:26px 30px;background:var(--cream);border-radius:18px;
    font-family:'Abhaya Libre',serif;font-size:22px;color:var(--sage-deep);line-height:1.4;
  }
  .bio-body .pull .script{font-size:28px;display:block;margin-bottom:8px}

  .values{padding:120px 0;background:var(--cream)}
  .values-head{text-align:center;max-width:640px;margin:0 auto 60px}
  .values-head .script{display:block;font-size:36px;margin-bottom:8px}
  .values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  @media(max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.values-grid{grid-template-columns:1fr}}
  .value-card{
    background:#fff;padding:30px 26px;border-radius:18px;
    transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  }
  .value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
  .value-card .n{font-family:'Abhaya Libre',serif;color:var(--sage);font-size:14px;letter-spacing:.12em;display:block;margin-bottom:14px}
  .value-card h4{font-size:20px;color:var(--sage-deep);margin-bottom:8px}
  .value-card p{font-size:15px;color:var(--mute);margin:0;line-height:1.6}

  /* timeline */
  .journey{padding:120px 0;background:#fff}
  .journey-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
  @media(max-width:900px){.journey-wrap{grid-template-columns:1fr;gap:40px}}
  .jlist{display:flex;flex-direction:column;gap:4px;position:relative;padding-left:24px;border-left:1px dashed rgba(61,121,108,.3)}
  .jitem{padding:18px 0 22px 24px;position:relative}
  .jitem::before{
    content:"";position:absolute;left:-30px;top:24px;width:11px;height:11px;border-radius:50%;
    background:var(--sage);box-shadow:0 0 0 4px #fff;
  }
  .jitem .yr{font-family:'Abhaya Libre',serif;color:var(--sage);font-size:15px;letter-spacing:.1em;display:block;margin-bottom:4px}
  .jitem h4{font-size:19px;color:var(--sage-deep);margin-bottom:4px}
  .jitem p{font-size:15px;color:var(--mute);margin:0;line-height:1.55}

  /* ───── METHODS PAGE ───── */
  .mdetail{padding:120px 0;background:#fff}
  .mdetail + .mdetail{padding-top:0}
  .mrow{
    display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center;
    padding:80px 0;border-top:1px solid var(--line);
  }
  .mrow:first-child{border-top:0}
  .mrow.flip{grid-template-columns:1.2fr 1fr}
  .mrow.flip .mvis{order:2}
  @media(max-width:900px){.mrow, .mrow.flip{grid-template-columns:1fr;gap:32px}.mrow.flip .mvis{order:0}}

  .mvis{
    position:relative;aspect-ratio:5/4;border-radius:22px;overflow:hidden;
    background:var(--cream);display:flex;align-items:center;justify-content:center;
  }
  .mvis .circle{
    width:60%;aspect-ratio:1;border-radius:50%;border:1px solid var(--sage);
    position:absolute;animation:drift 18s ease-in-out infinite;
  }
  .mvis .circle.c2{width:40%;border-color:rgba(61,121,108,.4);animation-delay:-6s;animation-duration:22s}
  .mvis .circle.c3{width:22%;background:rgba(61,121,108,.08);border:0;animation-delay:-3s;animation-duration:15s}
  .mvis .num-big{
    position:relative;font-family:'Abhaya Libre',serif;font-size:clamp(100px,14vw,200px);
    line-height:1;color:var(--sage-deep);opacity:.15;
  }
  .mvis .label{
    position:absolute;top:24px;left:24px;font-size:13px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--sage);
  }

  .mcontent .n{font-family:'Abhaya Libre',serif;color:var(--sage);letter-spacing:.1em;font-size:14px;display:block;margin-bottom:12px}
  .mcontent h2{font-size:clamp(32px,3.2vw,44px);margin-bottom:18px}
  .mcontent p{font-size:17px;line-height:1.7;margin-bottom:14px}
  .mcontent ul{padding:0;margin:18px 0 0;list-style:none}
  .mcontent ul li{
    padding:12px 0 12px 28px;border-top:1px solid var(--line);position:relative;font-size:15.5px;
  }
  .mcontent ul li::before{
    content:"";position:absolute;left:0;top:20px;width:14px;height:1px;background:var(--sage);
  }
  .mcontent ul li:last-child{border-bottom:1px solid var(--line)}

  /* ───── TARIEVEN PAGE ───── */
  .pricing{padding:120px 0;background:#fff}
  .pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  @media(max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}}
  .price-card{
    background:#fff;border:1px solid var(--line);border-radius:22px;padding:36px 32px;
    display:flex;flex-direction:column;position:relative;overflow:hidden;
    transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .3s var(--ease);
  }
  .price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift);border-color:rgba(61,121,108,.2)}
  .price-card.feat{background:var(--sage-deep);color:#fff;border-color:var(--sage-deep)}
  .price-card.feat h3,.price-card.feat .amt{color:#fff}
  .price-card.feat .tag{background:var(--sage);color:#fff}
  .price-card.feat ul li{color:rgba(255,255,255,.8);border-color:rgba(255,255,255,.12)}
  .price-card.feat ul li:last-child{border-color:rgba(255,255,255,.12)}
  .price-card.feat ul li::before{background:#fff}
  .price-card .tag{
    position:absolute;top:20px;right:20px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;
    background:var(--cream);color:var(--bronze);padding:6px 10px;border-radius:999px;font-weight:500;
  }
  .price-card h3{font-size:26px;color:var(--sage-deep);margin-bottom:6px}
  .price-card .desc{font-size:14px;color:var(--mute);margin-bottom:24px;min-height:40px}
  .price-card.feat .desc{color:rgba(255,255,255,.7)}
  .price-card .amt{
    font-family:'Abhaya Libre',serif;font-size:54px;color:var(--sage-deep);line-height:1;margin-bottom:6px;
  }
  .price-card .amt small{font-size:16px;color:var(--mute);font-family:inherit;margin-left:4px}
  .price-card.feat .amt small{color:rgba(255,255,255,.6)}
  .price-card .unit{font-size:13px;color:var(--mute);letter-spacing:.08em;text-transform:uppercase;margin-bottom:24px}
  .price-card ul{list-style:none;padding:0;margin:0 0 28px}
  .price-card ul li{
    padding:12px 0 12px 26px;border-top:1px solid var(--line);font-size:14.5px;position:relative;line-height:1.4;
  }
  .price-card ul li:last-child{border-bottom:1px solid var(--line)}
  .price-card ul li::before{
    content:"";position:absolute;left:0;top:19px;width:12px;height:1px;background:var(--sage);
  }
  .price-card .cta{margin-top:auto}

  .pricing-notes{
    margin-top:60px;padding:40px 44px;background:var(--cream);border-radius:22px;
    display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  }
  @media(max-width:900px){.pricing-notes{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.pricing-notes{grid-template-columns:1fr}}
  .note h5{font-family:'Abhaya Libre',serif;color:var(--sage-deep);font-size:18px;margin:0 0 6px}
  .note p{font-size:14px;color:var(--mute);margin:0;line-height:1.55}

  /* FAQ */
  .faq{padding:120px 0;background:var(--cream)}
  .faq-head{text-align:center;max-width:640px;margin:0 auto 48px}
  .faq-head .script{display:block;font-size:36px;margin-bottom:8px}
  .faq-wrap{max-width:820px;margin:0 auto}
  .q{
    border-top:1px solid rgba(61,121,108,.15);padding:22px 0;cursor:pointer;
  }
  .q:last-child{border-bottom:1px solid rgba(61,121,108,.15)}
  .q summary{
    list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;
    font-family:'Abhaya Libre',serif;font-size:20px;color:var(--sage-deep);font-weight:500;
  }
  .q summary::-webkit-details-marker{display:none}
  .q summary::after{
    content:"+";width:30px;height:30px;border-radius:50%;border:1px solid var(--sage);
    display:flex;align-items:center;justify-content:center;color:var(--sage);font-size:20px;
    transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease);
    flex-shrink:0;
  }
  .q[open] summary::after{content:"−";background:var(--sage);color:#fff;transform:rotate(180deg)}
  .q p{margin:14px 0 0;font-size:16px;color:var(--mute);line-height:1.65}

  /* ─────────────────────────────────────────────
     MOBILE OPTIMISATIONS
     Desktop layout above is preserved as-is.
     Overrides only apply at ≤ 780px / ≤ 560px.
     ───────────────────────────────────────────── */

  /* Hamburger button — hidden on desktop */
  .nav-toggle{
    display:none;background:transparent;border:0;padding:10px;margin-right:-10px;
    cursor:pointer;position:relative;width:44px;height:44px;border-radius:12px;
    transition:background .25s var(--ease);z-index:50;
  }
  .nav-toggle span{
    display:block;width:22px;height:1.5px;background:var(--sage-deep);margin:5px auto;
    border-radius:2px;transition:transform .35s var(--ease), opacity .25s var(--ease);
  }
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

  /* Backdrop behind mobile menu */
  .nav-backdrop{
    position:fixed;inset:0;background:rgba(39,53,50,.35);backdrop-filter:blur(4px);
    -webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;z-index:40;
    transition:opacity .35s var(--ease);
  }
  .nav-backdrop.on{opacity:1;pointer-events:auto}

  @media (max-width:780px){
    .nav-toggle{display:block}
    .nav-inner{padding:16px 0}
    .nav.scrolled .nav-inner{padding:12px 0}
    .brand{font-size:17px}
    .brand-mark{width:30px;height:30px}

    /* Mobile drawer */
    .nav-links{
      position:fixed;top:0;right:0;bottom:0;left:0;width:100%;
      height:100vh;height:100dvh;
      background:#fff;flex-direction:column;align-items:stretch;gap:0;
      padding:88px 28px 32px;z-index:45;
      transform:translateX(102%);transition:transform .42s var(--ease);
      box-shadow:-20px 0 60px -20px rgba(39,53,50,.25);
      overflow-y:auto;
    }
    .nav-links.open{transform:translateX(0)}
    .nav-links a{
      display:block;padding:18px 4px;font-size:19px;
      border-bottom:1px solid var(--line);border-radius:0;color:var(--sage-deep);
      font-family:'Abhaya Libre',serif;font-weight:500;letter-spacing:-.01em;
    }
    .nav-links a::after{display:none}
    .nav-links a:not(.nav-cta){display:block}
    .nav-links .nav-cta{
      margin-top:22px;text-align:center;padding:16px 22px !important;
      font-family:'Red Hat Display',sans-serif;font-size:15px;border-bottom:0;
    }
    html.nav-open, body.nav-open{overflow:hidden;touch-action:none;overscroll-behavior:none}
    body.nav-open{position:fixed;width:100%;left:0;right:0}
  }

  /* Hero */
  @media (max-width:900px){
    .hero{padding:56px 0 40px}
    .hero-grid{gap:48px}
    .hero-visual{max-width:440px;margin:0 auto;justify-self:center}
  }
  @media (max-width:560px){
    .hero{padding:40px 0 24px}
    .hero h1{font-size:clamp(40px,11vw,56px);line-height:1.05}
    .eyebrow{font-size:12px;letter-spacing:.16em;margin-bottom:18px}
    .eyebrow::before{width:24px}
    .hero-script{font-size:38px;margin-top:6px}
    .hero-lede{font-size:17px;line-height:1.6;margin:22px 0 28px;max-width:none}
    .hero-cta-row{gap:10px}
    .hero-cta-row .btn{flex:1 1 auto;justify-content:center;padding:15px 20px;font-size:14.5px}
    .hero-meta{
      gap:0;margin-top:40px;
      display:grid;grid-template-columns:repeat(3,1fr);
    }
    .hero-meta div{padding-left:14px;border-left-width:1px}
    .hero-meta div:first-child{padding-left:0;border-left:0}
    .hero-meta strong{font-size:22px}
    .hero-meta span{font-size:11px;letter-spacing:.05em;line-height:1.3;margin-top:6px}
    .hero-visual{max-width:320px;aspect-ratio:4/5}
    .hv-script{font-size:30px;bottom:-10px;left:-14px;max-width:180px}
    .hv-dot{width:48px;height:48px;left:-16px}
  }

  /* Section rhythm */
  @media (max-width:780px){
    section{padding:80px 0}
    .section-head{margin-bottom:44px}
    .section-head .script{font-size:30px}
    h2{font-size:clamp(30px,6.2vw,40px);line-height:1.1}
    h3{font-size:22px}
    p{font-size:16px}
  }
  @media (max-width:560px){
    section{padding:64px 0}
  }

  /* About */
  @media (max-width:780px){
    .about{background:linear-gradient(180deg,#fff,#fff 50%,var(--cream) 50%)}
    .about-imgs{aspect-ratio:1/.9;max-width:440px;margin:0 auto}
    .about-imgs .i-ring{width:130px;right:-10px;top:10%}
    .about-text p{font-size:16.5px;line-height:1.7}
    .about-quote{font-size:19px;padding:18px 20px;margin-top:24px}
  }

  /* Methods */
  @media (max-width:780px){
    .methods{padding:80px 0}
    .methods-head{margin-bottom:44px}
    .methods-head .script{font-size:32px}
    .methods-intro{font-size:16px;line-height:1.7}
    .method-card{padding:26px 22px;border-radius:18px}
    .method-card h3{font-size:20px}
    .method-card .glyph{width:56px;height:56px;right:-8px;top:-8px}
  }
  @media (max-width:560px){
    .method-grid{gap:14px}
    .methods .reveal[style*="text-align:center"]{margin-top:40px !important}
  }

  /* Process */
  @media (max-width:780px){
    .process{padding:80px 0}
    .step{padding:22px 0;gap:18px;grid-template-columns:38px 1fr}
    .step-num{width:38px;height:38px;font-size:17px}
    .step h4{font-size:18px}
    .step p{font-size:14.5px}
    .step.active p{max-height:240px}
  }

  /* Reviews marquee */
  @media (max-width:780px){
    .reviews{padding:80px 0}
    .reviews-head{margin-bottom:44px}
    .reviews-head .script{font-size:30px}
    .review-card{width:300px;padding:24px 22px;border-radius:16px}
    .review-card blockquote{font-size:16.5px;line-height:1.5}
    .marquee{gap:16px;animation-duration:40s}
  }

  /* Banner */
  @media (max-width:780px){
    .banner{padding:80px 0}
    .banner .script{font-size:clamp(42px,10vw,60px);margin-bottom:18px}
    .banner p{font-size:16px;margin-bottom:28px;padding:0 8px}
    .banner::before{width:200px;height:200px;left:-80px}
    .banner::after{width:140px;height:140px;right:-60px}
  }

  /* Contact */
  @media (max-width:780px){
    .contact{padding:80px 0 64px}
    .contact-grid{border-radius:20px}
    .contact-form{padding:36px 24px}
    .contact-form h2{font-size:28px}
    .contact-form .sub{font-size:15px;margin-bottom:24px}
    .field input,.field textarea{padding:14px 14px;font-size:16px;border-radius:10px}
    .field textarea{min-height:110px}
    .contact-photo{min-height:280px;order:-1}
    .contact-photo .info{left:20px;right:20px;bottom:20px;padding:18px 20px;border-radius:12px}
    .contact-photo .info strong{font-size:19px}
    .contact-photo .info span{font-size:13px}
  }

  /* Footer */
  @media (max-width:780px){
    footer{padding:48px 0 32px}
    .foot{margin-bottom:32px;gap:32px 24px}
    .foot h4{font-size:12px;margin-bottom:12px}
    .foot a{font-size:14.5px}
    .foot-brand{grid-column:1 / -1}
    .foot-brand p{font-size:14px;max-width:none}
  }
  @media (max-width:480px){
    .foot{grid-template-columns:1fr 1fr}
    .foot-brand{grid-column:1 / -1}
  }

  /* Buttons — ensure easy tap targets */
  @media (max-width:560px){
    .btn{padding:15px 24px;font-size:14.5px}
  }

  /* Tweaks panel — avoid covering mobile content */
  @media (max-width:560px){
    .tweaks{
      right:12px;left:12px;bottom:12px;width:auto;padding:14px 16px;
      border-radius:14px;
    }
    .tweaks h5{font-size:16px;margin-bottom:10px}
    .tweak-row{padding:6px 0}
  }

  /* ─── PAGE HEADER (subpages) ─── */
  @media (max-width:780px){
    .page-head{padding:72px 0 48px}
    .page-head h1{font-size:clamp(40px,10.5vw,60px);line-height:1.05}
    .page-head .script{font-size:clamp(32px,7vw,44px);margin-bottom:8px}
    .page-head .lede{font-size:17px;line-height:1.6;margin-top:20px}
    .page-head::after{width:220px;height:220px;right:-100px;top:4%}
    .crumbs{font-size:12px;margin-bottom:20px}
  }

  /* ─── OVER MIJ ─── */
  @media (max-width:900px){
    .bio{padding:80px 0}
    .bio-grid{gap:40px}
    .bio-portrait{
      position:relative;top:0;max-width:420px;margin:0 auto;
      aspect-ratio:4/4.4;border-radius:22px 22px 140px 140px;
    }
  }
  @media (max-width:780px){
    .bio-body h3{font-size:22px;margin:32px 0 10px}
    .bio-body p{font-size:16.5px;line-height:1.7}
    .bio-body .pull{font-size:19px;padding:22px 22px;margin:24px 0;border-radius:14px}
    .bio-body .pull .script{font-size:24px}

    .values{padding:80px 0}
    .values-head{margin-bottom:44px}
    .values-head .script{font-size:30px}
    .value-card{padding:26px 22px;border-radius:16px}
    .value-card h4{font-size:18px}
    .value-card p{font-size:14.5px}

    .journey{padding:80px 0}
    .journey-wrap{gap:36px}
    .jlist{padding-left:20px}
    .jitem{padding:14px 0 18px 16px}
    .jitem::before{left:-26px;top:20px;width:9px;height:9px}
    .jitem h4{font-size:17px}
    .jitem p{font-size:14.5px}
    .jitem .yr{font-size:14px}
  }

  /* ─── AANBOD / METHOD DETAIL ─── */
  @media (max-width:900px){
    .mdetail{padding:64px 0}
    .mrow{padding:48px 0;gap:32px}
  }
  @media (max-width:780px){
    .mvis{aspect-ratio:5/3.8;border-radius:18px}
    .mvis .num-big{font-size:clamp(80px,22vw,140px)}
    .mvis .label{top:18px;left:18px;font-size:12px}
    .mcontent .n{font-size:13px}
    .mcontent h2{font-size:clamp(26px,6vw,34px);margin-bottom:14px}
    .mcontent p{font-size:16px;line-height:1.65}
    .mcontent ul li{font-size:14.5px;padding:11px 0 11px 22px}
    .mcontent ul li::before{width:12px;top:18px}
  }

  /* ─── TARIEVEN ─── */
  @media (max-width:900px){
    .pricing{padding:80px 0}
    .pricing-grid{gap:18px}
  }
  @media (max-width:780px){
    .price-card{padding:30px 26px;border-radius:18px}
    .price-card h3{font-size:22px}
    .price-card .desc{min-height:auto;margin-bottom:18px;font-size:14px}
    .price-card .amt{font-size:44px}
    .price-card .unit{margin-bottom:20px}
    .price-card ul li{font-size:14px;padding:11px 0 11px 22px}
    .price-card ul li::before{width:12px;top:18px}
    .price-card .tag{top:16px;right:16px;font-size:10.5px;padding:5px 9px}

    .pricing-notes{
      margin-top:40px;padding:30px 26px;gap:22px;border-radius:18px;
    }
    .note h5{font-size:17px}
    .note p{font-size:13.5px}
  }

  /* ─── FAQ ─── */
  @media (max-width:780px){
    .faq{padding:80px 0}
    .faq-head{margin-bottom:36px}
    .faq-head .script{font-size:30px}
    .q{padding:18px 0}
    .q summary{font-size:17.5px;gap:16px}
    .q summary::after{width:26px;height:26px;font-size:17px}
    .q p{font-size:15px;line-height:1.6;margin-top:10px}
  }

  /* ─── Misc safety ─── */
  /* iOS: prevent input zoom by ensuring 16px+ font */
  @media (max-width:780px){
    input, textarea, select{font-size:16px !important}
  }
  /* Prevent horizontal overflow from decorative elements */
  @media (max-width:560px){
    .hero-bg,.banner::before,.banner::after,.page-head::after{will-change:transform}
  }
