/* ============================================================
   LM CLEANING – style.css  (geteiltes Stylesheet)
   Wird in jeder HTML-Seite eingebunden: <link rel="stylesheet" href="style.css">

   Schriften: starten mit System-Fallback (kein externer Aufruf, DSGVO-neutral).
   Lokale Manrope/Inter später optional über die @font-face-Vorlage unten aktivieren.
   ============================================================ */

/* --- Optional später: lokale Schriften (Dateien in /fonts/ ablegen, dann einkommentieren)
@font-face{font-family:'Manrope';src:url('fonts/manrope-700.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Manrope';src:url('fonts/manrope-800.woff2') format('woff2');font-weight:800;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-400.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Inter';src:url('fonts/inter-600.woff2') format('woff2');font-weight:600;font-display:swap}
--- */

:root{
  --sky:#66C6FF; --ice:#A7D8FF; --white:#FFFFFF; --bg-soft:#F8FAFC;
  --text:#0F172A; --navy:#0B3558; --navy-2:#0e4067; --navy-deep:#081f37;
  --border:#E2E8F0; --muted:#5b6b7e; --maxw:1280px;
  --shadow:0 24px 60px -24px rgba(11,53,88,.28);
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter','Helvetica Neue',Arial,system-ui,sans-serif;color:var(--text);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Manrope','Helvetica Neue',Arial,sans-serif;color:var(--navy);font-weight:700;line-height:1.08;letter-spacing:-.022em}
h1{font-size:clamp(2.3rem,5.2vw,4.4rem);font-weight:800}
h2{font-size:clamp(1.9rem,3.6vw,3rem);font-weight:800}
h3{font-size:1.22rem;font-weight:700;letter-spacing:-.01em}
p{color:var(--muted)}
a{text-decoration:none;color:inherit}
img,svg{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
section{padding:110px 0}

.label{display:inline-flex;align-items:center;gap:12px;font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--navy);margin-bottom:26px}
.label .num{color:var(--sky);font-family:'Manrope';font-weight:800}
.label::before{content:"";width:34px;height:1.5px;background:var(--sky)}
.lead{font-size:1.15rem;max-width:640px;color:var(--muted)}

.btn{display:inline-flex;align-items:center;gap:11px;font-family:'Manrope';font-weight:700;font-size:.95rem;padding:16px 30px;border-radius:8px;border:1.5px solid transparent;cursor:pointer;transition:.4s var(--ease);white-space:nowrap}
.btn svg{transition:transform .4s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn-primary{background:var(--sky);color:var(--navy)}
.btn-primary:hover{background:#4fb8f7;box-shadow:0 16px 36px -12px rgba(102,198,255,.75)}
.btn-line{background:transparent;color:var(--navy);border-color:var(--border)}
.btn-line:hover{border-color:var(--navy)}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.08)}

.rv{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv.in{opacity:1;transform:none}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:.4s var(--ease)}
header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(14px);box-shadow:0 1px 0 var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:90px;transition:.4s var(--ease)}
header.scrolled .nav{height:72px}
.logo{display:flex;flex-direction:column;align-items:center;line-height:1;cursor:pointer}
.logo svg{width:44px;height:auto}
.logo .word{font-family:'Manrope';font-weight:700;font-size:.58rem;letter-spacing:.4em;margin-top:3px;padding-left:.4em;transition:color .4s;color:var(--navy)}
header.athero:not(.scrolled) .logo .word{color:#fff}
header.athero:not(.scrolled) nav a{color:rgba(255,255,255,.9)}
header.athero:not(.scrolled) .burger span{background:#fff}
nav ul{display:flex;gap:38px;list-style:none;align-items:center}
nav a{font-weight:500;font-size:.95rem;color:var(--text);position:relative;padding:4px 0;cursor:pointer;transition:color .3s}
nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--sky);transition:width .35s var(--ease)}
nav a:hover::after,nav a.active::after{width:100%}
.nav-right{display:flex;align-items:center;gap:26px}
.burger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2px;background:var(--navy);margin:6px 0;transition:.3s}

/* HERO */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--navy-deep)}
.hero-art{position:absolute;inset:0;z-index:0}
.hero-art svg{width:100%;height:100%}
.hero .wrap{position:relative;z-index:1}
.hero-inner{max-width:860px;padding:120px 0 80px}
.hero h1{color:#fff;margin-bottom:26px}
.hero h1 em{font-style:normal;color:var(--sky)}
.hero p{color:rgba(255,255,255,.84);font-size:1.2rem;max-width:560px;margin-bottom:38px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-label{color:#fff}
.hero-label::before{background:var(--sky)}

/* SEITEN-HERO */
.phero{position:relative;background:var(--navy-deep);color:#fff;overflow:hidden;padding:170px 0 90px}
.phero-art{position:absolute;inset:0;z-index:0;opacity:.9}
.phero-art svg{width:100%;height:100%}
.phero .wrap{position:relative;z-index:1}
.phero h1{color:#fff;font-size:clamp(2rem,4.4vw,3.4rem);max-width:760px}
.phero p{color:rgba(255,255,255,.78);max-width:560px;margin-top:20px;font-size:1.12rem}
.phero .label{color:#fff}
.phero .label::before{background:var(--sky)}

/* TRUST-PILLARS */
.pillars{border-bottom:1px solid var(--border)}
.pillars .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.pillar{padding:44px 32px;border-left:1px solid var(--border)}
.pillar:first-child{border-left:none;padding-left:0}
.pillar .ic{color:var(--sky);margin-bottom:16px}
.pillar strong{display:block;font-family:'Manrope';font-weight:700;color:var(--navy);font-size:1.02rem;margin-bottom:4px}
.pillar span{font-size:.9rem;color:var(--muted)}

.sec-head{max-width:720px;margin-bottom:60px}
.sec-head.center{margin:0 auto 60px;text-align:center}
.sec-head.center .label{justify-content:center}

/* LEISTUNGEN */
.svc-top{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:60px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);border-left:1px solid var(--border)}
.card{position:relative;padding:42px 38px 46px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:#fff;transition:.45s var(--ease);overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--sky);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.card:hover{background:var(--bg-soft)}
.card:hover::before{transform:scaleX(1)}
.card .knum{font-family:'Manrope';font-weight:800;font-size:.85rem;color:var(--ice);margin-bottom:22px}
.card .ic{color:var(--navy);margin-bottom:20px;transition:.45s var(--ease)}
.card:hover .ic{color:var(--sky)}
.card h3{margin-bottom:11px}
.card p{font-size:.95rem;line-height:1.65}

/* WARUM */
.why{background:var(--bg-soft)}
.why-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:80px;align-items:center}
.why-visual{position:relative;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);background:var(--navy)}
.why-visual svg{width:100%;display:block}
.why-quote{position:absolute;left:0;bottom:0;right:0;padding:30px;background:linear-gradient(0deg,rgba(8,32,55,.96),transparent)}
.why-quote strong{font-family:'Manrope';font-size:1.05rem;color:#fff;display:block}
.why-quote span{font-size:.85rem;color:rgba(255,255,255,.72)}
.why-list{list-style:none}
.why-list li{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid var(--border)}
.why-list li:first-child{padding-top:0}
.why-list .check{width:30px;height:30px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;flex:none;font-size:.85rem}
.why-list strong{font-family:'Manrope';font-size:1.05rem;color:var(--navy);display:block;margin-bottom:3px}
.why-list small{color:var(--muted);font-size:.92rem;line-height:1.6}

/* ZIELGRUPPEN */
.pills{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);border-left:1px solid var(--border)}
.pill{display:flex;gap:18px;align-items:center;padding:32px 34px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);font-family:'Manrope';font-weight:600;color:var(--navy);font-size:1.02rem;transition:.4s var(--ease)}
.pill:hover{background:var(--bg-soft)}
.pill .ic{color:var(--sky);flex:none}

/* ABLAUF */
.process{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.process .glow{position:absolute;top:-30%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(102,198,255,.18),transparent 65%);z-index:0}
.process .wrap{position:relative;z-index:1}
.process h2,.process .label{color:#fff}
.process .label .num{color:var(--sky)}
.process .label::before{background:var(--sky)}
.process .lead{color:rgba(255,255,255,.72)}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:32px;margin-top:60px}
.step{padding-top:28px;border-top:1px solid rgba(255,255,255,.2)}
.step .num{font-family:'Manrope';font-weight:800;font-size:2.6rem;color:var(--sky);line-height:1;margin-bottom:16px;letter-spacing:-.04em}
.step h3{color:#fff;font-size:1.06rem;margin-bottom:9px}
.step p{font-size:.89rem;color:rgba(255,255,255,.68);line-height:1.6}

/* EINSATZGEBIET */
.cov-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:80px;align-items:center}
.cov-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.cov-tags span{border:1px solid var(--border);border-radius:6px;padding:9px 18px;font-size:.86rem;color:var(--navy);font-family:'Manrope';font-weight:500}
.cov-map{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);background:var(--navy-deep)}
.cov-map svg{width:100%;display:block}

/* FAQ */
.faq{background:var(--bg-soft)}
.faq-list{max-width:880px;margin:0 auto;border-top:1px solid var(--border)}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:28px 8px;font-family:'Manrope';font-weight:700;font-size:1.16rem;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:24px}
.faq-q .sign{flex:none;width:30px;height:30px;display:grid;place-items:center;color:var(--sky);font-weight:700;font-size:1.3rem;transition:transform .35s var(--ease)}
.faq-item.open .sign{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{padding:0 8px 28px;font-size:1.01rem;max-width:720px}

/* CTA */
.cta-final{position:relative;color:#fff;overflow:hidden;text-align:center;background:linear-gradient(135deg,var(--navy-deep),var(--navy-2))}
.cta-final .glow{position:absolute;bottom:-40%;left:50%;transform:translateX(-50%);width:800px;height:600px;background:radial-gradient(circle,rgba(102,198,255,.22),transparent 60%);z-index:0}
.cta-final .wrap{position:relative;z-index:1}
.cta-final h2{color:#fff;max-width:800px;margin:0 auto 20px}
.cta-final p{color:rgba(255,255,255,.82);max-width:560px;margin:0 auto 36px;font-size:1.12rem}

/* DETAIL (Leistungen) */
.detail{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:70px 0;border-bottom:1px solid var(--border)}
.detail:nth-child(even) .detail-art{order:-1}
.detail-art{border-radius:14px;overflow:hidden;background:var(--bg-soft);border:1px solid var(--border)}
.detail-art svg{width:100%;display:block}
.detail h3{font-size:1.7rem;margin-bottom:8px}
.detail .label{margin-bottom:16px}
.detail ul{list-style:none;margin-top:18px;display:grid;gap:10px}
.detail ul li{display:flex;gap:12px;align-items:flex-start;font-size:.96rem;color:var(--text)}
.detail ul .d{width:20px;height:20px;border-radius:50%;background:var(--ice);color:var(--navy);display:grid;place-items:center;font-size:.7rem;flex:none;margin-top:3px}

/* VISION / WERTE (Über uns) */
.vision{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.vision .glow{position:absolute;top:-20%;left:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(102,198,255,.16),transparent 65%)}
.vision .wrap{position:relative;z-index:1;text-align:center;max-width:820px}
.vision h2{color:#fff;margin-bottom:22px}
.vision p{color:rgba(255,255,255,.82);font-size:1.18rem}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px}
.value{padding:34px 30px;border:1px solid var(--border);border-radius:14px;transition:.4s var(--ease)}
.value:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.value .ic{color:var(--sky);margin-bottom:18px}
.value h3{margin-bottom:8px}
.value p{font-size:.95rem}

/* KONTAKT */
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:start}
.form{display:grid;gap:18px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:grid;gap:7px}
.field label{font-family:'Manrope';font-weight:600;font-size:.85rem;color:var(--navy)}
.field input,.field select,.field textarea{font-family:'Inter';font-size:.96rem;padding:13px 15px;border:1.5px solid var(--border);border-radius:8px;background:#fff;color:var(--text);transition:.25s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 4px rgba(102,198,255,.16)}
.field textarea{min-height:120px;resize:vertical}
.check-row{display:flex;gap:11px;align-items:flex-start;font-size:.85rem;color:var(--muted)}
.check-row input{margin-top:4px;width:16px;height:16px;flex:none}
.hp{position:absolute;left:-9999px;top:-9999px;height:0;width:0;overflow:hidden}
.form-status{border-radius:8px;padding:16px 18px;font-family:'Manrope';font-weight:600;margin-bottom:8px}
.form-status.ok{background:rgba(102,198,255,.12);border:1px solid var(--sky);color:var(--navy)}
.form-status.error{background:#fef2f2;border:1px solid #f3c0c0;color:#9b2c2c}
.contact-card{background:var(--navy-deep);color:#fff;border-radius:16px;padding:40px 36px}
.contact-card h3{color:#fff;margin-bottom:24px}
.contact-card .row{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-top:1px solid rgba(255,255,255,.12)}
.contact-card .row:first-of-type{border-top:none}
.contact-card .ic{color:var(--sky);flex:none;margin-top:2px}
.contact-card strong{display:block;font-family:'Manrope';font-size:.95rem;color:#fff}
.contact-card span{font-size:.9rem;color:rgba(255,255,255,.72)}

/* RECHTLICHES */
.legal{max-width:820px}
.legal h2{font-size:1.5rem;margin:38px 0 14px}
.legal p{margin-bottom:14px}
.legal .note{background:var(--bg-soft);border:1px solid var(--border);border-radius:10px;padding:18px 20px;font-size:.92rem;color:var(--muted)}

/* FOOTER */
footer{background:var(--navy-deep);color:#aebfd0;padding:88px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:48px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.1)}
footer .logo{align-items:flex-start}
footer .logo .word{color:#fff}
footer h4{color:#fff;font-family:'Manrope';font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px}
footer ul{list-style:none;display:grid;gap:12px}
footer a{color:#aebfd0;font-size:.94rem;cursor:pointer;transition:color .3s}
footer a:hover{color:var(--sky)}
.foot-about{font-size:.95rem;color:#7e93a8;margin-top:20px;max-width:320px;line-height:1.7}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:.86rem;color:#7e93a8;flex-wrap:wrap;gap:14px}
.foot-bottom a{color:#7e93a8}

/* COOKIE-BANNER */
.cookie-bar{position:fixed;left:20px;right:20px;bottom:20px;max-width:540px;z-index:200;background:var(--navy-deep);color:#fff;border-radius:16px;padding:26px 28px;box-shadow:var(--shadow);display:none}
.cookie-bar.show{display:block}
.cookie-bar h4{color:#fff;font-family:'Manrope';font-size:1.05rem;margin-bottom:10px}
.cookie-bar p{color:rgba(255,255,255,.78);font-size:.9rem;margin-bottom:18px;line-height:1.6}
.cookie-bar a{color:var(--sky);text-decoration:underline}
.cookie-actions{display:flex;gap:12px;flex-wrap:wrap}
.cookie-actions .btn{padding:12px 22px;font-size:.9rem}
.cookie-toggle{position:fixed;left:20px;bottom:20px;z-index:199;background:var(--navy);color:#fff;border:none;border-radius:999px;width:44px;height:44px;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:var(--shadow)}
.cookie-toggle.show{display:flex}

/* RESPONSIVE */
@media(max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .pills{grid-template-columns:repeat(2,1fr)}
  .why-grid,.cov-grid,.contact-grid,.detail{grid-template-columns:1fr;gap:40px}
  .detail:nth-child(even) .detail-art{order:0}
  .steps{grid-template-columns:repeat(2,1fr);gap:38px 30px}
  .svc-top{grid-template-columns:1fr;gap:26px}
  .values{grid-template-columns:1fr}
  .pillars .wrap{grid-template-columns:repeat(2,1fr)}
  .pillar{border-left:none;padding:28px 0;border-top:1px solid var(--border)}
  .pillar:first-child,.pillar:nth-child(2){border-top:none}
}
@media(max-width:680px){
  section{padding:72px 0}
  .wrap{padding:0 22px}
  nav ul{position:fixed;top:0;right:0;height:100vh;width:80%;max-width:330px;background:#fff;flex-direction:column;justify-content:center;gap:8px;transform:translateX(105%);transition:transform .45s var(--ease);box-shadow:var(--shadow);padding:40px}
  nav ul.open{transform:translateX(0)}
  nav ul a{color:var(--navy)!important;font-size:1.25rem;font-family:'Manrope';font-weight:700}
  .burger{display:block;z-index:70}
  .burger.x span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .burger.x span:nth-child(2){opacity:0}
  .burger.x span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  header.athero:not(.scrolled) .burger.x span{background:var(--navy)}
  .nav-right .btn{display:none}
  .cards,.pills,.steps,.frow{grid-template-columns:1fr}
  .pillars .wrap{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .cookie-bar{left:12px;right:12px;bottom:12px}
}