/* Base Styles & Reset */
:root {
    --color-primary: #e10600;
    --color-accent: #ffd000;
    --brand-yellow: #FFD200;
    --color-dark: #111;
    --color-gray: #666;
    --color-light-gray: #f6f7f9;
    --color-white: #fff;

    --max-width: 1120px;
    --spacing-unit: 1rem; /* 16px */
}

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Poppins', sans-serif;
    font-size: 1rem; /* 16px base */
    line-height: 1.6;
    color: var(--color-dark);
    background-color: var(--color-white);
}

a {
    color: var(--color-primary);
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

ul {
    list-style: none;
}

/* Accessibility */
.skip-link {
    position: absolute;
    top: -9999px;
    left: -9999px;
    background-color: var(--color-primary);
    color: var(--color-white);
    padding: var(--spacing-unit);
    z-index: 9999;
}

.skip-link:focus {
    top: 0;
    left: 0;
    position: fixed;
}

/* Container */
.container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 calc(var(--spacing-unit) * 1.5); /* 24px padding */
}

@media (max-width: 768px) {
    .container {
        padding: 0 4%; /* 92% padding on mobile */
    }
}

/* Section Titles */
.section-title {
    font-size: 2.5rem;
    text-align: center;
    margin-bottom: calc(var(--spacing-unit) * 3);
    color: var(--color-dark);
}

/* Buttons */
.button {
    display: inline-block;
    padding: calc(var(--spacing-unit) * 0.75) calc(var(--spacing-unit) * 1.5);
    border-radius: 5px;
    font-weight: bold;
    text-align: center;
    cursor: pointer;
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
    border: 2px solid transparent;
}

.button--primary {
    background-color: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
}

.button--primary:hover,
.button--primary:focus {
    background-color: #c70500; /* Darkened primary */
    border-color: #c70500;
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

.button--secondary {
    background-color: var(--color-dark);
    color: var(--color-white);
    border-color: var(--color-dark);
}

.button--secondary:hover,
.button--secondary:focus {
    background-color: #222; /* Lightened dark */
    border-color: #222;
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

/* Header */
.header {
    background-color: var(--color-white);
    padding: var(--spacing-unit) 0;
    border-bottom: 1px solid var(--color-light-gray);
    position: sticky;
    top: 0;
    z-index: 1000;
    transition: transform 0.3s ease-in-out;
}

.header--hidden {
    transform: translateY(-100%);
}

.header__container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.header__logo img {
    height: 100px; /* Adjusted size */
}

.header__nav {
    display: flex;
    align-items: center;
}

.header__menu {
    display: flex;
    gap: calc(var(--spacing-unit) * 1.5);
}

.header__menu a {
    color: var(--color-dark);
    font-weight: 500;
    padding: calc(var(--spacing-unit) * 0.5) 0;
    position: relative;
}

.header__menu a::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 2px;
    background-color: var(--color-primary);
    transition: width 0.3s ease;
}

.header__menu a:hover::after,
.header__menu a:focus::after {
    width: 100%;
}

/* Electric Shock Animation */
@keyframes electric-shock {
  0% { transform: translate(0, 0); }
  10%, 30%, 50%, 70%, 90% { transform: translate(-1px, 1px); }
  20%, 40%, 60%, 80% { transform: translate(1px, -1px); }
  100% { transform: translate(0, 0); }
}

@keyframes lightning-glow {
    from {
        filter: drop-shadow(0 0 2px yellow);
    }
    to {
        filter: drop-shadow(0 0 10px yellow) drop-shadow(0 0 20px yellow);
    }
}

.header__cta-button {
    background-color: var(--color-primary);
    color: var(--color-white);
    padding: calc(var(--spacing-unit) * 0.75) calc(var(--spacing-unit) * 1.25);
    border-radius: 5px;
    font-weight: bold;
    white-space: nowrap;
    transition: transform 0.2s ease-in-out;
    position: relative;
    min-width: 150px;
    min-height: 40px;
}

.header__cta-button .button-text {
    transition: opacity 0.3s ease-in-out;
}

.header__cta-button:hover .button-text {
    opacity: 0;
}

.lightning-bolt {
    display: none;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s ease-in-out;
}

.header__cta-button:hover .lightning-bolt {
    display: block;
    animation: lightning-glow 1s infinite alternate;
}

.header__cta-button:hover,
.header__cta-button:focus {
    background-color: #c70500;
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

.header__nav-toggle {
    display: none; /* Hidden by default on desktop */
    background: none;
    border: none;
    font-size: 2rem;
    cursor: pointer;
    color: var(--color-dark);
    padding: 0.5rem;
}



.header__nav-toggle-icon {
    display: block;
    width: 30px;
    height: 3px;
    background-color: var(--color-dark);
    position: relative;
    transition: transform 0.3s ease;
}

.header__nav-toggle-icon::before, .header__nav-toggle-icon::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 3px;
    background-color: var(--color-dark);
    transition: transform 0.3s ease;
}

.header__nav-toggle-icon::before {
    top: -10px;
}

.header__nav-toggle-icon::after {
    top: 10px;
}

/* Mobile Navigation */
@media (max-width: 768px) {
    .header {
        padding: calc(var(--spacing-unit) * 0.5) 0;
    }

    .header__logo img {
        height: 140px;
    }

    .header__container {
        padding-top: 0;
        padding-bottom: 0;
    }

    .header__nav-toggle {
        display: block;
    }

    .header__menu {
        flex-direction: column;
        width: 100%;
        background-color: var(--color-white);
        position: absolute;
        top: 100%;
        left: 0;
        border-top: 1px solid var(--color-light-gray);
        padding: 0;
        box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        max-height: 0;
        opacity: 0;
        overflow: hidden;
        visibility: hidden;
        transition: max-height 0.5s ease-in-out, opacity 0.5s ease-in-out, visibility 0.5s ease-in-out, padding 0.5s ease-in-out;
    }

    .header__menu.is-open {
        display: flex;
        max-height: 500px; /* Adjust as needed */
        opacity: 1;
        visibility: visible;
        padding: var(--spacing-unit) 0;
    }

    .header__menu li {
        text-align: center;
        padding: var(--spacing-unit) 0;
    }

    .header__menu a {
        font-size: 1.2rem;
        padding: var(--spacing-unit) 0;
        display: block;
    }

    .header__cta-button {
        margin-top: calc(var(--spacing-unit) * 2);
        width: 100%;
        text-align: center;
    }
}

/* Hero Section */
.hero {
    background-color: var(--color-primary);
    padding: calc(var(--spacing-unit) * 4) 0;
    color: var(--color-white);
}

.hero__container {
    display: flex;
    align-items: center;
    gap: calc(var(--spacing-unit) * 3);
}

.hero__content {
    flex: 1;
}

.hero__title {
    font-size: 3.5rem;
    line-height: 1.1;
    margin-bottom: var(--spacing-unit);
    color: var(--color-white);
}

@media (max-width: 1024px) {
    .hero__title {
        font-size: 3rem;
    }
}

@media (max-width: 768px) {
    .hero__title {
        font-size: 2.5rem;
    }
}

.hero__description {
    font-size: 1.25rem;
    margin-bottom: calc(var(--spacing-unit) * 2);
    color: var(--color-white);
}

.hero__actions {
    display: flex;
    gap: var(--spacing-unit);
    margin-bottom: calc(var(--spacing-unit) * 2);
    flex-wrap: wrap;
}

.hero__usp-list {
    list-style: none;
    font-size: 1.1rem;
    color: var(--color-white);
}

.hero__usp-list li {
    margin-bottom: calc(var(--spacing-unit) * 0.5);
}

.hero__image-wrapper {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

.hero__image {
    border-radius: 8px;
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
    max-height: 1500px; /* Make the image even larger */
    width: auto; /* Ensure aspect ratio is maintained */
}

@media (max-width: 768px) {
    .hero__container {
        flex-direction: column;
        text-align: center;
    }

    .hero__image-wrapper {
        margin-top: calc(var(--spacing-unit) * 2);
    }
}

/* Diensten Section */
.diensten, .service, .reviews, .tarieven, .contact { /* Combined padding for sections */
    
}

.diensten__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3 per row on desktop */
    gap: calc(var(--spacing-unit) * 2);
}

@media (max-width: 1024px) {
    .diensten__grid {
        grid-template-columns: repeat(2, 1fr); /* 2 per row on tablet */
    }
}

@media (max-width: 768px) {
    .diensten__grid {
        grid-template-columns: 1fr; /* 1 per row on mobile */
    }
}

.card { /* New class for individual service cards */
    background-color: var(--color-light-gray);
    padding: calc(var(--spacing-unit) * 2);
    border-radius: 8px;
    text-align: center;
    box-shadow: 0 4px 8px rgba(0,0,0,0.05);
}

.card .card-icon {
    display: flex;
    justify-content: center;
    margin-bottom: .6rem;
}

.card .card-icon img {
    width: 64px;
    height: 64px;
}

@media (max-width: 1024px) {
    .card .card-icon img {
        width: 48px;
        height: 48px;
    }
}

@media (max-width: 768px) {
    .card .card-icon img {
        width: 40px;
        height: 40px;
    }
}

.card h3 {
    color: #184a99; /* New color for titles */
    margin-bottom: var(--spacing-unit);
}

    .card p {
        color: #6b7280; /* New color for paragraphs */
    }


/* Service Section */
.service {
    background-color: var(--color-primary);
    color: var(--color-white);
    text-align: center;
    padding: calc(var(--spacing-unit) * 4) 0;
}

.service .section-title {
    color: var(--color-white);
}

.service p {
    font-size: 1.1rem;
    margin-bottom: calc(var(--spacing-unit) * 2);
}

.service__actions {
    display: flex;
    justify-content: center;
    gap: var(--spacing-unit);
    flex-wrap: wrap;
}

.service__actions .button--primary {
    background-color: var(--color-accent);
    border-color: var(--color-accent);
    color: var(--color-dark);
}

.service__actions .button--primary:hover,
.service__actions .button--primary:focus {
    background-color: #e6bb00; /* Darkened accent */
    border-color: #e6bb00;
}

.service__actions .button--secondary {
    background-color: transparent;
    border-color: var(--color-white);
    color: var(--color-white);
}

.service__actions .button--secondary:hover,
.service__actions .button--secondary:focus {
    background-color: rgba(255,255,255,0.1);
    border-color: var(--color-white);
}



/* Footer */
.footer {
    background-color: var(--color-dark);
    color: var(--color-white);
    padding: calc(var(--spacing-unit) * 3) 0;
    text-align: center;
}

.footer__container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-unit);
}

.footer__copyright, .footer__slogan {
    font-size: 0.9rem;
    color: rgba(255,255,255,0.7);
}

.footer__menu {
    display: flex;
    gap: calc(var(--spacing-unit) * 1.5);
    margin-top: var(--spacing-unit);
}

.footer__menu a {
    color: var(--color-primary);
    font-size: 0.9rem;
}

.footer__menu a:hover {
    color: var(--color-accent);
}

/* New Contact Pro Section Styles */
.section-contact{position:relative;overflow:hidden}
.contact-grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:2rem; align-items:start;
}
@media (max-width:900px){ .contact-grid{grid-template-columns:1fr} }

.contact-info h2{font-size:clamp(28px,3.2vw,40px);margin:.2rem 0 .6rem}
.contact-info .lead{color:var(--muted);max-width:46ch}
.info-list{list-style:none;padding:0;margin:1.25rem 0 0;display:grid;gap:1rem}
.info-list li{display:flex;gap:.9rem;align-items:flex-start}
.info-list .ico{width:40px;height:40px;display:grid;place-items:center;background:#fff;border:1px solid #eee;border-radius:.9rem;position:relative}
.info-list .ico svg{width:22px;height:22px;color:var(--brand)}
.info-list .ico.whats{background:#e8f8ef;border-color:#d6f1e2}
.info-list .ico.whats svg{color:#25d366}
.info-list .ico .ping{content:"";position:absolute;inset:-3px; border-radius:14px; border:2px solid #25d366; animation:ping 1.5s infinite}
@keyframes ping{0%{opacity:.9;transform:scale(.85)}100%{opacity:0;transform:scale(1.25)}}
.info-list a{color:var(--ink)}
.info-list a:hover{color:var(--brand);text-decoration:none}

.contact-card{
  position:relative;background:linear-gradient(180deg,#f9fafb,#f3f4f6);
  border:1px solid #eee;border-radius:16px;padding:1.25rem 1.25rem 1rem; overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.06);
}
.card-glow{position:absolute;inset:-40%; background:
  radial-gradient(800px 400px at 80% 10%, rgba(225,6,0,.08), transparent 60%),
  radial-gradient(700px 360px at 0% 100%, rgba(255,208,0,.10), transparent 55%);
  filter:saturate(1.1); pointer-events:none;
}
.card-title{color:var(--brand);margin:0 0 .75rem;font-size:1.15rem}

.fld{display:block;margin:.8rem 0}
.fld span{display:block;font-weight:600;margin:0 0 .35rem}
.fld input,.fld textarea{
  width:100%;padding:.7rem .9rem;border:1px solid #e5e7eb;border-radius:.7rem;
  background:#fff; color:var(--ink); transition:border .2s, box-shadow .2s, transform .06s;
}
.fld input:focus,.fld textarea:focus{
  outline:none;border-color:var(--brand); box-shadow:0 0 0 4px rgba(225,6,0,.12);
}
.fld .err{display:none;color:#b91c1c;font-size:.85rem;margin-top:.3rem}

.btn-row{display:flex;gap:.6rem;align-items:center;margin-top:.7rem;flex-wrap:wrap}
.btn{
  display:inline-grid;place-items:center;border:1px solid #111;padding:.7rem 1rem;border-radius:.8rem;
  font-weight:700; cursor:pointer; transition:transform .08s ease, filter .2s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff;position:relative;overflow:hidden}
.btn-primary::after{
  content:"";position:absolute;inset:0;background:
    linear-gradient(120deg, rgba(255,255,255,.0) 0%, rgba(255,255,255,.35) 35%, rgba(255,255,255,0) 70%);
  transform:translateX(-120%); transition:transform .7s ease;
}
.btn-primary:hover::after{transform:translateX(120%)}
.btn-ghost{background:transparent;border-color:#ddd;color:#111}
.btn-ghost:hover{background:var(--brand);border-color:var(--brand);color:#fff;filter:none}

.ripple{position:relative; overflow:hidden}
.ripple > i{
  position:absolute;border-radius:50%;transform:scale(0); animation:rip .6s ease-out;
  background:rgba(255,255,255,.5); pointer-events:none;
}
@keyframes rip{to{transform:scale(12);opacity:0}}

.toast{
  position:fixed;right:18px;bottom:18px;display:flex;gap:.5rem;align-items:center;
  background:#111;color:#fff;padding:.7rem 1rem;border-radius:.8rem;box-shadow:0 10px 25px rgba(0,0,0,.25)
}
.toast .ok{width:18px;height:18px;color:#22c55e}

/* In-view animaties */
[data-animate]{opacity:0;transform:translateY(18px);transition:opacity .5s ease, transform .5s ease}
[data-animate].in{opacity:1;transform:none}
[data-animate="fade-up-delayed"]{transition-delay:.15s}

/* Hero animatie container */
.hero-media{ background:#fff; border-radius:16px; overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.08); border:1px solid #eee }
 .hero-media img{ width:100%; height:100%; display:block; object-fit: cover; object-position: center center; }

/* Dynamische Diensten Grid */
.diensten__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
}

.svc-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 12px;
  padding: 1.5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,.05);
  transition: transform .2s ease, box-shadow .2s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
}
.svc-card:hover, .svc-card.kbd {
  transform: translateY(-5px) scale(1.01);
  box-shadow: 0 8px 20px rgba(0,0,0,.08);
}
.svc-card.kbd{ outline:2px solid var(--brand); outline-offset:2px }

.svc-ink {
  position: absolute;
  inset: -10%;
  background: radial-gradient(400px 200px at 50% 10%, rgba(225,6,0,.05), transparent 60%);
  filter: saturate(1.1);
  pointer-events: none;
  transition: transform .1s ease-out;
}

.svc-icon {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  background: var(--color-light-gray);
  border-radius: 50%;
  margin-bottom: 1rem;
  color: var(--color-primary);
  flex-shrink: 0;
}
.svc-icon svg {
  width: 28px;
  height: 28px;
  display: block;
  stroke: currentColor;
  fill: none;
}

.svc-card h3 {
  font-size: 1.3rem;
  margin-bottom: 0.5rem;
  color: var(--color-dark);
}

.svc-card p {
  font-size: 0.95rem;
  color: var(--color-gray);
  flex-grow: 1;
  margin-bottom: 1rem;
}

.svc-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: none;
  transition: gap .2s ease;
}
.svc-cta:hover {
  gap: 0.8rem;
  text-decoration: none;
}
.svc-cta .arr {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  transition: transform .2s ease;
}
.svc-cta:hover .arr {
  transform: translateX(3px);
}

/* Modal Styles */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1001;
}

.modal[hidden] {
    display: none;
}

.modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal-content {
    position: relative;
    background-color: var(--color-white);
    padding: calc(var(--spacing-unit) * 2);
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    max-width: 600px;
    width: 90%;
}

.modal-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: none;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--color-dark);
}

:root{
  --brand:#e10600; --accent:#ffd000; --ink:#111; --muted:#6b7280; --card:#f6f7f9;
}
.rv-title{ text-align:center; margin:0 0 .8rem; font-size:clamp(26px,3vw,36px) }

.rv-wrap{ position:relative; display:grid; grid-template-columns:auto 1fr auto; gap:.5rem; align-items:center }
.rv-nav{
  display:grid; place-items:center; width:44px; height:44px; border-radius:50%;
  border:1px solid #e5e7eb; background:#fff; color:#111; cursor:pointer;
  transition:transform .12s ease, background .2s ease, color .2s ease, border .2s ease;
}
.rv-nav:hover{ background:#111; color:#fff; border-color:#111 }
.rv-nav.prev .arr{ transform:scaleX(-1) }
.arr{ width:18px; height:18px }

.rv-viewport{ position:relative; background:linear-gradient(180deg,#fbfcfd,#f3f4f6); border:1px solid #eef0f2; border-radius:18px; overflow:hidden }
.rv-track{ display:grid; grid-auto-flow:column; grid-auto-columns:100%; align-items:stretch; }
.rv-slide{
  display:grid; grid-template-columns:56px 1fr; gap:1rem; align-items:center; padding:1.25rem 1.25rem 1.4rem;
}
 @media (max-width:640px){ .rv-slide{ grid-template-columns:1fr; } }

.rv-quote{
  width:56px; height:56px; display:grid; place-items:center; border-radius:50%;
  background:#fff; border:1px solid #e9ecef; color:#184a99; box-shadow:0 8px 18px (0,0,0,.06);
}
.rv-quote svg{ width:26px; height:26px }

.rv-body{ min-height:96px; display:grid; align-content:center; gap:.35rem }
.rv-text{ font-size:1.05rem; line-height:1.5; }
.rv-meta{ display:flex; flex-wrap:wrap; gap:.6rem; align-items:center; color:var(--muted) }
.rv-stars{ display:inline-flex; gap:2px; color:#ffd000 }
.rv-loc{ background:#fff; border:1px solid #eee; border-radius:.6rem; padding:.15rem .45rem; color:#111 }

.rv-progress{ position:absolute; left:0; right:0; bottom:0; height:3px; background:rgba(0,0,0,.05) }
.rv-progress span{ display:block; height:100%; width:0%; background:var(--brand) }

.rv-enter{ animation:rvIn .45s ease both }
.rv-exit{ animation:rvOut .45s ease both }
 @keyframes rvIn{ from{opacity:0; transform:translateX(6%)} to{opacity:1; transform:none} }
 @keyframes rvOut{ from{opacity:1; transform:none} to{opacity:0; transform:translateX(-6%)} }

/* in-view helper (optioneel als je dit al gebruikt) */
[data-animate]{opacity:0; transform:translateY(16px); transition:opacity .45s ease, transform .45s ease}
[data-animate].in{opacity:1; transform:none}



/* New Contact Pro Section Styles */
.section-contact{position:relative;overflow:hidden}
.contact-grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:2rem; align-items:start;
}
@media (max-width:900px){ .contact-grid{grid-template-columns:1fr} }

.contact-info h2{font-size:clamp(28px,3.2vw,40px);margin:.2rem 0 .6rem}
.contact-info .lead{color:var(--muted);max-width:46ch}
.info-list{list-style:none;padding:0;margin:1.25rem 0 0;display:grid;gap:1rem}
.info-list li{display:flex;gap:.9rem;align-items:flex-start}
.info-list .ico{width:40px;height:40px;display:grid;place-items:center;background:#fff;border:1px solid #eee;border-radius:.9rem;position:relative}
.info-list .ico svg{width:22px;height:22px;color:var(--brand)}
.info-list .ico.whats{background:#e8f8ef;border-color:#d6f1e2}
.info-list .ico.whats svg{color:#25d366}
.info-list .ico .ping{content:"";position:absolute;inset:-3px; border-radius:14px; border:2px solid #25d366; animation:ping 1.5s infinite}
@keyframes ping{0%{opacity:.9;transform:scale(.85)}100%{opacity:0;transform:scale(1.25)}}
.info-list a{color:var(--ink)}
.info-list a:hover{color:var(--brand);text-decoration:none}

.contact-card{
  position:relative;background:linear-gradient(180deg,#f9fafb,#f3f4f6);
  border:1px solid #eee;border-radius:16px;padding:1.25rem 1.25rem 1rem; overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.06);
}
.card-glow{position:absolute;inset:-40%; background:
  radial-gradient(800px 400px at 80% 10%, rgba(225,6,0,.08), transparent 60%),
  radial-gradient(700px 360px at 0% 100%, rgba(255,208,0,.10), transparent 55%);
  filter:saturate(1.1); pointer-events:none;
}
.card-title{color:var(--brand);margin:0 0 .75rem;font-size:1.15rem}

.fld{display:block;margin:.8rem 0}
.fld span{display:block;font-weight:600;margin:0 0 .35rem}
.fld input,.fld textarea{
  width:100%;padding:.7rem .9rem;border:1px solid #e5e7eb;border-radius:.7rem;
  background:#fff; color:var(--ink); transition:border .2s, box-shadow .2s, transform .06s;
}
.fld input:focus,.fld textarea:focus{
  outline:none;border-color:var(--brand); box-shadow:0 0 0 4px rgba(225,6,0,.12);
}
.fld .err{display:none;color:#b91c1c;font-size:.85rem;margin-top:.3rem}

.btn-row{display:flex;gap:.6rem;align-items:center;margin-top:.7rem;flex-wrap:wrap}
.btn{
  display:inline-grid;place-items:center;border:1px solid #111;padding:.7rem 1rem;border-radius:.8rem;
  font-weight:700; cursor:pointer; transition:transform .08s ease, filter .2s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff;position:relative;overflow:hidden}
.btn-primary::after{
  content:"";position:absolute;inset:0;background:
    linear-gradient(120deg, rgba(255,255,255,.0) 0%, rgba(255,255,255,.35) 35%, rgba(255,255,255,0) 70%);
  transform:translateX(-120%); transition:transform .7s ease;
}
.btn-primary:hover::after{transform:translateX(120%)}
.btn-ghost{background:transparent;border-color:#ddd;color:#111}
.btn-ghost:hover{background:var(--brand);border-color:var(--brand);color:#fff;filter:none}

.ripple{position:relative; overflow:hidden}
.ripple > i{
  position:absolute;border-radius:50%;transform:scale(0); animation:rip .6s ease-out;
  background:rgba(255,255,255,.5); pointer-events:none;
}
@keyframes rip{to{transform:scale(12);opacity:0}}

.toast{
  position:fixed;right:18px;bottom:18px;display:flex;gap:.5rem;align-items:center;
  background:#111;color:#fff;padding:.7rem 1rem;border-radius:.8rem;box-shadow:0 10px 25px rgba(0,0,0,.25)
}
.toast .ok{width:18px;height:18px;color:#22c55e}

/* In-view animaties */
[data-animate]{opacity:0;transform:translateY(18px);transition:opacity .5s ease, transform .5s ease}
[data-animate].in{opacity:1;transform:none}
[data-animate="fade-up-delayed"]{transition-delay:.15s}

.prices-title{ text-align:center; margin:0 0 .4rem; font-size:clamp(28px,3vw,40px) }
.prices-intro{ text-align:center; color:#6b7280; margin:0 auto 1.25rem }

.price-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1rem;
  max-width:1040px; margin:0 auto;
}
@media (max-width:900px){ .price-grid{ grid-template-columns:1fr } }

.price-card{
  background:linear-gradient(180deg,#ffffff,#f7f7f9);
  border:1px solid #edeff2; border-radius:16px; padding:1.1rem;
  box-shadow:0 14px 30px rgba(0,0,0,.05);
}
.price-card.alt{ background:linear-gradient(180deg,#fff6f6,#fafafa); border-color:#f0dede }
.price-card h3{ margin:.1rem 0 .25rem; color:#111 }
.price-card .sub{ color:#6b7280; margin:0 0 .6rem }
.price-list{ list-style:none; padding:0; margin:0 0 .8rem; display:grid; gap:.35rem; color:#1f2937 }
.price-list li{ background:#fff; border:1px solid #eceff2; border-radius:.6rem; padding:.45rem .6rem }

.price-cta{ display:flex; gap:.5rem; justify-content:flex-end }
@media (max-width:560px){ .price-cta{ justify-content:center } }

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:1px solid #111;padding:1.1rem .8rem;border-radius:.95rem;font-weight:700;cursor:pointer;transition:transform .08s,filter .2s}
.btn .arr{
  width:18px;height:18px; /* Consistent size */
  flex-shrink:0; /* Prevent shrinking */
  margin-left:.25rem; /* Small space between text and arrow */
  vertical-align:middle; /* Align with text baseline */
}
.btn .arr{
  width:18px;height:18px; /* Consistent size */
  flex-shrink:0; /* Prevent shrinking */
  margin-left:.25rem; /* Small space between text and arrow */
  vertical-align:middle; /* Align with text baseline */
}
.btn:active{ transform:translateY(1px) }
.btn-primary{ background:#e10600; border-color:#e10600; color:#fff }
.btn-primary:hover{ filter:brightness(.98) }

.btn-ghost{ background:#fff; border-color:#e5e7eb; color:#111 }
.btn-ghost:hover{ filter:brightness(.97) }

/* Zorg dat oude 3e knop geen ruimte meer inneemt als hij nog in DOM zou staan */
.price-card .btn.ask,
.price-card .btn--ask{ display:none !important; }

:root{
  /* pas aan als je header hoger/lager is */
  --header-height: 72px;
  --scroll-gap: 12px;
}

/* native smooth scroll; uit bij reduced-motion */
html:focus-within { scroll-behavior:smooth; }
 @media (prefers-reduced-motion: reduce){
  html:focus-within { scroll-behavior:auto; }
}

/* Laat secties netjes onder de header landen */
.scroll-anchor{
  scroll-margin-top: calc(var(--header-height) + var(--scroll-gap));
}

/* (optioneel) highlight kort de doel-sectie na scroll */
 @keyframes anchorFlash { from{box-shadow:0 0 0 0 rgba(225,6,0,.0)} 50%{box-shadow:0 0 0 6px rgba(225,6,0,.08)} to{box-shadow:0 0 0 0 rgba(225,6,0,.0)} }
.anchor-flash{ animation:anchorFlash .9s ease-out; border-radius:12px }


/* Voorkom ongewenste browsersprongen door anchoring/scroll-snapping */
html, body { overflow-anchor: none; }

/* ---------- Globale spacing-variabelen ---------- */
:root{
  --space-xl: clamp(36px, 4.5vw, 70px);  /* grote witruimte */
  --space-lg: clamp(28px, 3.5vw, 56px);  /* ruim */
  --space-md: clamp(14px, 2vw, 24px);   /* medium */
}

/* ---------- Extra witregel rond de gevraagde secties ---------- */
/* Boven & onder diensten */
#diensten{ margin-block: var(--space-lg); }

/* Wat klanten zeggen */
#reviews-hero{ margin-block: 0; }
/* Onze tarieven */
#tarieven{ margin-block: var(--space-xl); }
/* Contacteer ons / offerte */
#contact{ margin-block: var(--space-xl); }

/* Fallback: als secties een .section class hebben, geef nog iets extra lucht */
.section{ padding-block: var(--space-md); }



/* ---------- Kleine heading-ademruimte (boven/onder titels) ---------- */
:is(#diensten,#kaart-pro,#reviews-hero,#tarieven,#contact) h2{
  margin-block: 0 0.6rem;
}

/* New Button Styles */
.btn-call{
  background: var(--brand-yellow);
  color: var(--color-primary);
  border: 2px solid var(--brand-yellow);
  font-weight: 700;
  border-radius: 10px;
  padding: 12px 22px;
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
}
.btn-call:hover{
  transform: translateY(-1px) scale(1.03);
  box-shadow: 0 10px 18px rgba(0,0,0,.15);
  filter: brightness(0.98);
}
.btn-call:focus-visible{
  outline: 3px solid var(--color-primary);
  outline-offset: 2px;
}

.btn-quote{
  background: transparent;
  color: var(--brand-yellow);
  border: 2px solid var(--brand-yellow);
  font-weight: 700;
  border-radius: 10px;
  padding: 12px 22px;
  position: relative;
  overflow: hidden;
  transition: color .25s ease, transform .25s ease, box-shadow .25s ease;
}
.btn-quote:hover{
  color: var(--color-primary);
  transform: translateY(-1px) scale(1.03);
  box-shadow: 0 10px 18px rgba(0,0,0,.15);
}
.btn-quote::before{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(120deg,
              transparent 0%,
              rgba(255,255,255,.25) 20%,
              transparent 40%);
  transform: translateX(-120%);
  transition: transform .6s ease;
}
.btn-quote:hover::before{ transform: translateX(120%); }
.btn-quote::after{
  content: "";
  position: absolute; inset: 0;
  background: var(--brand-yellow);
  opacity: 0;
  transition: opacity .25s ease;
  z-index: -1;
}
.btn-quote:hover::after{ opacity: 1; }

.hero, .hero *{
  color: #fff; /* behoud wit op rode hero-achtergrond */
}
.btn-call, .btn-quote{ font-size: 16px; line-height: 1.1; }

.btn-quote:focus-visible{
  outline: 3px solid var(--brand-yellow);
  outline-offset: 2px;
}

/* Hero Media Styles */
.hero-media{
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  isolation: isolate;
  display: inline-block;
}
.hero-media img{
  display: block;
  width: 100%;
  height: auto;
  transition: transform .35s ease, filter .35s ease;
  will-change: transform;
}
.hero-media:hover img{
  transform: scale(1.06);
  filter: saturate(1.05) contrast(1.02);
}

@supports (-webkit-box-reflect: below 0){
  .hero-media img{
    -webkit-box-reflect: below 0
      linear-gradient(transparent, rgba(0,0,0,.05) 30%, rgba(0,0,0,.18));
  }
}

.hero-media:hover{
  box-shadow: 0 18px 36px rgba(0,0,0,.22);
}

/* Responsive Styles */
@media (max-width: 640px){
  .hero .cta-group{
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr;
  }
  .btn-call, .btn-quote{ width: 100%; }
  .hero-media{ width: 100%; }
  .hero-media::after{ display: none; }
}

.section--werkgebied { padding: clamp(2.5rem, 6vw, 5rem) 0; }

.werkgebied__title {
  color: var(--color-primary, #e10600); /* merk-rood */
  font-weight: 800;
  font-size: clamp(1.75rem, 2.5vw, 2.5rem);
  line-height: 1.15;
  margin: 0 0 1rem;
  text-align: center;
}

.werkgebied__intro {
  color: var(--color-text-muted, #555);
  font-size: clamp(1rem, 1.2vw, 1.125rem);
  margin: 0 0 2rem;
  text-align: center;
}

.werkgebied__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem clamp(1rem, 3vw, 2.5rem);
}

@media (min-width: 768px) {
  .werkgebied__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .werkgebied__grid { grid-template-columns: repeat(4, 1fr); }
}

.werkgebied__region {
  color: var(--color-heading, #111);
  font-weight: 800;
  font-size: 1.5rem;
  margin: 0 0 1rem;
}

.werkgebied__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .75rem;
  color: var(--color-text, #111);
  font-size: 1.0625rem;
}

.werkgebied__list li {
  display: flex;
  align-items: center;
  gap: .5rem;
}

/* Geel pin-icoon (SVG via CSS background) */
.pin {
  width: 16px; height: 16px; display: inline-block; flex: 0 0 16px;
  background: no-repeat center / contain
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23FFC400' d='M12 2a7 7 0 0 0-7 7c0 5.25 7 13 7 13s7-7.75 7-13a7 7 0 0 0-7-7z'/><circle cx='12' cy='9' r='2.5' fill='%23e10600'/></svg>");
}

.map-title{ text-align:center; margin:0; font-weight:800 }
.map-sub{ text-align:center; color:#6b7280; margin:.25rem 0 1rem }

.map-wrap{ position:relative; border-top:1px solid #eee; background:#f6f7f9; }
.map-canvas{
  width:100%;
  aspect-ratio: 16 / 4;
}
 @supports not (aspect-ratio: 16 / 4){
  .map-canvas{ height:25vw; max-height:520px; }
}

.map-legend{
  position:absolute; right:12px; top:12px; z-index:2;
  background:rgba(255,255,255,.92); border:1px solid #e5e7eb; border-radius:.6rem;
  padding:.35rem .6rem; font-size:.85rem; color:#111; backdrop-filter:saturate(1.1) blur(2px);
}
.lg{display:inline-block;width:12px;height:12px;border-radius:50%;vertical-align:middle;margin-right:.35rem}
.lg-focus{ background:#e10600 }
.lg-std{ border:2px solid #e10600; background:#fff }
.sep{ color:#9ca3af; margin:0 .4rem }

.gm-style .gm-style-iw-c{ border-radius:.6rem !important; }

#kaart-pro{ margin-top: 0; }
#kaart-pro :is(.map-wrap, .wg-map-wrap, .map-canvas){ margin-block-end: var(--space-lg); }

#service {
    padding-bottom: 4rem;
}



#kaart-pro {
    padding-top: 0;
}

.footer-company-link {
    display: inline-block; /* Required for transform to work correctly */
    transition: transform 0.3s ease-in-out;
    color: var(--color-primary); /* Ensure the link color is red */
    text-decoration: none; /* Remove underline by default */
}

.footer-company-link:hover {
    transform: scale(1.1);
    text-decoration: underline; /* Add underline on hover for better UX */
}

.hp-field{position:absolute;left:-9999px;opacity:0;width:1px;height:1px}
.form__status{margin-top:.75rem;font-weight:600}
.form__status--ok{color:#157f2e}.form__status--err{color:#c00}