* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'Helvetica Neue', Arial, sans-serif; color: #1B2A47; background: #fff; min-width: 1200px; }
.container { width: 1200px; margin: 0 auto; padding: 0 40px; }

/* Concept banner */
.concept-banner { background: #E8932E; color: #1B2A47; text-align: center; padding: 10px; font-size: 13px; font-weight: 500; }

/* Logo */
.logo { display: inline-block; }
.logo-text { font-size: 20px; font-weight: 700; letter-spacing: 2px; color: #1B2A47; }
.logo-line { display: flex; align-items: center; gap: 6px; margin-top: 2px; }
.logo-bar { height: 2px; background: #E8932E; flex: 1; }
.logo-circles { display: flex; gap: 4px; }
.logo-circle { width: 10px; height: 10px; border: 1.5px solid #1B2A47; border-radius: 50%; }

/* Header */
header { padding: 20px 0; border-bottom: 1px solid #eee; }
.header-content { display: flex; justify-content: space-between; align-items: center; }
nav ul { list-style: none; display: flex; gap: 30px; }
nav a { color: #1B2A47; text-decoration: none; font-size: 15px; font-weight: 500; }
nav a:hover { color: #E8932E; }
nav a.active { color: #E8932E; }
.header-phone { background: #1B2A47; color: #fff; padding: 10px 18px; border-radius: 4px; font-weight: 500; font-size: 14px; text-decoration: none; }

/* Buttons */
.btn-primary { background: #E8932E; color: #1B2A47; padding: 14px 28px; border: none; border-radius: 4px; font-weight: 600; font-size: 15px; cursor: pointer; text-decoration: none; display: inline-block; }
.btn-secondary { background: transparent; color: #fff; padding: 14px 28px; border: 2px solid #fff; border-radius: 4px; font-weight: 500; font-size: 15px; cursor: pointer; text-decoration: none; display: inline-block; }
.btn-dark { background: #1B2A47; color: #fff; padding: 14px 28px; border: none; border-radius: 4px; font-weight: 600; font-size: 15px; cursor: pointer; text-decoration: none; display: inline-block; }
.btn-outline-dark { background: transparent; color: #1B2A47; padding: 14px 28px; border: 2px solid #1B2A47; border-radius: 4px; font-weight: 600; font-size: 15px; cursor: pointer; text-decoration: none; display: inline-block; }

/* Hero */
.hero { background: #1B2A47; color: #fff; padding: 70px 0; }
.hero-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 50px; align-items: center; }
.hero h1 { font-size: 42px; line-height: 1.2; margin-bottom: 20px; font-weight: 700; }
.hero h1 span { color: #E8932E; }
.hero p { font-size: 17px; line-height: 1.6; margin-bottom: 30px; opacity: 0.9; }
.hero-buttons { display: flex; gap: 12px; }
.hero-image { background: #2a3a5c; height: 280px; border-radius: 6px; display: flex; align-items: center; justify-content: center; color: #8a9bbf; font-size: 13px; border: 2px dashed #4a5a7c; }

/* Page hero (kleinere variant voor subpagina's) */
.page-hero { background: #1B2A47; color: #fff; padding: 50px 0; }
.page-hero h1 { font-size: 36px; margin-bottom: 10px; }
.page-hero h1 span { color: #E8932E; }
.page-hero p { font-size: 16px; opacity: 0.9; max-width: 700px; }

/* Trust bar */
.trust-bar { background: #f5f5f5; padding: 30px 0; }
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.trust-item { text-align: center; }
.trust-icon { width: 48px; height: 48px; background: #1B2A47; border-radius: 50%; margin: 0 auto 10px; display: flex; align-items: center; justify-content: center; color: #E8932E; font-size: 22px; font-weight: bold; }
.trust-title { font-weight: 600; font-size: 15px; margin-bottom: 4px; }
.trust-sub { font-size: 13px; color: #666; }

/* Sections */
section { padding: 70px 0; }
.section-title { font-size: 32px; margin-bottom: 12px; font-weight: 700; }
.section-subtitle { font-size: 16px; color: #666; margin-bottom: 40px; max-width: 700px; }
.accent { color: #E8932E; }
.section-light { background: #f9f9f9; }

/* Diensten cards */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.service-card { background: #fff; border: 1px solid #eee; padding: 30px; border-radius: 6px; }
.service-card h3 { font-size: 20px; margin-bottom: 12px; color: #1B2A47; }
.service-card p { font-size: 15px; line-height: 1.6; color: #555; margin-bottom: 12px; }
.service-card ul { list-style: none; padding: 0; }
.service-card li { font-size: 14px; color: #555; padding: 4px 0 4px 18px; position: relative; }
.service-card li:before { content: "✓"; color: #E8932E; position: absolute; left: 0; font-weight: bold; }
.service-tag { display: inline-block; background: #fff5e8; color: #E8932E; padding: 4px 10px; border-radius: 3px; font-size: 12px; font-weight: 600; margin-bottom: 12px; }

/* Werkwijze */
.steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.step { text-align: center; }
.step-number { width: 56px; height: 56px; background: #1B2A47; color: #E8932E; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 22px; font-weight: 700; margin: 0 auto 16px; }
.step h4 { font-size: 17px; margin-bottom: 8px; color: #1B2A47; }
.step p { font-size: 14px; color: #666; line-height: 1.5; }

/* Werkgebied */
.werkgebied-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.werkgebied p { font-size: 16px; line-height: 1.7; color: #444; margin-bottom: 14px; }
.werkgebied ul { list-style: none; margin-top: 16px; }
.werkgebied li { padding: 8px 0; font-size: 15px; color: #1B2A47; border-bottom: 1px solid #eee; }
.werkgebied li strong { color: #E8932E; }
.map-placeholder { background: #f0f0f0; height: 340px; border-radius: 6px; display: flex; align-items: center; justify-content: center; color: #888; font-size: 13px; border: 2px dashed #ccc; }

/* Reviews */
.reviews { background: #1B2A47; color: #fff; }
.reviews .section-title { color: #fff; }
.reviews .section-subtitle { color: #aab5cc; }
.reviews-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.review-placeholder { background: #243558; padding: 30px; border-radius: 6px; border: 2px dashed #4a5a7c; text-align: center; color: #aab5cc; font-size: 14px; }

/* Jeroen CTA (boven footer op elke pagina) */
.jeroen-cta { background: #f5f5f5; padding: 60px 0; }
.jeroen-cta-grid { display: grid; grid-template-columns: auto 1fr auto; gap: 40px; align-items: center; }
.jeroen-photo { width: 140px; height: 140px; border-radius: 50%; background: #ddd; display: flex; align-items: center; justify-content: center; color: #888; font-size: 12px; border: 3px dashed #bbb; text-align: center; padding: 10px; }
.jeroen-cta-text h3 { font-size: 24px; color: #1B2A47; margin-bottom: 8px; }
.jeroen-cta-text p { font-size: 15px; color: #555; line-height: 1.5; }
.jeroen-cta-buttons { display: flex; flex-direction: column; gap: 10px; }

/* Form */
.form-section { background: #f9f9f9; padding: 40px; border-radius: 6px; }
.form-row { margin-bottom: 16px; }
.form-row label { display: block; font-size: 14px; font-weight: 500; margin-bottom: 6px; color: #1B2A47; }
.form-row input, .form-row select, .form-row textarea { width: 100%; padding: 10px 12px; border: 1px solid #ddd; border-radius: 4px; font-size: 14px; font-family: inherit; background: #fff; }
.form-row textarea { min-height: 100px; resize: vertical; }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-checkbox { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: #666; margin: 16px 0; }
.form-checkbox input { width: auto; margin-top: 3px; }
.form-note { background: #fff5e8; padding: 14px 18px; border-left: 4px solid #E8932E; font-size: 14px; color: #1B2A47; margin: 16px 0; border-radius: 0 4px 4px 0; }
.submit-btn { background: #E8932E; color: #1B2A47; padding: 14px 32px; border: none; border-radius: 4px; font-weight: 600; font-size: 15px; cursor: pointer; }

/* Contact info */
.contact-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 50px; }
.contact-info h3 { font-size: 18px; margin-bottom: 16px; color: #1B2A47; }
.contact-item { padding: 12px 0; border-bottom: 1px solid #eee; }
.contact-item-label { font-size: 12px; color: #888; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 4px; }
.contact-item-value { font-size: 15px; color: #1B2A47; font-weight: 500; }
.whatsapp-btn { background: #25D366; color: #fff; padding: 12px 20px; border-radius: 4px; display: inline-block; text-decoration: none; font-weight: 500; font-size: 14px; margin-top: 12px; }

/* CTA section (oranje) */
.cta-section { background: #E8932E; padding: 60px 0; text-align: center; }
.cta-section h2 { font-size: 30px; color: #1B2A47; margin-bottom: 12px; }
.cta-section p { font-size: 16px; color: #1B2A47; margin-bottom: 26px; }
.cta-section .btn-primary { background: #1B2A47; color: #fff; padding: 16px 36px; font-size: 16px; }

/* FAQ */
.faq-item { background: #fff; border: 1px solid #eee; padding: 20px 24px; margin-bottom: 12px; border-radius: 6px; }
.faq-item h4 { font-size: 16px; color: #1B2A47; margin-bottom: 8px; }
.faq-item p { font-size: 14px; color: #555; line-height: 1.6; }

/* Footer */
footer { background: #1B2A47; color: #fff; padding: 50px 0 20px; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 40px; margin-bottom: 30px; }
.footer-col h4 { color: #E8932E; font-size: 14px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px; }
.footer-col p, .footer-col li { font-size: 14px; line-height: 1.7; color: #aab5cc; list-style: none; }
.footer-col a { color: #aab5cc; text-decoration: none; }
.footer-logo .logo-text { color: #fff; }
.footer-logo .logo-bar { background: #E8932E; }
.footer-logo .logo-circle { border-color: #fff; }
.footer-about { font-size: 14px; line-height: 1.7; color: #aab5cc; margin-top: 14px; }
.footer-bottom { border-top: 1px solid #2a3a5c; padding-top: 20px; display: flex; justify-content: space-between; font-size: 12px; color: #8a9bbf; }
