/* ============================================================
   5 Designs – Ihr Raumausstatter · Bohmte & Osnabrück
   Brand: Dunkelgrün #1e2b1d · Creme #efefe7 · Tan #c1ad8d
   ============================================================ */
:root{
  --green:#1e2b1d;
  --green-soft:#2c4129;
  --green-deep:#162015;
  --cream:#efefe7;
  --cream-soft:#f7f7f2;
  --tan:#c1ad8d;
  --tan-soft:#d8cab2;
  --petrol:#015059;
  --text:#2b2f2a;
  --muted:#676d65;
  --white:#ffffff;
  --line:#e3e3d8;
  --radius:4px;
  --radius-sm:3px;
  --shadow:0 8px 40px rgba(22,32,21,.12);
  --font-head:'Plus Jakarta Sans',sans-serif;
  --font-body:'Inter',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:clip;overscroll-behavior-x:none;max-width:100%}
body{font-family:var(--font-body);color:var(--text);background:var(--white);line-height:1.65;font-size:16.5px}
h1,h2,h3,h4,h5{font-family:var(--font-head);color:var(--green);line-height:1.18;font-weight:800;overflow-wrap:normal}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
svg{display:block}
.container{max-width:1280px;margin:0 auto;padding:0 28px}
.container-wide{max-width:1460px;margin:0 auto;padding:0 28px}
section{padding:84px 0;position:relative}
.section-cream{background:var(--cream)}
.section-dark{background:var(--green);color:#dcded7}
.section-dark h2,.section-dark h3{color:#fff}

/* Eyebrow + headers */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:700;font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--green-soft);margin-bottom:16px}
.section-dark .eyebrow,.review-section .eyebrow,.cta-band .eyebrow{color:var(--tan)}
.section-h2,.intro-text h2,.about-text h2{text-transform:uppercase;letter-spacing:.015em}
.section-h2{font-size:clamp(1.65rem,2.9vw,2.45rem);text-wrap:balance}
.section-h2 .hl,.hero-h1 .hl,.hero-h1 .gold,.cta-band h2 .hl{background:linear-gradient(100deg,var(--tan) 0%,#e8dcc3 55%,var(--tan) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.split-header{display:grid;grid-template-columns:1fr;gap:28px;margin-bottom:48px}
@media(min-width:880px){.split-header{grid-template-columns:50% 50%;align-items:start;gap:40px}}
.split-header .right{padding-top:6px;color:var(--muted);font-size:17px;max-width:560px}
.section-dark .split-header .right{color:#bcc2b8}
.centered-header{text-align:center;max-width:780px;margin:0 auto 48px}
.centered-header .eyebrow{justify-content:center}
.centered-header p{color:var(--muted);margin-top:14px}

/* Watermark-Typografie */
.wm{position:absolute;top:6px;left:0;right:0;font-family:var(--font-head);font-weight:800;font-size:clamp(64px,10vw,150px);letter-spacing:.06em;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(30,43,29,.08);text-transform:uppercase;white-space:nowrap;overflow:clip;pointer-events:none;text-align:center;user-select:none}
.section-dark .wm,.review-section .wm{-webkit-text-stroke:1px rgba(239,239,231,.07)}
.section-cream .wm{-webkit-text-stroke:1px rgba(30,43,29,.07)}

/* Reveal (GSAP + Fallback) */
.reveal{opacity:0;transform:translateY(36px)}
.no-anim .reveal,.reveal.visible{opacity:1;transform:none;transition:opacity .8s ease,transform .8s cubic-bezier(.22,1,.36,1)}

/* ============ NAV (hell, Logo sichtbar) ============ */
.nav{position:sticky;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:16px 40px;background:var(--cream);border-bottom:1px solid var(--line);transition:box-shadow .35s ease,padding .35s ease,background .35s ease}
.nav.scrolled{background:rgba(247,247,242,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 6px 30px rgba(22,32,21,.1);padding:10px 40px}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo-img{height:64px;max-width:280px;object-fit:contain;transition:height .35s ease}
.nav.scrolled .nav-logo-img{height:54px}
.nav-logo-text{font-family:var(--font-head);font-size:27px;font-weight:800;color:var(--green)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links>a,.nav-item>a{color:var(--green);font-weight:600;font-size:15.5px;display:inline-flex;align-items:center;gap:6px;padding:8px 0;position:relative}
.nav-links>a::after,.nav-item>a::after{content:"";position:absolute;left:0;bottom:2px;width:0;height:2px;background:var(--tan);transition:width .3s ease}
.nav-links>a:hover::after,.nav-item>a:hover::after,.nav-links>a.active::after{width:100%}
.nav-caret{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}
.nav-item{position:relative}
.nav-dropdown{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;border-radius:var(--radius);box-shadow:0 18px 60px rgba(22,32,21,.16);padding:10px;min-width:350px;opacity:0;visibility:hidden;transition:all .28s ease}
.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown a{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:8px;color:var(--text);transition:background .2s}
.nav-dropdown a:hover{background:var(--cream)}
.ddimg{width:62px;height:46px;border-radius:3px;overflow:hidden;flex-shrink:0;background:var(--cream)}
.ddimg img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.nav-dropdown a:hover .ddimg img{transform:scale(1.08)}
.ddt{font-weight:700;font-size:15px;color:var(--green);display:flex;flex-direction:column;line-height:1.3}
.ddt small{font-weight:500;font-size:12.5px;color:var(--muted)}
.nav-cta{background:var(--petrol);color:#fff!important;padding:12px 24px!important;border-radius:var(--radius-sm);font-weight:700!important;transition:background .25s,transform .25s}
.nav-cta:hover{background:#02666f;transform:translateY(-1px)}
.nav-cta::after{display:none!important}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:6px}
.nav-burger svg{width:30px;height:30px;stroke:var(--green);fill:none;stroke-width:2}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:700;font-size:16px;padding:16px 30px;border-radius:var(--radius-sm);cursor:pointer;border:none;transition:transform .25s,background .25s,box-shadow .25s,color .25s}
.btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .25s}
.btn:hover svg{transform:translateX(4px)}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-soft);transform:translateY(-2px);box-shadow:0 12px 30px rgba(22,32,21,.28)}
.btn-light{background:var(--cream);color:var(--green)}
.btn-light:hover{background:#fff;transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.22)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ============ HERO (Home) ============ */
.hero{position:relative;min-height:calc(88svh - 97px);display:flex;align-items:center;overflow:clip;background:var(--green)}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:130px;background:linear-gradient(to bottom,rgba(30,43,29,0),var(--green));z-index:1;pointer-events:none}
.hero-bg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;will-change:transform}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(18,26,17,.84) 0%,rgba(18,26,17,.55) 48%,rgba(18,26,17,.22) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding:80px 0 120px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;background:rgba(239,239,231,.12);border:1px solid rgba(239,239,231,.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;font-weight:600;font-size:14px;padding:9px 18px;border-radius:3px;margin-bottom:26px}
.hero-eyebrow svg{width:16px;height:16px;stroke:var(--tan);fill:none;stroke-width:1.8}
.hero-h1{color:#fff;font-size:clamp(1.8rem,3.1vw,2.6rem);max-width:1240px;letter-spacing:.01em;text-transform:uppercase;line-height:1.22;text-shadow:0 2px 24px rgba(12,18,11,.5)}
.hero-h1{text-wrap:balance}
.hero-br{display:none}
@media(min-width:1024px){.hero-br{display:block}}
.hero-sub{color:rgba(255,255,255,.92);font-size:clamp(1rem,1.3vw,1.15rem);max-width:660px;margin-top:20px;text-shadow:0 1px 16px rgba(12,18,11,.55)}
.hero-cta-group{display:flex;flex-wrap:wrap;gap:16px;margin-top:32px}
.hero-scroll{position:absolute;bottom:26px;z-index:2;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.7);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase}
.hero-scroll svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.6;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}

/* ============ LOGO-BAND (dunkelgrün, weisse Kacheln) ============ */
.kunden-strip{padding:10px 0 58px;background:var(--green);position:relative;overflow:clip}
.kunden-strip::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 260px at 85% 0%,rgba(193,173,141,.12),transparent)}
.kunden-label{text-align:center;font-family:var(--font-head);font-weight:700;font-size:13.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--tan);margin-bottom:34px;position:relative}
.marquee{overflow:clip;position:relative;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;gap:78px;width:max-content;will-change:transform;animation:marquee 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee-track img{height:64px;width:auto;max-width:200px;object-fit:contain;opacity:.92;transition:opacity .3s,transform .3s;flex-shrink:0}
.marquee-track img:hover{opacity:1;transform:translateY(-3px)}

/* ============ INTRO (Ihr Raum. Ihr Traum.) ============ */
.intro-grid{display:grid;grid-template-columns:1fr;gap:54px;align-items:center}
@media(min-width:960px){.intro-grid{grid-template-columns:1.05fr .95fr}}
.intro-imgs{position:relative;min-height:420px}
.intro-img-1{width:78%;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.intro-img-1 img{width:100%;height:440px;object-fit:cover}
.intro-img-2{position:absolute;right:0;bottom:-44px;width:46%;border-radius:var(--radius);overflow:hidden;box-shadow:0 18px 50px rgba(22,32,21,.22);border:6px solid #fff}
.intro-img-2 img{width:100%;height:260px;object-fit:cover}
.intro-badge{position:absolute;top:-22px;right:6%;background:var(--green);color:#fff;border-radius:var(--radius);padding:18px 22px;box-shadow:var(--shadow);text-align:center}
.intro-badge .num{font-family:var(--font-head);font-weight:800;font-size:2rem;color:var(--tan);line-height:1}
.intro-badge .lbl{font-size:12.5px;color:#d5d8d0;margin-top:4px}
.intro-text h2{font-size:clamp(1.65rem,2.8vw,2.3rem);margin-bottom:20px}
.intro-text p{color:var(--muted);margin-bottom:16px}
.intro-pills{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 30px}
.pill{display:inline-flex;align-items:center;gap:8px;background:var(--green);border:1px solid var(--green);border-radius:3px;padding:10px 16px;font-family:var(--font-head);font-weight:700;font-size:12.5px;letter-spacing:.09em;text-transform:uppercase;color:#fff;transition:background .25s,border-color .25s,transform .25s}
.pill:hover{background:var(--green-soft);border-color:var(--tan);transform:translateY(-2px)}
.pill svg{width:14px;height:14px;stroke:var(--tan);fill:none;stroke-width:2}

/* ============ STATS (dunkelgrün, weisse Kacheln) ============ */
.stats-band{background:var(--green);padding:84px 0;position:relative;overflow:clip}
.stats-band::before{content:"";position:absolute;inset:0;background:radial-gradient(820px 320px at 80% 10%,rgba(193,173,141,.13),transparent)}
.stats-band .wm{-webkit-text-stroke:1px rgba(239,239,231,.06)}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;position:relative;z-index:1}
@media(min-width:880px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat{text-align:center;padding:40px 18px 36px;background:var(--cream-soft);border-radius:var(--radius);border-top:3px solid var(--tan);box-shadow:0 16px 44px rgba(0,0,0,.22);transition:transform .3s,box-shadow .3s}
.stat:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.3)}
.stat-num{font-family:var(--font-head);font-weight:800;font-size:clamp(2.2rem,3.6vw,3.2rem);color:var(--green);line-height:1}
.stat-num .suffix{background:linear-gradient(100deg,var(--tan) 0%,#a8946f 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{color:var(--muted);font-size:12.5px;margin-top:12px;font-weight:700;font-family:var(--font-head);letter-spacing:.12em;text-transform:uppercase}

/* ============ LEISTUNGEN GRID (schlicht, bildlastig, symmetrisch 3+2) ============ */
.leistungen-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:22px}
.leistung-tile{position:relative;display:block;height:330px;overflow:hidden;border-radius:4px;width:100%;box-shadow:0 6px 28px rgba(22,32,21,.12)}
@media(min-width:720px){.leistung-tile{width:calc(50% - 11px)}}
@media(min-width:1080px){
  .leistung-tile:nth-child(-n+2){width:calc(50% - 11px);height:400px}
  .leistung-tile:nth-child(n+3){width:calc(33.333% - 15px)}
}
.leistung-tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.22,1,.36,1)}
.leistung-tile:hover img{transform:scale(1.06)}
.leistung-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,26,17,.72) 0%,rgba(18,26,17,.18) 42%,rgba(18,26,17,0) 65%);transition:background .4s}
.leistung-tile:hover::after{background:linear-gradient(to top,rgba(18,26,17,.86) 0%,rgba(18,26,17,.42) 55%,rgba(18,26,17,.08) 100%)}
.lt-chip{position:absolute;left:18px;bottom:18px;z-index:2;background:var(--green);color:#fff;font-family:var(--font-head);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:12px 18px;display:inline-flex;align-items:center;gap:10px;border-radius:3px;transition:background .3s}
.lt-chip .num{color:var(--tan)}
.leistung-tile:hover .lt-chip{background:var(--green-deep)}
.lt-arrow{position:absolute;right:18px;bottom:18px;z-index:2;width:42px;height:42px;border-radius:3px;background:rgba(255,255,255,.94);display:flex;align-items:center;justify-content:center;transition:background .3s,transform .3s}
.lt-arrow svg{width:18px;height:18px;stroke:var(--green);fill:none;stroke-width:2;transition:transform .3s}
.leistung-tile:hover .lt-arrow{background:var(--tan)}
.leistung-tile:hover .lt-arrow svg{transform:translateX(3px)}
.lt-desc{position:absolute;left:20px;right:76px;bottom:72px;z-index:2;color:rgba(255,255,255,.94);font-size:14.5px;line-height:1.55;opacity:0;transform:translateY(10px);transition:opacity .4s,transform .4s}
.leistung-tile:hover .lt-desc{opacity:1;transform:none}

/* ============ REVIEWS (Full-Bleed-Bild links, dunkelgrün) ============ */
.review-section{background:var(--green);overflow:clip;padding:0;position:relative}
.review-bg-half{position:absolute;left:0;top:0;bottom:0;width:44%;background-size:cover;background-position:center;display:none}
@media(min-width:960px){.review-bg-half{display:block}}
.review-bg-half::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(30,43,29,0) 55%,var(--green) 99%)}
.review-img-badge{position:absolute;left:36px;bottom:36px;z-index:3;display:none}
@media(min-width:960px){.review-img-badge{display:block}}
.review-grid{display:grid;grid-template-columns:1fr;width:100%;padding:88px 0}
@media(min-width:960px){.review-grid{grid-template-columns:44% 1fr;gap:70px}}
.review-content{position:relative;z-index:2}
.review-stage{position:relative;min-height:300px;margin-top:34px}
.review-card{position:absolute;inset:0;background:none;border:none;padding:0;opacity:0;visibility:hidden;transform:translateY(18px);transition:all .55s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column}
.review-card.active{opacity:1;visibility:visible;transform:none}
.quote-mark{font-family:var(--font-head);font-size:4.6rem;color:var(--tan);line-height:.6;display:block;margin-bottom:20px}
.stars{color:var(--tan);font-size:19px;letter-spacing:3px;margin-bottom:16px}
.review-card p{color:#e2e4de;font-size:clamp(16.5px,1.35vw,19px);line-height:1.7;flex:1}
.review-who{display:flex;align-items:center;gap:14px;margin-top:28px}
.who-avatar{width:48px;height:48px;border-radius:3px;background:var(--tan);color:var(--green);font-family:var(--font-head);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:16px}
.who-name{color:#fff;font-weight:700;font-size:15.5px}
.who-meta{color:#9aa194;font-size:13.5px}
.review-nav{display:flex;align-items:center;gap:12px;margin-top:32px}
.review-dot{width:34px;height:4px;border-radius:4px;background:rgba(239,239,231,.22);border:none;cursor:pointer;transition:background .3s,width .3s}
.review-dot.active{background:var(--tan);width:52px}
.g-badge{display:inline-flex;align-items:center;gap:14px;background:#fff;border-radius:var(--radius);padding:14px 22px;box-shadow:0 14px 40px rgba(0,0,0,.3)}
.g-letter{font-family:var(--font-head);font-weight:800;font-size:30px;background:linear-gradient(45deg,#4285F4,#EA4335,#FBBC05,#34A853);-webkit-background-clip:text;background-clip:text;color:transparent}
.g-text strong{display:block;color:var(--green);font-size:15.5px}
.g-text small{color:var(--muted);font-size:12.5px}
.review-section h2{color:#fff}

/* ============ PROZESS (Scroll-Progress-Rail) ============ */
.prozess-grid{display:grid;grid-template-columns:1fr;gap:0;position:relative}
@media(min-width:880px){.prozess-grid{grid-template-columns:repeat(4,1fr);gap:30px;padding-top:76px}}
.prozess-rail{position:absolute;top:22px;left:11%;right:11%;height:2px;background:#dcdccf;display:none;z-index:0}
@media(min-width:880px){.prozess-rail{display:block}}
.prozess-rail-fill{height:100%;width:0%;background:var(--green)}
.prozess-step{position:relative;padding:34px 26px 30px;border-radius:var(--radius);background:#fff;border:1px solid var(--line);transition:transform .4s,box-shadow .4s,border-color .4s}
.prozess-step:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.prozess-step.active{border-color:var(--tan)}
.prozess-badge{position:absolute;top:-76px;left:50%;transform:translateX(-50%);width:46px;height:46px;border-radius:3px;background:var(--cream-soft);border:2px solid #dcdccf;display:none;align-items:center;justify-content:center;font-family:var(--font-head);font-weight:800;font-size:16px;color:var(--muted);transition:background .45s,color .45s,border-color .45s,transform .45s;z-index:1}
@media(min-width:880px){.prozess-badge{display:flex}}
.prozess-step.active .prozess-badge{background:var(--green);color:var(--tan);border-color:var(--green);transform:translateX(-50%) scale(1.08)}
.prozess-num-mobile{font-family:var(--font-head);font-weight:800;font-size:13px;letter-spacing:.12em;color:var(--tan);margin-bottom:10px;text-transform:uppercase}
@media(min-width:880px){.prozess-num-mobile{display:none}}
.prozess-step h3{font-size:18.5px;margin-bottom:10px}
.prozess-step p{color:var(--muted);font-size:14.8px}
.prozess-icon{width:52px;height:52px;border-radius:4px;background:rgba(30,43,29,.08);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:background .45s}
.prozess-icon svg{width:25px;height:25px;stroke:var(--green);fill:none;stroke-width:1.7;transition:stroke .45s}
.prozess-step.active .prozess-icon{background:var(--green)}
.prozess-step.active .prozess-icon svg{stroke:var(--tan)}
@media(max-width:879px){.prozess-step{margin-bottom:18px}}

/* ============ ABOUT / FAMILIENBETRIEB ============ */
.about-grid{display:grid;grid-template-columns:1fr;gap:54px;align-items:center}
@media(min-width:960px){.about-grid{grid-template-columns:.95fr 1.05fr}}
.about-img-wrap{position:relative}
.about-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.about-img img{width:100%;height:520px;object-fit:cover}
.about-badge{position:absolute;bottom:-26px;left:-18px;background:var(--green);border-radius:var(--radius);padding:22px 26px;box-shadow:0 14px 40px rgba(22,32,21,.3);max-width:230px}
@media(max-width:600px){.about-badge{left:10px}}
.about-badge .num{font-family:var(--font-head);font-weight:800;font-size:2.2rem;color:var(--tan);line-height:1}
.about-badge .lbl{font-size:13.5px;color:#e6e8e2;margin-top:5px;font-weight:600}
.about-text h2{font-size:clamp(1.65rem,2.8vw,2.3rem);margin-bottom:20px}
.about-text p{color:var(--muted);margin-bottom:16px}
.about-quote{border-left:3px solid var(--tan);padding:6px 0 6px 20px;font-family:var(--font-head);font-weight:700;font-size:19px;color:var(--green);margin:24px 0}
.feature-link{display:inline-flex;align-items:center;gap:9px;font-weight:700;color:var(--green-soft);font-size:16px}
.feature-link svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .25s}
.feature-link:hover svg{transform:translateX(5px)}
.check-list{list-style:none;margin:18px 0 8px}
.check-list li{display:flex;gap:12px;align-items:flex-start;margin-bottom:13px;color:var(--text)}
.check-list li svg{width:21px;height:21px;stroke:var(--green-soft);fill:none;stroke-width:2;flex-shrink:0;margin-top:2px}
.check-list li strong{color:var(--green)}
.section-dark .check-list li{color:#d3d6cf}
.section-dark .check-list li strong{color:#fff}
.section-dark .check-list li svg{stroke:var(--tan)}

/* ============ WERTE ============ */
.werte-grid{display:grid;grid-template-columns:1fr;gap:26px}
@media(min-width:880px){.werte-grid{grid-template-columns:repeat(3,1fr)}}
.wert-card{background:#fff;border-radius:var(--radius);padding:38px 32px;border:1px solid var(--line);transition:transform .3s,box-shadow .3s}
.wert-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.wert-icon{width:64px;height:64px;border-radius:4px;background:rgba(30,43,29,.08);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.wert-icon svg{width:30px;height:30px;stroke:var(--green);fill:none;stroke-width:1.6}
.wert-card h3{font-size:20px;margin-bottom:12px}
.wert-card p{color:var(--muted);font-size:15.2px}

/* ============ TV-SPOT ============ */
.tv-section{background:var(--cream)}
.tv-video-wrap{max-width:920px;margin:0 auto;border-radius:var(--radius);overflow:hidden;box-shadow:0 24px 70px rgba(22,32,21,.25);position:relative;background:var(--green)}
.tv-video-wrap video{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:#000}
.tv-sender{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px 38px;margin-top:36px}
.tv-sender span{font-family:var(--font-head);font-weight:800;font-size:clamp(17px,1.6vw,22px);letter-spacing:.06em;color:var(--green);opacity:.55;text-transform:uppercase;transition:opacity .3s}
.tv-sender span:hover{opacity:.9}
.tv-sender .dot{width:5px;height:5px;border-radius:50%;background:var(--tan);opacity:1;padding:0}
.tv-badge{display:inline-flex;align-items:center;gap:9px;background:var(--green);color:#fff;font-family:var(--font-head);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;padding:10px 18px;border-radius:3px;margin-bottom:18px}
.tv-badge svg{width:16px;height:16px;stroke:var(--tan);fill:none;stroke-width:1.8}

/* Hero-Proof-Zeile */
.hero-proof{display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;margin-top:34px;color:rgba(255,255,255,.66);font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.hero-proof svg{width:17px;height:17px;stroke:var(--tan);fill:none;stroke-width:1.8}
.hero-proof strong{color:rgba(255,255,255,.92);font-weight:700}

/* ============ CTA BAND (dunkelgrün, edel) ============ */
.cta-band{position:relative;padding:110px 0;overflow:clip;background:var(--green)}
.cta-band-bg{position:absolute;inset:-10% 0;background-size:cover;background-position:center;will-change:transform}
.cta-band-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(22,32,21,.93) 0%,rgba(22,32,21,.82) 55%,rgba(22,32,21,.68) 100%)}
.cta-band .container{position:relative;z-index:2;text-align:center}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3.1vw,2.55rem);max-width:760px;margin:0 auto 18px;text-transform:uppercase;letter-spacing:.015em}
.cta-band p{color:rgba(239,239,231,.82);max-width:560px;margin:0 auto 34px;font-size:17.5px}
.cta-band .eyebrow{justify-content:center}

/* ============ GALERIE (nahtlos, symmetrisch) ============ */
.galerie-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(180px,26vw,260px);gap:16px}
@media(min-width:880px){.galerie-grid{grid-template-columns:repeat(3,1fr);grid-auto-rows:clamp(240px,23vw,330px)}}
.galerie-item{border-radius:var(--radius);overflow:hidden;cursor:zoom-in;position:relative;background:var(--line);height:100%}
.galerie-item img{width:100%;height:100%;object-fit:cover;transition:transform .65s cubic-bezier(.22,1,.36,1)}
.galerie-item:hover img{transform:scale(1.06)}
.galerie-item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(22,32,21,.38),transparent 45%);opacity:0;transition:opacity .4s}
.galerie-item:hover::after{opacity:1}
.galerie-zoom{position:absolute;right:14px;bottom:14px;width:40px;height:40px;border-radius:3px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(8px);transition:all .35s;z-index:2}
.galerie-item:hover .galerie-zoom{opacity:1;transform:none}
.galerie-zoom svg{width:19px;height:19px;stroke:var(--green);fill:none;stroke-width:2}
.galerie-item.wide{grid-column:span 2}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(18,24,17,.95);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;padding:40px}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 90px rgba(0,0,0,.6);object-fit:contain}
.lightbox-close{position:absolute;top:26px;right:30px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .25s}
.lightbox-close:hover{background:rgba(255,255,255,.22)}
.lightbox-close svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2}
.lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:50%;width:52px;height:52px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .25s}
.lightbox-arrow:hover{background:rgba(255,255,255,.22)}
.lightbox-arrow svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2}
.lightbox-prev{left:26px}.lightbox-next{right:26px}
@media(max-width:700px){.lightbox-arrow{width:42px;height:42px}.lightbox-prev{left:10px}.lightbox-next{right:10px}}

/* ============ FAQ ============ */
.faq-grid{display:grid;grid-template-columns:1fr;gap:14px;max-width:880px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:box-shadow .3s,border-color .3s}
.faq-item.open{box-shadow:var(--shadow);border-color:var(--petrol);border-bottom-width:2px}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;background:none;border:none;text-align:left;font-family:var(--font-head);font-weight:700;font-size:17px;color:var(--green);padding:22px 26px;cursor:pointer}
.faq-q .plus{width:34px;height:34px;border-radius:3px;background:var(--cream);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .35s,background .35s}
.faq-q .plus svg{width:16px;height:16px;stroke:var(--green);fill:none;stroke-width:2.2;transition:stroke .3s}
.faq-item.open .plus svg{stroke:#fff}
.faq-item.open .plus{transform:rotate(45deg);background:var(--petrol)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.22,1,.36,1)}
.faq-item.open .faq-a{max-height:340px}
.faq-a-inner{padding:0 26px 24px;color:var(--muted);font-size:15.5px}

/* ============ KONTAKT ============ */
.contact-grid{display:grid;grid-template-columns:1fr;gap:36px}
@media(min-width:960px){.contact-grid{grid-template-columns:.9fr 1.1fr}}
.contact-card{background:#fff;border-radius:var(--radius);padding:38px 36px;box-shadow:var(--shadow)}
.contact-line{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--cream);font-size:16px}
.contact-line:last-of-type{border-bottom:none}
.contact-line svg{width:20px;height:20px;stroke:var(--green-soft);fill:none;stroke-width:1.8;flex-shrink:0}
.contact-line a:hover{color:var(--green-soft);text-decoration:underline}
.contact-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:420px}
.contact-map iframe{width:100%;height:100%;min-height:420px;border:0;display:block}

/* Forms */
.form-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:680px){.form-grid{grid-template-columns:1fr 1fr}.form-grid .full{grid-column:span 2}}
.form-field label{display:block;font-weight:600;font-size:14.5px;margin-bottom:7px;color:var(--green)}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:16px;background:var(--cream-soft);color:var(--green);transition:border-color .25s,box-shadow .25s}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--green-soft);box-shadow:0 0 0 3px rgba(30,43,29,.12)}
.form-field textarea{min-height:140px;resize:vertical}
.form-note{font-size:13px;color:var(--muted);margin-top:14px}

/* ============ MULTI-STEP FORMULAR ============ */
.ms-progress{margin-bottom:30px}
.ms-progress-label{display:flex;justify-content:space-between;font-size:13.5px;font-weight:600;color:var(--muted);margin-bottom:9px}
.ms-progress-label strong{color:var(--green)}
.ms-progress-track{height:7px;background:var(--cream);border-radius:10px;overflow:hidden}
.ms-progress-bar{height:100%;width:33%;background:linear-gradient(90deg,var(--green-soft),var(--green));border-radius:10px;transition:width .5s cubic-bezier(.22,1,.36,1)}
.ms-step{display:none;animation:msIn .45s cubic-bezier(.22,1,.36,1)}
.ms-step.active{display:block}
@keyframes msIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.ms-step h3{font-size:clamp(1.2rem,2.2vw,1.5rem);margin-bottom:8px}
.ms-step .ms-sub{color:var(--muted);font-size:15px;margin-bottom:24px}
.ms-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:760px){.ms-tiles.cols-3{grid-template-columns:repeat(3,1fr)}}
.ms-tile{background:var(--cream-soft);border:1.5px solid var(--line);border-radius:var(--radius);padding:22px 16px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;font-family:var(--font-head);font-weight:700;font-size:15px;color:var(--green);text-align:center;transition:border-color .25s,background .25s,transform .25s,box-shadow .25s}
.ms-tile:hover{border-color:var(--green-soft);background-color:#fff;transform:translateY(-3px);box-shadow:0 10px 26px rgba(22,32,21,.1)}
.ms-tile.selected{border-color:var(--green);background-color:#fff;box-shadow:0 10px 26px rgba(22,32,21,.14)}
.ms-tile svg{width:30px;height:30px;stroke:var(--green);fill:none;stroke-width:1.6}
.ms-tile-img,.ms-tile-img:hover,.ms-tile-img.selected{background-size:cover!important;background-position:center!important}
.ms-tile-img{position:relative;overflow:clip;padding:0;min-height:116px;justify-content:flex-end;border-width:2px}
.ms-tile-img::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,26,17,.82) 0%,rgba(18,26,17,.18) 62%);transition:background .3s}
.ms-tile-img:hover::before{background:linear-gradient(to top,rgba(18,26,17,.88) 0%,rgba(18,26,17,.32) 70%)}
.ms-tile-img .ms-tile-label{position:relative;z-index:2;color:#fff;font-family:var(--font-head);font-weight:700;font-size:14px;line-height:1.3;padding:12px 10px;width:100%;text-align:center;text-shadow:0 1px 10px rgba(0,0,0,.4)}
.ms-tile-img.selected{border-color:var(--tan);box-shadow:0 10px 26px rgba(22,32,21,.25)}
.ms-tile-img.selected::after{content:"";position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;background:var(--tan) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="%231e2b1d" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><path d="M5 13l4 4L19 7"/></svg>') center/13px no-repeat;z-index:3}
.ms-back{display:inline-flex;align-items:center;gap:7px;background:none;border:none;color:var(--muted);font-weight:600;font-size:14px;cursor:pointer;margin-top:22px;padding:6px 0}
.ms-back:hover{color:var(--green)}
.ms-back svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}
.ms-banner{display:flex;align-items:center;gap:12px;background:#e8f8ee;border:1px solid #bfe9cf;color:#1e7a43;border-radius:var(--radius-sm);padding:14px 18px;font-weight:700;font-size:15px;margin-bottom:24px}
.ms-banner svg{width:22px;height:22px;stroke:#27ae60;fill:none;stroke-width:2.4;flex-shrink:0}

/* ============ PAGE HERO (Unterseiten) ============ */
.page-hero{position:relative;min-height:56vh;display:flex;align-items:flex-end;background:var(--green);overflow:clip}
.page-hero-bg{position:absolute;inset:-10% 0;background-size:cover;background-position:center;will-change:transform}
.page-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(18,26,17,.88) 8%,rgba(18,26,17,.36) 60%,rgba(18,26,17,.42))}
.page-hero .container{position:relative;z-index:2;padding-bottom:64px;padding-top:120px}
.page-hero h1{color:#fff;font-size:clamp(1.7rem,3.4vw,2.7rem);max-width:920px;letter-spacing:.015em;text-transform:uppercase;text-wrap:balance}
.page-hero .breadcrumb{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.78);font-size:14px;margin-bottom:18px;font-weight:600}
.page-hero .breadcrumb a:hover{color:var(--tan)}
.page-hero .breadcrumb svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2}
.page-hero p.lead{color:rgba(255,255,255,.86);font-size:17.5px;max-width:640px;margin-top:18px}

/* ============ LEISTUNG DETAIL ============ */
.detail-grid{display:grid;grid-template-columns:1fr;gap:50px;align-items:center}
@media(min-width:960px){.detail-grid{grid-template-columns:1.05fr .95fr}}
.detail-img{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.detail-img img{width:100%;height:460px;object-fit:cover}

/* Angebot + Sidebar Layout */
.angebot-layout{display:grid;grid-template-columns:1fr;gap:40px;align-items:stretch}
@media(min-width:1020px){.angebot-layout{grid-template-columns:1fr 330px}}
.angebot-grid{display:grid;grid-template-columns:1fr;gap:20px;grid-auto-rows:1fr;align-content:stretch}
@media(min-width:680px){.angebot-grid{grid-template-columns:repeat(2,1fr)}
.angebot-grid .angebot-card:last-child:nth-child(odd){grid-column:span 2}}
.angebot-card{background:#fff;border-radius:var(--radius);padding:30px 28px;border:1px solid var(--line);transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;flex-direction:column;justify-content:center}
.angebot-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--tan)}
.angebot-card h4{font-size:17.5px;margin-bottom:9px;display:flex;align-items:flex-start;gap:11px}
.angebot-card h4 svg{width:21px;height:21px;stroke:var(--green-soft);fill:none;stroke-width:2;flex-shrink:0;margin-top:2px}
.angebot-card p{color:var(--muted);font-size:14.8px}

/* Service-Sidebar (rechts, klebend, mit Bildern) */
.service-sidebar{position:sticky;top:120px;display:flex;flex-direction:column;gap:22px;align-self:start}
.sidebar-card{background:#fff;border-radius:var(--radius);box-shadow:0 4px 24px rgba(22,32,21,.08);overflow:hidden;border:1px solid var(--line)}
.sidebar-card-head{background:var(--green);color:#fff;font-family:var(--font-head);font-weight:800;font-size:15px;letter-spacing:.08em;text-transform:uppercase;padding:17px 22px}
.sb-tiles{display:grid;gap:9px;padding:12px}
.sb-tile{display:grid;grid-template-columns:64px 1fr;gap:13px;align-items:center;padding:8px;background:var(--cream-soft);border:1px solid var(--line);border-radius:3px;transition:transform .25s,border-color .25s,box-shadow .25s,background .25s}
.sb-tile:hover{transform:translateX(4px);border-color:var(--tan);box-shadow:0 8px 22px rgba(22,32,21,.1)}
.sb-tile.active{background:var(--green);border-color:var(--green)}
.sb-tile-img{width:64px;height:54px;border-radius:2px;overflow:hidden;background:var(--cream)}
.sb-tile-img img{width:100%;height:100%;object-fit:cover}
.sb-tile-num{font-family:var(--font-head);font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--tan);margin-bottom:2px}
.sb-tile-title{font-family:var(--font-head);font-size:14px;font-weight:700;line-height:1.25;color:var(--green)}
.sb-tile.active .sb-tile-title{color:#fff}
.sidebar-cta{background:var(--green);border-radius:var(--radius);padding:28px 26px;color:#dcded7;box-shadow:var(--shadow)}
.sidebar-cta h4{color:#fff;font-size:18px;margin-bottom:10px}
.sidebar-cta p{font-size:14px;margin-bottom:18px}
.sidebar-cta .btn{width:100%;justify-content:center;padding:13px 18px;font-size:14.5px}
.sidebar-phone{display:flex;align-items:center;gap:9px;margin-top:14px;font-weight:700;color:#fff;font-size:15px;justify-content:center}
.sidebar-phone svg{width:16px;height:16px;stroke:var(--tan);fill:none;stroke-width:2}

/* ============ SOCIAL FLOAT (rechte Seite) ============ */
.social-float{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:899;display:flex;flex-direction:column;gap:2px}
.social-float a{width:46px;height:46px;background:var(--petrol);display:flex;align-items:center;justify-content:center;border-radius:3px 0 0 3px;transition:background .25s,transform .25s;box-shadow:-4px 4px 18px rgba(22,32,21,.22)}
.social-float a:hover{background:#02666f;transform:translateX(-4px)}
.social-float svg{width:21px;height:21px;stroke:#fff;fill:none;stroke-width:1.8}
@media(max-width:700px){.social-float a{width:40px;height:40px}.social-float svg{width:18px;height:18px}}

/* ============ TEAM ============ */
.team-grid{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:780px){.team-grid{grid-template-columns:repeat(3,1fr)}}
.team-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 4px 24px rgba(22,32,21,.07);transition:transform .3s,box-shadow .3s}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.team-photo{height:330px;overflow:hidden;background:var(--cream)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s}
.team-card:hover .team-photo img{transform:scale(1.05)}
.team-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.team-photo-placeholder svg{width:90px;height:90px;stroke:var(--tan);fill:none;stroke-width:1.2}
.team-body{padding:22px 26px 26px}
.team-body .name{font-family:var(--font-head);font-weight:800;font-size:19px;color:var(--green)}
.team-body .role{color:var(--muted);font-size:14.5px;margin-top:4px}

/* ============ FOOTER (dunkelgrün) ============ */
footer{background:var(--green);color:#bcc2b8;padding:80px 0 32px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:44px;margin-bottom:54px}
@media(min-width:880px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.foot-brand img{height:78px;width:auto;object-fit:contain;margin-bottom:20px}
.foot-brand p{font-size:14.8px;max-width:330px}
.foot-col h5{color:#fff;font-size:15.5px;margin-bottom:18px;letter-spacing:.02em}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:11px}
.foot-col a{color:#bcc2b8;font-size:14.8px;transition:color .25s}
.foot-col a:hover{color:var(--tan)}
.foot-contact-line{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:14.8px}
.foot-contact-line svg{width:16px;height:16px;stroke:var(--tan);fill:none;stroke-width:1.8;flex-shrink:0}
.foot-bottom{border-top:1px solid rgba(239,239,231,.14);padding-top:26px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:13.5px;color:#99a093}
.foot-bottom a{color:#bcc2b8}
.foot-bottom a:hover{color:var(--tan)}

.nav-backdrop{display:none}
@media(max-width:1023px){.nav-backdrop{display:block}}

/* ============ FLOAT CALL ============ */
.float-call{position:fixed;right:24px;bottom:24px;z-index:900;width:60px;height:60px;border-radius:50%;background:var(--petrol);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(1,80,89,.45);animation:pulse-call 2.4s infinite;transition:transform .25s}
.float-call:hover{transform:scale(1.08)}
.float-call svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:2}
@keyframes pulse-call{0%{box-shadow:0 10px 30px rgba(1,80,89,.45),0 0 0 0 rgba(1,80,89,.45)}70%{box-shadow:0 10px 30px rgba(1,80,89,.45),0 0 0 18px rgba(1,80,89,0)}100%{box-shadow:0 10px 30px rgba(1,80,89,.45),0 0 0 0 rgba(1,80,89,0)}}

/* ============ EXIT-INTENT POPUP ============ */
.exit-popup{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.exit-popup.open{opacity:1;visibility:visible}
.exit-popup-backdrop{position:absolute;inset:0;background:rgba(18,24,17,.8);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.exit-popup-card{position:relative;z-index:2;background:#fff;border-radius:6px;max-width:560px;width:100%;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,.5);transform:translateY(26px) scale(.97);transition:transform .45s cubic-bezier(.22,1,.36,1)}
.exit-popup.open .exit-popup-card{transform:none}
.exit-popup-img{height:200px;background-size:cover;background-position:center;position:relative}
.exit-popup-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(22,32,21,.55),transparent)}
.exit-popup-body{padding:36px 40px 40px;text-align:center}
.exit-popup-body h3{font-size:clamp(1.4rem,2.6vw,1.8rem);margin-bottom:14px}
.exit-popup-body p{color:var(--muted);margin-bottom:26px;font-size:16px}
.exit-popup-close{position:absolute;top:14px;right:14px;z-index:3;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.92);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s}
.exit-popup-close:hover{background:#fff}
.exit-popup-close svg{width:18px;height:18px;stroke:var(--green);fill:none;stroke-width:2.2}

/* ============ DANKE PAGE ============ */
.danke-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:100px 24px 80px}
.danke-icon{width:90px;height:90px;border-radius:50%;background:#e8f8ee;display:flex;align-items:center;justify-content:center;margin:0 auto 28px}
.danke-icon svg{width:44px;height:44px;stroke:#27ae60;fill:none;stroke-width:2.4}
.danke-wrap h1{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:16px}
.danke-wrap p{color:var(--muted);max-width:480px;margin:0 auto 32px}

/* ============ LEGAL ============ */
.legal-wrap{max-width:840px;margin:0 auto;padding:90px 28px}
.legal-wrap h1{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:34px}
.legal-wrap h3{font-size:20px;margin:34px 0 12px}
.legal-wrap p,.legal-wrap li{color:var(--muted);font-size:15.5px;margin-bottom:12px}
.legal-wrap ul{padding-left:22px}
.legal-wrap a{color:var(--green-soft);font-weight:600;text-decoration:underline}

/* ============ MOBILE NAV ============ */
@media(max-width:1023px){
  .nav{padding:12px 20px;z-index:1100}
  /* WICHTIG: kein backdrop-filter auf Mobil — sonst wird die Navi zum Bezugsrahmen
     des fixed-Menüs und es bricht beim Scrollen zusammen */
  .nav.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none}
  .nav-logo-img{height:52px}
  .nav-burger{display:block;position:relative;z-index:1102}
  .nav-links{position:fixed;top:0;right:0;bottom:0;height:100dvh;width:min(360px,88vw);background:var(--cream);flex-direction:column;align-items:flex-start;gap:4px;padding:90px 32px 40px;transform:translateX(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:-20px 0 60px rgba(22,32,21,.3);z-index:1101}
  .nav-links.open{transform:none}
  .nav-backdrop{position:fixed;inset:0;background:rgba(18,24,17,.5);opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease;z-index:1090}
  body.nav-open .nav-backdrop{opacity:1;visibility:visible}
  body.nav-open{overflow:hidden}
  .hero-cta-group .btn-ghost{display:none}
  .hero-cta-group .btn-light{width:100%;justify-content:center}
  .nav-links>a,.nav-item>a{font-size:18px;padding:12px 0;width:100%}
  .nav-item{width:100%}
  .nav-dropdown{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:rgba(30,43,29,.04);border-left:2px solid var(--tan);min-width:0;width:100%;left:auto;right:auto;margin:6px 0 8px;padding:6px 6px 8px;border-radius:0 4px 4px 0;display:none}
  .nav-item.open .nav-dropdown{display:block}
  /* Touch/iOS: Desktop-Hover-Transform auf Mobile neutralisieren, sonst rutscht das Dropdown nach links */
  .nav-item:hover .nav-dropdown{position:static;transform:none;left:auto;right:auto;opacity:1;visibility:visible}
  .nav-dropdown a{padding:10px 8px}
  .nav-dropdown a:hover{background:rgba(30,43,29,.06)}
  .nav-cta{margin-top:18px;width:100%;justify-content:center;display:inline-flex;text-align:center}
  .legal-wrap h1{font-size:1.4rem}
  .hero-bg::after{background:linear-gradient(180deg,rgba(18,26,17,.72) 0%,rgba(18,26,17,.6) 45%,rgba(18,26,17,.74) 100%)}
  .hero-h1{font-size:1.42rem;letter-spacing:0;line-height:1.26}
  .page-hero h1{font-size:1.34rem;letter-spacing:0;line-height:1.26}
  .section-h2{font-size:1.38rem}
  .hero-proof{font-size:11.5px;gap:8px 12px;letter-spacing:.06em}
  section{padding:70px 0}
  .review-card{padding:30px 26px}
  .review-stage{min-height:430px}
  .exit-popup-body{padding:28px 24px 32px}
  .service-sidebar{position:static}
  .marquee-track img{height:48px;max-width:150px}
  .marquee-track{gap:48px}
}
@media(max-width:600px){
  .galerie-grid{gap:10px}
  .intro-imgs{min-height:0}
  .intro-img-1 img{height:320px}
  .intro-img-2{bottom:-30px}
  .intro-img-2 img{height:170px}
  .about-img img{height:380px}
  .stats-grid{gap:14px}
  .stat{padding:26px 12px}
  .container,.container-wide{padding:0 20px}
  .ms-tiles{grid-template-columns:1fr 1fr}
}
/* ===== Bewertungen: Leistungsbild ===== */
.review-stage{min-height:470px}
.review-media{width:100%;height:178px;border-radius:var(--radius);overflow:hidden;margin-bottom:24px;box-shadow:0 14px 38px rgba(0,0,0,.3)}
.review-media img{width:100%;height:100%;object-fit:cover;object-position:center}
.review-card .quote-mark{margin-bottom:14px}

/* ===== Meisterbetrieb-Siegel (Hero) ===== */
.hero-siegel{position:absolute;top:26px;right:26px;z-index:4;width:118px;height:118px;opacity:.8;filter:drop-shadow(0 8px 22px rgba(0,0,0,.32));animation:siegel-float 5.5s ease-in-out infinite}
.hero-siegel svg{width:100%;height:100%;display:block}
.hero-siegel .siegel-ring{animation:siegel-spin 30s linear infinite;transform-origin:60px 60px}
@keyframes siegel-spin{to{transform:rotate(360deg)}}
@keyframes siegel-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@media(max-width:780px){.hero-siegel{width:92px;height:92px;top:16px;right:16px}}

/* ===== Karriere: Bereiche & Recruiting ===== */
.karriere-roles{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:680px){.karriere-roles{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.karriere-roles{grid-template-columns:repeat(3,1fr)}}
.role-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s;position:relative}
.role-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--tan)}
.role-card-img{height:188px;overflow:hidden;background:var(--cream)}
.role-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.role-card:hover .role-card-img img{transform:scale(1.06)}
.role-card-body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.role-card-body .role-eyebrow{font-family:var(--font-head);font-weight:700;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--petrol);margin-bottom:10px}
.role-card-body h3{font-size:20px;margin-bottom:10px}
.role-card-body p{color:var(--muted);font-size:15px;flex:1}
.role-card-link{display:inline-flex;align-items:center;gap:9px;margin-top:18px;font-weight:700;color:var(--green-soft);font-size:15.5px}
.role-card-link svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .3s}
.role-card:hover .role-card-link svg{transform:translateX(4px)}

.benefits-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:680px){.benefits-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.benefits-grid{grid-template-columns:repeat(3,1fr)}}
.benefit-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;transition:transform .3s,box-shadow .3s}
.benefit-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.benefit-icon{width:56px;height:56px;border-radius:14px;background:rgba(1,80,89,.1);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.benefit-icon svg{width:27px;height:27px;stroke:var(--petrol);fill:none;stroke-width:1.7}
.benefit-card h3{font-size:18px;margin-bottom:9px}
.benefit-card p{color:var(--muted);font-size:14.8px}

.prakt-quote{max-width:860px;margin:0 auto;text-align:center}
.prakt-quote .stars{color:var(--tan);font-size:22px;letter-spacing:4px;justify-content:center;display:block;margin-bottom:20px}
.prakt-quote blockquote{font-family:var(--font-head);font-weight:600;font-size:clamp(18px,2vw,23px);line-height:1.6;color:#fff;margin:0}
.prakt-quote .prakt-who{margin-top:26px;color:var(--tan);font-weight:700;font-size:16px}
.prakt-quote .prakt-meta{color:#9aa194;font-size:14px;margin-top:4px}

@media(max-width:1024px){.review-stage{min-height:560px}}
@media(max-width:560px){.review-media{height:150px}.review-stage{min-height:600px}}

/* ===== Leistungen: Fließtext ===== */
.leistung-prose{margin-top:56px;padding-top:48px;border-top:1px solid rgba(30,43,29,.1)}
.leistung-prose h3{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.015em;font-size:clamp(1.25rem,2.1vw,1.6rem);margin-bottom:22px;text-wrap:balance}
.lp-cols{display:grid;gap:0 48px;grid-template-columns:1fr}
@media(min-width:880px){.lp-cols{grid-template-columns:1fr 1fr}}
.lp-cols p{color:var(--muted);margin-bottom:14px;line-height:1.75}
.lp-cols p:last-child{margin-bottom:0}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
