/*!********************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-14.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-14.use[2]!./src/assets/index.css ***!
  \********************************************************************************************************************************************************************/
@import url(https://unpkg.com/tailwindcss@^1.0/dist/tailwind.min.css);
/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./src/LandingPage.vue?vue&type=style&index=0&id=0b434add&scoped=true&lang=css ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************/

/* Global typography */
[data-v-0b434add] {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Critical styles voor LCP optimalisatie */
.hero-section[data-v-0b434add] {
  /* Voorkom layout shift */
  min-height: 100vh;
  background-color: #1e293b; /* Fallback */
  /* Zorg voor juiste spacing vanaf header */
  padding-top: 5rem;
  font-family: 'Inter', sans-serif;
}

/* Hero text styling - forceer witte tekst */
.hero-title[data-v-0b434add] {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}
.hero-text[data-v-0b434add] {
  color: #ffffff !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}
@media (min-width: 768px) {
.hero-section[data-v-0b434add] {
    min-height: 600px;
    padding-top: 6rem;
}
}
.section[data-v-0b434add] {
  /* Verbeterde spacing tussen secties */
  padding: 5rem 0;
  scroll-margin-top: 6rem;
  /* Voorkom layout shift door vaste afmetingen */
  contain: layout style;
  /* Zorg voor juiste z-index stacking */
  position: relative;
  z-index: 1;
}

/* Header styling voor betere layout */
header[data-v-0b434add] {
  /* Betere backdrop filter voor browser ondersteuning */
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background-color: rgba(255, 255, 255, 0.95);
  font-family: 'Inter', sans-serif;
}

/* Mobile spacing verbetering */
@media (max-width: 768px) {
.hero-section[data-v-0b434add] {
    min-height: 100vh;
    background-position: center center !important;
    padding-top: 4rem;
}
.section[data-v-0b434add] {
    padding: 3rem 0;
    scroll-margin-top: 5rem;
}
}

/* Performance optimalisaties */
.hero-section div[data-v-0b434add] {
  will-change: auto; /* Verminder GPU gebruik */
}

/* Preload animatie voor lazy components */
@keyframes spin-0b434add {
to {
    transform: rotate(360deg);
}
}
.animate-spin[data-v-0b434add] {
  animation: spin-0b434add 1s linear infinite;
}

/* Container styling voor betere layout flow */
main[data-v-0b434add] {
  position: relative;
  overflow-x: hidden; /* Voorkom horizontale scroll */
  font-family: 'Inter', sans-serif;
}

/* Consistent typography */
h1[data-v-0b434add], h2[data-v-0b434add], h3[data-v-0b434add], h4[data-v-0b434add], h5[data-v-0b434add], h6[data-v-0b434add] {
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: #111827;
}
p[data-v-0b434add] {
  font-family: 'Inter', sans-serif;
  line-height: 1.6;
  color: #4b5563;
}

/* Button typography */
button[data-v-0b434add], .btn[data-v-0b434add], a.btn[data-v-0b434add] {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: 0.025em;
}

/* Navigation typography */
nav a[data-v-0b434add] {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  letter-spacing: 0.025em;
}

/* Fix voor mobile menu overlapping */
.mobile-menu[data-v-0b434add] {
  background-color: white;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

/* Verbeterde button styling */
.btn-primary[data-v-0b434add] {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  transition: all 0.3s ease;
  font-family: 'Inter', sans-serif;
}
.btn-primary[data-v-0b434add]:hover {
  background: linear-gradient(135deg, #1d4ed8, #1e40af);
  transform: translateY(-1px);
  box-shadow: 0 10px 25px rgba(37, 99, 235, 0.3);
}

/* Consistent spacing voor cards */
.card[data-v-0b434add] {
  margin-bottom: 1.5rem;
}

/* Smooth scrolling voor alle links */
html[data-v-0b434add] {
  scroll-behavior: smooth;
}

/* Focus states voor accessibility */
a[data-v-0b434add]:focus,
button[data-v-0b434add]:focus {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

/* Responsive font sizes */
@media (max-width: 640px) {
h1[data-v-0b434add] {
    font-size: 2.5rem;
    line-height: 1.1;
}
h2[data-v-0b434add] {
    font-size: 1.875rem;
    line-height: 1.2;
}
h3[data-v-0b434add] {
    font-size: 1.5rem;
    line-height: 1.3;
}
}
@media (min-width: 641px) and (max-width: 1024px) {
h1[data-v-0b434add] {
    font-size: 3.5rem;
    line-height: 1.1;
}
h2[data-v-0b434add] {
    font-size: 2.25rem;
    line-height: 1.2;
}
h3[data-v-0b434add] {
    font-size: 1.75rem;
    line-height: 1.3;
}
}
@media (min-width: 1025px) {
h1[data-v-0b434add] {
    font-size: 4rem;
    line-height: 1.1;
}
h2[data-v-0b434add] {
    font-size: 2.5rem;
    line-height: 1.2;
}
h3[data-v-0b434add] {
    font-size: 2rem;
    line-height: 1.3;
}
}

/*!********************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-12.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-12.use[2]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./src/App.vue?vue&type=style&index=0&id=7ba5bd90&lang=css ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************/

body {
  margin: 0;
  padding: 0;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/*!************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??clonedRuleSet-14.use[1]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-14.use[2]!./src/assets/index.css (1) ***!
  \************************************************************************************************************************************************************************/
@tailwind base;
@tailwind components;
@tailwind utilities;

/* Custom styles can go here */
.hero-section {
  opacity: 0;
  transition: opacity 0.3s ease-in;
}

.hero-section.loaded {
  opacity: 1;
}

@keyframes fade-in {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

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

.gpu-accelerated {
  transform: translateZ(0);
  will-change: transform;
  backface-visibility: hidden;
}

.group:hover .group-hover\:translate-x-1 {
  transform: translateX(0.25rem);
}

.group:hover .group-hover\:scale-110 {
  transform: scale(1.1);
}

