/* Roboto – lokal gehostet (Variable Font, 100–900). Datei: /font/Roboto.woff2 */
@font-face{font-family:'Roboto';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('../font/Roboto.woff2') format('woff2')}

:root{
  --ink:#34363a;--ink-2:#2b2d30;--ink-soft:#52555b;--muted:#878c93;
  --line:#e6e8e6;--paper:#ffffff;--paper-2:#f4f6f2;--grey:#eceee9;
  --g1:#8ac642;--g1-bright:#9bd650;--g2:#569624;
  --grad:linear-gradient(100deg,var(--g2),var(--g1) 55%,var(--g1-bright));
  --shadow-1:0 2px 10px rgba(52,54,58,.07);--shadow-2:0 24px 60px -24px rgba(52,54,58,.4);
  --ease:cubic-bezier(.22,.61,.36,1);--wrap:1280px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Roboto,system-ui,Arial,sans-serif;color:var(--ink);background:var(--paper);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.lock{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:min(100% - 48px,var(--wrap));margin-inline:auto}

.eyebrow{display:inline-flex;align-items:center;gap:11px;font-size:.72rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--g2)}
.bars{display:inline-flex;align-items:flex-end;gap:2px;height:13px}
.bars i{width:3px;background:var(--grad);border-radius:1px;display:block}
.bars i:nth-child(1){height:6px}.bars i:nth-child(2){height:13px}.bars i:nth-child(3){height:9px}

/* ---------- Header ---------- */
.head{position:sticky;top:0;z-index:80;background:#fff;
  border-bottom:1px solid transparent;transition:padding .35s var(--ease),
  box-shadow .35s var(--ease),border-color .35s var(--ease)}
.head .topline{height:4px;background:var(--grad)}
.head-in{display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:12px 24px;width:min(100% - 0px,calc(var(--wrap) + 48px));margin-inline:auto}
.head.scrolled{box-shadow:var(--shadow-1);border-bottom-color:var(--line)}
.brand img{height:88px;width:auto}
.nav{display:flex;align-items:center;gap:34px}
.nav a:not(.cta){position:relative;font-weight:500;font-size:1rem;padding:6px 0;transition:color .2s var(--ease)}
.nav a:not(.cta)::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}
.nav a:not(.cta):hover{color:var(--g2)}
.nav a:not(.cta):hover::after,.nav a.active::after{transform:scaleX(1)}
.nav .cta{background:var(--grad);color:#fff;padding:11px 22px;border-radius:999px;font-weight:700;
  box-shadow:0 8px 20px -8px var(--g2);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.nav .cta:hover{transform:translateY(-2px);box-shadow:0 14px 26px -10px var(--g2)}
.burger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:#fff;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer;z-index:90}
.burger span{width:22px;height:2px;background:var(--ink);transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.scrim{position:fixed;inset:0;background:rgba(20,21,23,.45);opacity:0;pointer-events:none;
  transition:opacity .35s var(--ease);z-index:70}
.scrim.show{opacity:1;pointer-events:auto}

/* ---------- Hero ---------- */
.hero{position:relative;isolation:isolate;background:var(--ink);overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media video,.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.62;transform:scale(1.06) translateZ(0);
  will-change:transform;backface-visibility:hidden}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,rgba(52,54,58,.86) 26%,rgba(52,54,58,.46) 70%,rgba(86,150,36,.3))}
.hero-in{padding-block:clamp(70px,12vw,140px);max-width:900px}
.hero .eyebrow{color:var(--g1-bright)}
.hero h1{color:#fff;font-weight:900;letter-spacing:-.025em;line-height:1.02;
  font-size:clamp(2.5rem,7vw,5.4rem);margin:.35em 0 .55em}
.hero h1 em{font-style:normal;color:var(--g1-bright)}
.hero p{color:#dfe2e3;font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:620px;font-weight:300}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:999px;font-weight:700;
  font-size:1rem;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 12px 30px -12px var(--g1)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 36px -14px var(--g1)}
.btn-ghost{color:#fff;border:1px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.1);transform:translateY(-3px)}
.btn .arr{transition:transform .25s var(--ease)}.btn:hover .arr{transform:translateX(4px)}
.hero-strip{position:relative;z-index:2;background:rgba(255,255,255,.06);border-top:1px solid rgba(255,255,255,.12)}
.hero-strip-in{display:flex;flex-wrap:wrap;gap:24px 54px;padding-block:22px;color:#cdd0d2;font-size:.85rem;letter-spacing:.03em}
.hero-strip b{color:#fff;font-weight:900;font-size:1.5rem;margin-right:8px}

/* ---------- Section base ---------- */
.sec{padding-block:clamp(66px,8.5vw,116px);position:relative}
.sec-head{max-width:680px;margin-bottom:48px}
.sec-head h1,.sec-head h2{font-weight:900;letter-spacing:-.02em;line-height:1.05;font-size:clamp(2rem,4.4vw,3.4rem);margin:.3em 0 .35em}
.sec-head p{color:var(--ink-soft);font-size:1.1rem;font-weight:300}
.sec-head h1 .hl,.sec-head h2 .hl{color:var(--g2)}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}

/* ---------- Leistungen: single icons ---------- */
.leistungen{position:relative;background:var(--paper-2);overflow:hidden}
.leistungen::before{content:"";position:absolute;inset:0;background-image:url('img/bg-leistungen.jpg');
  background-size:cover;background-position:center;opacity:.06;filter:grayscale(1)}
.leistungen .wrap{position:relative}
.lgrid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.lico{background:none;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;
  gap:12px;padding:14px 6px;border-radius:16px;transition:transform .35s var(--ease),background .3s}
.lico img{width:104px;height:104px;object-fit:contain;
  filter:drop-shadow(0 10px 16px rgba(52,54,58,.16));transition:transform .35s var(--ease)}
.lico span{font-weight:600;font-size:1rem;color:var(--ink);transition:color .25s var(--ease)}
.lico:hover{transform:translateY(-6px)}
.lico:hover img{transform:scale(1.08)}
.lico:hover span,.lico.active span{color:var(--g2);font-weight:700}
.lico.active{background:rgba(255,255,255,.7)}
.lpanel{grid-column:1 / -1;overflow:hidden;max-height:0;opacity:0;margin-top:0;
  background:#fff;border:1px solid transparent;border-radius:18px;box-shadow:none;
  padding:0 30px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;
  transition:max-height .45s var(--ease),opacity .35s var(--ease),margin-top .35s var(--ease),padding .35s var(--ease),border-color .35s,box-shadow .35s}
.lpanel.show{max-height:420px;opacity:1;margin-top:18px;padding:26px 30px;border-color:var(--line);box-shadow:var(--shadow-1)}
.lpanel h3{font-size:1.3rem;font-weight:700;margin-bottom:6px}
.lpanel p{color:var(--ink-soft);max-width:620px}
.lpanel a{display:inline-flex;align-items:center;gap:8px;color:var(--g2);font-weight:700;white-space:nowrap;margin-top:4px}
.lpanel a .arr{transition:transform .25s var(--ease)}.lpanel a:hover .arr{transform:translateX(4px)}

/* ---------- Kunden ---------- */
.kunden{background:var(--paper)}
.logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:30px 60px}
.logos a{position:relative;display:block;height:clamp(74px,8.5vw,108px)}
.logos img{height:clamp(74px,8.5vw,108px);width:auto;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.logos .lg-hover{position:absolute;left:0;top:0;opacity:0}
.logos a:hover .lg-base{opacity:0}
.logos a:hover .lg-hover{opacity:1}
.logos a:hover img{transform:translateY(-2px)}

/* ---------- Works gallery ---------- */
.works{background:var(--paper)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:230px;gap:18px}
.work{position:relative;border-radius:20px;overflow:hidden;background:var(--ink);box-shadow:var(--shadow-1)}
.work.wide{grid-column:span 2}.work.tall{grid-row:span 2}
.work>img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.work:hover>img{transform:scale(1.06)}
.work-cap{position:absolute;left:0;right:0;bottom:0;padding:20px 18px 16px;color:#fff;line-height:1.35;
  font-size:.84rem;background:linear-gradient(to top,rgba(18,19,21,.9),rgba(18,19,21,.15) 70%,transparent)}
.work-cap b{display:block;font-size:1.02rem;font-weight:700}.work-cap span{color:#c9ccce}
.work::after{content:"";position:absolute;inset:0;border:2px solid transparent;border-radius:20px;
  transition:border-color .3s var(--ease);pointer-events:none}
.work:hover::after{border-color:var(--g1)}

/* ---------- Mustermappe: green slanted band + overhang ---------- */
.mappe{position:relative;padding-top:130px;background:var(--paper);overflow:visible}
.mappe-band{position:relative;overflow:visible}
.mappe-band::before{content:"";position:absolute;inset:0;background:var(--grad);z-index:0;
  clip-path:polygon(0 44px,100% 0,100% 100%,0 100%)}
.mappe-in{position:relative;z-index:1;display:grid;grid-template-columns:1.02fr .98fr;align-items:center;
  gap:24px;padding:96px 0 60px}
.mappe-txt{position:relative;z-index:2;color:#fff}
.mappe-txt .eyebrow{color:#fff;opacity:.92}
.mappe-txt h2{font-weight:900;font-size:clamp(1.9rem,3.8vw,3.1rem);line-height:1.05;margin:.3em 0 .4em}
.mappe-txt p{color:rgba(255,255,255,.9);font-weight:300;max-width:440px}
.mappe-txt .btn{margin-top:24px;background:#fff;color:var(--ink)}
.mappe-txt .btn:hover{background:transparent;color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.92)}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.tag{font-size:.78rem;font-weight:500;color:#fff;border:1px solid rgba(255,255,255,.35);padding:6px 14px;border-radius:999px}
.mappe-img{position:relative;z-index:3;justify-self:end}
.mappe-img img{width:min(840px,68vw);margin-top:-320px;
  filter:drop-shadow(0 48px 66px rgba(0,0,0,.42))}

/* ---------- Teppich (grey) ---------- */
.teppich{background:var(--grey)}
.teppich-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.teppich-img{border-radius:22px;overflow:hidden;box-shadow:var(--shadow-2);aspect-ratio:1/1;background:var(--ink)}
.teppich-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.teppich-img video{position:relative;top:-7%;width:100%;height:114%;object-fit:cover;
  will-change:transform;display:block}
.teppich:hover .teppich-img img{transform:scale(1.05)}
.teppich h2 .hl{color:var(--g2)}

/* ---------- Wir (green band) ---------- */
.wir{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.wir::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:.95}
.wir .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.wir .eyebrow{color:#fff;opacity:.9}
.wir h2{font-weight:900;font-size:clamp(1.9rem,3.8vw,3rem);line-height:1.06;margin:.3em 0 .4em}
.wir p{color:rgba(255,255,255,.92);font-weight:300;max-width:520px}
.wir .btn{margin-top:24px;background:#fff;color:var(--ink)}
.wir .btn:hover{background:transparent;color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.92)}
.wir-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.wstat{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:20px 22px;transition:background .3s var(--ease),transform .3s var(--ease)}
.wstat:hover{background:rgba(255,255,255,.22);transform:translateY(-3px)}
.wstat b{display:block;font-size:2rem;font-weight:900;line-height:1}
.wstat span{font-size:.86rem;color:rgba(255,255,255,.85)}

/* ---------- Footer (slanted top) ---------- */
.wir{z-index:1;padding-bottom:96px}
.foot{position:relative;background:var(--ink);color:#cfd2d4;padding-top:108px;margin-top:-54px;z-index:2;
  clip-path:polygon(0 54px,100% 0,100% 100%,0 100%)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1.1fr 1.1fr;gap:40px;padding-bottom:46px}
.foot h4{color:#fff;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin-bottom:18px}
.foot a{display:block;padding:3px 0;font-size:.92rem;line-height:1.5;color:#cfd2d4;transition:color .2s var(--ease)}
.foot a:hover{color:var(--g1-bright)}
.foot-brand img{display:block;height:66px;margin:0 0 16px}
.foot-brand p{font-weight:300;font-size:.94rem;color:#a9adb1;max-width:280px}
.foot .tel{font-size:1.5rem;font-weight:900;color:#fff}
.foot .small{font-size:.88rem;color:#a9adb1;font-weight:300;line-height:1.75;margin:0}
.foot .tel+.small{margin-top:5px}
.foot-brand address.small{font-style:normal}
.foot-bar{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;display:flex;flex-wrap:wrap;
  justify-content:space-between;gap:12px;font-size:.82rem;color:#9498a0}

/* ---------- Scroll-to-top ---------- */
.toTop{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);width:54px;height:54px;
  border-radius:999px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-2);display:grid;
  place-items:center;cursor:pointer;z-index:60;opacity:0;pointer-events:none;
  transition:opacity .35s var(--ease),transform .35s var(--ease)}
.toTop.show{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.toTop svg{stroke:var(--g2);transition:transform .25s var(--ease),stroke .25s}
.toTop::after{content:"";position:absolute;inset:-4px;border-radius:999px;background:var(--grad);z-index:-1;opacity:0;transition:opacity .3s var(--ease)}
@media(hover:hover){
  .toTop:hover svg{transform:translateY(-3px);stroke:#fff}
  .toTop:hover{border-color:transparent}
  .toTop:hover::after{opacity:1}
}
.eu{display:inline-flex;align-items:center;gap:8px;color:#9498a0}
.eu svg{flex:0 0 auto;border-radius:3px}
.eu-hero{display:inline-flex;align-items:center;gap:8px;color:#cdd0d2;font-size:.85rem;letter-spacing:.03em}
.eu-stars{height:34px;width:34px;flex:0 0 auto}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .lgrid{grid-template-columns:repeat(3,1fr)}
  .mappe-in,.teppich-grid,.wir .wrap{grid-template-columns:1fr}
  .mappe-img{justify-self:center}.mappe-img img{width:min(360px,72vw);margin-top:24px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-auto-rows:190px}
}
@media(max-width:860px){
  .burger{display:flex}
  .nav{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:min(84vw,360px);background:#fff;
    flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:6px;
    padding:104px 40px 40px;transform:translateX(100%);transition:transform .4s var(--ease);
    box-shadow:var(--shadow-2);overflow-y:auto;z-index:75}
  .nav.open{transform:none}
  .nav a:not(.cta){font-size:1.4rem;padding:12px 0;width:100%}
  .nav .cta{margin-top:16px}
}
@media(max-width:560px){
  .brand img{height:64px}
  .lgrid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .work.tall{grid-row:span 1}
  .foot-grid{grid-template-columns:1fr}
  .wir-stats{grid-template-columns:1fr 1fr}
  .hero-strip-in{gap:16px 30px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

/* ---------- Kontakt & Anfrage ---------- */
.kontakt-sec{background:var(--paper)}
.kontakt-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.kontakt-info .tel{display:inline-block;font-size:1.7rem;font-weight:900;color:var(--ink)}
.kontakt-info .mail{display:inline-block;margin-top:6px;font-size:1.05rem;font-weight:700;color:var(--g2);word-break:break-word}
.kontakt-info .mail:hover{text-decoration:underline}
.ko-list{margin-top:24px;display:grid;gap:16px}
.ko-list>div{display:flex;gap:12px;align-items:flex-start}
.ko-list .bars{margin-top:4px}
.ko-list b{display:block;font-weight:700}
.ko-list span:not(.bars){color:var(--ink-soft);font-size:.95rem}
.form{background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-1);padding:30px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:.85rem;font-weight:600;color:var(--ink)}
.field input,.field select,.field textarea{font:inherit;color:var(--ink);background:var(--paper-2);
  border:1px solid var(--line);border-radius:12px;padding:12px 14px;transition:border-color .2s,box-shadow .2s}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--g1);
  box-shadow:0 0 0 3px rgba(138,198,66,.18)}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:.86rem;color:var(--ink-soft);margin:4px 0 18px}
.consent input{margin-top:3px;flex:0 0 auto}
.form .btn-primary{border:0;cursor:pointer;width:100%;justify-content:center}
.form-note{padding:14px 16px;border-radius:12px;margin-bottom:18px;font-size:.92rem}
.form-note.ok{background:rgba(138,198,66,.14);color:var(--g2);border:1px solid rgba(138,198,66,.4)}
.form-note.err{background:#fdecec;color:#b3261e;border:1px solid #f3c2bd}
@media(max-width:860px){.kontakt-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}}
/* ============ MATERIALIEN ============ */
.mat-hero{position:relative;isolation:isolate;background:var(--ink);color:#fff;overflow:hidden;
  padding-block:clamp(60px,9vw,116px)}
.mat-hero .bgimg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) brightness(1.05) contrast(1.02);opacity:.95;transform:scale(1.04) translateZ(0);
  will-change:transform;backface-visibility:hidden}
.mat-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(100deg,rgba(43,45,48,.92) 0%,rgba(43,45,48,.74) 30%,rgba(43,45,48,.22) 62%,rgba(86,150,36,.18) 100%)}
.mat-hero .eyebrow{color:var(--g1-bright)}
.mat-hero h1{font-weight:900;letter-spacing:-.025em;line-height:1.04;margin:.32em 0 .42em;max-width:780px;
  font-size:clamp(2.2rem,5.5vw,4rem)}
.mat-hero h1 em{font-style:normal;color:var(--g1-bright)}
.mat-hero p{color:#dfe2e3;font-weight:300;max-width:660px;font-size:clamp(1.02rem,1.5vw,1.22rem)}
.legend{display:flex;flex-wrap:wrap;gap:10px 16px;margin-top:32px}
.legend .lg{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:#e7eae8;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:7px 13px;border-radius:999px}
.legend svg{width:16px;height:16px;flex:0 0 auto;color:var(--g1-bright)}

/* sticky category nav */
.cat-nav{position:sticky;top:92px;z-index:40;background:#fff;
  border-bottom:1px solid var(--line);transform:translateZ(0)}
.cat-nav-in{display:flex;gap:8px;overflow-x:auto;padding:12px 24px;scrollbar-width:none;
  width:min(100%,calc(var(--wrap) + 48px));margin-inline:auto}
.cat-nav-in::-webkit-scrollbar{display:none}
.cat-nav a{white-space:nowrap;font-size:.9rem;font-weight:600;color:var(--ink-soft);padding:8px 16px;
  border:1px solid var(--line);border-radius:999px;transition:color .25s var(--ease),border-color .25s var(--ease),background .25s var(--ease)}
.cat-nav a:hover{color:var(--g2);border-color:var(--g1)}
.cat-nav a.active{background:var(--grad);color:#fff;border-color:transparent}

/* category sections */
.matsec{padding-block:clamp(46px,6vw,82px);scroll-margin-top:150px}
.matsec:nth-of-type(even){background:var(--paper-2)}
.matsec .sec-head{margin-bottom:30px}
.mat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}

.mat-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:18px;overflow:hidden;box-shadow:var(--shadow-1);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease)}
.mat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-2);border-color:transparent}
.mat-img{position:relative;display:block;aspect-ratio:1008/588;overflow:hidden;background:#fff;cursor:zoom-in}
.mat-img img{width:100%;height:100%;object-fit:cover;transform-origin:center;transition:transform .35s var(--ease)}
.mat-img.zoomed img{transition:transform .08s linear}
.mat-img .zoom{position:absolute;right:10px;bottom:10px;width:34px;height:34px;border-radius:999px;
  background:rgba(255,255,255,.94);display:grid;place-items:center;opacity:0;transform:translateY(6px) scale(.9);
  box-shadow:0 6px 14px rgba(0,0,0,.28);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.mat-img .zoom svg{width:17px;height:17px;color:var(--ink)}
.mat-img:hover .zoom{opacity:1;transform:none}
.mat-body{display:flex;flex-direction:column;flex:1;padding:18px 20px 16px}
.mat-body h3{font-size:1.12rem;font-weight:700;line-height:1.22}
.mat-body h3 small{display:block;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--g2);margin-bottom:3px}
.mat-body .desc{color:var(--ink-soft);font-size:.9rem;font-weight:300;margin:8px 0 14px}

.specs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.specs:empty{display:none}
.spec{display:inline-flex;align-items:center;gap:5px;font-size:.73rem;font-weight:600;color:var(--ink-soft);
  background:var(--paper-2);border:1px solid var(--line);padding:4px 9px;border-radius:8px;line-height:1.1}
.spec svg{width:13px;height:13px;flex:0 0 auto;color:var(--muted)}
.spec--on{color:var(--g2);background:rgba(138,198,66,.12);border-color:rgba(138,198,66,.34)}
.spec--on svg{color:var(--g2)}
.spec--todo{color:var(--muted)}

.mat-app{display:inline-flex;align-items:center;gap:7px;font-size:.86rem;font-weight:700;color:var(--g2);
  margin-top:auto;align-self:flex-start;padding:7px 12px;border:1px solid transparent;border-radius:9px;
  transition:border-color .2s var(--ease),background .2s var(--ease),transform .2s var(--ease)}
.mat-app:hover{border-color:var(--g1);background:rgba(138,198,66,.09)}
.mat-app .arr{transition:transform .25s var(--ease)}
.mat-card:hover .mat-app .arr{transform:translateX(4px)}

/* RPET = green eco band, white cards */
.matsec.rpet{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.matsec.rpet::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:.97}
.matsec.rpet .wrap{position:relative}
.matsec.rpet .eyebrow{color:#fff;opacity:.92}
.matsec.rpet .sec-head h2,.matsec.rpet .sec-head h2 .hl{color:#fff}
.matsec.rpet .sec-head p{color:rgba(255,255,255,.9)}
.matsec.rpet .spec--on{color:var(--g2);background:rgba(138,198,66,.14);border-color:rgba(138,198,66,.4)}

/* closing Mustermappe teaser (light) */
.mat-mappe{background:var(--paper)}
.mat-mappe .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.mat-mappe h2{font-weight:900;line-height:1.06;font-size:clamp(1.8rem,3.6vw,2.8rem);margin:.3em 0 .35em}
.mat-mappe h2 .hl{color:var(--g2)}
.mat-mappe p{color:var(--ink-soft);font-weight:300;max-width:520px;font-size:1.08rem}
.mat-mappe .row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.mat-mappe .mm-img{justify-self:center}
.mat-mappe .mm-img img{width:min(440px,80vw);filter:drop-shadow(0 30px 50px rgba(0,0,0,.25))}
.btn-dark{color:var(--ink);border:1px solid var(--ink-soft)}
.btn-dark:hover{background:var(--ink);color:#fff;transform:translateY(-3px)}

@media(max-width:860px){
  .mat-mappe .wrap{grid-template-columns:1fr}
  .mat-mappe .mm-img{order:-1}
  .mat-mappe .mm-img img{width:min(320px,72vw)}
}
@media(max-width:560px){
  .cat-nav{top:76px}
  .matsec{scroll-margin-top:132px}
  .mat-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
  .mat-body{padding:14px 14px 12px}
}

/* ============ ANWENDUNGEN ============ */
.app-hero .bgimg{filter:brightness(.7) contrast(1.05) saturate(1.05)}
.app-hero::after{background:linear-gradient(103deg,rgba(24,25,28,.9) 0%,rgba(24,25,28,.66) 42%,rgba(24,25,28,.34) 74%,rgba(86,150,36,.34) 100%)}
.app-jump{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.app-jump a{font-size:.8rem;font-weight:600;color:#e7eae8;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);padding:7px 14px;border-radius:999px;transition:background .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease)}
.app-jump a:hover{background:rgba(255,255,255,.15);border-color:var(--g1);transform:translateY(-2px)}

.appsec{padding-block:clamp(58px,7vw,104px);scroll-margin-top:150px;position:relative;background:#fff;overflow:clip}
.appsec.has-stage{padding-top:0}
.appsec .sec-head{margin-bottom:30px}
.appsec .sec-head p{max-width:660px}
.sub-head{margin:48px 0 18px}
.sub-head h3{font-size:1.25rem;font-weight:800;letter-spacing:-.01em}
.sub-head p{color:var(--ink-soft);font-weight:300;max-width:640px;margin-top:5px}

/* vertical XXL label – sits in the clear left gutter, behind nothing important */
.applabel{position:absolute;left:min(2vw,22px);top:clamp(70px,12vh,160px);transform:rotate(180deg);writing-mode:vertical-rl;
  font-weight:900;font-size:clamp(2.6rem,4vw,4.6rem);letter-spacing:.02em;line-height:1;text-transform:uppercase;
  color:rgba(20,20,22,.05);pointer-events:none;user-select:none;z-index:0;white-space:nowrap}
.applabel.light{color:rgba(255,255,255,.1)}
@media(max-width:1320px){.applabel{display:none}}

/* editorial grid */
.eg{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:198px;gap:14px;position:relative;z-index:1}
.s2{grid-column:span 2}.s3{grid-column:span 3}.r2{grid-row:span 2}.r3{grid-row:span 3}

/* gx tile + lightbox */
.gx{position:relative;border:0;padding:0;margin:0;font:inherit;text-align:left;display:block;width:100%;height:100%;border-radius:4px;overflow:hidden;background:var(--ink);box-shadow:var(--shadow-1);cursor:zoom-in}
.gx>img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.gx.contain{background:#eef0ed}.gx.contain>img{object-fit:contain}
.gx:hover>img{transform:scale(1.04)}
.gx-cap{position:absolute;left:0;right:0;bottom:0;padding:18px 16px 14px;color:#fff;line-height:1.34;font-size:.82rem;background:linear-gradient(to top,rgba(18,19,21,.9),rgba(18,19,21,.05) 76%,transparent);pointer-events:none}
.gx-cap b{display:block;font-size:1rem;font-weight:700}.gx-cap span{color:#cdd0d2}
.gx::after{content:"";position:absolute;inset:0;border:2px solid transparent;border-radius:4px;transition:border-color .3s var(--ease);pointer-events:none}
.gx:hover::after{border-color:var(--g1)}
.gx-zoom{position:absolute;top:12px;right:12px;z-index:2;width:30px;height:30px;border-radius:50%;background:rgba(18,19,21,.55);color:#fff;display:grid;place-items:center;opacity:0;transition:opacity .25s var(--ease);pointer-events:none}
.gx:hover .gx-zoom{opacity:1}

.lb{position:fixed;inset:0;z-index:120;background:rgba(12,13,14,.93);display:none;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.lb.open{display:flex}
.lb img{max-width:min(1120px,94vw);max-height:84vh;border-radius:6px;box-shadow:0 30px 80px rgba(0,0,0,.55)}
.lb-cap{position:absolute;left:0;right:0;bottom:20px;text-align:center;color:#e7eae8;font-size:.9rem;padding:0 24px;pointer-events:none}
.lb-x{position:absolute;top:18px;right:22px;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.08);color:#fff;font-size:1.4rem;cursor:pointer;display:grid;place-items:center}
.lb-x:hover{background:rgba(255,255,255,.16)}

/* big feature image (Banner lead, light intro precedes it) */
.bigfeat{position:relative;display:block;width:100%;border:0;padding:0;border-radius:6px;overflow:hidden;box-shadow:var(--shadow-2);cursor:zoom-in;background:var(--ink)}
.bigfeat img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:21/9;transition:transform .8s var(--ease)}
.bigfeat:hover img{transform:scale(1.03)}
.bigfeat .gx-cap{font-size:.86rem}
@media(max-width:640px){.bigfeat img{aspect-ratio:16/10}}

/* slanted photo stage (Teppich) – with parallax bg */
.stage{position:relative;isolation:isolate;color:#fff;overflow:hidden;padding-block:clamp(96px,17vh,210px);clip-path:polygon(0 var(--slant,52px),100% 0,100% 100%,0 100%)}
.stage-bg{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;transform:scale(1.2) translateZ(0);will-change:transform}
.stage::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(101deg,rgba(18,19,21,.82) 0%,rgba(18,19,21,.5) 42%,rgba(18,19,21,.18) 74%,rgba(86,150,36,.28))}
.stage.soft::after{background:linear-gradient(180deg,rgba(18,19,21,.3),rgba(18,19,21,.12) 36%,rgba(18,19,21,.5) 100%)}
.stage .eyebrow{color:var(--g1-bright)}
.stage h2{color:#fff;font-weight:800;letter-spacing:-.02em;line-height:1.04;font-size:clamp(2rem,4.6vw,3.6rem);margin:.26em 0 .34em;max-width:760px}
.stage h2 .hl{color:var(--g1-bright)}
.stage p{color:#eceeef;font-weight:300;max-width:580px;font-size:clamp(1rem,1.4vw,1.18rem)}
.stage.soft h2,.stage.soft p,.stage.soft .eyebrow{text-shadow:0 2px 20px rgba(0,0,0,.62)}
.stage.soft .eyebrow{color:#fff}

/* video background section (Fahne & Textil) – taller on desktop */
.vbg{position:relative;isolation:isolate;color:#fff;overflow:hidden;display:flex;align-items:center;
  min-height:clamp(440px,62vh,680px);padding-block:clamp(48px,7vw,90px);
  clip-path:polygon(0 var(--slant,44px),100% 0,100% 100%,0 calc(100% - var(--slant,44px)))}
.vbg-media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.vbg-media video,.vbg-media .vbg-poster{position:absolute;left:50%;top:0;transform:translateX(-50%);width:100%;height:calc(100% + 56px);object-fit:cover;object-position:center top}
.vbg::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,rgba(18,19,21,.74),rgba(18,19,21,.38) 50%,rgba(18,19,21,.12))}
.vbg .eyebrow{color:var(--g1-bright)}
.vbg h2{color:#fff;font-weight:800;letter-spacing:-.02em;font-size:clamp(1.9rem,4.2vw,3.2rem);line-height:1.05;margin:.26em 0 .34em}
.vbg h2 .hl{color:var(--g1-bright)}
.vbg p{color:#eceeef;font-weight:300;max-width:560px}
.vbg-tiles{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:520px;margin-top:28px}
.vbg-tiles .gx{height:clamp(170px,24vw,220px)}

/* GREEN BAND with VERTICAL diagonal; image runs under the diagonal */
.greenband{position:relative;border-radius:6px;overflow:hidden;min-height:clamp(320px,40vw,470px);background:var(--ink);box-shadow:var(--shadow-2)}
.greenband .gb-img{position:absolute;inset:0;border:0;padding:0;width:100%;cursor:zoom-in;background:none}
.greenband .gb-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.greenband .gb-txt{position:absolute;inset:0;width:60%;background:var(--grad);color:#fff;
  clip-path:polygon(0 0,100% 0,calc(100% - 96px) 100%,0 100%);
  padding:clamp(28px,4vw,54px);padding-right:120px;display:flex;flex-direction:column;justify-content:center}
.greenband .gb-txt h3{font-size:clamp(1.5rem,2.8vw,2.3rem);font-weight:800;line-height:1.08;margin-bottom:12px}
.greenband .gb-txt p{color:rgba(255,255,255,.94);font-weight:300;max-width:30ch}
@media(max-width:720px){
  .greenband{min-height:0;display:flex;flex-direction:column}
  .greenband .gb-img{position:relative;height:240px}
  .greenband .gb-txt{position:relative;width:100%;clip-path:polygon(0 0,100% 0,100% calc(100% - 40px),0 100%);padding:28px 24px 48px}
}

/* DECKENHÄNGER full band + protruding cut-out */
.dhband{position:relative;background:var(--grad);border-radius:6px;padding:clamp(30px,4vw,54px);overflow:visible;display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center;box-shadow:var(--shadow-2)}
.dhband .dh-txt{color:#fff;position:relative;z-index:1}
.dhband .dh-txt h3{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:800;margin-bottom:10px}
.dhband .dh-txt p{color:rgba(255,255,255,.94);font-weight:300;max-width:48ch}
.dhband .dh-obj{position:relative;height:100%;min-height:200px}
.dhband .dh-obj img{position:absolute;right:0;bottom:-clamp(30px,4vw,54px);max-height:148%;width:auto;filter:drop-shadow(0 26px 30px rgba(0,0,0,.4))}
.konf-mini{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.konf-mini figure{margin:0;width:120px}
.konf-mini img{width:120px;height:88px;object-fit:cover;border-radius:6px;display:block;border:1px solid rgba(255,255,255,.25)}
.konf-mini figcaption{font-size:.72rem;color:rgba(255,255,255,.8);margin-top:5px;line-height:1.3}
.konf-mini b{display:block;color:#fff;font-weight:700;font-size:.76rem}
@media(max-width:760px){
  .dhband{grid-template-columns:1fr}
  .dhband .dh-obj{min-height:340px}
  .dhband .dh-obj img{position:relative;right:auto;bottom:auto;max-height:340px;margin:0 auto;display:block}
}

/* before/after slider */
.ba{position:relative;border-radius:6px;overflow:hidden;box-shadow:var(--shadow-2);aspect-ratio:16/9;background:var(--ink);user-select:none;touch-action:pan-y}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba .ba-top{clip-path:inset(0 calc(100% - var(--p,50%)) 0 0);z-index:1}
.ba-line{position:absolute;top:0;bottom:0;left:var(--p,50%);width:2px;background:#fff;transform:translateX(-1px);z-index:3;pointer-events:none;box-shadow:0 0 0 1px rgba(0,0,0,.18)}
.ba-grip{position:absolute;top:50%;left:var(--p,50%);transform:translate(-50%,-50%);z-index:4;width:44px;height:44px;border-radius:50%;background:#fff;box-shadow:var(--shadow-2);display:grid;place-items:center;pointer-events:none;color:var(--ink);font-weight:800}
.ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5}
.ba-range:focus-visible+.ba-grip{outline:3px solid var(--g1);outline-offset:3px}
.ba-tag{position:absolute;bottom:12px;z-index:3;font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:#fff;background:rgba(18,19,21,.72);padding:5px 11px;border-radius:999px;pointer-events:none}
.ba-tag-l{left:12px}.ba-tag-r{right:12px}

/* flow: two images + big arrow badge overlapping */
.flow{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);max-width:820px;align-items:center}
.flow .gx{aspect-ratio:4/3}
.flow-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:4;width:clamp(58px,7vw,86px);height:clamp(58px,7vw,86px);border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;box-shadow:0 14px 30px rgba(0,0,0,.32),0 0 0 6px #fff}
.flow-badge svg{width:46%;height:46%}
.flow-cap{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);max-width:820px}
.flow-cap b{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}
@media(max-width:600px){
  .flow{grid-template-columns:1fr;gap:54px}
  .flow-badge{left:50%;top:calc(50% );transform:translate(-50%,-50%) rotate(90deg)}
  .flow-cap{grid-template-columns:1fr;gap:54px}
}

/* SCHMUTZFANG dark slanted band + mat half over it */
.sfband{position:relative;background:linear-gradient(120deg,#222428,#34373c);border-radius:6px;overflow:visible;
  clip-path:polygon(0 34px,100% 0,100% 100%,0 100%);padding:clamp(30px,4vw,52px);
  display:grid;grid-template-columns:1fr .9fr;gap:24px;align-items:center;color:#fff;box-shadow:var(--shadow-2)}
.sfband h3{font-size:clamp(1.4rem,2.6vw,2.1rem);font-weight:800;margin-bottom:8px}
.sfband .sf-lead{color:rgba(255,255,255,.86);font-weight:300;max-width:46ch}
.sfband ul{list-style:none;margin:14px 0 0;padding:0;display:grid;gap:9px}
.sfband li{display:flex;gap:10px;align-items:flex-start;font-weight:300;color:rgba(255,255,255,.86)}
.sfband li b{color:#fff;font-weight:700}
.sfband li::before{content:"";flex:0 0 auto;width:9px;height:9px;border-radius:50%;background:var(--g1);margin-top:7px}
.sfband .sf-obj{position:relative;min-height:170px}
.sfband .sf-obj img{position:absolute;right:-2%;top:50%;transform:translateY(-50%) rotate(-3deg);width:118%;max-width:none;filter:drop-shadow(0 22px 28px rgba(0,0,0,.5))}
@media(max-width:760px){
  .sfband{grid-template-columns:1fr}
  .sfband .sf-obj{min-height:0;margin-top:8px}
  .sfband .sf-obj img{position:relative;right:auto;top:auto;transform:rotate(-2deg);width:100%}
}

/* detail strip */
.detail{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.detail .gx{height:200px}

/* footer row */
.appsec-foot{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-top:30px;position:relative;z-index:1}
.mat-back{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:700;color:var(--g2);padding:9px 15px;border:1px solid var(--line);border-radius:8px;background:#fff;transition:border-color .2s var(--ease),background .2s var(--ease),transform .2s var(--ease)}
.mat-back:hover{border-color:var(--g1);background:rgba(138,198,66,.08);transform:translateY(-2px)}
.mat-back .arr{transition:transform .25s var(--ease)}.mat-back:hover .arr{transform:translateX(-4px)}
.btn-sm{padding:12px 22px;font-size:.94rem}

/* CTA */
.app-cta{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.app-cta::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:.96}
.app-cta .wrap{position:relative;max-width:760px}
.app-cta .eyebrow{color:#fff;opacity:.92}
.app-cta h2{font-weight:800;font-size:clamp(1.9rem,3.8vw,3rem);line-height:1.06;margin:.3em 0 .4em}
.app-cta h2 .hl2{color:var(--ink)}
.app-cta p{color:rgba(255,255,255,.92);font-weight:300;max-width:560px;font-size:1.06rem}
.app-cta .row{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.app-cta .btn{background:#fff;color:var(--ink)}
.app-cta .btn:hover{background:transparent;color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.92);transform:translateY(-3px)}
.app-cta .btn-line{background:transparent;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5)}
.app-cta .btn-line:hover{background:rgba(255,255,255,.12);box-shadow:inset 0 0 0 1px #fff;transform:translateY(-3px)}

@media(max-width:760px){
  .eg{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .s3{grid-column:span 2}.r3{grid-row:span 2}
  .detail{grid-template-columns:1fr 1fr}
  .vbg-tiles{max-width:none}
}
@media(max-width:560px){
  .appsec{scroll-margin-top:132px}
  .eg{gap:10px;grid-auto-rows:140px}.s2{grid-column:span 2}
  .detail{grid-template-columns:1fr}
  .appsec-foot{flex-direction:column;align-items:stretch}
  .appsec-foot .btn,.appsec-foot .mat-back{justify-content:center;text-align:center}
}
@media(prefers-reduced-motion:reduce){.stage-bg{transform:scale(1.06)!important}}

/* ============ ANWENDUNGEN – v7 Feinschliff ============ */
/* dezenter Eyelet-BG unter Banner, leitet in die Fahnen-Schräge */
#banner::before{content:"";position:absolute;inset:0;background:url(../img/bg_bw_eyelet_k.jpg) center/cover no-repeat;opacity:.06;z-index:0;pointer-events:none}
#banner .wrap{position:relative;z-index:1}

/* Fahnen-Video höher auf Desktop */
.vbg{min-height:clamp(560px,76vh,860px)}

/* in-content Anfrage-Buttons entfallen -> Foot linksbündig */
.appsec-foot{justify-content:flex-start}

/* DECKENHÄNGER: durchlaufendes schräges Band, Hänger riesig & oben/unten ragend */
.dhband{width:100vw;margin-left:calc(50% - 50vw);border-radius:0;overflow:visible;margin-top:22px;
  clip-path:polygon(0 44px,100% 0,100% 100%,0 calc(100% - 44px));
  padding:clamp(46px,6vw,86px) max(24px,calc(50vw - 600px));grid-template-columns:1.3fr .7fr}
.dhband .dh-obj{position:relative;min-height:0}
.dhband .dh-obj img{position:absolute;right:2%;top:50%;transform:translateY(-50%);bottom:auto;max-height:none;height:188%;width:auto;filter:drop-shadow(0 30px 36px rgba(0,0,0,.45))}
.dh-clear{height:clamp(70px,10vw,150px)}
@media(max-width:760px){
  .dhband{clip-path:polygon(0 22px,100% 0,100% 100%,0 calc(100% - 22px));grid-template-columns:1fr}
  .dhband .dh-obj img{position:relative;right:auto;top:auto;transform:none;height:auto;max-height:360px;margin:10px auto 0;display:block}
  .dh-clear{display:none}
}

/* VERLEGUNG: Chevron-Maske (">"), Ergebnisbild liegt in der Pfeilform */
.verleg{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,3vw,28px);align-items:stretch;max-width:860px}
.verleg .gx{aspect-ratio:4/3}
.chev{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--ink);border:0;padding:0;margin:0;cursor:zoom-in;
  clip-path:polygon(0 0,60% 0,100% 50%,60% 100%,0 100%,40% 50%)}
.chev>img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.chev:hover>img{transform:scale(1.05)}
.chev-tag{position:absolute;left:8%;top:50%;transform:translateY(-50%);z-index:2;color:#fff;font-weight:800;
  font-size:clamp(.8rem,1.4vw,1rem);text-shadow:0 2px 10px rgba(0,0,0,.6);pointer-events:none}
@media(max-width:600px){.verleg{grid-template-columns:1fr}.chev{aspect-ratio:16/10;clip-path:polygon(0 0,100% 0,100% 60%,50% 100%,0 60%)}.chev-tag{left:50%;top:30%;transform:translateX(-50%)}}

/* SCHMUTZFANG: full-bleed grauer Schräg-Balken, Matte läuft DARÜBER (nicht abgeschnitten) */
.sfwrap{position:relative;width:100vw;margin-left:calc(50% - 50vw);margin-top:clamp(60px,8vw,110px);padding-top:clamp(30px,6vw,80px)}
.sfband2{position:relative;background:linear-gradient(120deg,#22242a,#34373c);color:#fff;
  clip-path:polygon(0 40px,100% 0,100% 100%,0 100%);
  padding:clamp(44px,6vw,84px) max(24px,calc(50vw - 600px))}
.sf-copy{max-width:60%}
.sfband2 h3{font-size:clamp(1.6rem,3vw,2.5rem);font-weight:800;margin-bottom:12px}
.sfband2 .sf-lead{color:rgba(255,255,255,.86);font-weight:300;max-width:46ch}
.sfband2 ul{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:13px}
.sfband2 li{display:flex;gap:13px;align-items:flex-start;font-weight:300;color:rgba(255,255,255,.88)}
.sfband2 li b{color:#fff;font-weight:700}
.func-ico{flex:0 0 auto;width:30px;height:30px;color:var(--g1-bright);margin-top:1px}
.sf-float{position:absolute;right:4%;top:0;z-index:3;width:min(440px,40%);transform:rotate(-3deg);filter:drop-shadow(0 26px 32px rgba(0,0,0,.5));pointer-events:none}
@media(max-width:860px){
  .sf-copy{max-width:100%}
  .sf-float{position:relative;right:auto;top:auto;width:78%;margin:0 auto -10px;display:block;transform:rotate(-2deg)}
  .sfwrap{padding-top:0}
}

/* ============ ANWENDUNGEN – v8 ============ */
/* Banner-BG stärker + läuft hinter die Fahnen-Schräge (in den Dreiecken sichtbar) */
#banner::before{opacity:.12}
#fahnen{position:relative;background:#fff}
#fahnen::before{content:"";position:absolute;inset:0;background:url(../img/bg_bw_eyelet_k.jpg) center/cover no-repeat;opacity:.12;z-index:0;pointer-events:none}

/* DECKENHÄNGER: Band geclippt, Freisteller liegt DARÜBER (nicht geclippt) → ragt oben+unten raus, riesig */
.dhwrap{position:relative;width:100vw;margin-left:calc(50% - 50vw);margin-top:24px}
.dhband2{position:relative;background:var(--grad);color:#fff;
  clip-path:polygon(0 44px,100% 0,100% 100%,0 calc(100% - 44px));
  padding:clamp(54px,7vw,96px) max(24px,calc(50vw - 600px))}
.dhband2 .dh-txt{max-width:58%}
.dhband2 .dh-txt h3{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:800;margin-bottom:10px}
.dhband2 .dh-txt p{color:rgba(255,255,255,.94);font-weight:300;max-width:48ch}
.dh-float{position:absolute;right:7%;top:50%;transform:translateY(-50%);height:184%;width:auto;z-index:3;
  filter:drop-shadow(0 30px 38px rgba(0,0,0,.45));pointer-events:none}
@media(max-width:820px){
  .dhband2{clip-path:polygon(0 24px,100% 0,100% 100%,0 calc(100% - 24px))}
  .dhband2 .dh-txt{max-width:100%}
  .dh-float{position:relative;right:auto;top:auto;transform:none;height:auto;max-height:420px;width:auto;margin:14px auto 0;display:block}
}

/* VERLEGUNG: drei gleich große Pfeile – Bild ▸ grüner Pfeil ▸ Bild */
.chevrow{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(8px,1.6vw,16px);align-items:stretch;max-width:940px}
.chev{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--ink);border:0;padding:0;margin:0;cursor:zoom-in;
  clip-path:polygon(0 0,62% 0,100% 50%,62% 100%,0 100%,38% 50%)}
.chev>img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.chev:hover>img{transform:scale(1.05)}
.chev.green{background:var(--grad);cursor:default;display:grid;place-items:center;color:#fff}
.chev.green svg{width:40%;height:40%}
.chev-tag{position:absolute;left:6%;top:50%;transform:translateY(-50%);z-index:2;color:#fff;font-weight:800;
  font-size:clamp(.75rem,1.3vw,1rem);text-shadow:0 2px 10px rgba(0,0,0,.65);pointer-events:none}
@media(max-width:600px){
  .chevrow{grid-template-columns:1fr;gap:6px}
  .chev{aspect-ratio:16/8;clip-path:polygon(0 0,100% 0,100% 60%,50% 100%,0 60%)}
  .chev-tag{left:50%;top:26%;transform:translateX(-50%)}
}

/* SCHMUTZFANG: 3 Mattenbilder im grauen Balken, Funktionsware-Text, Matte groß & eingerückt darüber */
.sf-copy{max-width:56%}
.sf-shots{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px;max-width:56%}
.sf-shots .gx{aspect-ratio:4/3}
.sf-float{position:absolute;right:7%;top:-4%;width:min(560px,44%);transform:rotate(-3deg);z-index:3;
  filter:drop-shadow(0 28px 34px rgba(0,0,0,.55));pointer-events:none}
@media(max-width:860px){
  .sf-copy,.sf-shots{max-width:100%}
  .sf-float{position:relative;right:auto;top:auto;width:86%;margin:0 auto 6px;display:block;transform:rotate(-2deg)}
}

/* ============ ANWENDUNGEN – v9 ============ */
/* Banner-Eyelet endet exakt an der Video-Schräge (nur oberes Dreieck, nicht unter dem Video) */
#fahnen::before{clip-path:polygon(0 0,100% 0,0 48px)}

/* Konfektion-Mini jetzt RUND */
.konf-mini{gap:16px;margin-top:18px}
.konf-mini figure{width:auto}
.konf-mini img{width:84px;height:84px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.3)}
.konf-mini figcaption{width:90px;text-align:center;margin-top:7px}

/* Deckenhänger: Freisteller näher an den Text, mehr Abstand darunter */
.dhband2 .dh-txt{max-width:52%}
.dh-float{right:15%;height:176%}
.dh-clear{height:clamp(110px,13vw,200px)}
/* Galerie 2/3 Sale + 1/3 Yamaha, groß & ganz sichtbar */
.dh-gallery{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.dh-gallery .gx{height:clamp(300px,40vw,480px)}

/* VERLEGUNG: drei Pfeile – links gefüllt, breiter grüner Text-Pfeil, rechts gefüllt */
.chevrow{grid-template-columns:1fr 1.55fr 1fr;align-items:stretch}
.chevrow .chev{aspect-ratio:auto;height:clamp(170px,23vw,280px)}
.chev.cleft{clip-path:polygon(0 0,64% 0,100% 50%,64% 100%,0 100%)}
.chev.cmid{clip-path:polygon(0 0,86% 0,100% 50%,86% 100%,0 100%,14% 50%);background:var(--grad);display:grid;place-items:center;padding:0 8% 0 12%;cursor:default}
.chev.cmid .mid-txt{color:#fff;font-weight:800;text-align:center;line-height:1.16;font-size:clamp(.9rem,1.6vw,1.25rem)}
.chev.cmid .mid-txt small{display:block;font-weight:400;opacity:.92;font-size:.78em;margin-top:3px}
.chev.cright{clip-path:polygon(20% 0,100% 0,100% 100%,20% 100%,0 50%)}
.chev.cright .chev-tag{left:auto;right:6%}
@media(max-width:600px){
  .chevrow{grid-template-columns:1fr}
  .chevrow .chev{height:auto;aspect-ratio:16/8}
  .chev.cleft{clip-path:polygon(0 0,100% 0,100% 64%,50% 100%,0 64%)}
  .chev.cmid{clip-path:polygon(0 14%,50% 0,100% 14%,100% 86%,50% 100%,0 86%);padding:14% 8%}
  .chev.cright{clip-path:polygon(0 14%,50% 0,100% 14%,100% 100%,0 100%)}
  .chev.cright .chev-tag{left:50%;right:auto;transform:translateX(-50%)}
}

/* SCHMUTZFANG: Matte größer & näher an den Text, 3 Bilder größer & volle Breite */
.sf-copy{max-width:46%}
.sf-float{right:6%;top:-5%;width:min(600px,50%)}
.sf-shots{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(30px,3.6vw,48px);max-width:none}
.sf-shots .gx{aspect-ratio:4/3}
@media(max-width:860px){.sf-copy{max-width:100%}.sf-float{width:88%}}

/* ============ ANWENDUNGEN – v10 ============ */
/* Banner-Eyelet endet schräg genau an der Flagge (parallel zur Video-Schräge), nichts mehr darunter */
#banner::before{clip-path:polygon(0 0,100% 0,100% calc(100% - 46px),0 100%)}
#fahnen::before{display:none}

/* Fahnen: nur Desktop – Video höher in der Box (mehr Mitte sichtbar) */
@media(min-width:861px){.vbg-media video{height:calc(100% + 150px);top:-52px}}

/* Platten: Einzigartigkeits-Badge auf dem grünen Band */
.gb-badge{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;margin-bottom:14px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.45);color:#fff;
  font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:6px 13px;border-radius:999px}
.gb-badge svg{width:14px;height:14px}

/* Deckenhänger: vertikaler Text VOR den grünen Balken; Freisteller näher an den Text */
#deckenhaenger .applabel{z-index:5}
.dh-float{right:22%}

/* VERLEGUNG: gleiche Winkel überall (px-Run identisch), grüner Pfeil breit für Text */
.chevrow{grid-template-columns:1fr 1.6fr 1fr}
.chev.cleft{clip-path:polygon(0 0,60% 0,100% 50%,60% 100%,0 100%)}
.chev.cmid{clip-path:polygon(0 0,75% 0,100% 50%,75% 100%,0 100%,25% 50%);padding:0 15% 0 22%}
.chev.cright{clip-path:polygon(0 0,100% 0,100% 100%,0 100%,40% 50%)}
.chev.cright .chev-tag{left:auto;right:7%}

/* Schmutzfang: Matte deutlich größer & weit links an den Text */
.sf-copy{max-width:40%}
.sf-float{right:2%;top:-6%;width:min(720px,58%)}
@media(max-width:860px){.sf-copy{max-width:100%}.sf-float{width:90%}}

/* ============ ANWENDUNGEN – v11 ============ */
/* Fahnen Desktop: mittlerer Bildausschnitt via object-position (Wasserzeichen unten bleibt weg) */
@media(min-width:861px){.vbg-media video,.vbg-media .vbg-poster{height:100%;top:0;object-position:center 46%}}

/* Deckenhänger Freisteller weit links – sitzt am Text */
#deckenhaenger .dhband2 .dh-txt{max-width:48%}
.dh-float{left:49%;right:auto}

/* JOOP-Brecher: full-bleed, breiter, leichte vertikale Schräge */
.bigfeat.brecher{width:100vw;margin-left:calc(50% - 50vw);border-radius:0;box-shadow:0 30px 60px rgba(0,0,0,.22);clip-path:polygon(1.6% 0,100% 0,98.4% 100%,0 100%)}
.bigfeat.brecher img{aspect-ratio:auto;height:clamp(300px,36vw,520px)}

/* Verlegung: kleinere Pfeile (mehr Bild), wenig Weiß dazwischen, Text eingerückt */
.chevrow{gap:clamp(2px,.4vw,6px)}
.chev.cleft{clip-path:polygon(0 0,70% 0,100% 50%,70% 100%,0 100%)}
.chev.cmid{clip-path:polygon(0 0,81% 0,100% 50%,81% 100%,0 100%,19% 50%);padding:0 19% 0 26%}
.chev.cright{clip-path:polygon(0 0,100% 0,100% 100%,0 100%,30% 50%)}

/* Schmutzfang-Matte noch weiter links – sitzt am Text */
.sf-copy{max-width:34%}
.sf-float{right:0;width:min(820px,64%)}
@media(max-width:860px){.sf-copy{max-width:100%}.sf-float{width:90%}}

/* ============ ANWENDUNGEN – v12 ============ */
/* Flagge-Video: Ausschnitt ein Stück tiefer */
@media(min-width:861px){.vbg-media video,.vbg-media .vbg-poster{object-position:center 56%}}

/* JOOP: ohne Schräge, voll bis zum Rand, etwas höher */
.bigfeat.brecher{clip-path:none}
.bigfeat.brecher img{height:clamp(340px,40vw,560px)}

/* Deckenhänger: Freisteller ein Stück zurück nach rechts */
.dh-float{left:52%}

/* Schmutzfangmatte: links an den Text gerückt (wie Deckenhänger) */
.sf-float{left:35%;right:auto;width:min(820px,62%);top:-4%}
@media(max-width:860px){.sf-float{left:auto;right:auto;width:90%}}

/* ============ ANWENDUNGEN – v13 ============ */
/* Flagge-Video: mehr vom OBEREN Bildbereich zeigen */
@media(min-width:861px){.vbg-media video,.vbg-media .vbg-poster{object-position:center 38%}}
/* Schmutzfangmatte: wieder etwas nach rechts (lag im Text) */
.sf-float{left:42%;width:min(780px,56%)}
@media(max-width:860px){.sf-float{left:auto;width:90%}}

/* ============================================================
   RECHTSSEITEN (Impressum / AGB / Datenschutz) — v1
   ============================================================ */
.legal-hero{background:var(--ink);color:#fff;position:relative;isolation:isolate;overflow:hidden;
  padding-block:clamp(58px,10vw,104px)}
.legal-hero::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
  background:radial-gradient(120% 140% at 100% 0%,rgba(86,150,36,.55),transparent 55%)}
.legal-hero .eyebrow{color:var(--g1-bright)}
.legal-hero h1{font-weight:900;letter-spacing:-.025em;line-height:1.05;margin:.3em 0 .35em;
  font-size:clamp(2rem,5vw,3.4rem)}
.legal-hero p{color:#dfe2e3;font-weight:300;max-width:620px;font-size:clamp(1rem,1.4vw,1.16rem)}

.legal{padding-block:clamp(48px,7vw,88px)}
.legal .wrap{width:min(100% - 48px,860px)}
.legal-body{font-size:1.02rem;color:var(--ink-soft);font-weight:400}
.legal-body h2{color:var(--ink);font-weight:800;letter-spacing:-.01em;line-height:1.25;
  font-size:clamp(1.3rem,2.4vw,1.7rem);margin:2.2em 0 .5em;scroll-margin-top:120px}
.legal-body h2:first-child{margin-top:0}
.legal-body h2 .num{color:var(--g2);font-weight:900;margin-right:.4em}
.legal-body h3{color:var(--ink);font-weight:700;font-size:1.06rem;margin:1.5em 0 .35em}
.legal-body p{margin:.7em 0}
.legal-body ul,.legal-body ol{margin:.7em 0 .7em 1.3em}
.legal-body li{margin:.35em 0}
.legal-body ol.alpha{list-style:lower-alpha}
.legal-body a{color:var(--g2);font-weight:600;text-decoration:underline;text-underline-offset:2px;
  text-decoration-thickness:1px;text-decoration-color:rgba(86,150,36,.4);transition:text-decoration-color .2s}
.legal-body a:hover{text-decoration-color:var(--g2)}
.legal-body strong{color:var(--ink);font-weight:700}
.legal-card{background:var(--paper-2);border:1px solid var(--line);border-radius:16px;
  padding:clamp(22px,3vw,34px);margin:.4em 0 1.6em}
.legal-card p{margin:.25em 0}
.legal-card .lbl{display:block;font-size:.72rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--g2);margin-bottom:.7em}
.legal-card .biz{margin:0;font-weight:800;color:var(--ink);font-size:1.08rem;letter-spacing:.02em}
.legal-card .owner{margin:.05em 0 .7em;font-weight:400;color:var(--muted);font-size:.92rem}
.legal-toc{display:flex;flex-wrap:wrap;gap:8px;margin:.4em 0 2.4em}
.legal-toc a{display:inline-block;padding:7px 14px;border:1px solid var(--line);border-radius:999px;
  background:#fff;font-size:.9rem;font-weight:600;color:var(--ink);text-decoration:none;transition:.22s var(--ease)}
.legal-toc a:hover{border-color:var(--g1);color:var(--g2);transform:translateY(-1px)}
.legal-updated{margin-top:2.6em;padding-top:1.4em;border-top:1px solid var(--line);
  font-size:.9rem;color:var(--muted)}

/* ============ ANWENDUNGEN – v14 ============ */
/* Verlegung: drei Pfeile proportional größer & breiter (mehr Bild) */
.chevrow{max-width:1140px}
.chevrow .chev{height:clamp(210px,27vw,340px)}
/* Teppich: vertikales XXL-Label unter den Video-Block schieben –
   lag vorher unsichtbar auf dem dunklen Video, sitzt jetzt im hellen Galerie-Gutter */
#teppich .applabel{top:calc(clamp(560px,76vh,860px) + clamp(24px,3vw,48px))}
