
:root{
 --ink:#0d1116; --ink2:#151b22; --line:#e6eaef; --soft:#5d6b7a; --bg:#f6f8fa;
 --accent:#aba990; --accent-d:#95937a; --accent2:#ebbb0f; --tan:#aba990; --white:#fff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Manrope',system-ui,sans-serif;color:#1c2630;line-height:1.6;background:#fff;font-size:17px}
h1,h2,h3{line-height:1.12;color:var(--ink);font-weight:800;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 5vw}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;border-radius:10px;padding:15px 26px;font-size:16px;transition:.2s;cursor:pointer;border:0}
.btn--primary{background:var(--accent);color:#1c2630}
.btn--primary:hover{background:var(--accent-d)}
.btn--ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn--ghost:hover{background:rgba(255,255,255,.12)}
.btn--dark{background:var(--ink);color:#fff}
.eyebrow{display:inline-block;font-size:13px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.sec{padding:84px 0}
.sec--tight{padding:60px 0}
.center{text-align:center}
.lead{font-size:19px;color:var(--soft)}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo img{height:34px;width:auto;display:block}

.nav ul{display:flex;gap:26px;list-style:none}
.nav ul a{color:#34414f;font-weight:600;font-size:15px}
.nav ul a:hover{color:var(--accent)}
.nav .cta{display:flex;align-items:center;gap:14px}
.nav .tel{color:var(--ink);font-weight:800;font-size:15px}
.nav .tel span{color:var(--accent)}

/* Hero with video */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,11,15,.92) 0%,rgba(8,11,15,.74) 46%,rgba(8,11,15,.35) 100%);z-index:1}
.hero .wrap{position:relative;z-index:2;padding-top:60px;padding-bottom:60px}
.hero h1{color:#fff;font-size:clamp(34px,5vw,58px);max-width:16ch;margin:14px 0 18px}
.hero h1 em{color:var(--accent);font-style:normal}
.hero .sub{font-size:clamp(17px,1.6vw,21px);color:#dbe3ec;max-width:54ch;margin-bottom:30px}
.hero .actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.hero .tags{display:flex;gap:10px;flex-wrap:wrap}
.hero .tags span{font-size:13px;font-weight:700;letter-spacing:.04em;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:8px 14px;border-radius:999px}

/* Trust strip */
.trust{background:var(--ink2);color:#cfd8e2}
.trust .row{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;padding:22px 0}
.trust .item{display:flex;align-items:center;gap:11px;font-weight:700;font-size:15px;flex:1;min-width:220px}
.trust .item .ic{width:38px;height:38px;border-radius:9px;background:rgba(171,169,144,.22);color:#d8d5be;display:flex;align-items:center;justify-content:center;font-weight:800}

/* Section headers */
.sec-head{max-width:720px;margin:0 auto 48px}
.sec-head.center{text-align:center}
.sec-head h2{font-size:clamp(28px,3.4vw,42px);margin:10px 0 12px}

/* Services */
.grid{display:grid;gap:22px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:1fr 1fr}
.card{background:#fff;border:1px solid var(--line);border-top:3px solid var(--tan);border-radius:16px;padding:28px 26px 30px;transition:.2s}
.card:hover{box-shadow:0 18px 44px rgba(13,17,22,.10);transform:translateY(-3px);border-color:#d7dee6}
.card .ic{width:54px;height:54px;border-radius:12px;background:#aba990;color:#1c2630;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ic svg{width:27px;height:27px}
.card h3{font-size:20px;margin-bottom:8px}
.card p{font-size:15.5px;color:var(--soft)}
.card .more{display:inline-block;margin-top:14px;color:var(--accent);font-weight:700;font-size:15px}

/* Dark band */
.band{background:var(--ink);color:#fff}
.band h2{color:#fff}
.band .lead{color:#aeb9c5}

/* Notdienst */
.alert{background:linear-gradient(120deg,#0d1116,#1b242e);color:#fff;border-radius:20px;padding:42px 46px;display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:space-between;border:1px solid rgba(171,169,144,.5)}
.alert .big{font-size:clamp(24px,2.6vw,32px);font-weight:800}
.alert .big span{color:var(--accent)}

/* Steps */
.steps{counter-reset:s;display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{position:relative;padding-top:14px}
.step::before{counter-increment:s;content:counter(s);font-weight:800;font-size:15px;width:36px;height:36px;border-radius:50%;background:var(--accent);color:#1c2630;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.step h3{font-size:18px;margin-bottom:6px}
.step p{font-size:15px;color:var(--soft)}

/* FAQ */
.faq{max-width:860px;margin:0 auto}
.faq details{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;background:#fff;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:700;font-size:17px;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-size:24px;font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 22px 20px;color:var(--soft);font-size:15.5px}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.cinfo .ci{display:flex;gap:14px;margin-bottom:20px}
.cinfo .ci .ic{width:44px;height:44px;border-radius:10px;background:rgba(171,169,144,.2);color:#7f7d66;display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-weight:800}
.cinfo .ci b{display:block;font-size:16px;color:var(--ink)}
.cinfo .ci span{font-size:15px;color:var(--soft)}
.form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px}
.form label{display:block;font-size:13px;font-weight:700;color:var(--soft);margin:0 0 6px}
.form input,.form textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:13px 14px;font:inherit;font-size:15px;margin-bottom:16px;background:#fbfcfd}
.form textarea{min-height:120px;resize:vertical}

/* Footer */
footer{background:#0a0d11;color:#9aa6b2;padding:54px 0 26px;font-size:14.5px}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px;margin-bottom:30px}
footer h4{color:#fff;font-size:15px;margin-bottom:14px}
footer a{color:#9aa6b2}footer a:hover{color:#fff}
footer .logo{font-size:21px;margin-bottom:12px}
footer .bot{border-top:1px solid rgba(255,255,255,.1);padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px}

/* sticky mobile call */
.mobcall{display:none}

.note-preview{background:#f1f0ea;border-bottom:1px solid #dddac9;color:#6f6c57;text-align:center;font-size:13px;font-weight:700;padding:8px}

@media(max-width:900px){
 .grid-4,.grid-3,.steps,.contact{grid-template-columns:1fr}
 .grid-2{grid-template-columns:1fr}
 .nav ul,.nav .tel{display:none}
 .footer .cols,footer .cols{grid-template-columns:1fr}
 .mobcall{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--accent);color:#1c2630;align-items:center;justify-content:center;gap:8px;padding:14px;font-weight:800}
 body{padding-bottom:54px}
}

/* ===== WOW: Animationen ===== */
@keyframes heroUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.hero .wrap>*{animation:heroUp .85s both cubic-bezier(.2,.7,.2,1)}
.hero .eyebrow{animation-delay:.10s}.hero h1{animation-delay:.26s}.hero .sub{animation-delay:.46s}.hero .actions{animation-delay:.62s}.hero .tags{animation-delay:.78s}
@keyframes pulseTan{0%,100%{box-shadow:0 0 0 0 rgba(171,169,144,0)}50%{box-shadow:0 0 0 8px rgba(171,169,144,.20)}}
.hero .btn--primary{animation:heroUp .85s both,pulseTan 3s ease-in-out 1.6s infinite}
.scrollcue{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:3;color:#fff;font-size:30px;line-height:1;opacity:.75;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,10px)}}
header{transition:box-shadow .25s}
header.scrolled{box-shadow:0 8px 26px rgba(13,17,22,.12)}
header.scrolled .nav{height:60px}
.nav{transition:height .28s}
.nav ul a{position:relative}
.nav ul a::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:2px;background:var(--accent);transition:right .28s}
.nav ul a:hover::after{right:0}
.card{transition:transform .28s,box-shadow .28s,border-color .28s}
.card .ic{transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.card:hover .ic{transform:scale(1.1) rotate(-4deg)}
.btn{transition:transform .15s,background .2s}
.btn--primary:hover{transform:translateY(-2px)}
.js .reveal,.js .sec-head,.js .card,.js .step,.js .alert,.js .faq details,.js .cinfo,.js .form,.js .trust .item{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.2,.7,.2,1),transform .75s cubic-bezier(.2,.7,.2,1)}
.js .is-in{opacity:1!important;transform:none!important}
.js .card:nth-child(2),.js .step:nth-child(2),.js .trust .item:nth-child(2){transition-delay:.10s}
.js .card:nth-child(3),.js .step:nth-child(3),.js .trust .item:nth-child(3){transition-delay:.20s}
.js .card:nth-child(4),.js .step:nth-child(4){transition-delay:.30s}
@media (prefers-reduced-motion:reduce){*{animation:none!important}.js .reveal,.js .sec-head,.js .card,.js .step,.js .alert,.js .faq details,.js .cinfo,.js .form,.js .trust .item{opacity:1!important;transform:none!important}.scrollcue{display:none}}

/* ===== Innenseiten ===== */
.page-hero{background:linear-gradient(120deg,#0d1116 0%,#1b242e 100%);color:#fff;padding:66px 0 58px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border:2px solid rgba(171,169,144,.25);border-radius:50%}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{color:var(--accent)}
.page-hero h1{color:#fff;font-size:clamp(30px,4vw,46px);margin:10px 0 14px;max-width:22ch}
.page-hero p{color:#cdd6df;max-width:62ch;font-size:18px;margin:0}
.breadcrumb{font-size:12.5px;color:#9fb0c0;margin-bottom:14px;letter-spacing:.02em}
.breadcrumb a{color:#9fb0c0}.breadcrumb a:hover{color:#fff}
.split{display:grid;grid-template-columns:1.35fr .9fr;gap:46px;align-items:start}
.prose p{margin:0 0 14px;font-size:16.5px}
.prose h2{font-size:clamp(24px,3vw,32px);margin:26px 0 12px}
.checklist{list-style:none;padding:0;margin:14px 0}
.checklist li{position:relative;padding:9px 0 9px 30px;border-bottom:1px solid var(--line);font-size:16px}
.checklist li:last-child{border-bottom:0}
.checklist li::before{content:"\2713";position:absolute;left:0;top:9px;color:var(--accent);font-weight:800}
.sidecard{background:var(--bg);border:1px solid var(--line);border-top:3px solid var(--accent);border-radius:14px;padding:24px;margin-bottom:20px}
.sidecard h3{font-size:18px;margin:0 0 10px}
.sidecard p{font-size:14.5px;color:var(--soft);margin:0 0 6px}
.ctaband{background:linear-gradient(120deg,#0d1116,#1b242e);color:#fff;border-radius:20px;padding:40px 44px;text-align:center;border:1px solid rgba(171,169,144,.35)}
.ctaband h2{color:#fff;font-size:clamp(24px,2.8vw,32px);margin:0 0 8px}
.ctaband p{color:#aeb9c5;margin:0 0 20px}
.ctaband .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.page-img{width:100%;border-radius:14px;margin:0 0 22px;display:block;aspect-ratio:16/10;object-fit:cover;border:1px solid var(--line)}
/* Dropdown-Menü */
.nav ul li{position:relative}
.nav .has-sub>a::after{content:"\25BE";font-size:9px;margin-left:5px;opacity:.55}
.nav .submenu{position:absolute;top:100%;left:-12px;background:#fff;border:1px solid var(--line);border-radius:11px;box-shadow:0 18px 44px rgba(13,17,22,.14);min-width:248px;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s,transform .2s,visibility .2s;z-index:60;list-style:none}
.nav li:hover .submenu{opacity:1;visibility:visible;transform:none}
.nav .submenu li{display:block}
.nav .submenu a{display:block;padding:9px 12px;border-radius:7px;font-size:14px;color:#34414f;font-weight:600}
.nav .submenu a:hover{background:var(--bg);color:var(--accent)}
.nav .submenu a::after{display:none}
/* Mobile-Menü */
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:0}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px}
#mnav{display:none}
@media(max-width:900px){
 .nav ul{display:none}
 .burger{display:flex}
 #mnav.open{display:block;position:fixed;inset:0;top:64px;background:#fff;z-index:55;padding:18px 5vw;overflow:auto}
 #mnav a{display:block;padding:13px 0;border-bottom:1px solid var(--line);font-weight:700;color:var(--ink)}
 #mnav .sub a{padding-left:16px;font-weight:600;color:var(--soft);font-size:15px}
 .page-hero .wrap{padding-top:6px}
}

/* Unterseiten-Video-Hero */
.hero--sub{min-height:56vh}
.hero--sub .wrap{padding-top:96px;padding-bottom:46px;position:relative;z-index:2}
.hero--sub .breadcrumb,.hero--sub .breadcrumb a{color:rgba(255,255,255,.82)}
.hero--sub .eyebrow{color:var(--accent)}
.hero--sub h1{color:#fff;margin:6px 0 14px}
.hero--sub p{color:rgba(255,255,255,.92);max-width:700px}

/* ===== Mega-Menü (Leistungen) — hübschere Variante v4 ===== */
.nav .has-sub{position:relative}
.nav .mega{position:absolute;top:calc(100% + 14px);left:-16px;width:780px;max-width:92vw;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 28px 70px rgba(13,17,22,.20);padding:16px;opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .22s ease,transform .22s ease,visibility .22s;z-index:60}
.nav .mega::before{content:"";position:absolute;top:-18px;left:0;right:0;height:18px}
.nav .mega::after{content:"";position:absolute;top:-7px;left:28px;width:14px;height:14px;background:#fff;border-left:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg);border-radius:3px 0 0 0}
.nav .has-sub:hover .mega,.nav .has-sub:focus-within .mega{opacity:1;visibility:visible;transform:none}
.nav .mega__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.nav .mega__item{display:flex;align-items:flex-start;gap:13px;padding:13px;border-radius:13px;transition:background .18s}
.nav .mega__item:hover{background:var(--bg)}
.nav .mega__item::after{display:none!important}
.nav .mega__ic{flex:0 0 44px;height:44px;display:grid;place-items:center;border-radius:12px;background:linear-gradient(135deg,#f1eee2,#e6e2d0);color:var(--accent-d);transition:background .18s,color .18s,transform .18s}
.nav .mega__item:hover .mega__ic{background:var(--accent);color:#fff;transform:translateY(-2px)}
.nav .mega__ic svg{width:23px;height:23px}
.nav .mega__tx{display:flex;flex-direction:column;gap:3px;padding-top:1px}
.nav .mega__tx b{color:var(--ink);font-size:14.5px;font-weight:700;line-height:1.15}
.nav .mega__tx small{color:var(--soft);font-size:12px;line-height:1.35;font-weight:500}
.nav .mega__item:hover .mega__tx b{color:var(--accent-d)}
.nav .mega__foot{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:12px;padding:15px 18px;border-radius:13px;background:linear-gradient(120deg,var(--ink),#1b242e);color:#fff}
.nav .mega__foot span{font-size:13.5px;color:#cfd6de}
.nav .mega__foot b{color:#fff;font-weight:700}
.nav .mega__foot .btn{padding:11px 21px;font-size:14px;white-space:nowrap;flex:0 0 auto}
@media (max-width:1080px){.nav .mega{display:none}}
