/* ============================================================
   Lothar Heine – Website (Nachbau)
   ============================================================ */
:root{
  --cream:#f5f1db;
  --cream-2:#eee7b9;
  --ink:#191919;
  --ink-soft:#191919;      /* Live nutzt fast durchgehend Fast-Schwarz */
  --black:#000;
  --accent:#bbcd1c;        /* Lime-Highlight (exakt wie Original) */
  --accent-line:#b6cf3f;   /* Olive-Lime Unterstrich */
  --white:#fff;
  --radius:4px;            /* Buttons */
  --radius-box:8px;        /* Karten/Boxen */
  --maxw:1264px;
  --header-h:78px;
  --font:'Instrument Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
:root{color-scheme:light}
html{scroll-behavior:smooth;scroll-padding-top:var(--header-h);color-scheme:light;background:#fbf9ed}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--cream);
  font-size:18px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:70px 0}

h1,h2,h3,h4{margin:0 0 .5em;line-height:1.3;letter-spacing:-.012em;font-weight:600}
h1{font-size:clamp(2rem,6vw,48px);font-weight:700}
h2{font-size:clamp(1.7rem,4.5vw,32px);font-weight:600}
h3{font-size:24px}
p{margin:0 0 1.1em}

/* Brush-Marker-Highlight (exakt wie onepage: Verlauf links kräftig → rechts ausblendend) */
.highlight{position:relative;isolation:isolate;color:inherit;padding:0;background:transparent;white-space:nowrap}
.highlight::before{
  content:"";position:absolute;z-index:-1;inset:1px -2px -1px;border-radius:4px;
  background:linear-gradient(90deg,rgba(187,205,28,.4),rgba(187,205,28,.9) 4%,rgba(187,205,28,.1));
}

/* ---------- Scroll-Reveal (nur wenn JS aktiv; sonst alles sichtbar) ---------- */
.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.22,.61,.36,1),transform .8s cubic-bezier(.22,.61,.36,1)}
.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:700;font-size:17px;line-height:1.3;
  padding:18px 31px;border-radius:var(--radius);
  text-decoration:none;cursor:pointer;border:0;
  transition:transform .15s ease,background .15s ease,color .15s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--black);color:var(--white)}
.btn-primary:hover{background:#222}
.btn-ghost{background:var(--white);color:var(--ink)}
.btn-ghost:hover{background:#f3f0e2}
.btn-lime{background:var(--accent);color:#191919}
.btn-lime:hover{background:#c8da2a}
.btn-arrow{gap:.7em}
.btn-arrow .ico{
  display:grid;place-items:center;width:36px;height:36px;border-radius:50%;
  background:var(--white);color:var(--black);flex:0 0 auto;
}
.btn-arrow .ico svg{width:20px;height:20px;display:block}
.header-cta{font-size:15px;padding:10px 22px 10px 14px;font-weight:700}
.btn-row{display:flex;flex-wrap:wrap;gap:16px;margin-top:28px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:1000;background:var(--white);
  box-shadow:0 1px 0 rgba(0,0,0,.06);
  isolation:isolate;            /* eigener Stacking-Kontext – Leiste bleibt über allem */
  padding-top:env(safe-area-inset-top,0px);  /* Navbar-Hintergrund füllt den Statusleisten-Bereich (kein weißer Balken) */
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:var(--header-h)}
/* Karriere: nur Logo, transparent über dem Hero */
.k-header{position:absolute;top:0;left:0;right:0;background:transparent;box-shadow:none}
.k-header .header-inner{height:88px}
.k-header .logo-dark{display:none}
.logo img{height:62px;width:auto}
.main-nav{display:flex;align-items:center;gap:34px}
.main-nav a{
  text-decoration:none;font-weight:500;font-size:17px;color:var(--ink);
  padding:4px 0;position:relative;white-space:nowrap;
}
.main-nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;
  background:var(--accent-line);transform:scaleX(0);transform-origin:center;transition:transform .25s ease;
}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1)}
.header-cta{margin-left:8px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--ink);margin:5px 0;transition:.25s}

/* ---------- Hero ---------- */
.hero{background:var(--cream);overflow:hidden;padding:52px 0 76px}
.hero-grid{display:grid;grid-template-columns:minmax(0,448px) 1fr;gap:52px;align-items:center}
.hero h1{margin-bottom:.45em}
.hero-h1-mobile{display:none}   /* nur mobil: kurze, zentrierte Überschrift „Wir bauen alles!" */
.hero p{font-size:18px;color:var(--ink);max-width:33em}

/* marquee gallery */
.hero-gallery{min-width:0;overflow:hidden}
.gallery-rows{display:flex;flex-direction:column;gap:16px;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.marquee{display:flex;gap:16px;width:max-content;animation:scroll-left 42s linear infinite;will-change:transform;backface-visibility:hidden}
.marquee.reverse{animation-direction:normal;animation-duration:42s}
@media(hover:hover){.marquee:hover{animation-play-state:paused}}
.marquee img{height:220px;width:auto;border-radius:8px;flex:0 0 auto}
@keyframes scroll-left{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Band heading ---------- */
.band{background:transparent;text-align:center;padding:74px 0 4px}
.band + .section{padding-top:32px}
.band h2{margin:0;font-size:clamp(1.7rem,4.5vw,32px);font-weight:600}

/* ---------- Value cards ---------- */
.values{background:var(--cream)}
.section-head{text-align:center;max-width:48rem;margin:0 auto 52px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:46px}
.card h3{margin-bottom:.7em;text-align:center;font-size:24px}
.card p{margin:0;color:var(--ink);font-size:18px}

/* Startseite: EINE weiße Box mit 3 Spalten */
.values .cards{
  background:var(--white);border-radius:var(--radius-box);padding:45px;gap:46px;
  box-shadow:0 10px 40px rgba(60,55,30,.06);
}
.values .card{padding:0;background:transparent;border:0;box-shadow:none}
.values .card p{text-align:left}

/* Karriere: getrennte Karten mit lime Icon */
.k-intro .cards{gap:30px}
.k-intro .card{
  background:var(--white);border-radius:4px;padding:40px 30px;text-align:center;
  box-shadow:0 1px 3px rgba(17,17,26,.05),0 0 0 1px rgba(17,17,26,.04);
}
.k-intro .card .cico{display:block;width:45px;height:45px;margin:0 auto 20px;color:var(--accent)}
.k-intro .card .cico svg{width:45px;height:45px;display:block;stroke:var(--accent);fill:none;stroke-width:1.6}
.k-intro .card h3{margin-bottom:.6em}
.k-intro .card p{text-align:left}

/* ---------- Services ---------- */
.services{background:var(--cream)}
.service{
  position:relative;max-width:1000px;margin:0 auto 38px;padding:6px 0 6px 28px;
}
/* graue Spur */
.service::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px;background:#d9d2b4}
/* grüne Füllung, die beim Einscrollen von oben nach unten aufläuft */
.service::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform 1s cubic-bezier(.22,.61,.36,1)}
.js .service.in::after{transform:scaleY(1)}
.service h3{font-size:24px;margin-bottom:.45em}
.service p{color:var(--ink)}

/* ---------- Motto ---------- */
.motto{background:var(--cream-2);text-align:center;padding:64px 0}
.motto .lead{font-size:1.15rem;font-weight:600;margin-bottom:.2em;color:var(--ink-soft)}
.motto h2{font-size:clamp(2rem,5vw,3.4rem);margin:0}

/* ---------- About / history + values ---------- */
.about{background:var(--cream)}
.about .wrap{max-width:900px;margin:0 auto}
.about p{color:var(--ink-soft)}
.about-figure{margin:40px auto 0;max-width:1000px}
.about-figure img{width:100%;border-radius:14px}
.big-line{font-size:clamp(1.7rem,4.5vw,32px);font-weight:600;margin:.1em 0 .8em}

/* ---------- Split sections (Motto + Kuh / Team) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split-figure img{width:100%;border-radius:var(--radius-box);box-shadow:0 10px 40px rgba(60,55,30,.10)}
.split-text .lead{font-size:clamp(1.7rem,4.5vw,32px);font-weight:600;line-height:1.3;margin-bottom:.15em}
.motto-title{font-size:clamp(1.7rem,4.5vw,32px);font-weight:600;margin:0 0 .7em;line-height:1.3}
.motto-about,.values-text,.team{background:var(--cream-2)}
.values-text .wrap{max-width:980px;margin:0 auto;background:var(--white);border-radius:var(--radius-box);padding:50px 56px;box-shadow:0 10px 40px rgba(60,55,30,.06)}
.values-text .lead,.values-text .big-line{text-align:center}
.values-text .lead{font-size:clamp(1.7rem,4.5vw,32px);font-weight:600;line-height:1.3;text-align:center;margin-bottom:.15em}
.values-text p,.split-text p,.team p{color:var(--ink-soft)}
.team .split-text h2{margin-bottom:.5em}

/* ---------- References masonry ---------- */
.refs{background:var(--cream)}
.masonry{columns:4 260px;column-gap:16px;margin-top:8px}
.masonry img{
  width:100%;margin:0 0 16px;border-radius:var(--radius-box);break-inside:avoid;
  box-shadow:0 4px 16px rgba(60,55,30,.08);
}

/* ---------- Contact ---------- */
.contact{background:var(--cream)}
.contact-card{
  background:var(--white);border-radius:var(--radius-box);padding:45px;
  display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;
  box-shadow:0 10px 40px rgba(60,55,30,.06);
}
.contact-info h2{margin-bottom:.5em}
.contact-info>p{margin:.2em 0;color:var(--ink)}
.contact-info .ci{display:flex;align-items:center;gap:13px;font-weight:600;color:var(--ink);margin-top:1.15em}
.contact-info .ci .ci-ico{width:22px;height:22px;flex:0 0 auto;color:var(--ink)}
.contact-info .ci a{text-decoration:none}
.contact-btns{flex-direction:row;flex-wrap:nowrap;gap:14px;margin-top:34px}
.contact-btns .btn{flex:1 1 0;justify-content:center;text-align:center}
.btn-text{background:transparent;color:var(--ink)}
.btn-text:hover{background:rgba(0,0,0,.04)}
.contact-map iframe,.contact-map img{width:100%;height:420px;border:0;border-radius:var(--radius-box);object-fit:cover}

/* ---------- Footer ---------- */
.site-footer{background:var(--cream-2);text-align:center;padding:60px 0 46px}
.site-footer .logo img{height:64px;margin:0 auto 18px}
.site-footer .copy{font-weight:700;margin:0 0 14px}
.footer-links{display:flex;gap:26px;justify-content:center}
.footer-links a{text-decoration:none;font-weight:600;border-bottom:2px solid var(--accent-line);padding-bottom:2px}
.footer-links a:hover{border-bottom-color:var(--ink)}
.disclaimer{max-width:680px;margin:22px auto 0;font-size:.8rem;color:#8a8568}
.k-footer{background:var(--cream)}
.k-footer .disclaimer{color:var(--ink);margin:16px auto 20px}

/* ---------- Karriere ---------- */
.k-hero{position:relative;min-height:60vh;display:flex;align-items:center;
  background:#2b2b2b center/cover no-repeat;color:var(--white);text-align:center}
.k-hero::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.42)}
.k-hero .container{position:relative;z-index:1;width:100%}
.k-hero h1{font-size:clamp(2.6rem,7vw,5rem);text-shadow:0 2px 18px rgba(0,0,0,.4)}
.k-page{background:var(--cream-2)}
.k-intro{background:transparent;text-align:center}
.k-intro-box{
  background:var(--white);border:1px solid #d9d2b4;border-radius:var(--radius-box);
  padding:50px 56px;display:grid;grid-template-columns:1fr 1.18fr;gap:50px;align-items:center;
  text-align:left;margin-bottom:64px;
}
.k-intro-box .lead{font-size:clamp(2rem,5vw,48px);font-weight:600;line-height:1.16;margin:0;color:var(--ink)}
.k-intro-box .k-intro-text{font-size:18px;color:var(--ink);margin:0}
/* Karriere: Überschriften groß + linksbündig */
.k-page .section-head{text-align:left;max-width:none;margin:0 0 34px}
.k-page .section-head h2{font-size:clamp(2.4rem,7vw,48px);font-weight:600}
/* Wistia-Video im Testimonial */
.tcard .ph iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
/* Job-Karte: grüner Titel + Meta-Icons */
.job .jtitle{color:var(--accent)}
.job .jmeta{display:flex;flex-wrap:wrap;gap:6px 22px;margin-top:.5em}
.job .jmeta>span{display:inline-flex;align-items:center;gap:7px}
.job .jmeta .jm-ico{width:17px;height:17px;flex:0 0 auto;color:var(--ink-soft)}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.tcard{background:transparent;border:0;box-shadow:none;border-radius:0;overflow:visible}
.tcard .ph{
  display:block;width:100%;padding:0;border:0;cursor:pointer;
  position:relative;aspect-ratio:16/9;background:#222;overflow:hidden;border-radius:var(--radius-box);
}
.tcard .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.tcard .ph:hover img{transform:scale(1.04)}
.tcard .ph .play{
  position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;
  background:var(--accent);display:grid;place-items:center;color:#191919;
  box-shadow:0 4px 18px rgba(0,0,0,.25);transition:transform .15s ease;
}
.tcard .ph:hover .play{transform:scale(1.08)}
.tcard .ph .play svg{width:26px;height:26px;margin-left:3px}
.tcard .meta{padding:14px 2px 0;text-align:center}
.tcard .meta strong{font-weight:700}
.tcard .meta .role{color:var(--ink)}

/* Video-Lightbox (Overlay) */
.video-lightbox{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;padding:24px}
.video-lightbox[hidden]{display:none}
.vl-inner{position:relative;width:min(1000px,100%);aspect-ratio:16/9}
.vl-frame{position:absolute;inset:0}
.vl-frame iframe{width:100%;height:100%;border:0;border-radius:8px;background:#000}
.vl-close{position:absolute;top:16px;right:22px;width:46px;height:46px;border:0;border-radius:50%;background:rgba(255,255,255,.16);color:#fff;font-size:30px;line-height:1;cursor:pointer;transition:background .15s ease}
.vl-close:hover{background:rgba(255,255,255,.3)}

/* ---------- Referenz-Bild-Lightbox (Großansicht + Pfeile) ---------- */
.ref-counter{display:none}   /* nur in der mobilen Wisch-Galerie sichtbar */
.img-lightbox{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;padding:24px}
.img-lightbox[hidden]{display:none}
.il-stage{flex:1;min-width:0;height:100%;display:flex;align-items:center;justify-content:center}
.il-img{max-width:100%;max-height:86vh;width:auto;height:auto;object-fit:contain;border-radius:8px}
.il-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:0;border-radius:50%;
  background:rgba(255,255,255,.16);color:#fff;font-size:34px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s ease}
.il-nav:hover{background:rgba(255,255,255,.3)}
.il-prev{left:18px}
.il-next{right:18px}
.il-close{position:absolute;top:16px;right:22px;width:46px;height:46px;border:0;border-radius:50%;
  background:rgba(255,255,255,.16);color:#fff;font-size:30px;line-height:1;cursor:pointer;z-index:2;transition:background .15s ease}
.il-close:hover{background:rgba(255,255,255,.3)}
.il-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#fff;font-weight:600;font-size:16px}
@media(max-width:560px){
  .il-nav{width:44px;height:44px;font-size:28px}
  .il-prev{left:6px}.il-next{right:6px}
}
.k-testimonials{padding-bottom:20px}
#offene-stellen{padding-top:20px}
.jobs{max-width:none;margin:0}
.job{
  background:var(--white);border-radius:var(--radius-box);padding:22px 32px;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;
  box-shadow:0 6px 24px rgba(60,55,30,.07);
}
.job .jtitle{font-size:28px;font-weight:700;margin:0}
.job .jmeta{margin:.3em 0 0;color:var(--ink-soft);font-size:18px}

/* ---------- Legal pages ---------- */
.legal{background:var(--cream);padding-top:48px}
.legal .container{max-width:820px}
.legal h1{margin-bottom:.6em}
.legal h2{font-size:1.5rem;margin-top:1.6em}
.legal h3{font-size:1.15rem;margin-top:1.4em}
.legal p{color:var(--ink-soft);font-size:.98rem;margin:0 0 .8em}
.legal .ds-stand{font-weight:600;color:var(--ink)}
.legal .toc{margin:.4em 0 1.8em;padding:0 0 0 1.2em;columns:2;column-gap:46px}
.legal .toc li{margin:.3em 0;color:var(--ink-soft);font-size:.96rem;break-inside:avoid}
@media(max-width:640px){.legal .toc{columns:1}}

/* ---------- Cookie banner ---------- */
.cookie{position:fixed;left:50%;bottom:0;transform:translateX(-50%);z-index:999;width:100%;max-width:900px;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}
.cookie.hidden{display:none}
/* Schwebender Button (Desktop+Mobil): öffnet den Cookie-Banner erneut */
.cookie-fab{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom,0px));z-index:998;
  width:54px;height:54px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.08);
  box-shadow:0 6px 20px rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);transition:box-shadow .15s ease,transform .15s ease}
.cookie-fab[hidden]{display:none}
.cookie-fab:hover{box-shadow:0 8px 26px rgba(0,0,0,.26);transform:translateY(-1px)}
.cookie-fab svg{width:24px;height:24px}
.cookie-inner{
  background:var(--white);border-radius:8px;box-shadow:0 20px 140px 20px rgba(0,0,0,.10);
  display:flex;gap:28px;padding:28px 30px;align-items:center;
}
.cookie-text{flex:1;min-width:0}
.cookie-text h3{font-size:18px;font-weight:700;margin:0 0 .45em}
.cookie-text p{font-size:14px;line-height:1.55;color:var(--ink-soft);margin:0 0 .7em}
.cookie-link{font-size:14px;color:var(--ink);text-decoration:underline}
.cookie-actions{display:flex;flex-direction:column;gap:12px;justify-content:center;flex:0 0 188px}
.ck-btn{border:0;border-radius:4px;padding:12px 20px;font-weight:700;font-size:15px;line-height:1.2;cursor:pointer;font-family:inherit;color:var(--ink);transition:filter .15s ease}
.ck-btn:hover{filter:brightness(.96)}
.ck-accept{background:var(--cream)}
.ck-reject,.ck-edit{background:#f2f2f2}
@media(max-width:760px){
  .cookie{padding:12px}
  .cookie-inner{flex-direction:column;gap:18px;padding:22px}
  .cookie-actions{flex:0 0 auto;width:100%}
  .ck-btn{width:100%}
}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .cards,.testimonials{grid-template-columns:1fr 1fr}
  .contact-card{grid-template-columns:1fr;gap:30px}
  .masonry{columns:2 200px}
  /* Team & Motto mobil: Überschrift → Bild → Text (statt nebeneinander) */
  .split{display:flex;flex-direction:column;gap:0;align-items:stretch}
  .split-text{display:contents}
  .split-text > .lead, .split-text > h2{order:1}
  .split-figure{order:2;margin:22px 0}
  .split-text > p:not(.lead), .split-text > .btn-row{order:3}
}
@media(max-width:960px){
  .k-intro .cards{grid-template-columns:1fr}   /* Karriere-Karten einspaltig & full width */
}
@media(max-width:760px){
  html,body{overflow-x:hidden}
  body{font-size:16px}
  /* Navbar mobil: warmes Off-White wie Live-Bild (#fbf9ed, hebt sich dezent ab, KEINE weiße Leiste) – Dropdown bleibt weiß */
  .site-header:not(.k-header){background:#fbf9ed;box-shadow:none}
  /* HERO mobil: Reihenfolge Überschrift → Galerie → Text → Buttons (wie Live-Bild) */
  .hero{padding:30px 0 56px}
  .hero-grid{display:flex;flex-direction:column;gap:26px;align-items:stretch}  /* stretch → Buttons/Reihen volle Breite */
  .hero-text{display:contents}
  .hero-text h1{order:1;margin-bottom:0}
  .hero-h1-desktop{display:none}
  .hero-h1-mobile{display:block;text-align:center;font-size:clamp(2.4rem,11vw,3.4rem)}
  .hero-gallery{order:2}
  .hero-text p{order:3;margin:0}
  .hero-text .btn-row{order:4;margin:0}
  .main-nav{
    position:fixed;top:calc(var(--header-h) + env(safe-area-inset-top,0px));left:0;right:0;bottom:auto;background:var(--white);
    flex-direction:column;align-items:flex-start;gap:0;padding:8px 0;
    border-bottom:1px solid #eee;box-shadow:0 18px 30px rgba(0,0,0,.08);
    transform:translateY(-130%);visibility:hidden;        /* visibility verhindert den weißen Rand oben, falls -130% nicht ganz ausreicht */
    transition:transform .28s ease, visibility 0s linear .28s;
  }
  .main-nav.open{transform:translateY(0);visibility:visible;transition:transform .28s ease, visibility 0s linear 0s}
  .main-nav a{width:100%;padding:14px 24px}
  .main-nav a::after{display:none}
  .header-cta{display:none}
  /* Hamburger: abgerundeter Sand-Button (#f4e8c2), nur ZWEI dezente Striche (wie Live-Bild) */
  .nav-toggle{display:flex;flex-direction:column;align-items:center;justify-content:center;
    width:58px;height:50px;padding:0;gap:7px;background:#f4e8c2;border-radius:14px}
  .nav-toggle span{width:22px;height:2px;margin:0;border-radius:2px;background:rgba(25,25,25,.6)}
  /* Buttons immer full width */
  .btn{width:100%;justify-content:center}
  .btn-row{flex-direction:column;align-items:stretch;gap:12px}
  /* Karten einspaltig (Startseite + Karriere) */
  .cards,.testimonials{grid-template-columns:1fr}
  .values .cards{padding:30px 24px}   /* nur die weiße Startseiten-Box hat Innenabstand */
  .k-intro .card{padding:30px 24px}
  .values-text .wrap{padding:34px 26px;margin-left:24px;margin-right:24px}  /* gleicher Seitenabstand wie .container (nicht bis zum Rand) */
  .contact-card{padding:30px 26px}
  .k-intro-box{grid-template-columns:1fr;gap:22px;padding:34px 26px}
  .contact-map iframe,.contact-map img{height:300px}
  .section{padding:52px 0}
  /* Referenzen = wischbare Galerie: ein Bild pro Ansicht (Snap), Zähler darunter */
  .masonry{columns:auto;display:flex;gap:0;margin-top:8px;overflow-x:auto;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;border-radius:12px;scrollbar-width:none}
  .masonry::-webkit-scrollbar{display:none}
  .masonry img{flex:0 0 100%;width:100%;aspect-ratio:4/3;height:auto;object-fit:cover;
    margin:0;border-radius:12px;scroll-snap-align:center;box-shadow:none;cursor:pointer}
  .js .masonry img.reveal{opacity:1;transform:none}   /* im Carousel immer sichtbar (kein Fade beim Wischen) */
  .ref-counter{display:block;text-align:center;margin-top:16px;font-weight:600;font-size:17px;color:var(--ink)}
  /* Karriere-Hero mobil: exaktes Bild-Seitenverhältnis (1280×518) → GANZES Team sichtbar,
     kein Seitenbeschnitt, keine Verzerrung; dadurch automatisch niedrigere Höhe */
  /* Karriere-Hero mobil: niedriger als Desktop, aber etwas höher (leichter Seitenbeschnitt ok),
     Überschrift WIEDER mittig ÜBER dem Bild (Basis-Overlay & .container bleiben aktiv) */
  .k-hero{min-height:300px;background-position:center;padding:0}
  .k-hero h1{font-size:clamp(1.9rem,7vw,2.6rem)}
}
@media(max-width:560px){
  .container{padding:0 18px}
  .job{flex-direction:column;align-items:flex-start;gap:16px;padding:24px 24px}
  .job .btn{width:100%;justify-content:center}
  .job .jtitle{font-size:24px}
  .job .jmeta{font-size:16px}
  .values .cards{padding:28px 22px}
  .values-text .wrap,.k-intro-box,.contact-card{padding:28px 22px}
  .values-text .wrap{margin-left:18px;margin-right:18px}   /* wie .container-Padding bei Handy */
  .vl-close{top:8px;right:10px;width:42px;height:42px}
  .btn{padding:16px 26px}
  .masonry{columns:1}
}
