:root{
  --ink:#0B1B34;
  --muted:#5E6B7A;
  --bg:#ffffff;
  --alt:#F4FAFF;

  --blue-900:#043682;
  --blue-700:#0964B6;
  --blue-300:#81D1F6;

  --radius:18px;
  --shadow:0 18px 50px rgba(4,54,130,.14);
  --container:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  overflow-x:hidden;
}
img{max-width:100%; height:auto; display:block}
a{color:inherit}
.container{width:min(var(--container), 92vw); margin-inline:auto}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0}
.skip{position:absolute; left:-999px; top:10px; background:#fff; color:#000; padding:10px 14px; border-radius:10px; z-index:99999}
.skip:focus{left:10px}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px;
  padding:12px 16px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--blue-700), var(--blue-900));
  color:#fff;
  text-decoration:none;
  font-weight:900;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 14px 34px rgba(4,54,130,.22);
}
.btn:hover{transform: translateY(-1px)}
.btn--ghost{
  background:transparent;
  color:var(--blue-900);
  border:1px solid rgba(4,54,130,.22);
  box-shadow:none;
}
.btn--ghost:hover{background:rgba(129,209,246,.18)}
.btn--sm{padding:9px 12px; font-size:14px}

/* ===== Top Bar ===== */
.top__bar{
  background:linear-gradient(90deg, var(--blue-900), var(--blue-700));
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.14);
}
.top__barInner{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:10px 0;
  font-size:14px;
}
.top__barLeft, .top__barRight{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.top__area{color:rgba(255,255,255,.88)}
.pill{
  display:inline-flex; align-items:baseline; gap:10px;
  padding:7px 10px;
  border-radius:999px;
  text-decoration:none;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(6px);
}
.pill__k{opacity:.85; font-weight:750}
.pill__v{font-weight:950; letter-spacing:.2px}

/* ===== Masthead (big logo) ===== */
.mastlogo{background:#fff}
.mastlogo__inner{display:flex; justify-content:center; padding:18px 0 14px}
.mastlogo__link{display:inline-flex}
.mastlogo img{width:210px; filter: drop-shadow(0 16px 30px rgba(4,54,130,.16))}

/* ===== Primary nav under logo ===== */
.mastnav{
  background:#fff;
  border-bottom:1px solid rgba(4,54,130,.10);
}
.mastnav__inner{padding:10px 0 12px}
.nav{display:flex; gap:18px; justify-content:center; align-items:center; flex-wrap:wrap}
.nav a{text-decoration:none; font-weight:850; color:rgba(11,27,52,.86)}
.nav a:hover{color:var(--blue-700)}

.nav__dd{position:relative}
.nav__ddBtn{
  appearance:none; border:0; background:transparent; font:inherit;
  font-weight:850; color:rgba(11,27,52,.86); cursor:pointer;
  padding:10px 12px; border-radius:14px;
}
.nav__ddBtn:hover{background:rgba(129,209,246,.18); color:var(--blue-700)}
.nav__ddMenu{
  position:absolute; left:50%; transform:translateX(-50%);
  top: calc(100% + 10px);
  width:min(520px, 90vw);
  background:#fff;
  border:1px solid rgba(4,54,130,.12);
  border-radius:18px;
  padding:12px;
  box-shadow:var(--shadow);
  display:none;
  z-index:2000;
}
.nav__ddMenu.is-open{display:grid}
.nav__ddMenu a{
  padding:10px 12px;
  border-radius:14px;
  font-weight:800;
}
.nav__ddMenu a:hover{background:rgba(129,209,246,.18)}
.mastnav, .mastnav__inner, .nav { overflow: visible; }

/* ===== Sticky header ===== */
.stickhead{
  position:fixed; top:0; left:0; right:0;
  background:#fff;
  border-bottom:1px solid rgba(4,54,130,.12);
  box-shadow:0 10px 24px rgba(4,54,130,.10);
  transform: translateY(-110%);
  transition: transform .18s ease;
  z-index:9999;
}
body.sticky-on .stickhead{transform: translateY(0)}
.stickhead__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0;
  gap:14px;
}
.stickhead__brand img{width:84px}

.sticknav{display:flex; align-items:center; gap:10px; position:relative}
.sticknav__toggle{
  display:none;
  border:1px solid rgba(4,54,130,.16);
  background:#fff;
  border-radius:999px;
  padding:10px 12px;
  cursor:pointer;
}
.burger{width:20px; height:2px; background:var(--blue-900); display:block; position:relative}
.burger:before,.burger:after{content:""; position:absolute; left:0; width:20px; height:2px; background:var(--blue-900)}
.burger:before{top:-6px}
.burger:after{top:6px}

.sticknav__menu{display:flex; align-items:center; gap:16px}
.sticknav__menu a{text-decoration:none; font-weight:850; color:rgba(11,27,52,.86)}
.sticknav__menu a:hover{color:var(--blue-700)}

.sticknav__details summary{cursor:pointer; font-weight:850; color:rgba(11,27,52,.86); list-style:none}
.sticknav__details summary::-webkit-details-marker{display:none}
.sticknav__detailsMenu{display:grid; gap:6px; padding-top:8px}
.sticknav__detailsMenu a{padding:8px 10px; border-radius:12px}
.sticknav__detailsMenu a:hover{background:rgba(129,209,246,.18)}

/* Desktop: sticky Leistungen dropdown overlay */
@media (min-width: 641px){
  .sticknav__details{ position: relative; }
  .sticknav__detailsMenu{
    position:absolute;
    top: calc(100% + 12px);
    right: 0;
    width: min(520px, 92vw);
    background:#fff;
    border:1px solid rgba(4,54,130,.12);
    border-radius:18px;
    padding:12px;
    box-shadow: var(--shadow);
    display:none;
    z-index: 3000;
  }
  .sticknav__details[open] .sticknav__detailsMenu{ display:grid; }
}

/* ===== Hero ===== */
#content{
  background:
    radial-gradient(900px 520px at 20% 10%, rgba(129,209,246,.50), transparent 60%),
    radial-gradient(720px 520px at 90% 30%, rgba(9,100,182,.32), transparent 60%),
    linear-gradient(180deg, rgba(4,54,130,.06), rgba(4,54,130,0));
  background-repeat: no-repeat;
}
.hero{
  padding:40px 0 36px;
}
.hero__grid{display:grid; grid-template-columns:1.05fr .95fr; gap:22px; align-items:center}
.hero__copy h1{margin:0 0 10px; font-size:clamp(34px, 4vw, 54px); line-height:1.05; letter-spacing:-.8px}
.lead{margin:0 0 16px; color:rgba(11,27,52,.82); font-size:clamp(16px, 1.5vw, 19px)}
.hero__cta{display:flex; gap:12px; flex-wrap:wrap; margin:10px 0 16px}
.hero__media img{border-radius:22px; box-shadow:var(--shadow); border:1px solid rgba(4,54,130,.10)}
.hero__facts{display:flex; gap:12px; flex-wrap:wrap}
.fact{background:#fff; border:1px solid rgba(4,54,130,.10); border-radius:16px; padding:10px 12px; box-shadow:0 10px 28px rgba(4,54,130,.10)}
.fact__n{font-weight:950; color:var(--blue-900)}
.fact__t{font-size:13px; color:var(--muted)}

.section{padding:68px 0}
.section--alt{background:var(--alt)}
.section__head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:22px}
.section__head h2{margin:0; font-size:clamp(24px, 2.6vw, 34px); letter-spacing:-.4px}
.section__head p{margin:0; color:var(--muted); max-width:62ch}
.section__cta{margin-top:18px}

.grid{display:grid; gap:16px}
.cards{grid-template-columns:repeat(3,1fr)}
.card{
  background:#fff;
  border:1px solid rgba(4,54,130,.12);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(4,54,130,.10);
}
.card--link{text-decoration:none; color:inherit; display:block}
.card img{width:100%; height:190px; object-fit:cover}
.card__body{padding:16px}
.card__body h3{margin:0 0 8px}
.card__body p{margin:0 0 12px; color:rgba(11,27,52,.76)}
.card__more{font-weight:900; color:var(--blue-700)}

.split{display:grid; grid-template-columns:1.05fr .95fr; gap:18px; align-items:start}
.panel{
  background:linear-gradient(135deg, rgba(9,100,182,.10), rgba(129,209,246,.22));
  border:1px solid rgba(4,54,130,.14);
  border-radius:20px;
  padding:18px;
  box-shadow:0 14px 34px rgba(4,54,130,.12);
}
.list{margin:12px 0 0; padding-left:18px}
.steps{margin:10px 0 0; padding-left:18px}
.miniBox{display:grid; gap:10px; margin-top:14px}
.miniBox a{color:var(--blue-900); font-weight:900; text-decoration:none}
.miniBox a:hover{text-decoration:underline}

.pageHero{
  padding:30px 0 22px;
  background:linear-gradient(180deg, rgba(4,54,130,.05), rgba(4,54,130,0));
}
.pageHero__grid{display:grid; grid-template-columns:1.1fr .9fr; gap:18px; align-items:center}
.pageHero__media img{border-radius:22px; box-shadow:var(--shadow); border:1px solid rgba(4,54,130,.10)}

.prose{max-width:78ch}
.faq{display:grid; gap:10px; margin-top:10px}
details{background:#fff; border:1px solid rgba(4,54,130,.12); border-radius:16px; padding:12px 14px}
summary{cursor:pointer; font-weight:950; color:rgba(11,27,52,.88)}
details p{margin:10px 0 0; color:rgba(11,27,52,.76)}
.tiny{font-size:12px}
.muted{color:var(--muted)}

.contactGrid{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.contactCard{background:#fff; border:1px solid rgba(4,54,130,.12); border-radius:20px; padding:16px; box-shadow:0 10px 30px rgba(4,54,130,.10)}
.form{display:grid; gap:10px}
label span{display:block; font-size:13px; font-weight:850; color:rgba(11,27,52,.78); margin:0 0 6px}
input, select, textarea{
  width:100%; padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(4,54,130,.18);
  outline:none; font:inherit;
  background:#fff;
}
input:focus, select:focus, textarea:focus{
  border-color:rgba(9,100,182,.55);
  box-shadow:0 0 0 4px rgba(129,209,246,.28);
}
.map iframe{width:100%; height:320px; border:0; border-radius:18px}

.footer{
  margin-top:44px;
  background:linear-gradient(180deg, rgba(4,54,130,.06), rgba(4,54,130,.10));
  border-top:1px solid rgba(4,54,130,.12);
  padding:26px 0 20px;
}
.footer__grid{display:flex; justify-content:space-between; align-items:flex-start; gap:18px; flex-wrap:wrap}
.footer__brand{display:flex; align-items:center; gap:12px}
.footer__name{font-weight:950}
.footer__muted{color:var(--muted); font-size:13px}
.footer__cols{display:flex; gap:30px; flex-wrap:wrap}
.footer__h{font-weight:950; margin-bottom:8px}
.footer__cols a{display:block; text-decoration:none; color:rgba(11,27,52,.78); font-weight:750; margin:6px 0}
.footer__cols a:hover{color:var(--blue-700)}
.footer__bottom{display:flex; align-items:center; gap:10px; padding-top:10px; color:rgba(11,27,52,.74)}
.dot{opacity:.6}

section[id]{scroll-margin-top:96px}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .hero__grid, .split, .pageHero__grid{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 760px){
  .top__barInner{flex-direction:column; align-items:flex-start; gap:8px}
  .top__barRight{width:100%; justify-content:space-between}
}
@media (max-width: 640px){
  .cards{grid-template-columns:1fr}
  .contactGrid{grid-template-columns:1fr}
}

/* Fix button color */
.btn, .btn:visited { color: #fff; }
.btn--ghost, .btn--ghost:visited { color: var(--blue-900); }
.nav .btn, .sticknav__menu .btn { color:#fff !important; }

/* ===== Leistungen Cards ===== */
.section__head--center{
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
}
.section__cta--center{
  display:flex;
  justify-content:center;
}

.services{ padding: 72px 0; }
.services-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media (max-width: 980px){
  .services-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .services-grid{ grid-template-columns: 1fr; }
}

.service-card{
  position:relative;
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(4,54,130,.12);
  background:#fff;
  box-shadow: 0 14px 36px rgba(4,54,130,.10);
  transform: translateY(0);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  will-change: transform;
}
.service-card img{
  width:100%;
  height: 220px;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform .35s ease, filter .35s ease;
  filter: saturate(1.02) contrast(1.02);
}
.service-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding: 18px 16px 16px;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.62) 64%, rgba(0,0,0,.72) 100%);
  display:flex;
  flex-direction:column;
  gap:8px;
}
.service-overlay h3{
  margin:0;
  color:#fff;
  font-size: 18px;
  letter-spacing: -.2px;
  text-shadow: 0 8px 18px rgba(0,0,0,.25);
}
.service-cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  color: rgba(255,255,255,.92);
  font-weight:900;
  font-size: 13px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(9,100,182,.28);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  transition: transform .22s ease, background .22s ease;
}
.service-card:hover{
  transform: translateY(-6px);
  border-color: rgba(9,100,182,.30);
  box-shadow: 0 22px 60px rgba(4,54,130,.18);
}
.service-card:hover img{
  transform: scale(1.08);
  filter: saturate(1.06) contrast(1.05);
}
.service-card:hover .service-cta{
  background: rgba(9,100,182,.42);
  transform: translateX(4px);
}
.service-card::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:24px;
  pointer-events:none;
  opacity:0;
  transition: opacity .22s ease;
  box-shadow: 0 0 0 1px rgba(9,100,182,.18), 0 18px 60px rgba(9,100,182,.22);
}
.service-card:hover::after{ opacity:1; }

/* ===== Mobile Sticky Header: Desktop-Look (Header klappt auf) ===== */
@media (max-width: 640px){

  .stickhead{
    background:#fff;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
  }

  /* Wrap: damit Menü unter die erste Zeile kann */
  .stickhead__inner{
    flex-wrap:wrap;
    gap:12px;
  }

  .stickhead__brand img{
    width:72px;
    height:auto;
  }

  /* Burger sichtbar */
  .sticknav__toggle{
    display:inline-flex;
    width:44px;
    height:44px;
    padding:0;
    align-items:center;
    justify-content:center;
  }

  /* Menü ist Teil vom Sticky Header (kein overlay) */
  .sticknav__menu{
    display:none;
    flex: 0 0 100%;
    width:100%;

    position:static !important;
    inset:auto !important;
    transform:none !important;

    margin-top:10px;
    padding-top:10px;

    flex-direction:column;
    gap:10px;

    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    max-height:none !important;
    overflow:visible !important;

    border-top:1px solid rgba(4,54,130,.12);
  }
  .sticknav__menu.is-open{display:flex}

  /* Links wie Desktop */
  .sticknav__menu a{
    display:block;
    padding:12px 0;
    margin:0;
    border:0;
    border-radius:0;
    background:transparent;
    font-weight:850;
    color:rgba(11,27,52,.86);
    text-decoration:none;
  }
  .sticknav__menu a:hover{color:var(--blue-700)}

  /* Details inline */
  .sticknav__details{position:static !important}
  .sticknav__details summary{
    padding:12px 0;
    border:0;
    border-radius:0;
    background:transparent;
    font-weight:850;
    color:rgba(11,27,52,.86);
  }

  .sticknav__detailsMenu{
    position:static !important;
    width:100% !important;
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    padding:6px 0 0 !important;
    display:none;
    gap:8px;
  }
  .sticknav__details[open] .sticknav__detailsMenu{display:grid}

  .sticknav__detailsMenu a{
    padding:10px 12px;
    border-radius:12px;
    background:rgba(9,100,182,.06);
    border:1px solid rgba(4,54,130,.10);
  }

/* Anfrage Button mobil sauber positioniert */
.sticknav__menu .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:12px 16px;
  border-radius:999px;

  background:linear-gradient(135deg, var(--blue-700), var(--blue-900));
  color:#fff !important;

  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 14px 34px rgba(4,54,130,.22);

  margin-top:10px;

  align-self:flex-start;
  margin-left:48px;   /* ← DAS ist der wichtige Teil */
}
}