/* ============================================================
   Kraftwerk — shared branch / solution subpage components
   (loaded after styles.css; nav + mega-menu live in styles.css)
   ============================================================ */

.site-logo { display:inline-flex; align-items:center; }
.site-logo img { height: 34px; width:auto; display:block; }
.footer__brand .site-logo img { height: 30px; }

/* Footer layout */
.footer__top { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer__col h5 { font-size:12px; font-family:var(--mono); letter-spacing:.1em; text-transform:uppercase; color:#6f8099; margin-bottom:18px; font-weight:500; }
.footer__col ul { list-style:none; display:flex; flex-direction:column; gap:11px; }
.footer__col a { font-size:14.5px; }
.footer__brand p { font-size:14px; line-height:1.6; margin:18px 0; max-width:30ch; }
.footer__bottom { display:flex; align-items:center; justify-content:space-between; gap:20px; padding-top:28px; flex-wrap:wrap; }
.footer__legal { display:flex; gap:24px; font-size:13px; }
.footer__social { display:flex; gap:10px; }
.footer__social a { width:34px; height:34px; border-radius:8px; border:1px solid rgba(255,255,255,.14); display:grid; place-items:center; }
.footer__social svg { width:16px; height:16px; }

/* Breadcrumb */
.crumb { display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--ink-3); padding: 22px 0 0; }
.crumb a:hover { color: var(--ink); }
.crumb svg { width:13px; height:13px; }
.crumb b { color: var(--ink); font-weight:500; }

/* Page hero */
.phero { position:relative; overflow:hidden; padding: 40px 0 72px; isolation: isolate; }
.phero::before { content:""; position:absolute; inset:0; background: linear-gradient(180deg,var(--blue-050),transparent 70%); pointer-events:none; z-index: -1; }
.phero__grid { position:relative; display:grid; grid-template-columns: 1.1fr .9fr; gap:60px; align-items:center; padding-top: 36px; }
.phero h1 { font-size: clamp(38px, 4.6vw, 60px); letter-spacing:-.035em; line-height:1.1; margin: 16px 0 26px; }
.phero .lead { margin-bottom: 30px; }
.phero__cta { display:flex; gap:14px; flex-wrap:wrap; }

/* Hero media image (e.g. real photo) */
.phero__media { position:relative; border-radius:18px; overflow:hidden; box-shadow:var(--shadow-lg); background:var(--surface); aspect-ratio: 4 / 3.4; }
.phero__media img { width:100%; height:100%; object-fit:cover; display:block; }

/* Visual panel (UI mock) */
.vpanel { background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow-lg); overflow:hidden; }
.vpanel__head { padding:16px 20px; border-bottom:1px solid var(--line); background:#fbfcfe; display:flex; align-items:center; justify-content:space-between; }
.vpanel__head b { font-size:13.5px; }
.vpanel__head span { font-family:var(--mono); font-size:11px; color:var(--blue); background:var(--blue-100); padding:4px 9px; border-radius:999px; white-space:nowrap; }
.vpanel__list { padding: 8px 0; }
.vrow { display:flex; align-items:center; gap:14px; padding:13px 20px; border-bottom:1px solid var(--line); }
.vrow:last-child { border-bottom:0; }
.vrow > div { display:flex; flex-direction:column; gap:1px; min-width:0; }
.vrow__ico { width:36px; height:36px; border-radius:9px; background:var(--blue-100); color:var(--blue); display:grid; place-items:center; flex-shrink:0; }
.vrow__ico svg { width:18px; height:18px; }
.vrow b { font-size:14px; line-height:1.25; white-space:nowrap; }
.vrow small { font-size:12px; color:var(--ink-3); line-height:1.3; }
.vrow__status { margin-left:auto; flex-shrink:0; padding-left:10px; font-family:var(--mono); font-size:11px; color:var(--ink-3); }
.vrow__status.ok { color:var(--blue); }

/* Challenge intro */
.intro-grid { display:grid; grid-template-columns: 1fr 1fr; gap:64px; align-items:start; }
.intro-grid p { font-size:18px; line-height:1.6; color:var(--ink-2); }
.intro-grid p + p { margin-top:18px; }

/* Capabilities grid */
.caps { display:grid; grid-template-columns: repeat(3,1fr); gap:20px; }
.cap { padding:26px 24px; }
.cap__n { font-family:var(--mono); font-size:12px; color:var(--blue); display:block; margin-bottom:16px; }
.cap h3 { font-size:18px; margin-bottom:9px; }
.cap p { font-size:14px; color:var(--ink-2); line-height:1.5; }

/* Compliance chips */
.chips { display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; }
.chip { font-family:var(--mono); font-size:12.5px; color:var(--ink-2); border:1px solid var(--line-strong); border-radius:999px; padding:8px 15px; background:#fff; }
.chip b { color:var(--blue); font-weight:500; }

/* Products */
.prods { display:grid; grid-template-columns: repeat(2,1fr); gap:20px; }
.prod { padding:28px; display:flex; flex-direction:column; }
.prod__name { font-size:20px; font-weight:600; letter-spacing:-.02em; margin-bottom:8px; }
.prod__name em { color:var(--blue); font-style:normal; }
.prod p { font-size:14.5px; color:var(--ink-2); line-height:1.55; flex:1; margin-bottom:18px; }
.prod .textlink { font-size:14px; }

/* Related */
.related { display:grid; grid-template-columns: repeat(3,1fr); gap:20px; }
.rel { display:flex; align-items:center; gap:14px; padding:18px 22px; }
.rel__ico { width:38px; height:38px; border-radius:10px; display:grid; place-items:center; flex-shrink:0; }
.rel__ico svg { width:18px; height:18px; }
.rel b { font-size:15px; }
.rel svg.arr { width:15px; height:15px; margin-left:auto; color:var(--ink-3); transition:transform .2s; }
.rel:hover svg.arr { transform:translateX(3px); color:var(--blue); }

/* CTA */
.cta { position:relative; background:var(--ink); color:#fff; border-radius:22px; padding:72px 64px; overflow:hidden; }
.cta::after { content:""; position:absolute; right:-80px; top:-80px; width:420px; height:420px; background:radial-gradient(circle,rgba(147,192,30,.30),transparent 65%); }
.cta__grid { position:relative; display:grid; grid-template-columns:1.3fr auto; gap:40px; align-items:center; }
.cta h2 { color:#fff; max-width:18ch; margin-bottom:16px; }
.cta p { color:#aebbcf; max-width:46ch; font-size:17px; }
.cta__actions { display:flex; flex-direction:column; gap:12px; }

/* Section header */
.sec-head { display:grid; grid-template-columns:1fr auto; gap:24px; align-items:end; margin-bottom:48px; }
.sec-head .eyebrow { margin-bottom:18px; }
.sec-head h2 { max-width:20ch; }
.sec-head p { color:var(--ink-2); max-width:44ch; font-size:16.5px; }

@media (max-width:980px){
  .phero__grid,.intro-grid,.cta__grid { grid-template-columns:1fr; gap:40px; }
  .caps,.prods,.related { grid-template-columns:1fr 1fr; }
  .sec-head { grid-template-columns:1fr; }
}
@media (max-width:600px){
  .caps,.prods,.related,.footer__top { grid-template-columns:1fr; }
  .cta { padding:48px 28px; }
  :root { --pad-x:22px; }
}


/* ============================================================
   Übersichts-Hubs (Listing) — Loesungen / Plattform
   ============================================================ */
.page-hero { position:relative; overflow:hidden; padding: 56px 0 12px; isolation: isolate; }
.page-hero::before { content:""; position:absolute; inset:0; background:linear-gradient(180deg,var(--blue-050),transparent 70%); pointer-events:none; z-index: -1; }
.page-hero .inner { position:relative; max-width:760px; }
.page-hero h1 { font-size: clamp(38px,4.6vw,62px); letter-spacing:-.035em; line-height:1.02; margin:18px 0 20px; }
.lgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.lgrid + .group-label { margin-top:56px; }
.lcard { display:flex; flex-direction:column; padding:26px 24px; min-height:210px; }
.lcard__ico { width:46px; height:46px; border-radius:12px; background:var(--blue-100); color:var(--blue); display:grid; place-items:center; margin-bottom:18px; }
.lcard__ico svg { width:23px; height:23px; }
.lcard h3 { font-size:18px; margin-bottom:9px; letter-spacing:-.01em; }
.lcard h3 em { color:var(--blue); font-style:normal; }
.lcard p { font-size:14px; color:var(--ink-2); line-height:1.5; flex:1; }
.lcard__more { margin-top:16px; font-size:13.5px; font-weight:500; color:var(--ink-3); display:inline-flex; align-items:center; gap:6px; transition:color .15s; }
.lcard__more svg { width:13px; height:13px; transition:transform .2s; }
.lcard:hover .lcard__more { color:var(--blue); }
.lcard:hover .lcard__more svg { transform:translateX(3px); }
.group-label { font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin:0 0 22px; display:flex; align-items:center; gap:14px; }
.group-label::after { content:""; flex:1; height:1px; background:var(--line); }
@media (max-width:980px){ .lgrid { grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .lgrid { grid-template-columns:1fr; } }


/* ============================================================
   Lösung-Detailseiten (Vorteile / Module / Quote)
   ============================================================ */
.bigquote{font-size:clamp(21px,2.3vw,30px);line-height:1.38;letter-spacing:-.02em;color:#fff;max-width:60ch;margin-top:20px;padding-left:24px;border-left:3px solid var(--lime);font-weight:500}
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:28px 32px}
.benefit{padding-top:26px;border-top:2px solid var(--ink)}
.benefit__ico{width:38px;height:38px;color:var(--blue);margin-bottom:16px;display:block}
.benefit__ico svg{width:38px;height:38px}
.benefit h3{font-size:18px;margin-bottom:10px;line-height:1.25}
.benefit p{font-size:14.5px;color:var(--ink-2);line-height:1.55}
.modgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.modcard{background:#fff;padding:22px 22px;transition:background .15s}
.modcard:hover{background:var(--blue-050)}
.modcard h4{font-size:15px;font-weight:600;margin-bottom:6px;letter-spacing:-.01em}
.modcard p{font-size:12.5px;color:var(--ink-3);line-height:1.5}
@media(max-width:980px){.benefits{grid-template-columns:1fr 1fr}.modgrid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.benefits{grid-template-columns:1fr}.modgrid{grid-template-columns:1fr}}


/* ============================================================
   Produktseiten (kraftwerk.Energie / kraftwerk.Wasser …)
   ============================================================ */
.phero__stats{display:flex;gap:40px;flex-wrap:wrap;margin-top:32px}
.phero__stats>div{display:flex;flex-direction:column;gap:2px}
.phero__stats .n{font-family:var(--sans);font-weight:700;font-size:30px;letter-spacing:-.03em;color:var(--ink);line-height:1}
.phero__stats .l{font-size:13px;color:var(--ink-3)}
.kicker{font-family:var(--mono);font-size:12.5px;color:var(--ink-3);letter-spacing:.04em;margin:14px 0 6px}
.darkstats{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.darkstats .n{font-family:var(--sans);font-weight:700;font-size:clamp(34px,3.4vw,46px);letter-spacing:-.03em;color:#fff;line-height:1}
.darkstats .n em{color:var(--lime);font-style:normal}
.darkstats .l{font-size:14px;color:#9fb0c9;margin-top:8px}
.pains{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pain{padding:30px 26px}
.pain__n{font-family:var(--mono);font-size:13px;color:var(--lime-700);font-weight:600;display:block;margin-bottom:18px}
.pain h3{font-size:19px;margin-bottom:11px}
.pain p{font-size:14.5px;color:var(--ink-2);line-height:1.55}
.feats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.feat{padding:24px 22px}
.feat__ico{width:42px;height:42px;border-radius:11px;background:var(--blue-100);color:var(--blue);display:grid;place-items:center;margin-bottom:16px}
.feat__ico svg{width:21px;height:21px}
.feat h3{font-size:15.5px;margin-bottom:8px;letter-spacing:-.01em;line-height:1.25}
.feat p{font-size:13px;color:var(--ink-2);line-height:1.5}
.tabbtns{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:34px}
.tabbtn{padding:12px 22px;border:1px solid var(--line-strong);border-radius:999px;background:#fff;font-family:var(--sans);font-size:15px;font-weight:500;color:var(--ink-2);cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.tabbtn:hover{border-color:var(--ink);color:var(--ink)}
.tabbtn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.tabpanel{display:none}
.tabpanel.active{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.tabcol h4{font-size:13px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--lime-700);margin-bottom:18px}
.tablist{list-style:none;display:flex;flex-direction:column;gap:13px}
.tablist li{display:flex;gap:11px;font-size:15px;color:var(--ink-2);line-height:1.4}
.tablist li svg{width:18px;height:18px;color:var(--blue);flex-shrink:0;margin-top:1px}
.integ{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.integ__col h4{font-size:15px;margin-bottom:16px;padding-bottom:13px;border-bottom:2px solid var(--ink)}
.integ__col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.integ__col li{font-family:var(--mono);font-size:12.5px;color:var(--ink-2);line-height:1.35}
.quote{background:var(--ink);color:#fff;border-radius:22px;padding:60px 56px;position:relative;overflow:hidden}
.quote::after{content:"";position:absolute;right:-70px;top:-70px;width:360px;height:360px;background:radial-gradient(circle,rgba(147,192,30,.30),transparent 65%)}
.quote__mark{font-family:var(--display);font-size:64px;line-height:.5;color:var(--lime);position:relative;display:block;height:30px}
.quote p{font-size:clamp(20px,2.1vw,27px);line-height:1.42;letter-spacing:-.02em;max-width:46ch;position:relative;margin:18px 0 26px;color:#fff}
.quote__who{font-size:14px;color:#9fb0c9;position:relative}
.quote__filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px}
.qchip{font-size:13px;color:var(--ink-2);border:1px solid var(--line-strong);border-radius:999px;padding:7px 16px}
@media(max-width:980px){.feats{grid-template-columns:1fr 1fr}.integ{grid-template-columns:1fr 1fr}.pains{grid-template-columns:1fr}.darkstats{grid-template-columns:1fr 1fr;gap:32px 24px}.tabpanel.active{grid-template-columns:1fr;gap:32px}}
@media(max-width:600px){.feats{grid-template-columns:1fr}.integ{grid-template-columns:1fr}.darkstats{grid-template-columns:1fr}.quote{padding:40px 28px}}


/* DMS ingest steps */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.step{padding:22px 18px}
.step__n{font-family:var(--mono);font-size:12px;color:var(--lime-700);font-weight:600;display:block;margin-bottom:12px}
.step h4{font-size:15px;margin-bottom:6px}
.step p{font-size:12.5px;color:var(--ink-3);line-height:1.45}
@media(max-width:980px){.steps{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:600px){.steps{grid-template-columns:1fr}}
.pricewrap{display:flex;justify-content:center}
.pricecard{border:1px solid var(--line-strong);border-radius:20px;padding:42px;max-width:640px;box-shadow:var(--shadow-md);background:#fff}
.pricecard .ptag{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--lime-700);font-weight:600}
.pricecard h3{font-size:24px;margin:10px 0 4px}
.pricecard .psub{font-size:13.5px;color:var(--ink-3);margin-bottom:22px}
.pricecard ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:24px}
.pricecard li{display:flex;gap:11px;font-size:14.5px;color:var(--ink-2)}
.pricecard li svg{width:18px;height:18px;color:var(--blue);flex-shrink:0}
.priceex{background:var(--surface);border-radius:12px;padding:18px 20px;font-size:13.5px;color:var(--ink-2);line-height:1.6;margin-bottom:24px}
.priceex b{color:var(--ink)}


/* Vergleich (ohne/mit) */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.compare__col{border:1px solid var(--line);border-radius:16px;padding:30px}
.compare__col--good{border-color:var(--blue-100);box-shadow:var(--shadow-md)}
.compare__col h4{font-size:12px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}
.compare__col--bad h4{color:var(--ink-3)}
.compare__col--good h4{color:var(--lime-700)}
.compare__col ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.compare__col li{display:flex;gap:12px;font-size:14.5px;color:var(--ink-2);line-height:1.4}
.compare__col li svg{width:18px;height:18px;flex-shrink:0;margin-top:1px}
.compare__col--bad li svg{color:#c0392b}
.compare__col--good li svg{color:var(--blue)}
@media(max-width:760px){.compare{grid-template-columns:1fr}}


/* FAQ accordion */
.acc{max-width:840px;border-top:1px solid var(--line)}
.acc__item{border-bottom:1px solid var(--line)}
.acc__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:var(--sans);font-size:17px;font-weight:600;color:var(--ink);padding:22px 44px 22px 0;position:relative}
.acc__q::after{content:"";position:absolute;right:8px;top:25px;width:10px;height:10px;border-right:2px solid var(--ink-3);border-bottom:2px solid var(--ink-3);transform:rotate(45deg);transition:transform .2s}
.acc__item.open .acc__q::after{transform:rotate(-135deg)}
.acc__a{max-height:0;overflow:hidden;transition:max-height .28s ease}
.acc__a p{padding:0 0 24px;font-size:15.5px;color:var(--ink-2);line-height:1.62;max-width:68ch}
.acc__item.open .acc__a{max-height:360px}
.acc__cat{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--lime-700);margin:44px 0 4px}
.acc__cat:first-child{margin-top:0}

/* Newsroom */
.newsgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ncard{display:flex;flex-direction:column;padding:26px;min-height:230px}
.ncard__tag{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--lime-700);margin-bottom:14px}
.ncard__date{font-size:13px;color:var(--ink-3);margin-bottom:10px}
.ncard h3{font-size:18px;line-height:1.28;flex:1;letter-spacing:-.01em}
.ncard__arrow{margin-top:20px;width:30px;height:30px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;color:var(--ink-2);transition:all .18s}
.ncard:hover .ncard__arrow{background:var(--lime);border-color:var(--lime);color:var(--ink)}
.ncard__arrow svg{width:14px;height:14px}
@media(max-width:980px){.newsgrid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.newsgrid{grid-template-columns:1fr}}

/* Karriere perks + legal prose */
.legal{max-width:760px}
.legal h2{font-size:22px;margin:38px 0 12px;letter-spacing:-.02em}
.legal h2:first-child{margin-top:0}
.legal p{font-size:15.5px;color:var(--ink-2);line-height:1.65;margin-bottom:14px;max-width:70ch}
.legal p strong{color:var(--ink)}
.legal__note{background:var(--blue-050);border:1px solid var(--blue-100);border-radius:12px;padding:16px 20px;font-size:14px;color:var(--ink-2);margin-bottom:32px}