/* ============================================================
   HOMEPAGE.CSS — Alleen geladen op front-page.php
   Hero, stats, diensten, werkwijze, over-ons, reviews, contact.
   ============================================================ */

/* ── HERO ── */
.hero, .sm-hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; padding-bottom: 6rem; }
.hero__bg, .sm-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; }
.hero__overlay, .sm-hero__overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(61,43,31,0.82) 0%, rgba(61,43,31,0.55) 60%, rgba(61,43,31,0.3) 100%); }
.hero__content, .sm-hero__content { position: relative; z-index: 2; padding-top: 6rem; max-width: 680px; }
.hero__badge, .sm-hero__badge { display: inline-flex; align-items: center; gap: 0.5rem; margin-bottom: 1.5rem; }
.hero__badge svg, .sm-hero__badge svg { width: 1rem; height: 1rem; color: var(--color-gold); }
.hero__title, .sm-hero__title { font-family: var(--font-display); font-size: clamp(2.8rem, 6vw, 5rem); font-weight: 700; color: white; line-height: 1.1; margin-bottom: 1.5rem; }
.hero__title em, .sm-hero__title em { font-style: italic; display: block; color: rgba(255,255,255,0.85); }
.hero__subtitle, .sm-hero__subtitle { font-family: var(--font-body); font-size: 1.125rem; color: rgba(255,255,255,0.88); line-height: 1.75; margin-bottom: 2rem; max-width: 560px; }
.hero__usps, .sm-hero__usps { display: flex; flex-wrap: wrap; gap: 1rem 2rem; margin-bottom: 2.5rem; list-style: none; }
.hero__usps li, .sm-hero__usps li { display: flex; align-items: center; gap: 0.5rem; font-family: var(--font-body); font-size: 0.9rem; font-weight: 600; color: rgba(255,255,255,0.9); }
.hero__usps svg, .sm-hero__usps svg { width: 1rem; height: 1rem; color: var(--color-gold); flex-shrink: 0; }
.hero__cta-group, .sm-hero__cta-group { display: flex; flex-wrap: wrap; gap: 1rem; }
.hero__scroll-indicator, .sm-hero__scroll-indicator { position: absolute; bottom: 6rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.25rem; color: rgba(255,255,255,0.7); font-family: var(--font-body); font-size: 0.75rem; font-weight: 600; animation: sm-bounce 2s infinite; }
.hero__scroll-indicator svg, .sm-hero__scroll-indicator svg { width: 1.25rem; height: 1.25rem; }
@keyframes sm-bounce { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(6px); } }

/* ── STATS BAR ── */
.stats-bar, .sm-stats-bar { background-color: var(--color-espresso); padding: 3rem 0; }
.stats-bar__grid, .sm-stats-bar__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }
.stat-item, .sm-stat-item { text-align: center; }
.stat-item__value, .sm-stat-item__value { display: block; font-family: var(--font-display); font-size: 2.5rem; font-weight: 700; color: var(--color-gold); line-height: 1; margin-bottom: 0.4rem; }
.stat-item__label, .sm-stat-item__label { display: block; font-family: var(--font-body); font-size: 0.875rem; font-weight: 600; color: rgba(255,255,255,0.75); }
@media (max-width: 768px) { .stats-bar__grid, .sm-stats-bar__grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; } }

/* ── WERKWIJZE ── */
.werkwijze__inner, .sm-werkwijze__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.werkwijze__title, .sm-werkwijze__title { font-size: clamp(2rem, 4vw, 3rem); color: white; margin-top: 1rem; margin-bottom: 1.25rem; line-height: 1.15; }
.werkwijze__title-italic, .sm-werkwijze__title-italic { font-style: italic; display: block; color: var(--color-gold); }
.werkwijze__desc, .sm-werkwijze__desc { color: rgba(255,255,255,0.75); margin-bottom: 2rem; }
.werkwijze__cta-group, .sm-werkwijze__cta-group { display: flex; flex-wrap: wrap; gap: 1rem; }
.werkwijze__steps, .sm-werkwijze__steps { list-style: none; display: flex; flex-direction: column; gap: 1.75rem; }
.werkwijze__step, .sm-werkwijze__step { display: flex; gap: 1.25rem; align-items: flex-start; }
.werkwijze__step-nr, .sm-werkwijze__step-nr { flex-shrink: 0; width: 3.5rem; height: 3.5rem; border-radius: 50%; background-color: var(--color-terracotta); color: white; font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.werkwijze__step-title, .sm-werkwijze__step-title { font-family: var(--font-display); font-size: 1.2rem; color: white; margin-bottom: 0.4rem; }
.werkwijze__step-text, .sm-werkwijze__step-text { font-size: 0.9375rem; color: rgba(255,255,255,0.7); margin: 0; }
@media (max-width: 900px) { .werkwijze__inner, .sm-werkwijze__inner { grid-template-columns: 1fr; gap: 3rem; } }

/* ── OVER ONS (homepage) ── */
.over-ons__inner, .sm-over-ons__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.over-ons__image-wrap, .sm-over-ons__image-wrap { position: relative; }
.over-ons__image, .sm-over-ons__image { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); }
.over-ons__badge, .sm-over-ons__badge { position: absolute; bottom: -1.5rem; right: -1.5rem; background-color: var(--color-terracotta); color: white; padding: 1.25rem 1.5rem; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); text-align: center; }
.over-ons__badge-nr, .sm-over-ons__badge-nr { display: block; font-family: var(--font-display); font-size: 2rem; font-weight: 700; line-height: 1; }
.over-ons__badge-label, .sm-over-ons__badge-label { display: block; font-family: var(--font-body); font-size: 0.75rem; font-weight: 600; opacity: 0.9; margin-top: 0.2rem; }
.over-ons__title, .sm-over-ons__title { font-size: clamp(2rem, 4vw, 3rem); margin-top: 1rem; margin-bottom: 1.25rem; line-height: 1.15; }
.over-ons__title-italic, .sm-over-ons__title-italic { font-style: italic; display: block; color: var(--color-terracotta); }
@media (max-width: 900px) { .over-ons__inner, .sm-over-ons__inner { grid-template-columns: 1fr; gap: 3rem; } .over-ons__badge, .sm-over-ons__badge { bottom: -1rem; right: -0.5rem; } }
