:root {
    --brand-blue: #1d4ed8;
    --brand-ink: #050a14;
    --brand-ink-light: #0d1525;
    --brand-warm: #f28a24;
    
    --bg-primary: #050a14;
    --bg-secondary: #0d1525;
    
    --text-main: #ffffff;
    --text-muted: #94a3b8;
    --text-light: #e2e8f0;
}

html, body {
    margin: 0; padding: 0;
    font-family: 'Manrope', sans-serif;
    background-color: var(--bg-primary) !important;
    color: var(--text-main);
    overflow-x: hidden;
}

/* Texture overlay to remove flat empty feeling */
body::after {
    content: ""; position: fixed; top: 0; left: 0; width: 100vw; height: 100vh;
    background-image: url('data:image/svg+xml,%3Csvg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg"%3E%3Cfilter id="noiseFilter"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.65" numOctaves="3" stitchTiles="stitch"/%3E%3C/filter%3E%3Crect width="100%25" height="100%25" filter="url(%23noiseFilter)"/%3E%3C/svg%3E');
    opacity: 0.03; pointer-events: none; z-index: 9999;
}

h1, h2, h3 { font-family: 'Outfit', sans-serif; margin: 0; line-height: 1.1; letter-spacing: -0.02em; }
a { text-decoration: none; color: inherit; }

/* Giant ambient glows so the screen is NEVER empty */
.glow-bg {
    position: fixed; border-radius: 50%; filter: blur(150px); z-index: 0; opacity: 0.4; pointer-events: none;
}
.glow-1 { top: -10vw; left: -10vw; width: 50vw; height: 50vw; background: var(--brand-blue); animation: float 10s infinite alternate ease-in-out; }
.glow-2 { bottom: -10vw; right: -10vw; width: 60vw; height: 60vw; background: var(--brand-warm); opacity: 0.2; animation: float 15s infinite alternate-reverse ease-in-out; }

/* Massive Background text filling empty space */
.bg-text {
    position: fixed; top: 15%; left: -10%; font-size: 25vw; font-family: 'Outfit'; font-weight: 900;
    color: transparent; -webkit-text-stroke: 2px rgba(255,255,255,0.03); white-space: nowrap;
    z-index: 0; pointer-events: none; user-select: none;
}

@keyframes float { 0% { transform: translateY(0) scale(1); } 100% { transform: translateY(-50px) scale(1.1); } }

/* Hero */
.hero {
    position: relative; height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center;
    z-index: 5; text-align: center; padding: 0 2rem;
}
.hero h1 {
    font-size: clamp(3.5rem, 8vw, 7rem); font-weight: 900; color: #fff; margin-bottom: 2rem;
    text-shadow: 0 10px 30px rgba(0,0,0,0.5); z-index: 2; position: relative;
}
.hero .highlight { color: var(--brand-blue); }
.hero p {
    font-size: clamp(1.3rem, 3vw, 1.8rem); color: var(--text-light); max-width: 800px;
    margin: 0 auto 3rem; line-height: 1.6; z-index: 2; position: relative; font-weight: 500;
}

/* Action button */
.btn-super {
    display: inline-flex; align-items: center; gap: 1rem;
    background: var(--brand-blue); color: #fff; padding: 1.5rem 3rem; border-radius: 100px;
    font-family: 'Outfit'; font-weight: 800; font-size: 1.3rem;
    box-shadow: 0 20px 40px rgba(29, 78, 216, 0.4), inset 0 2px 0 rgba(255,255,255,0.2);
    transition: all 0.3s; z-index: 2; position: relative; border: none; cursor: pointer;
}
.btn-super:hover { transform: translateY(-5px) scale(1.02); box-shadow: 0 25px 50px rgba(29, 78, 216, 0.6), inset 0 2px 0 rgba(255,255,255,0.2); }

/* Horizontal Slider section replaced with deeply readable Image Cards */
.services-section {
    position: relative; z-index: 5; padding: 5rem 0 10rem;
}
.s-header { text-align: center; margin-bottom: 6rem; padding: 0 2rem; }
.s-header h2 { font-size: clamp(3rem, 6vw, 5rem); color: #fff; margin-bottom: 1.5rem; }
.s-header p { font-size: 1.4rem; color: var(--text-light); max-width: 700px; margin: 0 auto; line-height: 1.6; }

/* The new smooth scroll gallery trick (replaces horrible zoom mask) */
.gallery-track {
    display: flex; gap: 3rem; padding: 0 5vw; overflow-x: hidden; position: relative;
}
.g-card {
    flex: 0 0 500px; height: 650px; border-radius: 40px; position: relative; overflow: hidden;
    display: flex; flex-direction: column; justify-content: flex-end; padding: 3rem;
    box-shadow: 0 30px 60px rgba(0,0,0,0.5); border: 1px solid rgba(255,255,255,0.1);
    transform-origin: center;
}
/* Beautiful Dark Overlays for ultimate readability */
.g-card::before {
    content:''; position: absolute; inset:0; 
    background: linear-gradient(to top, rgba(5,10,20,1) 0%, rgba(5,10,20,0.4) 50%, rgba(5,10,20,0.1) 100%);
    z-index: 1; pointer-events: none;
}
.g-bg {
    position: absolute; inset: -10%; width: 120%; height: 120%; background-size: cover; background-position: center;
    z-index: 0; transition: transform 0.5s; /* We bind parallax to this via JS */
}
.g-content { position: relative; z-index: 2; }
.g-content h3 { font-size: 2.5rem; color: #fff; margin-bottom: 1rem; }
.g-content p { font-size: 1.3rem; color: #e2e8f0; line-height: 1.6; margin-bottom: 2rem; font-weight: 500; }
.g-list { list-style: none; padding: 0; margin: 0; }
.g-list li { font-size: 1.2rem; color: #fff; margin-bottom: 1rem; display: flex; align-items: center; gap: 12px; font-weight: 600; }
.g-list li i { color: #10b981; font-size: 1.4rem; }

/* Simple, massive alternating blocks (Removes empty space completely) */
.alt-section {
    padding: 10rem 2rem; position: relative; z-index: 5;
    background: var(--brand-ink-light); border-top: 1px solid rgba(255,255,255,0.05); border-bottom: 1px solid rgba(255,255,255,0.05);
}
.alt-container { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; }

.alt-content h2 { font-size: clamp(3rem, 5vw, 4.5rem); margin-bottom: 2rem; }
.alt-content p { font-size: 1.4rem; color: var(--text-light); line-height: 1.7; margin-bottom: 2rem; }
.alt-content ul { padding-left: 0; list-style: none; }
.alt-content ul li { font-size: 1.3rem; margin-bottom: 1.2rem; color: #fff; display: flex; align-items: center; gap: 15px; background: rgba(255,255,255,0.03); padding: 1rem 1.5rem; border-radius: 15px; border: 1px solid rgba(255,255,255,0.05); }
.alt-content ul li i { color: var(--brand-warm); font-size: 1.5rem; }

.alt-img-wrap { position: relative; width: 100%; height: 600px; border-radius: 40px; overflow: hidden; background: #000; box-shadow: 0 30px 60px rgba(0,0,0,0.5); }
.alt-img { position: absolute; top: -10%; left: -10%; width: 120%; height: 120%; background-size: cover; background-position: center; }

/* Routekaart Stappenplan - Extremely simple */
.steps-section { padding: 10rem 2rem; position: relative; z-index: 5; }
.step-container { max-width: 900px; margin: 0 auto; }
.step-box { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.1); border-radius: 30px; padding: 4rem; margin-bottom: 3rem; display: flex; gap: 3rem; align-items: flex-start; backdrop-filter: blur(10px); }
.step-num { font-size: 4rem; font-family: 'Outfit'; font-weight: 900; color: var(--brand-blue); line-height: 1; flex-shrink: 0; }
.step-text h3 { font-size: 2.5rem; color: #fff; margin-bottom: 1rem; }
.step-text p { font-size: 1.3rem; color: var(--text-light); line-height: 1.6; }

/* FAQ Clean & Simple */
.faq-section { padding: 5rem 2rem 10rem; position: relative; z-index: 5; }
.faq-wrap { max-width: 900px; margin: 0 auto; }
.faq-wrap h2 { font-size: 3.5rem; text-align: center; margin-bottom: 4rem; }
details.faq-item { border-bottom: 1px solid rgba(255,255,255,0.1); padding: 2rem 0; cursor: pointer; }
summary { font-size: 1.4rem; font-weight: 700; display: flex; justify-content: space-between; align-items: center; list-style: none; color: #fff; }
summary::-webkit-details-marker { display: none; }
.faq-icon { color: var(--brand-warm); transition: 0.3s; font-size: 1.5rem; }
details[open] .faq-icon { transform: rotate(45deg); }
details.faq-item p { font-size: 1.25rem; color: var(--text-light); margin: 1.5rem 0 0; line-height: 1.6; }

/* Responsive */
@media (max-width: 1024px) {
    .alt-container { grid-template-columns: 1fr; }
    .alt-img-wrap { height: 400px; }
    .g-card { flex: 0 0 400px; height: 500px; padding: 2rem; }
}

@media (max-width: 768px) {
    .bg-text { font-size: 40vw; top: 30%; }
    .hero h1 { font-size: 3.5rem; }
    .step-box { flex-direction: column; gap: 1.5rem; padding: 2.5rem; }
    .g-card { flex: 0 0 85vw; }
    .btn-super { width: 100%; justify-content: center; }
}
