/* ============================================================================
   De Tussenruimte — Gedeelde stijlen
   Organisatie: fonts → tokens → reset → nav → knoppen → layout → secties → footer
   ============================================================================ */

/* ─── Zelf-gehoste fonts (OFL-licentie) ─────────────────────────────────── */
@font-face {
    font-family: 'Cormorant Garamond';
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url('../fonts/cormorant-garamond-normal-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Cormorant Garamond';
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url('../fonts/cormorant-garamond-normal-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Cormorant Garamond';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/cormorant-garamond-normal-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Cormorant Garamond';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/cormorant-garamond-normal-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Cormorant Garamond';
    font-style: italic;
    font-weight: 300;
    font-display: swap;
    src: url('../fonts/cormorant-garamond-italic-300-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Cormorant Garamond';
    font-style: italic;
    font-weight: 300;
    font-display: swap;
    src: url('../fonts/cormorant-garamond-italic-300-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Jost';
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url('../fonts/jost-normal-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Jost';
    font-style: normal;
    font-weight: 300;
    font-display: swap;
    src: url('../fonts/jost-normal-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: 'Jost';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/jost-normal-latin-ext.woff2') format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: 'Jost';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('../fonts/jost-normal-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ─── Design tokens ──────────────────────────────────────────────────────── */
:root {
    /* Kleurenpalet: zachte aardtonen */
    --clr-cream:        #f5f0eb;
    --clr-sand:         #ede7de;
    --clr-sage:         #e4eae0;
    --clr-stone:        #d4c9bc;
    --clr-earth:        #8a6a50;
    --clr-deep:         #3d2b1f;
    --clr-text:         #2d2420;
    --clr-text-muted:   #8a7a72;

    /* Typografie */
    --font-heading: 'Cormorant Garamond', Georgia, serif;
    --font-body:    'Jost', system-ui, sans-serif;

    /* Fluid type scale — schaalt vloeiend mee met de schermgrootte */
    --type-label:   clamp(0.68rem,  1.3vw,  0.78rem);
    --type-body:    clamp(0.95rem,  1.8vw,  1.05rem);
    --type-lead:    clamp(1.1rem,   2.2vw,  1.3rem);
    --type-title:   clamp(1.9rem,   4.5vw,  3.25rem);
    --type-display: clamp(2.75rem,  6.5vw,  5rem);

    /* Container-breedtes */
    --container-sm: min(640px, 88vw);
    --container-md: min(840px, 88vw);
    --container-lg: min(1100px, 88vw);

    /* Decoratief */
    --radius-card:  1.5rem;
    --shadow-card:  0 -10px 44px rgba(0, 0, 0, 0.13);
    --transition:   0.25s ease;
    --nav-h:        64px;
}

/* ─── Reset ──────────────────────────────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-body);
    font-weight: 300;
    font-size: var(--type-body);
    color: var(--clr-text);
    background-color: var(--clr-deep);
    line-height: 1.6;
    overflow-x: hidden;
}

body.menu-open { overflow: hidden; }

img, svg { display: block; max-width: 100%; }
a        { color: inherit; text-decoration: none; }
ul       { list-style: none; }

/* ─── Navigatie ──────────────────────────────────────────────────────────── */
.site-nav {
    position: fixed;
    inset-block-start: 0;
    inset-inline: 0;
    z-index: 100;
    height: var(--nav-h);
    display: flex;
    align-items: center;
    padding-inline: clamp(1.25rem, 4vw, 3rem);
    transition:
        background-color var(--transition),
        box-shadow       var(--transition);
}

/* Achtergrond verschijnt zodra de gebruiker naar beneden scrollt (via JS) */
.site-nav.is-scrolled,
.site-nav--solid {
    background-color: rgba(245, 240, 235, 0.96);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 1px 20px rgba(0, 0, 0, 0.07);
}

.site-nav__logo {
    font-family: var(--font-heading);
    font-size: clamp(1.05rem, 2.5vw, 1.35rem);
    font-weight: 400;
    color: var(--clr-cream);
    letter-spacing: 0.03em;
    flex-shrink: 0;
    transition: color var(--transition);
}

.site-nav.is-scrolled .site-nav__logo,
.site-nav--solid .site-nav__logo {
    color: var(--clr-deep);
}

.site-nav__links {
    display: flex;
    align-items: center;
    gap: clamp(1rem, 2.5vw, 2.25rem);
    margin-inline-start: auto;
}

.site-nav__link {
    font-size: var(--type-label);
    font-weight: 400;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(245, 240, 235, 0.8);
    transition: color var(--transition);
}

.site-nav__link:hover { color: var(--clr-cream); }

.site-nav.is-scrolled .site-nav__link,
.site-nav--solid .site-nav__link {
    color: var(--clr-text-muted);
}

.site-nav.is-scrolled .site-nav__link:hover,
.site-nav--solid .site-nav__link:hover {
    color: var(--clr-deep);
}

/* CTA-link in de navigatiebalk */
.site-nav__link--cta {
    padding: 0.5em 1.2em;
    border: 1px solid rgba(245, 240, 235, 0.4);
    border-radius: 0.3rem;
    transition:
        border-color     var(--transition),
        color            var(--transition),
        background-color var(--transition);
}

.site-nav.is-scrolled .site-nav__link--cta,
.site-nav--solid .site-nav__link--cta {
    border-color: var(--clr-earth);
    color: var(--clr-earth);
}

.site-nav.is-scrolled .site-nav__link--cta:hover,
.site-nav--solid .site-nav__link--cta:hover {
    background-color: var(--clr-deep);
    border-color: var(--clr-deep);
    color: var(--clr-cream);
}

/* Hamburger-knop (zichtbaar op mobiel) */
.site-nav__toggle {
    display: none;
    flex-direction: column;
    justify-content: space-between;
    width: 26px;
    height: 18px;
    background: none;
    border: none;
    cursor: pointer;
    margin-inline-start: auto;
    padding: 0;
}

.site-nav__toggle span {
    display: block;
    height: 1.5px;
    background-color: var(--clr-cream);
    border-radius: 2px;
    transition:
        background-color var(--transition),
        transform        var(--transition),
        opacity          var(--transition);
}

.site-nav.is-scrolled .site-nav__toggle span,
.site-nav--solid .site-nav__toggle span {
    background-color: var(--clr-deep);
}

.site-nav__toggle.is-open span:nth-child(1) { transform: translateY(8.25px)  rotate(45deg);  }
.site-nav__toggle.is-open span:nth-child(2) { opacity: 0; }
.site-nav__toggle.is-open span:nth-child(3) { transform: translateY(-8.25px) rotate(-45deg); }

/* Mobiel volledige-scherm menu */
.site-nav__mobile-menu {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99;
    background-color: var(--clr-cream);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2.25rem;
    padding-top: var(--nav-h);
}

.site-nav__mobile-menu.is-open { display: flex; }

.site-nav__mobile-link {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 5vw, 2.25rem);
    font-weight: 300;
    color: var(--clr-deep);
    letter-spacing: 0.02em;
    transition: color var(--transition);
}

.site-nav__mobile-link:hover { color: var(--clr-earth); }

@media (max-width: 768px) {
    .site-nav__links  { display: none; }
    .site-nav__toggle { display: flex; }
}

/* ─── Knoppen ────────────────────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
    padding: 0.85em 2.2em;
    font-family: var(--font-body);
    font-size: var(--type-label);
    font-weight: 400;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    border-radius: 0.375rem;
    border: 1px solid transparent;
    cursor: pointer;
    transition:
        background-color var(--transition),
        color            var(--transition),
        border-color     var(--transition);
}

.btn--primary {
    background-color: var(--clr-deep);
    color: var(--clr-cream);
    border-color: var(--clr-deep);
}

.btn--primary:hover,
.btn--primary:focus-visible {
    background-color: var(--clr-earth);
    border-color: var(--clr-earth);
    outline: none;
}

.btn--outline {
    background-color: transparent;
    color: var(--clr-deep);
    border-color: var(--clr-deep);
}

.btn--outline:hover,
.btn--outline:focus-visible {
    background-color: var(--clr-deep);
    color: var(--clr-cream);
    outline: none;
}

.btn--outline-light {
    background-color: transparent;
    color: var(--clr-cream);
    border-color: rgba(245, 240, 235, 0.55);
}

.btn--outline-light:hover,
.btn--outline-light:focus-visible {
    background-color: var(--clr-cream);
    color: var(--clr-deep);
    border-color: var(--clr-cream);
    outline: none;
}

/* ─── Gedeelde sectie-inhoud ─────────────────────────────────────────────── */
.section__inner {
    width: var(--container-sm);
    text-align: center;
}

.section__inner--md { width: var(--container-md); }
.section__inner--lg { width: var(--container-lg); }

.section__label {
    font-size: var(--type-label);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--clr-earth);
    margin-bottom: 1.25rem;
}

.section__title {
    font-family: var(--font-heading);
    font-size: var(--type-title);
    font-weight: 300;
    line-height: 1.12;
    color: var(--clr-deep);
    margin-bottom: 1.25rem;
}

.section__body {
    font-size: var(--type-body);
    color: var(--clr-text-muted);
    line-height: 1.85;
    max-width: 54ch;
    margin-inline: auto;
}

.section__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
    margin-top: clamp(1.75rem, 4vh, 2.75rem);
}

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.site-footer {
    background-color: var(--clr-deep);
    padding: clamp(1.5rem, 4vh, 2.5rem) clamp(1.25rem, 4vw, 3rem);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-top: 1px solid rgba(245, 240, 235, 0.1);
}

.footer__brand {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    color: rgba(245, 240, 235, 0.45);
    font-weight: 300;
}

.footer__links {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
}

.footer__link {
    font-size: var(--type-label);
    color: rgba(245, 240, 235, 0.4);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: color var(--transition);
}

.footer__link:hover { color: rgba(245, 240, 235, 0.8); }

.footer__credit {
    width: 100%;
    font-size: 0.8rem;
    color: rgba(245, 240, 235, 0.4);
    letter-spacing: 0.05em;
    text-align: right;
}

.footer__credit a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition);
}

.footer__credit a:hover { color: rgba(245, 240, 235, 0.85); }

/* ─── Startpagina: Scroll-stack ─────────────────────────────────────────── */
.stack-section {
    position: sticky;
    top: 0;
    height: 100vh;
    min-height: 560px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.section--over,
.section--diensten,
.section--cheque,
.section--retraite,
.section--contact {
    border-radius: var(--radius-card) var(--radius-card) 0 0;
    box-shadow: var(--shadow-card);
}

.section--hero     { z-index: 1; }
.section--over     { z-index: 2; }
.section--diensten { z-index: 3; }
.section--cheque   { z-index: 4; }
.section--retraite { z-index: 5; }
.section--contact  { z-index: 6; }

.section--hero      { background-color: var(--clr-deep); }
.section--over      { background-color: var(--clr-cream); position: relative; height: auto; min-height: 100vh; padding-block: clamp(5rem, 9vh, 8rem); justify-content: flex-start; }
.section--diensten  { background-color: var(--clr-sand); }
.section--cheque    { background-color: var(--clr-sage); }
.section--retraite  { background-color: var(--clr-stone); }
.section--contact   { background-color: #7a5540; }

/* ─── Startpagina: Hero ──────────────────────────────────────────────────── */
.hero__bg {
    position: absolute;
    inset: 0;
    background-image: url('../Images/algemeen/pexels-path-1839000.webp');
    background-image: image-set(url('../Images/algemeen/pexels-path-1839000.webp') type('image/webp'), url('../Images/algemeen/pexels-path-1839000.jpg') type('image/jpeg'));
    background-size: cover;
    background-position: center 35%;
}

.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        155deg,
        rgba(61, 43, 31, 0.18) 0%,
        rgba(61, 43, 31, 0.72) 100%
    );
}

.hero__content {
    position: relative;
    z-index: 1;
    text-align: center;
    color: var(--clr-cream);
    padding: clamp(1.5rem, 5vw, 3rem);
    max-width: var(--container-md);
}

.hero__eyebrow {
    font-size: var(--type-label);
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: rgba(212, 201, 188, 0.9);
    margin-bottom: 1.5rem;
}

.hero__title {
    font-family: var(--font-heading);
    font-size: var(--type-display);
    font-weight: 300;
    line-height: 1.05;
    margin-bottom: 1.5rem;
}

.hero__title em {
    font-style: italic;
    color: var(--clr-stone);
}

.hero__intro {
    font-size: var(--type-body);
    line-height: 1.85;
    opacity: 0.82;
    max-width: 52ch;
    margin: 0 auto 2.5rem;
}

.hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

.hero__scroll-hint {
    position: absolute;
    bottom: clamp(1.75rem, 4vh, 2.75rem);
    left: 50%;
    translate: -50% 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.6rem;
    color: var(--clr-cream);
    opacity: 0.4;
    font-size: var(--type-label);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    pointer-events: none;
}

.hero__scroll-hint::after {
    content: '';
    width: 1px;
    height: 40px;
    background: currentColor;
    transform-origin: top;
    animation: hint-pulse 2.4s ease-in-out infinite;
}

@keyframes hint-pulse {
    0%, 100% { opacity: 0.2; transform: scaleY(0.5); }
    55%       { opacity: 1;   transform: scaleY(1);   }
}

/* ─── Startpagina: Over ──────────────────────────────────────────────────── */
.section--over .section__title,
.section--over .section__label { color: var(--clr-deep); }
.section--over .section__body  { color: var(--clr-text-muted); }

.over__signature {
    margin-top: clamp(2rem, 4vh, 3rem);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
}

.over__signature-line {
    width: 48px;
    height: 1px;
    background-color: var(--clr-stone);
}

.over__signature-name {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-style: italic;
    color: var(--clr-earth);
}

/* ─── Startpagina: Over — portret layout ────────────────────────────────── */
.over__layout {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: clamp(2.5rem, 6vw, 5rem);
    align-items: center;
    width: var(--container-lg);
}

.over__image {
    border-radius: 1rem;
    overflow: hidden;
    aspect-ratio: 3/4;
    flex-shrink: 0;
}

.over__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
}

.over__layout .section__inner {
    width: 100%;
    text-align: left;
}

.over__layout .section__label,
.over__layout .section__title,
.over__layout .section__body {
    text-align: left;
    margin-inline: 0;
}

.over__layout .over__signature { justify-content: flex-start; }

@media (max-width: 720px) {
    .over__layout {
        grid-template-columns: 1fr;
        width: var(--container-sm);
    }
    .over__image { aspect-ratio: 4/3; }
}

/* ─── Startpagina: Diensten ──────────────────────────────────────────────── */
.service-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(230px, 100%), 1fr));
    gap: clamp(0.875rem, 2.5vw, 1.5rem);
    margin-top: clamp(1.5rem, 3.5vh, 2.75rem);
    text-align: left;
}

.service-card {
    background: rgba(255, 255, 255, 0.55);
    border-radius: 1rem;
    padding: clamp(1.25rem, 2.5vw, 1.75rem);
    border: 1px solid rgba(255, 255, 255, 0.7);
    transition: transform var(--transition), box-shadow var(--transition);
}

.service-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(61, 43, 31, 0.1);
}

.service-card__number {
    display: none;
}

.service-card__title {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-weight: 400;
    color: var(--clr-deep);
    margin-bottom: 0.5rem;
}

.service-card__text {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.75;
    margin-bottom: 1rem;
}

.service-card__link {
    font-size: var(--type-label);
    font-weight: 400;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--clr-earth);
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    transition: gap var(--transition), color var(--transition);
}

.service-card__link::after { content: '→'; }
.service-card__link:hover  { gap: 0.7em; color: var(--clr-deep); }

/* ─── Startpagina: Loopbaancheque ────────────────────────────────────────── */
.cheque-highlights {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(160px, 100%), 1fr));
    gap: clamp(0.75rem, 2vw, 1.25rem);
    margin-top: clamp(1.5rem, 3vh, 2.25rem);
}

.cheque-item {
    background: rgba(255, 255, 255, 0.65);
    border-radius: 0.75rem;
    padding: 1.25rem 1rem;
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0.85);
}

.cheque-item__value {
    font-family: var(--font-heading);
    font-size: var(--type-title);
    color: var(--clr-earth);
    line-height: 1;
    margin-bottom: 0.4rem;
}

.cheque-item__desc {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.5;
}

.cheque-note {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    font-style: italic;
    max-width: 52ch;
    margin: clamp(1rem, 2vh, 1.5rem) auto 0;
    line-height: 1.7;
}

/* ─── Startpagina: Retraite preview ─────────────────────────────────────── */
.retraite-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
    width: var(--container-lg);
}

.retraite-layout__image {
    border-radius: 1rem;
    overflow: hidden;
    aspect-ratio: 4/5;
}

.retraite-layout__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.retraite-layout__content .section__label,
.retraite-layout__content .section__title,
.retraite-layout__content .section__body {
    text-align: left;
    margin-inline: 0;
}

.retraite-layout__content .section__ctas { justify-content: flex-start; }

.retraite-includes {
    margin-top: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.retraite-includes li {
    display: flex;
    align-items: baseline;
    gap: 0.6em;
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.6;
}

.retraite-includes li::before {
    content: '—';
    color: var(--clr-earth);
    flex-shrink: 0;
}

@media (max-width: 680px) {
    .retraite-layout {
        grid-template-columns: 1fr;
        width: var(--container-sm);
    }

    .retraite-layout__image { aspect-ratio: 16/9; }
}

/* ─── Startpagina: Contact ───────────────────────────────────────────────── */
.section--contact .section__label { color: rgba(245, 240, 235, 0.65); }
.section--contact .section__title { color: var(--clr-cream); margin-bottom: 1.5rem; }
.section--contact .section__body  { color: rgba(245, 240, 235, 0.75); }

.contact-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(3rem, 6vw, 6rem);
    align-items: center;
    width: var(--container-lg);
}

.contact-layout .section__label,
.contact-layout .section__title,
.contact-layout .section__body {
    text-align: left;
    margin-inline: 0;
}

.contact-layout .section__ctas    { justify-content: flex-start; }
.contact-layout .testimonial-grid { width: 100%; margin-top: 0; }

@media (max-width: 720px) {
    .contact-layout {
        grid-template-columns: 1fr;
        width: var(--container-sm);
    }

    .section--contact {
        height: auto;
        min-height: 100vh;
        overflow-y: visible;
        justify-content: flex-start;
        padding-top: calc(var(--nav-h) + 2.5rem);
        padding-bottom: 3rem;
    }
}

/* ─── Contactformulier ───────────────────────────────────────────────────── */
.contact-form {
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
    margin-top: 0.75rem;
}

.contact-form .form-group {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.contact-form label {
    font-size: var(--type-label);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(245, 240, 235, 0.65);
}

.contact-form input,
.contact-form textarea {
    font-family: var(--font-body);
    font-size: var(--type-label);
    font-weight: 300;
    color: var(--clr-cream);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(245, 240, 235, 0.25);
    border-radius: 0.375rem;
    padding: 0.75em 1em;
    transition: border-color var(--transition), background var(--transition);
    width: 100%;
    box-sizing: border-box;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: rgba(245, 240, 235, 0.35);
}

.contact-form input:focus,
.contact-form textarea:focus {
    outline: none;
    border-color: rgba(245, 240, 235, 0.6);
    background: rgba(255, 255, 255, 0.13);
}

.contact-form textarea {
    resize: vertical;
    min-height: 80px;
}

.contact-form__footer {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    flex-wrap: wrap;
    margin-top: 0.25rem;
}

.contact-option__heading {
    font-size: var(--type-label);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(245, 240, 235, 0.65);
    margin-bottom: 0.5rem;
}

.contact-option__text {
    font-size: var(--type-label);
    color: rgba(245, 240, 235, 0.7);
    line-height: 1.75;
    margin-bottom: 1.1rem;
}

.contact-divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin: 1.5rem 0;
    font-size: var(--type-label);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(245, 240, 235, 0.35);
}

.contact-divider::before,
.contact-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(245, 240, 235, 0.18);
}

/* ─── Retraite pagina ────────────────────────────────────────────────────── */
.inclusion-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr));
    gap: clamp(1rem, 2.5vw, 1.5rem);
    margin-top: clamp(2rem, 4vh, 3.5rem);
    width: var(--container-lg);
}

.inclusion-item {
    background: rgba(255, 255, 255, 0.55);
    border-radius: 0.75rem;
    padding: clamp(1.25rem, 2.5vw, 1.75rem);
    border: 1px solid rgba(255, 255, 255, 0.75);
    text-align: left;
}

.inclusion-item__icon {
    font-size: 1.4rem;
    margin-bottom: 0.75rem;
    line-height: 1;
}

.inclusion-item__title {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-weight: 400;
    color: var(--clr-deep);
    margin-bottom: 0.4rem;
}

.inclusion-item__text {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.75;
}

/* ─── Retraite: foto-grid ────────────────────────────────────────────────── */
.retraite-photo-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: auto auto;
    gap: 0.625rem;
    width: var(--container-lg);
    margin-top: clamp(2rem, 4vh, 3rem);
}

.retraite-photo-grid__item {
    border-radius: 0.5rem;
    overflow: hidden;
    aspect-ratio: 4/3;
}

.retraite-photo-grid__item--tall {
    grid-row: span 2;
    aspect-ratio: unset;
}

.retraite-photo-grid__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.retraite-photo-grid__item:hover img { transform: scale(1.03); }

@media (max-width: 680px) {
    .retraite-photo-grid {
        grid-template-columns: 1fr 1fr;
        width: var(--container-sm);
    }
    .retraite-photo-grid__item--tall {
        grid-row: span 1;
        aspect-ratio: 4/3;
    }
}

.quote-block {
    border-left: 2px solid var(--clr-earth);
    padding-left: clamp(1.25rem, 3vw, 2rem);
    margin: clamp(2.5rem, 5vh, 4rem) auto;
    max-width: 52ch;
    text-align: left;
}

.quote-block__text {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-style: italic;
    font-weight: 300;
    color: var(--clr-deep);
    line-height: 1.55;
    margin-bottom: 0.75rem;
}

.quote-block__source {
    font-size: var(--type-label);
    color: var(--clr-earth);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.booking-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(200px, 100%), 1fr));
    gap: clamp(0.75rem, 2vw, 1.25rem);
    margin-top: clamp(1.75rem, 4vh, 3rem);
    width: var(--container-md);
}

.booking-item {
    text-align: center;
    padding: 1.5rem 1rem;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.booking-item__label {
    font-size: var(--type-label);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--clr-stone);
    margin-bottom: 0.5rem;
}

.booking-item__value {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    color: var(--clr-cream);
    font-weight: 300;
}

.retraite-options {
    margin-top: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-width: 44ch;
    margin-inline: auto;
    text-align: left;
}

.retraite-options li {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    display: flex;
    gap: 0.6em;
}

.retraite-options li span { color: var(--clr-earth); }

/* ─── Loopbaancheque pagina ──────────────────────────────────────────────── */
.fact-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(180px, 100%), 1fr));
    gap: clamp(0.875rem, 2vw, 1.25rem);
    margin-top: clamp(2rem, 4vh, 3.5rem);
    width: var(--container-md);
}

.fact-item {
    text-align: center;
    padding: 1.75rem 1.25rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.8);
}

.fact-item__value {
    font-family: var(--font-heading);
    font-size: var(--type-display);
    font-weight: 300;
    color: var(--clr-earth);
    line-height: 1;
    margin-bottom: 0.5rem;
}

.fact-item__label {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    line-height: 1.5;
}

.steps-list {
    width: var(--container-md);
    margin-top: clamp(2rem, 4vh, 3.5rem);
    display: flex;
    flex-direction: column;
    gap: 0;
}

.step {
    display: grid;
    grid-template-columns: 3.5rem 1fr;
    gap: 1.25rem;
    align-items: start;
    text-align: left;
    padding-bottom: clamp(1.5rem, 3vh, 2.25rem);
    position: relative;
}

.step:not(:last-child)::after {
    content: '';
    position: absolute;
    left: 1.55rem;
    top: 2.5rem;
    bottom: 0;
    width: 1px;
    background: linear-gradient(to bottom, var(--clr-stone), transparent);
}

.step__number {
    font-family: var(--font-heading);
    font-size: var(--type-title);
    color: var(--clr-stone);
    line-height: 1;
    text-align: center;
}

.step__title {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-weight: 400;
    color: var(--clr-deep);
    margin-bottom: 0.4rem;
    padding-top: 0.2rem;
}

.step__text {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.75;
}

.conditions-list {
    margin-top: clamp(1.75rem, 3.5vh, 2.75rem);
    max-width: 48ch;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    text-align: left;
}

.conditions-list li {
    display: flex;
    align-items: baseline;
    gap: 0.75em;
    font-size: var(--type-body);
    color: var(--clr-text-muted);
    line-height: 1.7;
}

.conditions-list li::before {
    content: '✓';
    color: var(--clr-earth);
    font-family: var(--font-heading);
    flex-shrink: 0;
    font-size: 1em;
}

.conditions-list--no li::before {
    content: '✕';
    color: var(--clr-text-muted);
}

.conditions-columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
}

@media (max-width: 640px) {
    .conditions-columns { grid-template-columns: 1fr; gap: 2rem; }
}

.conditions-label {
    font-size: var(--type-label);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.conditions-label--positive { color: var(--clr-earth); }
.conditions-label--negative { color: var(--clr-text-muted); }

.conditions-note {
    margin-top: 2rem;
    font-size: var(--type-body);
    color: var(--clr-text-muted);
    font-style: italic;
    max-width: 54ch;
}

.faq-list {
    width: var(--container-md);
    margin-top: clamp(2rem, 4vh, 3.5rem);
    text-align: left;
}

.faq-item {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    padding: clamp(1.25rem, 2.5vh, 1.75rem) 0;
}

.faq-item__question {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-weight: 400;
    color: var(--clr-deep);
    margin-bottom: 0.6rem;
}

.faq-item__answer {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.8;
    max-width: 58ch;
}

/* ─── Blog pagina ────────────────────────────────────────────────────────── */
.article-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
    width: var(--container-lg);
    margin-top: clamp(2.5rem, 5vh, 4rem);
}

.article-card {
    background-color: white;
    border-radius: 1rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform var(--transition), box-shadow var(--transition);
}

.article-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 40px rgba(61, 43, 31, 0.12);
}

.article-card__image {
    aspect-ratio: 16/9;
    overflow: hidden;
}

.article-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.article-card:hover .article-card__image img { transform: scale(1.04); }

.article-card__body {
    padding: clamp(1.25rem, 2.5vw, 1.75rem);
    display: flex;
    flex-direction: column;
    flex: 1;
}

.article-card__meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.article-card__category {
    font-size: var(--type-label);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--clr-earth);
}

.article-card__date {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
}

.article-card__title {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-weight: 400;
    color: var(--clr-deep);
    line-height: 1.25;
    margin-bottom: 0.75rem;
}

.article-card__excerpt {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.8;
    flex: 1;
    margin-bottom: 1.5rem;
}

.article-card__readmore {
    font-size: var(--type-label);
    font-weight: 400;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--clr-earth);
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    transition: gap var(--transition), color var(--transition);
    align-self: flex-start;
}

.article-card__readmore::after { content: '→'; }
.article-card__readmore:hover  { gap: 0.7em; color: var(--clr-deep); }

.article-card--featured {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}

.article-card--featured .article-card__image {
    aspect-ratio: unset;
    min-height: 300px;
}

.article-card--featured .article-card__body { padding: clamp(2rem, 4vw, 3rem); }

.article-card--featured .article-card__title {
    font-size: var(--type-title);
    line-height: 1.12;
}

@media (max-width: 600px) {
    .article-card--featured { grid-template-columns: 1fr; }
}

.newsletter-banner {
    width: var(--container-md);
    background: var(--clr-sage);
    border-radius: 1rem;
    padding: clamp(2rem, 4vw, 3rem);
    text-align: center;
    margin-top: clamp(3rem, 6vh, 5rem);
    border: 1px solid rgba(255, 255, 255, 0.7);
}

.newsletter-banner__title {
    font-family: var(--font-heading);
    font-size: var(--type-title);
    font-weight: 300;
    color: var(--clr-deep);
    margin-bottom: 0.75rem;
}

.newsletter-banner__text {
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    line-height: 1.8;
    max-width: 48ch;
    margin: 0 auto 1.75rem;
}

.newsletter-form {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    flex-wrap: wrap;
    max-width: 420px;
    margin-inline: auto;
}

.newsletter-form input[type="email"] {
    flex: 1;
    min-width: 200px;
    padding: 0.8em 1em;
    border: 1px solid var(--clr-stone);
    border-radius: 0.375rem;
    font-family: var(--font-body);
    font-size: var(--type-label);
    font-weight: 300;
    color: var(--clr-text);
    background: white;
    transition: border-color var(--transition);
}

.newsletter-form input[type="email"]:focus {
    outline: none;
    border-color: var(--clr-earth);
}

.newsletter-form input[type="email"]::placeholder { color: var(--clr-text-muted); }

/* ─── Page hero achtergronden ────────────────────────────────────────────── */
.page-hero__bg--retraite {
    background-image: url('../Images/algemeen/dolfiam-boardwalk-537113.webp');
    background-image: image-set(url('../Images/algemeen/dolfiam-boardwalk-537113.webp') type('image/webp'), url('../Images/algemeen/dolfiam-boardwalk-537113.jpg') type('image/jpeg'));
    background-position: center 50%;
}

.page-hero__bg--loopbaancheque {
    background-image: url('../Images/algemeen/raychy13-summer-8848728.webp');
    background-image: image-set(url('../Images/algemeen/raychy13-summer-8848728.webp') type('image/webp'), url('../Images/algemeen/raychy13-summer-8848728.jpg') type('image/jpeg'));
    background-position: center 55%;
}

.page-hero__bg--loopbaancoaching {
    background-image: url('../Images/algemeen/dolfiam-boardwalk-537113.webp');
    background-image: image-set(url('../Images/algemeen/dolfiam-boardwalk-537113.webp') type('image/webp'), url('../Images/algemeen/dolfiam-boardwalk-537113.jpg') type('image/jpeg'));
    background-position: center 60%;
}

.page-hero__bg--life-coaching {
    background-image: url('../Images/algemeen/heikiwi-sunlight-8555131.webp');
    background-image: image-set(url('../Images/algemeen/heikiwi-sunlight-8555131.webp') type('image/webp'), url('../Images/algemeen/heikiwi-sunlight-8555131.jpg') type('image/jpeg'));
    background-position: center 50%;
}

.page-hero__bg--ondernemerscoaching {
    background-image: url('../Images/algemeen/marys_fotos-stone-3630617.webp');
    background-image: image-set(url('../Images/algemeen/marys_fotos-stone-3630617.webp') type('image/webp'), url('../Images/algemeen/marys_fotos-stone-3630617.jpg') type('image/jpeg'));
    background-position: center 40%;
}

.page-hero__bg--blog {
    background-image: url('../Images/algemeen/heikiwi-graser-10054053.webp');
    background-image: image-set(url('../Images/algemeen/heikiwi-graser-10054053.webp') type('image/webp'), url('../Images/algemeen/heikiwi-graser-10054053.jpg') type('image/jpeg'));
    background-position: center 50%;
}

/* ─── Lightbox ───────────────────────────────────────────────────────────── */
.lightbox-trigger {
    display: block;
    width: 100%;
    height: 100%;
    cursor: zoom-in;
}

.lightbox-trigger--hidden {
    display: none;
}

.lightbox-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000;
    background: rgba(30, 20, 12, 0.92);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
}

.lightbox-overlay.is-open {
    opacity: 1;
    pointer-events: all;
}

.lightbox-inner {
    position: relative;
    max-width: min(90vw, 1100px);
    max-height: 90vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lightbox-img {
    max-width: 100%;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 0.5rem;
    display: block;
    box-shadow: 0 8px 48px rgba(0, 0, 0, 0.5);
}

.lightbox-btn {
    position: absolute;
    background: rgba(245, 240, 235, 0.15);
    border: 1px solid rgba(245, 240, 235, 0.25);
    color: var(--clr-cream);
    font-size: 1.4rem;
    line-height: 1;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
}

.lightbox-btn:hover { background: rgba(245, 240, 235, 0.28); }

.lightbox-btn--prev  { left: -3.5rem; }
.lightbox-btn--next  { right: -3.5rem; }
.lightbox-btn--close { top: -3rem; right: 0; }

.lightbox-counter {
    position: absolute;
    bottom: -2.25rem;
    left: 50%;
    transform: translateX(-50%);
    font-size: var(--type-label);
    color: rgba(245, 240, 235, 0.55);
    letter-spacing: 0.15em;
    white-space: nowrap;
}

@media (max-width: 600px) {
    .lightbox-btn--prev  { left: 0.25rem; }
    .lightbox-btn--next  { right: 0.25rem; }
    .lightbox-btn--close { top: 0.25rem; right: 0.25rem; }
}

body.lightbox-open { overflow: hidden; }

/* ─── Bedankt pagina ────────────────────────────────────────────────────── */
.thankyou-section {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: var(--clr-cream);
    text-align: center;
    padding: var(--nav-h) 1.5rem 3rem;
}

.thankyou-icon {
    font-size: 2.5rem;
    margin-bottom: 1.5rem;
    line-height: 1;
}

.thankyou-title {
    font-family: var(--font-heading);
    font-size: var(--type-title);
    font-weight: 300;
    color: var(--clr-deep);
    margin-bottom: 1rem;
}

.thankyou-body {
    font-size: var(--type-body);
    color: var(--clr-text-muted);
    line-height: 1.8;
    max-width: 44ch;
    margin: 0 auto 2.5rem;
}

/* ─── Subpagina coaching: dienst-layout (foto + tekst naast elkaar) ─────── */
.dienst-layout {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: clamp(2.5rem, 6vw, 5rem);
    align-items: start;
    width: var(--container-lg);
}

.dienst-layout--reverse { direction: rtl; }
.dienst-layout--reverse > * { direction: ltr; }

.dienst-layout__image {
    border-radius: 1rem;
    overflow: hidden;
    aspect-ratio: 3/4;
}

.dienst-layout__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}

.dienst-layout__content .section__label,
.dienst-layout__content .section__title,
.dienst-layout__content .section__body {
    text-align: left;
    margin-inline: 0;
}

@media (max-width: 780px) {
    .dienst-layout,
    .dienst-layout--reverse {
        grid-template-columns: 1fr;
        direction: ltr;
        width: var(--container-sm);
    }
    .dienst-layout__image { aspect-ratio: 4/3; }
}

/* ─── Subpagina coaching: sfeerfoto breed ────────────────────────────────── */
.sfeer-image {
    width: var(--container-lg);
    border-radius: 1rem;
    overflow: hidden;
    aspect-ratio: 21/7;
}

.sfeer-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 40%;
    display: block;
}

/* ─── Subpagina coaching: duo foto's ────────────────────────────────────── */
.dienst-duo-images {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
    width: var(--container-lg);
}

.dienst-duo-images__item {
    border-radius: 0.75rem;
    overflow: hidden;
    aspect-ratio: 4/3;
}

.dienst-duo-images__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dienst-duo-images__item--quote {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--clr-sage);
    padding: clamp(2rem, 5vw, 3.5rem);
    aspect-ratio: auto;
    min-height: 200px;
}

.dienst-duo-images__item--quote .quote-block {
    margin: 0;
    max-width: 100%;
    border-left: none;
    padding-left: 0;
}

@media (max-width: 600px) {
    .dienst-duo-images { grid-template-columns: 1fr; }
    .sfeer-image { aspect-ratio: 16/7; }
}

/* ─── VDAB badge ─────────────────────────────────────────────────────────── */
.vdab-badge {
    display: block;
    width: clamp(180px, 30%, 280px);
    height: auto;
    margin-top: clamp(1.5rem, 3vh, 2.5rem);
    margin-inline: auto;
    border-radius: 0.375rem;
    opacity: 0.92;
}

.content-section--sage .section__body a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 3px;
    font-weight: 500;
}

.content-section--sage .section__body a:hover {
    opacity: 0.75;
}

/* ─── Utility classes ────────────────────────────────────────────────────── */
.section__body--mt    { margin-top: 1.25rem; }
.section__inner--left { text-align: left; }

.section__inner--left .section__label,
.section__inner--left .section__title,
.section__inner--left .section__body {
    text-align: left;
    margin-inline: 0;
}

/* ─── Subpagina: hero-banner ────────────────────────────────────────────── */
.page-hero {
    min-height: clamp(42vh, 56vh, 68vh);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding: var(--nav-h) clamp(1.25rem, 4vw, 3rem) clamp(3rem, 6vh, 5rem);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.page-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
}

.page-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(100, 70, 50, 0.12) 0%,
        rgba(100, 70, 50, 0.58) 100%
    );
}

.page-hero__content {
    position: relative;
    z-index: 1;
    color: var(--clr-cream);
    max-width: var(--container-md);
}

.page-hero__label {
    font-size: var(--type-label);
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--clr-stone);
    margin-bottom: 1rem;
}

.page-hero__title {
    font-family: var(--font-heading);
    font-size: var(--type-display);
    font-weight: 300;
    line-height: 1.05;
    margin-bottom: 1.25rem;
}

.page-hero__intro {
    font-size: var(--type-lead);
    font-weight: 300;
    opacity: 0.82;
    max-width: 52ch;
    margin-inline: auto;
    line-height: 1.7;
}

/* ─── Subpagina: inhoudsecties ───────────────────────────────────────────── */
.content-section {
    padding: clamp(4rem, 8vh, 7rem) clamp(1.25rem, 4vw, 3rem);
    display: flex;
    flex-direction: column;
    align-items: center;
}

.content-section--cream { background-color: var(--clr-cream); }
.content-section--sand  { background-color: var(--clr-sand);  }
.content-section--sage  { background-color: var(--clr-sage);  }
.content-section--stone { background-color: var(--clr-stone); }
.content-section--deep  { background-color: #7a5540;  }

.content-section--deep .section__label { color: var(--clr-stone); }
.content-section--deep .section__title { color: var(--clr-cream); }
.content-section--deep .section__body  { color: rgba(245, 240, 235, 0.7); }

/* ─── Testimonials ───────────────────────────────────────────────────────── */
.testimonial-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
    gap: clamp(1rem, 2.5vw, 1.5rem);
    margin-top: clamp(1.75rem, 4vh, 3rem);
    width: var(--container-md);
}

.testimonial-card {
    background: rgba(255, 255, 255, 0.08);
    border-radius: 1rem;
    padding: clamp(1.5rem, 3vw, 2rem);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.testimonial-card__quote {
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    font-style: italic;
    font-weight: 300;
    color: var(--clr-cream);
    line-height: 1.55;
    margin-bottom: 1.25rem;
}

.testimonial-card__quote::before { content: '\201C'; }
.testimonial-card__quote::after  { content: '\201D'; }

.testimonial-card__author {
    font-size: var(--type-label);
    color: var(--clr-stone);
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

/* ── Article card link wrapper ──────────────────────────────────────────── */
.article-card-link {
    display: block;
    text-decoration: none;
    color: inherit;
    border-radius: 1rem;
}

.article-card-link--featured {
    grid-column: 1 / -1;
}

.article-card-link--featured .article-card--featured {
    grid-column: unset;
}

.article-card-link:focus-visible {
    outline: 2px solid var(--clr-earth);
    outline-offset: 3px;
}

/* ── Blog post page ─────────────────────────────────────────────────────── */
#post-main {
    background-color: var(--clr-cream);
}

.post-hero {
    padding: clamp(5rem, 10vh, 8rem) 0 clamp(2rem, 5vh, 4rem);
    background: var(--clr-cream);
    text-align: center;
}

.post-hero__label {
    font-size: var(--type-label);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--clr-earth);
    margin-bottom: 1rem;
}

.post-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 300;
    color: var(--clr-deep);
    line-height: 1.15;
    width: var(--container-md);
    margin: 0 auto 1.5rem;
}

.post-hero__excerpt {
    font-size: var(--type-body);
    color: var(--clr-text-muted);
    font-style: italic;
    width: var(--container-md);
    margin: 1rem auto 0;
    line-height: 1.7;
}

.post-hero__meta {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    font-size: var(--type-label);
    color: var(--clr-text-muted);
    letter-spacing: 0.08em;
}

.post-hero__image {
    width: var(--container-lg);
    margin: 0 auto;
    border-radius: 1rem;
    overflow: hidden;
    aspect-ratio: 21/9;
}

.post-hero__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.post-body {
    width: var(--container-md);
    margin: clamp(2.5rem, 5vh, 4rem) auto clamp(4rem, 8vh, 6rem);
    font-size: var(--type-body);
    color: var(--clr-text);
    line-height: 1.9;
}

.post-body h2,
.post-body h3 {
    font-family: var(--font-heading);
    font-weight: 300;
    color: var(--clr-deep);
    margin-top: 2.5rem;
    margin-bottom: 0.75rem;
    line-height: 1.25;
}

.post-body h2 { font-size: var(--type-title); }
.post-body h3 { font-size: var(--type-lead); }

.post-body p { margin-bottom: 1.5rem; }

.post-body a {
    color: var(--clr-earth);
    text-underline-offset: 3px;
}

.post-body a:hover { color: var(--clr-deep); }

.post-body blockquote {
    border-left: 3px solid var(--clr-earth);
    margin: 2rem 0;
    padding: 0.5rem 0 0.5rem 2rem;
    font-style: italic;
    font-family: var(--font-heading);
    font-size: var(--type-lead);
    color: var(--clr-deep);
}

.post-back {
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    font-size: var(--type-label);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--clr-earth);
    text-decoration: none;
    margin-bottom: 3rem;
    transition: gap var(--transition), color var(--transition);
}

.post-back::before { content: '←'; }
.post-back:hover { gap: 0.7em; color: var(--clr-deep); }

/* ── Testimonial carousel ────────────────────────────────────────────────── */
.testimonial-carousel {
    width: 100%;
    margin-top: clamp(1rem, 2vh, 1.5rem);
}

.testimonial-carousel__track-wrapper {
    overflow: hidden;
    border-radius: 1rem;
}

.testimonial-carousel__track {
    display: flex;
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.testimonial-carousel__track > * {
    min-width: 100%;
    box-sizing: border-box;
}

a.testimonial-card {
    display: block;
    cursor: pointer;
    transition: background var(--transition), transform var(--transition);
}
a.testimonial-card:hover {
    background: rgba(255, 255, 255, 0.13);
    transform: translateY(-2px);
}

.testimonial-carousel__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.875rem;
}

.testimonial-carousel__controls {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.testimonial-carousel__btn {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--clr-cream);
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition);
    flex-shrink: 0;
    font-size: 0.8rem;
    line-height: 1;
}
.testimonial-carousel__btn:hover { background: rgba(255, 255, 255, 0.18); }

.testimonial-carousel__dots {
    display: flex;
    gap: 0.4rem;
    align-items: center;
}

.testimonial-carousel__dot {
    width: 0.4rem;
    height: 0.4rem;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.25);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background var(--transition), transform var(--transition);
}
.testimonial-carousel__dot--active {
    background: var(--clr-cream);
    transform: scale(1.35);
}

.testimonial-carousel__link {
    font-size: var(--type-label);
    font-weight: 400;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--clr-stone);
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    transition: gap var(--transition), color var(--transition);
    white-space: nowrap;
}
.testimonial-carousel__link::after { content: '→'; }
.testimonial-carousel__link:hover  { gap: 0.7em; color: var(--clr-cream); }

/* ── Ervaringen pagina: hero achtergrond ─────────────────────────────────── */
.page-hero__bg--ervaringen {
    background-image: url('../Images/algemeen/barbaraalane-soft-1678662.webp');
    background-image: image-set(url('../Images/algemeen/barbaraalane-soft-1678662.webp') type('image/webp'), url('../Images/algemeen/barbaraalane-soft-1678662.jpg') type('image/jpeg'));
    background-position: center 40%;
}

/* ── Ervaringen pagina: review entries ───────────────────────────────────── */
.review-entry {
    width: var(--container-md);
    margin-inline: auto;
    padding-top: clamp(2rem, 4vh, 3.5rem);
    padding-bottom: clamp(2rem, 4vh, 3.5rem);
}

.review-entry + .review-entry {
    border-top: 1px solid var(--clr-stone);
}

.review-entry__label {
    font-size: var(--type-label);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--clr-earth);
    margin-bottom: 0.4rem;
}

.review-entry__name {
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    font-weight: 400;
    color: var(--clr-deep);
    margin-bottom: 1.75rem;
}

.review-entry__quote-mark {
    font-family: var(--font-heading);
    font-size: 5rem;
    line-height: 0.8;
    color: var(--clr-earth);
    opacity: 0.35;
    margin-bottom: 0.5rem;
    display: block;
}

.review-entry__body {
    margin: 0;
    font-size: var(--type-lead);
    font-style: italic;
    font-weight: 300;
    font-family: var(--font-heading);
    color: var(--clr-text);
    line-height: 1.7;
}

.review-entry__body p + p { margin-top: 1.1em; }
