:root{
  --navy:#0D2340; --navy-2:#0C447C; --blue:#185FA5; --blue-light:#378ADD;
  --gold:#B28D3A; --gold-text:#836420;
  --bg:#F4F7FB; --surface:#ffffff; --border:#E2E8F0;
  --text:#1A2536; --text-muted:#56657C; --text-soft:#8595AB;
  --sans:'Poppins','Segoe UI',system-ui,-apple-system,Helvetica,Arial,sans-serif;
  --serif:'Lora',Georgia,'Times New Roman',serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:110px;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{font-family:var(--sans);color:var(--text);background:var(--bg);font-size:17px;line-height:1.72;letter-spacing:.005em;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"kern","liga","tnum"}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:-.01em;color:var(--navy)}
p{text-wrap:pretty}
::selection{background:rgba(13,35,64,.12);color:var(--navy)}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:3px}
.skip-link{position:absolute;left:16px;top:-60px;z-index:100;background:var(--navy);color:#fff;padding:10px 18px;border-radius:8px;font-size:15px;font-weight:500;transition:top .2s}
.skip-link:focus{top:12px}
main:focus{outline:none}
/* Fließtext-Links auch ohne Farbe erkennbar */
.legal a,.linklist a,.panel p a,.cta-box a:not(.btn){text-decoration:underline;text-underline-offset:2px}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
.wrap{max-width:1140px;margin:0 auto;padding-left:24px;padding-right:24px}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:104px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:80px;width:auto;display:block}
.menu{display:flex;align-items:center;gap:26px}
.menu a{font-size:15px;font-weight:500;color:var(--text-muted);transition:color .2s;padding:6px 0;border-bottom:2px solid transparent;letter-spacing:.005em;white-space:nowrap}
.menu a:hover{color:var(--navy-2)}
.menu a.active{color:var(--navy-2);border-bottom-color:var(--gold)}
.menu a.btn{color:#fff;border-bottom:none;margin-left:6px}
.menu a.btn:hover{color:#fff}
.btn{display:inline-block;background:var(--navy-2);color:#fff;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:500;letter-spacing:.01em;white-space:nowrap;transition:background .2s,transform .1s;cursor:pointer}
.btn:active{transform:translateY(1px)}
.btn:hover{background:var(--blue)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.55);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff;color:#fff}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{background:#E6EEF7}
.burger{display:none;font-size:26px;line-height:1;background:none;border:none;color:var(--navy-2);cursor:pointer;padding:8px;margin:-8px;border-radius:8px}

/* Hero (home) */
.hero{position:relative;background:var(--navy);overflow:hidden}
.hero-img{position:absolute;inset:0;opacity:.28}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-img::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,var(--navy) 30%,rgba(4,44,83,.55) 100%)}
.hero-inner{position:relative;padding:96px 0 104px;max-width:600px}
.pill{display:inline-block;font-family:var(--sans);font-size:12px;color:#9FC2E8;border:1px solid var(--blue);padding:7px 16px;border-radius:30px;margin-bottom:26px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.hero h1{font-size:54px;line-height:1.08;color:#fff;font-weight:600;letter-spacing:-.02em;margin-bottom:22px}
.hero p{font-size:19px;line-height:1.6;color:#C4DBF2;margin-bottom:34px;max-width:540px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

/* Page banner (subpages) */
.banner{position:relative;background:var(--navy);overflow:hidden}
.banner-img{position:absolute;inset:0;opacity:.25}
.banner-img img{width:100%;height:100%;object-fit:cover}
.banner-img::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,var(--navy) 40%,rgba(4,44,83,.6) 100%)}
.banner-inner{position:relative;padding:70px 0}
.banner .crumbs{font-size:12px;color:#9FC2E8;margin-bottom:12px;letter-spacing:.05em;text-transform:uppercase}
.banner .crumbs a{color:#9FC2E8}
.banner h1{font-size:42px;color:#fff;font-weight:600;letter-spacing:-.02em;line-height:1.12}
.banner p{font-size:18px;line-height:1.6;color:#C4DBF2;margin-top:14px;max-width:640px}

/* Stats */
.stats{background:var(--surface);border-bottom:1px solid var(--border)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:30px 16px;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat b{display:block;font-family:var(--serif);font-size:38px;font-weight:600;color:var(--navy-2);letter-spacing:-.02em;line-height:1}
.stat span{font-size:13px;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin-top:6px;display:block}

/* Sections */
section{padding-top:84px;padding-bottom:84px}
section.tight{padding-top:60px;padding-bottom:60px}
/* einheitlicher, großzügiger Abstand zwischen letztem Inhalt und Footer */
section:last-of-type{padding-bottom:104px}
.eyebrow{display:inline-block;font-family:var(--sans);font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-text);margin-bottom:14px}
.sec-head{max-width:660px;margin-bottom:46px}
.sec-head h2{font-size:36px;font-weight:600;letter-spacing:-.02em;line-height:1.15;margin:0 0 16px}
.sec-head p{font-size:18px;line-height:1.65;color:var(--text-muted)}
h2.block{font-size:29px;font-weight:600;letter-spacing:-.02em;line-height:1.2;margin:0 0 20px;color:var(--navy)}
h3.block{font-size:20px;font-weight:600;letter-spacing:-.01em;color:var(--navy-2);margin:26px 0 10px}

/* Service cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px -18px rgba(4,44,83,.35)}
.card-img{height:190px;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,44,83,0) 45%,rgba(4,44,83,.45) 100%)}
.card-body{padding:24px 26px 28px}
.card-body h3{font-size:20px;font-weight:600;letter-spacing:-.01em;color:var(--navy-2);margin-bottom:9px}
.card-body p{font-size:15.5px;line-height:1.62;color:var(--text-muted)}

/* Content panels */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px 36px;margin-bottom:26px}
.panel ul{list-style:none;margin:0}
.panel ul li{position:relative;padding:7px 0 7px 26px;font-size:15.5px;line-height:1.55;color:var(--text)}
.panel ul li::before{content:"";position:absolute;left:0;top:15px;width:6px;height:6px;border-radius:2px;background:var(--gold)}
.panel p{font-size:15.5px;line-height:1.65;color:var(--text-muted);margin-bottom:12px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
.linklist a{color:var(--blue);word-break:break-word}
.linklist a:hover{text-decoration:underline}

/* Quote */
.quote{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);color:#fff}
.quote .wrap{text-align:center;max-width:840px}
.quote p{font-family:var(--serif);font-size:28px;line-height:1.5;font-style:italic;font-weight:500;letter-spacing:-.01em}
.quote span{display:block;margin-top:20px;font-size:14px;font-family:var(--sans);color:#9FC2E8;font-style:normal;letter-spacing:.04em;text-transform:uppercase}

/* Split */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.split-img{border-radius:16px;overflow:hidden;height:420px}
.split-img img{width:100%;height:100%;object-fit:cover}
.split h2{font-size:33px;font-weight:600;letter-spacing:-.02em;line-height:1.18;margin-bottom:18px;color:var(--navy)}
.split p{font-size:16.5px;line-height:1.7;color:var(--text-muted);margin-bottom:16px}
.timeline{margin-top:26px;border-left:2px solid var(--border);padding-left:22px}
.tl{margin-bottom:18px;position:relative}
.tl::before{content:"";position:absolute;left:-29px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--blue);border:3px solid #fff;box-shadow:0 0 0 2px var(--border)}
.tl b{display:block;font-size:14px;color:var(--navy-2)}
.tl span{font-size:14px;color:var(--text-muted)}

/* Downloads list */
.dl{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:12px;transition:border-color .2s,transform .2s}
.dl:hover{border-color:var(--blue-light);transform:translateX(4px)}
.dl svg{width:24px;height:24px;stroke:var(--blue);flex-shrink:0}
.dl b{font-size:15px;color:var(--navy-2);display:block}
.dl span{font-size:13px;color:var(--text-soft)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.info{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:34px}
.info h3{font-size:20px;font-weight:600;color:var(--navy-2);margin-bottom:18px}
.info-row{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--text-muted);margin-bottom:14px}
.info-row svg{flex-shrink:0;width:20px;height:20px;margin-top:3px;stroke:var(--blue)}
.cta-box{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-2) 100%);border-radius:16px;padding:40px 34px;color:#fff;display:flex;flex-direction:column;justify-content:center}
.cta-box h3{font-size:25px;font-weight:600;letter-spacing:-.01em;color:#fff;margin-bottom:12px}
.cta-box p{font-size:16px;color:#B5D4F4;margin-bottom:24px}
.mapframe{border:0;width:100%;height:420px;border-radius:16px;filter:saturate(.9)}

/* Branchen */
.branchen{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.branchen-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.branche{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:24px 22px;transition:transform .2s,box-shadow .2s,border-color .2s}
.branche:hover{transform:translateY(-4px);box-shadow:0 16px 34px -20px rgba(13,35,64,.4);border-color:#D8C18A}
.branche-icon{width:50px;height:50px;flex:0 0 50px;border-radius:12px;background:#F3EAD4;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:16px}
.branche-icon svg{width:26px;height:26px;flex:none;stroke:var(--gold);fill:none;stroke-width:1.7;display:block}
.branche h3{font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--navy-2);margin-bottom:7px}
.branche p{font-size:14px;color:var(--text-muted);line-height:1.62}
@media(max-width:880px){.branchen-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.branchen-grid{grid-template-columns:1fr}}

/* Legal text */
.legal h3{font-family:var(--sans);font-size:15px;color:var(--navy-2);margin:26px 0 8px;font-weight:600;letter-spacing:.01em}
.legal p{font-size:14.5px;line-height:1.7;color:var(--text-muted);margin-bottom:12px}
.legal b{color:var(--text);font-weight:600}

/* Footer */
footer{position:relative;overflow:hidden;background:var(--navy) url('/assets/footer-bg.jpg') center/cover no-repeat;color:#9FC2E8;padding:80px 0 30px}
footer::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,35,64,.55) 0%,rgba(13,35,64,.30) 100%);z-index:0}
footer .wrap{position:relative;z-index:2}
.foot-watermark{position:absolute;right:-60px;bottom:-80px;width:420px;height:auto;opacity:.09;pointer-events:none;z-index:1}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1.4fr;gap:48px;margin-bottom:44px}
.foot-grid h4{font-family:var(--sans);color:#fff;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px}
.foot-grid div:first-child h4{font-family:var(--serif);font-size:20px;font-weight:600;letter-spacing:-.01em;text-transform:none;line-height:1.3;margin-bottom:16px}
.foot-grid p{margin-bottom:12px}
.foot-grid p,.foot-grid li{font-size:14.5px;color:#A9C4E2;line-height:1.85;list-style:none}
.foot-grid li{padding:3px 0}
.foot-grid a{color:#B5D4F4;transition:color .2s}
.foot-grid a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.14);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:#88A6C8}
.foot-bottom a{color:#A9C4E2;margin-left:18px;transition:color .2s}
.foot-bottom a:hover{color:#fff}

@media(max-width:880px){
  .menu{display:none}.burger{display:block}
  header.open .menu{display:flex;position:absolute;top:104px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--surface);border-bottom:1px solid var(--border);padding:8px 24px 16px;box-shadow:0 16px 30px -18px rgba(4,44,83,.4)}
  header.open .menu a{width:100%;padding:13px 0;border-bottom:1px solid var(--border)}
  header.open .menu a.btn{margin-top:12px;border:none;text-align:center;color:#fff}
  .hero h1{font-size:38px}.hero-inner{padding:64px 0 72px}
  .hero p,.banner p{font-size:17px}
  .banner h1{font-size:32px}.banner-inner{padding:56px 0}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--border)}
  .cards{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:32px}.split-img{height:300px}
  .grid-2,.contact-grid,.foot-grid{grid-template-columns:1fr}
  .foot-grid{gap:28px}
  .quote p{font-size:23px}
  section{padding-top:60px;padding-bottom:60px}
  section:last-of-type{padding-bottom:72px}
  .panel{padding:26px 22px}
}
@media(max-width:560px){
  .nav{height:74px}.brand img{height:50px}
  header.open .menu{top:74px}
  .cards,.branchen-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:31px}.sec-head h2{font-size:29px}
  h2.block{font-size:25px}.split h2{font-size:27px}
  .quote p{font-size:20px}
  .panel{padding:22px 20px}
  .info,.cta-box{padding:26px 22px}
  .foot-bottom{flex-direction:column;gap:6px}
  .foot-bottom a{margin-left:0;margin-right:18px}
}
