/* =========================================================
   Erd-& Baggerarbeiten Funk â€“ Stylesheet
   Industriell Â· modern Â· bodenstÃ¤ndig Â· Schwarz/WeiÃŸ/Blau
   ========================================================= */

:root{
  --ink:        #121216;   /* Fast-Schwarz */
  --ink-2:      #1c1d26;
  --navy:       #171a52;   /* Markenblau dunkel fÃ¼r dunkle FlÃ¤chen */
  --blue:       #2d2e9f;   /* PrimÃ¤r-Blau aus dem Logo */
  --blue-600:   #262889;
  --blue-700:   #1f216e;
  --blue-tint:  #ececff;
  --white:      #ffffff;
  --paper:      #f5f6f8;   /* Heller Hintergrund */
  --paper-2:    #eff0f6;
  --line:       #dde0eb;
  --muted:      #5a6573;
  --text:       #18222e;

  --maxw: 1180px;
  --radius: 4px;
  --shadow: 0 18px 50px -22px rgba(31,33,110,.28);
  --shadow-sm: 0 8px 24px -14px rgba(31,33,110,.24);

  --font-head: "Barlow Condensed", "Arial Narrow", Arial, sans-serif;
  --font-body: "Barlow", "Segoe UI", Arial, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--white); color:var(--text);
  font-family:var(--font-body); font-size:18px; line-height:1.65;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:var(--blue-700); text-decoration:none; }
a:hover{ text-decoration:underline; }

h1,h2,h3,h4{
  font-family:var(--font-head); font-weight:700;
  line-height:1.02; letter-spacing:.01em; text-transform:uppercase;
  color:var(--ink); margin:0 0 .4em;
}
h1{ font-size:clamp(2.6rem,6vw,4.6rem); }
h2{ font-size:clamp(2rem,4vw,3rem); }
h3{ font-size:clamp(1.35rem,2.3vw,1.7rem); letter-spacing:.02em; }
p{ margin:0 0 1rem; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:20px; }
.section{ position:relative; z-index:1; padding:clamp(56px,8vw,108px) 0; }
.section--paper{ background:var(--paper); }
.section--ink{ background:var(--ink); color:#cfd6df; }
.section--ink h2,.section--ink h3{ color:#fff; }

.eyebrow{
  font-family:var(--font-head); text-transform:uppercase; letter-spacing:.22em;
  font-weight:600; font-size:.95rem; color:var(--blue);
  display:inline-flex; align-items:center; gap:.6rem; margin-bottom:.7rem;
}
.eyebrow::before{ content:""; width:34px; height:2px; background:var(--blue); display:inline-block; }
.lead{ font-size:1.15rem; color:var(--muted); max-width:62ch; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--blue); --fg:#fff;
  display:inline-flex; align-items:center; gap:.55rem;
  background:var(--bg); color:var(--fg);
  font-family:var(--font-head); font-weight:600; text-transform:uppercase;
  letter-spacing:.06em; font-size:1.05rem;
  padding:.85rem 1.5rem; border:2px solid var(--bg); border-radius:var(--radius);
  cursor:pointer; transition:.18s ease; text-decoration:none; line-height:1;
}
.btn svg{ width:1.15em; height:1.15em; }
.btn:hover{ transform:translateY(-2px); text-decoration:none; box-shadow:var(--shadow-sm); }
.btn--blue{ --bg:var(--blue); }
.btn--blue:hover{ --bg:var(--blue-700); border-color:var(--blue-700); }
.btn--wa{ --bg:#1faa55; border-color:#1faa55; }
.btn--wa:hover{ --bg:#178c45; border-color:#178c45; }
.btn--dark{ --bg:var(--ink); border-color:var(--ink); }
.btn--dark:hover{ --bg:#000; border-color:#000; }
.btn--ghost{ --bg:transparent; --fg:#fff; border-color:rgba(255,255,255,.55); }
.btn--ghost:hover{ --bg:#fff; --fg:var(--ink); border-color:#fff; }
.btn--outline{ --bg:transparent; --fg:var(--ink); border-color:var(--ink); }
.btn--outline:hover{ --bg:var(--ink); --fg:#fff; }
.btn--lg{ font-size:1.15rem; padding:1rem 1.7rem; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:50; background:rgba(255,255,255,.96);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; gap:1rem; min-height:82px; position:relative; }
.nav-collapse{ display:flex; align-items:center; gap:1.4rem; margin-left:auto; }
.brand{ display:flex; align-items:center; gap:.7rem; text-decoration:none; }
.brand:hover{ text-decoration:none; }
.brand__mark{
  width:56px; height:56px; flex:none; border-radius:50%;
  background:#fff; display:grid; place-items:center; color:#fff;
  border:2px solid rgba(45,46,159,.14); box-shadow:0 8px 22px -16px rgba(31,33,110,.35);
  overflow:hidden;
}
.brand__mark svg{ width:26px; height:26px; }
.brand__logo{ width:100%; height:100%; object-fit:cover; display:block; }
.brand__name{ font-family:var(--font-head); text-transform:uppercase; line-height:1; }
.brand__name b{ display:block; font-weight:700; font-size:1.15rem; color:var(--ink); letter-spacing:.02em; }
.brand__name span{ font-size:.78rem; letter-spacing:.14em; color:var(--blue); font-weight:600; }

.nav-links{ display:flex; align-items:center; gap:.35rem; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em;
  font-weight:600; font-size:1.02rem; color:var(--ink);
  padding:.5rem .7rem; border-radius:var(--radius); transition:.15s;
}
.nav-links a:hover{ color:var(--blue); text-decoration:none; background:var(--blue-tint); }
.nav-links a[aria-current="page"]{ color:var(--blue); }
.nav-cta{ display:flex; align-items:center; gap:.5rem; }
.nav-cta .btn{ padding:.6rem 1rem; font-size:.95rem; }

.burger{
  display:none; width:46px; height:46px; border:1px solid var(--line);
  background:#fff; border-radius:var(--radius); cursor:pointer; padding:0;
  align-items:center; justify-content:center;
}
.burger span,.burger span::before,.burger span::after{
  content:""; display:block; width:22px; height:2px; background:var(--ink); position:relative; transition:.2s;
}
.burger span::before{ position:absolute; top:-7px; }
.burger span::after{ position:absolute; top:7px; }
.nav-open .burger span{ background:transparent; }
.nav-open .burger span::before{ transform:rotate(45deg); top:0; }
.nav-open .burger span::after{ transform:rotate(-45deg); top:0; }

/* ---------- Hero ---------- */
.hero{ position:relative; color:#fff; isolation:isolate; min-height:680px; overflow:hidden; display:flex; align-items:center; }
.hero__media{
  position:absolute; inset:0; z-index:-2;
  background:
    linear-gradient(180deg, rgba(8,16,26,.55) 0%, rgba(8,16,26,.78) 70%, rgba(8,16,26,.92) 100%),
    /* Wird durch eigenes Foto/Video ersetzt â€“ bis dahin Blueprint-Optik: */
    radial-gradient(120% 90% at 80% 10%, #2a327d 0%, #10143e 45%, #07111f 100%);
  background-size:cover; background-position:center;
}
.hero__media video,.hero__media img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-1; opacity:.92;
}
.hero__media .ph{
  position:absolute; inset:0; z-index:-1; display:grid; place-items:center;
  background:
    linear-gradient(180deg, rgba(8,16,26,.58), rgba(8,16,26,.92)),
    radial-gradient(120% 90% at 80% 10%, #2a327d 0%, #10143e 45%, #07111f 100%);
  color:#c0c3ff; font-family:var(--font-head); text-transform:uppercase;
  letter-spacing:.12em; text-align:center; padding:24px;
}
.hero__media .ph svg{ width:56px; height:56px; opacity:.35; margin-bottom:.7rem; }
.hero__grid{
  position:absolute; inset:0; z-index:-1; opacity:.16; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.5) 1px, transparent 1px);
  background-size:46px 46px;
  mask-image:linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
}
.hero__inner{ width:100%; padding:clamp(72px,12vw,150px) 0 clamp(56px,8vw,110px); position:relative; z-index:2; }
.hero__tag{
  display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-head);
  text-transform:uppercase; letter-spacing:.16em; font-weight:600; font-size:.95rem;
  background:rgba(45,46,159,.22); border:1px solid rgba(110,112,220,.46);
  color:#dbe8fb; padding:.45rem .9rem; border-radius:40px; margin-bottom:1.3rem;
}
.hero h1{ color:#fff; max-width:16ch; text-shadow:0 4px 30px rgba(0,0,0,.35); }
.hero h1 em{ color:#9ea1ff; font-style:normal; }
.hero__sub{ font-size:clamp(1.1rem,2vw,1.45rem); color:#dfe6ef; max-width:54ch; margin:.4rem 0 1.8rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.8rem; }
.hero__pills{ display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; margin-top:2.2rem; }
.hero__pills span{
  display:inline-flex; align-items:center; gap:.5rem; font-weight:600;
  font-size:.98rem; color:#cdd8e6;
}
.hero__pills svg{ width:18px; height:18px; color:#9ea1ff; flex:none; }

/* Quick-Kontaktleiste unter Hero */
.quickbar{ position:relative; z-index:3; background:var(--blue); color:#fff; }
.quickbar__row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1rem; padding:16px 0; }
.quickbar strong{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em; font-size:1.25rem; }
.quickbar__links{ display:flex; flex-wrap:wrap; gap:.6rem; }
.quickbar a{ color:#fff; }

/* ---------- Karten / Leistungen ---------- */
.grid{ display:grid; gap:22px; }
.grid--3{ grid-template-columns:repeat(3,1fr); }
.grid--4{ grid-template-columns:repeat(4,1fr); }
.grid--2{ grid-template-columns:repeat(2,1fr); }

.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:30px 26px; transition:.2s; position:relative; overflow:hidden;
}
.card::after{ content:""; position:absolute; left:0; top:0; height:100%; width:4px; background:var(--blue); transform:scaleY(0); transform-origin:top; transition:.25s; }
.card:hover{ box-shadow:var(--shadow); transform:translateY(-4px); }
.card:hover::after{ transform:scaleY(1); }
.card__icon{
  width:54px; height:54px; border-radius:8px; background:var(--blue-tint);
  color:var(--blue-700); display:grid; place-items:center; margin-bottom:1rem;
}
.card__icon svg{ width:30px; height:30px; }
.card h3{ margin-bottom:.4rem; }
.card p{ color:var(--muted); margin:0; font-size:1rem; }
.card--feature{ background:var(--navy); border-color:var(--navy); color:#cdd8e6; }
.card--feature h3{ color:#fff; }
.card--feature .card__icon{ background:rgba(118,179,255,.16); color:#c0c3ff; }
.card--feature::after{ background:#9ea1ff; }

/* Leistungs-Liste (kompakt) */
.svc-list{ columns:2; column-gap:48px; list-style:none; padding:0; margin:0; }
.svc-list li{ break-inside:avoid; padding:.55rem 0 .55rem 1.9rem; position:relative; border-bottom:1px solid var(--line); }
.svc-list li::before{
  content:""; position:absolute; left:0; top:1.05rem; width:12px; height:12px;
  background:var(--blue); clip-path:polygon(0 0,100% 50%,0 100%);
}
@media(max-width:680px){ .svc-list{ columns:1; } }

/* Split-Bereich Bild + Text */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(28px,5vw,64px); align-items:center; }
.split--rev .split__media{ order:2; }
.media-frame{
  position:relative; border-radius:var(--radius); overflow:hidden;
  background:linear-gradient(135deg,#2a327d,#0a1f38); min-height:340px;
  border:1px solid var(--line); box-shadow:var(--shadow);
}
.media-frame img{ width:100%; height:100%; object-fit:cover; min-height:340px; }
.media-frame .ph{
  position:absolute; inset:0; display:grid; place-items:center; color:#c0c3ff;
  font-family:var(--font-head); letter-spacing:.1em; text-transform:uppercase; text-align:center; padding:24px;
}
.media-frame .ph svg{ width:54px; height:54px; opacity:.7; margin-bottom:.6rem; }
.badge-stat{
  position:absolute; right:18px; bottom:18px; background:#fff; color:var(--ink);
  border-radius:var(--radius); padding:12px 16px; box-shadow:var(--shadow-sm);
}
.badge-stat b{ font-family:var(--font-head); font-size:1.6rem; display:block; line-height:1; color:var(--blue-700); }
.badge-stat span{ font-size:.85rem; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; }

/* ---------- Vertrauens-/Vorteilsband ---------- */
.usp{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.usp__item{ padding:26px 24px; border-right:1px solid var(--line); }
.usp__item:last-child{ border-right:0; }
.usp__item svg{ width:30px; height:30px; color:var(--blue); margin-bottom:.6rem; }
.usp__item b{ font-family:var(--font-head); text-transform:uppercase; font-size:1.2rem; color:var(--ink); display:block; }
.usp__item span{ color:var(--muted); font-size:.98rem; }

/* ---------- Maschinen ---------- */
.machine{ display:flex; gap:1rem; align-items:flex-start; padding:20px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); }
.machine svg{ width:40px; height:40px; color:var(--blue); flex:none; }
.machine b{ font-family:var(--font-head); text-transform:uppercase; font-size:1.2rem; color:var(--ink); display:block; line-height:1.1; }
.machine span{ color:var(--muted); font-size:.96rem; }

/* ---------- Galerie ---------- */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gallery__item{
  position:relative; aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden;
  background:linear-gradient(135deg,#2a327d,#0a1f38); border:1px solid var(--line);
}
.gallery__item.tall{ grid-row:span 2; aspect-ratio:auto; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:.4s; }
.gallery__item:hover img{ transform:scale(1.06); }
.gallery__item .ph{ position:absolute; inset:0; display:grid; place-items:center; color:#c0c3ff; gap:.4rem; text-align:center; padding:16px; }
.gallery__item .ph svg{ width:38px; height:38px; opacity:.7; }
.gallery__item .cap{
  position:absolute; left:0; bottom:0; width:100%; padding:14px 16px;
  background:linear-gradient(transparent,rgba(8,16,26,.85)); color:#fff;
  font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em; font-size:1.05rem;
}
@media(max-width:780px){ .gallery{ grid-template-columns:repeat(2,1fr);} .gallery__item.tall{ grid-row:span 1; aspect-ratio:4/3;} }

/* ---------- Ãœber uns ---------- */
.timeline{ list-style:none; margin:1.5rem 0 0; padding:0; }
.timeline li{ position:relative; padding:0 0 1.6rem 2rem; border-left:2px solid var(--line); }
.timeline li:last-child{ border-left-color:transparent; padding-bottom:0; }
.timeline li::before{ content:""; position:absolute; left:-9px; top:2px; width:16px; height:16px; border-radius:50%; background:var(--blue); border:3px solid #fff; box-shadow:0 0 0 1px var(--line); }
.timeline b{ font-family:var(--font-head); text-transform:uppercase; color:var(--blue-700); font-size:1.2rem; }

/* ---------- Kontakt / Formular ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(28px,5vw,56px); }
.contact-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px; }
.contact-line{ display:flex; gap:.9rem; align-items:flex-start; padding:14px 0; border-bottom:1px solid var(--line); }
.contact-line:last-child{ border-bottom:0; }
.contact-line svg{ width:24px; height:24px; color:var(--blue); flex:none; margin-top:3px; }
.contact-line b{ display:block; font-family:var(--font-head); text-transform:uppercase; font-size:1.05rem; color:var(--ink); letter-spacing:.04em; }
.contact-line a{ color:var(--text); }

.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:.35rem; }
.field--full{ grid-column:1 / -1; }
.field label{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em; font-size:.95rem; color:var(--ink); font-weight:600; }
.field label .req{ color:var(--blue); }
.field input,.field select,.field textarea{
  font-family:var(--font-body); font-size:1rem; padding:.8rem .9rem;
  border:1px solid var(--line); border-radius:var(--radius); background:#fff; color:var(--text); width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px var(--blue-tint); }
.field textarea{ min-height:130px; resize:vertical; }
.field input[type=file]{ padding:.55rem; background:var(--paper); }
.form-hint{ font-size:.88rem; color:var(--muted); }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.consent{ display:flex; gap:.6rem; align-items:flex-start; font-size:.95rem; color:var(--muted); }
.consent input{ width:auto; margin-top:.35rem; }

.alert{ padding:14px 18px; border-radius:var(--radius); margin-bottom:18px; border-left:4px solid; font-size:1rem; }
.alert--ok{ background:#eaf7ee; border-color:#1faa55; color:#155e35; }
.alert--err{ background:#fdecec; border-color:#d33; color:#922; }

/* ---------- Karte / DSGVO Consent ---------- */
.map-wrap{ position:relative; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; min-height:360px; background:var(--paper-2); }
.map-wrap iframe{ width:100%; height:100%; min-height:360px; border:0; display:block; }
.map-consent{ position:absolute; inset:0; display:grid; place-items:center; text-align:center; padding:30px; background:linear-gradient(135deg,#171a52,#10143e); color:#cdd8e6; }
.map-consent svg{ width:46px; height:46px; color:#9ea1ff; margin-bottom:.6rem; }
.map-consent p{ max-width:46ch; margin:.4rem auto 1.2rem; }

/* ---------- GroÃŸes CTA-Band ---------- */
.cta-band{ background:linear-gradient(120deg,var(--navy),var(--ink)); color:#fff; text-align:center; }
.cta-band h2{ color:#fff; }
.cta-band p{ color:#cdd8e6; max-width:60ch; margin-inline:auto; }
.cta-band .hero__cta{ justify-content:center; margin-top:1.6rem; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:#aeb8c4; padding:64px 0 26px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; }
.site-footer h4{ color:#fff; font-size:1.25rem; margin-bottom:1rem; }
.site-footer a{ color:#aeb8c4; }
.site-footer a:hover{ color:#fff; }
.footer-links{ list-style:none; padding:0; margin:0; display:grid; gap:.5rem; }
.footer-brand .brand__name b{ color:#fff; }

.footer-brand .brand__mark{ width:68px; height:68px; border-color:rgba(255,255,255,.14); box-shadow:none; }
.footer-brand .brand__name span{ color:#b8bbff; }

.footer-bottom{ border-top:1px solid #232c38; margin-top:42px; padding-top:22px; display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; font-size:.9rem; color:#7e8896; }
.footer-bottom a{ color:#aeb8c4; }

/* ---------- Rechtstexte ---------- */
.legal{ max-width:820px; }
.legal h2{ font-size:1.5rem; margin-top:2.2rem; }
.legal h3{ font-size:1.15rem; margin-top:1.4rem; }
.legal p,.legal li{ font-size:1rem; color:var(--text); }
.legal ul{ padding-left:1.2rem; }

/* ---------- Floating Mobile-Aktionsleiste ---------- */
.mobile-bar{ display:none; }

/* ---------- Cookie-Hinweis ---------- */
.cookie{
  position:fixed; left:16px; right:16px; bottom:16px; z-index:90; max-width:560px;
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:0 20px 50px -20px rgba(0,0,0,.5); padding:20px 22px; display:none;
}
.cookie.show{ display:block; }
.cookie h4{ font-size:1.2rem; margin-bottom:.3rem; }
.cookie p{ font-size:.95rem; color:var(--muted); margin-bottom:1rem; }
.cookie__btns{ display:flex; gap:.6rem; flex-wrap:wrap; }
.cookie__btns .btn{ font-size:.95rem; padding:.6rem 1.1rem; }

/* ---------- Reveal-Animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:.6s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } html{ scroll-behavior:auto; } }

/* =========================================================
   Responsive
   ========================================================= */
@media(max-width:980px){
  .grid--4{ grid-template-columns:repeat(2,1fr); }
  .grid--3{ grid-template-columns:repeat(2,1fr); }
  .usp{ grid-template-columns:repeat(2,1fr); }
  .usp__item:nth-child(2){ border-right:0; }
  .usp__item:nth-child(1),.usp__item:nth-child(2){ border-bottom:1px solid var(--line); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media(max-width:820px){
  .nav-collapse{
    display:none; position:absolute; left:0; right:0; top:100%; margin-left:0;
    flex-direction:column; align-items:stretch; gap:0; background:#fff;
    border-bottom:1px solid var(--line); box-shadow:var(--shadow-sm); padding:8px 20px 18px;
  }
  .nav-open .nav-collapse{ display:flex; }
  .nav-links{ flex-direction:column; align-items:stretch; gap:0; width:100%; }
  .nav-links a{ padding:.9rem .4rem; border-bottom:1px solid var(--line); font-size:1.15rem; }
  .nav-cta{ flex-direction:column; align-items:stretch; gap:.6rem; margin-top:14px; }
  .nav-cta .btn{ justify-content:center; font-size:1.05rem; padding:.85rem 1rem; }
  .burger{ display:flex; margin-left:auto; }
  .brand__mark{ width:50px; height:50px; }
  .brand__name b{ font-size:1.08rem; }
  .brand__name span{ font-size:.72rem; letter-spacing:.11em; }
  .split{ grid-template-columns:1fr; }
  .split--rev .split__media{ order:0; }
  .contact-grid{ grid-template-columns:1fr; }
  .grid--3,.grid--4,.grid--2{ grid-template-columns:1fr; }
  .form-grid{ grid-template-columns:1fr; }
  /* Mobile Schnell-Kontaktleiste am unteren Rand */
  .mobile-bar{
    display:grid; grid-template-columns:1fr 1fr 1fr; position:fixed; left:0; right:0; bottom:0; z-index:80;
    background:var(--ink); border-top:1px solid #232c38;
  }
  .mobile-bar a{
    display:flex; flex-direction:column; align-items:center; gap:3px; padding:9px 4px;
    color:#fff; font-family:var(--font-head); text-transform:uppercase; font-size:.8rem; letter-spacing:.04em;
  }
  .mobile-bar a:hover{ text-decoration:none; }
  .mobile-bar a svg{ width:22px; height:22px; }
  .mobile-bar a.wa{ background:#1faa55; }
  .mobile-bar a.call{ background:var(--blue); }
  body{ padding-bottom:64px; }
  .cookie{ bottom:80px; }
}
@media(max-width:560px){
  .usp{ grid-template-columns:1fr; }
  .usp__item{ border-right:0; border-bottom:1px solid var(--line); }
  .usp__item:last-child{ border-bottom:0; }
  .quickbar__row{ justify-content:center; text-align:center; }
}

/* ---------- Automatische Medienordner / Rotationen ---------- */
.media-rotator{ position:absolute; inset:0; overflow:hidden; }
.media-rotator__item{ position:absolute; inset:0; opacity:0; transition:opacity .85s ease; }
.media-rotator__item.is-active{ opacity:1; z-index:1; }
.media-rotator img,.media-rotator video{ width:100%; height:100%; object-fit:cover; }
.hero__media .media-rotator{ z-index:-1; }
.media-frame .media-rotator{ position:absolute; inset:0; }
.media-frame .media-rotator::after,
.gallery__item::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(8,16,26,0) 45%, rgba(8,16,26,.72) 100%);
}
.media-note{
  display:grid; gap:.5rem; margin-top:1rem; padding:16px 18px;
  border-left:4px solid var(--blue); background:var(--blue-tint); color:var(--text);
}
.media-note b{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em; color:var(--ink); }
.text-cols{ columns:2; column-gap:42px; }
.text-cols p{ break-inside:avoid; }
.process{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; counter-reset:step; align-items:stretch; }
.process__item{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:28px 24px 26px; position:relative; box-shadow:var(--shadow-sm);
  overflow:visible;
}
.process__item::before{
  counter-increment:step; content:counter(step);
  width:54px; height:54px; border-radius:50%; display:grid; place-items:center;
  font-family:var(--font-head); font-size:1.85rem; line-height:1; color:#fff;
  background:var(--blue); box-shadow:0 8px 20px -12px rgba(31,33,110,.6);
  margin-bottom:1rem;
}
.process__item:not(:last-child)::after{
  content:""; position:absolute; top:50%; right:-24px; width:26px; height:2px;
  background:var(--blue); opacity:.45;
}
.process__item h3{ font-size:1.35rem; margin-bottom:.45rem; }
.process__item p{ color:var(--muted); font-size:1rem; margin:0; }
.process__kicker{
  display:block; font-family:var(--font-head); text-transform:uppercase;
  letter-spacing:.16em; color:var(--blue); font-size:.86rem; margin-bottom:.35rem;
}
.service-detail{ display:grid; grid-template-columns:.9fr 1.1fr; gap:28px; align-items:stretch; margin-top:2rem; }
.service-detail__media{ min-height:300px; }
.service-detail__content{ background:#fff; border:1px solid var(--line); padding:30px; }
.service-detail__content p{ color:var(--muted); }
@media(max-width:980px){ .process{ grid-template-columns:repeat(2,1fr); } .process__item::after{ display:none; } .service-detail{ grid-template-columns:1fr; } .text-cols{ columns:1; } }
@media(max-width:560px){ .process{ grid-template-columns:1fr; } .hero{ min-height:620px; } }

.btn--insta{ --bg:#2d2e9f; border-color:#2d2e9f; }
.btn--insta:hover{ --bg:#1f216e; border-color:#1f216e; }


/* =========================================================
   Hero-Fix: stabile Startseiten-Buehne ohne Ueberlagerungen
   ========================================================= */
.hero{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  display:flex;
  align-items:center;
  min-height:clamp(620px, calc(100svh - 82px), 820px);
  background:
    radial-gradient(90% 80% at 82% 12%, rgba(45,46,159,.42) 0%, rgba(23,26,82,.62) 42%, rgba(7,17,31,1) 100%),
    #07111f;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(7,17,31,.94) 0%, rgba(7,17,31,.82) 42%, rgba(7,17,31,.58) 68%, rgba(7,17,31,.82) 100%),
    linear-gradient(180deg, rgba(7,17,31,.2) 0%, rgba(7,17,31,.78) 100%);
}
.hero__media{
  position:absolute;
  inset:0;
  z-index:0;
  background:
    radial-gradient(90% 80% at 82% 12%, rgba(45,46,159,.46) 0%, rgba(23,26,82,.72) 42%, rgba(7,17,31,1) 100%),
    #07111f;
}
.hero__media video,
.hero__media img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  opacity:.72;
  filter:saturate(1.05) contrast(1.02);
}
.hero__media .ph{
  position:absolute;
  inset:0;
  z-index:0;
  display:grid;
  place-items:center;
  background:
    radial-gradient(80% 70% at 75% 18%, rgba(45,46,159,.42), transparent 58%),
    linear-gradient(135deg, #07111f 0%, #10143e 54%, #07111f 100%);
  color:rgba(192,195,255,.7);
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.12em;
  text-align:center;
  padding:24px;
}
.hero__grid{
  z-index:2;
  opacity:.11;
  mask-image:linear-gradient(180deg, transparent 0%, #000 22%, #000 78%, transparent 100%);
}
.hero__inner{
  position:relative;
  z-index:3;
  width:100%;
  max-width:var(--maxw);
  padding-top:clamp(84px, 11vw, 150px);
  padding-bottom:clamp(84px, 10vw, 140px);
}
.hero__sub{
  color:#eef3ff;
  text-shadow:0 2px 18px rgba(0,0,0,.28);
}
.hero__pills span{
  color:#e7ecf6;
  text-shadow:0 2px 14px rgba(0,0,0,.28);
}
.hero .btn--ghost{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.6);
}
.hero .btn--ghost:hover{
  background:#fff;
  color:var(--ink);
}
.hero__media .media-rotator,
.media-rotator{
  z-index:0;
}
.hero__media .media-rotator__item{
  z-index:0;
}
.hero__media .media-rotator__item.is-active{
  z-index:1;
}
.quickbar{
  position:relative;
  z-index:4;
  margin-top:0;
}
@media(max-width:820px){
  .hero{ min-height:auto; }
  .hero__inner{ padding-top:76px; padding-bottom:76px; }
  .hero__tag{ font-size:.82rem; letter-spacing:.11em; }
  .hero__pills{ gap:.6rem 1rem; }
}
@media(max-width:560px){
  .hero__inner{ padding-top:64px; padding-bottom:68px; }
  .hero__cta .btn{ width:100%; justify-content:center; }
}


/* ---------- Footer Social Fix: Icons niemals groÃŸ skalieren ---------- */
.site-footer svg,
.footer-social svg,
.footer-social__icon{
  width:18px !important;
  height:18px !important;
  min-width:18px !important;
  max-width:18px !important;
  min-height:18px !important;
  max-height:18px !important;
  flex:0 0 18px !important;
  display:block !important;
}
.footer-social{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem;
  margin-top:1rem;
}
.footer-social a{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  width:auto;
  max-width:max-content;
  color:#fff;
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.06em;
  line-height:1;
}
.footer-social a:hover{
  color:#fff;
  text-decoration:none;
}
.mobile-bar svg{
  width:22px !important;
  height:22px !important;
  min-width:22px !important;
  max-width:22px !important;
  flex:0 0 22px !important;
}


/* Produktiv-Fix: Footer-Icons und Logo kompakt halten */
.site-footer .brand__mark{
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  flex:0 0 46px !important;
}
.site-footer .brand__logo{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}
.footer-social,
.footer-social a{
  display:inline-flex !important;
  align-items:center !important;
}
.footer-social svg,
.footer-social__icon{
  width:18px !important;
  height:18px !important;
  min-width:18px !important;
  max-width:18px !important;
  min-height:18px !important;
  max-height:18px !important;
  flex:0 0 18px !important;
}
.site-footer .footer-social a{
  gap:.45rem !important;
  width:auto !important;
}


/* =========================================================
   Responsive Medien-Slider und Medienraster
   - Standard: Hochformat/Handyformat
   - JS erkennt Querformat und setzt passende Klasse
   ========================================================= */
.media-slider{
  position:relative;
  width:100%;
  overflow:hidden;
}
.media-slider__viewport{
  overflow-x:auto;
  overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  border-radius:inherit;
}
.media-slider__viewport::-webkit-scrollbar{ display:none; }
.media-slider__track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(220px, 32%);
  gap:14px;
  align-items:stretch;
}
.media-slide,
.media-grid__item,
.media-placeholder{
  position:relative;
  margin:0;
  overflow:hidden;
  border-radius:16px;
  background:linear-gradient(135deg,#071827,#172152);
  border:1px solid rgba(255,255,255,.12);
  aspect-ratio:9/16;
  min-height:320px;
  scroll-snap-align:start;
  box-shadow:var(--shadow-sm);
}
.media-smart img,
.media-smart video,
.media-slide img,
.media-slide video,
.media-grid__item img,
.media-grid__item video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.media-smart.is-landscape{
  aspect-ratio:4/3;
}
.media-smart.is-wide{
  aspect-ratio:16/10;
}
.media-smart.is-portrait{
  aspect-ratio:9/16;
}
.media-placeholder{
  display:grid;
  place-items:center;
  padding:1.25rem;
  text-align:center;
  color:#dfe7f4;
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.06em;
}
.media-placeholder span{
  max-width:18ch;
}
.media-slider__btn{
  position:absolute;
  top:50%;
  z-index:4;
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,.95);
  color:var(--blue-700);
  box-shadow:0 14px 36px -20px rgba(0,0,0,.65);
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
}
.media-slider__btn:hover{ background:#fff; }
.media-slider__btn--prev{ left:10px; }
.media-slider__btn--next{ right:10px; }
.media-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.media-grid--projects .media-grid__item:first-child,
.media-grid--projects .media-grid__item:nth-child(4){
  grid-column:span 2;
}
.media-grid--projects .media-grid__item:first-child{
  aspect-ratio:4/3;
}
.media-section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:1rem;
  flex-wrap:wrap;
  margin-bottom:1.4rem;
}
.media-section-head > div{ max-width:68ch; }

/* Einbindung in bestehende Start- und Leistungsseite */
.home-about__media,
.service-row__media{
  min-height:auto !important;
  background:transparent !important;
  box-shadow:none !important;
  overflow:visible !important;
}
.home-about__media .media-slider__track,
.service-row__media .media-slider__track{
  grid-auto-columns:minmax(210px, 48%);
}
.home-about__media .media-slide,
.service-row__media .media-slide{
  min-height:390px;
  box-shadow:var(--shadow);
}
.home-projects .media-grid__item{
  border-color:rgba(255,255,255,.14);
}
.home-projects .media-grid__item::after,
.home-projects .media-slide::after,
.service-row__media .media-slide::after,
.home-about__media .media-slide::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,transparent 62%,rgba(0,0,0,.45));
}
.service-tile__media .media-slider__btn,
.home-hero__bg .media-slider__btn{ display:none; }

@media(max-width:980px){
  .media-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .media-slider__track{ grid-auto-columns:minmax(210px, 44%); }
  .home-about__media .media-slider__track,
  .service-row__media .media-slider__track{ grid-auto-columns:minmax(210px, 55%); }
}
@media(max-width:640px){
  .media-grid{ grid-template-columns:1fr 1fr; gap:10px; }
  .media-grid--projects .media-grid__item:first-child,
  .media-grid--projects .media-grid__item:nth-child(4){ grid-column:auto; }
  .media-slider__track{ grid-auto-columns:minmax(180px, 78%); gap:10px; }
  .home-about__media .media-slider__track,
  .service-row__media .media-slider__track{ grid-auto-columns:minmax(190px, 82%); }
  .media-slide,.media-grid__item,.media-placeholder{ min-height:260px; border-radius:12px; }
  .home-about__media .media-slide,
  .service-row__media .media-slide{ min-height:310px; }
  .media-slider__btn{ width:36px; height:36px; font-size:1.6rem; }
}

/* =========================================================
   MOBILE MASTER PATCH
   Robuste Optimierung fuer Mobile, Hochformat-Medien,
   horizontale Slider, volle Viewport-Breite und stabile Navigation.
   ========================================================= */

:root{
  --header-h:72px;
  --mobile-bar-h:58px;
  --safe-top:env(safe-area-inset-top, 0px);
  --safe-right:env(safe-area-inset-right, 0px);
  --safe-bottom:env(safe-area-inset-bottom, 0px);
  --safe-left:env(safe-area-inset-left, 0px);
  --page-pad:clamp(14px,4vw,20px);
}

html{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  scroll-padding-top:calc(var(--header-h) + 16px);
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
body{
  width:100%;
  max-width:100%;
  min-width:0;
  min-height:100vh;
  min-height:100svh;
  margin:0;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
}
@supports (min-height:100dvh){
  body{ min-height:100dvh; }
}

*,*::before,*::after{ box-sizing:border-box; }
img,picture,video,canvas,iframe,svg{ max-width:100%; }
img,picture,video,canvas{ display:block; }
iframe{ border:0; }
svg{ flex-shrink:0; }

body,
main,
section,
.site-header,
.site-footer,
.clean-footer,
.footer-main,
.footer-cta,
.start-page,
.services-page,
.contact-page{
  width:100%;
  max-width:100%;
}
main,
section,
.site-footer,
.clean-footer,
.footer-main,
.footer-cta,
.start-page,
.services-page,
.contact-page{
  overflow-x:clip;
}
@supports not (overflow:clip){
  main,
  section,
  .site-footer,
  .clean-footer,
  .footer-main,
  .footer-cta,
  .start-page,
  .services-page,
  .contact-page{ overflow-x:hidden; }
}

.container{
  width:100% !important;
  max-width:var(--maxw) !important;
  margin-inline:auto !important;
  padding-left:max(var(--page-pad), var(--safe-left)) !important;
  padding-right:max(var(--page-pad), var(--safe-right)) !important;
}

.grid,
.grid--2,
.grid--3,
.grid--4,
.split,
.footer-grid,
.contact-grid,
.gallery,
.usp,
.process,
.service-detail,
.service-row__grid,
.service-row__layout,
.service-overview__grid,
.services-head__grid,
.services-card-grid,
.service-block__layout,
.process-grid,
.home-hero__inner,
.home-hero__layout,
.home-about__grid,
.home-proof-grid,
.home-service-grid,
.home-services__grid{
  min-width:0;
}
.grid > *,
.grid--2 > *,
.grid--3 > *,
.grid--4 > *,
.split > *,
.footer-grid > *,
.contact-grid > *,
.gallery > *,
.usp > *,
.process > *,
.service-detail > *,
.service-row__grid > *,
.service-row__layout > *,
.service-overview__grid > *,
.services-head__grid > *,
.services-card-grid > *,
.service-block__layout > *,
.process-grid > *,
.home-hero__inner > *,
.home-hero__layout > *,
.home-about__grid > *,
.home-proof-grid > *,
.home-service-grid > *,
.home-services__grid > *{
  min-width:0;
}

h1,h2,h3,h4{ text-wrap:balance; }
p,li,a,span,strong,b,small,label,input,select,textarea,button{ overflow-wrap:break-word; }
.btn{
  max-width:100%;
  min-width:0;
  white-space:normal;
  text-align:center;
  justify-content:center;
  -webkit-tap-highlight-color:transparent;
}

/* ---------- Header und Burger-Menue ---------- */
.site-header{
  z-index:3000;
  overflow:visible !important;
}
.nav{ min-width:0; }
.brand{ min-width:0; }
.brand__mark{
  overflow:hidden;
  flex:0 0 50px;
}
.brand__logo{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.brand__name{ min-width:0; }
.brand__name b,
.brand__name span{
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.nav-links a{ white-space:nowrap; }

html.nav-open,
body.nav-open,
html.nav-is-open,
body.nav-is-open{
  overflow:hidden !important;
}

@media (max-width:1024px){
  :root{ --header-h:62px; }

  .site-header{
    position:sticky !important;
    top:0 !important;
    background:rgba(255,255,255,.98) !important;
    backdrop-filter:saturate(140%) blur(8px);
  }
  .nav{
    min-height:var(--header-h) !important;
    padding-top:7px !important;
    padding-bottom:7px !important;
    gap:10px !important;
    width:100%;
  }
  .brand{
    max-width:calc(100% - 54px) !important;
    gap:8px !important;
  }
  .brand__mark{
    width:40px !important;
    height:40px !important;
    flex-basis:40px !important;
  }
  .brand__name b{
    font-size:.92rem !important;
    line-height:1 !important;
  }
  .brand__name span{
    font-size:.58rem !important;
    line-height:1.1 !important;
    letter-spacing:.06em !important;
  }
  .burger{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    flex:0 0 42px !important;
    width:42px !important;
    height:42px !important;
    margin-left:auto !important;
    border:1px solid rgba(31,33,110,.22) !important;
    border-radius:10px !important;
    background:var(--blue) !important;
    color:#fff !important;
    box-shadow:0 8px 22px -18px rgba(0,0,0,.35);
    position:relative !important;
    z-index:3002 !important;
  }
  .burger span,
  .burger span::before,
  .burger span::after{
    width:20px !important;
    height:2px !important;
    background:#fff !important;
    border-radius:999px !important;
  }
  .nav-open .burger span,
  .nav-is-open .burger span{
    background:transparent !important;
  }
  .nav-open .burger span::before,
  .nav-open .burger span::after,
  .nav-is-open .burger span::before,
  .nav-is-open .burger span::after{
    background:#fff !important;
  }
  .nav-collapse{
    display:none !important;
    position:fixed !important;
    top:var(--header-h) !important;
    left:0 !important;
    right:0 !important;
    bottom:0 !important;
    width:100vw !important;
    max-width:100vw !important;
    height:calc(100vh - var(--header-h)) !important;
    height:calc(100dvh - var(--header-h)) !important;
    margin:0 !important;
    padding:12px max(16px, var(--safe-right)) calc(18px + var(--safe-bottom)) max(16px, var(--safe-left)) !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    overscroll-behavior:contain !important;
    background:#fff !important;
    border-top:1px solid var(--line) !important;
    box-shadow:0 24px 60px -34px rgba(0,0,0,.45) !important;
    z-index:3001 !important;
  }
  .nav-open .nav-collapse,
  .nav-is-open .nav-collapse{
    display:block !important;
  }
  .nav-collapse nav,
  .nav-links,
  .nav-links li{
    width:100% !important;
    max-width:100% !important;
  }
  .nav-links{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:0 !important;
    margin:0 !important;
    padding:0 !important;
  }
  .nav-links a{
    display:flex !important;
    align-items:center !important;
    width:100% !important;
    min-height:44px !important;
    padding:11px 2px !important;
    border-bottom:1px solid var(--line) !important;
    border-radius:0 !important;
    background:transparent !important;
    color:var(--ink) !important;
    font-size:.98rem !important;
    line-height:1.1 !important;
    letter-spacing:.04em !important;
    white-space:normal !important;
  }
  .nav-links a:hover,
  .nav-links a[aria-current="page"]{
    color:var(--blue) !important;
    background:transparent !important;
    text-decoration:none;
  }
  .nav-cta{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:8px !important;
    width:100% !important;
    margin-top:14px !important;
  }
  .nav-cta .btn{
    width:100% !important;
    min-height:42px !important;
    padding:11px 14px !important;
    font-size:.9rem !important;
  }

  body{ padding-bottom:0 !important; }
  .mobile-bar{
    display:none !important;
    visibility:hidden !important;
    pointer-events:none !important;
    height:0 !important;
    min-height:0 !important;
    max-height:0 !important;
    overflow:hidden !important;
  }
}

/* ---------- Hero: volle mobile Buehne, stabile Medienueberlagerung ---------- */
.hero,
.home-hero,
.services-hero{
  width:100%;
  min-height:clamp(560px, calc(100svh - var(--header-h)), 820px);
  overflow:hidden;
}
@supports (height:100dvh){
  .hero,
  .home-hero,
  .services-hero{
    min-height:clamp(560px, calc(100dvh - var(--header-h)), 820px);
  }
}
.hero__media,
.home-hero__bg,
.services-hero__bg{
  overflow:hidden;
}
.hero__media img,
.hero__media video,
.home-hero__bg img,
.home-hero__bg video,
.services-hero__bg img,
.services-hero__bg video{
  width:100% !important;
  height:100% !important;
  min-height:100% !important;
  object-fit:cover !important;
  object-position:center center;
}
.hero__inner,
.home-hero__inner,
.services-hero__inner{
  width:100%;
  min-width:0;
}

/* ---------- Medien: Hochformat als Standard, Querformat optional ---------- */
.media-frame,
.gallery__item,
.media-smart,
.media-slide,
.media-grid__item,
.media-placeholder{
  position:relative;
  overflow:hidden;
  aspect-ratio:9 / 16;
}
.media-frame{
  min-height:clamp(300px, 58vw, 480px);
}
.media-slide,
.media-grid__item,
.media-placeholder{
  min-height:clamp(260px, 44vw, 420px);
}
.media-frame img,
.media-frame video,
.gallery__item img,
.gallery__item video,
.media-smart img,
.media-smart video,
.media-slide img,
.media-slide video,
.media-grid__item img,
.media-grid__item video{
  width:100% !important;
  height:100% !important;
  min-height:100% !important;
  object-fit:cover !important;
  object-position:center center;
}
.media-smart.is-portrait,
.media-portrait,
[data-orientation="portrait"]{
  aspect-ratio:9 / 16 !important;
}
.media-smart.is-landscape,
.media-landscape,
[data-orientation="landscape"]{
  aspect-ratio:4 / 3 !important;
}
.media-smart.is-wide,
.media-wide,
[data-orientation="wide"]{
  aspect-ratio:16 / 9 !important;
}
.media-smart.is-square,
.media-square,
[data-orientation="square"]{
  aspect-ratio:1 / 1 !important;
}
.media-fit-contain img,
.media-fit-contain video,
[data-fit="contain"] img,
[data-fit="contain"] video{
  object-fit:contain !important;
  background:#07111f;
}

/* ---------- Medien-Slider: immer horizontal, nie untereinander ---------- */
.media-slider{
  --slide-width:clamp(220px, 30vw, 340px);
  position:relative !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  overflow:hidden !important;
  isolation:isolate;
}
.media-slider__viewport{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;
  scroll-padding-inline:2px;
  scrollbar-width:none;
  touch-action:pan-x pan-y;
}
.media-slider__viewport::-webkit-scrollbar{ display:none !important; }
.media-slider__track{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  align-items:stretch !important;
  gap:clamp(10px, 2vw, 14px) !important;
  width:max-content !important;
  min-width:100% !important;
  max-width:none !important;
  padding:4px 2px 14px !important;
  margin:0 !important;
}
.media-slide{
  flex:0 0 var(--slide-width) !important;
  width:var(--slide-width) !important;
  min-width:var(--slide-width) !important;
  max-width:none !important;
  float:none !important;
  display:block !important;
  margin:0 !important;
  border-radius:16px;
  scroll-snap-align:start;
  scroll-snap-stop:normal;
}
.home-about__media .media-slider,
.service-row__media .media-slider,
.split__media .media-slider{
  --slide-width:clamp(230px, 38vw, 380px);
}
.media-slider--landscape,
.home-hero__bg .media-slider{
  --slide-width:clamp(280px, 52vw, 680px);
}
.media-slider--landscape .media-slide,
.home-hero__bg .media-slide{
  aspect-ratio:16 / 9 !important;
}
.media-slider__btn{
  z-index:5;
  -webkit-tap-highlight-color:transparent;
}

.media-grid{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
  gap:clamp(10px, 2vw, 14px) !important;
  width:100%;
  max-width:100%;
  min-width:0;
}
.media-grid__item{
  display:block !important;
  float:none !important;
  width:auto !important;
  min-width:0 !important;
  max-width:100% !important;
  margin:0 !important;
  border-radius:16px;
}
.media-grid--projects .media-grid__item:nth-child(1),
.media-grid--projects .media-grid__item:nth-child(4){
  grid-column:span 2;
  aspect-ratio:4 / 3 !important;
}

/* ---------- Karten, Formulare, Karte ---------- */
.card,
.contact-card,
.home-card,
.home-hero__panel,
.home-hero__content,
.services-process-card,
.service-block__content,
.service-detail__content{
  max-width:100%;
}
.field input,
.field select,
.field textarea{
  min-width:0;
  max-width:100%;
}
.map-wrap,
.map-profile{
  width:100%;
  max-width:100%;
  min-height:clamp(320px, 56vw, 520px);
  border-radius:18px;
  overflow:hidden;
}
.map-wrap iframe,
.map-profile iframe{
  width:100% !important;
  height:clamp(320px, 56vw, 520px) !important;
  min-height:320px;
  display:block;
  border:0;
}
.map-profile__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:16px;
  background:#fff;
}

/* ---------- Footer kompatibel mit .site-footer und .clean-footer ---------- */
.clean-footer{
  background:#07111f;
  color:#b9c3d1;
  padding:0;
  margin-top:0;
}
.clean-footer a{
  color:inherit;
  text-decoration:none;
}
.clean-footer a:hover{
  color:#fff;
  text-decoration:none;
}
.footer-cta{
  background:linear-gradient(135deg,var(--blue),var(--blue-700));
  color:#fff;
  padding:26px 0;
}
.footer-cta__inner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:20px;
  align-items:center;
}
.footer-cta__text{
  display:flex;
  gap:16px;
  align-items:center;
  min-width:0;
}
.footer-cta__icon{
  width:52px;
  height:52px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.16);
  flex:0 0 52px;
}
.footer-cta__icon svg{ width:24px !important; height:24px !important; }
.footer-cta h2{
  color:#fff;
  font-size:clamp(1.5rem,3vw,2.1rem);
  margin:0 0 .2rem;
}
.footer-cta p{
  margin:0;
  color:rgba(255,255,255,.84);
}
.footer-cta__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-end;
}
.footer-main{ padding:48px 0 26px; }
.footer-grid{
  display:grid;
  grid-template-columns:1.15fr .9fr .95fr .85fr;
  gap:32px;
  align-items:start;
}
.footer-brand{ max-width:360px; }
.footer-brand__top{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.footer-brand__logo,
.site-footer .brand__mark{
  width:54px !important;
  height:54px !important;
  min-width:54px !important;
  flex:0 0 54px !important;
  border-radius:50%;
  overflow:hidden;
}
.footer-brand__logo img,
.site-footer .brand__logo{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}
.footer-brand__name b{
  display:block;
  color:#fff;
  font-family:var(--font-head);
  font-size:1.28rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.footer-brand__name span{
  display:block;
  color:#9ea1ff;
  font-family:var(--font-head);
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.11em;
  margin-top:3px;
}
.footer-brand p{
  color:#b9c3d1;
  margin:0 0 12px;
  font-size:.98rem;
  line-height:1.6;
}
.footer-slogan{
  color:#fff;
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:1.02rem;
  margin-top:12px;
}
.footer-col h3,
.clean-footer h3{
  color:#fff;
  font-family:var(--font-head);
  font-size:1.18rem;
  text-transform:uppercase;
  margin:0 0 14px;
  letter-spacing:.04em;
}
.footer-links,
.footer-contact{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.footer-links a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#b9c3d1;
  font-size:.98rem;
}
.footer-links a::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--blue);
  flex:0 0 7px;
}
.footer-contact li,
.footer-social a{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:#b9c3d1;
  font-size:.98rem;
  line-height:1.45;
}
.footer-social{
  display:grid;
  gap:10px;
  margin-top:1rem;
}
.footer-social a{
  padding:10px 12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:12px;
  background:rgba(255,255,255,.04);
  transition:.18s;
}
.footer-social a:hover{
  background:rgba(255,255,255,.08);
  transform:translateY(-2px);
}
.footer-icon{
  width:32px !important;
  height:32px !important;
  border-radius:50%;
  background:rgba(255,255,255,.08);
  color:#9ea1ff;
  display:grid;
  place-items:center;
  flex:0 0 32px;
  margin-top:-3px;
}
.site-footer svg,
.footer-icon svg,
.footer-social svg,
.footer-social__icon,
.mobile-bar svg{
  width:18px !important;
  height:18px !important;
  min-width:18px !important;
  max-width:18px !important;
  min-height:18px !important;
  max-height:18px !important;
  flex:0 0 18px !important;
  display:block !important;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.09);
  padding-top:20px;
  margin-top:34px;
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:14px;
  color:#7f8b99;
  font-size:.92rem;
}
.footer-bottom__links{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}

/* ---------- Tablet ---------- */
@media (max-width:980px){
  .grid--4,
  .grid--3,
  .footer-grid,
  .footer-cta__inner,
  .process{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
  }
  .grid--2,
  .split,
  .contact-grid,
  .service-detail,
  .service-row__grid,
  .service-row__layout,
  .services-head__grid,
  .service-block__layout,
  .home-hero__layout,
  .home-about__grid{
    grid-template-columns:1fr !important;
  }
  .split--rev .split__media{ order:0 !important; }
  .media-slider{ --slide-width:42vw; }
  .home-about__media .media-slider,
  .service-row__media .media-slider,
  .split__media .media-slider{ --slide-width:46vw; }
  .media-grid{ grid-template-columns:repeat(2, minmax(0,1fr)) !important; }
  .usp{ grid-template-columns:repeat(2, minmax(0,1fr)) !important; }
}

/* ---------- Smartphone ---------- */
@media (max-width:720px){
  :root{
    --header-h:62px;
    --page-pad:14px;
  }
  body{
    font-size:15px !important;
    line-height:1.55 !important;
    padding-bottom:0 !important;
  }
  .container{
    padding-left:max(14px, var(--safe-left)) !important;
    padding-right:max(14px, var(--safe-right)) !important;
  }
  .section{
    padding-top:clamp(32px, 9vw, 46px) !important;
    padding-bottom:clamp(32px, 9vw, 46px) !important;
  }
  h1{
    font-size:clamp(1.9rem, 10vw, 2.7rem) !important;
    line-height:1.02 !important;
  }
  h2{
    font-size:clamp(1.45rem, 7.4vw, 2.05rem) !important;
    line-height:1.05 !important;
  }
  h3{
    font-size:clamp(1.12rem, 5vw, 1.35rem) !important;
    line-height:1.08 !important;
  }
  .lead,
  .hero__sub,
  .home-hero__lead,
  .services-hero__lead{
    font-size:.98rem !important;
    line-height:1.58 !important;
  }
  .eyebrow{
    font-size:.78rem !important;
    letter-spacing:.14em !important;
    margin-bottom:.45rem !important;
  }
  .btn,
  .btn--lg{
    min-height:40px !important;
    padding:.68rem 1rem !important;
    font-size:.88rem !important;
    line-height:1.05 !important;
  }
  .hero,
  .home-hero,
  .services-hero{
    min-height:calc(100svh - var(--header-h)) !important;
  }
  @supports (height:100dvh){
    .hero,
    .home-hero,
    .services-hero{
      min-height:calc(100dvh - var(--header-h)) !important;
    }
  }
  .hero__inner,
  .home-hero,
  .services-hero{
    padding-top:clamp(42px, 9svh, 76px) !important;
    padding-bottom:clamp(42px, 9svh, 76px) !important;
  }
  .hero__cta,
  .home-hero__actions,
  .services-hero__actions,
  .start-cta__actions,
  .footer-cta__actions,
  .map-profile__actions,
  .quickbar__links{
    gap:8px !important;
  }
  .hero__cta .btn,
  .home-hero__actions .btn,
  .services-hero__actions .btn,
  .start-cta__actions .btn,
  .footer-cta__actions .btn,
  .map-profile__actions .btn,
  .quickbar__links .btn{
    width:100% !important;
  }
  .quickbar__row{
    justify-content:center !important;
    text-align:center !important;
  }
  .grid,
  .grid--2,
  .grid--3,
  .grid--4,
  .split,
  .contact-grid,
  .form-grid,
  .footer-grid,
  .footer-cta__inner,
  .process,
  .service-detail,
  .service-row__grid,
  .service-row__layout,
  .service-overview__grid,
  .services-head__grid,
  .services-card-grid,
  .service-block__layout,
  .process-grid,
  .home-hero__layout,
  .home-about__grid,
  .home-proof-grid,
  .home-service-grid,
  .home-services__grid{
    grid-template-columns:1fr !important;
  }
  .usp{ grid-template-columns:1fr !important; }
  .usp__item{
    border-right:0 !important;
    border-bottom:1px solid var(--line) !important;
  }
  .usp__item:last-child{ border-bottom:0 !important; }
  .svc-list,
  .text-cols{ columns:1 !important; }
  .card,
  .contact-card,
  .home-card,
  .home-hero__panel,
  .home-hero__content,
  .services-process-card,
  .service-block__content,
  .service-detail__content{
    padding:18px !important;
  }
  .field input,
  .field select,
  .field textarea{
    font-size:16px !important;
  }
  .media-slider{ --slide-width:78vw; }
  .home-about__media .media-slider,
  .service-row__media .media-slider,
  .split__media .media-slider{ --slide-width:80vw; }
  .media-slider__track{
    gap:10px !important;
    padding-bottom:12px !important;
  }
  .media-slide,
  .media-grid__item,
  .media-placeholder{
    min-height:clamp(220px, 62vw, 340px) !important;
    border-radius:12px !important;
  }
  .media-slider__btn{ display:none !important; }
  .media-grid{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:10px !important;
  }
  .media-grid--projects .media-grid__item:nth-child(1),
  .media-grid--projects .media-grid__item:nth-child(4){
    grid-column:auto !important;
    aspect-ratio:9 / 16 !important;
  }
  .gallery{
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:10px !important;
  }
  .gallery__item,
  .gallery__item.tall{
    grid-row:auto !important;
    aspect-ratio:9 / 16 !important;
  }
  .map-wrap,
  .map-profile,
  .map-wrap iframe,
  .map-profile iframe{
    min-height:320px !important;
    height:clamp(320px, 74vw, 440px) !important;
  }
  .footer-cta{ padding:20px 0 !important; }
  .footer-main{ padding:32px 0 20px !important; }
  .footer-cta__text{ align-items:flex-start; }
  .footer-cta__actions{ justify-content:stretch; }
  .footer-bottom{ flex-direction:column; }
  .footer-cta h2{ font-size:1.45rem !important; }
  .footer-cta p,
  .footer-brand p,
  .footer-links a,
  .footer-contact li,
  .footer-social a{ font-size:.9rem !important; }

  .mobile-bar{
    display:grid !important;
    visibility:visible !important;
    pointer-events:auto !important;
    grid-template-columns:repeat(3, minmax(0,1fr));
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    height:auto !important;
    max-height:none !important;
  }
  .mobile-bar a{
    min-width:0;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    font-family:var(--font-head);
    text-transform:uppercase;
    font-size:.76rem;
    letter-spacing:.04em;
    text-decoration:none;
  }
  .mobile-bar a.call{ background:var(--blue); }
  .mobile-bar a.wa{ background:#1faa55; }
  .mobile-bar a:hover{ text-decoration:none; }
  .mobile-bar a svg{
    width:21px !important;
    height:21px !important;
    max-width:21px !important;
    max-height:21px !important;
  }
  body.has-mobile-bar{
    padding-bottom:calc(var(--mobile-bar-h) + var(--safe-bottom)) !important;
  }
  body.has-mobile-bar .cookie{
    bottom:calc(var(--mobile-bar-h) + var(--safe-bottom) + 16px) !important;
  }
  .cookie{
    left:12px !important;
    right:12px !important;
    bottom:calc(16px + var(--safe-bottom)) !important;
    max-width:none !important;
  }
}

@supports selector(body:has(.mobile-bar)){
  @media (max-width:720px){
    body:has(.mobile-bar){
      padding-bottom:calc(var(--mobile-bar-h) + var(--safe-bottom)) !important;
    }
    body:has(.mobile-bar) .cookie{
      bottom:calc(var(--mobile-bar-h) + var(--safe-bottom) + 16px) !important;
    }
  }
}

@media (max-width:420px){
  :root{ --page-pad:12px; }
  body{ font-size:14.5px !important; }
  .container{
    padding-left:max(12px, var(--safe-left)) !important;
    padding-right:max(12px, var(--safe-right)) !important;
  }
  .section{
    padding-top:30px !important;
    padding-bottom:30px !important;
  }
  .brand__mark{
    width:36px !important;
    height:36px !important;
    flex-basis:36px !important;
  }
  .burger{
    width:40px !important;
    height:40px !important;
    flex-basis:40px !important;
  }
  .media-slider{ --slide-width:82vw; }
  .media-grid,
  .gallery{
    grid-template-columns:1fr !important;
  }
  .media-grid__item,
  .gallery__item,
  .gallery__item.tall{
    aspect-ratio:4 / 5 !important;
    min-height:210px !important;
  }
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
}

.media-zoomable {
  cursor: zoom-in;
  position: relative;
}

.media-zoomable img,
.media-zoomable video {
  pointer-events: none;
}

.media-slide,
.media-slider__item,
.media-grid__item,
.gallery-featured__item,
.gallery-preview__item {
  cursor: zoom-in;
}