/* ============================================================================
   AP IT Solutions — Design-System "Integrationsdiagramm"
   Petrol + Signal-Amber · Sans-Display / Mono-Utility / Serif-Ziffern
   Variablennamen bleiben (--navy/--accent/--gold ...), damit Inline-Styles
   auf allen Seiten weiter kaskadieren. Werte + Komponenten sind neu.
   ============================================================================ */
:root{
  /* Anker: offizielles Markenblau (Logo) */
  --navy:#023170; --navy-d:#021F47; --bg-navy:#023170;
  /* Sekundär/Struktur + Links: klares Blau */
  --accent:#2E6DA4; --accent-d:#235488;
  /* Einziger mutiger Akzent: Signal-Amber (ehem. "gold") */
  --gold:#D8842A; --signal:#D8842A; --signal-d:#B86C1B;
  /* Tinten & Flächen (kühl/blaustichig) */
  --ink:#1B2735; --muted:#5A6B7B; --line:#E2E8F0;
  --bg:#ffffff; --bg-alt:#F4F7FB; --mist:#E6EEF7;
  --ok:#2f7d5a;
  /* Form */
  --radius:7px; --radius-sm:5px; --maxw:1160px;
  --shadow:0 1px 2px rgba(14,59,63,.05), 0 14px 34px -18px rgba(14,59,63,.22);
  --shadow-h:0 2px 4px rgba(14,59,63,.06), 0 22px 48px -20px rgba(14,59,63,.30);
  /* Schrift-Rollen */
  --sans:"Segoe UI",-apple-system,BlinkMacSystemFont,Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"Cascadia Code","SF Mono","Segoe UI Mono",Consolas,"Liberation Mono",monospace;
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);line-height:1.62;background:var(--bg);
  font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  min-height:100vh;display:flex;flex-direction:column}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-d);text-decoration:underline;text-underline-offset:2px}
img{max-width:100%;height:auto}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
section{padding:84px 0;position:relative}
section.alt{background:var(--bg-alt)}
@media(max-width:640px){section{padding:54px 0}}

/* ---- Typo-Skala ---- */
h1,h2,h3,h4{color:var(--navy);line-height:1.12;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2.35rem,1.5rem + 3.1vw,3.55rem);line-height:1.04}
h2{font-size:clamp(1.7rem,1.25rem + 1.7vw,2.35rem);margin-bottom:.5em}
h3{font-size:1.2rem;letter-spacing:-.01em}
h4{font-size:1.05rem}
p{margin-bottom:1em}
.lead{font-size:clamp(1.1rem,1rem + .5vw,1.27rem);color:var(--muted);font-weight:400;line-height:1.55}
.muted{color:var(--muted)}
.center{text-align:center}
strong{font-weight:700;color:var(--ink)}

/* ---- Eyebrow: Mono-Label mit Node-Marke (wiederkehrendes Struktur-Signal) ---- */
.eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;
  font-size:.74rem;font-weight:600;color:var(--accent);margin-bottom:1.1em;
  display:inline-flex;align-items:center;gap:.7em}
.eyebrow::before{content:"";width:9px;height:9px;background:var(--signal);
  transform:rotate(45deg);flex:0 0 auto;box-shadow:0 0 0 3px rgba(216,132,42,.16)}
.eyebrow.center{display:flex;justify-content:center}

/* ---- Header ---- */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;color:var(--navy);
  font-size:1.12rem;letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand-logo{height:38px;width:auto;display:block}
.brand .mark{width:38px;height:38px;border-radius:8px;
  background:linear-gradient(150deg,var(--navy),var(--accent));color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:.92rem;position:relative;
  font-family:var(--mono);letter-spacing:.02em}
.brand .mark::after{content:"";position:absolute;right:-3px;bottom:-3px;width:8px;height:8px;
  background:var(--signal);transform:rotate(45deg);border:2px solid #fff}
.brand small{display:block;font-size:.6rem;font-weight:600;color:var(--muted);
  letter-spacing:.12em;text-transform:uppercase;font-family:var(--mono);margin-top:2px}
nav.menu{display:flex;align-items:center;gap:26px}
nav.menu a{color:var(--ink);font-weight:600;font-size:.95rem;position:relative;padding:4px 0}
nav.menu a:not(.btn):hover{color:var(--accent);text-decoration:none}
nav.menu a:not(.btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;
  background:var(--signal);transition:right .22s ease}
nav.menu a:not(.btn):hover::after{right:0}
.menu-toggle{display:none;background:none;border:0;font-size:1.6rem;color:var(--navy);cursor:pointer}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5em;background:var(--signal);color:var(--ink);
  padding:13px 24px;border-radius:var(--radius-sm);font-weight:700;font-size:.96rem;
  border:1px solid var(--signal);transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
  cursor:pointer;box-shadow:0 1px 0 rgba(0,0,0,.04)}
.btn:hover{background:var(--signal-d);border-color:var(--signal-d);text-decoration:none;color:var(--ink);
  transform:translateY(-2px);box-shadow:0 10px 22px -8px rgba(216,132,42,.55)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--navy);border-color:var(--line);box-shadow:none}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);background:transparent;box-shadow:none}
.btn.lg{padding:16px 32px;font-size:1.04rem}
.btn.white{background:#fff;color:var(--navy);border-color:#fff}
.btn.white:hover{background:var(--mist);color:var(--navy);border-color:var(--mist)}
.btn.ghost.white{background:transparent;color:#fff;border-color:rgba(255,255,255,.34)}
.btn.ghost.white:hover{border-color:var(--signal);color:#fff;background:rgba(255,255,255,.06)}

/* ---- Hero: asymmetrischer Schaltplan ---- */
.hero{background:var(--navy);color:#eaf1f8;padding:0;overflow:hidden;position:relative}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px) 0 0/100% 44px,
    linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px) 0 0/44px 100%,
    radial-gradient(900px 460px at 86% 8%,rgba(46,109,164,.55),transparent 70%)}
.hero .wrap{position:relative}
/* Nur die Startseite: asymmetrischer Split mit Schaltplan rechts */
.hero-split .wrap{display:grid;grid-template-columns:1.02fr .98fr;gap:48px;
  align-items:center;padding-top:78px;padding-bottom:78px}
.hero h1{color:#fff;max-width:17ch}
.hero .lead{color:#c7d6e8;max-width:50ch;margin:20px 0 30px}
.hero .lead strong{color:#fff}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.hero .badges{margin-top:36px;display:flex;gap:14px 26px;flex-wrap:wrap;
  color:#9fb6cf;font-size:.88rem;font-weight:600}
.hero .badges span{display:flex;align-items:center;gap:8px}
.tick{color:var(--signal);font-weight:800}
.hero .eyebrow{color:#9fc0e0}
.hero .eyebrow::before{box-shadow:0 0 0 3px rgba(216,132,42,.25)}

/* Proofbar unter dem Hero */
.proofbar{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:30px;align-items:center;
  color:#9fb6cf;font-size:.9rem;font-weight:600;font-family:var(--mono);letter-spacing:.01em}
.proofbar b{color:#fff;font-size:1rem}
.proofbar .sep{opacity:.4}

/* ---- Schaltplan-Grafik (Hero-Signatur) ---- */
.schematic{width:100%;height:auto;display:block;filter:drop-shadow(0 24px 50px rgba(0,0,0,.32))}
.schematic .panel{fill:rgba(255,255,255,.04);stroke:rgba(255,255,255,.14)}
.schematic .panel.live{fill:rgba(46,109,164,.18);stroke:rgba(159,182,207,.6)}
.schematic .wire{stroke:rgba(255,255,255,.22);stroke-width:1.5;fill:none}
.schematic .wire.warn{stroke:rgba(255,255,255,.16);stroke-dasharray:5 5}
.schematic .lbl{fill:#c7d6e8;font-family:var(--mono);font-size:11px;letter-spacing:.04em}
.schematic .lbl.hi{fill:#fff}
.schematic .pin{fill:#9fb6cf}
.schematic .signalwire{stroke:var(--signal);stroke-width:2.2;fill:none;
  stroke-dasharray:9 320;stroke-dashoffset:329;animation:flow 3.4s linear infinite}
.schematic .spark{fill:var(--signal);opacity:0;animation:spark 3.4s linear infinite}
@keyframes flow{to{stroke-dashoffset:0}}
@keyframes spark{0%,100%{opacity:0}46%,54%{opacity:1}}

/* ---- Grids & Cards ---- */
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;
  position:relative}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-h)}
.card h3{margin-bottom:.4em}
.card .ic{width:46px;height:46px;border-radius:9px;background:var(--bg-alt);color:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:1.35rem;font-weight:800;
  margin-bottom:16px;border:1px solid var(--line)}
/* Karten mit Akzentrand bekommen oben eine farbige Signatur-Kante */
.card[style*="--accent"]::before,.card[style*="--gold"]::before{content:"";position:absolute;
  left:-1px;top:-1px;width:46px;height:3px;border-radius:3px 3px 0 0}
.card[style*="--accent"]::before{background:var(--accent)}
.card[style*="--gold"]::before{background:var(--signal)}
.outcome{display:block;margin-top:14px;padding-top:13px;border-top:1px dashed var(--line);
  font-family:var(--mono);font-size:.82rem;color:var(--accent);letter-spacing:.01em}

/* ---- Pills: Mono = SAP-Systemnamen/Tags ---- */
.pill{display:inline-block;background:var(--bg-alt);border:1px solid var(--line);color:var(--navy);
  padding:6px 13px;border-radius:5px;font-weight:600;font-size:.82rem;margin:0 6px 10px 0;
  font-family:var(--mono);letter-spacing:.02em}

/* ---- Ablauf: Connector-Linie mit Nodes (echte Sequenz) ---- */
.steps{display:grid;gap:24px;grid-template-columns:repeat(4,1fr);position:relative}
.steps::before{content:"";position:absolute;top:19px;left:7%;right:7%;height:2px;
  background:repeating-linear-gradient(90deg,var(--line) 0 8px,transparent 8px 14px);z-index:0}
.step{position:relative;padding-top:0;z-index:1}
.step .n{width:40px;height:40px;border-radius:9px;background:#fff;color:var(--navy);
  font-family:var(--mono);font-weight:700;display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;border:1px solid var(--line);box-shadow:0 0 0 5px var(--bg);position:relative}
.step .n::after{content:"";position:absolute;right:-2px;top:-2px;width:8px;height:8px;
  background:var(--signal);transform:rotate(45deg)}
.step h3{font-size:1.05rem}
section.alt .step .n{box-shadow:0 0 0 5px var(--bg-alt)}

/* ---- Painpoint zwei-spaltig ---- */
.pp{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.pp .col{padding:28px 30px}
.pp .col.problem{background:#fbf6f3;border-right:1px solid var(--line)}
.pp .col.solution{background:#f1f7f3}
.pp h4{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;
  color:#a4502f;margin-bottom:10px}
.pp .col.solution h4{color:var(--ok)}

/* ---- CTA-Band ---- */
.band{background:linear-gradient(135deg,var(--navy),var(--accent));color:#fff;border-radius:14px;
  padding:54px;text-align:center;position:relative;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;opacity:.5;
  background:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px) 0 0/100% 40px,
  linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px) 0 0/40px 100%}
.band>*{position:relative}
.band h2{color:#fff}
.band p{color:#dbe7f4;max-width:60ch;margin:0 auto 26px}

/* ---- Listen ---- */
ul.clean{list-style:none}
ul.clean li{padding-left:30px;position:relative;margin-bottom:12px}
ul.clean li:before{content:"\2713";position:absolute;left:0;top:0;color:var(--ok);font-weight:800}
ul.cross li:before{content:"\2715";color:#a4502f}

/* ---- Stats: Serifen-Ziffern (Gravitas) ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.stat .statnum{font-family:var(--serif);font-size:clamp(2.4rem,1.8rem + 2vw,3rem);font-weight:700;
  color:var(--navy);line-height:1;margin:0;letter-spacing:-.01em;font-feature-settings:"lnum" 1}
.stat .statnum .plus{color:var(--signal)}
.stat .statlbl{color:var(--muted);font-size:.92rem;margin:12px 0 0;line-height:1.45}
.stat.dark .statnum{color:var(--signal)}
.stat.dark .statlbl{color:#c7d6e8}

/* ---- E-E-A-T / Zitat ---- */
.eeat{display:flex;gap:20px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-left:3px solid var(--signal);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow)}
.eeat .badge{flex:0 0 56px;height:56px;border-radius:11px;
  background:linear-gradient(150deg,var(--navy),var(--accent));color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:1rem;font-family:var(--mono)}

/* ---- FAQ ---- */
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  margin-bottom:12px;box-shadow:var(--shadow);transition:border-color .18s ease}
.faq details[open]{border-color:var(--accent)}
.faq summary{cursor:pointer;list-style:none;padding:18px 22px;font-weight:700;color:var(--navy);
  font-size:1.04rem;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--signal);font-weight:400;
  line-height:1;transition:transform .2s ease}
.faq details[open] summary::after{content:"\2013"}
.faq .a{padding:0 22px 20px;color:var(--muted)}

/* ---- Datenschutz-Leiste (cookielos) ---- */
.consent-bar{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;max-width:780px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 16px 50px rgba(14,59,63,.22);
  padding:16px 20px;display:flex;gap:16px;align-items:center;flex-wrap:wrap;font-size:.9rem;color:var(--ink)}
.consent-bar a{color:var(--accent);font-weight:600}
.consent-bar .btn{padding:10px 20px;font-size:.9rem;margin-left:auto;white-space:nowrap}
.consent-embed{border:1.5px dashed var(--line);border-radius:var(--radius);padding:32px 24px;
  text-align:center;color:var(--muted);display:grid;gap:12px;justify-items:center}
.consent-embed strong{color:var(--navy);font-size:1.05rem}
.consent-embed p{max-width:48ch;font-size:.9rem;margin:0}
@media(max-width:560px){.consent-bar{flex-direction:column;align-items:flex-start}.consent-bar .btn{margin-left:0}}

/* ---- Cookie-Consent (CMP) ---- */
.cc-backdrop{position:fixed;inset:0;z-index:400;background:rgba(8,18,40,.5);display:flex;
  align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.cc-card{background:#fff;border-radius:14px;box-shadow:0 28px 70px rgba(2,49,112,.32);max-width:540px;
  width:100%;padding:26px 26px 22px;position:relative;max-height:90vh;overflow:auto}
.cc-card h2{font-size:1.18rem;color:var(--navy);margin-bottom:12px;text-align:center}
.cc-card>p{font-size:.9rem;color:var(--muted);line-height:1.55;margin:0 0 18px}
.cc-close{position:absolute;top:11px;right:13px;background:none;border:0;font-size:1.45rem;line-height:1;
  color:var(--muted);cursor:pointer;padding:4px 7px;border-radius:6px}
.cc-close:hover{color:var(--navy);background:var(--bg-alt)}
.cc-actions{display:flex;flex-wrap:wrap;gap:10px}
.cc-actions .btn{flex:1 1 140px;justify-content:center}
.btn.cc-accept{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.cc-accept:hover{background:var(--accent-d);border-color:var(--accent-d);color:#fff;
  box-shadow:0 10px 22px -8px rgba(46,109,164,.55)}
.cc-links{margin-top:16px;display:flex;flex-wrap:wrap;justify-content:center;gap:6px 16px;font-size:.82rem}
.cc-links a{color:var(--accent);font-weight:600}
.cc-cat{display:flex;gap:16px;align-items:flex-start;justify-content:space-between;padding:14px 0;border-top:1px solid var(--line)}
.cc-cat:last-of-type{border-bottom:1px solid var(--line);margin-bottom:18px}
.cc-cat-t{font-weight:700;color:var(--navy);font-size:.95rem}
.cc-cat-d{font-size:.82rem;color:var(--muted);margin-top:3px;line-height:1.45}
.cc-sw{position:relative;width:44px;height:24px;flex:0 0 auto;display:inline-block}
.cc-sw input{position:absolute;inset:0;width:100%;height:100%;opacity:0;margin:0;cursor:pointer;z-index:2}
.cc-sw .track{position:absolute;inset:0;background:#cbd5e1;border-radius:999px;transition:background .2s}
.cc-sw .thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;
  transition:transform .2s;box-shadow:0 1px 2px rgba(0,0,0,.25)}
.cc-sw input:checked~.track{background:var(--accent)}
.cc-sw input:checked~.thumb{transform:translateX(20px)}
.cc-sw input:disabled{cursor:not-allowed}
.cc-sw input:disabled~.track{opacity:.55}
a.cc-reopen{cursor:pointer}
@media(max-width:520px){.cc-actions .btn{flex:1 1 100%}}

/* ---- Hinweise / Platzhalter ---- */
.note{background:#fff8ec;border:1px solid #ecd9a8;border-left:3px solid var(--signal);
  border-radius:var(--radius-sm);padding:15px 18px;font-size:.92rem;color:#6b5418}
.ph{background:#fff3cd;border:1px dashed #d8b24a;border-radius:4px;padding:1px 7px;font-weight:700;
  color:#6b5418;font-size:.95em}

/* ---- Footer ---- */
footer.site{background:var(--navy-d);color:#b9c8da;padding:60px 0 28px;font-size:.92rem;position:relative;margin-top:auto}
footer.site::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--signal),transparent 40%)}
footer.site h4{color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;
  margin-bottom:14px;font-family:var(--mono)}
footer.site a{color:#b9c8da;display:block;margin-bottom:9px}
footer.site a:hover{color:#fff}
.foot-logo{height:58px;width:auto;display:block;margin-bottom:14px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;padding-bottom:34px;
  border-bottom:1px solid rgba(255,255,255,.12)}
.foot-bottom{padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  color:#7f93a8;font-size:.85rem}
footer.site .foot-bottom a{display:inline;color:#7f93a8;margin-bottom:0}
.foot-bottom span:last-child{display:flex;gap:8px;align-items:center}

/* ---- Scroll-Reveal: dezent, wird per JS (consent.js) nur unterhalb des Folds
   und nur bei gewünschter Bewegung aktiviert → kein Flackern, kein Inhalt ohne JS ---- */
.reveal{opacity:0;transform:translateY(20px);
  transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---- Quality floor: Fokus + Reduced Motion ---- */
:focus-visible{outline:3px solid var(--signal);outline-offset:2px;border-radius:3px}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .schematic .signalwire{stroke-dashoffset:0;stroke-dasharray:none;opacity:.85}
  .schematic .spark{opacity:1}
}

/* ---- Responsive ---- */
@media(max-width:980px){
  .hero-split .wrap{grid-template-columns:1fr;gap:36px;padding-top:60px;padding-bottom:64px}
  .hero-split .schematic-wrap{order:2;max-width:520px}
}
@media(max-width:900px){
  .g3,.g4,.stats{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}.steps::before{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .g2,.g3,.g4,.pp,.foot-grid,.stats,.steps{grid-template-columns:1fr}
  nav.menu{display:none;position:absolute;top:72px;left:0;right:0;background:#fff;flex-direction:column;
    padding:18px 26px;border-bottom:1px solid var(--line);gap:14px;box-shadow:var(--shadow)}
  nav.menu.open{display:flex}
  nav.menu a:not(.btn)::after{display:none}
  .menu-toggle{display:block}
  .band{padding:36px 24px}
}
