/* ============================================================================
   Steinbeis AKI — Website (öffentlich) · gemeinsame Styles für alle Seiten
   Baut auf ../colors_and_type.css (Tokens) auf. Visuelle Sprache = Richtung D.
   ========================================================================== */
*{box-sizing:border-box}
body{margin:0;background:var(--bg-1);color:var(--fg-2);font-family:var(--font-body);-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-heading);color:var(--fg-1);margin:0;letter-spacing:-0.015em}
p{margin:0;text-wrap:pretty}
.wrap{max-width:1240px;margin:0 auto;padding:0 48px}
.kick{font:var(--w-semibold) 0.76rem var(--font-heading);letter-spacing:.18em;text-transform:uppercase;color:var(--teal-600)}

/* header */
.hd{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.hd .wrap{display:flex;align-items:center;justify-content:space-between;height:100px}
.hd img{height:84px}
.hd nav{display:flex;gap:30px}
.hd nav a{font-size:0.92rem;color:var(--fg-2)}
.hd nav a:hover,.hd nav a.active{color:var(--teal-600)}
.hd .lang{font:var(--w-medium) 0.78rem var(--font-mono);color:var(--fg-4)}
.hd .lang b{color:var(--navy-700)}
@media(max-width:900px){.hd nav{display:none}}

/* buttons */
.btn{display:inline-block;font:var(--w-semibold) 1rem var(--font-heading);padding:14px 28px;border:1.5px solid transparent;border-radius:var(--radius-sm);transition:.2s;cursor:pointer}
.btn-p{background:var(--navy-700);color:#fff}.btn-p:hover{background:var(--navy-800)}
.btn-o{border-color:var(--navy-300);color:var(--navy-700)}.btn-o:hover{background:var(--navy-50)}
.tlink{display:inline-block;font:var(--w-semibold) 1rem var(--font-heading);color:var(--navy-700);border-bottom:2px solid var(--teal-500);padding-bottom:4px;transition:.2s}
.tlink:hover{border-color:var(--navy-700)}

/* page intro / breadcrumb */
.crumb{padding:34px 0 0}
.crumb .wrap{display:flex;gap:10px;align-items:center;font:var(--w-medium) 0.82rem var(--font-mono);color:var(--fg-4)}
.crumb a:hover{color:var(--teal-600)}
.crumb .sep{color:var(--gray-300)}
.crumb .cur{color:var(--navy-700)}
.pintro{padding:34px 0 70px;border-bottom:1px solid var(--border)}
.pintro .kick{display:block;margin-bottom:22px}
.pintro h1{font-size:clamp(2.4rem,1.7rem+3vw,3.8rem);font-weight:700;line-height:1.05;max-width:16ch;margin-bottom:28px}
.pintro .lead{font-size:clamp(1.15rem,1rem+0.7vw,1.45rem);line-height:1.6;color:var(--fg-2);max-width:60ch}
.pintro .cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}

/* generic section */
.sec{padding:84px 0}
.sec.alt{background:var(--bg-2)}
.shead{display:flex;align-items:baseline;gap:18px;margin-bottom:14px}
.shead .no{font:var(--w-medium) 0.9rem var(--font-mono);color:var(--teal-600)}
.shead h2{font-size:clamp(1.7rem,1.3rem+1.6vw,2.4rem);font-weight:700}
.sintro{font-size:1.12rem;line-height:1.62;color:var(--fg-2);max-width:60ch;margin-bottom:50px}

/* SCHWERPUNKTE — detailed numbered blocks, NO cards */
.swps{border-top:1px solid var(--border)}
.swp{display:grid;grid-template-columns:300px 1fr;gap:56px;padding:48px 0;border-bottom:1px solid var(--border)}
@media(max-width:820px){.swp{grid-template-columns:1fr;gap:20px;padding:38px 0}}
.swp .lead-col .n{font:var(--w-medium) 0.9rem var(--font-mono);color:var(--teal-600)}
.swp .lead-col h3{font-size:clamp(1.4rem,1.1rem+1vw,1.9rem);font-weight:700;margin-top:12px;line-height:1.15}
.swp .body .claim{font-size:1.18rem;line-height:1.5;color:var(--fg-1);font-family:var(--font-heading);font-weight:400;letter-spacing:-0.01em;margin-bottom:22px;max-width:50ch}
.swp .body ul{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-direction:column;gap:11px;max-width:54ch}
.swp .body li{position:relative;padding-left:24px;font-size:1.02rem;line-height:1.5;color:var(--fg-2)}
.swp .body li::before{content:"";position:absolute;left:2px;top:.62em;width:8px;height:2px;background:var(--teal-500)}
.swp .body .res{display:flex;align-items:baseline;gap:12px;border-top:2px solid var(--gray-150);padding-top:16px;max-width:54ch}
.swp .body .res small{flex:none;font:var(--w-medium) 0.68rem var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--teal-600);padding-top:2px}
.swp .body .res span{font-size:1rem;line-height:1.5;color:var(--fg-1)}
.swp .body .res a{color:var(--navy-700);border-bottom:1.5px solid var(--teal-500)}

/* dark band */
.band{background:var(--navy-700);color:#fff}
.band .wrap{padding:78px 48px}
.band p{font-size:clamp(1.4rem,1.1rem+1.4vw,2.2rem);font-family:var(--font-heading);font-weight:400;line-height:1.32;max-width:30ch;letter-spacing:-0.01em}
.band p span{color:var(--teal-300)}

/* contact */
.contact{background:var(--navy-700);color:#fff}
.contact .wrap{padding:104px 48px}
.contact h2{font-size:clamp(2rem,1.4rem+2.6vw,3.4rem);font-weight:700;color:#fff;line-height:1.06;max-width:16ch;margin-bottom:26px}
.contact a.mail{font-size:clamp(1.2rem,1rem+1vw,1.7rem);font-family:var(--font-heading);color:var(--teal-300);border-bottom:2px solid var(--teal-400);padding-bottom:5px}

/* footer */
footer{background:var(--navy-900);color:#fff}
footer .wrap{padding:56px 48px 32px}
.ft-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;padding-bottom:30px}
footer img{height:50px}
.ft-nav{display:flex;gap:26px;flex-wrap:wrap}
.ft-nav a{font-size:0.9rem;color:var(--fg-on-dark-muted)}.ft-nav a:hover{color:#fff}
.ft-bot{display:flex;justify-content:space-between;border-top:1px solid var(--border-on-dark);padding-top:20px;flex-wrap:wrap;gap:10px}
.ft-bot span,.ft-bot a{font-size:0.83rem;color:var(--fg-on-dark-faint)}
.ft-bot .r{display:flex;gap:20px}.ft-bot a:hover{color:#fff}

/* ── Langtext-Detailseite: Sticky-Index + Inhalt ───────────────────────── */
.lt{display:grid;grid-template-columns:236px 1fr;gap:64px;align-items:start;padding:60px 0 20px}
@media(max-width:880px){.lt{grid-template-columns:1fr;gap:0;padding-top:36px}}
.lt-index{position:sticky;top:104px}
@media(max-width:880px){.lt-index{position:static;margin-bottom:34px;border-bottom:1px solid var(--border);padding-bottom:10px}}
.lt-index .cap{font:var(--w-medium) 0.7rem var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-4);padding:0 10px;margin-bottom:12px}
.lt-index ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.lt-index a{display:flex;gap:12px;align-items:baseline;padding:9px 10px;border-radius:var(--radius-sm);font:var(--w-medium) 0.95rem var(--font-heading);color:var(--fg-3);transition:.2s;line-height:1.25}
.lt-index a .n{font:var(--w-medium) 0.7rem var(--font-mono);color:var(--fg-4);flex:none}
.lt-index a:hover{color:var(--navy-700);background:var(--bg-2)}
.lt-index a.active{color:var(--navy-700);background:rgba(9,124,148,.08)}
.lt-index a.active .n{color:var(--teal-600)}
.lt-content{min-width:0;max-width:760px}
.lt-sec{padding-bottom:54px;scroll-margin-top:104px}
.lt-sec .h{font-size:clamp(1.5rem,1.2rem+1.1vw,2.1rem);font-weight:700;color:var(--fg-1);margin:0 0 22px;letter-spacing:-0.01em;display:flex;align-items:baseline;gap:14px}
.lt-sec .h .n{font:var(--w-medium) 0.8rem var(--font-mono);color:var(--teal-600)}
.lt-sec p{font-size:1.08rem;line-height:1.7;color:var(--fg-2);margin:0 0 16px}
.lt-sec p.big{font-size:clamp(1.2rem,1rem+0.7vw,1.5rem);line-height:1.5;color:var(--fg-1);font-family:var(--font-heading);font-weight:400;letter-spacing:-0.01em;margin-bottom:22px}
.lt-steps{list-style:none;margin:6px 0 22px;padding:0;counter-reset:s}
.lt-steps li{position:relative;padding:0 0 20px 54px;counter-increment:s}
.lt-steps li::before{content:counter(s,decimal-leading-zero);position:absolute;left:0;top:1px;font:var(--w-medium) 0.85rem var(--font-mono);color:var(--teal-600)}
.lt-steps li::after{content:"";position:absolute;left:14px;top:24px;bottom:2px;width:1px;background:var(--border)}
.lt-steps li:last-child{padding-bottom:0}
.lt-steps li:last-child::after{display:none}
.lt-steps li b{font-family:var(--font-heading);color:var(--fg-1);font-weight:600;display:block;margin-bottom:4px;font-size:1.06rem}
.lt-steps li span{font-size:1.04rem;line-height:1.6;color:var(--fg-2)}
.lt-list{list-style:none;margin:0 0 18px;padding:0;display:flex;flex-direction:column;gap:11px}
.lt-list li{position:relative;padding-left:24px;font-size:1.06rem;line-height:1.55;color:var(--fg-2)}
.lt-list li::before{content:"";position:absolute;left:2px;top:.66em;width:8px;height:2px;background:var(--teal-500)}
/* figure placeholder */
figure.ph{margin:10px 0 30px}
figure.ph .slot{width:100%;background:var(--navy-50);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}
figure.ph image-slot{width:100%;height:100%;display:block}
figure.ph figcaption{font:var(--text-caption);color:var(--fg-3);margin-top:11px}
figure.ph figcaption b{color:var(--fg-2);font-family:var(--font-heading);font-weight:600}
/* facts + quote */
.facts{display:flex;gap:48px;flex-wrap:wrap;border-top:2px solid var(--gray-150);border-bottom:2px solid var(--gray-150);padding:24px 0;margin:6px 0 30px}
.facts .f .num{font:700 clamp(1.9rem,1.4rem+1.4vw,2.6rem) var(--font-heading);color:var(--navy-700);letter-spacing:-0.02em;line-height:1}
.facts .f .lab{font-size:0.92rem;color:var(--fg-3);margin-top:6px}
.pull{margin:6px 0 30px;padding:0}
.pull p{font-size:clamp(1.3rem,1.05rem+1vw,1.8rem);font-family:var(--font-heading);font-weight:400;line-height:1.32;color:var(--navy-700);letter-spacing:-0.01em;margin:0}
.pull p .mk{color:var(--teal-400)}
.pull cite{display:block;margin-top:12px;font-style:normal;font:var(--text-caption);color:var(--fg-3)}
/* FAQ */
.faq details{border-top:1px solid var(--border)}
.faq details:last-of-type{border-bottom:1px solid var(--border)}
.faq summary{list-style:none;cursor:pointer;padding:20px 40px 20px 0;position:relative;font:600 1.12rem var(--font-heading);color:var(--fg-1);letter-spacing:-0.005em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:18px;font:400 1.5rem var(--font-heading);color:var(--teal-600);line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{color:var(--navy-700)}
.faq .ans{padding:0 40px 22px 0}
.faq .ans p{font-size:1.05rem;line-height:1.62;color:var(--fg-2);margin:0}
.eign p{font-size:1.1rem;line-height:1.65}
.eign .cta{margin-top:26px}

/* review-only back link */
.review-back{position:fixed;left:18px;bottom:18px;z-index:999;background:#fff;border:1px solid var(--border);border-radius:999px;padding:9px 18px;font:600 0.85rem var(--font-heading);color:var(--navy-700);box-shadow:var(--shadow-lg)}
