
  @import url('https://fonts.googleapis.com/css?family=Open+Sans:400,700&display=swap');
  @import url('https://fonts.googleapis.com/css?family=Raleway:400,700&display=swap');

  body {
  font-family: 'Open Sans', sans-serif;
  }

  h1, h2, h3, h4, h5, h6 {
  font-family: 'Raleway', sans-serif;
  }

  h1 {
  font-size: 34px;
  }

  h2 {
  font-size: 32px;
  }

  h3 {
  font-size: 26px;
  }

  h4 {
  font-size: 21px;
  }

  h5 {
  font-size: 18px;
  }

  h6 {
  font-size: 16px;
  }

  body {
  font-size: 15px;
  }

  body,
  .product-usps li,
  .stock-message {
  color: #161412;
  }

  h1, h2, h3, h4, h5, h6 {
  color: #161412 !important;
  }

  a,
  .woocommerce ul.products li.product .price,
  .woocommerce .price {
  color: #e3d3c7 !important;
  }

  a:hover,
  .woocommerce ul.products li.product .price,
  .woocommerce .price,
  .product-usps li i,
  .counter {
  color: #dcc8b9 !important;
  }

  .btn,
  .wpcf7-submit,
  .woocommerce span.onsale,
  .woocommerce a.button,
  .woocommerce .button,
  [type="submit"],
  .nf-form-content input[type=submit]
  {
  background: #e3d3c7 !important;
  color: #fff !important;
  }

  .btn:hover,
  .wpcf7-submit:hover,
  .woocommerce span.onsale:hover,
  .woocommerce a.button:hover,
  .woocommerce .button:hover,
  [type="submit"]:hover,
  .nf-form-content input[type=submit]:hover
  {
  background: #dcc8b9 !important;
  color: #fff !important;
  }

  div.social-media ul li a {
  background: #dfcdc0 !important;
  color: #fff !important;
  }

  div.social-media ul li a i {
  color: #fff !important;
  }

  div.social-media ul li a:hover {
  background: #dcc8b9 !important;
  color: #fff !important;
  }
  footer div.social-media ul li a {
  background: #e3d3c7 !important;
  }

  div.phone a.phone, div.email a.email {
  background: #dfcdc0 !important;
  color: #fff !important;
  }

  div.phone a.phone, div.email a.email i {
  color: #fff !important;
  }

  div.phone a.phone:hover, div.email a.email:hover {
  background: #dcc8b9 !important;
  color: #fff !important;
  }

  header button.navbar-toggle {
  color: #dfcdc0;
  border-color: #dfcdc0;
  }

  .woocommerce-info,
  .woocommerce-message {
  border-top-color: #dfcdc0 !important;
  }

  .woocommerce-info::before,
  .woocommerce-message::before {
  color: #dfcdc0 !important;
  }

  .btn,
  .wpcf7-submit,
  .woocommerce span.onsale,
  .woocommerce a.button,
  .woocommerce .button,
  .modal__container,
  .footer-cta-box,
  .rimg,
  [type="submit"] {
  -moz-border-radius: 5px !important;
  -webkit-border-radius: 5px !important;
  border-radius: 5px !important;
  }

  .img-responsive {
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  border-radius: 5px;
  }



  header div.header {
  background-color: rgba(255, 255, 255, .5) !important;
  }
  header .sticky_menu_small div.header {
  background-color: rgb(255, 255, 255) !important;
  }

  @media only screen and (max-width : 992px) {
  header nav.navbar-default {
  background: none !important;
  }
  }





  @media only screen and (min-width : 992px) {
  header > div.wrapper {
  min-height: 1099px;
  }
  header > div.wrapper.above {
  min-height: 1249px;
  }

  header div.header div.holder {
  height: 999px;
  }
  }





  nav.navbar-default, div.navbar-collapse {
  background-color: #dfcdc0; !important;
  }

  @media only screen and (min-width : 992px) {
  
  div.navbar-collapse {
  background: none !important;
  }

  header nav.navbar-default {
  background-color: rgba(223, 205, 192, .5) !important;
  }

  nav.navbar-default div.navbar-collapse ul.navbar-nav>li a:hover {
  background-color: rgba(223, 205, 192, .5) !important;
  -webkit-box-shadow: inset 0 0 0 1000px rgba(255, 255, 255, 0.1);
  -moz-box-shadow: inset 0 0 0 1000px rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 0 0 1000px rgba(255, 255, 255, 0.1);
  }

  header div.header.full-width nav.navbar-default div.navbar-collapse ul.navbar-nav > li > a:hover,
  header div.header.full-width nav.navbar-default div.navbar-collapse ul.navbar-nav > li > a:focus,
  header div.header.full-width nav.navbar-default div.navbar-collapse ul.navbar-nav > li > a:active {
  color: #dfcdc0 !important;
  }
  }


  section.featured div.wrapper {
  margin-top: 60px;
  }





  header div.header {
  text-align: center;
  }

  header div.navbar-collapse ul.navbar-nav li a, .nav .open>a, .nav .open>a:focus, .nav .open>a:hover {
  border-bottom: 1px solid #e3d3c7;
  }

  @media only screen and (min-width : 992px) {
  header div.navbar-collapse ul.navbar-nav li a, header nav.navbar-default div.navbar-collapse ul.navbar-nav li ul.dropdown-menu li.active > a {
  color: #e3d3c7 !important;
  }
  }


  header div.header div.contact i {
  color: #e3d3c7;
  }

  @media only screen and (min-width : 992px) {
  header div.navbar-collapse {
  text-align: center;
  }
  }

  section.featured div.item p,
  section.news div.item p {
  color: #161412 !important;
  }

  section.featured div.item,
  section.news div.item {
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  border-radius: 5px;
  }

  section.partners {
  background: #e3d3c7 !important;
  }

  section.partners img {
  border-radius: 0 !important;
  }

  footer,
  .footer-cta.center:after,
  .author {
  background: #dfcdc0 !important;
  }

  footer div.column > h4 {
  border-bottom: 1px solid #e3d3c7;
  }

  footer div.socket,
  .footer-sticky {
  background: #dcc8b9 !important;
  }


  section.treatments div.items div.item img {
  border-radius: 100% !important;
  }

  .img-circle {
  border-radius: 100% !important;
  }

  section.treatments div.button-wrap {
  background: #9c7694;
  margin-top: 30px;
  }

  section.treatments div.item a {
  color: #161412 !important;
  }

  section.prices table tr td a {
  color: #161412 !important;
  }

  aside div.block.treatments ul li a,
  .woocommerce .widget_product_categories ul li a,
  .woocommerce .widget_product_categories ul li span {
  color: #161412 !important;
  }

  aside div.block.treatments ul li:hover,
  .woocommerce .widget_product_categories ul li:hover {
  background: #dfcdc0;
  }

  @import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500&family=Playfair+Display:ital,wght@0,600;0,700;1,600&display=swap');

:root {
  --color-brand: #dcc8b9;
  --color-brand-light: #f4efeb; 
  --color-brand-dark: #8c7b6f;
  --color-text-main: #2d2a26;
  --color-text-muted: #66605b;
  --color-bg-body: #ffffff;
  --font-heading: 'Playfair Display', serif;
  --font-body: 'Inter', sans-serif;
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 4rem;
  --radius-default: 10px; 
  --radius-pill: 9999px;
  --border-width: 1px;
  --border-color: #e5e5e5;
}

body {
  margin: 0;
  background-color: var(--color-bg-body) !important;
  color: var(--color-text-main) !important;
  font-family: var(--font-body) !important;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

.modal__close {
  background: transparent;
  border: 0;
  color: #fff;
  position: absolute;
  top: 0;
  right: 0;
  background: var(--color-brand-dark);
}

h1, h2, h3 {
  font-family: var(--font-heading) !important;
  font-weight: 700;
  line-height: 1.2;
  margin-top: 0;
  margin-bottom: var(--space-md);
  color: var(--color-text-main) !important;
}

h1 { font-size: 2.5rem !important; }
h2 { font-size: 2rem !important; }
h3 { font-size: 1.5rem !important; }

p {
  margin-top: 0;
  margin-bottom: var(--space-md);
  color: var(--color-text-main) !important;
}


footer, .footer-cta.center::after, .author {
  background: var(--color-text-main) !important;
}

footer div.socket, .footer-sticky {
  background: var(--color-text-main) !important;
}


html {
  font-size: 16px !important;
}
.container {
  width: 100%;
  max-width: 1600px;
}

.container::before {
  display: none;
}


header div.header.full-width nav.navbar-default div.navbar-collapse ul.navbar-nav > li > a {
    color: var(--color-text-main) !important;
    text-transform: uppercase;
  font-size: 14px;
    letter-spacing: var(--space-xs);
  }
header > div.wrapper .container {
  width: 100%;
  max-width: 1600px;
}
header div.header div.wrapper img.logo {
  max-width: 150px;
}
#primary_navigation {
  text-align: right;
}



/* --- Global Button Styles --- */
/* Basis Button */
.btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 24px !important;
  text-decoration: none !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.05em !important;
  border: 1px solid transparent !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  /* Radius staat op 0 in je root, maar hier forceren we gebruik van de var */
  border-radius: var(--radius-default) !important; 
}

/* Primary: Donkere achtergrond (Text Main kleur), lichte tekst */
.btn-primary {
  background-color: var(--color-text-main) !important;
  color: var(--color-bg-body) !important;
  border-color: var(--color-text-main) !important;
}

.btn-primary:hover {
  background-color: var(--color-text-muted) !important;
  border-color: var(--color-text-muted) !important;
}

p:empty {
  display: none;
}

.hero-actions p {
  margin-bottom: 0;
}

/* Outline: Transparant met donkere rand */
.btn-outline {
  background-color: transparent !important;
  color: var(--color-text-main) !important;
  border-color: var(--color-text-main) !important;
}

.btn-outline:hover {
  background-color: var(--color-text-main) !important;
  color: var(--color-bg-body) !important;
}


@media (min-width: 992px) {
  header > div.wrapper {
    min-height: auto;
  }
footer div.socket div.right {
    text-align: left;
  }

header div.header div.holder {
    height: auto;
  }
}

body.home section.intro {
  padding: var(--space-2xl) 0;
}

@media (max-width: 991px) {

html.navbar-open body.mm-fullsize nav.type-fullsize button.navbar-toggle {
  color: var(--color-text-main);
}
header div.header.full-width nav.navbar-default div.navbar-collapse ul.navbar-nav > li > a {
 text-align: left;
}
header div.navbar-collapse ul.navbar-nav li a, .nav .open > a, .nav .open > a:focus, .nav .open > a:hover {
  border-bottom: 0px solid #e3d3c7;
}

.socket {
  padding-bottom: 145px !important;
}

html {
  font-size: 14px !important;
}

  .hero-section > div {
    max-width: 99% !important;
    padding: 0 !important;
}

}



/* --- Global Button Styles --- */
/* Basis Button */
.btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 24px !important;
  text-decoration: none !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.05em !important;
  border: 1px solid transparent !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  /* Radius staat op 0 in je root, maar hier forceren we gebruik van de var */
  border-radius: var(--radius-default) !important; 
}

/* Primary: Donkere achtergrond (Text Main kleur), lichte tekst */
.btn-primary {
  background-color: var(--color-text-main) !important;
  color: var(--color-bg-body) !important;
  border-color: var(--color-text-main) !important;
}

.btn-primary:hover {
  background-color: var(--color-text-muted) !important;
  border-color: var(--color-text-muted) !important;
}

/* Outline: Transparant met donkere rand */
.btn-outline {
  background-color: transparent !important;
  color: var(--color-text-main) !important;
  border-color: var(--color-text-main) !important;
}

.btn-outline:hover {
  background-color: var(--color-text-main) !important;
  color: var(--color-bg-body) !important;
}


/* --- Hero Section Refactored --- */

/* 1. De Section Wrapper */
.hero-section {
  /* Gebruik background body (wit) en brand (beige) */
  background: linear-gradient(110deg, var(--color-bg-body) 35%, var(--color-brand) 100%) !important;
  position: relative !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
}

/* 2. De Container (binnen WP) */
.hero-section > div {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  width: 100% !important;
  margin: 0 auto !important;
  gap: var(--space-xl) !important;
  padding: var(--space-xl) !important;
  align-items: center !important;
}

/* 3. Typography & Styling */
.hero-meta {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--color-brand-dark) !important; /* De donkere beige/bruin */
  margin-bottom: var(--space-md) !important;
  font-weight: 600 !important;
}

.hero-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(3rem, 5vw, 5rem) !important;
  line-height: 1.1 !important;
  color: var(--color-text-main) !important; /* De harde donkere kleur */
  margin-bottom: var(--space-xl) !important;
}

.hero-title-italic {
  font-family: var(--font-heading) !important;
  font-style: italic !important;
  font-weight: 400 !important;
  color: var(--color-text-muted) !important; /* De zachtere grijs/bruin */
/*  margin-left: 0.5em !important;*/
}

.hero-title br {
  display: none;
}

.hero-intro-box {
  border-left: 1px solid var(--color-text-muted) !important;
  padding-left: var(--space-lg) !important;
  margin-left: var(--space-sm) !important;
  max-width: 450px !important;
}

.hero-text {
  font-size: 1.1rem !important;
  color: var(--color-text-muted) !important;
  margin-bottom: var(--space-lg) !important;
}

/* Button Group */
.hero-actions {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-md) !important;
}

/* Image styling */
.hero-image-wrapper {
  position: relative !important;
  height: 100% !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: flex-end !important;
}

.hero-image {
  width: 100% !important;
  max-width: 500px !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
  margin-bottom: -40px !important; 
}

/* Mobiele fix */
@media (max-width: 900px) {
  /* 1. De Section: Voorkom horizontal scroll en fix padding */
  .hero-section {
    background: linear-gradient(180deg, var(--color-bg-body) 0%, var(--color-brand) 100%) !important;
    padding-top: 80px !important;
    padding-bottom: 40px !important;
    height: auto !important;
    min-height: auto !important;
    display: block !important;
    overflow-x: hidden !important; /* De levensredder: hakt alles af wat uitsteekt */
  }

  /* 2. De Container: Reset naar simpele flow */
  .hero-section > div {
    display: flex !important; /* Flex is veiliger dan Grid op mobiel voor 1 kolom */
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 var(--space-lg) !important; /* Minder padding aan zijkant (24px) */
    box-sizing: border-box !important; /* Zorgt dat padding IN de breedte valt */
    gap: var(--space-xl) !important;
  }

  /* 3. Typography fix: Zorg dat lange woorden niet uitsteken */
  .hero-title {
    font-size: 2.75rem !important; /* Iets kleiner voor veiligheid */
    margin-bottom: var(--space-md) !important;
    word-wrap: break-word !important; /* Breekt lange woorden af indien nodig */
  }

  .hero-intro-box {
    border-left: 1px solid var(--color-text-muted) !important;
    padding-left: var(--space-md) !important;
    margin-left: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  
  .hero-text {
    max-width: 100% !important;
  }

  /* 4. Actions: Buttons netjes onder elkaar of naast elkaar als t past */
  .hero-actions {
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
    width: 100% !important;
  }

  /* 5. Image Wrapper: Reset */
  .hero-image-wrapper {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    margin-top: var(--space-md) !important;
    margin-right: 0 !important;
    padding-right: 0 !important;
  }
  
  /* De Foto zelf */
  .hero-image {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin-bottom: 0 !important;
    /* Hier zorgen we dat hij niet van het scherm af kan */
    object-fit: contain !important;
  }
  
  /* Fab knop iets opschuiven zodat hij niet half buiten beeld valt */
  .hero-fab {
    right: 10px !important; /* Iets strakker op de rand */
    bottom: 10px !important;
    width: 50px !important;
    height: 50px !important;
    font-size: 1.2rem !important;
  }
}

/* --- Image Styling (Fixed Aspect Ratio) --- */
.hero-image-wrapper {
  position: relative !important;
  height: 100% !important;
  width: 100% !important;
  display: flex !important;
  justify-content: flex-end !important; /* Plaatst foto rechts */
  align-items: flex-end !important;     /* Plaatst foto onderaan */
}

.hero-image {
  width: 100% !important;
  max-width: none !important;
  aspect-ratio: 1/1.6 !important;
  object-fit: cover !important;
  display: block !important;
  margin-bottom: -40px !important;
  max-height: 500px;
  border-radius: var(--radius-default);
}

/* --- De Afspraken Knop (Floating Action Button) --- */
.hero-fab {
  position: absolute !important;
  bottom: 20px !important; /* Afstand vanaf onderkant foto */
  right: 20px !important;  /* Afstand vanaf rechts */
  
  width: 64px !important;
  height: 64px !important;
  
  /* Donkere kleur (gebruikt je text-main var) */
  background-color: var(--color-text-main) !important; 
  color: var(--color-bg-body) !important;
  
  /* In het design is deze specifiek rond voor contrast */
  border-radius: 50% !important; 
  
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.5rem !important;
  cursor: pointer !important;
  box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important;
  z-index: 20 !important;
  transition: transform 0.2s ease !important;
  text-decoration: none !important; /* Voor als het een <a> tag is */
}

.hero-fab:hover {
  color: var(--color-bg-body) !important;
  transform: scale(1.1) !important;
  background-color: var(--color-text-muted) !important;
}


/* --- Philosophy Section (Corrected Colors) --- */

/* Wrapper voor grid */
.philosophy-wrapper {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: var(--space-2xl) !important;
  align-items: center !important;
  margin: 0 auto !important;
  padding: var(--space-2xl) var(--space-xl) !important;
}

/* --- Visuals --- */
.philosophy-visuals {
  position: relative !important;
  padding-bottom: var(--space-xl) !important; 
  padding-right: var(--space-xl) !important;
}

.philosophy-img-back {
  width: 85% !important;
  aspect-ratio: 4/5 !important;
  position: relative !important;
  z-index: 1 !important;
  margin-left: auto !important;
  filter: grayscale(100%) !important;
}

.philosophy-img-back {
  border-radius: var(--radius-default);
  overflow: hidden;
}

.philosophy-img-front {
  position: absolute !important;
  width: 55% !important;
  aspect-ratio: 1/1 !important;
  bottom: 0 !important;
  left: 0 !important;
  z-index: 2 !important;
  border: 10px solid var(--color-bg-body) !important;
}

.philosophy-img-front {
  border-radius: var(--radius-pill);
  overflow: hidden;
}

.img-cover {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

/* --- Content --- */
.philosophy-content {
  padding-left: var(--space-lg) !important;
}

.philosophy-title {
  font-family: var(--font-heading) !important;
  font-size: 3rem !important;
  line-height: 1.1 !important;
  color: var(--color-text-main) !important; /* Terug naar jouw donkere kleur */
  margin-bottom: var(--space-lg) !important;
}

.philosophy-title-accent {
  font-style: italic !important;
  font-weight: 400 !important;
  color: var(--color-brand-dark) !important; /* Vervangt het goud */
}

.philosophy-label {
  display: block !important;
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--color-brand-dark) !important; /* Accentkleur */
  font-weight: 700 !important;
  margin-bottom: var(--space-md) !important;
}

.philosophy-quote {
  font-family: var(--font-heading) !important;
  font-size: 1.5rem !important;
  line-height: 1.4 !important;
  color: var(--color-text-muted) !important;
  font-style: italic !important;
  margin: 0 0 var(--space-lg) 0 !important;
  border-left: 2px solid var(--color-brand) !important; /* Jouw beige lijn */
  padding-left: var(--space-md) !important;
}

.philosophy-text-body p {
  color: var(--color-text-muted) !important;
  font-size: 1rem !important;
  line-height: 1.7 !important;
  margin-bottom: var(--space-md) !important;
}

/* De link style */
.btn-link {
  display: inline-block !important;
  color: var(--color-text-main) !important; /* Donkere tekst */
  text-decoration: none !important;
  border-bottom: 1px solid currentColor !important;
  padding-bottom: 2px !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
  margin-top: var(--space-md) !important;
  transition: opacity 0.2s !important;
}

.btn-link:hover {
  opacity: 0.7 !important;
}

/* --- Mobile Responsive --- */
@media (max-width: 900px) {
  .philosophy-wrapper {
    grid-template-columns: 1fr !important;
    gap: var(--space-xl) !important;
    padding: var(--space-xl) var(--space-lg) !important;
  }

  .philosophy-visuals {
    width: 100% !important;
    max-width: 400px !important;
    margin: 0 auto !important;
    padding-right: 0 !important; 
  }

  .philosophy-content {
    padding-left: 0 !important;
    text-align: left !important;
  }

  .philosophy-title {
    font-size: 2.5rem !important;
  }
}


/* --- Experience Section (Dark Mode) --- */

.experience-wrapper {
  /* We gebruiken jouw donkere tekstkleur als achtergrond voor dit blok */
  background-color: var(--color-text-main) !important;
  color: var(--color-brand) !important; /* Tekst wordt de beige brand kleur */
  padding: var(--space-2xl) var(--space-xl) !important;
  text-align: center !important;
}

/* Header styling */
.experience-header {
  max-width: 600px !important;
  margin: 0 auto var(--space-2xl) auto !important;
}

.experience-label {
  display: inline-block !important;
  border: 1px solid var(--color-brand-dark) !important;
  padding: 4px 12px !important;
  border-radius: 999px !important; /* Pill shape voor dit labeltje */
  font-size: 0.75rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  color: var(--color-brand) !important;
  margin-bottom: var(--space-lg) !important;
}

.experience-title {
  font-family: var(--font-heading) !important;
  font-size: 2.5rem !important;
  color: #fff !important; /* Witte titel knalt eruit */
  margin-bottom: 0 !important;
}

.experience-title-italic {
  font-family: var(--font-heading) !important;
  font-style: italic !important;
  color: var(--color-brand) !important; /* Beige accent */
}

/* Grid styling */
.experience-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--space-xl) !important;
  margin: 0 auto var(--space-2xl) auto !important;
}

.experience-card {
  padding: var(--space-lg) !important;
  /* Optioneel: subtiele border */
  border-radius: var(--radius-default);
  border: 1px solid rgba(220, 200, 185, 0.1) !important; 
  background: rgba(255, 255, 255, 0.02) !important; /* Heel subtiel glas effect */
}

.experience-number {
  display: block !important;
  font-family: var(--font-heading) !important;
  font-size: 2rem !important;
  color: var(--color-brand-dark) !important; /* Donkerdere beige */
  margin-bottom: var(--space-sm) !important;
  font-style: italic !important;
}

.experience-subtitle {
  font-size: 1.1rem !important;
  color: #fff !important;
  margin-bottom: var(--space-md) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

.experience-text {
  font-size: 0.95rem !important;
  color: rgba(255, 255, 255, 0.7) !important; /* Iets transparant wit voor body */
  line-height: 1.6 !important;
}

/* Footer & Button */
.experience-footer {
  margin-top: var(--space-xl) !important;
}

/* Speciale Inverted Button (Licht op Donker) */
.btn-inverted {
  color: var(--color-brand) !important;
  border-color: var(--color-brand) !important;
  background: transparent !important;
}

.btn-inverted:hover {
  background-color: var(--color-brand) !important;
  color: var(--color-text-main) !important;
}

/* Mobile Responsive */
@media (max-width: 900px) {
  .experience-grid {
    grid-template-columns: 1fr !important; /* Onder elkaar op mobiel */
    gap: var(--space-lg) !important;
  }
  
  .experience-title {
    font-size: 2rem !important;
  }
}



/* --- Treatments Section --- */

.treatments-wrapper {
  padding: var(--space-2xl) var(--space-xl) !important;
  background-color: var(--color-bg-body) !important;
}

/* Header */
.treatments-header {
  text-align: center !important;
  max-width: 600px !important;
  margin: 0 auto var(--space-2xl) auto !important;
}

.treatments-title {
  font-family: var(--font-heading) !important;
  font-size: 2.5rem !important;
  color: var(--color-text-main) !important;
  margin-bottom: var(--space-sm) !important;
}

.treatments-title-italic {
  font-family: var(--font-heading) !important;
  font-style: italic !important;
  color: var(--color-brand-dark) !important;
}

.treatments-intro {
  color: var(--color-text-muted) !important;
  font-size: 1.1rem !important;
}

/* Grid */
.treatments-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--space-xl) !important;
  margin-bottom: var(--space-2xl) !important;
}

/* Card Styling */
.treatment-card {
  display: flex !important;
  flex-direction: column !important;
}

.treatment-image-link {
  display: block !important;
  overflow: hidden !important; /* Nodig voor de zoom animatie */
  margin-bottom: var(--space-md) !important;
}

.treatment-image-wrapper {
  width: 100% !important;
  aspect-ratio: 3/4 !important; /* Staand formaat voor luxe uitstraling */
  background-color: var(--color-brand-light) !important;
  overflow: hidden !important;
  border-radius: var(--radius-default);
}

.treatment-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.4s ease !important;
  display: block !important;
}

/* Hover Effect: Foto zoomt in */
.treatment-card:hover .treatment-image {
  transform: scale(1.05) !important;
}

.treatment-content {
  padding-right: var(--space-md) !important;
}

.treatment-meta {
  font-family: var(--font-body) !important;
  font-size: 0.75rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  color: var(--color-text-muted) !important;
  margin-bottom: var(--space-xs) !important;
  font-weight: 500 !important;
}

.treatment-name {
  font-family: var(--font-heading) !important;
  font-size: 1.5rem !important;
  color: var(--color-text-main) !important;
  margin-bottom: var(--space-sm) !important;
  line-height: 1.2 !important;
}

.treatment-desc {
  font-size: 0.95rem !important;
  color: var(--color-text-muted) !important;
  margin-bottom: var(--space-md) !important;
  line-height: 1.6 !important;
}

/* Linkje onderaan de kaart */
.treatment-link {
  display: inline-block !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  color: var(--color-brand-dark) !important;
  text-decoration: none !important;
  border-bottom: 1px solid transparent !important;
  transition: border-color 0.2s !important;
}

.treatment-link:hover {
  border-bottom-color: currentColor !important;
}

/* Footer Button Center */
.treatments-footer {
  text-align: center !important;
}

/* Mobile Responsive */
@media (max-width: 900px) {
  .treatments-grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-2xl) !important; /* Meer ruimte tussen items op mobiel */
  }

  .treatments-wrapper {
    padding: var(--space-xl) var(--space-lg) !important;
  }
}



/* --- Final CTA Section (Consolidated) --- */

.cta-section {
  padding: var(--space-2xl) var(--space-xl) !important;
  text-align: center !important;
  min-height: 400px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  
  /* Nieuwe properties voor de 'L' decoratie */
  position: relative !important;
  overflow: hidden !important;
  z-index: 1 !important; 
}

/* Het Abstracte Element (De grote L) */
.cta-section::before {
  content: 'L'; 
  position: absolute !important;
  font-family: var(--font-heading) !important;
  font-size: 40rem !important; 
  font-style: italic !important;
  line-height: 0 !important;
  color: #fff !important;
  opacity: 0.15 !important; 
  top: 50% !important;
  left: 10% !important;
  transform: translateY(-50%) rotate(-10deg) !important;
  z-index: -1 !important;
  pointer-events: none !important;
}

.cta-container {
  max-width: 700px !important;
  margin: 0 auto !important;
  
  /* Zorgt dat de tekst bovenop de L ligt */
  position: relative !important;
  z-index: 2 !important;
}

.cta-title {
  font-family: var(--font-heading) !important;
  font-size: 3rem !important;
  line-height: 1.1 !important;
  color: var(--color-text-main) !important;
  margin-bottom: var(--space-lg) !important;
}

.cta-title-italic {
  font-family: var(--font-heading) !important;
  font-style: italic !important;
  color: #fff !important;
}

.cta-text {
  font-size: 1.1rem !important;
  color: var(--color-text-main) !important;
  margin-bottom: var(--space-xl) !important;
  line-height: 1.6 !important;
}

.cta-actions {
  display: flex !important;
  gap: var(--space-md) !important;
  justify-content: center !important;
  margin-bottom: var(--space-lg) !important;
  flex-wrap: wrap !important;
}

/* Kleine aanpassing voor de outline button op deze achtergrond */
.cta-section .btn-outline {
  border-color: var(--color-text-main) !important;
  color: var(--color-text-main) !important;
}

.cta-section .btn-outline:hover {
  background-color: var(--color-text-main) !important;
  color: var(--color-brand) !important;
}

.cta-note {
  font-size: 0.85rem !important;
  color: var(--color-brand-dark) !important;
  font-weight: 500 !important;
}

/* Mobile Responsive */
@media (max-width: 768px) {
  .cta-title {
    font-size: 2.25rem !important;
  }


  
  .cta-actions {
    flex-direction: column !important;
    align-items: center !important;
    gap: var(--space-md) !important;
  }
  
  .cta-section .btn {
    width: 100% !important;
    max-width: 300px !important;
  }
}

footer p {
  color: #fff !important;
}
footer .column img {
  max-width: 260px !important;
  margin-bottom: 2rem;
  filter: invert(1);
}
.footer-cta.text-center.above {
  padding-bottom: 0;
}
footer div.column > h4 {
  border-bottom: 0px solid #7c5a5e;
  padding: 0;
}
div.col-sm-24:nth-child(1) {
  padding-right: var(--space-2xl);
}


.footer-cta.text-center.above {
  background: radial-gradient( circle at 30% 30%, #e8dcd3 0%, var(--color-brand) 60% ) !important;
}


/* --- Treatment Detail Page --- */

.treatment-page {
  margin: 0 auto !important;
  padding: var(--space-2xl) var(--space-xl) !important;
}

/* Header */
.treatment-header {
  max-width: 800px !important;
  margin-bottom: var(--space-2xl) !important;
}

.treatment-category {
  display: inline-block !important;
  font-size: 0.75rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  color: var(--color-brand-dark) !important;
  margin-bottom: var(--space-sm) !important;
  font-weight: 600 !important;
}

.treatment-title {
  font-family: var(--font-heading) !important;
  font-size: 3rem !important;
  color: var(--color-text-main) !important;
  margin-bottom: var(--space-md) !important;
  line-height: 1.1 !important;
}

.treatment-title-italic {
  font-family: var(--font-heading) !important;
  font-style: italic !important;
  color: var(--color-brand-dark) !important;
}

.treatment-lead {
  font-size: 1.25rem !important;
  color: var(--color-text-muted) !important;
  max-width: 600px !important;
  line-height: 1.6 !important;
}

/* Layout Grid */
.treatment-grid {
  display: grid !important;
  grid-template-columns: 2fr 1fr !important; /* 2/3 content, 1/3 sidebar */
  gap: var(--space-2xl) !important;
  align-items: start !important;
}

/* Content Column */
.treatment-visual {
  margin-bottom: var(--space-xl) !important;
  border-radius: var(--radius-default) !important;
  overflow: hidden !important;
}

.treatment-img-main {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16/9 !important;
  object-fit: cover !important;
  display: block !important;
}

.text-block h3, 
.feature-list-wrapper h3 {
  font-family: var(--font-heading) !important;
  font-size: 1.75rem !important;
  color: var(--color-text-main) !important;
  margin-bottom: var(--space-md) !important;
  margin-top: var(--space-lg) !important;
}

.text-block p {
  color: var(--color-text-muted) !important;
  margin-bottom: var(--space-md) !important;
  font-size: 1.05rem !important;
}

/* Feature List (Checkmarks) */
.feature-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 var(--space-xl) 0 !important;
}

.feature-list li {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-md) !important;
  margin-bottom: var(--space-sm) !important;
  color: var(--color-text-main) !important;
  font-weight: 500 !important;
}

.feature-list li i {
  color: var(--color-brand-dark) !important; /* Groen vinkje of goud */
  font-size: 0.9rem !important;
}

/* Specs Box (Duur/Pijn) */
.specs-box {
  background-color: var(--color-brand-light) !important;
  padding: var(--space-lg) !important;
  display: flex !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: var(--space-md) !important;
  border-radius: var(--radius-default);
  border: 1px solid rgba(0,0,0,0.05) !important;
}

.spec-item {
  display: flex !important;
  align-items: center !important;
  gap: var(--space-sm) !important;
  border-radius: var(--radius-default);
  color: var(--color-text-main) !important;
}

.spec-item i {
  color: var(--color-brand-dark) !important;
  font-size: 1.2rem !important;
}

/* --- Sidebar styling --- */
.treatment-sidebar {
  position: sticky !important;
  top: 40px !important; /* Plakt aan bovenkant bij scrollen */
}

/* Promo Card (Actie) */
.promo-card {
  background-color: var(--color-brand) !important; /* Beige achtergrond */
  padding: var(--space-lg) !important;
  margin-bottom: var(--space-lg) !important;
  text-align: center !important;
  border: 1px solid rgba(0,0,0,0.05) !important;
  border-radius: var(--radius-default);
  position: relative !important;
}

.promo-badge {
  position: absolute !important;
  top: -12px !important;
  border-radius: var(--radius-pill);
  left: 50% !important;
  transform: translateX(-50%) !important;
  background-color: #3e1c14 !important; /* Donker contrast */
  color: #fff !important;
  padding: 4px 12px !important;
  text-transform: uppercase !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
}

.promo-title {
  font-family: var(--font-heading) !important;
  font-size: 1.5rem !important;
  margin-bottom: var(--space-xs) !important;
  color: var(--color-text-main) !important;
}

.promo-desc {
  font-size: 0.9rem !important;
  margin-bottom: var(--space-md) !important;
}

.promo-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: var(--space-xs) !important;
  font-size: 0.95rem !important;
  border-bottom: 1px solid rgba(0,0,0,0.05) !important;
  padding-bottom: 4px !important;
}

.price-old {
  text-decoration: line-through !important;
  opacity: 0.6 !important;
  font-size: 0.85rem !important;
}

.price-new {
  font-weight: 700 !important;
  color: #3e1c14 !important;
}

.promo-note {
  font-size: 0.75rem !important;
  margin-top: var(--space-sm) !important;
  font-style: italic !important;
  opacity: 0.7 !important;
  border-radius: var(--radius-default);
}

/* Price Card (Standaard) */
.price-card {
  border: 1px solid var(--border-color) !important;
  padding: var(--space-lg) !important;
  background: #fff !important;
  border-radius: var(--radius-default);
}

.price-card h3 {
  margin-top: 0 !important;
  font-family: var(--font-heading) !important;
  margin-bottom: var(--space-lg) !important;
}

.price-item {
  margin-bottom: var(--space-md) !important;
}

.price-header {
  display: flex !important;
  justify-content: space-between !important;
  font-weight: 700 !important;
  color: var(--color-text-main) !important;
  margin-bottom: 4px !important;
}

.price-desc {
  font-size: 0.85rem !important;
  color: var(--color-text-muted) !important;
  margin: 0 !important;
}

/* Utilities */
.full-width {
  width: 100% !important;
  margin-top: var(--space-md) !important;
}

/* Mobile Responsive */
@media (max-width: 900px) {
  .treatment-grid {
    grid-template-columns: 1fr !important;
  }
  
  .treatment-sidebar {
    position: static !important; /* Niet sticky op mobiel, anders neemt t teveel ruimte in */
    order: -1 !important; /* Zet de prijs/actie BOVEN de tekst op mobiel? Of haal weg als je t onder wilt */
  }

  .specs-box {
    flex-direction: column !important;
  border-radius: var(--radius-default);
    gap: var(--space-sm) !important;
  }
}

section.page {
  padding: 0;
}
.breadcrumbs, .page-header {
  display: none !important;
}




/* --- 1. Global Animations --- */

/* De basis class voor elementen die moeten animeren */
.reveal {
  opacity: 0;
  transform: translateY(30px); /* Ze beginnen 30px lager */
  transition: all 0.8s ease-out; /* Duurt 0.8s, lekker traag/luxe */
  will-change: opacity, transform;
}

/* De class die Javascript toevoegt als het element in beeld komt */
.reveal.active {
  opacity: 1;
  transform: translateY(0);
}

/* Optioneel: Staggered effect (als je meerdere dingen achter elkaar wilt laten opkomen) */
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }

/* --- 2. Global Image Hover (Subtiele Zoom) --- */
/* Zorg dat je afbeeldingen in een div met class 'img-zoom-container' zitten */
.img-zoom-container {
  overflow: hidden !important; /* Zorgt dat de foto niet buiten de randen gaat */
  display: block;
  border-radius: var(--radius-default, 0px); /* Pakt jouw border-radius */
}

.img-zoom-container img {
  transition: transform 0.6s ease-in-out !important;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.img-zoom-container:hover img {
  transform: scale(1.05) !important; /* 5% zoom, heel subtiel */
}

/* --- 3. Floating CTA Buttons (Rechtsonder) --- */
.floating-actions {
  position: fixed !important;
  bottom: 30px !important;
  right: 30px !important;
  z-index: 9999 !important;
  display: flex !important;
  flex-direction: column !important; /* Onder elkaar */
  gap: 15px !important;
  align-items: flex-end !important; /* Rechts uitlijnen */
}

/* De knoppen zelf */
.float-btn {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 12px 20px !important;
  border-radius: 50px !important; /* Pilvorm */
  text-decoration: none !important;
  font-family: var(--font-body) !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
  box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

.float-btn:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.2) !important;
}

/* Stijl voor de Quiz knop (Iets opvallender of juist rustiger?) */
.float-quiz {
  background-color: #fff !important;
  color: var(--color-text-main) !important;
  border: 1px solid rgba(0,0,0,0.05) !important;
}

/* Stijl voor de Afspraak knop (Primary) */
.float-book {
  background-color: var(--color-brand-dark) !important; /* Jouw goud/bruine kleur */
  color: #fff !important;
}

/* Icoontjes in de knop */
.float-btn i {
  font-size: 1.1rem !important;
}

/* Mobiele aanpassing: Knoppen iets kleiner of alleen icoon? 
   Voor nu houden we ze leesbaar. */
@media (max-width: 768px) {
  .floating-actions {
    bottom: 20px !important;
    right: 20px !important;
    gap: 10px !important;
  }
  
  .float-btn {
    padding: 10px 16px !important;
    font-size: 0.8rem !important;
  }
}


footer {
  color: #fff;
  padding-top: var(--space-2xl);
}

header.treatment-header {
  z-index: 0;
}




/* --- Smooth Page Transitions --- */

/* Alleen verbergen als JS ook echt aan staat */
.js-enabled body {
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
}

.js-enabled body.page-loaded {
  opacity: 1;
}




    /* --- De zwevende WhatsApp-knop --- */
    .whatsapp-float {
      position: fixed;          /* blijft op zijn plek bij scrollen */
      bottom: 25px;
      left: 25px;
      width: 60px;
      height: 60px;
      background: #25D366;       /* WhatsApp-groen */
      color: #fff;
      border-radius: 50%;        /* perfect rond */
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 32px;
      text-decoration: none;
      box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
      z-index: 1000;             /* boven andere elementen */
      transition: transform 0.25s ease, box-shadow 0.25s ease;
      animation: pulse 2s infinite;
    }
 
    /* Hover-effect: knop wordt iets groter */
    .whatsapp-float:hover {
      transform: scale(1.1);
      box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
      animation: none;           /* pulse stopt tijdens hover */
    }
