/* ============================================================
   qdcops – Landingpage VARIANTE A · "Editorial / ESTATE"
   Ruhig, zentriert, viel Weißraum, feine Hairlines, große Zahlen.
   Markenkonform: Wix Madefor Display, Navy/Blau.
   ============================================================ */

:root {
  --primary:#00A5DB; --blue-50:#7CCEE9; --navy:#0D2132;
  --white:#FFFFFF; --light-grey:#F7F7F7; --line:#E3E7EB;
  --line-dark:rgba(255,255,255,.14);
  --font:'Wix Madefor Display',system-ui,sans-serif;
  --font-btn:'Wix Madefor Display',system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --container:1440px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-size:17px;font-weight:500;line-height:1.65;color:var(--navy);background:var(--light-grey);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--blue-50);color:var(--navy)}
h1,h2,h3{font-weight:600;line-height:1.08;letter-spacing:-.02em;color:var(--navy)}
.material-symbols-rounded{font-variation-settings:'wght' 400}
.container{max-width:var(--container);margin:0 auto;padding:0 32px}

/* Label im ESTATE/Makers-Stil */
.label{font-family:var(--font-btn);font-weight:600;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--navy)}
.rule{height:1px;background:var(--line);border:0;margin:0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-btn);font-weight:600;font-size:17px;line-height:1;padding:15px 30px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s,border-color .25s}
.btn .material-symbols-rounded{font-size:18px;transition:transform .25s var(--ease)}
.btn:hover .material-symbols-rounded{transform:translateX(4px)}
.btn--navy{background:var(--navy);color:#fff}
.btn--navy:hover{transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(13,33,50,.5)}
.btn--ghost{background:transparent;color:var(--navy);border-color:rgba(13,33,50,.25)}
.btn--ghost:hover{border-color:var(--navy)}
.linklike{font-family:var(--font-btn);font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;border-bottom:1.5px solid var(--navy);padding-bottom:3px}
.linklike .material-symbols-rounded{font-size:18px;transition:transform .25s var(--ease)}
.linklike:hover .material-symbols-rounded{transform:translateX(4px)}

/* Header */
.site-header{position:sticky;top:0;z-index:60;background:rgba(247,247,247,.85);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s}
.site-header.scrolled{border-bottom-color:var(--line)}
.hdr{display:flex;align-items:center;justify-content:space-between;height:74px}
.hdr__logo{height:38px}
.hdr__right{display:flex;align-items:center;gap:26px}
.hdr__phone{font-family:var(--font-btn);font-weight:600;font-size:14px}
.hdr__cta{padding:11px 22px;font-size:13.5px}
.hdr nav{display:flex;gap:24px}
.hdr nav a{font-family:var(--font-btn);font-weight:600;font-size:13.5px;position:relative}
.hdr nav a:hover{color:var(--navy);text-decoration:none}
.hdr nav a::after{content:"";position:absolute;left:50%;bottom:-11px;transform:translateX(-50%);width:9px;height:8px;background:url('../assets/images/point.svg') center/contain no-repeat;opacity:0;transition:opacity .2s var(--ease);pointer-events:none}
.hdr nav a:hover::after{opacity:1}
.hdr__burger{display:none;width:42px;height:42px;border:0;background:transparent;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:0}
.hdr__burger span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s var(--ease),opacity .2s var(--ease)}
@media(max-width:760px){
  .hdr{position:relative}
  .hdr__burger{display:inline-flex}
  .hdr__right{position:absolute;top:100%;left:50%;transform:translateX(-50%);width:100vw;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 22px 36px -22px rgba(13,33,50,.35);padding:8px 28px 18px;display:none}
  .site-header.is-open .hdr__right{display:flex}
  .hdr__right nav{flex-direction:column;gap:0}
  .hdr__right nav a{padding:15px 2px;border-bottom:1px solid var(--line);font-size:15px}
  .hdr__cta{margin-top:14px;justify-content:center;width:100%;font-size:14px}
  .site-header.is-open .hdr__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .site-header.is-open .hdr__burger span:nth-child(2){opacity:0}
  .site-header.is-open .hdr__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* Hero – zentriert */
.hero{text-align:center;padding:clamp(56px,8vw,104px) 0 0}
.hero .label{display:inline-block;margin-bottom:24px}
.hero h1{font-size:clamp(40px,6.6vw,74px);max-width:16ch;margin:0 auto 22px}
.hero p.sub{font-size:19px;max-width:56ch;margin:0 auto 34px;color:#41515e}
.hero__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:clamp(48px,6vw,80px)}
.hero__img{position:relative;aspect-ratio:21 / 9}
.hero__img img{width:100%;height:100%;object-fit:cover;border-radius:22px;display:block}
.hero__hex{position:absolute;right:-18px;bottom:-40px;width:200px;height:130px;background:url('../assets/patterns/qdcops-pattern-hexagon-dark.png') center/720px repeat;border-radius:14px;opacity:.9;z-index:-1}

/* Hero – Split-Variante (Headline + Tagline links, Text + Buttons rechts) */
.hero--split{text-align:left;border-top:1px solid var(--line)}
.hero--split .hero__cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:start}
.hero--split .label{display:block;margin-bottom:16px}
.hero--split h1{max-width:none;margin:0}
.hero--split .hero__right{padding-top:6px}
.hero__lead{font-size:21px;line-height:1.55;color:#41515e;margin:0 0 30px;max-width:46ch}
.hero--split .hero__cta{justify-content:flex-start;margin-bottom:0}
.hero--split .hero__img{margin-top:clamp(40px,5vw,64px);width:100%;aspect-ratio:21 / 9}
.hero--split .hero__img img{border-radius:0}
.hero__band{height:clamp(180px,20vw,240px);background:var(--light-grey) url('../assets/patterns/qdcops-pattern-hexagon-light.png') center/auto 166.667% repeat}
.hero__video{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}
.hero__playpause{position:absolute;bottom:20px;right:max(20px,calc(50vw - 712px));z-index:4;width:48px;height:48px;border:0;border-radius:50%;background:rgba(13,33,50,.65);color:#fff;display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(6px);transition:transform .2s var(--ease),background .2s}
.hero__playpause:hover{transform:translateY(-2px);background:var(--navy)}
.hero__playpause .material-symbols-rounded{font-size:24px}
@media(max-width:920px){.hero--split .hero__cols{grid-template-columns:1fr;gap:20px}}

/* Fakten – ESTATE-Raster mit Featured-Zelle */
.facts{padding:clamp(56px,7vw,100px) 0;position:relative;z-index:0}
.facts::before{content:"";position:absolute;inset:0;z-index:-1;background:url('../assets/patterns/qdcops-pattern-hexagon-light.png') center top 70px/auto 366px repeat;opacity:.5;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,0) 100%);mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,0) 100%);pointer-events:none}
.facts-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden}
.fc{background:#fff;padding:34px 30px}
.fc--feat{grid-column:span 4}
.fc--half{grid-column:span 2}
.fc--third{grid-column:span 2}
.fc .n{font-weight:500;letter-spacing:-.04em;line-height:1;color:var(--navy)}
.fc--feat .n{font-size:clamp(56px,9vw,104px)}
.fc .n{font-size:clamp(38px,5vw,62px)}
.fc .n .u{color:var(--navy);font-weight:600}
.fc .l{margin-top:14px;font-size:18px;color:#51606c;hyphens:none;overflow-wrap:normal}

/* Editorial Split (Titel links / Text rechts) */
.split{padding:clamp(56px,7vw,100px) 0;border-top:1px solid var(--line)}
.split__top{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.split__top .label{margin-bottom:18px;display:block}
.split h2{font-size:clamp(30px,4.4vw,52px);max-width:14ch}
.split__body p{font-size:18px;color:#41515e;margin-bottom:18px}
.split__media{margin-top:clamp(40px,5vw,64px)}
.split__media img{width:100%;aspect-ratio:21 / 9;height:auto;object-fit:cover;border-radius:18px;display:block}
.checks{list-style:none;display:grid;gap:0;margin:clamp(28px,3vw,40px) 0 0}
.checks li{display:flex;gap:16px;align-items:center;padding:20px 0;border-top:1px solid var(--line);font-size:18px;color:var(--navy)}
.checks li:last-child{border-bottom:1px solid var(--line)}
.checks .material-symbols-rounded{color:var(--primary);font-size:24px;flex:0 0 auto}

/* Wie wir arbeiten – PDCA (Hairline-Zellraster) */
.proc{padding:clamp(56px,7vw,100px) 0;border-top:1px solid var(--line)}
.proc__head{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.proc__head .label{display:block;margin-bottom:18px}
.proc h2{font-size:clamp(30px,4.4vw,52px);max-width:14ch}
.proc__head p{font-size:18px;color:#41515e}
.steps{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(36px,4vw,52px)}
.stp{padding:4px 36px}
.stp:first-child{padding-left:0}
.stp:last-child{padding-right:0}
.stp + .stp{border-left:1px solid var(--line)}
.stp .ic{color:var(--primary);margin-bottom:16px;line-height:0}
.stp .ic .material-symbols-rounded{font-size:44px}
.stp .ic img{width:68px;height:68px;display:block}
.stp .ph{font-family:var(--font-btn);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);margin-bottom:6px}
.stp h3{font-size:21px;margin-bottom:10px}
.stp p{font-size:18px;color:#51606c}
@media(max-width:920px){
  .steps{grid-template-columns:1fr}
  .stp{padding:24px 0}
  .stp:first-child{padding-top:0}
  .stp + .stp{border-left:none;border-top:1px solid var(--line)}
}

/* Leistungen – Tab-Liste mit Bildwechsel (Text links, Bild rechts) */
.list{padding:clamp(56px,7vw,100px) 0 calc(clamp(56px,7vw,100px) * 3);border-top:1px solid var(--line);position:relative;z-index:0}
.list::before{content:"";position:absolute;inset:0;z-index:-1;background:url('../assets/patterns/qdcops-pattern-hexagon-light.png') center bottom 74px/auto 366px repeat;opacity:.5;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,0) 0%,rgba(0,0,0,0) 75%,rgba(0,0,0,.5) 100%);mask-image:linear-gradient(to bottom,rgba(0,0,0,0) 0%,rgba(0,0,0,0) 75%,rgba(0,0,0,.5) 100%);pointer-events:none}
.list .label{display:block;margin-bottom:16px}
.list h2{font-size:clamp(30px,4.4vw,52px);max-width:18ch}
.list__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,4vw,56px);align-items:start;margin-top:clamp(36px,4vw,52px)}
.lrow{position:relative;display:grid;grid-template-columns:46px 1fr auto;gap:0 20px;align-items:baseline;padding:22px 0;border-top:1px solid var(--line);cursor:pointer;color:inherit}
.lrow:last-child{border-bottom:1px solid var(--line)}
.lrow::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--primary);border-radius:2px;pointer-events:none;z-index:1}
.lrow.is-active::after{width:100%;transition:width 6s linear}
@media(prefers-reduced-motion:reduce){.lrow.is-active::after{transition:none}}
.lrow__no{font-family:var(--font-btn);font-weight:600;font-size:14px;color:var(--navy)}
.lrow__body{display:flex;flex-direction:column}
.lrow__t{font-size:22px;font-weight:600;letter-spacing:-.01em;transition:color .2s var(--ease)}
.lrow__d{font-size:18px;color:#51606c;line-height:1.6;height:0;opacity:0;overflow:hidden;transition:height .4s var(--ease),opacity .3s var(--ease),margin-top .4s var(--ease)}
.lrow.is-active .lrow__d{height:68px;opacity:1;margin-top:10px}
.lrow__img{display:none;width:100%;object-fit:cover;border-radius:14px}
.lrow__arw{color:var(--primary);opacity:0;transform:translateX(-8px);transition:opacity .25s var(--ease),transform .25s var(--ease)}
.lrow:hover .lrow__arw,.lrow.is-active .lrow__arw{opacity:1;transform:none}
.lrow:focus-visible{outline:2px solid var(--primary);outline-offset:4px;border-radius:6px}
.list__media{position:sticky;top:100px;aspect-ratio:1 / 1}
.list__media img{width:100%;height:100%;object-fit:cover;border-radius:18px;display:block}

/* Sektoren – feines mehrspaltiges Verzeichnis */
.dir{padding:clamp(56px,7vw,100px) 0;border-top:1px solid var(--line)}
.dir__head{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;margin-bottom:40px}
.dir h2{font-size:clamp(30px,4.4vw,52px);max-width:12ch}
.dir__head p{font-size:18px;color:#41515e}
.dir-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0 48px}
.dir-grid .it{display:flex;align-items:center;gap:14px;padding:18px 0;border-top:1px solid var(--line);font-size:18px;font-weight:600}
.dir-grid .it .material-symbols-rounded{color:var(--primary);font-size:22px}

/* Branchen-Karussell (Cards) */
.cards-wrap{position:relative;margin-top:clamp(8px,1vw,16px)}
.cards{
  display:flex;gap:24px;align-items:flex-start;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw); /* Vollbreite: links/rechts nicht abgeschnitten */
  padding:6px max(28px,calc(50vw - 692px)) 18px; /* erste Karte bündig zur Headline */
  scrollbar-width:none;cursor:grab;user-select:none;-webkit-user-select:none;
}
.cards::-webkit-scrollbar{display:none}
.cards.is-drag{cursor:grabbing;scroll-behavior:auto}
.ccard{flex:0 0 320px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;overflow:hidden;transition:flex-basis .6s cubic-bezier(.22,.61,.36,1)}
.ccard__img{margin:-28px -28px 0;background:var(--light-grey)}
.ccard__img img{width:100%;height:220px;object-fit:cover;display:block} /* feste Höhe → kein Höhen-Wackeln beim Breiten-Animieren */
.ccard__t{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:18px 2px 0;color:var(--navy)}
.ccard__d{display:none;font-size:18px;color:#51606c;line-height:1.55;margin:12px 2px 2px}
.ccard.is-lead{flex-basis:448px}
.ccard.is-lead .ccard__t{font-size:22px;margin-top:20px}
.ccard.is-lead .ccard__d{display:block;min-height:120px;width:392px;max-width:none;animation:ccardFade .45s .62s cubic-bezier(.22,.61,.36,1) both}
@keyframes ccardFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.ccard{transition:none}.ccard.is-lead .ccard__d{animation:none}}
/* Pfeil-Buttons (Primary-Stil) – an der Unterkante der großen Karte */
.cards__nav{position:absolute;right:0;bottom:0;display:flex;gap:12px;z-index:3}
.cnav{width:50px;height:50px;border-radius:50%;border:none;background:var(--navy);color:#fff;display:grid;place-items:center;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease),opacity .2s}
.cnav:hover{transform:translateY(-2px);box-shadow:0 12px 26px -10px rgba(13,33,50,.5)}
.cnav:disabled{opacity:.35;cursor:default;transform:none;box-shadow:none}
.cnav .material-symbols-rounded{font-size:22px}
@media(max-width:560px){.ccard{flex:0 0 270px;padding:22px}.ccard.is-lead{flex-basis:300px}.ccard__img{margin:-22px -22px 0}.ccard__img img{height:170px}.ccard.is-lead .ccard__d{min-height:0;width:256px}.cards__nav{position:static;justify-content:flex-end;margin-top:18px}}

/* Trennband (Muster, textfrei) */
.band{height:clamp(180px,20vw,240px);background:var(--navy) center/auto 166.667% repeat} /* 166.667% → 3 ganze Reihen, oben/unten bündig abschließend */
.band--light{background-color:var(--light-grey);background-position:center top;background-size:auto 366px}
.band--light + section{border-top:0}
.list + section{border-top:0}
.facts + section{border-top:0}

/* Kontakt */
.contact{padding:clamp(56px,7vw,100px) 0;border-top:1px solid var(--line)}
.contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:stretch}
.contact__intro{display:flex;flex-direction:column}
.contact h2{font-size:clamp(30px,4.4vw,52px);max-width:14ch;margin-bottom:20px}
.contact__intro p{font-size:18px;color:#41515e;margin-bottom:14px}
.person{margin-top:auto;display:flex;gap:16px;align-items:flex-start;padding-top:24px;border-top:1px solid var(--line)}
.person .av{width:54px;height:54px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-family:var(--font-btn);font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary),var(--navy))}
.person .role{font-family:var(--font-btn);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--navy)}
.person .nm{font-size:20px;font-weight:600;margin:3px 0}
.person .po{font-size:14.5px;color:#5a6772;margin-bottom:22px}
.person a{display:flex;align-items:center;gap:9px;font-size:17px;margin-top:6px;text-decoration:none}
.person a span:not(.material-symbols-rounded){text-decoration:none}
.person a:hover span:not(.material-symbols-rounded){text-decoration:underline}
.person .material-symbols-rounded{color:var(--primary);font-size:18px}
.form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px}
.form .fg{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .r{margin-bottom:16px}
.form .r--full{grid-column:1/-1}
.form label{display:block;font-family:var(--font-btn);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#5a6772;margin-bottom:7px}
.form input,.form textarea{width:100%;font-family:var(--font);font-size:16px;color:var(--navy);background:var(--light-grey);border:1.5px solid #B6C0C9;border-radius:10px;padding:13px 15px;transition:border-color .2s,box-shadow .2s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(0,165,219,.12)}
.form textarea{resize:vertical;min-height:120px}
.form .btn{width:100%;justify-content:center;margin-top:2px}
.form .hint{font-size:12.5px;color:#6a7783;margin-top:14px}

/* Kontakt – dunkle Variante (Navy) */
.contact--dark{background:var(--navy)}
.contact--dark .label{color:#fff}
.contact--dark h2{color:#fff}
.contact--dark .contact__intro p{color:rgba(255,255,255,.82)}
.contact--dark .person{border-top-color:rgba(255,255,255,.16)}
.contact--dark .person .role{color:#fff}
.contact--dark .person .nm{color:#fff}
.contact--dark .person .po{color:rgba(255,255,255,.7)}
.contact--dark .person a{color:rgba(255,255,255,.9)}
.contact--dark .person a:hover{color:#fff}
.contact--dark .person .material-symbols-rounded{color:var(--blue-50)}
/* Formularkarte bleibt auch im dunklen Bereich weiß */

/* Pflicht-Einwilligung (Checkbox) */
.form__consent{display:flex;gap:12px;align-items:flex-start;margin:4px 0 20px}
.form__consent input{margin-top:3px;width:18px;height:18px;flex:0 0 auto;accent-color:var(--primary);cursor:pointer}
.form__consent label{font-family:var(--font);font-size:12px;font-weight:500;letter-spacing:0;text-transform:none;line-height:1.5;color:#6a7783;margin-bottom:0}
.form__consent a{color:var(--navy);border-bottom:1px solid var(--primary)}
.form__consent .req{color:var(--primary)}

/* Footer */
.ft{background:var(--navy);color:rgba(255,255,255,.78);padding:calc(clamp(56px,7vw,100px) * 3) 0 30px;position:relative;z-index:0;overflow:hidden}
.ft::before{content:"";position:absolute;inset:0;z-index:-1;background:url('../assets/patterns/qdcops-pattern-hexagon-dark.png') center top 74px/auto 366px repeat;opacity:.5;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,0) 100%);mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,0) 100%);pointer-events:none}
.ft .container{position:relative;z-index:1}
.ft__top{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px}
.ft__brand{display:flex;align-items:center;gap:22px;justify-self:start}
.ft__logo{height:38px;width:auto;justify-self:start}
.ft__social{display:flex;gap:10px;justify-self:end}
.ft__soc{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:var(--blue-50);color:var(--navy);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.ft__soc:hover{transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(124,206,233,.6)}
.ft__soc svg{width:18px;height:18px;display:block}
.ft__strap{font-family:var(--font-btn);font-weight:600;font-size:17px;letter-spacing:.04em;text-align:center}
.ft__strap b{color:var(--primary)}
.ft__bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-top:64px;padding-top:22px;border-top:1px solid var(--line-dark)}
.ft__legal{font-size:12.5px;color:rgba(255,255,255,.5)}
.ft__links{display:flex;gap:20px;flex-wrap:wrap}
.ft__links a{font-family:var(--font-btn);font-weight:600;font-size:14px;color:rgba(255,255,255,.8)}
.ft__links a:hover{color:#fff}
@media(max-width:760px){
  .ft__top{grid-template-columns:1fr;justify-items:start;gap:18px}
  .ft__social{justify-self:start}
  .ft__strap{text-align:left}
  .ft__bar{flex-direction:column;align-items:flex-start;gap:12px}
}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);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}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* Responsive */
@media(max-width:920px){
  .split__top,.proc__head,.dir__head,.contact__grid{grid-template-columns:1fr;gap:24px}
  .person{margin-top:28px}
  .dir-grid{grid-template-columns:1fr 1fr}
  .facts-grid{grid-template-columns:repeat(2,1fr)}
  .fc--feat,.fc--half,.fc--third{grid-column:span 1}
  .facts-grid .fc:last-child{grid-column:1 / -1}
  .list__grid{grid-template-columns:1fr;gap:0}
  .list__media{display:none}
  .lrow__img{display:block;height:0;opacity:0;overflow:hidden;transition:height .4s var(--ease),opacity .3s var(--ease),margin-top .4s var(--ease)}
  .lrow.is-active .lrow__img{height:220px;opacity:1;margin-top:14px}
  .lrow.is-active::after{transition:none} /* Mobil: kein Auto-Ladebalken */
  /* Akkordeon mobil: Beschreibung natürlich hoch (kein Wobble-Schutz nötig) */
  .lrow__d{height:auto;max-height:0;transition:max-height .4s var(--ease),opacity .3s var(--ease),margin-top .4s var(--ease)}
  .lrow.is-active .lrow__d{height:auto;max-height:340px}
  /* Chevron statt Pfeil: geschlossen = nach unten, geöffnet = nach oben */
  .lrow__arw{opacity:1;transform:none;font-size:0;align-self:start;padding-top:2px}
  .lrow__arw::after{content:"expand_more";font-family:'Material Symbols Rounded';font-size:26px;color:var(--primary);transition:transform .3s var(--ease)}
  .lrow.is-active .lrow__arw::after{content:"expand_less"}
}
@media(max-width:760px){
  /* Muster mobil etwas niedriger – Wabengröße bleibt über auto/125% gekoppelt */
  .hero__band,.band{height:clamp(150px,34vw,200px)}
  /* Bodytexte mobil etwas kleiner */
  .hero__lead,.split__body p,.checks li,.proc__head p,.stp p,.lrow__d,.dir__head p,.ccard__d,.contact__intro p{font-size:16px}
}
@media(max-width:560px){
  .dir-grid{grid-template-columns:1fr}
  .form .fg{grid-template-columns:1fr}
  .facts::before,.list::before,.ft::before,.band--light{background-size:auto 275px}
  .band{background-size:auto 125%}
  .facts-grid{grid-template-columns:repeat(2,1fr)}
  .fc{padding:18px 16px}
  .fc--feat .n{font-size:clamp(30px,9vw,40px)}
  .fc .n{font-size:clamp(28px,8vw,36px)}
  .fc .l{font-size:14px;margin-top:9px;max-width:none}
}

/* ============================================================
   Rechtsseiten (Impressum, Datenschutz, Widerruf, AGB)
   Gleiches Design-System wie die Landingpage.
   ============================================================ */
.legal-hero{padding:clamp(48px,7vw,88px) 0 clamp(24px,3vw,36px);border-top:1px solid var(--line)}
.legal-hero .label{display:block;margin-bottom:16px}
.legal-hero h1{font-size:clamp(34px,5vw,60px);max-width:20ch}
.legal-hero .stand{margin-top:18px;font-family:var(--font-btn);font-weight:600;font-size:13px;letter-spacing:.04em;color:#6a7783}
.legal{padding:0 0 clamp(56px,7vw,96px)}
.legal__in{max-width:760px}
.legal__note{background:#fff;border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:12px;padding:16px 18px;font-size:14.5px;line-height:1.6;color:#51606c;margin-bottom:40px}
.legal h2{font-size:clamp(22px,2.6vw,30px);margin:40px 0 14px;padding-top:26px;border-top:1px solid var(--line)}
.legal h2:first-of-type{border-top:0;padding-top:0;margin-top:0}
.legal h3{font-size:18px;margin:26px 0 10px}
.legal p{font-size:16px;line-height:1.7;color:#41515e;margin-bottom:14px}
.legal ul{margin:0 0 18px;padding:0;list-style:none}
.legal li{position:relative;padding-left:24px;font-size:16px;line-height:1.7;color:#41515e;margin-bottom:8px}
.legal li::before{content:"";position:absolute;left:2px;top:11px;width:7px;height:7px;border-radius:2px;background:var(--primary)}
.legal a{color:var(--navy);border-bottom:1px solid var(--primary)}
.legal a:hover{color:var(--primary)}
.legal strong{color:var(--navy);font-weight:600}
.legal__back{display:inline-flex;align-items:center;gap:8px;margin-top:44px;font-family:var(--font-btn);font-weight:600;font-size:14px;border-bottom:1.5px solid var(--navy);padding-bottom:3px}
.legal__back .material-symbols-rounded{font-size:18px;transition:transform .25s var(--ease)}
.legal__back:hover .material-symbols-rounded{transform:translateX(-4px)}
.legal .stand{margin-top:32px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--font-btn);font-weight:600;font-size:13px;letter-spacing:.03em;color:#6a7783}
.legal-hero .stand{border-top:0;padding-top:0;margin-top:18px}
