/* ===== DIENST-PAGE COMPONENTS ===== */

.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94)}
.reveal.active{opacity:1;transform:none}

/* ===== BREADCRUMB ===== */
.breadcrumb{padding:96px 0 0;font-size:13px;color:var(--txt-light)}
.breadcrumb ol{list-style:none;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.breadcrumb li{display:flex;align-items:center;gap:8px}
.breadcrumb li:not(:last-child)::after{content:'/';color:var(--txt-light);opacity:.5}
.breadcrumb a{color:var(--txt-mid);transition:color .2s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb li:last-child{color:var(--black);font-weight:500}

/* ===== HERO ===== */
.dp-hero{padding:clamp(40px,5vw,72px) 0 clamp(40px,5vw,64px);text-align:center;max-width:880px}
.dp-hero__label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}
.dp-hero h1{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(36px,5.5vw,64px);font-weight:800;color:var(--black);line-height:1.05;letter-spacing:-.03em;margin-bottom:20px}
.dp-hero h1 span{color:var(--accent)}
.dp-hero__sub{font-size:clamp(15px,1.4vw,18px);color:var(--txt-mid);max-width:640px;margin:0 auto 32px;line-height:1.7}
.dp-hero__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:14px;font-weight:600;transition:all .25s;border:none;cursor:pointer;text-decoration:none}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(45,122,58,.25)}
.btn-outline{background:transparent;color:var(--txt);border:2px solid var(--border)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn svg{width:16px;height:16px;fill:currentColor}

/* ===== INTRO SPLIT ===== */
.dp-intro{padding:clamp(48px,6vw,80px) 0}
.dp-intro__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}
.dp-intro__text h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(26px,3vw,40px);font-weight:800;color:var(--black);line-height:1.15;letter-spacing:-.02em;margin-bottom:20px}
.dp-intro__text p{font-size:15px;line-height:1.85;color:var(--txt-mid);margin-bottom:16px}
.dp-intro__text p strong{color:var(--black);font-weight:600}
.dp-intro__text a{color:var(--accent);font-weight:600;border-bottom:1px solid rgba(45,122,58,.3);transition:border-color .2s}
.dp-intro__text a:hover{border-color:var(--accent)}
.dp-intro__img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.dp-intro__img img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/5}
@media(max-width:768px){.dp-intro__grid{grid-template-columns:1fr}.dp-intro__img img{aspect-ratio:16/10}}

/* ===== SUB-DIENSTEN / CARDS ===== */
.dp-cards{padding:clamp(48px,6vw,80px) 0}
.dp-cards__header{text-align:center;max-width:700px;margin:0 auto clamp(40px,5vw,56px)}
.dp-cards__label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px}
.dp-cards__header h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(28px,3.5vw,44px);font-weight:800;color:var(--black);line-height:1.1;margin-bottom:14px}
.dp-cards__header p{font-size:16px;color:var(--txt-mid);line-height:1.7}
.dp-cards__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(20px,2.5vw,28px)}
.dp-card{background:var(--card);border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column;color:inherit}
.dp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.dp-card__photo{height:220px;overflow:hidden}
.dp-card__photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.dp-card:hover .dp-card__photo img{transform:scale(1.05)}
.dp-card__body{padding:clamp(24px,3vw,32px);display:flex;flex-direction:column;gap:12px;flex:1}
.dp-card__body h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:22px;font-weight:800;color:var(--black);line-height:1.2}
.dp-card__body p{font-size:14px;line-height:1.7;color:var(--txt-mid);flex:1}
.dp-card__link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--accent);margin-top:8px}
.dp-card__link svg{width:14px;height:14px;fill:currentColor;transition:transform .25s}
.dp-card:hover .dp-card__link svg{transform:translateX(4px)}

/* ===== USP'S ===== */
.dp-usp{padding:clamp(48px,6vw,80px) 0}
.dp-usp__title{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(26px,3vw,40px);font-weight:800;color:var(--black);text-align:center;margin-bottom:clamp(32px,4vw,48px);letter-spacing:-.02em}
.dp-usp__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(20px,2.5vw,28px)}
.dp-usp__item{background:var(--card);padding:clamp(24px,3vw,32px);border-radius:var(--radius);transition:transform .3s,box-shadow .3s}
.dp-usp__item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.dp-usp__icon{font-size:32px;margin-bottom:14px;width:56px;height:56px;background:var(--green-glow);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}
.dp-usp__item h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:700;color:var(--black);margin-bottom:8px;line-height:1.25}
.dp-usp__item p{font-size:14px;line-height:1.7;color:var(--txt-mid)}

/* ===== FEATURES LIST ===== */
.dp-features{padding:clamp(48px,6vw,80px) 0;background:var(--card)}
.dp-features__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.dp-features__text h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(26px,3vw,40px);font-weight:800;color:var(--black);line-height:1.15;letter-spacing:-.02em;margin-bottom:16px}
.dp-features__text > p{font-size:15px;line-height:1.85;color:var(--txt-mid);margin-bottom:24px}
.dp-features__list{list-style:none;display:flex;flex-direction:column;gap:14px}
.dp-features__list li{display:flex;align-items:flex-start;gap:12px;font-size:15px;line-height:1.6;color:var(--black)}
.dp-features__list li strong{display:block;font-weight:700;margin-bottom:2px}
.dp-features__list li span{color:var(--txt-mid);font-weight:400;font-size:14px}
.dp-features__list svg{width:22px;height:22px;fill:var(--accent);flex-shrink:0;margin-top:1px}
.dp-features__img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.dp-features__img img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3}
@media(max-width:768px){.dp-features__inner{grid-template-columns:1fr}}

/* ===== HOW IT WORKS ===== */
.dp-how{padding:clamp(64px,8vw,100px) 0}
.dp-how__header{text-align:center;margin-bottom:clamp(48px,5vw,72px)}
.dp-how__label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px}
.dp-how__title{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(28px,3.5vw,42px);font-weight:800;color:var(--black);letter-spacing:-.02em}
.dp-how__steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px}
.dp-how__step{text-align:center;padding:0 12px}
.dp-how__step-num{width:56px;height:56px;border-radius:var(--radius);background:var(--green-glow);border:2px solid rgba(45,122,58,.15);color:var(--accent);font-family:'Plus Jakarta Sans',sans-serif;font-size:22px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.dp-how__step h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:700;color:var(--black);margin-bottom:8px}
.dp-how__step p{font-size:13px;line-height:1.7;color:var(--txt-mid)}

/* ===== FAQ ===== */
.dp-faq{padding:clamp(64px,8vw,100px) 0;background:var(--card)}
.dp-faq__inner{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,6vw,72px);align-items:start}
.dp-faq__header h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(24px,3vw,36px);font-weight:800;color:var(--black);margin-bottom:12px;line-height:1.15;letter-spacing:-.02em}
.dp-faq__header p{font-size:15px;line-height:1.7;color:var(--txt-mid)}
.dp-faq__list{display:flex;flex-direction:column;gap:12px}
.faq__item{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:border-color .3s;background:#fff}
.faq__item:hover{border-color:var(--accent)}
.faq__q{width:100%;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;font-size:15px;font-weight:600;color:var(--black);cursor:pointer;background:none;border:none;text-align:left;font-family:'Inter',sans-serif;gap:12px}
.faq__q svg{width:20px;height:20px;fill:var(--txt-light);transition:transform .3s;flex-shrink:0}
.faq__a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq__a p{padding:0 24px 20px;font-size:14px;line-height:1.75;color:var(--txt-mid)}
.faq__item.open .faq__q svg{transform:rotate(180deg)}
.faq__item.open .faq__a{max-height:600px}
@media(max-width:768px){.dp-faq__inner{grid-template-columns:1fr}}

/* ===== GALLERY ===== */
.dp-gallery{padding:clamp(48px,6vw,80px) 0}
.dp-gallery__header{text-align:center;max-width:680px;margin:0 auto clamp(32px,4vw,48px)}
.dp-gallery__label{font-size:12px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px}
.dp-gallery__header h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(26px,3vw,40px);font-weight:800;color:var(--black);line-height:1.15;letter-spacing:-.02em;margin-bottom:14px}
.dp-gallery__header p{font-size:15px;color:var(--txt-mid);line-height:1.7}
.dp-gallery__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;grid-template-rows:repeat(2,minmax(220px,1fr));gap:clamp(12px,1.5vw,16px)}
.dp-gallery__item{border-radius:var(--radius);overflow:hidden;position:relative;background:var(--card)}
.dp-gallery__item:nth-child(1){grid-row:span 2}
.dp-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.25,.46,.45,.94);display:block}
.dp-gallery__item:hover img{transform:scale(1.04)}
.dp-gallery__item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(26,46,26,.35));opacity:0;transition:opacity .3s;pointer-events:none}
.dp-gallery__item:hover::after{opacity:1}
.dp-gallery__caption{position:absolute;left:18px;right:18px;bottom:14px;color:#fff;font-size:13px;font-weight:600;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s;z-index:1;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.dp-gallery__item:hover .dp-gallery__caption{opacity:1;transform:translateY(0)}
@media(max-width:900px){.dp-gallery__grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,200px)}.dp-gallery__item:nth-child(1){grid-column:span 2;grid-row:auto}}
@media(max-width:560px){.dp-gallery__grid{grid-template-columns:1fr;grid-template-rows:none}.dp-gallery__item:nth-child(1){grid-column:auto}.dp-gallery__item{height:240px}}

/* ===== RELATED / NEXT STEPS ===== */
.dp-related{padding:clamp(48px,6vw,80px) 0}
.dp-related__header{text-align:center;margin-bottom:clamp(32px,4vw,48px)}
.dp-related__header h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(24px,3vw,36px);font-weight:800;color:var(--black);letter-spacing:-.02em}
.dp-related__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:clamp(16px,2vw,20px)}
.dp-related__card{background:var(--card);padding:24px;border-radius:var(--radius);transition:transform .25s,box-shadow .25s;color:inherit;display:flex;flex-direction:column;gap:8px}
.dp-related__card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.dp-related__card h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:700;color:var(--black)}
.dp-related__card p{font-size:13px;line-height:1.6;color:var(--txt-mid)}
.dp-related__card span{font-size:13px;font-weight:600;color:var(--accent);margin-top:auto;padding-top:8px;display:inline-flex;align-items:center;gap:6px}
.dp-related__card svg{width:12px;height:12px;fill:currentColor;transition:transform .25s}
.dp-related__card:hover svg{transform:translateX(3px)}

/* ===== CTA ===== */
.dp-cta{padding:clamp(80px,10vw,120px) 0;text-align:center;position:relative;overflow:hidden}
.dp-cta__bg{position:absolute;inset:0;z-index:0}
.dp-cta__bg img{width:100%;height:100%;object-fit:cover}
.dp-cta__bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,92,42,.88),rgba(26,46,26,.92))}
.dp-cta__content{position:relative;z-index:2}
.dp-cta h2{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(30px,4vw,52px);font-weight:800;color:#fff;line-height:1.1;letter-spacing:-.03em;margin-bottom:20px}
.dp-cta h2 span{color:var(--accent-light)}
.dp-cta__sub{font-size:17px;color:rgba(255,255,255,.7);max-width:500px;margin:0 auto 36px;line-height:1.7}
.dp-cta__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-white{background:rgba(255,255,255,.12);color:#fff;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);padding:14px 28px;border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:14px;font-weight:600;transition:all .25s;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.btn-white:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}

/* ===== STICKY CTA (MOBILE) ===== */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:rgba(250,252,248,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);padding:10px 16px;gap:8px}
.sticky-cta a{flex:1;text-align:center;padding:12px;border-radius:var(--radius);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px;text-decoration:none}
.sticky-cta .btn-call{background:var(--accent);color:#fff}
.sticky-cta .btn-email{background:var(--card);color:var(--black)}
.sticky-cta svg{width:16px;height:16px;fill:currentColor}
@media(max-width:768px){.sticky-cta{display:flex}}
