
:root{--bg:#080e15;--bg2:#0d1825;--panel:#101926;--surface:#f3f0ea;--text:#f7f9fc;--muted:#c8d5e5;--dark:#111827;--mutedDark:#5b6a7d;--line:rgba(255,255,255,.1);--lineDark:#dde6ef;--red:#ef3030;--blue:#1598ff;--shadow:0 26px 70px rgba(0,0,0,.28);--r:28px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--surface);color:var(--dark);line-height:1.55}a{text-decoration:none;color:inherit}img{display:block;max-width:100%}.wrap{width:min(1220px,calc(100% - 32px));margin:0 auto}.site-header{position:sticky;top:0;z-index:80;background:rgba(7,10,15,.86);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 10px 40px rgba(0,0,0,.20)}.bar{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center;padding:12px 0}.brand img{height:56px;width:auto}.nav{display:flex;align-items:center;justify-content:flex-end;gap:18px}.nav>a,.drop-toggle{color:#fff;font-weight:850;font-size:15px;padding:9px 0;position:relative}.nav>a.active,.drop-toggle.active{color:#fff}.nav>a.active:after,.drop-toggle.active:after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--red))}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border-radius:16px;background:linear-gradient(135deg,#ff4545,#df2020);color:#fff;font-weight:900;box-shadow:0 18px 34px rgba(241,54,54,.24);border:0;cursor:pointer}.btn.dark{background:rgba(255,255,255,.04);box-shadow:none;border:1px solid rgba(255,255,255,.14)}.header-hotline{display:flex;align-items:center;justify-content:center;gap:14px;color:#d7e2f2;padding:0 0 14px;font-size:14px}.header-hotline strong{color:#fff}.header-hotline a{padding:9px 15px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);font-weight:900}.pulse{width:10px;height:10px;border-radius:50%;background:var(--red);box-shadow:0 0 0 8px rgba(241,54,54,.12)}.drop{position:relative}.mega-menu{position:absolute;right:-260px;top:calc(100% + 16px);width:min(900px,92vw);background:#0b1119;border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:var(--shadow);padding:18px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s ease}.drop:hover .mega-menu{opacity:1;visibility:visible;transform:translateY(0)}.mega-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:18px}.mega-list{display:grid;gap:8px}.mega-item{display:block;padding:13px 14px;border-radius:16px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.06);color:#fff}.mega-item:hover,.mega-item.active{background:rgba(21,152,255,.1);border-color:rgba(21,152,255,.28)}.mega-item span{display:block;color:#9fb0c6;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.mega-preview{position:relative;overflow:hidden;border-radius:20px;min-height:360px;background:#111}.mega-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.66) contrast(1.06) saturate(.95)}.mega-preview div{position:absolute;left:20px;right:20px;bottom:20px;color:#fff}.mega-preview h3{font-size:34px;margin:6px 0}.mega-preview p{color:#d9e5f5;margin:0}.nav-toggle{display:none}.mobile-panel{display:none}.hero{position:relative;overflow:hidden;background:radial-gradient(circle at 82% 18%,rgba(21,152,255,.13),transparent 24%),radial-gradient(circle at 15% 88%,rgba(241,54,54,.11),transparent 26%),linear-gradient(180deg,#091019 0%,#0b1521 52%,#0b121c 100%);color:#fff}.hero-inner{padding:70px 0 88px}.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:46px;align-items:center}.eyebrow{display:inline-flex;gap:10px;align-items:center;color:#9ccaff;text-transform:uppercase;letter-spacing:.12em;font-weight:900;font-size:13px}.eyebrow:before{content:"";width:32px;height:2px;background:linear-gradient(90deg,var(--blue),var(--red))}.hero h1{font-size:clamp(48px,7vw,88px);line-height:.97;letter-spacing:-.04em;margin:20px 0 18px}.hero p{font-size:clamp(18px,2vw,23px);color:#d7e2f0;max-width:760px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.hero-checks{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;margin-top:32px}.hero-check{display:flex;gap:12px;color:#eef5ff}.hero-check i{color:var(--blue);font-weight:900}.hero-visual{position:relative;min-height:560px;border-radius:34px;overflow:hidden;background:linear-gradient(145deg,#111d2d,#07111b);border:1px solid rgba(255,255,255,.09);box-shadow:var(--shadow)}.hero-mosaic{position:absolute;inset:18px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1.18fr .82fr;gap:14px}.hero-mosaic img{width:100%;height:100%;object-fit:cover;border-radius:22px;filter:brightness(.82) contrast(1.05) saturate(.94)}.hero-mosaic img:first-child{grid-row:span 2}.hero-brand-panel{position:absolute;left:26px;right:26px;bottom:26px;z-index:3;padding:22px;border-radius:24px;background:rgba(6,12,20,.78);border:1px solid rgba(255,255,255,.11);backdrop-filter:blur(12px)}.hero-brand-panel strong{display:block;font-size:24px}.hero-brand-panel span{display:block;color:#c7d3e3;margin-top:4px}.section{padding:84px 0}.surface{background:var(--surface)}.dark-section{background:#0b121c;color:#fff}.kicker{font-size:13px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:#1f78cc;margin-bottom:12px}.section-title{font-size:clamp(32px,4vw,56px);line-height:1.04;letter-spacing:-.03em;margin:0 0 14px}.section-sub{font-size:19px;color:#5b6a7d;max-width:820px;margin:0}.trust-grid,.method-grid,.mini-features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}.trust-card,.method,.mini{padding:28px;border-radius:24px;background:#fff;border:1px solid var(--lineDark);box-shadow:0 14px 34px rgba(16,23,34,.07)}.trust-card h3,.method h4,.mini strong{display:block;font-size:23px;margin:0 0 10px}.trust-card p,.method p,.mini p{margin:0;color:#566679}.service-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:38px}.secondary-grid{grid-template-columns:repeat(4,1fr)}.service-card{position:relative;min-height:350px;border-radius:30px;overflow:hidden;background:#101822;box-shadow:var(--shadow);transition:.22s ease}.secondary-grid .service-card{min-height:285px}.service-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.78) contrast(1.05) saturate(.92);transition:transform .7s ease}.service-card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,8,13,.16),rgba(5,8,13,.76) 58%,rgba(5,8,13,.94));z-index:1}.service-card .content{position:absolute;left:0;right:0;bottom:0;z-index:2;color:#fff;padding:24px}.service-card .tag{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.service-card h3{font-size:34px;line-height:1.02;margin:12px 0 8px;color:#fff}.secondary-grid .service-card h3{font-size:26px}.service-card p{color:#e9f1fb;margin:0;max-height:0;overflow:hidden;opacity:.95;transition:.22s ease}.service-card:hover{transform:translateY(-5px)}.service-card:hover img{transform:scale(1.05)}.service-card:hover p{max-height:180px;margin-top:8px}.cta-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:18px;color:#fff;font-weight:900}.ghost{padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.07)}.page-hero{padding:84px 0 60px;background:radial-gradient(circle at top right,rgba(21,152,255,.12),transparent 26%),linear-gradient(90deg,#091019,#0d1927);color:#fff}.page-hero-grid{display:grid;grid-template-columns:1fr .88fr;gap:34px;align-items:center}.page-hero h1{font-size:clamp(42px,6vw,74px);line-height:1;letter-spacing:-.04em;margin:18px 0}.page-hero p{font-size:20px;color:#d4deeb}.visual{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.08)}.visual img{width:100%;aspect-ratio:16/11;object-fit:cover;filter:brightness(.9) contrast(1.04) saturate(.92)}.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}.time-card{padding:24px;border-radius:22px;background:#fff;border:1px solid var(--lineDark)}.time-card .num{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:#e9f4ff;color:#1177cb;font-weight:900}.time-card h4{font-size:21px;margin:14px 0 8px}.time-card p{margin:0;color:#566679}.cta-band{display:flex;align-items:center;justify-content:space-between;gap:22px;border-radius:30px;padding:34px;background:linear-gradient(135deg,#0d1927,#14263a);color:#fff;box-shadow:var(--shadow)}.cta-band h3{font-size:34px;margin:0 0 8px}.cta-band p{margin:0;color:#d7e2f0}.phone{font-size:26px;font-weight:900}.faq-grid{display:grid;gap:14px;margin-top:30px}.faq-item{background:#fff;border-radius:20px;border:1px solid var(--lineDark);box-shadow:0 10px 24px rgba(16,23,34,.06)}.faq-item summary{padding:18px 22px;cursor:pointer;font-size:19px;font-weight:900}.faq-answer{padding:0 22px 20px;color:#566679}.contact-card{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px}.contact-box,.contact-form-card{background:#fff;border:1px solid var(--lineDark);border-radius:24px;padding:28px;box-shadow:0 14px 34px rgba(16,23,34,.08)}.contact-form{display:grid;gap:16px}.form-grid{display:grid;gap:16px}.form-grid.two{grid-template-columns:repeat(2,1fr)}.form-grid.three{grid-template-columns:repeat(3,1fr)}label{font-weight:850}.input{width:100%;margin-top:8px;padding:15px 16px;border-radius:14px;border:1px solid #d6e0eb;background:#f8fbff;font:inherit}.input:focus{outline:none;border-color:#1598ff;box-shadow:0 0 0 4px rgba(21,152,255,.12)}textarea.input{min-height:140px}.dynamic-fields{display:none;padding:18px;border-radius:18px;background:#f8fbff;border:1px solid #dce7f2}.dynamic-fields.active{display:block}.field-title{font-size:18px;font-weight:900;margin:0 0 12px}.consent{display:flex;gap:10px;align-items:flex-start;color:#566679;font-weight:500}.local-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.local-pills span{padding:9px 12px;border-radius:999px;background:#eef6ff;color:#1469ba;font-weight:850}.footer{background:#080e15;color:#d7e2f0;padding:52px 0 30px}.footer-grid{display:grid;grid-template-columns:1.2fr .9fr .9fr .8fr;gap:28px}.footer-logo{height:58px;width:auto;margin-bottom:14px}.footer h4{color:#fff;margin:0 0 12px}.footer p{margin:8px 0;color:#bdc9d9}.legal{display:flex;justify-content:space-between;gap:16px;margin-top:28px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);font-size:14px;color:#9eabba}.hotline-float{position:fixed;right:18px;bottom:18px;z-index:60;display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:18px;background:#0b1119;color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow)}.mobile-quickbar{display:none}@media(max-width:980px){.hero-grid,.page-hero-grid,.contact-card{grid-template-columns:1fr}.service-grid,.secondary-grid,.trust-grid,.method-grid,.mini-features,.timeline,.footer-grid{grid-template-columns:1fr}.hero-visual{min-height:450px}.nav{display:none}.nav-toggle{display:block;color:#fff;background:none;border:0;font-size:30px;margin-left:auto}.bar{grid-template-columns:auto auto}.mobile-panel.active{display:grid;gap:8px;padding:0 0 18px}.mobile-panel a{color:#fff;padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.05)}.header-hotline{display:none}.form-grid.two,.form-grid.three{grid-template-columns:1fr}.hero-checks{grid-template-columns:1fr}.hero h1{font-size:46px}.section{padding:62px 0}.hotline-float{display:none}.mobile-quickbar{position:fixed;bottom:0;left:0;right:0;background:#080e15;border-top:1px solid rgba(255,255,255,.1);display:grid;grid-template-columns:repeat(3,1fr);z-index:70}.mobile-quickbar a{color:#fff;text-align:center;padding:12px 8px;font-size:13px;font-weight:900}.mobile-quickbar a:nth-child(3){background:linear-gradient(135deg,#ff4545,#df2020)}body{padding-bottom:54px}}@media(max-width:640px){.hero h1{font-size:40px}.page-hero h1{font-size:36px}.hero-visual{min-height:360px}.hero-mosaic{inset:12px;gap:10px}.hero-brand-panel{left:16px;right:16px;bottom:16px}.cta-band{display:block}.phone{margin:16px 0}.service-card{min-height:300px}.brand img{height:48px}}


/* ===== v23: stronger homepage + contrast fixes ===== */
.section-title{color:#101722}
.dark-section .section-title,
.hero .section-title,
.page-hero .section-title{color:#fff}
.dark-section .section-sub{color:#cbd8e8!important}
.dark-section .kicker{color:#8cc9ff}
.dark-section .trust-card{background:linear-gradient(180deg,#111c2b,#0f1824);border-color:rgba(255,255,255,.10);box-shadow:0 20px 50px rgba(0,0,0,.22)}
.dark-section .trust-card h3{color:#fff}
.dark-section .trust-card p{color:#cbd8e8}
.service-card h3,.service-card .content,.service-card .cta-row span{color:#fff!important}
.service-card p{color:#edf4ff!important}
.hero h1,.hero p,.hero-check{color:#fff}
.hero p{color:#dce7f5}
.page-hero h1{color:#fff}
.page-hero p{color:#d7e4f2}
.nav>a.active,.drop-toggle.active{color:#fff!important}

/* premium homepage blocks */
.hero{background:
 radial-gradient(circle at 85% 18%,rgba(21,152,255,.16),transparent 25%),
 radial-gradient(circle at 10% 90%,rgba(239,48,48,.13),transparent 28%),
 linear-gradient(180deg,#080e15 0%,#0b1522 48%,#0b121c 100%)}
.hero-inner{padding:84px 0 98px}
.hero h1{font-size:clamp(48px,7.4vw,96px)}
.hero p{font-size:clamp(18px,2vw,24px);line-height:1.55}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 13px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#eef6ff;font-weight:800;font-size:14px}
.hero-badge:before{content:"✓";color:#61b9ff;font-weight:900}
.hero-proof{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:30px;max-width:820px}
.hero-proof div{padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10)}
.hero-proof strong{display:block;font-size:22px;color:#fff;margin-bottom:4px}
.hero-proof span{display:block;color:#c8d7e9;font-size:14px}
.hero-visual{min-height:620px}
.hero-brand-panel strong{font-size:28px}
.hero-brand-panel span{font-size:16px}

.lead-service{display:grid;grid-template-columns:1fr .88fr;gap:28px;align-items:stretch;margin-top:34px}
.lead-card{padding:34px;border-radius:30px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--lineDark);box-shadow:0 18px 44px rgba(16,23,34,.09)}
.lead-card h3{font-size:clamp(28px,3vw,44px);line-height:1.04;margin:0 0 14px;color:#101722}
.lead-card p{font-size:18px;color:#516173;margin:0 0 20px}
.lead-list{display:grid;gap:12px;margin:22px 0 0;padding:0;list-style:none}
.lead-list li{display:flex;gap:10px;align-items:flex-start;color:#273244;font-weight:700}
.lead-list li:before{content:"✓";color:#1598ff;font-weight:900}
.lead-side{position:relative;border-radius:30px;overflow:hidden;min-height:430px;box-shadow:var(--shadow)}
.lead-side img{width:100%;height:100%;object-fit:cover;filter:brightness(.86) contrast(1.04)}
.lead-side:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(4,8,14,.82))}
.lead-side div{position:absolute;left:24px;right:24px;bottom:24px;color:#fff;z-index:2}
.lead-side strong{display:block;font-size:28px;line-height:1.05}
.lead-side span{display:block;color:#dce8f7;margin-top:8px}

.value-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px}
.value-item{padding:22px;border-radius:22px;background:#fff;border:1px solid var(--lineDark);box-shadow:0 12px 30px rgba(16,23,34,.06)}
.value-item strong{display:block;color:#101722;font-size:20px;margin-bottom:8px}
.value-item span{display:block;color:#5b6a7d}

.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.problem-card{padding:28px;border-radius:26px;background:linear-gradient(180deg,#101a29,#0e1724);border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow)}
.problem-card h3{font-size:25px;line-height:1.05;margin:0 0 12px;color:#fff}
.problem-card p{margin:0;color:#cbd8e8}

.mobile-quickbar a{color:#fff!important}
@media(max-width:980px){
 .hero-inner{padding:54px 0 68px}
 .hero-proof,.lead-service,.value-strip,.problem-grid{grid-template-columns:1fr}
 .hero-visual{min-height:420px}
 .lead-side{min-height:340px}
}


/* ===== v25 homepage cleanup ===== */
.home-hero .hero-inner{padding-top:76px!important;padding-bottom:92px!important}
.home-hero-grid{grid-template-columns:1.02fr .98fr!important;gap:46px!important;align-items:center!important}
.home-hero h1{font-size:clamp(44px,6.5vw,86px)!important;line-height:.98!important;letter-spacing:-.045em!important;margin:20px 0 22px!important;color:#fff!important}
.home-hero p{font-size:clamp(18px,1.7vw,22px)!important;line-height:1.6!important;color:#d9e6f6!important;max-width:780px!important}
.home-trust-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.home-trust-row span{display:inline-flex;align-items:center;gap:8px;padding:10px 13px;border-radius:999px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#eef6ff;font-weight:850;font-size:14px}
.home-trust-row span:before{content:"";width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--red));box-shadow:0 0 0 5px rgba(21,152,255,.08)}
.home-team-photo{position:relative;min-height:620px;border-radius:34px;overflow:hidden;background:#111c2b;border:1px solid rgba(255,255,255,.09);box-shadow:0 26px 70px rgba(0,0,0,.30)}
.home-team-photo img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.92) contrast(1.03) saturate(.96)}
.home-team-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,10,18,.04),rgba(5,10,18,.55));pointer-events:none}
.home-photo-card{position:absolute;left:24px;right:24px;bottom:24px;z-index:2;padding:22px 24px;border-radius:24px;background:rgba(7,13,22,.78);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(12px);color:#fff}
.home-photo-card strong{display:block;font-size:28px;line-height:1.08;margin-bottom:8px;color:#fff}
.home-photo-card span{display:block;color:#dbe7f6;font-size:16px;line-height:1.5}
.home-intro .section-title,.home-services-section .section-title,.home-process-section .section-title{color:#101722!important}
.home-reasons{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}
.home-reason{padding:26px;border-radius:24px;background:#fff;border:1px solid rgba(16,23,34,.08);box-shadow:0 14px 36px rgba(16,23,34,.07)}
.home-reason h3{margin:0 0 10px;color:#101722;font-size:22px;line-height:1.12}
.home-reason p{margin:0;color:#566678;line-height:1.62}
.home-service-feature{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;margin-top:36px;align-items:stretch}
.home-main-service{position:relative;border-radius:30px;overflow:hidden;min-height:520px;box-shadow:var(--shadow);display:block;background:#101822}
.home-main-service img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.82) contrast(1.04)}
.home-main-service:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,8,13,.10),rgba(5,8,13,.85));pointer-events:none}
.home-main-service div{position:absolute;left:26px;right:26px;bottom:26px;z-index:2;color:#fff}
.home-main-service span{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#fff}
.home-main-service h3{font-size:42px;line-height:1.02;margin:14px 0 10px;color:#fff}
.home-main-service p{color:#e8f2ff;font-size:18px;line-height:1.5;margin:0}
.home-service-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.home-service-list a{display:block;padding:20px;border-radius:20px;background:#fff;border:1px solid rgba(16,23,34,.08);box-shadow:0 12px 30px rgba(16,23,34,.055);transition:.2s ease}
.home-service-list a:hover{transform:translateY(-3px);border-color:rgba(21,152,255,.28);box-shadow:0 18px 36px rgba(16,23,34,.10)}
.home-service-list strong{display:block;color:#101722;font-size:21px;line-height:1.1;margin-bottom:8px}
.home-service-list span{display:block;color:#5b6a7d;line-height:1.5}
.home-process{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}
.home-process article{padding:26px;border-radius:24px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid rgba(16,23,34,.08);box-shadow:0 14px 36px rgba(16,23,34,.07)}
.home-process article>span{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;background:#eaf5ff;color:#137cd3;font-weight:900;margin-bottom:16px}
.home-process h3{color:#101722;font-size:22px;line-height:1.12;margin:0 0 10px}
.home-process p{color:#566678;margin:0;line-height:1.6}
.service-card h3,.service-card p,.service-card .tag,.service-card .cta-row{color:#fff!important}
.dark-section .section-title{color:#fff!important}.dark-section .section-sub{color:#cbd8e8!important}
@media(max-width:980px){
  .home-hero .hero-inner{padding-top:52px!important;padding-bottom:66px!important}
  .home-hero-grid,.home-service-feature{grid-template-columns:1fr!important}
  .home-team-photo{min-height:430px}
  .home-reasons,.home-process,.home-service-list{grid-template-columns:1fr!important}
  .home-main-service{min-height:360px}
  .home-hero h1{font-size:42px!important}
}


/* ===== v25: Startseite entmischt, 4-Farb-System nur Unterhaltsreinigung ===== */
.hero-inner{padding-top:82px!important;padding-bottom:92px!important}
.hero h1{font-size:clamp(44px,6.5vw,82px)!important;line-height:1.02!important;letter-spacing:-.04em!important}
.hero p{font-size:clamp(18px,2vw,23px)!important;color:#dbe7f6!important}
.hero-grid{align-items:center!important}
.hero-proof{grid-template-columns:repeat(2,1fr)!important;gap:14px!important}
.hero-proof div{min-height:auto!important;padding:16px 18px!important}
.hero-proof strong{font-size:19px!important}
.hero-team-photo{position:relative;min-height:610px;border-radius:34px;overflow:hidden;background:#111d2d;border:1px solid rgba(255,255,255,.09);box-shadow:var(--shadow)}
.hero-team-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.78) contrast(1.04) saturate(.95)}
.hero-team-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,9,15,.02),rgba(5,9,15,.60));pointer-events:none}
.hero-team-caption{position:absolute;left:24px;right:24px;bottom:24px;z-index:2;padding:22px;border-radius:24px;background:rgba(6,12,20,.76);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(12px);color:#fff}
.hero-team-caption strong{display:block;font-size:28px;line-height:1.08;margin-bottom:8px;color:#fff}
.hero-team-caption span{display:block;color:#d7e4f3;line-height:1.55}
.home-intro-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-top:34px}
.home-intro-card{padding:28px;border-radius:24px;background:#fff;border:1px solid var(--lineDark);box-shadow:0 14px 34px rgba(16,23,34,.07)}
.home-intro-card h3{font-size:24px;line-height:1.12;color:#101722;margin:0 0 10px}
.home-intro-card p{color:#566679;margin:0}
.service-card p{max-height:none!important;margin-top:8px!important}
.service-card:before{background:linear-gradient(180deg,rgba(5,8,13,.14),rgba(5,8,13,.72) 52%,rgba(5,8,13,.94))!important}
.home-process{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.process-card{padding:28px;border-radius:24px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--lineDark);box-shadow:0 14px 34px rgba(16,23,34,.07)}
.process-card span{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:#e9f4ff;color:#1177cb;font-weight:900;margin-bottom:16px}
.process-card h3{font-size:24px;line-height:1.12;color:#101722;margin:0 0 10px}
.process-card p{color:#566679;margin:0}
.maintenance-hygiene{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:34px;align-items:stretch}
.hygiene-panel{padding:30px;border-radius:28px;background:linear-gradient(180deg,#101a29,#0e1724);color:#fff;border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow)}
.hygiene-panel h3{font-size:clamp(28px,3vw,42px);line-height:1.06;margin:0 0 14px;color:#fff}
.hygiene-panel p{color:#cbd8e8;margin:0 0 18px;font-size:18px}
.hygiene-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}
.hygiene-list li{display:flex;gap:10px;color:#eef5ff;font-weight:700}.hygiene-list li:before{content:"✓";color:#1598ff;font-weight:900}
@media(max-width:980px){
  .hero-inner{padding-top:54px!important;padding-bottom:64px!important}
  .hero-grid,.home-intro-grid,.home-process,.maintenance-hygiene{grid-template-columns:1fr!important}
  .hero-proof{grid-template-columns:1fr!important}
  .hero-team-photo{min-height:440px}
}
@media(max-width:640px){.hero h1{font-size:39px!important}.hero-team-photo{min-height:360px}}


/* v26: Hero-Teamfoto größer + Startseite ruhiger */
.hero-grid{grid-template-columns:.92fr 1.08fr!important;gap:54px!important;align-items:center!important}
.hero-team-photo{min-height:720px!important;border-radius:36px!important}
.hero-team-photo img{filter:brightness(.88) contrast(1.04) saturate(.96)!important;object-position:center!important}
.hero-team-caption{left:28px!important;right:28px!important;bottom:28px!important;padding:24px!important}
.hero-team-caption strong{font-size:31px!important}
.hero-proof{grid-template-columns:repeat(3,1fr)!important;max-width:840px!important}
.hero-proof div{min-height:106px!important}
@media(max-width:1180px){.hero-team-photo{min-height:620px!important}.hero-grid{grid-template-columns:1fr 1fr!important;gap:34px!important}.hero h1{font-size:clamp(42px,6vw,74px)!important}}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr!important}.hero-team-photo{min-height:520px!important}.hero-proof{grid-template-columns:1fr!important}.hero-inner{padding-top:54px!important}}
@media(max-width:640px){.hero-team-photo{min-height:390px!important}.hero-team-caption strong{font-size:23px!important}.hero-team-caption{left:16px!important;right:16px!important;bottom:16px!important}}

/* SEO/Accessibility additions */
.skip-link{position:absolute;left:-999px;top:10px;background:#fff;color:#080e15;padding:10px 14px;border-radius:10px;z-index:9999;font-weight:900}.skip-link:focus{left:10px}.breadcrumbs{background:#eef2f6;border-bottom:1px solid #dde6ef;font-size:14px}.breadcrumbs .wrap{display:flex;gap:10px;align-items:center;padding:12px 0;color:#5b6a7d}.breadcrumbs a{color:#1469ba;font-weight:800}.breadcrumbs span:last-child{color:#101722;font-weight:800}.breadcrumbs .sep{color:#8b98a8}.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:32px}.related-card{display:block;padding:22px;border-radius:22px;background:#fff;border:1px solid var(--lineDark);box-shadow:0 12px 30px rgba(16,23,34,.06)}.related-card strong{display:block;color:#101722;font-size:20px;line-height:1.15;margin-bottom:8px}.related-card span{display:block;color:#5b6a7d}.article-body{max-width:900px;margin:0 auto;font-size:18px;color:#344255}.article-body h2{font-size:32px;color:#101722;line-height:1.1;margin:34px 0 12px}.article-body p{margin:0 0 18px}.article-body .cta-band{margin-top:40px}.local-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}.local-grid span{display:inline-flex;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--lineDark);font-weight:850;color:#143052}.home-faq .faq-item summary{color:#101722}.home-faq .faq-answer{color:#566679}
@media(max-width:980px){.related-grid{grid-template-columns:1fr}.article-body{font-size:17px}.article-body h2{font-size:26px}.breadcrumbs{display:none}}

/* SEO content pages */
.article-content{background:#fff;border:1px solid var(--lineDark);border-radius:28px;padding:34px;box-shadow:0 14px 34px rgba(16,23,34,.07);max-width:920px}
.article-content h2{font-size:clamp(28px,3vw,42px);line-height:1.1;margin:34px 0 14px;color:#101722}
.article-content h3{font-size:24px;margin:24px 0 10px;color:#101722}
.article-content p,.article-content li{color:#4d5e72;font-size:18px}
.article-content a{color:#146ec4;font-weight:800}
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px}
.article-card{display:block;background:#fff;border:1px solid var(--lineDark);border-radius:24px;overflow:hidden;box-shadow:0 14px 34px rgba(16,23,34,.07)}
.article-card img{width:100%;height:210px;object-fit:cover}
.article-card div{padding:22px}.article-card h3{margin:0 0 10px;color:#101722;font-size:24px}.article-card p{margin:0;color:#5b6a7d}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px}.gallery-card{background:#fff;border:1px solid var(--lineDark);border-radius:24px;overflow:hidden;box-shadow:0 14px 34px rgba(16,23,34,.07)}.gallery-card img{width:100%;height:240px;object-fit:cover}.gallery-card div{padding:20px}.gallery-card h3{margin:0 0 8px;color:#101722}.gallery-card p{margin:0;color:#5b6a7d}@media(max-width:980px){.article-grid,.gallery-grid{grid-template-columns:1fr}.article-content{padding:24px}.article-card img,.gallery-card img{height:230px}}


/* ===== v28 corrections: hero image, social links, service cards ===== */

/* Hero: team photo wider and not cut like a portrait crop */
@media (min-width: 981px){
  .hero-grid{grid-template-columns:.88fr 1.12fr!important;gap:54px!important;align-items:center!important}
}
.hero-team-photo{
  aspect-ratio:16/9!important;
  min-height:0!important;
  height:auto!important;
  border-radius:34px!important;
  overflow:hidden!important;
}
.hero-team-photo img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
  filter:brightness(.82) contrast(1.04) saturate(.96)!important;
}
.hero-team-caption{
  left:22px!important;
  right:22px!important;
  bottom:22px!important;
  max-width:560px!important;
}

/* Start hero badges no weird text wrapping */
.hero-badges{gap:10px!important}
.hero-badge{white-space:normal!important}

/* Service cards: lower cards must not look cut or squeezed */
.secondary-grid{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:22px!important;
}
.secondary-grid .service-card{
  min-height:340px!important;
}
.secondary-grid .service-card h3{
  font-size:30px!important;
  line-height:1.06!important;
}
.secondary-grid .service-card .content{
  padding:24px!important;
}
.secondary-grid .service-card p{
  font-size:16px!important;
}
.secondary-grid .cta-row{
  align-items:flex-end!important;
}
.secondary-grid .ghost{
  min-width:112px!important;
  text-align:center!important;
  white-space:nowrap!important;
}

/* Social links in footer/contact */
.social-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.social-links a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:9px 13px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff!important;
  font-weight:850;
  font-size:14px;
}
.contact-box .social-links a{
  color:#101722!important;
  background:#eef6ff;
  border-color:#d6e8ff;
}

@media(max-width:980px){
  .hero-team-photo{aspect-ratio:4/3!important;min-height:0!important}
  .secondary-grid{grid-template-columns:1fr!important}
  .secondary-grid .service-card{min-height:320px!important}
  .hero-team-caption{left:16px!important;right:16px!important;bottom:16px!important}
}


/* ===== v29 mobile menu + quick contact bar corrections ===== */
@media(max-width:980px){
  body{padding-bottom:88px!important;}
  .site-header{background:rgba(7,10,15,.94)!important;}
  .bar{padding:10px 0!important;}
  .brand img{height:52px!important;}
  .nav-toggle{font-size:36px!important;line-height:1!important;padding:10px 4px;color:#fff!important;}
  .mobile-panel.active{
    display:block!important;
    padding:0 0 18px!important;
    max-height:calc(100vh - 104px)!important;
    overflow:auto!important;
    overscroll-behavior:contain!important;
  }
  .mobile-panel a{
    display:block!important;
    color:#fff!important;
    padding:14px 16px!important;
    border-radius:16px!important;
    background:rgba(255,255,255,.06)!important;
    border:1px solid rgba(255,255,255,.06)!important;
    font-weight:750!important;
  }
  .mobile-panel a.active-mobile{
    border-color:rgba(21,152,255,.55)!important;
    background:linear-gradient(135deg,rgba(21,152,255,.18),rgba(255,255,255,.06))!important;
  }
  .mobile-menu-top{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:10px!important;
    margin:8px 0 16px!important;
  }
  .mobile-menu-top .mobile-action{
    text-align:center!important;
    padding:13px 10px!important;
    font-size:14px!important;
    font-weight:900!important;
  }
  .mobile-menu-top .primary{
    grid-column:1/-1!important;
    background:linear-gradient(135deg,#ff4545,#df2020)!important;
    border-color:rgba(255,255,255,.12)!important;
    box-shadow:0 14px 28px rgba(241,54,54,.22)!important;
  }
  .mobile-menu-label{
    color:#8fb5df!important;
    font-size:12px!important;
    text-transform:uppercase!important;
    letter-spacing:.12em!important;
    font-weight:900!important;
    margin:16px 4px 8px!important;
  }
  .mobile-main-link{font-size:18px!important;}
  .mobile-socials{
    display:grid!important;
    grid-template-columns:1fr 1fr!important;
    gap:10px!important;
    margin-top:14px!important;
  }
  .mobile-socials a{
    text-align:center!important;
    background:rgba(21,152,255,.11)!important;
  }
  .menu-open .mobile-quickbar{display:none!important;}
  .mobile-quickbar{
    position:fixed!important;
    left:12px!important;
    right:12px!important;
    bottom:calc(12px + env(safe-area-inset-bottom))!important;
    z-index:90!important;
    display:grid!important;
    grid-template-columns:repeat(3,1fr)!important;
    gap:8px!important;
    padding:8px!important;
    border-radius:22px!important;
    background:rgba(8,14,21,.92)!important;
    backdrop-filter:blur(18px)!important;
    border:1px solid rgba(255,255,255,.12)!important;
    box-shadow:0 16px 44px rgba(0,0,0,.36)!important;
  }
  .mobile-quickbar a{
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    gap:2px!important;
    min-height:46px!important;
    padding:7px 4px!important;
    border-radius:16px!important;
    color:#fff!important;
    font-size:12px!important;
    font-weight:900!important;
    text-align:center!important;
    background:rgba(255,255,255,.06)!important;
    border:1px solid rgba(255,255,255,.08)!important;
  }
  .mobile-quickbar a::before{font-size:17px;line-height:1;display:block;}
  .mobile-quickbar a:nth-child(1)::before{content:"☎";}
  .mobile-quickbar a:nth-child(2)::before{content:"✆";}
  .mobile-quickbar a:nth-child(3){
    background:linear-gradient(135deg,#ff4545,#df2020)!important;
    border-color:rgba(255,255,255,.12)!important;
    box-shadow:0 10px 22px rgba(241,54,54,.24)!important;
  }
  .mobile-quickbar a:nth-child(3)::before{content:"✉";}
}
@media(max-width:640px){
  .hero-inner{padding-bottom:72px!important;}
}


/* ===== v30 Feinschliff: Hero-Teamfoto, mobile Menü, Quickbar, Leistungskarten ===== */

/* Teamfoto im Hero komplett zeigen, nicht eng croppen */
.hero-team-photo{
  aspect-ratio:16/9!important;
  min-height:0!important;
  height:auto!important;
  border-radius:34px!important;
  overflow:hidden!important;
  background:#0b1119!important;
}
.hero-team-photo img{
  position:relative!important;
  inset:auto!important;
  width:100%!important;
  height:auto!important;
  aspect-ratio:16/9!important;
  object-fit:contain!important;
  object-position:center center!important;
  filter:brightness(.86) contrast(1.04) saturate(.96)!important;
}
.hero-team-photo:after{
  background:linear-gradient(180deg,rgba(5,9,15,0),rgba(5,9,15,.35))!important;
}
.hero-team-caption{
  left:22px!important;
  right:auto!important;
  bottom:22px!important;
  width:min(520px,calc(100% - 44px))!important;
  padding:18px 20px!important;
}
.hero-team-caption strong{font-size:25px!important}

/* Hero Text mobil besser lesbar */
.hero p strong{font-weight:700;color:#fff}
@media(max-width:640px){
  .hero h1{font-size:38px!important;line-height:1.05!important}
  .hero p{font-size:18px!important;line-height:1.55!important}
  .hero-team-caption{position:static!important;width:auto!important;margin:10px 0 0!important;border-radius:18px!important}
  .hero-team-photo:after{display:none!important}
}

/* Leistungskarten: ganze Kachel klickbar, nur ein CTA */
.service-card{display:block!important;color:inherit!important}
.service-card .cta-row{justify-content:flex-start!important;margin-top:18px!important}
.service-card .cta-row .ghost{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:11px 15px!important;
  border-radius:14px!important;
  color:#fff!important;
  font-weight:900!important;
  white-space:nowrap!important;
}
.secondary-grid{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:22px!important;
}
.secondary-grid .service-card{min-height:360px!important}
.secondary-grid .service-card h3{font-size:30px!important;line-height:1.08!important}
.secondary-grid .service-card p{font-size:16px!important;line-height:1.5!important}

/* Mobile Menü: Kontakt und Anfrage sofort oben sichtbar */
.mobile-menu-top{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:10px!important;
  margin-bottom:14px!important;
}
.mobile-menu-top .mobile-action{
  border-radius:16px!important;
  min-height:50px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  font-weight:900!important;
}
.mobile-menu-top .primary{
  grid-column:1/-1!important;
  background:linear-gradient(135deg,#ff4545,#df2020)!important;
  color:#fff!important;
}

/* Untere mobile Schnellleiste edler und weniger massiv */
@media(max-width:980px){
  body{padding-bottom:76px!important}
  .mobile-quickbar{
    position:fixed!important;
    left:14px!important;
    right:14px!important;
    bottom:calc(12px + env(safe-area-inset-bottom))!important;
    z-index:90!important;
    display:grid!important;
    grid-template-columns:repeat(3,1fr)!important;
    gap:7px!important;
    padding:7px!important;
    border-radius:999px!important;
    background:rgba(8,14,21,.88)!important;
    backdrop-filter:blur(18px)!important;
    border:1px solid rgba(255,255,255,.12)!important;
    box-shadow:0 18px 46px rgba(0,0,0,.38)!important;
  }
  .mobile-quickbar a{
    min-height:42px!important;
    padding:8px 6px!important;
    border-radius:999px!important;
    color:#fff!important;
    font-size:13px!important;
    font-weight:900!important;
    background:rgba(255,255,255,.065)!important;
    border:1px solid rgba(255,255,255,.09)!important;
    box-shadow:none!important;
  }
  .mobile-quickbar a:nth-child(3){
    background:linear-gradient(135deg,rgba(255,69,69,.92),rgba(223,32,32,.92))!important;
  }
  .mobile-quickbar a::before{
    display:none!important;
    content:""!important;
  }
  .menu-open .mobile-quickbar{display:none!important}
  .secondary-grid{grid-template-columns:1fr!important}
  .secondary-grid .service-card{min-height:330px!important}
}


/* ===== v32: finale Freelancer-Bilder – bessere Platzierung ohne harte Crops ===== */

@media (min-width:981px){
  .hero-grid{grid-template-columns:.92fr 1.08fr!important;gap:54px!important;align-items:center!important;}
}
.hero-team-photo{
  aspect-ratio:16/9!important;
  min-height:0!important;
  height:auto!important;
  border-radius:34px!important;
  overflow:hidden!important;
  background:#0b1119!important;
}
.hero-team-photo img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
  filter:brightness(.86) contrast(1.04) saturate(.96)!important;
}
.hero-team-photo:after{background:linear-gradient(180deg,rgba(5,9,15,0),rgba(5,9,15,.34))!important;}
.hero-team-caption{left:22px!important;right:22px!important;bottom:22px!important;width:auto!important;max-width:560px!important;padding:18px 20px!important;}

.service-grid{align-items:start!important;}
.service-card{
  min-height:0!important;
  height:auto!important;
  aspect-ratio:16/9!important;
}
.service-card img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
}
.service-card.card-unterhalt{aspect-ratio:3/2!important;}
.service-card.card-portrait{aspect-ratio:4/3!important;}
.service-card.card-pv img{object-position:center center!important;}
.service-card.card-pu img{object-position:center center!important;}
.service-card.card-stein img{object-position:center center!important;}
.service-card.card-fassade img{object-position:center center!important;}
.service-card.card-hausmeister img{object-position:center center!important;}
.service-card.card-bau img{object-position:center center!important;}
.secondary-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:22px!important;
}
.secondary-grid .service-card{min-height:0!important;}
.secondary-grid .service-card h3{font-size:30px!important;line-height:1.08!important;}
.secondary-grid .service-card p{font-size:16px!important;line-height:1.5!important;}
.service-card p{max-height:none!important;margin-top:8px!important;}

.visual{background:#0b1119!important;}
.visual img{
  width:100%!important;
  height:auto!important;
  aspect-ratio:auto!important;
  object-fit:contain!important;
  object-position:center center!important;
}

@media(max-width:980px){
  .hero-team-photo{aspect-ratio:16/10!important;}
  .hero-team-photo img{object-fit:cover!important;object-position:center center!important;}
  .hero-team-caption{position:static!important;margin:10px 0 0!important;border-radius:18px!important;width:auto!important;max-width:none!important;}
  .hero-team-photo:after{display:none!important;}
  .service-grid,.secondary-grid{grid-template-columns:1fr!important;}
  .service-card{aspect-ratio:16/10!important;}
  .service-card.card-unterhalt,.service-card.card-portrait{aspect-ratio:4/3!important;}
}


/* ===== v33: Abstände, Bildgrößen, Kontaktformular, PU-Vorher/Nachher, Fassadenlogik ===== */

/* Startseite: Leistungen größer, weniger Leerlauf */
.services-wide{
  padding-top:58px!important;
  padding-bottom:54px!important;
}
.services-wide .wrap{
  width:min(1380px,calc(100% - 44px))!important;
}
.services-wide .section-sub{
  margin-bottom:26px!important;
}
.services-wide .service-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:26px!important;
  margin-top:28px!important;
}
.services-wide .service-card{
  min-height:0!important;
  aspect-ratio:16/9!important;
  border-radius:30px!important;
}
.services-wide .service-card.card-unterhalt{aspect-ratio:3/2!important}
.services-wide .service-card.card-portrait{aspect-ratio:4/3!important}
.services-wide .service-card:last-child{
  grid-column:1/-1!important;
  aspect-ratio:21/8!important;
}
.services-wide .service-card img{
  filter:brightness(.90) contrast(1.04) saturate(.94)!important;
}
.services-wide .service-card:before{
  background:linear-gradient(180deg,rgba(5,8,13,.04),rgba(5,8,13,.45) 52%,rgba(5,8,13,.86))!important;
}
.services-wide .service-card .content{
  padding:28px!important;
}
.services-wide .service-card h3{
  font-size:clamp(30px,3vw,42px)!important;
}
.services-wide .service-card p{
  font-size:17px!important;
  line-height:1.52!important;
  max-width:760px!important;
}
.services-wide + .section{
  padding-top:54px!important;
}

/* Hero-Foto größer, aber nicht unnötig abgeschnitten */
@media(min-width:981px){
  .hero-grid{
    grid-template-columns:.86fr 1.14fr!important;
    gap:58px!important;
  }
  .hero-team-photo{
    min-height:520px!important;
    aspect-ratio:auto!important;
  }
  .hero h1{
    font-size:clamp(48px,6.3vw,82px)!important;
  }
}
.hero-team-photo img{
  object-fit:cover!important;
  object-position:center center!important;
  filter:brightness(.88) contrast(1.04) saturate(.96)!important;
}

/* CTA Telefonnummer darf nicht umbrechen */
.cta-band{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) max-content max-content!important;
  align-items:center!important;
}
.cta-band .phone,
.phone{
  white-space:nowrap!important;
  min-width:max-content!important;
  font-variant-numeric:tabular-nums!important;
}
@media(max-width:760px){
  .cta-band{
    grid-template-columns:1fr!important;
    text-align:left!important;
  }
  .cta-band .phone{font-size:24px!important}
}

/* PU vorher/nachher besser sichtbar */
.pu-before-after .service-card{
  aspect-ratio:16/9!important;
}
.pu-before-after .service-card img{
  filter:brightness(1.02) contrast(1.05) saturate(.98)!important;
}
.pu-before-after .service-card:before{
  background:linear-gradient(180deg,rgba(5,8,13,0),rgba(5,8,13,.10) 48%,rgba(5,8,13,.56))!important;
}
.pu-before-after .service-card .tag{
  background:rgba(8,14,21,.62)!important;
}
.pu-before-after .service-card h3{
  text-shadow:0 2px 12px rgba(0,0,0,.45)!important;
}

/* Kontaktseite: keine leere linke Fläche neben langem Formular */
.contact-card{
  grid-template-columns:1fr!important;
  max-width:1120px!important;
  margin-inline:auto!important;
}
.contact-box{
  display:block!important;
}
.contact-form-card{
  padding:34px!important;
}
@media(min-width:981px){
  .contact-form-card .form-grid.two{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .contact-form-card .form-grid.three{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
  }
}

/* Bot-Schutz-Feld unsichtbar halten */
.hp-field{
  display:none!important;
  position:absolute!important;
  left:-9999px!important;
  top:auto!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
}

/* Mobile: Karten größer und mit weniger unnötigem Abstand */
@media(max-width:980px){
  .services-wide{
    padding-top:48px!important;
    padding-bottom:48px!important;
  }
  .services-wide .wrap{
    width:min(100% - 28px,720px)!important;
  }
  .services-wide .service-grid{
    grid-template-columns:1fr!important;
    gap:18px!important;
  }
  .services-wide .service-card,
  .services-wide .service-card.card-unterhalt,
  .services-wide .service-card.card-portrait,
  .services-wide .service-card:last-child{
    grid-column:auto!important;
    aspect-ratio:16/10!important;
  }
  .services-wide .service-card .content{padding:22px!important}
  .services-wide .service-card h3{font-size:30px!important}
}



/* v34: Teamfoto auf Über-uns- und Karriere-Seite vollständig sichtbar */
.page-hero .visual.team-visual img{
  width:100%;
  height:auto;
  aspect-ratio:16/9;
  object-fit:cover;
  object-position:center center;
}
.page-hero .visual.team-visual picture{
  display:block;
}
@media(max-width:980px){
  .page-hero .visual.team-visual img{
    aspect-ratio:16/10;
    object-position:center center;
  }
}


/* ===== v35: mobile hero team photo + stronger FAQ ===== */

/* Desktop: team photo is wider, faces visible, trust cards below hero */
@media (min-width:981px){
  .hero-grid{
    grid-template-columns:.82fr 1.18fr!important;
    gap:58px!important;
    align-items:center!important;
  }
  .hero-team-photo{
    width:100%!important;
    aspect-ratio:16/9!important;
    min-height:0!important;
    height:auto!important;
  }
  .hero-proof-row{
    max-width:none!important;
    margin-top:28px!important;
    grid-template-columns:repeat(3,1fr)!important;
  }
}

/* Team image should not be hidden behind the text box */
.hero-team-photo{
  position:relative!important;
  border-radius:34px!important;
  overflow:hidden!important;
  background:#101926!important;
  border:1px solid rgba(255,255,255,.10)!important;
  box-shadow:var(--shadow)!important;
}
.hero-team-photo img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
  filter:brightness(.90) contrast(1.03) saturate(.96)!important;
}
.hero-team-caption{
  position:absolute!important;
  left:22px!important;
  right:22px!important;
  bottom:22px!important;
  z-index:2!important;
  max-width:560px!important;
  padding:18px 20px!important;
  border-radius:20px!important;
  background:rgba(6,12,20,.72)!important;
  border:1px solid rgba(255,255,255,.12)!important;
  backdrop-filter:blur(12px)!important;
}
.hero-team-caption strong{
  font-size:25px!important;
  line-height:1.08!important;
}
.hero-team-caption span{
  font-size:15px!important;
  line-height:1.45!important;
}

/* Better FAQ headline + cards */
.home-faq .section-title{
  max-width:980px!important;
}
.home-faq .faq-grid{
  margin-top:34px!important;
}
.home-faq .faq-item{
  border-radius:24px!important;
}
.home-faq summary{
  font-size:clamp(21px,2.1vw,28px)!important;
  line-height:1.18!important;
}
.home-faq .faq-answer p{
  font-size:18px!important;
  line-height:1.65!important;
}

/* Mobile: show the complete team image first, caption below image, no cover over faces */
@media(max-width:980px){
  .hero-inner{
    padding-top:54px!important;
  }
  .hero-grid{
    grid-template-columns:1fr!important;
    gap:28px!important;
  }
  .hero-team-photo{
    aspect-ratio:16/9!important;
    min-height:0!important;
    height:auto!important;
    overflow:visible!important;
    border-radius:28px!important;
    background:transparent!important;
    box-shadow:none!important;
    border:0!important;
  }
  .hero-team-photo img{
    position:relative!important;
    inset:auto!important;
    width:100%!important;
    height:auto!important;
    object-fit:contain!important;
    object-position:center center!important;
    border-radius:28px!important;
    box-shadow:var(--shadow)!important;
    filter:brightness(.92) contrast(1.03) saturate(.96)!important;
  }
  .hero-team-photo:after{
    display:none!important;
  }
  .hero-team-caption{
    position:relative!important;
    left:auto!important;
    right:auto!important;
    bottom:auto!important;
    margin-top:12px!important;
    padding:16px 18px!important;
    border-radius:20px!important;
    background:rgba(11,18,28,.86)!important;
  }
  .hero-team-caption strong{
    font-size:22px!important;
  }
  .hero-proof-row{
    grid-template-columns:1fr!important;
    margin-top:22px!important;
  }
  .hero-proof-row div{
    padding:18px!important;
  }
}


/* v36-polish-and-security */
html{scroll-padding-top:118px}
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{
  outline:3px solid rgba(21,152,255,.72)!important;
  outline-offset:3px!important;
}
.bot-trap,.hp-field{
  /* display:none verhindert, dass Desktop-Browser (z. B. Chrome-Autofill)
     die Honeypot-Felder automatisch befüllen und dadurch den Versand blockieren. */
  display:none!important;
  position:absolute!important;
  left:-10000px!important;
  top:auto!important;
  width:1px!important;
  height:1px!important;
  opacity:0!important;
  pointer-events:none!important;
  overflow:hidden!important;
}
.form-security-message{
  padding:14px 16px;
  border-radius:14px;
  background:#fff3f3;
  border:1px solid rgba(239,48,48,.25);
  color:#8a1e1e;
  font-weight:800;
}
.contact-form button[disabled]{
  opacity:.72;
  cursor:not-allowed;
  box-shadow:none!important;
}
.contact-form-card{
  position:relative;
}
.contact-form-card:before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:24px;
  pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(21,152,255,.03);
}
.contact-card{
  align-items:start!important;
}
.dynamic-fields.active{
  animation:fieldFade .18s ease both;
}
@keyframes fieldFade{from{opacity:.45;transform:translateY(4px)}to{opacity:1;transform:none}}
summary::-webkit-details-marker{display:none}
.faq-item summary::before{
  content:"▸";
  display:inline-block;
  margin-right:8px;
  transform:translateY(-1px);
}
.faq-item[open] summary::before{
  content:"▾";
}
.service-card,.trust-card,.method,.mini,.faq-item,.contact-box,.contact-form-card{
  will-change:auto;
}
img{height:auto}
.mobile-panel{max-height:calc(100vh - 112px);overflow:auto}
@media(max-width:980px){
  body{padding-bottom:calc(88px + env(safe-area-inset-bottom))!important}
  .mobile-quickbar{max-width:680px;margin:0 auto!important}
  .footer{padding-bottom:calc(120px + env(safe-area-inset-bottom))!important}
  .contact-form-card{padding:24px!important}
  .input{font-size:16px!important}
}
@media(min-width:981px){
  .contact-card{
    grid-template-columns:minmax(0,.72fr) minmax(0,1.28fr)!important;
  }
}


/* ===== v37 fachliche Korrekturen, Layout-Rhythmus und bessere Bildplatzierung ===== */
:root{--cream:#f3f0ea;--card:#ffffff;}

/* Grundrhythmus: nicht zu viel Luft, aber sauber getrennt */
.section{padding-top:66px!important;padding-bottom:66px!important}
.section + .section{margin-top:0!important}
.services-wide{padding-top:54px!important;padding-bottom:36px!important}
.services-wide + .section{padding-top:42px!important}

/* Startseite Hero: Teamfoto auf Desktop größer, nicht wie ein Mini-Bild */
@media(min-width:981px){
  .hero-inner{padding-top:88px!important;padding-bottom:86px!important}
  .hero-grid{grid-template-columns:.78fr 1.22fr!important;gap:62px!important;align-items:center!important}
  .hero h1{font-size:clamp(50px,6vw,78px)!important;line-height:1.03!important}
  .hero-team-photo{min-height:560px!important;width:100%!important;aspect-ratio:auto!important;border-radius:34px!important;overflow:hidden!important}
  .hero-team-photo img{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;object-fit:cover!important;object-position:center center!important;filter:brightness(.90) contrast(1.03) saturate(.96)!important}
  .hero-team-caption{max-width:520px!important;left:24px!important;right:auto!important;bottom:24px!important}
}
@media(max-width:980px){
  .hero-team-photo{aspect-ratio:16/9!important;overflow:visible!important;background:transparent!important;border:0!important;box-shadow:none!important}
  .hero-team-photo img{position:relative!important;width:100%!important;height:auto!important;object-fit:contain!important;border-radius:26px!important;box-shadow:var(--shadow)!important}
  .hero-team-caption{position:relative!important;left:auto!important;right:auto!important;bottom:auto!important;margin-top:12px!important}
}

/* Leistungsübersicht: größere Bilder, weniger Lücken, letzte Karte nicht allein verloren */
.services-wide .wrap{width:min(1340px,calc(100% - 44px))!important}
.services-wide .section-sub{margin-bottom:22px!important}
.services-wide .service-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:22px!important;margin-top:24px!important;align-items:stretch!important}
.services-wide .service-card{min-height:0!important;aspect-ratio:16/9!important;border-radius:28px!important}
.services-wide .service-card.card-unterhalt{aspect-ratio:16/9!important}
.services-wide .service-card.card-portrait{aspect-ratio:16/9!important}
.services-wide .service-card:nth-last-child(1):nth-child(odd){grid-column:1/-1!important;aspect-ratio:28/9!important}
.services-wide .service-card img{filter:brightness(.92) contrast(1.04) saturate(.96)!important;object-fit:cover!important}
.services-wide .service-card:before{background:linear-gradient(180deg,rgba(5,8,13,.02),rgba(5,8,13,.43) 48%,rgba(5,8,13,.88))!important}
.services-wide .service-card .content{padding:26px!important}
.services-wide .service-card h3{font-size:clamp(30px,3vw,40px)!important}
.services-wide .service-card p{font-size:17px!important;line-height:1.5!important;max-width:820px!important}
.services-wide .service-card .ghost{font-size:15px!important}
@media(max-width:980px){
  .services-wide .wrap{width:min(1220px,calc(100% - 30px))!important}
  .services-wide .service-grid{grid-template-columns:1fr!important;gap:18px!important}
  .services-wide .service-card,.services-wide .service-card:nth-last-child(1):nth-child(odd){grid-column:auto!important;aspect-ratio:4/3!important}
  .services-wide{padding-bottom:26px!important}
}

/* Unterseiten: Hero-Bilder auf Desktop größer */
@media(min-width:981px){
  .page-hero{padding:90px 0 76px!important}
  .page-hero-grid{grid-template-columns:.78fr 1.22fr!important;gap:58px!important;align-items:center!important}
  .page-hero .visual{min-height:430px!important;border-radius:30px!important}
  .page-hero .visual img{height:100%!important;aspect-ratio:auto!important;object-fit:cover!important;object-position:center center!important}
  .page-hero h1{font-size:clamp(48px,5.8vw,76px)!important}
}
@media(max-width:980px){
  .page-hero .visual img{aspect-ratio:16/10!important;object-fit:cover!important}
}

/* CTA: Telefonnummer nie auf zwei Zeilen */
.cta-band{grid-template-columns:minmax(0,1fr) max-content max-content!important;gap:24px!important;align-items:center!important}
.cta-band .phone,.phone{white-space:nowrap!important;display:inline-block!important;font-variant-numeric:tabular-nums!important;min-width:max-content!important}
.cta-band .btn{white-space:nowrap!important}
@media(max-width:760px){.cta-band{grid-template-columns:1fr!important}.cta-band .phone{margin:10px 0!important}}

/* PU/Bodensanierung Vorher-Nachher: Bilder erkennbar lassen */
.pu-before-after .service-card:before{background:linear-gradient(180deg,rgba(5,8,13,.03),rgba(5,8,13,.22) 55%,rgba(5,8,13,.62))!important}
.pu-before-after .service-card img{filter:brightness(1.08) contrast(1.04) saturate(1.02)!important}
.pu-before-after .service-card h3{text-shadow:0 2px 14px rgba(0,0,0,.35)}

/* Kontaktformular mehr Breite, linke Spalte kompakter */
@media(min-width:981px){
  .contact-card{grid-template-columns:minmax(260px,.50fr) minmax(0,1.50fr)!important;gap:26px!important;align-items:start!important}
  .contact-form-card{padding:34px!important}
}
.contact-box .social-links a{color:#101722!important}

/* Floating WhatsApp: Festnetznummer, nicht am Rand kleben */
.hotline-float{right:34px!important;bottom:34px!important;max-width:235px!important;z-index:65!important}
.hotline-float span{white-space:nowrap!important}
@media(max-width:980px){.hotline-float{display:none!important}}

/* Fachtext-Bausteine */
.detail-rich .method-grid{margin-top:28px!important}
.detail-rich .method h4{color:#101722}
.detail-rich .method p{font-size:16.5px;line-height:1.65}
.check-list{display:grid;gap:10px;margin:18px 0 0;padding:0;list-style:none}
.check-list li{display:flex;gap:10px;align-items:flex-start;color:#273244;font-weight:700;line-height:1.55}
.check-list li:before{content:'✓';color:var(--blue);font-weight:900;flex:0 0 auto}
.info-band{margin-top:28px;padding:26px;border-radius:24px;background:linear-gradient(135deg,#0e1a29,#14263a);color:#fff;border:1px solid rgba(255,255,255,.10);box-shadow:var(--shadow)}
.info-band h3{margin:0 0 10px;font-size:26px;color:#fff}.info-band p{margin:0;color:#dbe7f6;line-height:1.65}
.farb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:22px}.farb-card{border-radius:20px;padding:20px;background:#fff;border:1px solid var(--lineDark);box-shadow:0 12px 28px rgba(16,23,34,.06)}.farb-card strong{display:block;font-size:18px;margin-bottom:8px}.farb-card p{margin:0;color:#566679}.dot-blue,.dot-red,.dot-yellow,.dot-green{width:16px;height:16px;border-radius:99px;display:inline-block;margin-right:8px;vertical-align:-2px}.dot-blue{background:#1598ff}.dot-red{background:#ef3030}.dot-yellow{background:#f3bf25}.dot-green{background:#2bbf66}
@media(max-width:980px){.farb-grid{grid-template-columns:1fr}.detail-rich .method-grid{grid-template-columns:1fr!important}}

/* Rechtliche Seiten lesbarer */
.legal-card{background:#fff;border:1px solid var(--lineDark);border-radius:28px;padding:34px;box-shadow:0 18px 44px rgba(16,23,34,.08)}
.legal-card h2{font-size:30px;margin:28px 0 12px}.legal-card h2:first-child{margin-top:0}.legal-card h3{font-size:22px;margin:20px 0 8px}.legal-card p,.legal-card li{color:#263245;line-height:1.7}.legal-card ul{padding-left:22px}

/* ===== v38 Fix Unterseiten-Bilder: Desktop-Hero sauber füllen, kein schwarzer Leerraum ===== */
@media (min-width: 981px){
  .page-hero-grid{
    grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr) !important;
    gap:48px !important;
    align-items:center !important;
  }
  .page-hero .visual{
    position:relative !important;
    width:100% !important;
    height:480px !important;
    min-height:480px !important;
    max-height:480px !important;
    overflow:hidden !important;
    border-radius:30px !important;
    background:#0b1119 !important;
  }
  .page-hero .visual img{
    position:absolute !important;
    inset:0 !important;
    width:100% !important;
    height:100% !important;
    display:block !important;
    object-fit:cover !important;
    object-position:center center !important;
    aspect-ratio:auto !important;
  }
}

/* Etwas kompaktere Lücken in der Leistungsübersicht auf Desktop */
@media (min-width: 981px){
  .services-wide .service-grid{
    gap:18px !important;
  }
}


/* ===== v39 finale Durchsicht: Bildgrößen, Abstände, CTA, Kontakt, Mobile ===== */

/* Leistungsseiten: Bild darf nie klein mit schwarzem Leerraum darunter wirken */
@media (min-width:981px){
  .page-hero{padding-top:92px!important;padding-bottom:82px!important;}
  .page-hero-grid{
    grid-template-columns:minmax(0,.90fr) minmax(520px,1.10fr)!important;
    gap:54px!important;
    align-items:center!important;
  }
  .page-hero .visual{
    position:relative!important;
    width:100%!important;
    aspect-ratio:16/9!important;
    height:auto!important;
    min-height:0!important;
    max-height:none!important;
    overflow:hidden!important;
    border-radius:32px!important;
    background:transparent!important;
    box-shadow:var(--shadow)!important;
  }
  .page-hero .visual img{
    position:absolute!important;
    inset:0!important;
    width:100%!important;
    height:100%!important;
    display:block!important;
    object-fit:cover!important;
    object-position:center center!important;
    aspect-ratio:auto!important;
    filter:brightness(.94) contrast(1.04) saturate(.97)!important;
  }
  .page-hero h1{font-size:clamp(48px,5.4vw,78px)!important;line-height:1.02!important;}
  .page-hero p{max-width:780px!important;}
}
@media (max-width:980px){
  .page-hero{padding-top:50px!important;padding-bottom:56px!important;}
  .page-hero .visual{aspect-ratio:16/10!important;height:auto!important;min-height:0!important;background:transparent!important;}
  .page-hero .visual img{position:relative!important;width:100%!important;height:100%!important;object-fit:cover!important;aspect-ratio:16/10!important;}
}

/* Startseite: Teamfoto mehr Präsenz, mobil vollständig sichtbar */
@media (min-width:981px){
  .hero-inner{padding-top:88px!important;padding-bottom:88px!important;}
  .hero-grid{grid-template-columns:minmax(0,.92fr) minmax(560px,1.08fr)!important;gap:56px!important;align-items:center!important;}
  .hero h1{font-size:clamp(48px,5.4vw,82px)!important;line-height:1.02!important;}
  .hero-team-photo{position:relative!important;width:100%!important;aspect-ratio:16/9!important;min-height:0!important;height:auto!important;border-radius:34px!important;overflow:hidden!important;background:transparent!important;}
  .hero-team-photo img{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;object-fit:cover!important;object-position:center center!important;filter:brightness(.90) contrast(1.03) saturate(.96)!important;}
  .hero-team-caption{left:24px!important;right:24px!important;bottom:24px!important;max-width:560px!important;}
}
@media (max-width:980px){
  .hero-team-photo{aspect-ratio:auto!important;height:auto!important;min-height:0!important;background:transparent!important;border:0!important;box-shadow:none!important;overflow:visible!important;}
  .hero-team-photo img{position:relative!important;width:100%!important;height:auto!important;object-fit:contain!important;aspect-ratio:auto!important;border-radius:26px!important;box-shadow:var(--shadow)!important;}
  .hero-team-caption{position:relative!important;left:auto!important;right:auto!important;bottom:auto!important;margin-top:12px!important;padding:18px!important;}
}

/* Leistungsübersichten: alle Karten einheitlich hoch, keine Lücken zwischen Reihen */
.service-grid{align-items:stretch!important;}
.service-grid .service-card,
.services-wide .service-grid .service-card{
  min-height:0!important;
  aspect-ratio:16/9!important;
  height:auto!important;
}
.service-grid .service-card img,
.services-wide .service-grid .service-card img{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  object-position:center center!important;
  filter:brightness(.88) contrast(1.04) saturate(.96)!important;
}
.service-grid .service-card:before,
.services-wide .service-grid .service-card:before{
  background:linear-gradient(180deg,rgba(5,8,13,.04),rgba(5,8,13,.50) 50%,rgba(5,8,13,.91))!important;
}
.service-card .content{padding:24px!important;}
.service-card p{max-height:none!important;overflow:visible!important;margin-top:8px!important;}
.service-card .cta-row{margin-top:16px!important;}
@media (min-width:981px){
  .service-grid{gap:22px!important;}
  .service-grid .service-card:last-child:nth-child(odd){grid-column:1/-1!important;aspect-ratio:28/9!important;}
  .service-grid .service-card:last-child:nth-child(odd) .content{max-width:760px!important;}
  .services-wide .wrap{width:min(1340px,calc(100% - 44px))!important;}
}
@media(max-width:980px){
  .service-grid .service-card,.service-grid .service-card:last-child:nth-child(odd){grid-column:auto!important;aspect-ratio:4/3!important;}
}

/* CTA und Telefonnummern */
.cta-band{display:grid!important;grid-template-columns:minmax(0,1fr) max-content max-content!important;align-items:center!important;gap:24px!important;}
.phone,.cta-band .phone{white-space:nowrap!important;display:inline-block!important;font-variant-numeric:tabular-nums!important;line-height:1.15!important;}
.cta-band .btn{white-space:nowrap!important;}
@media(max-width:760px){.cta-band{grid-template-columns:1fr!important}.cta-band .phone{margin:8px 0!important}}

/* Floating WhatsApp: nicht an Bildschirmkante kleben */
.hotline-float{right:28px!important;bottom:34px!important;max-width:260px!important;}
@media(min-width:981px){body{padding-bottom:0!important;}}
@media(max-width:980px){.hotline-float{display:none!important}.mobile-quickbar{box-shadow:0 -18px 45px rgba(0,0,0,.24)!important}.menu-open .mobile-quickbar{display:none!important}}

/* Kontaktformular: Hauptformular bekommt Platz, Direktkontakt kompakt */
@media(min-width:981px){
  .contact-card{grid-template-columns:minmax(260px,.48fr) minmax(0,1.52fr)!important;gap:26px!important;align-items:start!important;}
  .contact-form-card{padding:34px!important;}
}
.form-security-message{margin-top:8px;color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-radius:12px;padding:10px 12px;font-weight:800;}

/* Vorher/Nachher und dunkle Servicebilder: Lesbar, aber Bild erkennbar */
.pu-before-after .service-card:before{background:linear-gradient(180deg,rgba(5,8,13,.01),rgba(5,8,13,.18) 54%,rgba(5,8,13,.52))!important;}
.pu-before-after .service-card img{filter:brightness(1.18) contrast(1.04) saturate(1.03)!important;}

/* Rechtliche Seiten angenehm lesbar */
.legal-card{max-width:1120px!important;margin:0 auto!important;}
.legal-card h2{margin-top:28px!important;}



/* ===== v40 final layout + tracking + image tuning ===== */
.page-hero-grid{grid-template-columns:minmax(0,1.02fr) minmax(0,.98fr)!important;gap:58px!important;align-items:center!important}
.page-hero-grid > *{min-width:0!important}
.page-hero-grid > div:first-child{position:relative;z-index:2;max-width:720px!important}
.page-hero{overflow:hidden}
.page-hero h1{overflow-wrap:anywhere;word-break:normal;position:relative;z-index:2}
.page-hero p{position:relative;z-index:2}
.page-hero .visual{position:relative;z-index:1;justify-self:end;width:100%;max-width:680px!important;aspect-ratio:16/10!important;display:flex!important;align-items:center!important;overflow:hidden!important;border-radius:30px!important;background:rgba(255,255,255,.05)!important}
.page-hero .visual img{width:100%!important;height:100%!important;display:block!important;aspect-ratio:auto!important;object-fit:cover!important;object-position:center center!important}
.page-hero .hero-image-box{box-shadow:var(--shadow)!important}

/* Hero image tuning per page */
.page-unterhalt .page-hero .visual img{object-position:50% 48%!important}
.page-glas .page-hero .visual img{object-position:52% 46%!important}
.page-stein .page-hero .visual img{object-position:50% 24%!important}
.page-fassade .page-hero .visual img{object-position:50% 48%!important}
.page-tiefgarage .page-hero .visual img{object-position:50% 54%!important}
.page-hausmeister .page-hero .visual img{object-position:56% 42%!important}
.page-pv .page-hero .visual img{object-position:50% 28%!important}
.page-bodensanierung .page-hero .visual img{object-position:50% 24%!important}
.page-baureinigung .page-hero .visual img{object-position:50% 44%!important}
.page-ueber-uns .page-hero .visual img{object-position:50% 34%!important}
.page-ratgeber .page-hero .visual img{object-position:50% 48%!important}
.page-referenzen .page-hero .visual img{object-position:50% 34%!important}
.page-karriere .page-hero .visual img{object-position:50% 34%!important}
.page-dachrinne .page-hero .visual img{object-position:50% 48%!important}

/* Service overview cards */
.service-grid{align-items:stretch!important}
.service-grid .service-card,
.services-wide .service-card{display:block!important;min-height:0!important;aspect-ratio:16/10!important;border-radius:28px!important;overflow:hidden!important}
.service-grid .service-card img,
.services-wide .service-card img{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important}
.service-grid .service-card:last-child:nth-child(odd),
.services-wide .service-card:last-child:nth-child(odd){grid-column:1/-1!important;aspect-ratio:21/8!important}
.service-grid .service-card .content,
.services-wide .service-card .content{padding:26px!important}
.service-grid .service-card h3,
.services-wide .service-card h3{font-size:clamp(26px,2.7vw,40px)!important;line-height:1.05!important}
.service-grid .service-card p,
.services-wide .service-card p{font-size:17px!important;line-height:1.5!important;max-height:none!important;overflow:visible!important}

/* Subject-specific crop tuning on service cards */
.card-unterhalt img{object-position:50% 48%!important}
.card-stein img{object-position:50% 18%!important}
.card-pv img{object-position:50% 28%!important}
.card-pu img{object-position:50% 22%!important}
.card-fassade img{object-position:50% 46%!important}
.card-hausmeister img{object-position:56% 42%!important}
.card-bau img{object-position:50% 42%!important}
.card-tiefgarage img{object-position:50% 54%!important}

/* Gallery / references cards */
.gallery-grid{align-items:stretch!important}
.gallery-card img{height:250px!important;object-fit:cover!important;object-position:center center!important}
.gallery-card:nth-child(3) img{object-position:50% 18%!important}
.gallery-card:nth-child(6) img{object-position:50% 28%!important}
.gallery-card:nth-child(7) img{object-position:50% 22%!important}
.gallery-card:nth-child(8) img{object-position:50% 42%!important}
.gallery-card:nth-child(9) img{object-position:56% 42%!important}

/* Floating whatsapp a bit safer */
.hotline-float{bottom:28px!important;right:22px!important}

/* Cookie consent banner */
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:120;max-width:980px;margin:0 auto;background:rgba(8,14,21,.96);color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:22px;box-shadow:0 24px 70px rgba(0,0,0,.35);padding:22px;display:none}
.cookie-banner.show{display:block}
.cookie-banner h3{margin:0 0 8px;font-size:22px}
.cookie-banner p{margin:0;color:#d9e5f5}
.cookie-banner .cookie-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.cookie-banner .cookie-note{font-size:14px;color:#c7d4e6;margin-top:10px}
.cookie-banner .btn.muted{background:rgba(255,255,255,.05)!important;border:1px solid rgba(255,255,255,.14)!important;box-shadow:none!important}
.cookie-manage{position:fixed;left:20px;bottom:20px;z-index:110;display:none;background:#0b1521;color:#fff;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:10px 14px;box-shadow:0 18px 36px rgba(0,0,0,.24)}
.cookie-manage.show{display:inline-flex}

@media(max-width:1100px){
  .page-hero-grid{grid-template-columns:1fr!important;gap:28px!important}
  .page-hero .visual{justify-self:start!important;max-width:100%!important;aspect-ratio:16/10!important}
}
@media(max-width:980px){
  .service-grid .service-card,
  .services-wide .service-card,
  .service-grid .service-card:last-child:nth-child(odd),
  .services-wide .service-card:last-child:nth-child(odd){grid-column:auto!important;aspect-ratio:4/3!important}
  .gallery-grid{grid-template-columns:1fr!important}
}
@media(max-width:640px){
  .cookie-banner{left:12px;right:12px;bottom:12px;padding:18px}
  .cookie-banner .cookie-actions{display:grid;grid-template-columns:1fr}
  .hotline-float{bottom:84px!important;right:12px!important}
  .cookie-manage{left:12px;bottom:84px}
}


/* ===== v41: Bilder vollständig sichtbar + Dachrinnenreinigung final ===== */
/* Unterseiten: Bild darf nicht mehr unter/über Text laufen und wird nicht künstlich beschnitten */
@media (min-width: 981px){
  .page-hero{padding:88px 0 76px!important;overflow:hidden!important}
  .page-hero-grid{grid-template-columns:minmax(0,.94fr) minmax(0,1.06fr)!important;gap:56px!important;align-items:center!important}
  .page-hero-grid > *{min-width:0!important}
  .page-hero-grid > div:first-child{position:relative!important;z-index:2!important;max-width:760px!important}
  .page-hero h1{font-size:clamp(48px,5.15vw,74px)!important;line-height:1.02!important;max-width:760px!important;hyphens:auto!important;overflow-wrap:anywhere!important}
  .page-hero .visual{position:relative!important;z-index:1!important;justify-self:stretch!important;width:100%!important;max-width:780px!important;min-height:0!important;height:auto!important;aspect-ratio:auto!important;background:transparent!important;overflow:hidden!important;border-radius:30px!important}
  .page-hero .visual img{position:relative!important;inset:auto!important;width:100%!important;height:auto!important;display:block!important;aspect-ratio:auto!important;object-fit:contain!important;object-position:center center!important;background:transparent!important}
}
@media (max-width:980px){
  .page-hero .visual{min-height:0!important;height:auto!important;background:transparent!important}
  .page-hero .visual img{position:relative!important;width:100%!important;height:auto!important;object-fit:contain!important;aspect-ratio:auto!important}
}

/* Service-Karten: Text liegt nicht mehr über dem Foto, vollständiges Bild ist sichtbar */
.service-grid .service-card,
.services-wide .service-grid .service-card,
.services-wide .service-card{
  display:flex!important;flex-direction:column!important;min-height:0!important;height:auto!important;aspect-ratio:auto!important;overflow:hidden!important;background:#0b1119!important;border-radius:28px!important
}
.service-grid .service-card img,
.services-wide .service-grid .service-card img,
.services-wide .service-card img{
  position:relative!important;inset:auto!important;width:100%!important;height:auto!important;display:block!important;aspect-ratio:auto!important;object-fit:contain!important;object-position:center center!important;filter:brightness(.96) contrast(1.03) saturate(.98)!important;background:#0b1119!important;transition:none!important
}
.service-grid .service-card:before,
.services-wide .service-card:before{display:none!important}
.service-grid .service-card .content,
.services-wide .service-card .content{
  position:relative!important;left:auto!important;right:auto!important;bottom:auto!important;background:linear-gradient(180deg,#0b1119,#101926)!important;padding:22px 24px 24px!important;min-height:185px!important;display:flex!important;flex-direction:column!important;justify-content:flex-start!important
}
.service-grid .service-card h3,
.services-wide .service-card h3{font-size:clamp(28px,2.4vw,38px)!important;line-height:1.07!important;margin:12px 0 8px!important;color:#fff!important}
.service-grid .service-card p,
.services-wide .service-card p{max-height:none!important;overflow:visible!important;opacity:1!important;margin:0!important;color:#e9f1fb!important;font-size:16.5px!important;line-height:1.5!important}
.service-grid .service-card .cta-row,
.services-wide .service-card .cta-row{margin-top:auto!important;padding-top:16px!important}
.service-grid .service-card:last-child:nth-child(odd),
.services-wide .service-card:last-child:nth-child(odd){grid-column:auto!important;aspect-ratio:auto!important}
.service-card:hover img{transform:none!important}

/* Ratgeber/Referenzen: keine abgeschnittenen Vorschaubilder */
.gallery-card img,
.article-card img{height:auto!important;object-fit:contain!important;object-position:center center!important;background:#f3f0ea!important}
.gallery-card{display:flex!important;flex-direction:column!important}
.gallery-card div{flex:1!important}

/* Teamfoto auf Über-uns/Karriere/Ratgeber nicht links/rechts abschneiden */
.page-ueber-uns .page-hero .visual img,
.page-karriere .page-hero .visual img,
.page-ratgeber .page-hero .visual img,
.page-referenzen .page-hero .visual img{object-fit:contain!important;object-position:center center!important}

/* Cookie Banner nicht mit mobiler Schnellleiste kollidieren */
@media(max-width:640px){.cookie-banner{bottom:calc(82px + env(safe-area-inset-bottom))!important}.cookie-manage{bottom:calc(84px + env(safe-area-inset-bottom))!important}}

.card-dachrinne img{object-position:center center!important}


/* v42 mobile/menu/cookie/text tuning */
.page-hero{position:relative;overflow:hidden}
.hero::after,.page-hero::after{content:"";position:absolute;right:-14%;top:12%;width:46%;height:130px;background:linear-gradient(90deg,rgba(21,152,255,0),rgba(21,152,255,.22),rgba(239,48,48,.16),rgba(239,48,48,0));filter:blur(28px);transform:rotate(-8deg);pointer-events:none;animation:claySweep 9s ease-in-out infinite alternate;opacity:.9}
@keyframes claySweep{from{transform:translateX(0) rotate(-8deg)}to{transform:translateX(86px) rotate(-8deg)}}

/* show more useful crop of important images */
.page-home .service-card.card-stein img,.page-leistungen .service-card.card-stein img{object-position:50% 22%!important}
.page-home .service-card.card-pv img,.page-leistungen .service-card.card-pv img{object-position:50% 26%!important}
.page-home .service-card.card-pu img,.page-leistungen .service-card.card-pu img{object-position:50% 18%!important}
.page-home .service-card.card-bau img,.page-leistungen .service-card.card-bau img{object-position:50% 30%!important}
.page-home .service-card.card-hausmeister img,.page-leistungen .service-card.card-hausmeister img{object-position:54% 42%!important}
.page-leistungen .page-hero .visual img{object-position:50% 24%!important}
.page-ueber-uns .page-hero .visual img{object-position:50% 30%!important}
.page-ratgeber .page-hero .visual img{object-position:50% 34%!important}
.page-referenzen .page-hero .visual img{object-position:50% 28%!important}
.page-referenzen .gallery-card:nth-child(3) img{object-position:50% 20%!important}
.page-referenzen .gallery-card:nth-child(6) img{object-position:50% 24%!important}
.page-referenzen .gallery-card:nth-child(7) img{object-position:50% 18%!important}
.page-referenzen .gallery-card:nth-child(8) img{object-position:50% 28%!important}
.page-referenzen .gallery-card:nth-child(9) img{object-position:54% 36%!important}

/* cookies: only banner + footer link, no floating pill */
.cookie-manage,.cookie-manage.show{display:none!important}
.mobile-panel [data-open-cookie-settings]{display:none!important}

/* mobile cards a bit taller so more of image is visible */
@media(max-width:980px){
  .service-grid .service-card,.services-wide .service-card{aspect-ratio:4/3!important}
  .gallery-card img{height:260px!important}
}
@media(max-width:640px){
  .service-grid .service-card,.services-wide .service-card{aspect-ratio:5/4!important}
  .page-hero .visual img{aspect-ratio:4/3!important;object-fit:cover!important}
  .gallery-card img{height:235px!important}
  .hero::after,.page-hero::after{right:-30%;width:74%;height:110px}
}


/* ===== v43: Desktop-Leistungskarten wieder hochwertig als Bildkarten + Scroll-Streifen oben ===== */
.site-header{position:sticky!important;overflow:visible!important}
.site-header::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-1px;
  width:148px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--blue),var(--red));
  transform:translateX(calc(-50% + var(--clay-scroll-shift,0px)));
  transition:transform .08s linear;
  opacity:.95;
  box-shadow:0 0 22px rgba(21,152,255,.25),0 0 22px rgba(239,48,48,.22);
}
.nav>a.active:after,.drop-toggle.active:after{height:4px!important;box-shadow:0 0 18px rgba(21,152,255,.24)}

@media(min-width:981px){
  /* Desktop: Karten wieder wie hochwertige Bildkacheln, nicht Bild oben + Textblock unten */
  .service-grid .service-card,
  .services-wide .service-card,
  .services-wide .service-grid .service-card{
    position:relative!important;
    display:block!important;
    aspect-ratio:16/9!important;
    min-height:390px!important;
    height:auto!important;
    overflow:hidden!important;
    border-radius:30px!important;
    background:#101822!important;
    box-shadow:var(--shadow)!important;
  }
  .service-grid .service-card:last-child:nth-child(odd),
  .services-wide .service-card:last-child:nth-child(odd),
  .services-wide .service-grid .service-card:last-child:nth-child(odd){
    grid-column:1/-1!important;
    aspect-ratio:21/8!important;
    min-height:420px!important;
  }
  .service-grid .service-card img,
  .services-wide .service-card img,
  .services-wide .service-grid .service-card img{
    position:absolute!important;
    inset:0!important;
    width:100%!important;
    height:100%!important;
    max-width:none!important;
    object-fit:cover!important;
    display:block!important;
    filter:brightness(.84) contrast(1.05) saturate(.96)!important;
    transform:none!important;
    transition:transform .65s ease!important;
    background:#101822!important;
  }
  .service-card:hover img{transform:scale(1.025)!important}
  .service-grid .service-card:before,
  .services-wide .service-card:before{
    content:""!important;
    display:block!important;
    position:absolute!important;
    inset:0!important;
    z-index:1!important;
    background:linear-gradient(180deg,rgba(5,8,13,.04),rgba(5,8,13,.35) 42%,rgba(5,8,13,.91) 100%)!important;
  }
  .service-grid .service-card .content,
  .services-wide .service-card .content,
  .services-wide .service-grid .service-card .content{
    position:absolute!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    z-index:2!important;
    background:transparent!important;
    padding:28px!important;
    min-height:0!important;
    display:block!important;
  }
  .service-grid .service-card .tag,
  .services-wide .service-card .tag{
    width:auto!important;
    max-width:max-content!important;
    align-self:flex-start!important;
    display:inline-flex!important;
    padding:8px 13px!important;
    border-radius:999px!important;
    background:rgba(255,255,255,.16)!important;
    border:1px solid rgba(255,255,255,.22)!important;
    color:#fff!important;
  }
  .service-grid .service-card h3,
  .services-wide .service-card h3{
    font-size:clamp(31px,3vw,45px)!important;
    line-height:1.03!important;
    margin:14px 0 8px!important;
    color:#fff!important;
    text-shadow:0 2px 16px rgba(0,0,0,.35)!important;
  }
  .service-grid .service-card p,
  .services-wide .service-card p{
    font-size:18px!important;
    line-height:1.5!important;
    color:#edf4ff!important;
    margin:0!important;
    max-width:860px!important;
    max-height:none!important;
    overflow:visible!important;
    text-shadow:0 2px 14px rgba(0,0,0,.35)!important;
  }
  .service-grid .service-card .cta-row,
  .services-wide .service-card .cta-row{
    margin-top:18px!important;
    padding-top:0!important;
    justify-content:flex-start!important;
  }
  .service-grid .service-card .ghost,
  .services-wide .service-card .ghost{
    display:inline-flex!important;
    width:auto!important;
    max-width:max-content!important;
    color:#fff!important;
    background:rgba(255,255,255,.09)!important;
    border:1px solid rgba(255,255,255,.24)!important;
  }

  /* Desktop-Crops gezielt, damit Motive besser sitzen */
  .card-unterhalt img{object-position:50% 47%!important}
  .card-glas img{object-position:50% 50%!important}
  .card-fassade img{object-position:50% 48%!important}
  .card-stein img{object-position:50% 20%!important}
  .card-tiefgarage img{object-position:50% 54%!important}
  .card-hausmeister img{object-position:56% 42%!important}
  .card-pv img{object-position:50% 28%!important}
  .card-pu img{object-position:50% 20%!important}
  .card-bau img{object-position:50% 42%!important}
  .card-dachrinne img{object-position:50% 50%!important}
}

/* Mobile: Cookie-Einstellungen nicht im aufgeklappten Menü anzeigen */
.mobile-panel [data-open-cookie-settings],
.mobile-panel .cookie-manage{display:none!important}


/* ===== v44: endgültiger Fix Desktop-Leistungskarten + interaktiver Headerstreifen ===== */
/* Headerstreifen: nicht mehr statisch in der Mitte, sondern als bewegender Verlauf über die ganze Leiste */
.site-header::after{
  left:0!important;
  right:0!important;
  bottom:-1px!important;
  width:100%!important;
  height:3px!important;
  border-radius:0!important;
  transform:none!important;
  background:linear-gradient(90deg,
    transparent 0%,
    transparent 30%,
    rgba(21,152,255,.20) 38%,
    var(--blue) 46%,
    var(--red) 54%,
    rgba(239,48,48,.20) 62%,
    transparent 70%,
    transparent 100%)!important;
  background-size:240% 100%!important;
  background-position-x:calc(50% + var(--clay-scroll-shift,0px))!important;
  box-shadow:0 0 22px rgba(21,152,255,.22),0 0 22px rgba(239,48,48,.18)!important;
  opacity:.95!important;
}

/* Leistungen Hero: Teamfoto sauber darstellen */
.page-leistungen .page-hero .visual img{object-position:50% 32%!important;}

@media(min-width:981px){
  /* sauberes 2-Spalten-Raster, kein Ineinanderlaufen */
  .service-grid,
  .services-wide .service-grid{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:30px!important;
    align-items:stretch!important;
    overflow:visible!important;
  }
  .service-grid > .service-card,
  .services-wide .service-grid > .service-card,
  .services-wide > .wrap > .service-grid > .service-card{
    position:relative!important;
    display:block!important;
    min-width:0!important;
    width:100%!important;
    max-width:100%!important;
    aspect-ratio:16/9!important;
    min-height:390px!important;
    overflow:hidden!important;
    border-radius:30px!important;
    background:#101822!important;
    box-shadow:var(--shadow)!important;
    isolation:isolate!important;
  }
  .service-grid > .service-card:last-child:nth-child(odd){
    grid-column:1/-1!important;
    aspect-ratio:21/8!important;
    min-height:420px!important;
  }
  .service-grid > .service-card img,
  .services-wide .service-card img{
    position:absolute!important;
    inset:0!important;
    width:100%!important;
    height:100%!important;
    max-width:none!important;
    display:block!important;
    object-fit:cover!important;
    object-position:center center!important;
    filter:brightness(.84) contrast(1.05) saturate(.96)!important;
    transition:transform .55s ease!important;
    z-index:0!important;
  }
  .service-card:hover img{transform:scale(1.025)!important}
  .service-grid > .service-card:before,
  .services-wide .service-card:before{
    content:""!important;
    display:block!important;
    position:absolute!important;
    inset:0!important;
    z-index:1!important;
    background:linear-gradient(180deg,rgba(5,8,13,.02),rgba(5,8,13,.35) 40%,rgba(5,8,13,.92) 100%)!important;
    pointer-events:none!important;
  }
  .service-grid > .service-card .content,
  .services-wide .service-card .content{
    position:absolute!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    z-index:2!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    box-sizing:border-box!important;
    padding:26px!important;
    background:transparent!important;
    overflow:hidden!important;
    display:block!important;
  }
  .service-grid > .service-card .tag,
  .services-wide .service-card .tag{
    display:inline-flex!important;
    width:auto!important;
    max-width:max-content!important;
    padding:8px 13px!important;
    border-radius:999px!important;
    background:rgba(255,255,255,.16)!important;
    border:1px solid rgba(255,255,255,.24)!important;
    color:#fff!important;
    white-space:nowrap!important;
  }
  .service-grid > .service-card h3,
  .services-wide .service-card h3{
    font-size:clamp(30px,3vw,44px)!important;
    line-height:1.03!important;
    margin:14px 0 8px!important;
    color:#fff!important;
    max-width:100%!important;
    width:100%!important;
    overflow-wrap:normal!important;
    word-break:normal!important;
    text-shadow:0 2px 16px rgba(0,0,0,.35)!important;
  }
  .service-grid > .service-card p,
  .services-wide .service-card p{
    font-size:17px!important;
    line-height:1.45!important;
    color:#edf4ff!important;
    margin:0!important;
    width:100%!important;
    max-width:100%!important;
    overflow:hidden!important;
    display:-webkit-box!important;
    -webkit-line-clamp:3!important;
    -webkit-box-orient:vertical!important;
    text-shadow:0 2px 14px rgba(0,0,0,.35)!important;
  }
  .service-grid > .service-card .cta-row,
  .services-wide .service-card .cta-row{
    margin-top:16px!important;
    padding-top:0!important;
    justify-content:flex-start!important;
  }
  .service-grid > .service-card .ghost,
  .services-wide .service-card .ghost{
    display:inline-flex!important;
    width:auto!important;
    max-width:max-content!important;
    color:#fff!important;
    background:rgba(255,255,255,.09)!important;
    border:1px solid rgba(255,255,255,.24)!important;
  }

  /* Desktop-Crops */
  .card-unterhalt img{object-position:50% 47%!important}
  .card-glas img{object-position:50% 50%!important}
  .card-fassade img{object-position:50% 48%!important}
  .card-stein img{object-position:50% 20%!important}
  .card-tiefgarage img{object-position:50% 54%!important}
  .card-hausmeister img{object-position:56% 42%!important}
  .card-pv img{object-position:50% 28%!important}
  .card-pu img{object-position:50% 20%!important}
  .card-bau img{object-position:50% 42%!important}
  .card-dachrinne img{object-position:50% 50%!important}
}

@media(max-width:980px){
  .service-grid,.services-wide .service-grid{gap:20px!important}
  .service-grid > .service-card,.services-wide .service-card{aspect-ratio:4/3!important}
}


/* ===== v45 FINAL REPAIR: stable service cards + scroll header stripe ===== */
.site-header{position:sticky!important;overflow:visible!important}
.site-header::after{
  content:""!important;
  position:absolute!important;
  left:0!important;
  right:0!important;
  bottom:-1px!important;
  height:4px!important;
  z-index:5!important;
  background:linear-gradient(90deg,
    rgba(21,152,255,0) 0%,
    rgba(21,152,255,.25) 12%,
    #1598ff 30%,
    #7ca8ff 46%,
    #ef3030 68%,
    rgba(239,48,48,.25) 86%,
    rgba(239,48,48,0) 100%)!important;
  background-size:220% 100%!important;
  background-position-x:calc(50% + var(--clay-scroll-shift,0px))!important;
  transform:translateY(var(--clay-scroll-drop,0px))!important;
  box-shadow:0 0 22px rgba(21,152,255,.35),0 0 24px rgba(239,48,48,.28)!important;
  transition:height .2s ease,transform .2s ease,background-position .12s linear!important;
  pointer-events:none!important;
}
body.header-scrolled .site-header::after{height:6px!important;}

/* reliable desktop card grid: no overlap */
@media(min-width:981px){
  .service-grid,
  .services-wide .service-grid{
    display:flex!important;
    flex-wrap:wrap!important;
    gap:30px!important;
    align-items:stretch!important;
    justify-content:flex-start!important;
    overflow:visible!important;
  }
  .service-grid > .service-card,
  .services-wide .service-grid > .service-card,
  .services-wide .service-card{
    flex:0 0 calc((100% - 30px)/2)!important;
    width:calc((100% - 30px)/2)!important;
    max-width:calc((100% - 30px)/2)!important;
    min-width:0!important;
    height:430px!important;
    min-height:430px!important;
    aspect-ratio:auto!important;
    position:relative!important;
    display:block!important;
    overflow:hidden!important;
    contain:layout paint!important;
    isolation:isolate!important;
    border-radius:30px!important;
    background:#0b1119!important;
    box-shadow:var(--shadow)!important;
    color:#fff!important;
  }
  .service-grid > .service-card:last-child:nth-child(odd),
  .services-wide .service-grid > .service-card:last-child:nth-child(odd){
    flex-basis:100%!important;
    width:100%!important;
    max-width:100%!important;
    height:430px!important;
    min-height:430px!important;
  }
  .service-grid > .service-card img,
  .services-wide .service-card img{
    position:absolute!important;
    inset:0!important;
    width:100%!important;
    height:100%!important;
    max-width:none!important;
    display:block!important;
    object-fit:cover!important;
    object-position:center center!important;
    filter:brightness(.84) contrast(1.05) saturate(.96)!important;
    transform:none!important;
    z-index:0!important;
  }
  .service-grid > .service-card::before,
  .services-wide .service-card::before{
    content:""!important;
    position:absolute!important;
    inset:0!important;
    z-index:1!important;
    display:block!important;
    background:linear-gradient(180deg,rgba(5,8,13,.08) 0%,rgba(5,8,13,.28) 38%,rgba(5,8,13,.94) 100%)!important;
    pointer-events:none!important;
  }
  .service-grid > .service-card .content,
  .services-wide .service-card .content{
    position:absolute!important;
    left:0!important;
    right:0!important;
    bottom:0!important;
    z-index:2!important;
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    padding:26px!important;
    background:transparent!important;
    box-sizing:border-box!important;
    overflow:hidden!important;
  }
  .service-grid > .service-card .tag,
  .services-wide .service-card .tag{
    display:inline-flex!important;
    align-items:center!important;
    width:auto!important;
    max-width:92%!important;
    padding:8px 13px!important;
    border-radius:999px!important;
    background:rgba(255,255,255,.16)!important;
    border:1px solid rgba(255,255,255,.24)!important;
    color:#fff!important;
    font-size:12px!important;
    line-height:1!important;
    white-space:nowrap!important;
  }
  .service-grid > .service-card h3,
  .services-wide .service-card h3{
    color:#fff!important;
    font-size:clamp(30px,3vw,42px)!important;
    line-height:1.03!important;
    margin:14px 0 8px!important;
    max-width:95%!important;
    white-space:normal!important;
    overflow-wrap:normal!important;
    word-break:normal!important;
    text-shadow:0 2px 16px rgba(0,0,0,.45)!important;
  }
  .service-grid > .service-card p,
  .services-wide .service-card p{
    color:#eef5ff!important;
    font-size:16.5px!important;
    line-height:1.45!important;
    margin:0!important;
    max-width:95%!important;
    overflow:hidden!important;
    display:-webkit-box!important;
    -webkit-line-clamp:2!important;
    -webkit-box-orient:vertical!important;
    text-shadow:0 2px 12px rgba(0,0,0,.45)!important;
  }
  .service-grid > .service-card .cta-row,
  .services-wide .service-card .cta-row{
    margin-top:16px!important;
    justify-content:flex-start!important;
  }
  .service-grid > .service-card .ghost,
  .services-wide .service-card .ghost{
    display:inline-flex!important;
    width:auto!important;
    max-width:max-content!important;
    color:#fff!important;
    background:rgba(255,255,255,.09)!important;
    border:1px solid rgba(255,255,255,.24)!important;
  }
}

/* card crop tuning */
.card-unterhalt img{object-position:50% 47%!important}
.card-glas img{object-position:50% 50%!important}
.card-fassade img{object-position:50% 48%!important}
.card-stein img{object-position:50% 22%!important}
.card-tiefgarage img{object-position:50% 54%!important}
.card-hausmeister img{object-position:56% 42%!important}
.card-pv img{object-position:50% 29%!important}
.card-pu img{object-position:50% 22%!important}
.card-bau img{object-position:50% 42%!important}
.card-dachrinne img{object-position:50% 50%!important}

/* reference gallery: no duplicate hero-card and consistent images */
.gallery-card img{object-fit:cover!important;object-position:center center!important;}
.page-referenzen .gallery-card:nth-child(3) img{object-position:50% 22%!important}
.page-referenzen .gallery-card:nth-child(6) img{object-position:50% 29%!important}
.page-referenzen .gallery-card:nth-child(7) img{object-position:50% 22%!important}
.page-referenzen .gallery-card:nth-child(8) img{object-position:50% 42%!important}
.page-referenzen .gallery-card:nth-child(9) img{object-position:56% 42%!important}

/* hide social shortcuts inside the contact content, social remains only in footer */
.page-kontakt .contact-box .social-links{display:none!important}

@media(max-width:980px){
  .service-grid,.services-wide .service-grid{display:grid!important;grid-template-columns:1fr!important;gap:20px!important}
  .service-grid > .service-card,.services-wide .service-card{height:auto!important;min-height:0!important;aspect-ratio:4/3!important;width:100%!important;max-width:100%!important;flex:none!important}
  .service-grid > .service-card .content,.services-wide .service-card .content{padding:22px!important}
  .service-grid > .service-card p,.services-wide .service-card p{-webkit-line-clamp:3!important}
}


/* ===== v46: mobile card consistency, cookie cleanup, career CTA, dynamic header strip ===== */
/* Cookie technical note is removed from HTML; keep hidden if cached */
.cookie-note{display:none!important}
.mobile-socials{display:none!important}
.page-kontakt .contact-box .social-links{display:none!important}

/* Stronger, actually scroll-reactive header color strip */
.site-header::after{
  content:""!important;
  position:absolute!important;
  left:0!important;right:0!important;bottom:-1px!important;
  height:4px!important;
  z-index:5!important;
  background:linear-gradient(90deg,#1598ff 0%,#5cc6ff 18%,#7d65ff 38%,#ff4e7a 60%,#ef3030 78%,#1598ff 100%)!important;
  background-size:260% 100%!important;
  background-position:var(--clay-scroll-bg,0%) 0!important;
  filter:hue-rotate(var(--clay-strip-hue,0deg)) saturate(1.45)!important;
  box-shadow:0 0 22px rgba(21,152,255,.40),0 0 26px rgba(239,48,48,.30)!important;
  transform:translateY(var(--clay-scroll-drop,0px))!important;
  transition:height .18s ease,transform .18s ease,filter .12s linear,background-position .12s linear!important;
  pointer-events:none!important;
}
body.header-scrolled .site-header::after{height:7px!important;}

/* Mobile: every service card looks the same: image + text below, no confusing category bars */
@media(max-width:980px){
  .service-grid,.services-wide .service-grid{display:grid!important;grid-template-columns:1fr!important;gap:22px!important;align-items:stretch!important}
  .service-grid > .service-card,
  .services-wide .service-card{
    display:flex!important;
    flex-direction:column!important;
    width:100%!important;
    max-width:100%!important;
    height:auto!important;
    min-height:0!important;
    aspect-ratio:auto!important;
    overflow:hidden!important;
    border-radius:28px!important;
    background:#0b1119!important;
    box-shadow:var(--shadow)!important;
    color:#fff!important;
  }
  .service-grid > .service-card::before,.services-wide .service-card::before{display:none!important;content:none!important}
  .service-grid > .service-card img,
  .services-wide .service-card img{
    position:relative!important;
    inset:auto!important;
    width:100%!important;
    height:auto!important;
    max-width:100%!important;
    aspect-ratio:16/10!important;
    object-fit:cover!important;
    display:block!important;
    filter:brightness(.96) contrast(1.04) saturate(.98)!important;
    transform:none!important;
    z-index:0!important;
  }
  .service-grid > .service-card .content,
  .services-wide .service-card .content{
    position:relative!important;
    left:auto!important;right:auto!important;bottom:auto!important;
    width:100%!important;
    min-height:0!important;
    padding:24px!important;
    background:linear-gradient(180deg,#0b1119,#101926)!important;
    z-index:1!important;
    display:block!important;
    overflow:visible!important;
  }
  .service-grid > .service-card .tag,
  .services-wide .service-card .tag{display:none!important}
  .service-grid > .service-card h3,
  .services-wide .service-card h3{
    font-size:clamp(30px,8vw,42px)!important;
    line-height:1.05!important;
    margin:0 0 10px!important;
    color:#fff!important;
  }
  .service-grid > .service-card p,
  .services-wide .service-card p{
    display:block!important;
    -webkit-line-clamp:unset!important;
    -webkit-box-orient:unset!important;
    overflow:visible!important;
    max-height:none!important;
    color:#e9f1fb!important;
    font-size:18px!important;
    line-height:1.5!important;
    margin:0!important;
  }
  .service-grid > .service-card .cta-row,.services-wide .service-card .cta-row{margin-top:18px!important;justify-content:flex-start!important}
}

@media(max-width:640px){
  .service-grid > .service-card img,.services-wide .service-card img{aspect-ratio:4/3!important}
  .service-grid > .service-card .content,.services-wide .service-card .content{padding:22px!important}
}

/* Karriere: on mobile the application button belongs under the team photo */
.career-mobile-cta{display:none!important}
@media(max-width:980px){
  .page-karriere .career-original-cta{display:none!important}
  .page-karriere .career-mobile-cta{display:flex!important;margin-top:18px!important}
  .page-karriere .career-mobile-cta .btn{width:100%!important}
}

/* Minor text/crop tuning */
.card-tiefgarage img{object-position:50% 54%!important}
.card-pu img{object-position:50% 22%!important}
.card-pv img{object-position:50% 28%!important}
.card-stein img{object-position:50% 22%!important}


/* ===== v48: Header-Farbstreifen darf Mega-Menü nicht überlagern ===== */
.site-header{isolation:isolate!important;}
.site-header::after{z-index:1!important;}
.site-header .wrap,.site-header .bar,.site-header .header-hotline{position:relative!important;z-index:2!important;}
.site-header .drop{position:relative!important;z-index:80!important;}
.site-header .mega-menu{z-index:999!important;background:#0b1119!important;}
.site-header .mega-layout,.site-header .mega-list,.site-header .mega-preview{position:relative!important;z-index:1000!important;}
/* Wenn das Leistungsmenü offen ist, bleibt der Streifen hinter dem Menü und stört nicht im Dropdown. */
.site-header:has(.drop:hover)::after{opacity:.55!important;}

/* v50 Bodensanierung Optionen */
.boden-design-section .info-band{margin-top:24px;padding:22px 24px;border-radius:22px;background:linear-gradient(135deg,#0d1927,#14263a);color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow)}
.boden-design-section .info-band strong{color:#fff}

/* ===== v51: Desktop Header / Leistungen-Hover finalisieren ===== */
@media (min-width:981px){
  .site-header{
    overflow:visible!important;
    isolation:isolate!important;
  }
  .site-header .wrap{position:relative!important;z-index:3!important;}
  .site-header .bar{
    position:relative!important;
    z-index:60!important;
  }
  .site-header .header-hotline{
    position:relative!important;
    z-index:20!important;
  }
  .site-header .nav{
    position:relative!important;
    z-index:70!important;
  }
  .site-header .drop{
    position:relative!important;
    z-index:80!important;
  }
  .site-header .drop::after{
    content:"";
    position:absolute;
    left:-28px;
    right:-28px;
    top:100%;
    height:34px;
    pointer-events:auto;
  }
  .site-header .mega-menu{
    z-index:9999!important;
    top:calc(100% + 18px)!important;
    right:-300px!important;
    width:min(960px,calc(100vw - 56px))!important;
    background:linear-gradient(180deg,rgba(11,17,25,.985),rgba(7,12,19,.985))!important;
    border:1px solid rgba(255,255,255,.14)!important;
    box-shadow:0 34px 90px rgba(0,0,0,.46)!important;
    backdrop-filter:blur(20px)!important;
    transform:translateY(10px) scale(.985)!important;
  }
  .site-header .drop:hover .mega-menu{
    opacity:1!important;
    visibility:visible!important;
    transform:translateY(0) scale(1)!important;
  }
  .site-header .mega-layout,.site-header .mega-list,.site-header .mega-preview{
    position:relative!important;
    z-index:10000!important;
  }
  .site-header .mega-item{
    background:rgba(255,255,255,.045)!important;
    border-color:rgba(255,255,255,.08)!important;
    transition:background .18s ease,border-color .18s ease,transform .18s ease!important;
  }
  .site-header .mega-item:hover,.site-header .mega-item.active{
    background:linear-gradient(90deg,rgba(21,152,255,.15),rgba(239,48,48,.055))!important;
    border-color:rgba(21,152,255,.36)!important;
    transform:translateX(3px)!important;
  }
  .site-header .mega-preview{
    border:1px solid rgba(255,255,255,.10)!important;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.035)!important;
  }
  .site-header::after{
    z-index:1!important;
    pointer-events:none!important;
  }
  .site-header:has(.drop:hover)::after{
    opacity:0!important;
  }
}


/* v53 Einsatzgebiet / lokale SEO-Seiten */
.area-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:30px}.area-card{display:block;padding:18px 18px;border-radius:18px;background:#fff;border:1px solid var(--lineDark);box-shadow:0 10px 24px rgba(16,23,34,.06)}.area-card strong{display:block;font-size:19px;color:#101722}.area-card span{display:block;margin-top:6px;color:#5b6a7d;font-size:15px}.area-card:hover{transform:translateY(-2px);border-color:rgba(21,152,255,.35)}.local-service-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:30px}.local-service{display:block;padding:22px;border-radius:20px;background:#fff;border:1px solid var(--lineDark);box-shadow:0 10px 24px rgba(16,23,34,.06)}.local-service strong{display:block;color:#101722;font-size:21px}.local-service span{display:block;color:#5b6a7d;margin-top:8px}.local-note{margin-top:28px;padding:24px;border-radius:24px;background:linear-gradient(135deg,#0d1927,#14263a);color:#fff}.local-note p{color:#d7e2f0;margin:8px 0 0}.area-pill-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.area-pill-list a,.area-pill-list span{display:inline-flex;padding:9px 12px;border-radius:999px;background:#eef6ff;color:#1469ba;font-weight:850}@media(max-width:980px){.area-grid{grid-template-columns:1fr 1fr}.local-service-grid{grid-template-columns:1fr}}@media(max-width:640px){.area-grid{grid-template-columns:1fr}.area-card{padding:16px}.local-service{padding:18px}}


/* ===== v54: finaler Header-Farbstreifen auf allen Seiten =====
   Realer Strip statt konfliktanfälliger Pseudo-Elemente.
   Immer Blau -> Hellrot/Rot, scrollabhängig und hinter dem Dropdown. */
.site-header{
  position:sticky!important;
  overflow:visible!important;
  isolation:isolate!important;
}
.site-header::after,
.site-header::before{
  display:none!important;
  content:none!important;
}
.clay-final-scroll-strip{
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:4px;
  z-index:4;
  pointer-events:none;
  background:
    linear-gradient(
      90deg,
      #1598ff 0%,
      #48b7ff 18%,
      #9f7cff 38%,
      #ff6b7a 62%,
      #ef3030 78%,
      #1598ff 100%
    );
  background-size:280% 100%;
  background-position:var(--clay-final-strip-pos, 0%) 50%;
  box-shadow:
    0 0 16px rgba(21,152,255,.45),
    0 0 18px rgba(239,48,48,.28);
  transform:translateY(var(--clay-final-strip-drop, 0px));
  opacity:1;
  transition:height .18s ease, transform .18s ease, box-shadow .18s ease;
  animation:clayFinalStripIdle 7s ease-in-out infinite alternate;
}
body.header-scrolled .clay-final-scroll-strip{
  height:5px;
  box-shadow:
    0 0 18px rgba(21,152,255,.55),
    0 0 24px rgba(239,48,48,.38);
}
@keyframes clayFinalStripIdle{
  from{background-position:0% 50%;}
  to{background-position:100% 50%;}
}
/* Dropdown bleibt sauber vor dem Streifen */
.site-header .mega-menu,
.site-header .drop,
.site-header .nav{
  z-index:9999!important;
}
@media(max-width:980px){
  .clay-final-scroll-strip{
    height:4px;
    bottom:-1px;
  }
}


/* ===== v55: Header-Streifen final sichtbar, aber NIE über dem Leistungen-Dropdown ===== */

/* Der Streifen bekommt kräftigere Farben und bewegt sich deutlich sichtbar. */
.clay-final-scroll-strip{
  z-index:2!important;
  height:5px!important;
  opacity:1!important;
  pointer-events:none!important;
  background:
    linear-gradient(
      90deg,
      #129cff 0%,
      #38c6ff 18%,
      #8b8cff 34%,
      #ff7a8a 52%,
      #ff3c3c 68%,
      #129cff 100%
    )!important;
  background-size:420% 100%!important;
  background-position:var(--clay-final-strip-pos, 0%) 50%!important;
  box-shadow:
    0 0 18px rgba(18,156,255,.65),
    0 0 24px rgba(255,60,60,.42)!important;
  animation:clayStripColorRunV55 3.2s linear infinite!important;
  transition:opacity .14s ease, transform .16s ease, height .16s ease, box-shadow .16s ease!important;
}

body.header-scrolled .clay-final-scroll-strip{
  height:6px!important;
  box-shadow:
    0 0 22px rgba(18,156,255,.78),
    0 0 30px rgba(255,60,60,.55)!important;
}

@keyframes clayStripColorRunV55{
  0%{background-position:0% 50%;}
  100%{background-position:420% 50%;}
}

/* Wichtig: Wenn das Dropdown offen ist, wird der Streifen komplett ausgeblendet. */
body.mega-open .clay-final-scroll-strip,
.site-header:has(.drop:hover) .clay-final-scroll-strip,
.site-header:has(.mega-menu:hover) .clay-final-scroll-strip{
  opacity:0!important;
}

/* Dropdown immer oberste Ebene, damit keine Header-Effekte durchscheinen. */
.site-header .drop,
.site-header .mega-menu,
.site-header .mega-layout,
.site-header .mega-list,
.site-header .mega-preview{
  z-index:99999!important;
}

.site-header .mega-menu{
  background:linear-gradient(180deg,rgba(8,13,20,.995),rgba(6,10,16,.995))!important;
  backdrop-filter:blur(22px)!important;
  -webkit-backdrop-filter:blur(22px)!important;
}

/* In reduzierter Bewegung trotzdem kräftiger Verlauf, nur ohne Daueranimation. */
@media (prefers-reduced-motion: reduce){
  .clay-final-scroll-strip{
    animation:none!important;
  }
}


/* ===== v56: Header-Streifen bleibt auch nach Hover / Seitenwechsel farbig aktiv =====
   Keine reine CSS-Animation mehr, sondern eine dauerhaft per JS aktualisierte Position.
   Dadurch bleibt der Verlauf nach einem Hover über Leistungen nicht blau stehen. */
.clay-final-scroll-strip{
  z-index:2!important;
  opacity:1!important;
  height:5px!important;
  pointer-events:none!important;
  background:
    linear-gradient(
      90deg,
      #129cff 0%,
      #3ec8ff 18%,
      #8e86ff 36%,
      #ff7b88 55%,
      #ef3030 74%,
      #129cff 100%
    )!important;
  background-size:420% 100%!important;
  background-position:var(--clay-v56-strip-pos, 0%) 50%!important;
  animation:none!important;
  box-shadow:
    0 0 18px rgba(18,156,255,.68),
    0 0 24px rgba(239,48,48,.46)!important;
  transition:opacity .14s ease, transform .16s ease, height .16s ease, box-shadow .16s ease!important;
}

body.header-scrolled .clay-final-scroll-strip{
  height:6px!important;
  box-shadow:
    0 0 22px rgba(18,156,255,.82),
    0 0 32px rgba(239,48,48,.58)!important;
}

/* Beim offenen Leistungen-Menü komplett ausblenden, aber nach dem Schließen sofort wieder aktiv. */
body.mega-open .clay-final-scroll-strip,
.site-header:has(.drop:hover) .clay-final-scroll-strip,
.site-header:has(.mega-menu:hover) .clay-final-scroll-strip{
  opacity:0!important;
}

/* Fallback: falls CSS :has nicht unterstützt wird, regelt JS body.mega-open. */


/* ===== v57 FINAL: Header-Streifen stabil auf ALLEN Seiten =====
   Problem vorher: Einige Seiten blieben nach Hover/Navigation blau, weil JS/CSS-Variablen kollidierten.
   Lösung: Der sichtbare Verlauf läuft jetzt auf einem ::before-Element rein per CSS-Animation.
   Kein JavaScript nötig, kein Einfrieren nach Hover, kein blauer Standstreifen. */

.clay-final-scroll-strip{
  position:absolute!important;
  left:0!important;
  right:0!important;
  bottom:-1px!important;
  height:5px!important;
  z-index:2!important;
  pointer-events:none!important;
  overflow:hidden!important;
  opacity:1!important;
  background:transparent!important;
  transform:translateY(var(--clay-final-strip-drop,0px))!important;
  box-shadow:
    0 0 18px rgba(21,152,255,.48),
    0 0 24px rgba(239,48,48,.34)!important;
}

.clay-final-scroll-strip::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  width:260%!important;
  background:
    linear-gradient(
      90deg,
      #1598ff 0%,
      #42caff 12%,
      #7f8cff 25%,
      #b06dff 38%,
      #ff8a9a 52%,
      #ff4545 66%,
      #ef3030 78%,
      #1598ff 100%
    )!important;
  background-size:100% 100%!important;
  animation:clayFinalStripRunV57 4.2s linear infinite!important;
  will-change:transform!important;
}

@keyframes clayFinalStripRunV57{
  0%{transform:translateX(-54%);}
  100%{transform:translateX(0%);}
}

body.header-scrolled .clay-final-scroll-strip{
  height:6px!important;
  transform:translateY(var(--clay-final-strip-drop,3px))!important;
  box-shadow:
    0 0 22px rgba(21,152,255,.62),
    0 0 30px rgba(239,48,48,.48)!important;
}

/* Wichtig: Keine alte mega-open-Klasse darf den Streifen dauerhaft blockieren. */
body.mega-open .clay-final-scroll-strip{
  opacity:1!important;
}

/* Nur solange das Leistungen-Menü wirklich gehovert wird, verschwindet der Streifen. */
.site-header:has(.drop:hover) .clay-final-scroll-strip,
.site-header:has(.mega-menu:hover) .clay-final-scroll-strip{
  opacity:0!important;
}

/* Alte Pseudo-Streifen endgültig aus. */
.site-header::before,
.site-header::after{
  display:none!important;
  content:none!important;
}

/* Dropdown bleibt optisch sauber über allem. */
.site-header .mega-menu,
.site-header .drop,
.site-header .mega-layout,
.site-header .mega-list,
.site-header .mega-preview{
  z-index:99999!important;
}

@media (prefers-reduced-motion: reduce){
  .clay-final-scroll-strip::before{
    animation:clayFinalStripRunV57 8s linear infinite!important;
  }
}

/* Conversion: Auf Mobil das Anfrageformular VOR den Direktkontakt-Block ziehen,
   damit Besucher nicht erst an doppelten Telefon/WhatsApp-Hinweisen vorbeiscrollen. */
@media(max-width:980px){
  .page-kontakt .contact-card .contact-form-card{order:-1}
  .page-kontakt .contact-card .contact-box{order:0}
}
