/*
Theme Name: De Haarwerk Salon
Theme URI: https://haarwerksalon.com
Author: Studio Levant
Author URI: https://studio-levant.nl
Description:  WordPress thema voor De Haarwerk Salon — haarwerken met persoonlijke aandacht.
Version: 1.0.4
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: dehaarwerksalon
Tags: one-column, custom-menu, featured-images, translation-ready
*/

/* ==========================================================================
   Inter + Butler Font Face
   ========================================================================== */

@font-face {
  font-family: 'Inter';
  src: url('assets/fonts/Inter-Latin-Variable.woff2') format('woff2');
  font-weight: 300 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Butler';
  src: url('assets/fonts/Butler_Regular.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Butler';
  src: url('assets/fonts/Butler_Medium.otf') format('opentype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Butler';
  src: url('assets/fonts/Butler_Bold.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ==========================================================================
   CSS Custom Properties (Design Tokens)
   ========================================================================== */

:root {
  /* Primary - warm rose/mauve */
  --color-primary-50: #f8f6f4;
  --color-primary-100: #eeebe6;
  --color-primary-200: #dcd6cc;
  --color-primary-300: #bdb0a0;
  --color-primary-400: #ad9b8a;
  --color-primary-500: #9d8672;
  --color-primary-600: #907766;
  --color-primary-700: #786156;
  --color-primary-800: #635149;
  --color-primary-900: #51433d;
  --color-primary-950: #2b221f;

  /* Neutral - warm gray */
  --color-neutral-50: #fafaf9;
  --color-neutral-100: #f5f5f4;
  --color-neutral-200: #e7e5e4;
  --color-neutral-300: #d6d3d1;
  --color-neutral-400: #a8a29e;
  --color-neutral-500: #78716c;
  --color-neutral-600: #57534e;
  --color-neutral-700: #44403c;
  --color-neutral-800: #292524;
  --color-neutral-900: #1c1917;
  --color-neutral-950: #0c0a09;

  /* Accent - soft gold */
  --color-accent-500: #d4a574;
  --color-accent-600: #b8956a;

  /* Semantic */
  --color-background: #BDB0A0;
  --color-section-bg: #ede9e4;
  --color-foreground: var(--color-neutral-900);

  /* Typography */
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --font-serif: 'Butler', serif;

  /* Layout */
  --container-max: 1400px;
  --container-px: 1rem;
  --container-px-sm: 1.5rem;
  --container-px-lg: 2rem;
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */

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

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

body {
  background-color: var(--color-background);
  color: var(--color-foreground);
  font-family: var(--font-sans);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  overflow-x: hidden;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
  position: relative;
  display: inline-block;
}

a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform 0.45s ease;
}

a:hover::after,
a:focus-visible::after {
  transform: scaleX(1);
  transform-origin: left center;
}

/* Exclude button/card/icon-only anchors from generic underline */
.btn-primary::after,
.btn-outline::after,
.header-logo::after,
.header-contact-btn::after,
.mobile-menu-cta>a:first-child::after,
.action-card::after,
.contact-mini-card::after,
.footer-contact-item::after {
  display: none;
}

/* Footer contact links: underline only the text, not the full row */
a.footer-contact-item>span {
  position: relative;
  display: inline-block;
}

a.footer-contact-item>span::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform 0.45s ease;
}

a.footer-contact-item:hover>span::after,
a.footer-contact-item:focus-visible>span::after {
  transform: scaleX(1);
  transform-origin: left center;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font: inherit;
  color: inherit;
}

ul,
ol {
  list-style: none;
}

:focus-visible {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 2px;
}

::selection {
  background-color: var(--color-primary-200);
  color: var(--color-primary-900);
}

::-moz-selection {
  background-color: var(--color-primary-200);
  color: var(--color-primary-900);
}

/* ==========================================================================
   Layout
   ========================================================================== */

.container {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: var(--container-max);
  padding-left: var(--container-px);
  padding-right: var(--container-px);
}

@media (min-width: 640px) {
  .container {
    padding-left: var(--container-px-sm);
    padding-right: var(--container-px-sm);
  }
}

@media (min-width: 1024px) {
  .container {
    padding-left: var(--container-px-lg);
    padding-right: var(--container-px-lg);
  }
}

/* ==========================================================================
   Animations
   ========================================================================== */

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInScale {
  from {
    opacity: 0;
    transform: scale(0.95);
  }

  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.animate-fade-in-down {
  animation: fadeInDown 0.8s ease-out forwards;
}

.animate-fade-in-up {
  animation: fadeInUp 0.8s ease-out forwards;
}

.animate-fade-in-scale {
  animation: fadeInScale 1s ease-out forwards;
}

.animate-fade-in {
  animation: fadeIn 0.6s ease-out forwards;
}

.animation-delay-100 {
  animation-delay: 100ms;
}

.animation-delay-200 {
  animation-delay: 200ms;
}

.animation-delay-300 {
  animation-delay: 300ms;
}

.animation-delay-400 {
  animation-delay: 400ms;
}

.animation-delay-500 {
  animation-delay: 500ms;
}

.animation-delay-600 {
  animation-delay: 600ms;
}

.animation-delay-700 {
  animation-delay: 700ms;
}

.animation-delay-800 {
  animation-delay: 800ms;
}

.opacity-0-initial {
  opacity: 0;
}

/* IntersectionObserver reveal */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}

.reveal.revealed {
  opacity: 1;
  transform: translateY(0);
}

.reveal-left {
  opacity: 0;
  transform: translateX(-48px);
  transition: opacity 1s ease-out, transform 1s ease-out;
}

.reveal-left.revealed {
  opacity: 1;
  transform: translateX(0);
}

.reveal-right {
  opacity: 0;
  transform: translateX(48px);
  transition: opacity 1s ease-out, transform 1s ease-out;
}

.reveal-right.revealed {
  opacity: 1;
  transform: translateX(0);
}

/* ==========================================================================
   Header
   ========================================================================== */

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  background: transparent;
  transition: all 0.3s ease;
}

.site-header.scrolled {
  background: rgba(237, 233, 228, 0.95);
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.site-header.menu-open {
  background: #ede9e4;
  transition: none;
}

.site-header.menu-open.scrolled {
  background: #ede9e4;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.header-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-width: 0;
}

.header-logo {
  display: flex;
  align-items: center;
  min-width: 0;
  flex: 1 1 auto;
}

.header-logo-wrap {
  position: relative;
  height: 4rem;
  width: 200px;
}

.header-logo-wrap img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left center;
}

@media (min-width: 768px) {
  .header-logo-wrap {
    height: 5rem;
    width: 250px;
  }
}

/* Desktop nav */
.desktop-nav {
  display: none;
  align-items: center;
  gap: 2rem;
}

@media (min-width: 768px) {
  .desktop-nav {
    display: flex;
  }
}

.desktop-nav a {
  font-size: 0.875rem;
  font-weight: 500;
  font-family: var(--font-sans);
  color: var(--color-neutral-600);
  transition: color 0.2s;
}

.desktop-nav a:hover {
  color: var(--color-neutral-900);
}

/* Contact button */
.header-contact-btn {
  display: none;
  align-items: center;
  gap: 0.5rem;
  border-radius: 9999px;
  border: 1px solid var(--color-neutral-200);
  background: white;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  font-family: var(--font-sans);
  color: var(--color-neutral-800);
}

@media (min-width: 768px) {
  .header-contact-btn {
    display: inline-flex;
  }
}

.header-contact-btn:hover {
  border-color: var(--color-neutral-300);
}

.header-contact-btn svg {
  width: 1rem;
  height: 1rem;
  transition: transform 0.2s;
}

.header-contact-btn:hover svg {
  transform: translateX(2px);
}

/* Hamburger */
.hamburger {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 3rem;
  height: 3rem;
  position: relative;
  z-index: 120;
  flex: 0 0 auto;
}

@media (min-width: 768px) {
  .hamburger {
    display: none;
  }
}

.hamburger span {
  display: block;
  height: 2px;
  width: 24px;
  background: var(--color-neutral-900);
  transition: all 0.2s;
}

.hamburger.open span:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}

.hamburger.open span:nth-child(2) {
  opacity: 0;
}

.hamburger.open span:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  top: 104px;
  z-index: 40;
  pointer-events: none;
  width: 100%;
  max-width: 100vw;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  background: rgba(28, 25, 23, 0.08);
  transition: opacity 0.18s ease, visibility 0s linear 0.28s;
  contain: layout paint;
}

@media (min-width: 768px) {
  .mobile-menu {
    display: none;
  }
}

.mobile-menu-inner {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  background: #ede9e4;
  transform: translate3d(100%, 0, 0);
  transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
  backface-visibility: hidden;
  display: flex;
  flex-direction: column;
  width: min(100%, 28rem);
  max-width: 100vw;
  box-shadow: -20px 0 40px rgba(28, 25, 23, 0.14);
}

.mobile-menu.open {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.18s ease;
}

.mobile-menu.open .mobile-menu-inner {
  transform: translate3d(0, 0, 0);
}

.mobile-menu nav {
  flex: 1;
  overflow-y: auto;
  padding: 2rem 1.5rem 0;
  overscroll-behavior: contain;
}

.mobile-menu-item {
  border-bottom: 1px solid rgba(231, 229, 228, 0.5);
}

.mobile-menu-item a,
.mobile-menu-item span {
  display: block;
  padding: 1.25rem 0;
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--color-neutral-900);
}

.mobile-menu-cta {
  border-top: 1px solid rgba(231, 229, 228, 0.6);
  padding: 1.25rem 1.5rem;
}

.mobile-menu-cta>a:first-child {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  border-radius: 9999px;
  background: var(--color-neutral-900);
  padding: 0.875rem;
  font-size: 1rem;
  font-weight: 500;
  font-family: var(--font-sans);
  color: white;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
}

.mobile-menu-cta p {
  margin-top: 1rem;
  text-align: center;
  font-size: 0.875rem;
  color: var(--color-neutral-500);
}

.mobile-menu-cta p a {
  display: inline;
  color: var(--color-primary-600);
  background: none;
  padding: 0;
  border-radius: 0;
  justify-content: initial;
  width: auto;
  font-weight: normal;
}

@media (max-width: 767px) {
  .reveal-left,
  .reveal-right {
    transform: translateY(24px);
  }

  .site-header {
    width: 100%;
    max-width: 100vw;
    overflow-x: clip;
  }

  .site-header .container {
    max-width: 100%;
  }

  .header-logo-wrap {
    width: min(200px, calc(100vw - 7rem));
    max-width: 100%;
  }
}

/* ==========================================================================
   Shared Button Styles
   ========================================================================== */

.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border-radius: 9999px;
  border: 1px solid var(--color-neutral-200);
  background: white;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-neutral-800);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

@media (min-width: 768px) {
  .btn-primary {
    padding: 0.875rem 1.5rem;
    gap: 0.75rem;
  }
}

.btn-primary:hover {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.btn-primary .btn-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 9999px;
  background: var(--color-neutral-100);
  transition: background 0.2s;
}

@media (min-width: 768px) {
  .btn-primary .btn-icon {
    width: 2rem;
    height: 2rem;
  }
}

.btn-primary:hover .btn-icon {
  background: var(--color-primary-100);
}

.btn-primary .btn-icon svg {
  width: 0.875rem;
  height: 0.875rem;
}

@media (min-width: 768px) {
  .btn-primary .btn-icon svg {
    width: 1rem;
    height: 1rem;
  }
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border-radius: 9999px;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-neutral-600);
  border: 1px solid var(--color-primary-200);
  background: rgba(255, 255, 255, 0.65);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

@media (min-width: 768px) {
  .btn-outline {
    padding: 0.875rem 1.5rem;
  }
}

.btn-outline:hover {
  color: var(--color-neutral-900);
  background: rgba(255, 255, 255, 0.9);
}

/* Homepage hero secondary button should stay transparent */
.hero .btn-outline {
  background: transparent;
  box-shadow: none;
}

.hero .btn-outline:hover,
.hero .btn-outline:focus-visible {
  background: transparent;
}

/* Consistent button interaction across all pages */
.btn-primary,
.btn-outline,
.header-contact-btn,
.mobile-menu-cta>a:first-child {
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease;
  will-change: transform;
}

.btn-primary:hover,
.btn-primary:focus-visible,
.btn-outline:hover,
.btn-outline:focus-visible,
.header-contact-btn:hover,
.header-contact-btn:focus-visible,
.mobile-menu-cta>a:first-child:hover,
.mobile-menu-cta>a:first-child:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 12px 20px -14px rgba(0, 0, 0, 0.45);
}

.btn-primary:active,
.btn-outline:active,
.header-contact-btn:active,
.mobile-menu-cta>a:first-child:active {
  transform: translateY(0);
  box-shadow: 0 3px 8px -6px rgba(0, 0, 0, 0.35);
}

.btn-primary:focus-visible,
.btn-outline:focus-visible,
.header-contact-btn:focus-visible,
.mobile-menu-cta>a:first-child:focus-visible {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 3px;
}

/* ==========================================================================
   Hero Section
   ========================================================================== */

.hero {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: var(--color-section-bg);
  padding-top: 6rem;
  padding-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .hero {
    padding-top: 7rem;
  }
}

.hero .container {
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: center;
  padding-bottom: 1.5rem;
}

.hero-grid {
  display: grid;
  align-items: center;
  gap: 2rem;
  padding: 2rem 0;
}

@media (min-width: 768px) {
  .hero-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }
}

.hero-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.hero-tagline {
  margin-bottom: 1.25rem;
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-neutral-600);
}

@media (min-width: 640px) {
  .hero-tagline {
    gap: 0.75rem;
    font-size: 0.9rem;
    letter-spacing: 0.2em;
  }
}

.hero-tagline .line {
  display: flex;
  height: 1px;
  width: 2rem;
  background: rgba(120, 97, 86, 0.7);
}

.hero-tagline .accent {
  color: var(--color-primary-700);
}

.hero h1 {
  margin-bottom: 1.5rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 640px) {
  .hero h1 {
    font-size: 2.25rem;
  }
}

@media (min-width: 768px) {
  .hero h1 {
    font-size: 3rem;
  }
}

@media (min-width: 1024px) {
  .hero h1 {
    font-size: 3.3rem;
  }
}

.hero h1 span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.hero h1 .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.hero-description {
  margin-bottom: 2rem;
  max-width: 28rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-500);
}

.hero-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Hero Image */
.hero-image {
  position: relative;
  display: flex;
  height: 100%;
  align-items: center;
  justify-content: flex-end;
}

.hero-image-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: 1rem;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

@media (min-width: 768px) {
  .hero-image-wrapper {
    width: 88%;
  }
}

.hero-image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right;
}

/* Stats Bar */
.hero-stats-wrapper {
  margin-top: auto;
  padding-top: 2rem;
}

.hero-stats {
  border-radius: 1rem;
  background: white;
  padding: 1.5rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

@media (min-width: 768px) {
  .hero-stats {
    padding: 2rem 3rem;
  }
}

.hero-stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  align-items: center;
}

@media (min-width: 640px) {
  .hero-stats-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 768px) {
  .hero-stats-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 2.5rem;
  }
}

.stat-item {
  text-align: center;
}

@media (min-width: 768px) {
  .stat-item {
    text-align: left;
  }
}

.stat-value {
  font-family: var(--font-serif);
  font-weight: 400;
  font-style: italic;
  color: var(--color-neutral-800);
  font-size: 1.875rem;
}

.stat-value.long {
  font-size: 1.5rem;
}

@media (min-width: 768px) {
  .stat-value {
    font-size: 3rem;
  }

  .stat-value.long {
    font-size: 3rem;
  }
}

.stat-value .suffix {
  font-size: 1.25rem;
  color: var(--color-neutral-400);
}

@media (min-width: 768px) {
  .stat-value .suffix {
    font-size: 1.875rem;
  }
}

.stat-label {
  margin-top: 0.25rem;
  font-size: 0.75rem;
  color: var(--color-neutral-500);
}

@media (min-width: 768px) {
  .stat-label {
    font-size: 0.875rem;
  }
}

.stat-description {
  grid-column: 1 / -1;
  margin-top: 0.5rem;
  border-top: 1px solid var(--color-neutral-100);
  padding-top: 1rem;
  text-align: center;
}

@media (min-width: 640px) {
  .stat-description {
    grid-column: 1 / -1;
  }
}

@media (min-width: 768px) {
  .stat-description {
    grid-column: auto;
    margin-top: 0;
    border-top: none;
    border-left: 1px solid var(--color-neutral-100);
    padding-top: 0;
    padding-left: 2.5rem;
    text-align: left;
  }
}

.stat-description p {
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

.stat-description a {
  display: inline-block;
  margin-top: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-neutral-800);
  transition: color 0.2s;
}

@media (min-width: 768px) {
  .stat-description a {
    margin-top: 0.75rem;
    text-align: left;
  }
}

.stat-description a:hover {
  color: var(--color-primary-500);
}

/* ==========================================================================
   About Section
   ========================================================================== */

.about {
  background: var(--color-section-bg);
  padding: 4rem 0;
  overflow: hidden;
}

@media (min-width: 768px) {
  .about {
    padding: 6rem 0;
  }
}

.about-grid {
  display: grid;
  gap: 1.5rem;
  align-items: center;
}

@media (min-width: 1024px) {
  .about-grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
}

.about-image-col {
  position: relative;
}

.about-image-wrapper {
  position: relative;
  max-width: 28rem;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: 1rem;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.about-image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Section headings shared pattern */
.section-heading {
  margin-bottom: 1rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .section-heading {
    margin-bottom: 1.5rem;
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .section-heading {
    font-size: 3rem;
  }
}

.section-heading span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.section-heading .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.section-subtitle {
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .section-subtitle {
    font-size: 1.125rem;
  }
}

/* About content */
.about-content p {
  margin-bottom: 1rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .about-content p {
    margin-bottom: 1.5rem;
    font-size: 1.125rem;
  }
}

.about-content .btn-primary {
  margin-top: 0.5rem;
}

/* Features Grid (below About) */
.features-grid {
  margin-top: 4rem;
  display: grid;
  gap: 2rem;
}

@media (min-width: 768px) {
  .features-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.feature-card {
  border-radius: 1rem;
  background: white;
  padding: 2rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.feature-card h3 {
  margin-bottom: 0.75rem;
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.25rem;
  color: var(--color-neutral-900);
}

.feature-card p {
  color: var(--color-neutral-600);
  line-height: 1.625;
}

/* ==========================================================================
   Services Section
   ========================================================================== */

.services {
  background: var(--color-section-bg);
  padding: 4rem 0;
}

@media (min-width: 768px) {
  .services {
    padding: 6rem 0;
  }
}

.services-header {
  margin-bottom: 5rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

@media (min-width: 768px) {
  .services-header {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
  }
}

.services-header .section-intro {
  max-width: 36rem;
}

.seo-topic-cluster .services-header,
.seo-related-links .services-header {
  margin-bottom: 2.5rem;
}

.services-grid {
  display: grid;
  gap: 3rem;
}

@media (min-width: 768px) {
  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .services-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.service-card .service-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  border-radius: 9999px;
  background: rgba(220, 214, 204, 0.6);
  color: var(--color-primary-700);
  margin-bottom: 1.5rem;
  transition: all 0.3s;
}

.service-card:hover .service-icon {
  transform: scale(1.1);
  background: rgba(189, 176, 160, 0.7);
}

.service-card .service-icon svg {
  width: 1.75rem;
  height: 1.75rem;
}

.service-card h3 {
  margin-bottom: 0.75rem;
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--color-neutral-900);
}

.service-card p {
  color: var(--color-neutral-600);
  line-height: 1.625;
}

/* ==========================================================================
   WhyChooseUs Section
   ========================================================================== */

.why-choose-us {
  background: var(--color-section-bg);
  padding: 4rem 0;
}

@media (min-width: 768px) {
  .why-choose-us {
    padding: 6rem 0;
  }
}

.why-header {
  margin-bottom: 4rem;
  max-width: 36rem;
}

.steps-layout {
  display: grid;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .steps-layout {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
  }
}

.steps-list {
  display: flex;
  flex-direction: column;
  position: relative;
}

/* Step Card */
.step-card {
  position: relative;
}

.step-card-btn {
  width: 100%;
  text-align: left;
  position: relative;
}

.step-card-inner {
  position: relative;
  overflow: hidden;
  border-radius: 1rem;
  padding: 1.5rem;
  transition: all 0.3s;
  background: white;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.step-card-inner:hover {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.step-card.active .step-card-inner {
  background: var(--color-primary-700);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.step-card-watermark {
  position: absolute;
  right: -2rem;
  top: -2rem;
  width: 7rem;
  height: 7rem;
  opacity: 0.15;
  display: none;
}

.step-card.active .step-card-watermark {
  display: block;
}

.step-card-watermark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.step-card-row {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.step-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  flex-shrink: 0;
  border-radius: 9999px;
  background: var(--color-primary-100);
  transition: all 0.3s;
}

.step-card:hover .step-card-icon {
  background: var(--color-primary-200);
}

.step-card.active .step-card-icon {
  background: rgba(255, 255, 255, 0.2);
}

.step-card-icon svg {
  width: 1.75rem;
  height: 1.75rem;
  color: var(--color-primary-700);
  transition: color 0.3s;
}

.step-card.active .step-card-icon svg {
  color: white;
}

.step-card-text {
  flex: 1;
}

.step-card-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-primary-500);
  transition: color 0.3s;
}

.step-card.active .step-card-label {
  color: var(--color-primary-200);
}

.step-card-title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.25rem;
  color: var(--color-neutral-900);
  transition: color 0.3s;
}

.step-card.active .step-card-title {
  color: white;
}

/* Step chevron (mobile) */
.step-card-chevron {
  transition: transform 0.3s;
}

.step-card.active .step-card-chevron {
  transform: rotate(180deg);
}

.step-card-chevron svg {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-primary-500);
}

.step-card.active .step-card-chevron svg {
  color: white;
}

@media (min-width: 1024px) {
  .step-card-chevron {
    display: none;
  }
}

/* Connector line (desktop) */
.step-connector {
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%) scaleX(0);
  transform-origin: left;
  transition: all 0.3s;
  display: none;
}

@media (min-width: 1024px) {
  .step-connector {
    display: block;
  }
}

.step-card.active .step-connector {
  transform: translateY(-50%) scaleX(1);
  opacity: 1;
}

.step-connector-line {
  height: 2px;
  width: 4rem;
  background: var(--color-primary-700);
}

/* Mobile accordion content */
.step-accordion {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: all 0.3s ease-in-out;
}

.step-card.active .step-accordion {
  max-height: 900px;
  opacity: 1;
}

@media (min-width: 1024px) {
  .step-accordion {
    display: none;
  }
}

.step-accordion-inner {
  border-radius: 1rem;
  background: white;
  padding: 1.5rem;
  margin-top: 0.5rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.step-accordion-inner p {
  color: var(--color-neutral-600);
  line-height: 1.625;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

.step-accordion-inner p:last-child {
  margin-bottom: 0;
}

/* Step progress arrow */
.step-arrow {
  display: flex;
  justify-content: center;
  padding: 0.5rem 0;
}

.step-arrow svg {
  width: 1.5rem;
  height: 1.5rem;
  color: var(--color-primary-400);
}

/* Step Content Panel (desktop) */
.step-content-panel {
  display: none;
  position: relative;
}

@media (min-width: 1024px) {
  .step-content-panel {
    display: block;
  }
}

.step-content-card {
  position: relative;
  width: 100%;
  border-radius: 1rem;
  background: white;
  padding: 2rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

@media (min-width: 1024px) {
  .step-content-card {
    padding: 2.5rem;
  }
}

.step-content-card .watermark-icon {
  position: absolute;
  right: 1rem;
  top: 1rem;
  opacity: 0.05;
}

@media (min-width: 1024px) {
  .step-content-card .watermark-icon {
    right: 2rem;
    top: 2rem;
  }
}

.step-content-card .watermark-icon svg {
  width: 8rem;
  height: 8rem;
}

@media (min-width: 1024px) {
  .step-content-card .watermark-icon svg {
    width: 10rem;
    height: 10rem;
  }
}

.step-content-card .step-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-primary-500);
}

.step-content-card h3 {
  margin-bottom: 1.5rem;
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.5rem;
  color: var(--color-primary-700);
}

@media (min-width: 1024px) {
  .step-content-card h3 {
    font-size: 1.875rem;
  }
}

.step-content-card p {
  color: var(--color-neutral-600);
  line-height: 1.625;
  margin-bottom: 1rem;
}

.step-content-card p:last-child {
  margin-bottom: 0;
}

/* CTA centered below steps */
.why-cta {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
}

/* ==========================================================================
   Before/After Section
   ========================================================================== */

.before-after {
  background: var(--color-section-bg);
  padding: 4rem 0;
}

@media (min-width: 768px) {
  .before-after {
    padding: 6rem 0;
  }
}

.before-after-header {
  margin-bottom: 4rem;
  max-width: 36rem;
}

.testimonials-grid {
  display: grid;
  gap: 2rem;
}

@media (min-width: 768px) {
  .testimonials-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Testimonial Card */
.testimonial-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 1rem;
  background: white;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  transition: box-shadow 0.3s;
}

.testimonial-card:hover {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

/* Before/After Slider */
.ba-slider {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  cursor: ew-resize;
  overflow: hidden;
  border-radius: 1rem 1rem 0 0;
  user-select: none;
  -webkit-user-select: none;
}

.ba-slider .ba-after,
.ba-slider .ba-before {
  position: absolute;
  inset: 0;
}

.ba-slider .ba-after {
  background: var(--color-neutral-200);
}

.ba-slider .ba-before {
  background: var(--color-neutral-300);
}

.ba-slider .ba-after img,
.ba-slider .ba-before img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}

.ba-label {
  position: absolute;
  bottom: 1rem;
  border-radius: 9999px;
  padding: 0.25rem 0.75rem;
  font-size: 0.75rem;
  font-weight: 500;
  z-index: 5;
}

.ba-label-after {
  right: 1rem;
  background: var(--color-primary-700);
  color: white;
}

.ba-label-before {
  left: 1rem;
  background: white;
  color: var(--color-neutral-700);
}

/* Slider handle */
.ba-handle {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 10;
  width: 4px;
  transform: translateX(-50%);
  cursor: ew-resize;
  background: white;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.ba-handle-circle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 9999px;
  background: white;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.ba-handle-circle svg {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-primary-700);
}

/* Testimonial content */
.testimonial-content {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 1.5rem;
}

.testimonial-quote-icon {
  margin-bottom: 0.75rem;
  flex-shrink: 0;
}

.testimonial-quote-icon svg {
  width: 2rem;
  height: 2rem;
  color: var(--color-primary-200);
}

.testimonial-quote {
  margin-bottom: 1rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

.testimonial-footer {
  margin-top: auto;
  padding-top: 1rem;
}

.testimonial-stars {
  display: flex;
  gap: 0.25rem;
  margin-bottom: 0.5rem;
}

.testimonial-stars svg {
  width: 1rem;
  height: 1rem;
  color: var(--color-accent-500);
}

.testimonial-name {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 1.125rem;
  color: var(--color-neutral-900);
}

/* ==========================================================================
   Vergoedingen Page
   ========================================================================== */

.vergoedingen-page {
  background: var(--color-section-bg);
}

.vergoedingen-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-section-bg);
  padding-top: 8rem;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .vergoedingen-hero {
    padding-top: 10rem;
    padding-bottom: 5rem;
  }
}

.vergoedingen-breadcrumb {
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-neutral-500);
}

.vergoedingen-breadcrumb a {
  transition: color 0.2s;
}

.vergoedingen-breadcrumb a:hover {
  color: var(--color-neutral-900);
}

.vergoedingen-breadcrumb .is-current {
  color: var(--color-neutral-900);
}

.vergoedingen-heading {
  max-width: 48rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .vergoedingen-heading {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .vergoedingen-heading {
    font-size: 3rem;
  }
}

.vergoedingen-heading span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.vergoedingen-heading .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.vergoedingen-description {
  margin-top: 1rem;
  max-width: 42rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .vergoedingen-description {
    font-size: 1.125rem;
  }
}

.vergoedingen-hero-divider {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(173, 155, 138, 0.85), transparent);
}

.vergoedingen-steps {
  padding-top: 2.5rem;
  padding-bottom: 1rem;
  background: var(--color-section-bg);
}

@media (min-width: 768px) {
  .vergoedingen-steps {
    padding-top: 4rem;
    padding-bottom: 2rem;
  }
}

.vergoedingen-steps-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

@media (min-width: 1024px) {
  .vergoedingen-steps-grid {
    flex-direction: row;
    align-items: stretch;
    gap: 0.75rem;
  }
}

.vergoedingen-step-column {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  flex: 1;
}

@media (min-width: 1024px) {
  .vergoedingen-step-column {
    flex-direction: row;
    align-items: stretch;
    gap: 0.75rem;
  }
}

.vergoedingen-step-card {
  flex: 1;
  height: 100%;
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.8);
  padding: 1.5rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.vergoedingen-step-card .step-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-primary-500);
}

.vergoedingen-step-card h2 {
  margin-top: 0.5rem;
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-neutral-900);
}

.vergoedingen-step-card p {
  margin-top: 0.75rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .vergoedingen-step-card p {
    font-size: 1rem;
  }
}

.vergoedingen-step-card.stagger-ready {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
}

.vergoedingen-step-card.stagger-ready.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: var(--step-delay, 0ms);
}

.flow-arrow-mobile,
.flow-arrow-desktop {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  background: rgba(255, 255, 255, 0.8);
  color: var(--color-primary-500);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.flow-arrow-mobile {
  margin: 0 auto;
  width: 2rem;
  height: 2rem;
}

.flow-arrow-mobile svg {
  width: 1rem;
  height: 1rem;
  transform: rotate(90deg);
}

.flow-arrow-desktop {
  display: none;
}

@media (min-width: 1024px) {
  .flow-arrow-mobile {
    display: none;
  }

  .flow-arrow-desktop {
    display: flex;
    width: 2.5rem;
    height: 2.5rem;
    flex-shrink: 0;
    align-self: center;
  }

  .flow-arrow-desktop svg {
    width: 1.25rem;
    height: 1.25rem;
  }
}

.vergoedingen-details {
  background: var(--color-section-bg);
  padding-top: 1.5rem;
  padding-bottom: 2.5rem;
}

@media (min-width: 768px) {
  .vergoedingen-details {
    padding-top: 2rem;
    padding-bottom: 4rem;
  }
}

.vergoedingen-details-grid {
  display: grid;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .vergoedingen-details-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 3rem;
  }
}

.vergoedingen-card {
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 1.5rem;
  background: rgba(255, 255, 255, 0.8);
  padding: 1.5rem 1rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (min-width: 768px) {
  .vergoedingen-card {
    padding: 2rem;
  }
}

.vergoedingen-card .card-tag {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-primary-600);
}

.vergoedingen-card h3 {
  margin-top: 0.5rem;
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 400;
  color: var(--color-neutral-900);
}

.vergoedingen-card .card-intro {
  margin-top: 0.75rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .vergoedingen-card .card-intro {
    font-size: 1rem;
  }
}

.example-rows {
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.example-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.75rem;
  border-radius: 0.75rem;
  padding: 0.75rem 1rem;
  background: white;
}

.example-row.is-subtotal {
  background: rgba(238, 235, 230, 0.8);
  box-shadow: inset 0 0 0 1px rgba(220, 214, 204, 0.9);
}

.row-sign {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-neutral-500);
}

.row-sign.is-deduction {
  color: var(--color-primary-600);
}

.row-label {
  font-size: 0.875rem;
  color: var(--color-neutral-600);
}

.row-label.is-subtotal {
  font-weight: 600;
  color: var(--color-neutral-900);
}

.row-amount {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-neutral-900);
}

.row-amount.is-deduction {
  color: var(--color-primary-700);
}

.total-row {
  margin-top: 1rem;
  border-radius: 0.75rem;
  background: var(--color-neutral-900);
  color: white;
  padding: 0.75rem 1rem;
}

.total-inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.total-label {
  max-width: 70%;
  font-size: 0.875rem;
  color: var(--color-neutral-200);
}

.total-amount {
  font-weight: 600;
}

.org-grid {
  margin-top: 1.5rem;
  display: grid;
  gap: 0.75rem;
}

@media (min-width: 640px) {
  .org-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.org-card {
  border-radius: 0.75rem;
  border: 1px solid var(--color-neutral-200);
  background: white;
  padding: 1rem;
}

.org-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-neutral-500);
}

.org-value {
  margin-top: 0.25rem;
  font-weight: 500;
  color: var(--color-neutral-900);
}

.complaints-card {
  margin-top: 1.5rem;
  border-radius: 0.75rem;
  border: 1px solid var(--color-neutral-200);
  background: white;
  padding: 1rem;
}

.complaints-card h4 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--color-neutral-900);
}

.complaints-card p {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

.vergoedingen-card.stagger-ready {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
}

.vergoedingen-card.stagger-ready.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: var(--card-delay, 0ms);
}

.vergoedingen-step-card.stagger-ready:not(.is-visible),
.vergoedingen-card.stagger-ready:not(.is-visible),
.oplossingen-highlight-card.stagger-ready:not(.is-visible),
.contact-card.stagger-ready:not(.is-visible),
.ons-team-card.stagger-ready:not(.is-visible),
.action-card.stagger-ready:not(.is-visible),
.footer-reveal.stagger-ready:not(.is-visible) {
  transition: none;
}

/* ==========================================================================
   Oplossingen Page
   ========================================================================== */

.oplossingen-page {
  background: var(--color-section-bg);
}

.oplossingen-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-section-bg);
  padding-top: 8rem;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .oplossingen-hero {
    padding-top: 10rem;
    padding-bottom: 5rem;
  }
}

.oplossingen-breadcrumb {
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-neutral-500);
}

.oplossingen-breadcrumb a {
  transition: color 0.2s;
}

.oplossingen-breadcrumb a:hover {
  color: var(--color-neutral-900);
}

.oplossingen-breadcrumb .is-current {
  color: var(--color-neutral-900);
}

.oplossingen-heading {
  max-width: 48rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .oplossingen-heading {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .oplossingen-heading {
    font-size: 3rem;
  }
}

.oplossingen-heading span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.oplossingen-heading .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.oplossingen-description {
  margin-top: 1rem;
  max-width: 42rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .oplossingen-description {
    font-size: 1.125rem;
  }
}

.oplossingen-hero-divider {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(173, 155, 138, 0.85), transparent);
}

.oplossingen-highlights {
  background: var(--color-section-bg);
  padding-top: 3rem;
  padding-bottom: 2rem;
}

@media (min-width: 768px) {
  .oplossingen-highlights {
    padding-top: 4rem;
    padding-bottom: 3rem;
  }
}

.oplossingen-highlights-grid {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 768px) {
  .oplossingen-highlights-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.oplossingen-highlight-card {
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.75);
  padding: 1.5rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.oplossingen-highlight-card h3 {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-neutral-900);
}

.oplossingen-highlight-card p {
  margin-top: 0.75rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .oplossingen-highlight-card p {
    font-size: 1rem;
  }
}

.oplossingen-highlight-card.stagger-ready {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
}

.oplossingen-highlight-card.stagger-ready.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: var(--highlight-delay, 0ms);
}

.oplossingen-content-section {
  background: var(--color-section-bg);
  padding: 4rem 0;
  overflow: hidden;
}

@media (min-width: 768px) {
  .oplossingen-content-section {
    padding: 6rem 0;
  }
}

.oplossingen-content-grid {
  display: grid;
  align-items: center;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .oplossingen-content-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4rem;
  }
}

@media (min-width: 1024px) {
  .oplossingen-content-grid.is-reversed .oplossingen-content-image {
    order: 2;
  }

  .oplossingen-content-grid.is-reversed .oplossingen-content-text {
    order: 1;
  }
}

.oplossingen-content-media-wrap {
  position: relative;
  max-width: 32rem;
  margin: 0 auto;
}

@media (min-width: 1024px) {
  .oplossingen-content-media-wrap {
    margin: 0;
  }

  .oplossingen-content-media-wrap.is-reversed {
    margin-left: auto;
  }
}

.oplossingen-content-media {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 1rem;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.oplossingen-content-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.oplossingen-content-media-shadow {
  position: absolute;
  right: -1rem;
  bottom: -1rem;
  z-index: -1;
  height: 100%;
  width: 100%;
  border-radius: 1rem;
  background: rgba(220, 214, 204, 0.75);
}

.oplossingen-content-media-wrap.is-reversed .oplossingen-content-media-shadow {
  right: auto;
  left: -1rem;
}

.oplossingen-content-text h2 {
  margin-bottom: 1.5rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .oplossingen-content-text h2 {
    font-size: 2.25rem;
  }
}

.oplossingen-content-text h2 span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.oplossingen-content-text h2 .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.oplossingen-content-text p {
  margin-bottom: 1rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .oplossingen-content-text p {
    font-size: 1.125rem;
  }
}

.oplossingen-content-text p:last-child {
  margin-bottom: 0;
}

.oplossingen-content-text p.is-empty {
  display: none;
}

/* ==========================================================================
   Persoonlijk Advies Page
   ========================================================================== */

.persoonlijk-advies-page {
  background: var(--color-section-bg);
}

.persoonlijk-advies-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-section-bg);
  padding-top: 8rem;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .persoonlijk-advies-hero {
    padding-top: 10rem;
    padding-bottom: 5rem;
  }
}

.persoonlijk-advies-breadcrumb {
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-neutral-500);
}

.persoonlijk-advies-breadcrumb a {
  transition: color 0.2s;
}

.persoonlijk-advies-breadcrumb a:hover {
  color: var(--color-neutral-900);
}

.persoonlijk-advies-breadcrumb .is-current {
  color: var(--color-neutral-900);
}

.persoonlijk-advies-heading {
  max-width: 48rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .persoonlijk-advies-heading {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .persoonlijk-advies-heading {
    font-size: 3rem;
  }
}

.persoonlijk-advies-heading span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.persoonlijk-advies-heading .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.persoonlijk-advies-description {
  margin-top: 1rem;
  max-width: 42rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .persoonlijk-advies-description {
    font-size: 1.125rem;
  }
}

.persoonlijk-advies-hero-divider {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(173, 155, 138, 0.85), transparent);
}

.persoonlijk-advies-content-section {
  background: var(--color-section-bg);
  padding: 4rem 0;
  overflow: hidden;
}

@media (min-width: 768px) {
  .persoonlijk-advies-content-section {
    padding: 6rem 0;
  }
}

.persoonlijk-advies-content-grid {
  display: grid;
  align-items: center;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .persoonlijk-advies-content-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4rem;
  }
}

@media (min-width: 1024px) {
  .persoonlijk-advies-content-grid.is-reversed .persoonlijk-advies-content-image {
    order: 2;
  }

  .persoonlijk-advies-content-grid.is-reversed .persoonlijk-advies-content-text {
    order: 1;
  }
}

.persoonlijk-advies-content-media-wrap {
  position: relative;
  max-width: 32rem;
  margin: 0 auto;
}

@media (min-width: 1024px) {
  .persoonlijk-advies-content-media-wrap {
    margin: 0;
  }

  .persoonlijk-advies-content-media-wrap.is-reversed {
    margin-left: auto;
  }
}

.persoonlijk-advies-content-media {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 1rem;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.persoonlijk-advies-content-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.persoonlijk-advies-content-media-shadow {
  position: absolute;
  right: -1rem;
  bottom: -1rem;
  z-index: -1;
  height: 100%;
  width: 100%;
  border-radius: 1rem;
  background: rgba(220, 214, 204, 0.75);
}

.persoonlijk-advies-content-media-wrap.is-reversed .persoonlijk-advies-content-media-shadow {
  right: auto;
  left: -1rem;
}

.persoonlijk-advies-content-text h2 {
  margin-bottom: 1.5rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .persoonlijk-advies-content-text h2 {
    font-size: 2.25rem;
  }
}

.persoonlijk-advies-content-text h2 span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.persoonlijk-advies-content-text h2 .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.persoonlijk-advies-content-text p {
  margin-bottom: 1rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .persoonlijk-advies-content-text p {
    font-size: 1.125rem;
  }
}

.persoonlijk-advies-content-text p:last-child {
  margin-bottom: 0;
}

.persoonlijk-advies-content-text p.is-empty {
  display: none;
}

/* ==========================================================================
   Ons Team Page
   ========================================================================== */

.ons-team-page {
  background: var(--color-section-bg);
}

.ons-team-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-section-bg);
  padding-top: 8rem;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .ons-team-hero {
    padding-top: 10rem;
    padding-bottom: 5rem;
  }
}

.ons-team-breadcrumb {
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-neutral-500);
}

.ons-team-breadcrumb a {
  transition: color 0.2s;
}

.ons-team-breadcrumb a:hover {
  color: var(--color-neutral-900);
}

.ons-team-breadcrumb .is-current {
  color: var(--color-neutral-900);
}

.ons-team-heading {
  max-width: 48rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .ons-team-heading {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .ons-team-heading {
    font-size: 3rem;
  }
}

.ons-team-heading span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.ons-team-heading .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.ons-team-description {
  margin-top: 1rem;
  max-width: 42rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .ons-team-description {
    font-size: 1.125rem;
  }
}

.ons-team-hero-divider {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(173, 155, 138, 0.85), transparent);
}

.ons-team-members {
  padding-top: 2.5rem;
  padding-bottom: 4rem;
  background: var(--color-section-bg);
}

@media (min-width: 640px) {
  .ons-team-members {
    padding-top: 3rem;
    padding-bottom: 5rem;
  }
}

@media (min-width: 768px) {
  .ons-team-members {
    padding-top: 6rem;
    padding-bottom: 7rem;
  }
}

.ons-team-grid {
  display: grid;
  gap: 1rem;
}

@media (min-width: 640px) {
  .ons-team-grid {
    gap: 1.5rem;
  }
}

@media (min-width: 768px) {
  .ons-team-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1280px) {
  .ons-team-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.ons-team-card {
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.7);
  padding: 0.875rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s ease;
}

@media (min-width: 640px) {
  .ons-team-card {
    border-radius: 1.5rem;
    padding: 1.25rem;
  }
}

.ons-team-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.ons-team-card.stagger-ready {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
}

.ons-team-card.stagger-ready.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: var(--team-delay, 0ms);
}

.ons-team-card.stagger-ready.is-visible:hover {
  transform: translateY(-4px);
}

.ons-team-media {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: 1rem;
}

.ons-team-media.accent-1 {
  background: linear-gradient(135deg, rgba(189, 176, 160, 0.7), rgba(157, 134, 114, 0.5));
}

.ons-team-media.accent-2 {
  background: linear-gradient(135deg, rgba(220, 214, 204, 0.8), rgba(254, 240, 138, 0.5));
}

.ons-team-media.accent-3 {
  background: linear-gradient(135deg, rgba(254, 240, 138, 0.6), rgba(189, 176, 160, 0.5));
}

.ons-team-media.accent-4 {
  background: linear-gradient(135deg, rgba(189, 176, 160, 0.6), rgba(120, 97, 86, 0.3));
}

.ons-team-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ons-team-placeholder {
  position: absolute;
  inset: 0;
}

.ons-team-placeholder .glow-one {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.55), transparent 45%);
}

.ons-team-placeholder .glow-two {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 80%, rgba(120, 97, 86, 0.22), transparent 50%);
}

.ons-team-card-content {
  padding: 1rem 0.25rem 0;
}

@media (min-width: 640px) {
  .ons-team-card-content {
    padding-top: 1.25rem;
  }
}

.ons-team-role {
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-primary-600);
}

@media (min-width: 640px) {
  .ons-team-role {
    font-size: 0.875rem;
    letter-spacing: 0.12em;
  }
}

.ons-team-name {
  margin-top: 0.25rem;
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-neutral-900);
}

@media (min-width: 640px) {
  .ons-team-name {
    font-size: 1.875rem;
  }
}

.ons-team-highlights {
  margin-top: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

@media (min-width: 640px) {
  .ons-team-highlights {
    margin-top: 1rem;
    gap: 0.625rem;
  }
}

.ons-team-highlights li {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-700);
}

@media (min-width: 640px) {
  .ons-team-highlights li {
    gap: 0.75rem;
  }
}

.ons-team-highlights li.is-empty {
  display: none;
}

.ons-team-highlights li .bullet {
  margin-top: 0.625rem;
  width: 0.375rem;
  height: 0.375rem;
  flex-shrink: 0;
  border-radius: 9999px;
  background: var(--color-primary-500);
}

@media (prefers-reduced-motion: reduce) {

  .ons-team-card,
  .ons-team-card.stagger-ready,
  .ons-team-card.stagger-ready.is-visible {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ==========================================================================
   Contact Page
   ========================================================================== */

.contact-page {
  background: var(--color-section-bg);
}

.contact-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-section-bg);
  padding-top: 8rem;
  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .contact-hero {
    padding-top: 10rem;
    padding-bottom: 5rem;
  }
}

.contact-breadcrumb {
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-neutral-500);
}

.contact-breadcrumb a {
  transition: color 0.2s;
}

.contact-breadcrumb a:hover {
  color: var(--color-neutral-900);
}

.contact-breadcrumb .is-current {
  color: var(--color-neutral-900);
}

.contact-heading {
  max-width: 48rem;
  font-size: 1.875rem;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--color-neutral-900);
}

@media (min-width: 768px) {
  .contact-heading {
    font-size: 2.25rem;
  }
}

@media (min-width: 1024px) {
  .contact-heading {
    font-size: 3rem;
  }
}

.contact-heading span {
  font-family: var(--font-serif);
  font-weight: 400;
}

.contact-heading .italic {
  font-style: italic;
  color: var(--color-primary-700);
}

.contact-description {
  margin-top: 1rem;
  max-width: 42rem;
  font-size: 1rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .contact-description {
    font-size: 1.125rem;
  }
}

.contact-hero-divider {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(173, 155, 138, 0.85), transparent);
}

.contact-content {
  background: var(--color-section-bg);
  padding: 4rem 0;
}

@media (min-width: 768px) {
  .contact-content {
    padding: 5rem 0;
  }
}

.contact-grid {
  display: grid;
  gap: 2rem;
}

@media (min-width: 1024px) {
  .contact-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 3rem;
  }
}

.contact-card {
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: 1.5rem;
  background: rgba(255, 255, 255, 0.8);
  padding: 1.5rem 1rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

@media (min-width: 768px) {
  .contact-card {
    padding: 2rem;
  }
}

.contact-card.stagger-ready {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
}

.contact-card.stagger-ready.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: var(--contact-delay, 0ms);
}

.contact-card .card-tag {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-primary-600);
}

.contact-card h2,
.contact-card h3 {
  margin-top: 0.5rem;
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 400;
  color: var(--color-neutral-900);
}

.contact-mini-grid {
  margin-top: 1.5rem;
  display: grid;
  gap: 0.75rem;
}

@media (min-width: 640px) {
  .contact-mini-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.contact-mini-card {
  display: block;
  border-radius: 0.75rem;
  border: 1px solid var(--color-neutral-200);
  background: white;
  padding: 1rem;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

a.contact-mini-card:hover {
  transform: translateY(-2px);
  border-color: rgba(173, 155, 138, 0.65);
  box-shadow: 0 8px 12px -6px rgba(0, 0, 0, 0.12);
}

.contact-mini-card-address {
  grid-column: 1 / -1;
}

.mini-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-neutral-500);
}

a.contact-mini-card:hover .mini-label {
  color: var(--color-primary-600);
}

.mini-value {
  margin-top: 0.25rem;
  font-weight: 500;
  color: var(--color-neutral-900);
}

.mini-hint {
  margin-top: 0.25rem;
  font-size: 0.75rem;
  color: var(--color-primary-600);
}

.contact-mini-card-address .contact-route-link {
  margin-top: 0.25rem;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.4;
}

.contact-socials {
  margin-top: 1.5rem;
  border-radius: 1rem;
  border: 1px solid rgba(220, 214, 204, 0.8);
  background: rgba(250, 248, 245, 0.95);
  padding: 1rem;
}

.contact-socials-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-700);
}

.contact-socials-row a {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-weight: 500;
  color: var(--color-primary-600);
  transition: color 0.2s ease;
}

.contact-socials-row a:hover {
  color: var(--color-primary-700);
}

.contact-socials-row svg {
  width: 1rem;
  height: 1rem;
}

.contact-card-route {
  overflow: hidden;
  padding: 0;
}

.contact-route-header {
  border-bottom: 1px solid rgba(231, 229, 228, 0.95);
  padding: 1.25rem 1.5rem;
}

.contact-route-header h3 {
  margin-top: 0.25rem;
  font-size: 1.5rem;
}

.contact-map-wrap {
  position: relative;
  height: 350px;
  width: 100%;
}

@media (min-width: 768px) {
  .contact-map-wrap {
    height: 380px;
  }
}

.contact-map-wrap iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.contact-copy {
  margin-top: 0.75rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .contact-copy {
    font-size: 1rem;
  }
}

.contact-copy+.contact-copy {
  margin-top: 1rem;
}

.contact-practical-list {
  margin-top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.contact-practical-item {
  border-radius: 0.75rem;
  background: white;
  padding: 0.875rem 1rem;
}

.contact-practical-item .item-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-neutral-900);
}

.contact-practical-item .item-copy {
  margin-top: 0.25rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

.contact-route-link {
  margin-top: 0.5rem;
  display: inline-flex;
  align-items: center;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-primary-600);
  transition: color 0.2s;
}

.contact-route-link:hover {
  color: var(--color-primary-700);
}

@media (prefers-reduced-motion: reduce) {

  .vergoedingen-step-card,
  .vergoedingen-step-card.stagger-ready,
  .vergoedingen-step-card.stagger-ready.is-visible,
  .vergoedingen-card,
  .vergoedingen-card.stagger-ready,
  .vergoedingen-card.stagger-ready.is-visible,
  .oplossingen-highlight-card,
  .oplossingen-highlight-card.stagger-ready,
  .oplossingen-highlight-card.stagger-ready.is-visible,
  .contact-card,
  .contact-card.stagger-ready,
  .contact-card.stagger-ready.is-visible,
  .action-card,
  .action-card.stagger-ready,
  .action-card.stagger-ready.is-visible,
  .footer-reveal,
  .footer-reveal.stagger-ready,
  .footer-reveal.stagger-ready.is-visible {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ==========================================================================
   Call To Action Section
   ========================================================================== */

.cta-section {
  position: relative;
  background: var(--color-section-bg);
}

.cta-grid {
  position: relative;
  display: grid;
  align-items: stretch;
  gap: 2rem;
  padding-top: 3rem;
}

@media (min-width: 768px) {
  .cta-grid {
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
  }
}

/* CTA Image */
.cta-image {
  position: relative;
  order: 2;
}

@media (min-width: 768px) {
  .cta-image {
    order: 1;
  }
}

.cta-image-wrapper {
  position: relative;
  margin: 0 auto;
  width: 100%;
  max-width: 350px;
  aspect-ratio: 7/8;
}

@media (min-width: 768px) {
  .cta-image-wrapper {
    margin: 0;
    height: 590px;
    width: 510px;
    max-width: none;
    aspect-ratio: auto;
  }
}

.cta-image-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 60%;
}

/* CTA Content */
.cta-content {
  order: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (min-width: 768px) {
  .cta-content {
    order: 2;
  }
}

.cta-content .section-heading {
  margin-bottom: 0.5rem;
}

@media (min-width: 768px) {
  .cta-content .section-heading {
    margin-bottom: 1rem;
  }
}

.cta-description {
  margin-bottom: 1.5rem;
  max-width: 36rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-600);
}

@media (min-width: 768px) {
  .cta-description {
    font-size: 1rem;
  }
}

/* Action Cards */
.action-cards {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.action-card {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  border-radius: 1rem;
  background: white;
  padding: 1.25rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.2s;
}

@media (min-width: 768px) {
  .action-card {
    padding: 1.5rem;
  }
}

.action-card:hover {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.action-card.stagger-ready {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
}

.action-card.stagger-ready.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: var(--action-delay, 0ms);
}

.action-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  border-radius: 9999px;
  background: var(--color-primary-600);
}

@media (min-width: 768px) {
  .action-card-icon {
    width: 3.5rem;
    height: 3.5rem;
  }
}

.action-card-icon svg {
  width: 1.5rem;
  height: 1.5rem;
  color: white;
}

@media (min-width: 768px) {
  .action-card-icon svg {
    width: 1.75rem;
    height: 1.75rem;
  }
}

.action-card-body {
  flex: 1;
}

.action-card-body h3 {
  margin-bottom: 0.25rem;
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-neutral-900);
}

.action-card-body p {
  font-size: 0.875rem;
  color: var(--color-neutral-500);
}

.action-card-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-primary-600);
  transition: color 0.2s;
}

.action-card:hover .action-card-link {
  color: var(--color-primary-700);
}

.action-card-link svg {
  width: 0.875rem;
  height: 0.875rem;
  transition: transform 0.2s;
}

.action-card:hover .action-card-link svg {
  transform: translateX(2px);
}

/* ==========================================================================
   Footer
   ========================================================================== */

.site-footer {
  position: relative;
  overflow: hidden;
  background: var(--color-neutral-900);
}

.footer-orb {
  pointer-events: none;
  position: absolute;
  top: -6rem;
  left: 50%;
  transform: translateX(-50%);
  width: 24rem;
  height: 12rem;
  border-radius: 9999px;
  background: rgba(41, 37, 36, 0.3);
  filter: blur(48px);
}

.footer-main {
  position: relative;
  border-bottom: 1px solid var(--color-neutral-800);
  padding: 4rem 0;
}

.footer-reveal {
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

.footer-reveal.stagger-ready {
  opacity: 0;
  transform: translate3d(0, 2.5rem, 0);
}

.footer-reveal.stagger-ready.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-delay: var(--footer-delay, 0ms);
}

@media (min-width: 768px) {
  .footer-main {
    padding: 5rem 0;
  }
}

.footer-grid {
  display: grid;
  gap: 3rem;
}

@media (min-width: 768px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .footer-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Footer brand column */
.footer-brand img {
  height: auto;
  width: 100%;
  max-width: 260px;
}

.footer-brand .tagline {
  margin-top: 1rem;
  font-size: 0.875rem;
  line-height: 1.625;
  color: var(--color-neutral-400);
}

.footer-stars {
  margin-top: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.footer-stars svg {
  width: 1rem;
  height: 1rem;
  color: var(--color-accent-500);
}

.footer-stars span {
  margin-left: 0.5rem;
  font-size: 0.75rem;
  color: var(--color-neutral-500);
}

/* Footer navigation */
.footer-col h4 {
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: white;
}

.footer-col h4.accent {
  color: var(--color-primary-200);
}

.footer-col ul {
  margin-top: 1rem;
}

.footer-col ul li {
  margin-bottom: 0.75rem;
}

.footer-nav-link {
  display: inline-block;
  font-size: 0.875rem;
  color: var(--color-neutral-400);
  transition: color 0.3s;
}

.footer-nav-link:hover {
  color: white;
}

.footer-nav-link .link-line {
  display: none;
}

/* Footer contact info */
.footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.875rem;
  color: rgba(189, 176, 160, 0.8);
  transition: color 0.2s;
}

a.footer-contact-item:hover {
  color: var(--color-primary-100);
}

.footer-contact-item svg {
  margin-top: 2px;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-accent-500);
}

/* Footer hours */
.footer-hours-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.875rem;
}

.footer-hours-item .hours-row {
  display: flex;
  flex: 1;
  justify-content: space-between;
  color: rgba(189, 176, 160, 0.8);
}

.footer-hours-item .hours-row .time {
  color: var(--color-primary-200);
}

.footer-hours-item svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-accent-500);
}

.footer-hours-item .spacer {
  width: 1rem;
  height: 1rem;
}

/* Footer bottom bar */
.footer-bottom {
  position: relative;
  padding: 1.5rem 0;
}

.footer-bottom-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

@media (min-width: 640px) {
  .footer-bottom-inner {
    flex-direction: row;
  }
}

.footer-copyright {
  font-size: 0.75rem;
  color: rgba(173, 155, 138, 0.7);
}

.footer-credits {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: var(--color-neutral-400);
}

.footer-credits a {
  font-weight: 500;
  color: var(--color-accent-500);
  transition: color 0.5s;
}

.footer-credits a:hover {
  color: var(--color-accent-600);
}

.footer-credits a::after {
  background: var(--color-accent-500);
}

.footer-credits a:hover::after {
  width: 100%;
}

/* ==========================================================================
   Utility: screen reader only
   ========================================================================== */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
