/* ============================================================
   EK ABDICHTUNG — Styles
   ============================================================ */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--font-body);font-size:var(--fs-body);line-height:1.65;
  color:var(--text-body);background:var(--off-white);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,video,svg{display:block;max-width:100%}
/* thin branded scrollbar (premium polish) */
html{scrollbar-width:thin;scrollbar-color:var(--navy-300) transparent}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--navy-300);border-radius:6px;border:2px solid var(--off-white)}
::-webkit-scrollbar-thumb:hover{background:var(--navy-500)}
a{color:inherit;text-decoration:none}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{margin:0;font-family:var(--font-display);color:var(--text-strong);font-weight:600;line-height:1.08}
p{margin:0}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--brand-navy);color:#fff}

/* No-FOUC: hide reveal targets only when JS active */
.has-js [data-reveal]{opacity:0;transform:translateY(22px)}
.has-js [data-hero]{opacity:0}
@media (prefers-reduced-motion:reduce){
  .has-js [data-reveal],.has-js [data-hero]{opacity:1!important;transform:none!important}
}

.skip-link{position:fixed;top:-100px;left:16px;z-index:999;background:var(--brand-navy);color:#fff;
  padding:12px 18px;border-radius:var(--radius);font-size:.9rem;transition:top .2s}
.skip-link:focus{top:16px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.ico{width:1.25em;height:1.25em;fill:none;stroke:currentColor;stroke-width:1.6;
  stroke-linecap:round;stroke-linejoin:round;flex:none}

/* sections */
.section--light{background:var(--off-white);color:var(--text-body);padding-block:var(--section-y)}
.section--alt{background:var(--white)}
.section--dark{background:var(--navy-900);color:var(--text-on-dark);padding-block:var(--section-y);position:relative}
.section--darker{background:var(--navy-950);color:var(--text-on-dark)}
.section--dark h2,.section--dark h3{color:var(--text-on-dark)}

/* ---------- Typo utilities ---------- */
.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:.16em;text-transform:uppercase;font-size:var(--fs-label)}
.eyebrow{display:flex;align-items:center;gap:.7rem;font-family:var(--font-mono);font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;font-size:var(--fs-label);color:var(--text-muted);margin-bottom:1.4rem}
.eyebrow .mono{letter-spacing:.18em;color:var(--accent)}
.eyebrow--light{color:var(--text-on-dark-mut)}
.eyebrow--light .mono{color:var(--accent-soft)}
.eyebrow__tick{width:26px;height:1.5px;background:var(--accent);flex:none}
.section-title{font-size:var(--fs-h2);letter-spacing:-.015em;max-width:18ch}
.section-lead{font-size:var(--fs-lead);color:var(--text-muted);max-width:56ch;margin-top:1.3rem;line-height:1.55}
.section--dark .section-lead{color:var(--text-on-dark-mut)}
.accent-word{color:var(--accent-soft);position:relative}
.accent-fig{color:var(--accent);font-variant-numeric:tabular-nums}
.section--dark .accent-fig{color:var(--accent-soft)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:500;
  font-size:.98rem;letter-spacing:-.01em;padding:.95rem 1.6rem;border-radius:var(--radius);
  transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),
  border-color var(--dur-fast) var(--ease),transform var(--dur-fast) var(--ease);will-change:transform}
.btn .ico{width:1.1em;height:1.1em;stroke-width:1.8;transition:transform var(--dur-fast) var(--ease)}
.btn:hover .ico{transform:translateX(4px)}
.btn--primary{background:var(--brand-navy);color:#fff}
.btn--primary:hover{background:var(--navy-800)}
.btn--light{background:#fff;color:var(--navy-900)}
.btn--light:hover{background:var(--off-white)}
.btn--ghost-light{border:1px solid rgba(255,255,255,.3);color:#fff}
.btn--ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn--block{width:100%;justify-content:center;padding-block:1.1rem}
.btn:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,
textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent-bright);outline-offset:3px;border-radius:2px}

.textlink{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:500;
  font-size:.95rem;color:var(--text-strong);position:relative;padding-bottom:3px}
.textlink::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:100%;background:var(--line-strong);
  transform:scaleX(1);transform-origin:right;transition:transform var(--dur) var(--ease),background var(--dur) var(--ease)}
.textlink:hover::after{background:var(--accent);transform-origin:left}
.textlink .ico{width:1em;height:1em;stroke-width:1.8;color:var(--accent);transition:transform var(--dur-fast) var(--ease)}
.textlink:hover .ico{transform:translateX(4px)}

/* ============================================================
   DICHTUNGSLINIE — signature scroll rail
   ============================================================ */
.seal-rail{position:fixed;left:max(22px,calc((100vw - var(--maxw))/2 - 26px));top:0;bottom:0;width:2px;z-index:var(--z-rail);
  pointer-events:none;display:none}
.seal-rail__track{position:absolute;inset:0;background:linear-gradient(var(--line-light),var(--line-light));opacity:.5}
.seal-rail__progress{position:absolute;left:0;top:0;width:100%;height:0;
  background:linear-gradient(var(--navy-500),var(--brand-navy));transform-origin:top}
.seal-rail__marker{position:absolute;left:50%;top:0;width:9px;height:9px;border-radius:50%;
  background:var(--accent);transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(146,51,45,.18)}
@media (min-width:1180px){.seal-rail{display:block}}

/* section seam wave (logo-derived) */
.seam{position:absolute;left:0;right:0;height:34px;pointer-events:none;z-index:2;overflow:hidden;line-height:0}
.seam svg{width:100%;height:100%}
.seam--top{top:-1px}
.seam--bottom{bottom:-1px}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);transition:background var(--dur) var(--ease),
  box-shadow var(--dur) var(--ease),backdrop-filter var(--dur) var(--ease)}
.nav__inner{display:flex;align-items:center;gap:1.5rem;max-width:var(--maxw);margin-inline:auto;
  padding:1.05rem var(--gutter);transition:padding var(--dur) var(--ease)}
.nav__brand{display:flex;align-items:center;gap:.7rem}
.nav__brand img{width:40px;height:40px;border-radius:5px;background:#fff}
.nav__brand-text{display:flex;flex-direction:column;font-family:var(--font-display);font-weight:600;
  font-size:.95rem;letter-spacing:.04em;color:#fff;line-height:1.15;transition:color var(--dur) var(--ease)}
.nav__brand-text strong{color:#fff;font-weight:700}
.nav__brand-text em{font-style:normal;font-family:var(--font-mono);font-weight:400;font-size:.6rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--navy-200);margin-top:2px}
.nav__links{display:flex;gap:2rem;margin-left:auto}
.nav__links a{font-family:var(--font-display);font-weight:500;font-size:.95rem;color:rgba(255,255,255,.82);
  position:relative;padding:.3rem 0;transition:color var(--dur-fast) var(--ease)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--accent);
  transition:width var(--dur) var(--ease)}
.nav__links a:hover{color:#fff}.nav__links a:hover::after{width:100%}
.nav__cta{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-weight:500;
  font-size:.85rem;letter-spacing:.04em;color:#fff;border:1px solid rgba(255,255,255,.28);
  padding:.6rem .95rem;border-radius:var(--radius);transition:all var(--dur-fast) var(--ease)}
.nav__cta .ico{width:1.05em;height:1.05em;color:var(--accent-soft)}
.nav__cta:hover{border-color:#fff;background:rgba(255,255,255,.07)}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px;margin-left:auto}
.nav__burger span{width:24px;height:2px;background:#fff;transition:transform .3s var(--ease),opacity .3s}

/* scrolled state */
.nav.is-scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 1px 0 var(--line-light),0 10px 30px -18px rgba(16,32,58,.25)}
.nav.is-scrolled .nav__inner{padding-block:.7rem}
.nav.is-scrolled .nav__brand-text{color:var(--text-strong)}
.nav.is-scrolled .nav__brand-text strong{color:var(--brand-navy)}
.nav.is-scrolled .nav__brand-text em{color:var(--text-muted)}
.nav.is-scrolled .nav__links a{color:var(--text-body)}
.nav.is-scrolled .nav__links a:hover{color:var(--brand-navy)}
.nav.is-scrolled .nav__cta{color:var(--brand-navy);border-color:var(--line-strong)}
.nav.is-scrolled .nav__cta:hover{background:var(--surface-raised)}
.nav.is-scrolled .nav__burger span{background:var(--text-strong)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:90;background:var(--navy-950);
  display:flex;flex-direction:column;justify-content:center;gap:2rem;padding:7rem var(--gutter) 3rem;
  clip-path:inset(0 0 100% 0);transition:clip-path .55s var(--ease);visibility:hidden}
.mobile-menu.is-open{clip-path:inset(0 0 0 0);visibility:visible}
.mobile-menu__links{display:flex;flex-direction:column;gap:.4rem}
.mobile-menu__links a{display:flex;align-items:baseline;gap:1rem;font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.8rem,9vw,2.6rem);color:#fff;padding:.5rem 0;border-bottom:1px solid var(--navy-800)}
.mm-idx{font-family:var(--font-mono);font-size:.8rem;font-weight:500;color:var(--accent-soft);letter-spacing:.1em}
.mobile-menu__cta{align-self:flex-start;margin-top:1rem}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:7rem var(--gutter) 0;color:#fff;overflow:hidden;isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-2;background:var(--navy-950)}
.hero__poster,.hero__video{position:absolute;inset:0;width:100%;height:100%;min-width:100%;min-height:100%;
  object-fit:cover;object-position:center;filter:saturate(.92) brightness(.94) contrast(1.06)}
.hero__poster{transform:scale(1.06);animation:kenburns 26s ease-in-out infinite alternate}
.hero__video{opacity:0;transition:opacity 1.1s var(--ease)}
.hero__video.is-ready{opacity:1}
@keyframes kenburns{from{transform:scale(1.04) translate3d(0,0,0)}to{transform:scale(1.14) translate3d(-1.5%,-1.5%,0)}}
@media (prefers-reduced-motion:reduce){.hero__poster{animation:none}}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    /* left text column dark navy -> transparent right (Bild rechts sichtbar) */
    linear-gradient(90deg,rgba(10,37,64,.90) 0%,rgba(10,37,64,.66) 38%,rgba(10,37,64,.20) 70%,rgba(10,37,64,0) 100%),
    /* top (nav) + bottom (Standort-Zeile) darkening */
    linear-gradient(180deg,rgba(8,22,40,.50) 0%,rgba(8,22,40,0) 20%,rgba(8,22,40,0) 52%,rgba(8,22,40,.92) 100%)}
.hero__grid-overlay{position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(ellipse 90% 80% at 30% 60%,#000,transparent 95%)}

.hero__content{max-width:var(--maxw);width:100%;margin-inline:auto;flex:1;display:flex;flex-direction:column;
  justify-content:center;padding-top:3rem}
.hero__title{font-size:var(--fs-h1);font-weight:600;letter-spacing:-.025em;line-height:1.02;margin:.4rem 0 0;color:#fff;
  text-shadow:0 2px 24px rgba(8,16,28,.45)}
.hero__title .line{display:block;overflow:hidden}
.hero__sub{font-size:var(--fs-lead);max-width:50ch;margin-top:1.7rem;color:rgba(241,245,251,.92);line-height:1.55;
  text-shadow:0 1px 10px rgba(8,16,28,.55)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}

.hero__foot{max-width:var(--maxw);width:100%;margin:0 auto;display:flex;align-items:flex-end;gap:2.5rem;
  padding:2rem 0 2rem;border-top:1px solid rgba(255,255,255,.14);margin-top:3rem}
.hero__coord,.hero__loc{display:flex;flex-direction:column;gap:.25rem;font-size:.92rem;color:rgba(238,243,250,.9)}
.hero__coord .mono,.hero__loc .mono{color:rgba(255,255,255,.74);font-size:.65rem;text-shadow:0 1px 6px rgba(8,16,28,.6)}
.hero__scrolltip{margin-left:auto;display:flex;flex-direction:column;align-items:center;gap:.6rem;color:rgba(255,255,255,.72)}
.hero__scrollline{width:1.5px;height:46px;background:linear-gradient(var(--accent-soft),transparent);position:relative;overflow:hidden}
.hero__scrollline::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:#fff;
  animation:scrolldrop 2.2s var(--ease) infinite}
@keyframes scrolldrop{0%{top:-50%}60%,100%{top:100%}}
@media (prefers-reduced-motion:reduce){.hero__scrollline::after{animation:none;display:none}}

/* ============================================================
   TRUST / COUNTERS
   ============================================================ */
.trust{background:var(--navy-950);color:#fff;padding-block:clamp(3rem,5vw,4.5rem);position:relative}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--navy-800);
  border:1px solid var(--navy-800);border-radius:var(--radius-lg);overflow:hidden}
.stat{background:var(--navy-950);padding:2.2rem 1.8rem;display:flex;flex-direction:column;gap:.8rem}
.stat__num{font-family:var(--font-display);font-weight:600;font-size:var(--fs-stat);line-height:1;
  letter-spacing:-.02em;color:#fff;font-variant-numeric:tabular-nums;display:flex;align-items:baseline}
.stat__num i{font-style:normal;color:var(--accent-soft);font-size:.55em;margin-left:.08em}
.stat__num.accent-fig{color:var(--accent-soft)}
.stat__label{font-size:.95rem;color:var(--text-on-dark-mut);line-height:1.4}
.stat__label .mono{display:block;color:var(--navy-400);margin-top:.3rem;font-size:.62rem}
.trust__line{display:flex;align-items:center;gap:.7rem;justify-content:center;margin-top:1.8rem;
  font-size:.95rem;color:var(--text-on-dark-mut);text-align:center;flex-wrap:wrap}
.trust__line .ico{color:var(--accent-soft);width:1.3em;height:1.3em}

/* ============================================================
   LEISTUNGEN / SCHICHTENINDEX
   ============================================================ */
.leistungen__head{margin-bottom:3.5rem}
.schicht{display:grid;grid-template-columns:minmax(280px,4fr) 8fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.schicht__stage{position:sticky;top:120px;align-self:start;display:flex;flex-direction:column;gap:1.4rem;
  padding:2rem;background:var(--white);border:1px solid var(--line-light);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md)}
.schicht__index{font-family:var(--font-display);font-weight:600;font-size:var(--fs-index);color:var(--text-strong);
  letter-spacing:-.02em;font-variant-numeric:tabular-nums;display:flex;align-items:baseline;gap:.1rem}
.schicht__index i{font-style:normal;font-size:.5em;color:var(--text-faint);font-family:var(--font-mono)}
.schicht__visual{aspect-ratio:16/10;background:
  radial-gradient(80% 85% at 50% 42%,rgba(36,67,113,.12),transparent 70%),
  linear-gradient(160deg,#fff,var(--off-white));
  border:1px solid var(--line-light);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden}
.schicht__visual::after{content:"";position:absolute;inset:0;
  background-image:linear-gradient(var(--line-light) 1px,transparent 1px),linear-gradient(90deg,var(--line-light) 1px,transparent 1px);
  background-size:100% 24px,24px 100%;opacity:.45;
  -webkit-mask-image:radial-gradient(78% 78% at 50% 46%,#000,transparent);
  mask-image:radial-gradient(78% 78% at 50% 46%,#000,transparent)}
.schicht__icon{width:56%;height:56%;fill:none;stroke:var(--brand-navy);stroke-width:1.05;
  stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1;
  filter:drop-shadow(0 10px 20px rgba(36,67,113,.14))}
.schicht__active-name{color:var(--accent);letter-spacing:.14em}
.schicht__section-cut{display:flex;gap:6px;height:30px;align-items:stretch}
.schicht__section-cut span{flex:1;border-radius:2px}
.schicht__section-cut span:nth-child(1){background:repeating-linear-gradient(45deg,var(--navy-200),var(--navy-200) 3px,transparent 3px,transparent 6px)}
.schicht__section-cut span:nth-child(2){background:var(--brand-navy)}
.schicht__section-cut span:nth-child(3){background:var(--accent)}

.schicht__list{display:flex;flex-direction:column}
.leistung{position:relative;display:grid;grid-template-columns:auto auto 1fr;align-items:center;gap:1.3rem;
  padding:1.6rem 0;border-top:1px solid var(--line-light);cursor:default;
  transition:padding-left var(--dur) var(--ease)}
.leistung:last-child{border-bottom:1px solid var(--line-light)}
.leistung__no{color:var(--text-muted);transition:color var(--dur) var(--ease);align-self:start;padding-top:.35rem}
.leistung__ico{width:30px;height:30px;color:var(--text-muted);stroke-width:1.4;align-self:start;
  transition:color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.leistung__ico .opacity{opacity:.35}
.leistung h3{font-size:var(--fs-h3);font-weight:500;letter-spacing:-.01em;color:var(--text-strong);
  transition:color var(--dur) var(--ease)}
.leistung p{color:var(--text-muted);margin-top:.35rem;max-width:54ch;font-size:.98rem}
.leistung__marker{position:absolute;left:-1px;top:1.6rem;width:0;height:calc(100% - 3.2rem);min-height:34px;
  background:var(--accent);transition:width var(--dur) var(--ease)}
.leistung.is-active .leistung__no{color:var(--accent)}
.leistung.is-active .leistung__ico{color:var(--brand-navy);transform:scale(1.05)}
.leistung.is-active h3{color:var(--text-strong)}
.leistung.is-active{padding-left:1.6rem}
.leistung.is-active .leistung__marker{width:3px}
.leistung:hover .leistung__ico{color:var(--brand-navy)}
.leistung:hover h3{color:var(--brand-navy)}

/* ============================================================
   ZIELGRUPPEN
   ============================================================ */
.zielgruppen__head{margin-bottom:3rem}
.zg-split{display:grid;grid-template-columns:repeat(3,1fr)}
.zg{padding:2.6rem 2.2rem 2.4rem;border-left:1px solid var(--line-light);position:relative;
  transition:background var(--dur) var(--ease)}
.zg:first-child{border-left:none;padding-left:0}
.zg-split{border-top:1px solid var(--line-light);border-bottom:1px solid var(--line-light)}
.zg__no{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;
  border:1px solid var(--line-strong);border-radius:50%;color:var(--accent);font-size:.7rem;margin-bottom:1.6rem}
.zg h3{font-size:var(--fs-h3);font-weight:500;letter-spacing:-.01em;margin-bottom:.9rem}
.zg p{color:var(--text-muted);margin-bottom:1.6rem;line-height:1.55}
.zg:hover{background:var(--surface-raised)}
.zg:first-child:hover{background:transparent}
@media(hover:hover){.zg:first-child{margin-left:0}.zg:first-child:hover{background:var(--surface-raised);margin-inline:-1.4rem;padding-inline:1.4rem;border-radius:var(--radius)}}

/* ============================================================
   REFERENZEN
   ============================================================ */
.referenzen__head{margin-bottom:3.5rem}
.ref-list{display:flex;flex-direction:column;gap:clamp(2.5rem,5vw,4.5rem)}
.ref{display:grid;grid-template-columns:1.45fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
  padding-top:clamp(2.5rem,5vw,4.5rem);border-top:1px solid var(--navy-700)}
.ref:first-child{border-top:none;padding-top:0}
.ref--reverse .ref__media{order:2}
.ref__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--navy-800);
  border:1px solid var(--navy-700)}
.ref__media img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform 1.2s var(--ease);
  filter:saturate(.92) contrast(1.03)}
.ref:hover .ref__media img{transform:scale(1.04)}
.ref__index{position:absolute;top:1rem;left:1rem;color:#fff;background:rgba(12,22,38,.6);
  backdrop-filter:blur(6px);padding:.4rem .7rem;border-radius:3px;letter-spacing:.12em;
  border:1px solid rgba(255,255,255,.15)}
.ref__data h3{font-size:var(--fs-h3);font-weight:600;letter-spacing:-.015em;margin-bottom:1.6rem;color:#fff}
.ref__sheet{display:flex;flex-direction:column;gap:0}
.ref__sheet>div{display:grid;grid-template-columns:9rem 1fr;gap:1rem;padding:.85rem 0;
  border-top:1px solid var(--navy-700)}
.ref__sheet>div:last-child{border-bottom:1px solid var(--navy-700)}
.ref__sheet dt{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--navy-300);padding-top:.15rem;margin:0}
.ref__sheet dd{margin:0;color:var(--text-on-dark);font-size:1rem}

/* ============================================================
   WARUM / USP
   ============================================================ */
.warum__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.warum__media{position:relative;margin-top:2.5rem;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line-light)}
.warum__media img{width:100%;aspect-ratio:4/5;object-fit:cover}
.warum__media-tag{position:absolute;left:1rem;bottom:1rem;color:#fff;background:rgba(16,32,58,.78);
  backdrop-filter:blur(6px);padding:.45rem .8rem;border-radius:3px;letter-spacing:.12em;font-size:.6rem}
.usp-list{display:flex;flex-direction:column;gap:0;padding-top:.5rem}
.usp{padding:2rem 0;border-top:1px solid var(--line-light);display:grid;
  grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:1.6rem;row-gap:.6rem;align-items:start}
.usp:last-child{border-bottom:1px solid var(--line-light)}
.usp__no{grid-row:1 / span 2;grid-column:1;font-size:.7rem;color:var(--accent);
  border:1px solid var(--line-strong);border-radius:50%;
  width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;margin-top:.15rem}
.usp h3{grid-column:2;grid-row:1}
.usp p{grid-column:2;grid-row:2}
.usp h3{font-size:var(--fs-h3);font-weight:500;letter-spacing:-.01em;margin-bottom:.6rem}
.usp p{color:var(--text-muted);line-height:1.6}

/* ============================================================
   ABLAUF
   ============================================================ */
.ablauf__head{margin-bottom:3.5rem}
.ablauf__steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative}
.ablauf__steps::before{content:"";position:absolute;top:18px;left:12.5%;right:12.5%;height:1px;
  background:var(--navy-700);z-index:0}
.step{position:relative;z-index:1;padding-top:0;display:flex;flex-direction:column;gap:.8rem}
.step__no{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;
  background:var(--navy-950);border:1px solid var(--navy-600);color:var(--accent-soft);font-size:.72rem;margin-bottom:.6rem}
.step__ico{width:26px;height:26px;color:var(--navy-200);stroke-width:1.5}
.step h3{font-size:var(--fs-h4);font-weight:600;color:#fff}
.step p{color:var(--text-on-dark-mut);font-size:.95rem;line-height:1.55}

/* ============================================================
   KONTAKT
   ============================================================ */
.kontakt__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2.5rem,5vw,5rem);align-items:start;
  margin-bottom:clamp(2.5rem,5vw,4rem)}
.kontakt__nap{display:flex;flex-direction:column;gap:1.4rem;margin-top:2.5rem}
.kontakt__nap li{display:flex;gap:1rem;align-items:flex-start}
.kontakt__nap .ico{width:1.4em;height:1.4em;color:var(--accent);margin-top:.2rem}
.kontakt__nap .mono{display:block;color:var(--text-muted);margin-bottom:.25rem;font-size:.64rem}
.kontakt__nap a{display:inline-flex;align-items:center;min-height:40px}
.kontakt__nap a:hover{color:var(--accent)}
.kontakt__locations{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:2rem}
.loc-chip{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--line-strong);
  border-radius:100px;padding:.5rem .9rem;font-size:.85rem;color:var(--text-body)}
.loc-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}

.kontakt__panel{background:var(--white);border:1px solid var(--line-light);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-md)}
.form{display:flex;flex-direction:column;gap:1.1rem}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}
.field label span{color:var(--accent)}
.field input,.field textarea,.select-wrap select{font-family:var(--font-body);font-size:1rem;color:var(--text-strong);
  background:var(--off-white);border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:.85rem .95rem;transition:border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease)}
.field input::placeholder,.field textarea::placeholder{color:var(--text-faint)}
.field input:focus,.field textarea:focus,.select-wrap select:focus{outline:none;border-color:var(--brand-navy);background:#fff}
.field textarea{resize:vertical;min-height:110px;line-height:1.55}
.field.is-invalid input,.field.is-invalid textarea{border-color:var(--accent)}
.field__err{color:var(--accent);font-size:.8rem;min-height:0;display:none}
.field.is-invalid .field__err{display:block}
.select-wrap{position:relative;display:flex}
.select-wrap select{appearance:none;width:100%;cursor:pointer}
.select-wrap .ico{position:absolute;right:1rem;top:50%;transform:translateY(-50%) rotate(90deg);
  width:1.05em;height:1.05em;color:var(--text-muted);pointer-events:none}
.check{display:flex;gap:.7rem;align-items:flex-start;font-size:.85rem;color:var(--text-muted);line-height:1.5;cursor:pointer}
.check input{width:18px;height:18px;margin-top:2px;accent-color:var(--brand-navy);flex:none}
.check a{color:var(--brand-navy);text-decoration:underline;text-underline-offset:2px}
.form__success{display:flex;align-items:center;gap:.6rem;color:var(--brand-navy);font-size:.95rem;
  background:rgba(36,67,113,.06);border:1px solid var(--line-light);padding:.9rem 1rem;border-radius:var(--radius)}
.form__success[hidden]{display:none}
.form__success .ico{color:var(--accent);width:1.3em;height:1.3em}
.form__success .mono{color:var(--text-faint);font-size:.6rem}

/* map */
.mapcard{position:relative;height:clamp(220px,32vw,360px);border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line-light);background:
  radial-gradient(110% 90% at 70% 20%,#e8eef6,transparent 60%),var(--surface-sunken)}
.mapcard__grid{position:absolute;inset:0;opacity:.7;
  background-image:linear-gradient(var(--line-light) 1px,transparent 1px),
                   linear-gradient(90deg,var(--line-light) 1px,transparent 1px);background-size:38px 38px}
.mapcard__grid::after{content:"";position:absolute;left:18%;top:0;bottom:0;width:46%;
  background:linear-gradient(90deg,transparent,rgba(36,67,113,.07),transparent);transform:skewX(-18deg)}
.mapcard__load{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;
  align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:1.1rem 1.5rem;font-family:var(--font-display);font-weight:500;color:var(--text-strong);
  box-shadow:var(--shadow-md);transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}
.mapcard__load .ico{color:var(--accent);width:1.4em;height:1.4em}
.mapcard__load em{font-style:normal;color:var(--text-faint);font-size:.58rem}
.mapcard__load:hover{transform:translate(-50%,-50%) translateY(-2px);box-shadow:var(--shadow-lg)}
.mapcard__pin{position:absolute;left:42%;top:38%;color:var(--accent);animation:pinpulse 2.6s var(--ease) infinite}
.mapcard__pin .ico{width:28px;height:28px;fill:var(--accent);stroke:#fff;stroke-width:1.4}
@keyframes pinpulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@media (prefers-reduced-motion:reduce){.mapcard__pin{animation:none}}
.mapcard iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{padding-top:clamp(3.5rem,6vw,5.5rem);padding-bottom:2rem}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:2.5rem;
  padding-bottom:3rem;border-bottom:1px solid var(--navy-800)}
.nav__brand--footer img{width:44px;height:44px}
.nav__brand--footer .nav__brand-text{color:#fff}
.footer__claim{color:var(--text-on-dark-mut);font-size:.92rem;margin-top:1.3rem;line-height:1.55;max-width:34ch}
.footer__col{display:flex;flex-direction:column;gap:.7rem}
.footer__h{color:var(--navy-300);margin-bottom:.4rem}
.footer__col a{color:var(--text-on-dark-mut);font-size:.95rem;transition:color var(--dur-fast) var(--ease);width:fit-content}
.footer__col a:hover{color:#fff}
.footer__contact p{color:var(--text-on-dark-mut);font-size:.95rem;line-height:1.6}
.footer__tel{font-family:var(--font-display);font-weight:600;color:#fff!important;font-size:1.1rem;margin-top:.3rem}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  padding-top:1.8rem;font-size:.82rem;color:var(--text-on-dark-faint)}
.footer__legal{display:flex;gap:1.5rem}
.footer__legal a:hover{color:#fff}
.footer__sig{color:var(--navy-600);letter-spacing:.2em}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px){
  .schicht{grid-template-columns:1fr;gap:2.5rem}
  .schicht__stage{display:none}
  .warum__grid{grid-template-columns:1fr;gap:2.5rem}
  .warum__media{max-width:440px;margin-top:1.5rem}
  .kontakt__grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr;gap:2rem}
  .footer__brand{grid-column:1/-1}
}
@media (max-width:1024px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex;align-items:center;padding:14px 8px;margin-right:-8px}
  .nav.is-open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.is-open .nav__burger span:nth-child(2){opacity:0}
  .nav.is-open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media (max-width:900px){
  .trust__grid{grid-template-columns:1fr 1fr}
  .ref{grid-template-columns:1fr;gap:1.5rem}
  .ref--reverse .ref__media{order:0}
  .ablauf__steps{grid-template-columns:1fr 1fr;gap:2rem}
  .ablauf__steps::before{display:none}
  .zg-split{grid-template-columns:1fr}
  .zg{border-left:none;border-top:1px solid var(--line-light);padding:2rem 0}
  .zg:first-child{border-top:none;padding-top:0}
  @media(hover:hover){.zg:hover,.zg:first-child:hover{background:transparent;margin-inline:0;padding-inline:0}}
}
@media (max-width:560px){
  .hero{padding-inline:var(--gutter)}
  .hero__foot{flex-wrap:wrap;gap:1.2rem}
  .hero__scrolltip{display:none}
  /* full-width text on mobile -> vertically weighted scrim for legibility */
  .hero__scrim{background:
    linear-gradient(180deg,rgba(8,22,40,.64) 0%,rgba(8,22,40,.32) 34%,rgba(8,22,40,.48) 60%,rgba(8,22,40,.95) 100%),
    linear-gradient(90deg,rgba(10,37,64,.55) 0%,rgba(10,37,64,.12) 100%)}
  .hero__actions .btn{flex:1;justify-content:center}
  .trust__grid{grid-template-columns:1fr 1fr}
  .stat{padding:1.6rem 1.2rem}
  .form__row{grid-template-columns:1fr}
  .ablauf__steps{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .leistung{grid-template-columns:auto 1fr;gap:1rem}
  .leistung__ico{display:none}
  /* Nav-Marke kompakt: Mono-Caption ausblenden, Navbar niedrig halten */
  .nav__brand-text em{display:none}
  /* Body-Text >=16px auf Mobil + komfortablere Tap-Targets */
  .leistung p,.step p,.footer__col a,.footer__contact p{font-size:1rem}
  .loc-chip{padding:.6rem 1rem}
  .textlink{padding-block:.5rem 8px}
}

/* Schmale Phones: Hero-CTAs vertikal stapeln, je 100% Breite, große Tap-Targets */
@media (max-width:520px){
  .hero__actions{flex-direction:column;align-items:stretch;gap:.75rem;width:100%}
  .hero__actions .btn{flex:0 0 auto;width:100%;justify-content:center;padding-block:1.05rem}
}
