.elementor-kit-11{--e-global-color-primary:#06141A;--e-global-color-secondary:#0B2730;--e-global-color-text:#00D1D6;--e-global-color-accent:#7AF1FF;--e-global-color-248aa62:#DFFCFF;--e-global-typography-primary-font-family:"Plus Jakarta Sans";--e-global-typography-primary-font-size:65px;--e-global-typography-primary-font-weight:700;--e-global-typography-primary-text-transform:none;--e-global-typography-primary-font-style:normal;--e-global-typography-primary-text-decoration:none;--e-global-typography-primary-line-height:1.2em;--e-global-typography-primary-letter-spacing:0px;--e-global-typography-primary-word-spacing:0em;--e-global-typography-secondary-font-family:"Plus Jakarta Sans";--e-global-typography-secondary-font-size:36px;--e-global-typography-secondary-font-weight:600;--e-global-typography-secondary-text-transform:capitalize;--e-global-typography-secondary-font-style:normal;--e-global-typography-secondary-text-decoration:none;--e-global-typography-secondary-line-height:1.1em;--e-global-typography-secondary-letter-spacing:0px;--e-global-typography-text-font-family:"Plus Jakarta Sans";--e-global-typography-text-font-size:16px;--e-global-typography-text-font-weight:400;--e-global-typography-text-text-transform:none;--e-global-typography-text-font-style:normal;--e-global-typography-text-text-decoration:none;--e-global-typography-text-line-height:1.5em;--e-global-typography-text-letter-spacing:0px;--e-global-typography-accent-font-family:"Plus Jakarta Sans";--e-global-typography-accent-font-size:16px;--e-global-typography-accent-font-weight:400;--e-global-typography-accent-text-transform:capitalize;--e-global-typography-accent-font-style:normal;--e-global-typography-accent-text-decoration:none;--e-global-typography-accent-line-height:1em;--e-global-typography-accent-letter-spacing:0px;--e-global-typography-392b9e0-font-family:"Poppins";--e-global-typography-392b9e0-font-size:22px;--e-global-typography-392b9e0-font-weight:600;--e-global-typography-392b9e0-text-transform:capitalize;--e-global-typography-392b9e0-font-style:normal;--e-global-typography-392b9e0-text-decoration:none;--e-global-typography-392b9e0-line-height:1.2em;--e-global-typography-392b9e0-letter-spacing:0px;--e-global-typography-c05b693-font-family:"Poppins";--e-global-typography-c05b693-font-size:22px;--e-global-typography-c05b693-font-weight:300;--e-global-typography-c05b693-text-transform:none;--e-global-typography-c05b693-font-style:normal;--e-global-typography-c05b693-text-decoration:none;--e-global-typography-c05b693-line-height:1.5em;--e-global-typography-c05b693-letter-spacing:0px;--e-global-typography-6558fb1-font-family:"Poppins";--e-global-typography-6558fb1-font-size:16px;--e-global-typography-6558fb1-font-weight:300;--e-global-typography-6558fb1-text-transform:uppercase;--e-global-typography-6558fb1-font-style:normal;--e-global-typography-6558fb1-text-decoration:none;--e-global-typography-6558fb1-line-height:1.5em;--e-global-typography-6558fb1-letter-spacing:10px;--e-global-typography-92bce3b-font-family:"Poppins";--e-global-typography-92bce3b-font-size:16px;--e-global-typography-92bce3b-font-weight:400;--e-global-typography-92bce3b-text-transform:capitalize;--e-global-typography-92bce3b-font-style:italic;--e-global-typography-92bce3b-text-decoration:underline;--e-global-typography-92bce3b-line-height:1em;--e-global-typography-92bce3b-letter-spacing:0px;--e-global-typography-b2deeae-font-family:"Poppins";--e-global-typography-b2deeae-font-size:85px;--e-global-typography-b2deeae-font-weight:600;--e-global-typography-b2deeae-text-transform:none;--e-global-typography-b2deeae-font-style:normal;--e-global-typography-b2deeae-text-decoration:none;--e-global-typography-b2deeae-line-height:1em;--e-global-typography-b2deeae-letter-spacing:0px;--e-global-typography-fb1a3e0-font-family:"Poppins";--e-global-typography-fb1a3e0-font-size:200px;--e-global-typography-fb1a3e0-font-weight:600;--e-global-typography-fb1a3e0-text-transform:none;--e-global-typography-fb1a3e0-font-style:normal;--e-global-typography-fb1a3e0-text-decoration:none;--e-global-typography-fb1a3e0-line-height:1.2em;--e-global-typography-fb1a3e0-letter-spacing:0px;--e-global-typography-397e168-font-family:"Poppins";--e-global-typography-397e168-font-size:16px;--e-global-typography-397e168-font-weight:400;--e-global-typography-397e168-text-transform:capitalize;--e-global-typography-397e168-font-style:italic;--e-global-typography-397e168-text-decoration:none;--e-global-typography-397e168-line-height:1.3em;--e-global-typography-397e168-letter-spacing:0px;background-color:var( --e-global-color-primary );}.elementor-kit-11 e-page-transition{background-color:#FFBC7D;}.site-header{background-color:var( --e-global-color-primary );padding-inline-end:8%;padding-inline-start:8%;}.site-footer{background-color:var( --e-global-color-accent );}.elementor-kit-11 a{color:var( --e-global-color-accent );}.elementor-kit-11 a:hover{color:var( --e-global-color-primary );}.elementor-kit-11 h4{color:var( --e-global-color-primary );font-family:var( --e-global-typography-392b9e0-font-family ), Sans-serif;font-size:var( --e-global-typography-392b9e0-font-size );font-weight:var( --e-global-typography-392b9e0-font-weight );text-transform:var( --e-global-typography-392b9e0-text-transform );font-style:var( --e-global-typography-392b9e0-font-style );text-decoration:var( --e-global-typography-392b9e0-text-decoration );line-height:var( --e-global-typography-392b9e0-line-height );letter-spacing:var( --e-global-typography-392b9e0-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1600px;}.e-con{--container-max-width:1600px;--container-default-padding-top:0px;--container-default-padding-right:0px;--container-default-padding-bottom:0px;--container-default-padding-left:0px;}.elementor-widget:not(:last-child){--kit-widget-spacing:0px;}.elementor-element{--widgets-spacing:0px 0px;--widgets-spacing-row:0px;--widgets-spacing-column:0px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .header-inner{width:1600px;max-width:100%;}.site-header .site-navigation ul.menu li a{color:var( --e-global-color-primary );}.site-header .site-navigation-toggle .site-navigation-toggle-icon{color:var( --e-global-color-accent );}.site-header .site-navigation .menu li{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );text-transform:var( --e-global-typography-text-text-transform );font-style:var( --e-global-typography-text-font-style );text-decoration:var( --e-global-typography-text-text-decoration );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}.site-footer .copyright p{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );text-transform:var( --e-global-typography-text-text-transform );font-style:var( --e-global-typography-text-font-style );text-decoration:var( --e-global-typography-text-text-decoration );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}@media(max-width:1024px){.elementor-kit-11{--e-global-typography-primary-font-size:45px;--e-global-typography-secondary-font-size:25px;--e-global-typography-text-font-size:14px;--e-global-typography-accent-font-size:14px;--e-global-typography-c05b693-font-size:18px;--e-global-typography-c05b693-line-height:1.4em;--e-global-typography-6558fb1-font-size:14px;--e-global-typography-92bce3b-font-size:14px;--e-global-typography-b2deeae-font-size:65px;--e-global-typography-fb1a3e0-font-size:145px;--e-global-typography-397e168-font-size:14px;}.elementor-kit-11 h4{font-size:var( --e-global-typography-392b9e0-font-size );line-height:var( --e-global-typography-392b9e0-line-height );letter-spacing:var( --e-global-typography-392b9e0-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}.site-header{padding-inline-end:5%;padding-inline-start:5%;}.site-header .site-navigation .menu li{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}.site-footer .copyright p{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}}@media(max-width:767px){.elementor-kit-11{--e-global-typography-primary-font-size:28px;--e-global-typography-primary-line-height:1.1em;--e-global-typography-secondary-font-size:20px;--e-global-typography-392b9e0-font-size:18px;--e-global-typography-c05b693-font-size:16px;--e-global-typography-b2deeae-font-size:42px;--e-global-typography-b2deeae-line-height:1em;--e-global-typography-fb1a3e0-font-size:100px;--e-global-typography-fb1a3e0-line-height:1em;}.elementor-kit-11 h4{font-size:var( --e-global-typography-392b9e0-font-size );line-height:var( --e-global-typography-392b9e0-line-height );letter-spacing:var( --e-global-typography-392b9e0-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}.site-header{padding-inline-end:8%;padding-inline-start:8%;}.site-header .site-navigation .menu li{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}.site-footer .copyright p{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}}/* Start custom CSS *//* ============================================
   THE MIRROR OF LIFE - COMPLETE CSS
   Voor WordPress + Elementor Free
   ============================================ */

/* ============================================
   1. CSS VARIABELEN (KLEURENSCHEMA)
   ============================================ */

:root {
  /* Donker thema kleuren */
  --deep: #06141a;
  --ocean: #0b2730;
  --teal: #00d1d6;
  --ring: #7af1ff;
  --ink: #dffcff;
  --white: #f8feff;
  
  /* Glassmorphism effecten */
  --glass: rgba(11, 39, 48, 0.7);
  --glass-border: rgba(122, 241, 255, 0.2);
  --shadow: rgba(0, 0, 0, 0.3);
  
  /* Layout */
  --radius: 18px;
  --nav-height: 70px;
  --transition: 0.3s ease;
}

/* Licht thema kleuren */
[data-wp-dark-mode-active="false"],
.wp-dark-mode-light {
  --deep: #f0f9fb;
  --ocean: #e1f3f6;
  --teal: #0097a7;
  --ring: #00bcd4;
  --ink: #004d5a;
  --white: #001f26;
  
  --glass: rgba(225, 243, 246, 0.8);
  --glass-border: rgba(0, 151, 167, 0.3);
  --shadow: rgba(0, 0, 0, 0.1);
}


/* ============================================
   2. GLOBALE BODY & TYPOGRAFIE
   ============================================ */

body {
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--deep);
  color: var(--white);
  line-height: 1.6;
  overflow-x: hidden;
}

/* Smooth scroll */
html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--nav-height) + 2rem);
}

/* Reduced motion voor toegankelijkheid */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}


/* ============================================
   3. HEADER STYLING
   ============================================ */

/* Header glassmorphism effect */
.elementor-location-header {
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--glass-border);
  box-shadow: 0 4px 20px var(--shadow);
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

/* Logo styling */
.site-logo img,
.logo-orb {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  box-shadow: 0 0 20px var(--ring), 0 0 40px var(--teal);
  animation: pulse 3s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { 
    box-shadow: 0 0 20px var(--ring), 0 0 40px var(--teal); 
  }
  50% { 
    box-shadow: 0 0 30px var(--ring), 0 0 60px var(--teal); 
  }
}

/* Navigatie menu styling */
.elementor-nav-menu--main {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

.elementor-nav-menu--main .elementor-item {
  color: var(--ink) !important;
  font-weight: 500;
  font-size: 16px;
  text-decoration: none;
  transition: color var(--transition);
  position: relative;
  padding: 0.5rem 1rem;
}

.elementor-nav-menu--main .elementor-item:hover,
.elementor-nav-menu--main .elementor-item:focus {
  color: var(--teal) !important;
}

.elementor-nav-menu--main .elementor-item.elementor-item-active {
  color: var(--teal) !important;
}

/* Actieve pagina onderlijn */
.elementor-nav-menu--main .elementor-item.elementor-item-active::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--teal);
}

/* Header knoppen (theme, language, login) */
.header-controls,
.nav-controls {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.icon-btn,
.theme-toggle-btn,
.lang-switcher a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 8px 12px;
  background: transparent;
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  color: var(--white);
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: all var(--transition);
}

.icon-btn:hover,
.theme-toggle-btn:hover,
.lang-switcher a:hover,
.lang-switcher a.current-lang {
  background: var(--glass);
  border-color: var(--teal);
  transform: translateY(-2px);
}

/* Mobile menu toggle */
.elementor-menu-toggle {
  background: transparent !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  color: var(--teal) !important;
  min-width: 44px;
  min-height: 44px;
}


/* ============================================
   4. HERO SECTION
   ============================================ */

.hero-section,
#home {
  min-height: 100vh !important;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

/* Hero tekst gradient effect */
.hero-section .elementor-heading-title,
.hero-title {
  background: linear-gradient(135deg, var(--ring), var(--teal));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800 !important;
  line-height: 1.1 !important;
}

/* Hero animatie */
.hero-section .elementor-column {
  animation: fadeInUp 0.8s ease-out;
}

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


/* ============================================
   5. KNOPPEN (BUTTONS)
   ============================================ */

/* Primaire knoppen (gradient) */
.elementor-button,
.btn-primary,
.elementor-button-wrapper .elementor-button {
  background: linear-gradient(135deg, var(--teal), var(--ring)) !important;
  color: var(--deep) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  font-weight: 700 !important;
  font-size: 18px !important;
  padding: 16px 40px !important;
  transition: all var(--transition) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 44px;
}

.elementor-button:hover,
.btn-primary:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 10px 30px rgba(0, 209, 214, 0.4) !important;
}

/* Secundaire knoppen */
.btn-secondary,
.elementor-button-secondary {
  background: var(--glass) !important;
  color: var(--white) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius) !important;
  font-weight: 600 !important;
  padding: 12px 24px !important;
  transition: all var(--transition) !important;
}

.btn-secondary:hover {
  background: var(--teal) !important;
  color: var(--deep) !important;
  border-color: var(--teal) !important;
  transform: translateY(-2px);
}


/* ============================================
   6. BLOG CARDS / POSTS
   ============================================ */

/* Blog grid container */
.elementor-posts-container,
.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2rem;
}

/* Individuele blog card */
.elementor-post,
.blog-card {
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius) !important;
  overflow: hidden;
  transition: all var(--transition);
  box-shadow: 0 4px 20px var(--shadow);
  opacity: 0;
  transform: translateY(20px);
  animation: fadeInCard 0.6s ease-out forwards;
}

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

.elementor-post:hover,
.blog-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 10px 40px var(--shadow) !important;
  border-color: var(--teal) !important;
}

/* Blog card afbeelding */
.elementor-post__thumbnail,
.blog-card-image {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

/* Blog card content */
.elementor-post__card,
.blog-card-content {
  padding: 2rem;
}

/* Blog card titel */
.elementor-post__title,
.blog-card h3 {
  color: var(--teal) !important;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
  margin-bottom: 1rem;
}

.elementor-post__title a {
  color: var(--teal) !important;
  text-decoration: none;
}

/* Blog metadata (datum, auteur) */
.elementor-post__meta-data,
.blog-date,
.blog-author {
  color: var(--ink) !important;
  font-size: 0.875rem;
  margin-bottom: 0.5rem;
}

/* Blog tags */
.elementor-post__tags,
.blog-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.elementor-post__tags a,
.blog-tag {
  padding: 0.25rem 0.75rem;
  background: rgba(0, 209, 214, 0.2) !important;
  border-radius: 50px;
  font-size: 0.75rem;
  color: var(--teal) !important;
  text-decoration: none;
}


/* ============================================
   7. SERVICE CARDS
   ============================================ */

.service-card,
.elementor-widget-icon-box {
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius) !important;
  padding: 2.5rem !important;
  text-align: center;
  transition: all var(--transition);
  box-shadow: 0 4px 20px var(--shadow);
}

.service-card:hover,
.elementor-widget-icon-box:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 40px var(--shadow);
  border-color: var(--teal) !important;
}

/* Service iconen */
.service-icon,
.elementor-icon-box-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 1.5rem;
  background: linear-gradient(135deg, var(--teal), var(--ring)) !important;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
}

.elementor-icon-box-icon i,
.elementor-icon-box-icon svg {
  color: var(--deep) !important;
  font-size: 2.5rem;
}

.service-card:hover .service-icon,
.elementor-widget-icon-box:hover .elementor-icon-box-icon {
  transform: scale(1.1) rotate(5deg);
}

/* Service titel */
.elementor-icon-box-title {
  color: var(--teal) !important;
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  margin-bottom: 1rem;
}

/* Service beschrijving */
.elementor-icon-box-description {
  color: var(--ink) !important;
  line-height: 1.7;
}


/* ============================================
   8. CONTACT FORMULIER
   ============================================ */

/* Contact Form 7 wrapper */
.wpcf7,
.contact-form-wrapper {
  max-width: 600px;
  margin: 0 auto;
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius) !important;
  padding: 3rem !important;
  box-shadow: 0 4px 20px var(--shadow);
}

/* Formulier labels */
.wpcf7 label,
.contact-form-wrapper label {
  display: block;
  margin-bottom: 1.5rem;
  color: var(--teal) !important;
  font-weight: 600;
}

/* Formulier inputs & textarea */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea,
.contact-form-wrapper input,
.contact-form-wrapper textarea {
  width: 100% !important;
  padding: 0.875rem 1.25rem !important;
  background: var(--ocean) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  color: var(--white) !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 1rem !important;
  margin-top: 0.5rem;
  transition: all var(--transition);
}

.wpcf7 input:focus,
.wpcf7 textarea:focus {
  outline: 2px solid var(--teal) !important;
  border-color: var(--teal) !important;
}

.wpcf7 textarea {
  min-height: 150px;
  resize: vertical;
}

/* Submit knop */
.wpcf7 input[type="submit"],
.wpcf7-submit {
  background: linear-gradient(135deg, var(--teal), var(--ring)) !important;
  color: var(--deep) !important;
  border: none !important;
  padding: 1rem 2.5rem !important;
  border-radius: var(--radius) !important;
  font-weight: 700 !important;
  font-size: 18px !important;
  cursor: pointer;
  transition: all var(--transition) !important;
  width: auto !important;
}

.wpcf7 input[type="submit"]:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 10px 30px rgba(0, 209, 214, 0.4) !important;
}

/* Formulier validatie berichten */
.wpcf7-not-valid-tip {
  color: #ff6b6b !important;
  font-size: 0.875rem;
  margin-top: 0.5rem;
}

.wpcf7-response-output {
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  padding: 1rem !important;
  margin-top: 1rem !important;
}

.wpcf7-mail-sent-ok {
  background: rgba(0, 209, 214, 0.2) !important;
  color: var(--teal) !important;
}

.wpcf7-validation-errors {
  background: rgba(255, 107, 107, 0.2) !important;
  color: #ff6b6b !important;
}


/* ============================================
   9. AUTHOR PAGES (MARCO & THOMAS)
   ============================================ */

/* Author header layout */
.author-header {
  display: flex;
  gap: 3rem;
  margin-bottom: 3rem;
  align-items: center;
  flex-wrap: wrap;
}

/* Author profielfoto */
.author-image,
.profile-image {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--teal);
  box-shadow: 0 10px 40px var(--shadow);
}

/* Author info */
.author-info h1 {
  font-size: 2.5rem;
  color: var(--teal) !important;
  margin-bottom: 0.5rem;
}

.author-role {
  font-size: 1.25rem;
  color: var(--ring) !important;
  margin-bottom: 1rem;
}

/* Author bio content */
.author-content,
.bio-content {
  background: var(--glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 3rem;
  box-shadow: 0 4px 20px var(--shadow);
  line-height: 1.8;
  font-size: 1.125rem;
  color: var(--white);
}


/* ============================================
   10. SOCIAL MEDIA ICONS
   ============================================ */

.social-links,
.elementor-social-icons-wrapper {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-top: 2rem;
}

.social-link,
.elementor-social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px;
  color: var(--teal) !important;
  text-decoration: none;
  transition: all var(--transition);
  font-size: 1.75rem;
}

.social-link:hover,
.elementor-social-icon:hover {
  background: var(--teal) !important;
  color: var(--deep) !important;
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 10px 30px rgba(0, 209, 214, 0.3) !important;
}

.elementor-social-icon i {
  color: inherit !important;
}


/* ============================================
   11. FOOTER
   ============================================ */

.elementor-location-footer,
footer {
  background: var(--ocean) !important;
  padding: 3rem 2rem;
  text-align: center;
  border-top: 1px solid var(--glass-border);
}

.elementor-location-footer p,
footer p {
  color: var(--ink) !important;
  font-size: 0.875rem;
  margin: 0;
}


/* ============================================
   12. SCROLL TO TOP KNOP
   ============================================ */

#scroll-to-top,
.scroll-top-button,
.wpfront-scroll-top-button {
  position: fixed !important;
  bottom: 2rem !important;
  right: 2rem !important;
  width: 56px !important;
  height: 56px !important;
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border) !important;
  border-radius: 50% !important;
  color: var(--teal) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 999 !important;
  transition: all var(--transition) !important;
  box-shadow: 0 4px 20px var(--shadow) !important;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
}

#scroll-to-top.visible,
.scroll-top-button.visible {
  opacity: 1 !important;
  pointer-events: all !important;
}

#scroll-to-top:hover,
.scroll-top-button:hover {
  background: var(--teal) !important;
  color: var(--deep) !important;
  transform: translateY(-5px) !important;
  box-shadow: 0 10px 30px rgba(0, 209, 214, 0.4) !important;
}


/* ============================================
   13. SEARCH BOX
   ============================================ */

.search-box,
.elementor-search-form {
  position: relative;
  width: 100%;
  max-width: 100%;
}

.search-box input,
.elementor-search-form__input {
  width: 100% !important;
  padding: 0.875rem 1.25rem 0.875rem 3rem !important;
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius) !important;
  color: var(--white) !important;
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 1rem !important;
  transition: all var(--transition);
}

.search-box input:focus {
  outline: 2px solid var(--teal) !important;
  border-color: var(--teal) !important;
}

.search-box input::placeholder {
  color: var(--ink) !important;
  opacity: 0.7;
}


/* ============================================
   14. TAG CHIPS / FILTERS
   ============================================ */

.tag-filters,
.filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 2rem;
}

.tag-chip,
.filter-chip {
  padding: 0.5rem 1rem;
  background: var(--glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: 50px;
  color: var(--ink);
  font-size: 0.875rem;
  cursor: pointer;
  transition: all var(--transition);
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

.tag-chip:hover,
.tag-chip.active,
.filter-chip:hover,
.filter-chip.active {
  background: var(--teal);
  color: var(--deep);
  border-color: var(--teal);
  transform: translateY(-2px);
}


/* ============================================
   15. SECTIE TITELS
   ============================================ */

.section-title,
.elementor-heading-title.elementor-size-default {
  color: var(--teal) !important;
  font-weight: 700 !important;
  text-align: center;
  margin-bottom: 3rem;
}

h2.section-title,
.elementor-widget-heading h2 {
  font-size: clamp(2rem, 5vw, 3rem) !important;
}


/* ============================================
   16. RESPONSIVE DESIGN
   ============================================ */

/* Tablet (768px en kleiner) */
@media (max-width: 768px) {
  /* Navigatie menu wordt hamburger */
  .elementor-nav-menu--main {
    display: none;
  }
  
  .elementor-nav-menu--main.elementor-nav-menu--dropdown.elementor-nav-menu--active {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--glass);
    backdrop-filter: blur(20px);
    padding: 1rem;
    border-bottom: 1px solid var(--glass-border);
  }
  
  /* Author header stapelt verticaal */
  .author-header {
    flex-direction: column;
    text-align: center;
  }
  
  /* Service cards volle breedte */
  .services-grid,
  .elementor-widget-icon-box {
    grid-template-columns: 1fr !important;
  }
  
  /* Kleinere padding */
  .service-card,
  .contact-form-wrapper,
  .author-content {
    padding: 2rem !important;
  }
}

/* Mobile (640px en kleiner) */
@media (max-width: 640px) {
  /* Kleinere font sizes */
  .hero-section .elementor-heading-title {
    font-size: 2.5rem !important;
  }
  
  .section-title {
    font-size: 2rem !important;
  }
  
  /* Blog grid 1 kolom */
  .elementor-posts-container,
  .blog-grid {
    grid-template-columns: 1fr !important;
  }
  
  /* Kleinere padding overall */
  .elementor-section {
    padding: 2rem 1rem !important;
  }
  
  /* Scroll to top kleiner */
  #scroll-to-top {
    width: 48px !important;
    height: 48px !important;
    bottom: 1rem !important;
    right: 1rem !important;
  }
}


/* ============================================
   17. ELEMENTOR SPECIFIEKE FIXES
   ============================================ */

/* Verwijder Elementor standaard marges */
.elementor-widget-heading .elementor-heading-title {
  margin: 0;
}

/* Fix voor Elementor column gaps */
.elementor-column-gap-default > .elementor-column > .elementor-element-populated {
  padding: 10px;
}

/* Zorg dat sections full width zijn */
.elementor-section.elementor-section-boxed > .elementor-container {
  max-width: 1400px;
}

/* Fix voor Elementor buttons in donker thema */
.elementor-button-wrapper .elementor-button {
  color: var(--deep) !important;
}


/* ============================================
   18. ANIMATIES & TRANSITIONS
   ============================================ */

/* Fade in voor secties */
.elementor-invisible {
  opacity: 0;
}

.elementor-invisible.animated {
  opacity: 1;
}

/* Hover lift effect */
.hover-lift {
  transition: transform var(--transition);
}

.hover-lift:hover {
  transform: translateY(-5px);
}

/* Smooth transitions voor alle interactieve elementen */
a, button, input, textarea, select {
  transition: all var(--transition);
}


/* ============================================
   19. POLYLANG TAALWISSELAAR STYLING
   ============================================ */

/* Polylang dropdown */
.lang-item,
.pll-parent-menu-item {
  display: inline-flex;
  align-items: center;
}

.lang-item-first,
.pll-parent-menu-item a {
  padding: 0.5rem 1rem !important;
  background: transparent;
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  color: var(--white) !important;
  text-decoration: none;
  font-weight: 600;
  font-size: 14px;
  transition: all var(--transition);
}

.lang-item-first:hover,
.pll-parent-menu-item a:hover {
  background: var(--glass);
  border-color: var(--teal);
}

/* Huidige taal actieve status */
.current-lang {
  background: var(--glass) !important;
  border-color: var(--teal) !important;
}


/* ============================================
   20. PRINT STYLING
   ============================================ */

@media print {
  .elementor-location-header,
  .elementor-location-footer,
  .scroll-top-button,
  .nav-controls,
  .blog-controls {
    display: none !important;
  }
  
  body {
    background: white !important;
    color: black !important;
  }
}


/* ============================================
   21. TOEGANKELIJKHEID (A11Y)
   ============================================ */

/* Focus states voor toetsenbord navigatie */
*:focus-visible {
  outline: 2px solid var(--teal) !important;
  outline-offset: 2px;
}

/* Skip link */
.skip-link {
  position: absolute;
  top: -100px;
  left: 1rem;
  background: var(--teal);
  color: var(--deep);
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius);
  text-decoration: none;
  font-weight: 600;
  z-index: 10000;
  transition: top 0.3s;
}

.skip-link:focus {
  top: 1rem;
}

/* Verbeter contrast voor betere leesbaarheid */
.low-contrast-text {
  color: var(--white) !important;
}

/* Grotere touch targets voor mobiel */
@media (hover: none) and (pointer: coarse) {
  button,
  a,
  input[type="submit"],
  .elementor-button {
    min-height: 48px !important;
    min-width: 48px !important;
  }
}


/* ============================================
   22. WP DARK MODE PLUGIN INTEGRATIE
   ============================================ */

/* Dark mode toggle button styling */
.wp-dark-mode-switch {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 8px;
  background: transparent !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 12px !important;
  cursor: pointer;
  transition: all var(--transition);
}

.wp-dark-mode-switch:hover {
  background: var(--glass) !important;
  border-color: var(--teal) !important;
  transform: translateY(-2px);
}

.wp-dark-mode-switch i,
.wp-dark-mode-switch svg {
  color: var(--teal) !important;
  font-size: 1.25rem;
}

/* WP Dark Mode floating button */
.wp-dark-mode-floating-button {
  bottom: 100px !important;
  right: 2rem !important;
  background: var(--glass) !important;
  backdrop-filter: blur(20px) !important;
  border: 1px solid var(--glass-border) !important;
  box-shadow: 0 4px 20px var(--shadow) !important;
}


/* ============================================
   23. BLOG DESIGNER PLUGIN STYLING
   ============================================ */

/* Blog Designer posts */
.blog_template {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 2rem;
}

.blog_template .post {
  background: var(--glass) !important;
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius) !important;
  overflow: hidden;
  transition: all var(--transition);
  box-shadow: 0 4px 20px var(--shadow);
}

.blog_template .post:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 40px var(--shadow);
  border-color: var(--teal) !important;
}

.blog_template .post-image {
  height: 200px;
  overflow: hidden;
}

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

.blog_template .post-content {
  padding: 2rem;
}

.blog_template .post-title {
  color: var(--teal) !important;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
  margin-bottom: 1rem;
}

.blog_template .post-title a {
  color: var(--teal) !important;
  text-decoration: none;
}

.blog_template .post-meta {
  color: var(--ink) !important;
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

.blog_template .post-excerpt {
  color: var(--white) !important;
  line-height: 1.7;
}


/* ============================================
   24. CUSTOM ELEMENTEN
   ============================================ */

/* Glassmorphism helper class */
.glass-effect {
  background: var(--glass) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid var(--glass-border) !important;
  box-shadow: 0 4px 20px var(--shadow) !important;
}

/* Gradient text helper */
.gradient-text {
  background: linear-gradient(135deg, var(--ring), var(--teal));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Container helper */
.container-custom {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
}

/* Spacing helpers */
.spacing-small {
  padding: 2rem 0;
}

.spacing-medium {
  padding: 4rem 0;
}

.spacing-large {
  padding: 6rem 0;
}


/* ============================================
   25. ARTICLE / SINGLE POST STYLING
   ============================================ */

/* Single post layout */
.single-post .entry-content,
.article-content {
  max-width: 800px;
  margin: 0 auto;
  padding: 2rem;
  line-height: 1.8;
  font-size: 1.125rem;
  color: var(--white);
}

/* Article header */
.single-post .entry-header,
.article-header {
  margin-bottom: 3rem;
  text-align: center;
}

.single-post .entry-title,
.article-title {
  font-size: clamp(2rem, 5vw, 3rem);
  color: var(--teal) !important;
  font-weight: 700;
  margin-bottom: 1rem;
}

/* Article meta */
.single-post .entry-meta,
.article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  color: var(--ink);
  font-size: 0.875rem;
  margin-bottom: 2rem;
}

/* Article featured image */
.single-post .post-thumbnail img,
.article-image {
  width: 100%;
  max-height: 500px;
  object-fit: cover;
  border-radius: var(--radius);
  margin-bottom: 2rem;
}

/* Article content styling */
.entry-content h2,
.article-content h2 {
  font-size: 2rem;
  margin: 2.5rem 0 1rem;
  color: var(--teal) !important;
  font-weight: 700;
}

.entry-content h3,
.article-content h3 {
  font-size: 1.5rem;
  margin: 2rem 0 1rem;
  color: var(--ring) !important;
  font-weight: 600;
}

.entry-content p,
.article-content p {
  margin-bottom: 1.5rem;
  line-height: 1.8;
}

.entry-content strong,
.article-content strong {
  font-weight: 700;
  color: var(--teal);
}

.entry-content em,
.article-content em {
  font-style: italic;
  color: var(--ring);
}

.entry-content a,
.article-content a {
  color: var(--teal);
  text-decoration: underline;
  transition: color var(--transition);
}

.entry-content a:hover,
.article-content a:hover {
  color: var(--ring);
}

/* Article lists */
.entry-content ul,
.entry-content ol,
.article-content ul,
.article-content ol {
  margin: 1.5rem 0 1.5rem 2rem;
  color: var(--white);
}

.entry-content li,
.article-content li {
  margin-bottom: 0.5rem;
  line-height: 1.7;
}

/* Article blockquotes */
.entry-content blockquote,
.article-content blockquote {
  margin: 2rem 0;
  padding: 1.5rem 2rem;
  background: var(--glass);
  backdrop-filter: blur(20px);
  border-left: 4px solid var(--teal);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-style: italic;
  color: var(--ink);
}

/* Article code blocks */
.entry-content code,
.article-content code {
  background: var(--glass);
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-family: 'Courier New', monospace;
  font-size: 0.9em;
  color: var(--ring);
}

.entry-content pre,
.article-content pre {
  background: var(--ocean);
  padding: 1.5rem;
  border-radius: var(--radius);
  overflow-x: auto;
  margin: 2rem 0;
}

.entry-content pre code {
  background: none;
  padding: 0;
}


/* ============================================
   26. PAGINATION STYLING
   ============================================ */

.pagination,
.elementor-pagination,
.wp-pagenavi {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  margin-top: 3rem;
}

.pagination a,
.pagination span,
.elementor-pagination a,
.wp-pagenavi a,
.wp-pagenavi span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0.5rem 1rem;
  background: var(--glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  color: var(--white);
  text-decoration: none;
  font-weight: 600;
  transition: all var(--transition);
}

.pagination a:hover,
.elementor-pagination a:hover,
.wp-pagenavi a:hover {
  background: var(--teal);
  color: var(--deep);
  border-color: var(--teal);
  transform: translateY(-2px);
}

.pagination .current,
.elementor-pagination .current,
.wp-pagenavi .current {
  background: var(--teal);
  color: var(--deep);
  border-color: var(--teal);
}


/* ============================================
   27. SIDEBAR STYLING (indien van toepassing)
   ============================================ */

.sidebar,
.widget-area {
  padding: 2rem;
}

.sidebar .widget,
.widget {
  background: var(--glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 2rem;
  margin-bottom: 2rem;
  box-shadow: 0 4px 20px var(--shadow);
}

.sidebar .widget-title,
.widget .widget-title {
  color: var(--teal) !important;
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  border-bottom: 2px solid var(--glass-border);
}

.sidebar ul,
.widget ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sidebar ul li,
.widget ul li {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--glass-border);
}

.sidebar ul li:last-child,
.widget ul li:last-child {
  border-bottom: none;
}

.sidebar a,
.widget a {
  color: var(--white);
  text-decoration: none;
  transition: color var(--transition);
}

.sidebar a:hover,
.widget a:hover {
  color: var(--teal);
}


/* ============================================
   28. COMMENTS STYLING
   ============================================ */

.comments-area {
  max-width: 800px;
  margin: 4rem auto 0;
  padding: 0 2rem;
}

.comments-title {
  color: var(--teal);
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 2rem;
}

.comment-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.comment {
  background: var(--glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 2rem;
  margin-bottom: 1.5rem;
}

.comment-author {
  font-weight: 700;
  color: var(--teal);
  margin-bottom: 0.5rem;
}

.comment-meta {
  color: var(--ink);
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

.comment-content {
  color: var(--white);
  line-height: 1.7;
}

.reply {
  margin-top: 1rem;
}

.reply a {
  color: var(--teal);
  text-decoration: none;
  font-weight: 600;
  transition: color var(--transition);
}

.reply a:hover {
  color: var(--ring);
}

/* Comment form */
.comment-form {
  background: var(--glass);
  backdrop-filter: blur(20px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 2rem;
  margin-top: 3rem;
}

.comment-form label {
  display: block;
  color: var(--teal);
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  padding: 0.875rem 1.25rem;
  background: var(--ocean);
  border: 1px solid var(--glass-border);
  border-radius: 12px;
  color: var(--white);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1rem;
  margin-bottom: 1rem;
  transition: all var(--transition);
}

.comment-form input:focus,
.comment-form textarea:focus {
  outline: 2px solid var(--teal);
  border-color: var(--teal);
}

.comment-form input[type="submit"] {
  background: linear-gradient(135deg, var(--teal), var(--ring)) !important;
  color: var(--deep) !important;
  border: none !important;
  padding: 1rem 2rem !important;
  border-radius: var(--radius) !important;
  font-weight: 700 !important;
  cursor: pointer;
  transition: all var(--transition) !important;
}

.comment-form input[type="submit"]:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0, 209, 214, 0.4);
}


/* ============================================
   29. BREADCRUMBS
   ============================================ */

.breadcrumbs,
.elementor-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 1rem 0;
  font-size: 0.875rem;
  color: var(--ink);
}

.breadcrumbs a,
.elementor-breadcrumbs a {
  color: var(--teal);
  text-decoration: none;
  transition: color var(--transition);
}

.breadcrumbs a:hover,
.elementor-breadcrumbs a:hover {
  color: var(--ring);
}

.breadcrumbs .separator {
  color: var(--ink);
  margin: 0 0.5rem;
}


/* ============================================
   30. LIGHTBOX / MODAL OVERRIDES
   ============================================ */

.elementor-lightbox {
  background: rgba(6, 20, 26, 0.95) !important;
  backdrop-filter: blur(10px);
}

.elementor-lightbox-content {
  border-radius: var(--radius);
  overflow: hidden;
}


/* ============================================
   31. WORDPRESS ADMIN BAR FIX
   ============================================ */

body.admin-bar .elementor-location-header {
  top: 32px !important;
}

@media screen and (max-width: 782px) {
  body.admin-bar .elementor-location-header {
    top: 46px !important;
  }
}


/* ============================================
   32. LAZY LOADING PLACEHOLDER
   ============================================ */

img[loading="lazy"] {
  background: linear-gradient(135deg, var(--ocean), var(--deep));
}


/* ============================================
   33. WORDPRESS GUTENBERG BLOCKS STYLING
   ============================================ */

/* Gutenberg block spacing */
.wp-block {
  margin-bottom: 1.5rem;
}

/* Gutenberg buttons */
.wp-block-button__link {
  background: linear-gradient(135deg, var(--teal), var(--ring)) !important;
  color: var(--deep) !important;
  border-radius: var(--radius) !important;
  padding: 1rem 2rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: all var(--transition) !important;
}

.wp-block-button__link:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0, 209, 214, 0.4);
}

/* Gutenberg quote */
.wp-block-quote {
  background: var(--glass);
  backdrop-filter: blur(20px);
  border-left: 4px solid var(--teal);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 1.5rem 2rem;
  margin: 2rem 0;
  color: var(--ink);
}

/* Gutenberg code */
.wp-block-code {
  background: var(--ocean);
  border-radius: var(--radius);
  padding: 1.5rem;
  color: var(--ring);
}


/* ============================================
   34. PERFORMANCE OPTIMALISATIES
   ============================================ */

/* GPU acceleration voor animaties */
.elementor-motion-effects-element,
.hover-lift,
.blog-card,
.service-card {
  will-change: transform;
  transform: translateZ(0);
}

/* Smooth font rendering */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}


/* ============================================
   35. FIX VOOR VEELVOORKOMENDE CONFLICTEN
   ============================================ */

/* Zorg dat Elementor widgets niet conflicteren */
.elementor-widget-wrap {
  position: relative;
  z-index: 1;
}

/* Fix voor WooCommerce indien geïnstalleerd */
.woocommerce .button,
.woocommerce button.button {
  background: linear-gradient(135deg, var(--teal), var(--ring)) !important;
  color: var(--deep) !important;
  border-radius: var(--radius) !important;
}

/* Fix voor Yoast SEO breadcrumbs */
.yoast-breadcrumbs {
  color: var(--ink);
  padding: 1rem 0;
}

.yoast-breadcrumbs a {
  color: var(--teal);
}


/* ============================================
   36. CUSTOM UTILITY CLASSES
   ============================================ */

/* Text alignment */
.text-center { text-align: center !important; }
.text-left { text-align: left !important; }
.text-right { text-align: right !important; }

/* Display */
.d-none { display: none !important; }
.d-block { display: block !important; }
.d-flex { display: flex !important; }
.d-grid { display: grid !important; }

/* Margin helpers */
.mt-1 { margin-top: 1rem !important; }
.mt-2 { margin-top: 2rem !important; }
.mt-3 { margin-top: 3rem !important; }
.mb-1 { margin-bottom: 1rem !important; }
.mb-2 { margin-bottom: 2rem !important; }
.mb-3 { margin-bottom: 3rem !important; }

/* Padding helpers */
.pt-1 { padding-top: 1rem !important; }
.pt-2 { padding-top: 2rem !important; }
.pt-3 { padding-top: 3rem !important; }
.pb-1 { padding-bottom: 1rem !important; }
.pb-2 { padding-bottom: 2rem !important; }
.pb-3 { padding-bottom: 3rem !important; }

/* Color helpers */
.text-teal { color: var(--teal) !important; }
.text-ring { color: var(--ring) !important; }
.text-white { color: var(--white) !important; }
.text-ink { color: var(--ink) !important; }

.bg-deep { background-color: var(--deep) !important; }
.bg-ocean { background-color: var(--ocean) !important; }
.bg-glass { background: var(--glass) !important; }


/* ============================================
   EINDE VAN CSS
   Save dit bestand als: mirror-of-life-complete.css
   Of voeg toe via: Custom CSS and JS plugin
   ============================================ *//* End custom CSS */