  /* =============================================================== */
  /* PAGE HERO */
  /* =============================================================== */
  .page-hero {
    height: 62vh;
    min-height: 420px;
    position: relative;
    display: flex;
    align-items: flex-end;
    background-image: url('../img/Hero_Image.png');
    background-size: cover;
    background-position: center 30%;
    overflow: hidden;
  }

  .page-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
      to bottom,
      rgba(28,28,26,0.15) 0%,
      rgba(28,28,26,0.7) 100%
    );
  }

  .page-hero-content {
    position: relative;
    padding: 0 5rem 4.5rem;
    animation: fadeUp 0.9s 0.2s ease forwards;
    opacity: 0;
  }

  .page-eyebrow {
    font-size: 0.68rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--sand);
    margin-bottom: 1.2rem;
  }

  .page-hero-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2.8rem, 5.5vw, 4.8rem);
    font-weight: 300;
    line-height: 1.08;
    color: var(--cream);
  }
  .page-hero-title em { font-style: italic; color: var(--sand); }

  /* =============================================================== */
  /* DIENST SECTIES — gedeelde stijl */
  /* =============================================================== */

  /* Reusable helpers */
  .section-eyebrow {
    font-size: 0.68rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--stone);
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
  }
  .section-eyebrow::before {
    content: '';
    display: block;
    width: 2rem;
    height: 1px;
    background: var(--sand);
    flex-shrink: 0;
  }
  .section-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2.2rem, 3.5vw, 3.2rem);
    font-weight: 300;
    line-height: 1.15;
    color: var(--charcoal);
    margin-bottom: 1.75rem;
  }
  .section-title em { font-style: italic; color: var(--accent); }
  .section-body {
    font-size: 0.92rem;
    line-height: 1.9;
    color: var(--stone);
    margin-bottom: 2.5rem;
  }

  .btn-primary {
    display: inline-block;
    font-family: 'Jost', sans-serif;
    font-size: 0.72rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--warm-white);
    background: var(--charcoal);
    padding: 0.9rem 2.2rem;
    transition: background 0.3s;
  }
  .btn-primary:hover { background: var(--accent); }

  /* ---- DIENST BLOK ---- */
  .dienst {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 580px;
    position: relative;
    overflow: hidden;
  }

  /* Alternerend: even sectie heeft afbeelding rechts */
  .dienst.reverse { direction: rtl; }
  .dienst.reverse > * { direction: ltr; }

  .dienst-visual {
    position: relative;
    overflow: hidden;
    background: var(--charcoal);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 500px;
  }

  /* Groot watermark-getal — het signature element van deze pagina */
  .dienst-watermark {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(14rem, 22vw, 22rem);
    font-weight: 300;
    font-style: italic;
    color: rgba(255,255,255,0.04);
    line-height: 1;
    position: absolute;
    bottom: -2rem;
    right: -1.5rem;
    pointer-events: none;
    user-select: none;
  }

  /* Placeholder vierkant — vervang door <img> */
  .dienst-photo-placeholder {
    width: 58%;
    aspect-ratio: 4/5;
    background: var(--sand);
    opacity: 0.18;
    position: relative;
    z-index: 1;
  }
  .dienst-photo-placeholder::after {
    content: '';
    position: absolute;
    inset: 1.2rem;
    border: 1px solid rgba(201,184,154,0.4);
  }

  .dienst-content {
    padding: 6rem 5rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: var(--warm-white);
    position: relative;
  }

  /* Afwisselende achtergrond voor visueel ritme */
  .dienst:nth-child(even) .dienst-content { background: var(--cream); }
  .dienst:nth-child(even) .section-eyebrow { color: var(--stone); }

  /* Bullet-lijst met kenmerken */
  .dienst-features {
    list-style: none;
    margin-bottom: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }

  .dienst-features li {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    font-size: 0.88rem;
    line-height: 1.65;
    color: var(--stone);
  }

  .dienst-features li::before {
    content: '';
    display: block;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--sand);
    margin-top: 0.58rem;
    flex-shrink: 0;
  }

  /* =============================================================== */
  /* WERKPROCES */
  /* =============================================================== */
  .process {
    padding: 7rem 5rem;
    background: var(--charcoal);
  }

  .process-header {
    margin-bottom: 5rem;
    max-width: 580px;
  }

  .process-header .section-eyebrow { color: var(--stone); }
  .process-header .section-title   { color: var(--cream); }
  .process-header .section-title em { color: var(--sand); }
  .process-header .section-body    { color: rgba(245,240,232,0.55); margin-bottom: 0; }

  .process-steps {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    position: relative;
  }

  /* Verbindingslijn */
  .process-steps::before {
    content: '';
    position: absolute;
    top: 1.55rem;
    left: 2.5rem;
    right: 2.5rem;
    height: 1px;
    background: rgba(255,255,255,0.1);
  }

  .process-step {
    padding: 0 2rem 0 0;
    position: relative;
  }

  .process-step-dot {
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 50%;
    background: var(--sand);
    margin-bottom: 2rem;
    position: relative;
    z-index: 1;
  }

  .process-step-label {
    font-size: 0.65rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--sand);
    margin-bottom: 0.6rem;
    opacity: 0.7;
  }

  .process-step-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem;
    font-weight: 400;
    color: var(--cream);
    font-style: italic;
    margin-bottom: 0.7rem;
    line-height: 1.2;
  }

  .process-step-desc {
    font-size: 0.8rem;
    line-height: 1.75;
    color: rgba(245,240,232,0.5);
  }

  /* =============================================================== */
  /* FAQ ACCORDION */
  /* =============================================================== */
  .faq {
    padding: 7rem 5rem;
    background: var(--cream);
  }

  .faq-inner {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 5rem;
    align-items: start;
  }

  .faq-aside {
    position: sticky;
    top: 5rem;
  }

  .faq-aside .section-title { margin-bottom: 1rem; }
  .faq-aside .section-body  { margin-bottom: 0; }

  .faq-list {
    display: flex;
    flex-direction: column;
  }

  .faq-item {
    border-top: 1px solid var(--light-border2);
  }
  .faq-item:last-child { border-bottom: 1px solid var(--light-border2); }

  .faq-question {
    width: 100%;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.6rem 0;
    text-align: left;
    gap: 1.5rem;
  }

  .faq-question-text {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    font-weight: 400;
    color: var(--charcoal);
    line-height: 1.3;
  }

  .faq-icon {
    flex-shrink: 0;
    width: 1.4rem;
    height: 1.4rem;
    position: relative;
    color: var(--sand);
  }
  .faq-icon::before,
  .faq-icon::after {
    content: '';
    position: absolute;
    background: currentColor;
    transition: transform 0.35s ease, opacity 0.35s ease;
  }
  .faq-icon::before { width: 100%; height: 1px; top: 50%; left: 0; transform: translateY(-50%); }
  .faq-icon::after  { width: 1px; height: 100%; left: 50%; top: 0; transform: translateX(-50%); }

  .faq-item.open .faq-icon::after { transform: translateX(-50%) rotate(90deg); opacity: 0; }

  .faq-answer {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.38s ease;
  }
  .faq-item.open .faq-answer { grid-template-rows: 1fr; }

  .faq-answer-inner {
    overflow: hidden;
  }

  .faq-answer-text {
    padding-bottom: 1.6rem;
    font-size: 0.88rem;
    line-height: 1.85;
    color: var(--stone);
  }

  /* =============================================================== */
  /* TABLET (max 1024px) */
  /* =============================================================== */
  @media (max-width: 1024px) {
    .page-hero-content { padding: 0 3rem 3.5rem; }

    .diensten-nav-link { padding: 1.1rem 1rem; }
    .diensten-nav-num  { display: none; }

    .dienst { grid-template-columns: 1fr; direction: ltr; }
    .dienst.reverse { direction: ltr; }
    .dienst-visual { min-height: 320px; }
    .dienst-watermark { font-size: 12rem; }
    .dienst-content { padding: 4.5rem 3rem; }

    .process { padding: 5rem 3rem; }
    .process-steps { grid-template-columns: 1fr 1fr; gap: 3rem 2rem; }
    .process-steps::before { display: none; }

    .faq { padding: 5rem 3rem; }
    .faq-inner { grid-template-columns: 1fr; gap: 3rem; }
    .faq-aside { position: static; }
  }

  /* =============================================================== */
  /* MOBIEL (max 768px) */
  /* =============================================================== */
  @media (max-width: 768px) {
    .page-hero { height: 55dvh; min-height: 360px; }
    .page-hero-content { padding: 0 1.5rem 3rem; }

    .diensten-nav-inner { flex-direction: column; }
    .diensten-nav-link  {
      justify-content: flex-start;
      border-right: none;
      border-bottom: 1px solid rgba(255,255,255,0.07);
      padding: 1rem 1.5rem;
    }
    .diensten-nav-link:last-child { border-bottom: none; }

    .dienst-content { padding: 3.5rem 1.5rem; }
    .dienst-watermark { font-size: 8rem; }

    .process { padding: 4rem 1.5rem; }
    .process-steps { grid-template-columns: 1fr; gap: 2.5rem; }

    .faq { padding: 4rem 1.5rem; }
  }