/* Self-hosted fonts — no third-party requests (DSGVO) */
@font-face{font-family:'Archivo';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/archivo-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/archivo-ext-500.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/archivo-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/archivo-ext-600.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/archivo-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/archivo-ext-700.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;src:url('../fonts/archivo-800.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:800;font-display:swap;src:url('../fonts/archivo-ext-800.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Archivo';font-style:normal;font-weight:900;font-display:swap;src:url('../fonts/archivo-900.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Archivo';font-style:normal;font-weight:900;font-display:swap;src:url('../fonts/archivo-ext-900.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/manrope-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/manrope-ext-400.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/manrope-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/manrope-ext-500.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/manrope-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/manrope-ext-600.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/manrope-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Manrope';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/manrope-ext-700.woff2') format('woff2');unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}

/* ============================================================
   WK Bau GmbH — Light theme (matches brand screenshot)
   Brand red #C7251A · cream #F7F4ED · ink #1A1915
   ============================================================ */
:root{
  --red:#C7251A;
  --red-deep:#A81C12;
  --red-bright:#E12C1E;
  --ink:#1A1915;
  --ink-soft:#56524A;
  --ink-faint:#76736C;
  --paper:#F7F4ED;
  --paper-2:#EFEDE6;
  --paper-3:#EBEAE6;
  --card:#FFFFFF;
  --line:#E2DDD2;
  --line-soft:#ECE8DF;
  --gold:#E8941F;
  --char:#1A1915;
  --char-2:#141310;
  --maxw:1320px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.6}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;font-weight:700;line-height:.98;letter-spacing:-0.02em;text-transform:uppercase;color:var(--ink)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 44px}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:'Archivo';font-weight:700;font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--red)}
.eyebrow::before{content:"";width:34px;height:3px;background:var(--red);display:inline-block}

/* image placeholder system */
.imgslot{position:relative;display:block;overflow:hidden;background:var(--paper-3);
  background-image:repeating-linear-gradient(45deg,rgba(26,25,21,.03) 0 12px,transparent 12px 24px);
  border:1px dashed var(--line)}
.imgslot::after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;text-align:center;padding:18px;font-family:'Archivo';font-weight:600;font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);z-index:0}
.imgslot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.imgslot img.missing{display:none}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:14px;font-family:'Archivo';font-weight:600;font-size:14px;letter-spacing:.06em;text-transform:uppercase;padding:0;border-radius:100px;cursor:pointer;transition:.25s ease;border:1.5px solid transparent}
.btn-red{background:var(--red);color:#fff;padding:16px 14px 16px 28px}
.btn-red .arr{width:38px;height:38px;border-radius:50%;background:#fff;color:var(--red);display:grid;place-items:center;flex:none;transition:.25s}
.btn-red:hover{background:var(--red-deep);transform:translateY(-2px)}
.btn-out{border-color:var(--ink);color:var(--ink);padding:16px 14px 16px 28px}
.btn-out .arr{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;flex:none;transition:.25s}
.btn-out .arr svg{stroke:#fff}
.btn-out:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.contact .btn-out,footer .btn-out{border-color:rgba(255,255,255,.3);color:#fff}
.contact .btn-out:hover,footer .btn-out:hover{background:#fff;color:var(--ink)}

/* header */
header{position:sticky;top:0;z-index:60;background:rgba(247,244,237,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;height:88px}
.logo{display:flex;align-items:center;gap:13px}
.logo .mark{width:42px;height:auto;flex:none}
.logo .wm{font-family:'Archivo';font-weight:800;font-size:25px;letter-spacing:.01em;line-height:1;color:var(--ink)}
.logo .wm b{color:var(--red)}
.menu{display:flex;align-items:center;gap:38px}
.menu a{font-family:'Archivo';font-weight:600;font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);transition:.2s;position:relative}
.menu a:hover,.menu a.active{color:var(--ink)}
.menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--red)}
.nav-cta .btn{padding:12px 12px 12px 22px}
.nav-cta .btn .arr{width:32px;height:32px}

/* mobile burger + nav */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.5);cursor:pointer}
.burger span{display:block;width:22px;height:2px;background:var(--ink);margin:0 auto;transition:.3s}
.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)}
.mobile-nav{position:fixed;inset:0;z-index:55;background:#F7F4ED;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  opacity:0;visibility:hidden;transition:.3s}
.mobile-nav.open{opacity:1;visibility:visible}
.mobile-nav a{font-family:'Archivo';font-weight:700;font-size:24px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);padding:8px}
.mobile-nav a.btn{font-size:14px;margin-top:18px;color:#fff}

/* hero (split) */
.hero{padding:70px 0 86px}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(40px,4.6vw,72px);font-weight:700;letter-spacing:-0.035em}
.hero h1 .red{color:var(--red)}
.hero .lede{font-size:19px;color:var(--ink-faint);max-width:42ch;margin:24px 0 34px;line-height:1.55}
.hero-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:16px;margin-top:34px;padding-top:28px;border-top:1px solid var(--line)}
.hero .ht-sep{width:1px;height:40px;background:var(--line)}
.hero .ht-num{font-family:'Archivo';font-weight:800;font-size:20px;color:var(--ink);line-height:1;margin-bottom:3px}
.hero-trust .badge{width:46px;height:46px;border-radius:50%;background:#1f8a4c;display:grid;place-items:center;flex:none}
.hero-trust .badge svg{width:24px;height:24px;color:#fff}
.hero-trust .stars{color:#E8941F;letter-spacing:3px;font-size:16px}
.hero-trust .lbl{font-family:'Archivo';font-weight:700;font-size:15px;color:var(--ink);margin-top:2px}
.hero-media{position:relative}
.hero-media .imgslot{width:100%;height:560px;border-radius:10px}
.hero-stamp{position:absolute;left:-28px;bottom:38px;background:var(--red);color:#fff;padding:22px 34px;border-radius:10px;box-shadow:0 22px 44px -22px rgba(199,37,26,.6)}
.hero-stamp .big{font-family:'Archivo';font-weight:800;font-size:54px;line-height:.9;color:#fff}
.hero-stamp .sm{font-family:'Archivo';font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-top:8px}

/* section */
section{padding:88px 0}
.sec-head{margin-bottom:44px}
.sec-head h2{font-size:clamp(38px,4.6vw,68px);font-weight:700;margin-top:20px}
.sec-head .row{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.sec-head p{color:var(--ink-faint);font-size:18px;max-width:46ch;margin-top:18px}

/* services (image cards) */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.svc{position:relative;height:380px;border-radius:10px;overflow:hidden;display:flex;align-items:flex-end}
.svc .imgslot{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:0}
.svc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,25,21,.05) 28%,rgba(26,25,21,.9) 100%);transition:.35s;z-index:2}
.svc:hover::after{background:linear-gradient(180deg,rgba(199,37,26,.18) 0%,rgba(26,25,21,.92) 100%)}
.svc .ov{position:relative;z-index:3;padding:36px;width:100%}
.svc .num{font-family:'Archivo';font-weight:700;font-size:14px;letter-spacing:.2em;color:#fff;opacity:.7}
.svc h3{font-size:30px;font-weight:700;color:#fff;margin:10px 0 0;display:flex;align-items:center;justify-content:space-between;gap:16px}
.svc h3 .go{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.16);display:grid;place-items:center;flex:none;transition:.3s}
.svc:hover h3 .go{background:var(--red)}
.svc p{color:rgba(255,255,255,.82);font-size:15px;margin-top:12px;max-width:42ch;max-height:0;opacity:0;overflow:hidden;transition:.4s}
.svc:hover p{max-height:90px;opacity:1}

/* stats strip */
.stats{background:var(--red);padding:0}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:54px 30px;border-right:1px solid rgba(255,255,255,.24);text-align:center}
.stat:last-child{border-right:none}
.stat .n{font-family:'Archivo';font-weight:800;font-size:clamp(44px,4.5vw,64px);color:#fff;line-height:1}
.stat .l{font-family:'Archivo';font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:rgba(255,255,255,.88);margin-top:10px}

/* about */
.about{background:var(--paper-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.about .imgslot{width:100%;height:560px;border-radius:10px}
.about h2{font-size:clamp(40px,4.4vw,64px);font-weight:700;margin:20px 0 26px}
.about p{color:var(--ink-soft);font-size:17px;max-width:46ch;margin-bottom:18px}
.about .btn{margin-top:14px}

/* features */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.feat{background:var(--card);padding:46px 40px;transition:.3s}
.feat:hover{background:#fff;box-shadow:inset 0 0 0 2px var(--red)}
.feat .ic{width:54px;height:54px;color:var(--red);margin-bottom:26px}
.feat .ic svg{width:100%;height:100%}
.feat h3{font-size:23px;font-weight:700;color:var(--ink);margin-bottom:14px}
.feat p{color:var(--ink-soft);font-size:15px}

/* projects */
.projects{background:var(--paper)}
.proj-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:260px;gap:14px}
.proj-grid .imgslot{width:100%;height:100%;border-radius:8px}
.proj-grid .tall{grid-row:span 2}
.proj-grid .wide{grid-column:span 2}

/* contact (dark band) */
.contact{background:var(--char)}
.contact .eyebrow,.contact h2{color:#fff}
.contact .eyebrow::before{background:var(--red)}
.contact-card{background:#222019;border:1px solid #2c2a22;border-radius:12px;overflow:hidden;display:grid;grid-template-columns:.9fr 1.1fr}
.contact-card .left{padding:60px;border-right:1px solid #2c2a22}
.contact-card h2{font-size:clamp(32px,3.4vw,46px);font-weight:700;color:#fff;margin:18px 0 0}
.contact-card .sub{color:rgba(255,255,255,.6);font-size:16px;margin:18px 0 36px;max-width:32ch}
.person{display:flex;align-items:center;gap:18px}
.person .imgslot{width:80px;height:80px;flex:none;border-radius:50%;border-color:rgba(255,255,255,.18);background:#2c2a22}
.person .imgslot::after{color:rgba(255,255,255,.5)}
.person .nm{font-family:'Archivo';font-weight:700;font-size:20px;color:#fff;text-transform:none;line-height:1.15}
.person .rl{font-size:13px;color:rgba(255,255,255,.5);margin-top:5px}
.contact-card .right{padding:30px 60px;display:flex;flex-direction:column;justify-content:center}
.ctab a{display:flex;align-items:center;gap:20px;padding:26px 0;border-bottom:1px solid #2c2a22;transition:.25s;color:#fff}
.ctab a:first-child{padding-top:0}
.ctab a:last-child{border-bottom:none;padding-bottom:0}
.ctab a:hover{padding-left:8px}
.ctab .ic{width:52px;height:52px;border-radius:10px;background:var(--red);display:grid;place-items:center;flex:none;transition:.25s}
.ctab .ic svg{width:22px;height:22px;color:#fff}
.ctab a:hover .ic{transform:rotate(-6deg) scale(1.05)}
.ctab .lbl{font-family:'Archivo';font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.ctab .val{font-family:'Archivo';font-weight:700;font-size:21px;color:#fff;margin-top:4px}

/* footer */
footer{background:var(--char-2);color:#fff;border-top:4px solid var(--red)}
.foot-top{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;padding:60px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-item{display:flex;align-items:center;gap:18px}
.foot-item .ic{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.06);display:grid;place-items:center;flex:none;color:#fff;border:1px solid rgba(255,255,255,.12)}
.foot-item .ic svg{width:22px;height:22px}
.foot-item .lbl{font-family:'Archivo';font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.foot-item .val{font-family:'Archivo';font-weight:700;font-size:22px;color:#fff;margin-top:3px}
.foot-main{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:36px;padding:70px 0}
.foot-brand .logo{margin-bottom:24px}
.foot-brand .logo .mark{width:40px}
.foot-brand .logo .wm{color:#fff}
.foot-brand p{color:rgba(255,255,255,.5);font-size:14.5px;max-width:30ch}
.socials{display:flex;gap:12px;margin-top:28px}
.socials a{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;transition:.25s}
.socials a svg{width:18px;height:18px;color:#fff}
.socials a:hover{background:var(--red);border-color:var(--red)}
.fcol h4{font-family:'Archivo';font-size:13px;letter-spacing:.18em;color:rgba(255,255,255,.45);margin-bottom:22px}
.fcol a{display:block;color:rgba(255,255,255,.82);font-size:15.5px;padding:8px 0;transition:.2s}
.fcol a:hover{color:var(--red)}
.foot-cta h4{font-family:'Archivo';font-size:20px;color:#fff;margin-bottom:14px;letter-spacing:.02em}
.foot-cta p{color:rgba(255,255,255,.5);font-size:14.5px;margin-bottom:24px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding:28px 0;border-top:1px solid rgba(255,255,255,.1);font-size:13.5px;color:rgba(255,255,255,.45)}
.foot-bottom .links{display:flex;gap:32px}
.foot-bottom a:hover{color:#fff}

@media(max-width:1000px){
  .hero-grid,.about-grid,.contact-card{grid-template-columns:1fr}
  .hero-media .imgslot{height:420px}
  .hero-stamp{left:auto;right:24px;bottom:24px}
  .svc-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr 1fr}
  .stats .wrap{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:none}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .contact-card .left,.contact-card .right{padding:40px}
  .foot-top,.foot-main{grid-template-columns:1fr 1fr}
  .menu,.nav-cta{display:none}
  .burger{display:flex}
}
@media(max-width:640px){
  .wrap{padding:0 22px}
  .feat-grid,.proj-grid,.foot-top,.foot-main,.stats .wrap{grid-template-columns:1fr}
  section{padding:80px 0}
  .hero{padding:46px 0 64px}
  .hero-stamp{padding:16px 22px}
  .hero-stamp .big{font-size:40px}
}

/* full logo lockup in header */
.logo-full{height:62px;width:auto;display:block}
@media(max-width:640px){.logo-full{height:50px}}

/* ===================== MULTI-PAGE COMPONENTS ===================== */
/* sub-page hero — light editorial header */
.page-hero{position:relative;background:var(--paper-2);border-bottom:1px solid var(--line);padding:72px 0 60px;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-60px;top:-40px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(199,37,26,.06),transparent 70%);pointer-events:none}
.page-hero h1{color:var(--ink);font-size:clamp(42px,5.6vw,80px);font-weight:700;margin-top:6px}
.page-hero .ph-sub{color:var(--ink-faint);font-size:18px;max-width:52ch;margin-top:18px}
/* sub-page hero WITH photo background — same overlay treatment as the home hero */
.page-hero.has-img{background:#241f1a;border-bottom:none;padding:0;min-height:360px;display:flex;align-items:flex-end}
.page-hero.has-img::after{display:none}
.page-hero.has-img::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(26,25,21,.45) 0%,rgba(26,25,21,.22) 45%,rgba(26,25,21,.9) 100%)}
.page-hero.has-img > .imgslot{position:absolute;inset:0;z-index:0;border:none;border-radius:0;background:#241f1a;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0 14px,transparent 14px 28px)}
.page-hero.has-img > .imgslot::after{color:rgba(255,255,255,.3)}
.page-hero.has-img > .wrap{position:relative;z-index:2;width:100%;padding:56px 0 48px}
.page-hero.has-img .breadcrumb,.page-hero.has-img .breadcrumb a{color:rgba(255,255,255,.82)}
.page-hero.has-img .breadcrumb a:hover{color:#fff}
.page-hero.has-img h1{color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.4)}
.page-hero.has-img .ph-sub{color:rgba(255,255,255,.9);max-width:52ch}
.breadcrumb{display:flex;align-items:center;gap:10px;font-family:'Archivo';font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.breadcrumb a{color:var(--ink-faint)}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb span{color:var(--red)}

/* alternating image + text rows */
.introw{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.introw .imgslot{width:100%;height:480px;border-radius:10px}
.introw.flip .imgslot{order:2}
.introw h2{font-size:clamp(30px,3.4vw,48px);margin:18px 0 22px}
.introw p{color:var(--ink-soft);font-size:16.5px;margin-bottom:16px;max-width:50ch}
.svc-list{list-style:none;margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:12px 24px}
.svc-list li{display:flex;align-items:flex-start;gap:10px;color:var(--ink-soft);font-size:15px;font-weight:500}
.svc-list li::before{content:"\2713";color:var(--red);font-weight:900;flex:none}

/* process steps */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.pstep{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:34px 28px;transition:.3s}
.pstep:hover{box-shadow:inset 0 0 0 2px var(--red)}
.pstep .pn{font-family:'Archivo';font-weight:800;font-size:42px;color:var(--red);line-height:1}
.pstep h3{font-size:20px;margin:14px 0 10px}
.pstep p{color:var(--ink-soft);font-size:14.5px}

/* category chips */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:42px}
.chip{font-family:'Archivo';font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:10px 20px;border-radius:100px;border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;transition:.2s;user-select:none}
.chip.on,.chip:hover{background:var(--red);border-color:var(--red);color:#fff}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gcard{position:relative;height:300px;border-radius:10px;overflow:hidden}
.gcard .imgslot{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:0}
.gcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(26,25,21,.88) 100%);z-index:2;transition:.3s}
.gcard:hover::after{background:linear-gradient(180deg,rgba(199,37,26,.16) 0%,rgba(26,25,21,.92) 100%)}
.gcard .cap{position:absolute;left:0;bottom:0;z-index:3;padding:24px}
.gcard .cap .cat{font-family:'Archivo';font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#C7251A}
.gcard .cap h3{font-size:21px;color:#fff;margin-top:6px}

/* contact page */
.contact-page{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}
.cinfo .citem{display:flex;gap:18px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line)}
.cinfo .citem:first-of-type{padding-top:0}
.cinfo .citem:last-child{border-bottom:none}
.cinfo .ic{width:50px;height:50px;border-radius:10px;background:var(--red);display:grid;place-items:center;flex:none;color:#fff}
.cinfo .ic svg{width:22px;height:22px}
.cinfo .lbl{font-family:'Archivo';font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
.cinfo .val{display:block;font-family:'Archivo';font-weight:700;font-size:19px;color:var(--ink);margin-top:4px}
a.val:hover{color:var(--red)}
.form{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:40px}
.form .fg{margin-bottom:18px}
.form label{display:block;font-family:'Archivo';font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.form input,.form textarea,.form select{width:100%;border:1px solid var(--line);border-radius:8px;padding:14px 16px;font-family:'Manrope';font-size:15px;background:var(--paper);color:var(--ink);transition:.2s}
.form select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C7251A' stroke-width='2.6'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--red);background-color:#fff;box-shadow:0 0 0 4px rgba(199,37,26,.08)}
.form textarea{min-height:130px;resize:vertical}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form .check{display:flex;gap:10px;align-items:flex-start;font-family:'Manrope';font-size:12.5px;font-weight:400;letter-spacing:0;text-transform:none;color:var(--ink-soft);line-height:1.5}
.form .check a{color:var(--red);text-decoration:underline}
.form button.btn{border:none}
.alert{background:#E7F4EC;border:1px solid #B9DCC6;color:#1f8a4c;padding:14px 18px;border-radius:8px;margin-bottom:24px;font-size:14.5px;font-weight:600}
.map{width:100%;height:430px;border:0;border-radius:12px;display:block}

/* CTA band */
.cta-band{background:var(--red);text-align:center}
.cta-band h2{color:#fff;font-size:clamp(34px,4vw,60px)}
.cta-band p{color:rgba(255,255,255,.88);font-size:18px;margin:18px auto 34px;max-width:48ch}
.btn-white{background:#fff;color:var(--red);padding:16px 14px 16px 28px;display:inline-flex;align-items:center;gap:14px;font-family:'Archivo';font-weight:600;font-size:14px;letter-spacing:.06em;text-transform:uppercase;border-radius:100px;transition:.25s}
.btn-white .arr{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;flex:none}
.btn-white:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-white:hover .arr{background:#fff;color:var(--ink)}

@media(max-width:1000px){
  .introw,.contact-page{grid-template-columns:1fr;gap:36px}
  .introw.flip .imgslot{order:0}
  .introw .imgslot{height:360px}
  .process{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .process,.gallery,.svc-list{grid-template-columns:1fr}
  .form{padding:26px}
  .form .row2{grid-template-columns:1fr}
  .page-hero{padding:48px 0 40px}
  .page-hero.has-img{min-height:280px;padding:0}
  .page-hero.has-img > .wrap{padding:40px 0 34px}
}

/* legal pages (Impressum / Datenschutz) */
.legal{max-width:860px;margin:0 auto}
.legal h2{font-size:clamp(24px,2.4vw,32px);margin:46px 0 16px;text-transform:none;letter-spacing:-.01em}
.legal h2:first-child{margin-top:0}
.legal h3{font-size:20px;margin:30px 0 10px;text-transform:none}
.legal h4{font-size:16px;margin:22px 0 8px;text-transform:none;color:var(--ink);font-family:'Archivo';font-weight:700}
.legal p{color:var(--ink-soft);font-size:16px;margin-bottom:16px;line-height:1.7}
.legal ul{color:var(--ink-soft);font-size:16px;margin:0 0 16px 22px}
.legal li{margin-bottom:8px}
.legal a{color:var(--red);text-decoration:underline;word-break:break-word}
.legal strong{color:var(--ink)}
.legal .src{font-size:13.5px;color:var(--ink-faint);margin-top:34px;padding-top:18px;border-top:1px solid var(--line);font-style:italic}

/* info top-bar (above header) */
.topbar{background:var(--red);color:#fff}
.tb-in{display:flex;align-items:center;justify-content:space-between;height:44px}
.tb-left{display:flex;align-items:center;gap:28px}
.tb-left a,.tb-left span.tb-hours{display:inline-flex;align-items:center;gap:8px;color:#fff;font-family:'Archivo';font-weight:600;font-size:13px;letter-spacing:.02em}
.tb-left a:hover{opacity:.82}
.tb-left svg{width:15px;height:15px;flex:none}
.tb-social{display:flex;align-items:center;gap:16px}
.tb-social a{color:#fff;display:inline-flex;transition:.2s}
.tb-social svg{width:16px;height:16px}
.tb-social a:hover{opacity:.78}
.tb-left a,.tb-left span.tb-hours{white-space:nowrap}
@media(max-width:1000px){.tb-left span.tb-hours{display:none}}
@media(max-width:640px){
  .tb-social{display:none}
  .tb-left{gap:22px}
  .tb-left a{font-size:12px}
  .tb-in{height:40px;justify-content:center}
}
@media(max-width:420px){.tb-left a.tb-mail{display:none}}

/* ===== Variant B: transparent header over full-bleed image hero (home only) ===== */
header.over{position:absolute;top:0;left:0;right:0;background:transparent;border-bottom:1px solid rgba(255,255,255,.16);backdrop-filter:none}
header.over .logo .mark{width:42px;height:auto}
header.over .logo .wm{color:#fff}
header.over .logo .wm b{color:#C7251A}
header.over .menu a{color:rgba(255,255,255,.85)}
header.over .menu a:hover,header.over .menu a.active{color:#fff}
header.over .menu a.active::after{background:#fff}
header.over .burger{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.08)}
header.over .burger span{background:#fff}
/* solidify on scroll */
header.over.scrolled{position:fixed;background:rgba(247,244,237,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);animation:drop .4s ease}
@keyframes drop{from{transform:translateY(-100%)}to{transform:translateY(0)}}
header.over.scrolled .logo .wm{color:var(--ink)}
header.over.scrolled .logo .wm b{color:var(--red)}
header.over.scrolled .menu a{color:var(--ink-soft)}
header.over.scrolled .menu a:hover,header.over.scrolled .menu a.active{color:var(--ink)}
header.over.scrolled .menu a.active::after{background:var(--red)}
header.over.scrolled .burger{border-color:var(--line);background:rgba(255,255,255,.5)}
header.over.scrolled .burger span{background:var(--ink)}

.hero-img{position:relative;height:100svh;min-height:600px;max-height:900px;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink)}
.hero-img > .imgslot{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:0;background:#241f1a;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0 14px,transparent 14px 28px)}
.hero-img > .imgslot::after{color:rgba(255,255,255,.3)}
.hero-img::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(26,25,21,.5) 0%,rgba(26,25,21,.18) 40%,rgba(26,25,21,.88) 100%)}
.hero-img .hero-inner{position:relative;z-index:2;width:100%;padding:0 0 84px}
.hero-img h1{color:#fff;font-size:clamp(48px,6.6vw,102px);font-weight:700;letter-spacing:-.035em;line-height:.96;text-shadow:0 4px 34px rgba(0,0,0,.35);max-width:60%}
.hero-img h1 .red{color:#C7251A}
.hero-img .lede{color:rgba(255,255,255,.86);font-size:clamp(16px,1.5vw,20px);max-width:46ch;margin-top:20px}
.hero-img .hero-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:26px}
.hero-img .hero-trust{display:flex;align-items:center;gap:16px;margin-top:34px;padding-top:26px;border-top:1px solid rgba(255,255,255,.22)}
.hero-img .hero-trust .lbl{font-family:'Archivo';font-weight:700;font-size:15px;color:#fff;margin-top:2px}
.hero-img .hero-trust .stars{color:#E8941F;letter-spacing:3px;font-size:16px}
.hero-img .hero-trust .badge{width:46px;height:46px;border-radius:50%;background:#1f8a4c;display:grid;place-items:center;flex:none}
.hero-img .hero-trust .badge svg{width:24px;height:24px;color:#fff}
.hero-img .btn-out{border-color:rgba(255,255,255,.5);color:#fff}
.hero-img .btn-out .arr{background:var(--red);color:#fff}
.hero-img .btn-out .arr svg{stroke:#fff}
/* Variant A: smaller hero buttons with more breathing room */
.hero-img .hero-cta{gap:14px}
.hero-img .hero-cta .btn{font-size:12.5px;letter-spacing:.05em}
.hero-img .hero-cta .btn-red,.hero-img .hero-cta .btn-out{padding:12px 12px 12px 22px;gap:11px}
.hero-img .hero-cta .btn .arr{width:30px;height:30px}
.hero-img .btn-out:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero-img .hero-stamp{position:absolute;top:116px;right:44px;left:auto;bottom:auto;z-index:2}
@media(max-width:1000px){.hero-img h1{max-width:100%}.hero-img .hero-stamp{display:none}}
@media(max-width:640px){.hero-img{min-height:90vh}.hero-img .hero-inner{padding-bottom:54px}.hero-img .hero-stamp{display:none}}

/* ===== Restyled sections (services cards / project cards / about stats card) ===== */
.sec-head.center{text-align:center;max-width:680px;margin:0 auto 60px}
.sec-head.center .eyebrow{display:inline-flex}
.sec-head.center h2{margin-top:16px}
.sec-head.center p{margin:18px auto 0;max-width:54ch;color:var(--ink-faint);font-size:18px}

/* "Mehr erfahren / ansehen" link */
.more{display:inline-flex;align-items:center;gap:9px;font-family:'Archivo';font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--red)}
.more svg{width:18px;height:14px;transition:.22s}
.scard:hover .more svg,.pcard:hover .more svg{transform:translateX(5px)}

/* service cards (image top + red circular icon) */
.scard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.scard{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;position:relative;transition:.3s}
.scard:hover{transform:translateY(-5px);border-color:var(--red);box-shadow:0 22px 44px -28px rgba(0,0,0,.4)}
.scard-img{position:relative;height:196px}
.scard-img .imgslot{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:0}
.scard-ic{position:absolute;top:168px;left:26px;z-index:3;width:56px;height:56px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;box-shadow:0 10px 22px -8px rgba(199,37,26,.65)}
.scard-ic svg{width:26px;height:26px}
.scard-body{padding:40px 26px 28px}
.scard-body h3{font-size:19px;font-weight:700;margin-bottom:12px;overflow-wrap:break-word;hyphens:auto}
.scard-body p{color:var(--ink-soft);font-size:14.5px;margin-bottom:20px;min-height:63px}

/* project cards (badge + title below) */
.pcard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px 20px}
.pcard{display:block}
.pcard-img{position:relative;height:236px;border-radius:12px;overflow:hidden;background:var(--paper-3)}
.pcard-img .imgslot{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:0}
.pcard-img .imgslot img{transition:transform .4s ease}
.pcard:hover .pcard-img .imgslot img{transform:scale(1.05)}
.pcard-badge{position:absolute;top:16px;left:16px;z-index:3;background:#fff;color:var(--ink);font-family:'Archivo';font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:7px 14px;border-radius:8px;box-shadow:0 4px 14px -6px rgba(0,0,0,.35)}
.pcard-title{font-size:22px;font-weight:700;color:var(--ink);margin:18px 0 12px;text-transform:uppercase;letter-spacing:-.01em}

/* about with overlapping stats card */
.about2{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:center}
.about2-copy h2{font-size:clamp(34px,4vw,58px);font-weight:700;line-height:1.0;margin:18px 0 26px}
.about2-copy p{color:var(--ink-soft);font-size:16.5px;margin-bottom:16px;max-width:46ch}
.about2-copy .btn{margin-top:16px}
.about2-media{position:relative;padding-bottom:46px}
.about2-media > .imgslot{width:100%;height:480px;border-radius:14px}
.mini-stats{position:relative;z-index:2;margin:-72px auto 0;width:92%;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 26px 54px -32px rgba(0,0,0,.4);display:grid;grid-template-columns:.9fr 1.5fr;overflow:hidden}
.ms-hero{background:var(--red);padding:30px 26px;display:flex;flex-direction:column;justify-content:center}
.ms-big{font-family:'Archivo';font-weight:900;font-size:clamp(48px,5vw,68px);color:#fff;line-height:.88}
.ms-sub{font-family:'Archivo';font-weight:600;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.9);margin-top:12px}
.ms-list{display:grid;grid-template-columns:repeat(3,1fr)}
.ms{padding:26px 12px;text-align:center;border-right:1px solid var(--line)}
.ms:last-child{border-right:none}
.ms-ic{color:var(--red);display:inline-flex}
.ms-ic svg{width:26px;height:26px}
.ms-n{font-family:'Archivo';font-weight:800;font-size:18px;color:var(--ink);margin-top:12px;line-height:1.15;text-wrap:balance;display:flex;align-items:center;justify-content:center;min-height:2.3em}
.ms-l{font-size:12px;color:var(--ink-faint);margin-top:8px;line-height:1.3}

@media(max-width:1000px){
  .scard-grid,.pcard-grid{grid-template-columns:1fr 1fr}
  .about2{grid-template-columns:1fr;gap:34px}
  .about2-media > .imgslot{height:380px}
  .mini-stats{grid-template-columns:1fr;width:100%;margin-top:-56px}
  .ms-hero{flex-direction:row;align-items:baseline;gap:14px;padding:22px 26px}
  .ms-big{font-size:46px}
  .ms-sub{margin-top:0}
}
@media(max-width:480px){
  .ms-list{grid-template-columns:1fr}
  .ms{border-right:none;border-bottom:1px solid var(--line)}
  .ms:last-child{border-bottom:none}
  .ms-n{min-height:0}
}
@media(max-width:640px){
  .scard-grid,.pcard-grid{grid-template-columns:1fr}
  .scard-body p{min-height:0}
}

/* ===== CTA — red split band: text left, button right (variant B) ===== */
.cta{background:var(--paper);padding-top:40px}
.cta-split{background:var(--red);border-radius:16px;padding:52px 56px;display:flex;align-items:center;justify-content:space-between;gap:44px}
.cta-text h2{color:#fff;font-size:clamp(30px,3.4vw,48px);font-weight:700;line-height:1.02}
.cta-text p{color:rgba(255,255,255,.9);font-size:17px;margin-top:14px;max-width:48ch}
.cta-split .btn-white{flex:none}
@media(max-width:760px){.cta-split{flex-direction:column;align-items:flex-start;padding:40px 30px;gap:26px}}

/* long word values in the about stats card */
.ms-n{overflow-wrap:break-word}

/* ===== unified logo image (same logo everywhere, tone adapts to background) ===== */
.logo-img{height:52px;width:auto;display:block}
.logo{display:inline-flex;align-items:center}
header.over .on-light{display:none}
header.over .on-dark{display:block}
header.over.scrolled .on-dark{display:none}
header.over.scrolled .on-light{display:block}
.foot-brand .logo-img{height:58px}
@media(max-width:640px){.logo-img{height:44px}.foot-brand .logo-img{height:50px}}

/* ===== hero tweaks: smaller headline, lower content, smaller stamp, project count ===== */
.hero-img h1{font-size:clamp(38px,4.8vw,78px)}
.hero-img .lede{font-size:clamp(15px,1.4vw,18px);margin-top:18px}
.hero-img .hero-inner{padding-bottom:60px}
.hero-img .hero-stamp{padding:14px 20px;top:104px;right:40px}
.hero-img .hero-stamp .big{font-size:36px}
.hero-img .hero-stamp .sm{font-size:8px}
.hero-img .hero-trust{flex-wrap:wrap}
.ht-sep{width:1px;height:40px;background:rgba(255,255,255,.25)}
.ht-num{font-family:'Archivo';font-weight:800;font-size:20px;color:#fff;line-height:1;margin-bottom:3px}
/* anchor offset so sticky header doesn't cover linked Leistung sections */
.introw{scroll-margin-top:120px}

/* ===== hero v2: bigger headline centered, buttons pinned bottom (desktop + mobile) ===== */
.hero-img .hero-inner{display:flex;align-items:stretch;padding:0}
.hero-img .hero-inner > .wrap{display:flex;flex-direction:column;justify-content:space-between;height:100%;padding-top:118px;padding-bottom:42px;width:100%}
.hero-center{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;max-width:none;padding-bottom:30px}
.hero-img h1{font-size:clamp(40px,5.4vw,82px);line-height:1.0;max-width:none}
.hero-img .lede{max-width:50ch;font-size:clamp(15px,1.3vw,18px)}
.hero-img .hero-cta{margin-top:0}
.hero-img .hero-trust{margin-top:26px}
.hero-img .hero-stamp{display:none}
@media(max-width:640px){
  .hero-img .hero-inner > .wrap{padding-top:104px;padding-bottom:30px}
  .hero-img h1{font-size:clamp(34px,9vw,50px)}
  .hero-img .lede{margin-top:14px}
  .hero-img .hero-trust{margin-top:18px}
  .hero-img .hero-cta{flex-direction:column;align-items:stretch;width:100%}
  .hero-img .hero-cta .btn{justify-content:center;width:100%}
}

/* ===== Project detail lightbox ===== */
body.lb-open{overflow:hidden}
.proj-lb{position:fixed;inset:0;z-index:1000;display:none}
.proj-lb.show{display:block}
.proj-lb-overlay{position:absolute;inset:0;background:rgba(20,19,16,.72);backdrop-filter:blur(3px)}
.proj-lb-box{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(1040px,94vw);max-height:92vh;overflow:auto;background:var(--paper);border-radius:18px;box-shadow:0 40px 100px -30px rgba(0,0,0,.7)}
.proj-lb-close{position:absolute;top:14px;right:16px;z-index:5;width:42px;height:42px;border-radius:50%;border:none;background:rgba(255,255,255,.9);color:var(--ink);font-size:26px;line-height:1;cursor:pointer;transition:.2s}
.proj-lb-close:hover{background:var(--red);color:#fff}
.proj-lb-content{display:block}
.plb-top{display:grid;grid-template-columns:1.05fr .95fr;gap:0}
.plb-media{padding:0}
.plb-main{height:100%;min-height:420px;border:none;border-radius:18px 0 0 18px}
.plb-main .imgslot,.plb-main img{width:100%;height:100%;object-fit:cover}
.plb-main{overflow:hidden}
/* gallery thumbnails: full-width strip, 2 rows, horizontally scrollable */
.plb-thumbs{display:grid;grid-template-rows:repeat(2,1fr);grid-auto-flow:column;grid-auto-columns:200px;gap:12px;padding:18px 42px 6px;overflow-x:auto;scroll-snap-type:x proximity;scrollbar-width:thin}
.plb-thumbs::-webkit-scrollbar{height:9px}
.plb-thumbs::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.plb-thumbs .imgslot{width:200px;height:140px;border:1px solid var(--line);border-radius:10px;overflow:hidden;cursor:zoom-in;scroll-snap-align:start;transition:.18s}
.plb-thumbs .imgslot:hover{border-color:var(--red);transform:translateY(-2px)}
.plb-thumbs .imgslot img{width:100%;height:100%;object-fit:cover}
/* fullscreen image zoom */
.plb-zoom{position:fixed;inset:0;z-index:1100;display:none;align-items:center;justify-content:center;background:rgba(20,19,16,.92);padding:40px;cursor:zoom-out}
.plb-zoom.show{display:flex}
.plb-zoom img{max-width:94vw;max-height:90vh;object-fit:contain;border-radius:10px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8)}
.plb-zoom-close{position:absolute;top:22px;right:26px;width:46px;height:46px;border-radius:50%;border:none;background:rgba(255,255,255,.92);color:var(--ink);font-size:28px;line-height:1;cursor:pointer;transition:.2s}
.plb-zoom-close:hover{background:var(--red);color:#fff}
.plb-info{padding:46px 42px}
.plb-badge{position:static;display:inline-block;margin-bottom:14px;box-shadow:none;border:1px solid var(--line)}
.plb-info h3{font-size:clamp(26px,3vw,40px);font-weight:700;text-transform:uppercase;letter-spacing:-.01em;line-height:1.04}
.plb-desc{color:var(--ink-soft);font-size:16px;margin-top:14px;line-height:1.6}
.plb-facts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:24px 0}
.plb-fact{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.plb-fact span{display:block;font-family:'Archivo';font-weight:600;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:4px}
.plb-fact b{font-family:'Archivo';font-weight:700;font-size:18px;color:var(--ink)}
.plb-info h4{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.plb-work{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.plb-work li{position:relative;padding-left:22px;color:var(--ink-soft);font-size:14.5px}
.plb-work li::before{content:"✓";position:absolute;left:0;color:var(--red);font-weight:700}
.proj-lb-nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 42px 30px;border-top:1px solid var(--line)}
.plb-prev,.plb-next{background:none;border:1.5px solid var(--ink);color:var(--ink);font-family:'Archivo';font-weight:600;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:11px 20px;border-radius:100px;cursor:pointer;transition:.2s}
.plb-prev:hover,.plb-next:hover{background:var(--ink);color:#fff}
.plb-contact{flex:none}
@media(max-width:760px){
  .plb-top{grid-template-columns:1fr}
  .plb-main{min-height:240px;border-radius:18px 18px 0 0}
  .plb-info{padding:30px 24px}
  .plb-facts,.plb-work{grid-template-columns:1fr}
  .plb-thumbs{grid-template-rows:1fr;grid-auto-columns:70%;padding:14px 24px 4px}
  .plb-thumbs .imgslot{width:100%;height:120px}
  .proj-lb-nav{flex-wrap:wrap;justify-content:center;padding:18px 24px 26px}
  .plb-contact{order:-1;width:100%;justify-content:center}
}

/* ===== Leistungen carousel ===== */
.lcar-controls{display:flex;gap:10px;align-self:center}
.lcar-btn{width:48px;height:48px;border-radius:50%;border:1.5px solid var(--ink);background:none;color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:.2s}
.lcar-btn:hover{background:var(--red);border-color:var(--red);color:#fff}
.lcar-btn svg{width:20px;height:20px}
.lcar-btn:disabled{opacity:.3;cursor:not-allowed}
.lcar{display:grid;grid-auto-flow:column;grid-auto-columns:280px;gap:22px;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding:6px 2px 16px;margin-top:40px;scrollbar-width:none}
.lcar::-webkit-scrollbar{display:none}
.lcard{scroll-snap-align:start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 26px;display:flex;flex-direction:column;gap:14px;transition:.25s;min-height:210px}
a.lcard:hover{transform:translateY(-5px);border-color:var(--red);box-shadow:0 22px 44px -28px rgba(0,0,0,.4)}
.lc-ic{width:50px;height:50px;border-radius:12px;background:var(--paper-2);color:var(--red);display:grid;place-items:center}
.lc-ic svg{width:26px;height:26px}
.lcard h3{font-size:19px;font-weight:700;line-height:1.15;flex:1}
.lc-more{display:inline-flex;align-items:center;gap:8px;font-family:'Archivo';font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--red)}
.lc-more svg{width:16px;height:13px;transition:.2s}
a.lcard:hover .lc-more svg{transform:translateX(4px)}
.lc-more.muted{color:var(--ink-faint)}
@media(max-width:640px){.lcar{grid-auto-columns:80%}.lcar-controls{align-self:flex-start;margin-top:10px}}

/* FAQ (Über uns) */
.faq{display:grid;gap:14px;max-width:860px}
.faq-item{background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:20px 24px}
.faq-item h3{font-size:18px;font-weight:700;margin-bottom:6px;color:var(--ink)}
.faq-item p{color:var(--ink-soft);font-size:15.5px;margin:0}

/* Two-service grid: 2 cols centered on desktop; tablet/mobile breakpoints stack it */
@media(min-width:1001px){.scard-grid.scard-2{grid-template-columns:repeat(2,1fr);max-width:860px;margin-inline:auto}}


/* ===== Project modal — TWIN-style stacked layout ===== */
.proj-lb-content{padding:0}
.plb-head{padding:44px 44px 0}
.plb-badge{position:static;display:inline-block;margin-bottom:14px;box-shadow:none;border:1px solid var(--line)}
.plb-head h3{font-size:clamp(26px,3vw,40px);font-weight:700;text-transform:uppercase;letter-spacing:-.01em;line-height:1.04}
.plb-meta{margin-top:12px;font-family:'Archivo';font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
.plb-hero{display:block;position:relative;width:calc(100% - 88px);margin:22px 44px 0;height:min(52vh,460px);border-radius:14px;overflow:hidden;border:none;cursor:zoom-in;padding:0;background:var(--paper-3)}
.plb-hero img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.plb-hero:hover img{transform:scale(1.03)}
.plb-hero-zoom{position:absolute;right:14px;bottom:14px;display:inline-flex;align-items:center;gap:7px;background:rgba(20,19,16,.8);color:#fff;font-family:'Archivo';font-weight:600;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;padding:8px 13px;border-radius:100px}
.plb-hero-zoom svg{width:15px;height:15px}
.plb-cols{display:grid;grid-template-columns:1fr 1fr;gap:34px;padding:30px 44px 6px}
.plb-col h4{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--red);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.plb-col h4::before{content:"";width:26px;height:2px;background:var(--red)}
.plb-desc{color:var(--ink-soft);font-size:16px;line-height:1.65;margin:0}
.plb-work{list-style:none;display:grid;gap:10px;grid-template-columns:1fr}
.plb-work li{position:relative;padding-left:24px;color:var(--ink-soft);font-size:15px}
.plb-work li::before{content:"";position:absolute;left:2px;top:7px;width:0;height:0;border-left:7px solid var(--red);border-top:4.5px solid transparent;border-bottom:4.5px solid transparent}
.plb-thumbs{display:flex;gap:12px;padding:18px 44px 10px;overflow-x:auto;scrollbar-width:thin}
.plb-thumb{flex:0 0 200px;width:200px;height:140px;border:1px solid var(--line);border-radius:10px;overflow:hidden;cursor:zoom-in;padding:0;background:var(--paper-3);transition:.18s}
.plb-thumb:hover{border-color:var(--red);transform:translateY(-2px)}
.plb-thumb img{width:100%;height:100%;object-fit:cover}
@media(max-width:640px){
  .plb-head{padding:28px 22px 0}
  .plb-hero{width:calc(100% - 44px);margin:16px 22px 0;height:42vh}
  .plb-cols{grid-template-columns:1fr;gap:22px;padding:24px 22px 4px}
  .plb-thumbs{padding:14px 22px 8px}
  .plb-thumb{flex-basis:74%;width:74%;height:150px}
}
/* ===== Navigable image lightbox ===== */
.plb-zoom{position:fixed;inset:0;z-index:1100;display:none;align-items:center;justify-content:center;background:rgba(20,19,16,.94);padding:40px;cursor:zoom-out}
.plb-zoom.show{display:flex}
.plb-zoom img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:10px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8)}
.plb-z-close{position:absolute;top:20px;right:24px;width:46px;height:46px;border-radius:50%;border:none;background:rgba(255,255,255,.92);color:var(--ink);font-size:28px;line-height:1;cursor:pointer;transition:.2s;z-index:2}
.plb-z-close:hover{background:var(--red);color:#fff}
.plb-z-prev,.plb-z-next{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:none;background:rgba(255,255,255,.9);color:var(--ink);font-size:30px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;z-index:2}
.plb-z-prev{left:24px}.plb-z-next{right:24px}
.plb-z-prev:hover,.plb-z-next:hover{background:var(--red);color:#fff}
.plb-z-count{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;font-family:'Archivo';font-weight:600;font-size:13px;letter-spacing:.1em;background:rgba(0,0,0,.45);padding:6px 14px;border-radius:100px}
@media(max-width:640px){.plb-z-prev,.plb-z-next{width:44px;height:44px;font-size:24px}.plb-z-prev{left:10px}.plb-z-next{right:10px}}
/* ===== Cookie consent ===== */
.ck-banner{position:fixed;left:0;right:0;bottom:0;z-index:1200;background:var(--red-deep);color:#fff;box-shadow:0 -10px 40px -10px rgba(0,0,0,.4);transform:translateY(110%);transition:transform .35s ease}
.ck-banner.show{transform:none}
.ck-inner{max-width:1100px;margin:0 auto;padding:20px 24px;display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.ck-text{flex:1 1 420px;min-width:240px}
.ck-text strong{font-family:'Archivo';font-size:15px;display:block;margin-bottom:5px}
.ck-text p{font-size:13.5px;line-height:1.6;color:rgba(255,255,255,.86);margin:0}
.ck-text a{color:#fff;text-decoration:underline}
.ck-btns{display:flex;gap:10px;flex-wrap:wrap}
.btn-ck{font-family:'Archivo';font-weight:600;font-size:13px;padding:12px 18px;border-radius:100px;border:1.5px solid rgba(255,255,255,.4);background:transparent;color:#fff;cursor:pointer;transition:.2s}
.btn-ck:hover{border-color:#fff}
.btn-ck.ck-accept,.btn-ck.ck-accept2{background:var(--red);border-color:var(--red)}
.btn-ck.ck-accept:hover,.btn-ck.ck-accept2:hover{background:var(--red-bright);border-color:var(--red-bright)}
@media(max-width:640px){.ck-inner{padding:16px}.ck-btns{width:100%}.btn-ck{flex:1 1 auto;text-align:center}}
.ck-modal{position:fixed;inset:0;z-index:1300;display:none}
.ck-modal.show{display:block}
.ck-modal-ov{position:absolute;inset:0;background:rgba(20,19,16,.6)}
.ck-modal-box{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(540px,92vw);max-height:88vh;overflow:auto;background:var(--paper);border-radius:16px;padding:30px 30px 26px;box-shadow:0 40px 100px -30px rgba(0,0,0,.6)}
.ck-modal-box h3{font-size:24px}
.ck-modal-box>p{color:var(--ink-soft);font-size:14px;margin:10px 0 18px;line-height:1.6}
.ck-modal-box>p a{color:var(--red)}
.ck-x{position:absolute;top:14px;right:16px;width:38px;height:38px;border-radius:50%;border:none;background:var(--paper-2);font-size:22px;cursor:pointer}
.ck-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px 0;border-top:1px solid var(--line)}
.ck-row span{display:flex;flex-direction:column}
.ck-row b{font-family:'Archivo';font-size:15px}
.ck-row small{color:var(--ink-faint);font-size:12.5px;margin-top:3px;line-height:1.5}
.ck-row input{width:20px;height:20px;flex:none;margin-top:3px;accent-color:var(--red)}
.ck-modal-btns{display:flex;gap:10px;margin-top:22px;flex-wrap:wrap}
.ck-modal-btns .btn-ck{flex:1 1 auto;text-align:center;border-color:var(--ink);color:var(--ink)}
.ck-modal-btns .ck-accept2{color:#fff}
/* ===== WhatsApp floating button ===== */
.wa-fab{position:fixed;right:20px;bottom:20px;z-index:1150;width:58px;height:58px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 30px -6px rgba(199,37,26,.45);transition:transform .2s, bottom .25s}
.wa-fab svg{width:32px;height:32px}
.wa-fab:hover{transform:scale(1.08);background:var(--red-bright)}
body.ck-show .wa-fab{bottom:132px}
@media(max-width:640px){.wa-fab{width:54px;height:54px;right:16px;bottom:16px}.wa-fab svg{width:30px;height:30px}body.ck-show .wa-fab{bottom:210px}}
/* ===== Google Maps consent gate ===== */
.map-consent{height:430px;border-radius:12px;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--paper-2);border:1px solid var(--line)}
.map-gate-inner{max-width:460px;padding:24px}
.map-gate-inner h3{font-size:20px;margin-bottom:8px}
.map-gate-inner p{color:var(--ink-soft);font-size:14px;line-height:1.6;margin-bottom:18px}
.map-remember{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--ink-faint);margin-top:14px}
.map-remember input{width:auto;accent-color:var(--red)}
.ck-foot-link{cursor:pointer}

/* mobile: cookie banner stacks cleanly; hero heading never overflows */
.hero h1,.page-hero h1{overflow-wrap:break-word;hyphens:manual}
@media(max-width:640px){
  .ck-inner{flex-direction:column;align-items:stretch;gap:14px}
  .ck-text{flex:none}
  .ck-btns{width:100%}
  .btn-ck{flex:1 1 auto;text-align:center;padding:13px 16px}
}

body.lb-open .wa-fab{display:none}

/* red banner buttons */
.ck-banner .btn-ck{border-color:rgba(255,255,255,.55);color:#fff;background:transparent}
.ck-banner .btn-ck:hover{border-color:#fff;background:rgba(255,255,255,.12)}
.ck-banner .btn-ck.ck-accept{background:#fff;border-color:#fff;color:var(--red-deep)}
.ck-banner .btn-ck.ck-accept:hover{background:var(--paper);border-color:var(--paper);color:var(--red-deep)}
/* Leistungen — each service as a separated card under its category */
.lpillar{display:grid;gap:40px}
.svc-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.svc-card{display:flex;flex-direction:column;gap:12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px 18px;transition:.2s}
.svc-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:0 16px 30px -18px rgba(0,0,0,.25)}
.svc-no{font-family:'Archivo';font-weight:800;font-size:12.5px;letter-spacing:.12em;color:var(--red)}
.svc-name{font-family:'Archivo';font-weight:700;font-size:16px;line-height:1.16;text-transform:uppercase;letter-spacing:-.01em;color:var(--ink)}
@media(max-width:1000px){.svc-cards{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.svc-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:440px){.svc-cards{grid-template-columns:1fr}}

/* ============================================================
   2026 REFRESH — type, color & finish layer
   Stone & Ember palette · Bricolage Grotesque + Hanken Grotesk
   ============================================================ */
body{background:
    radial-gradient(900px 520px at 88% -8%, rgba(199,37,26,.045), transparent 60%),
    radial-gradient(720px 480px at -6% 4%, rgba(26,24,18,.04), transparent 55%),
    var(--paper);
  background-attachment:fixed}



/* trust signals harmonised */
.hero-trust .badge,.hero-img .hero-trust .badge{background:#1f8a4c}
.hero-trust .stars,.hero-img .hero-trust .stars{color:var(--gold)}

/* buttons — more presence + arrow micro-motion */
.btn{letter-spacing:.08em}
.btn-red{box-shadow:0 12px 26px -14px rgba(199,37,26,.55)}
.btn-red:hover{box-shadow:0 16px 30px -12px rgba(168,28,18,.6)}
.btn .arr{transition:transform .25s ease, background .25s ease}
.btn:hover .arr svg{animation:none}
.btn:hover .arr{transform:translateX(2px)}
.btn-white{box-shadow:0 12px 26px -16px rgba(0,0,0,.4)}

/* unified card finish */
.scard,.feat-grid,.pstep,.lcard,.faq-item,.form,.svc-card,.pcard-img,.cinfo .form{
  border-color:var(--line)}
.scard,.pstep,.lcard,.faq-item,.svc-card{border-radius:16px}
.scard:hover,.pstep:hover,.lcard:hover,.svc-card:hover{
  box-shadow:0 24px 48px -30px rgba(26,24,18,.4)}
.feat-grid{border-radius:18px}
.form{border-radius:18px}
.mini-stats{border-radius:18px}

/* header glass + hairline tuned to stone */
header{border-bottom-color:var(--line-soft)}
.menu a.active::after{height:2px;bottom:-9px}

/* section eyebrow tick on dark surfaces stays red */
.contact .eyebrow::before,footer .foot-cta::before{background:var(--red)}

/* gentle, motion-safe page-load reveal for the hero */
@media (prefers-reduced-motion: no-preference){
  .hero-copy > *,.hero-center > *{animation:wkRise .7s cubic-bezier(.2,.7,.2,1) both}
  .hero-copy > *:nth-child(1),.hero-center > *:nth-child(1){animation-delay:.04s}
  .hero-copy > *:nth-child(2),.hero-center > *:nth-child(2){animation-delay:.12s}
  .hero-copy > *:nth-child(3),.hero-center > *:nth-child(3){animation-delay:.20s}
  .hero-copy > *:nth-child(4),.hero-center > *:nth-child(4){animation-delay:.28s}
  .hero-media,.hero-img > .imgslot{animation:wkFade 1s ease .1s both}
}
@keyframes wkRise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes wkFade{from{opacity:0}to{opacity:1}}

/* accessible focus ring (keyboard users) */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:2px solid var(--red);outline-offset:3px;border-radius:4px}

/* keep long German compounds clean on every headline */
h1,h2,h3{overflow-wrap:break-word;hyphens:manual}

/* ---- mobile hardening: let grid tracks shrink + size long German headlines ---- */
@media(max-width:1000px){.hero-copy,.hero-center,.hero-grid,.about2,.about2-copy{min-width:0}}
.hero-copy>*,.hero .lede{max-width:100%}
@media(max-width:640px){
  .hero h1{font-size:clamp(30px,8.4vw,42px);line-height:1.05}
  .hero .lede{font-size:16.5px;max-width:100%}
  .sec-head h2{font-size:clamp(30px,8vw,42px)}
  .page-hero h1{font-size:clamp(30px,8vw,46px)}
}
@media(max-width:380px){
  .hero h1{font-size:27px}
  .page-hero h1{font-size:28px}
}

/* ---- photo page-hero: keep gutter below 1320px (was edge-flush on tablet/mobile) ---- */
.page-hero.has-img > .wrap{padding-left:44px;padding-right:44px}
@media(max-width:640px){.page-hero.has-img > .wrap{padding-left:22px;padding-right:22px}}

/* ============================================================
   HOMEPAGE (mockup structure) — dark hero stamp · feature bar
   · dark projects band · FAQ split   [original palette]
   ============================================================ */
/* hero rating stamp (top-right) */
.hero-stamp .stamp-card{background:rgba(20,19,16,.5);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:16px 22px;text-align:center;color:#fff;min-width:150px}
.hero-stamp .stamp-card .stars{color:#E8941F;letter-spacing:2px;font-size:15px}
.hero-stamp .stamp-card .sc-num{font-family:'Archivo';font-weight:900;font-size:30px;line-height:1;margin-top:8px}
.hero-stamp .stamp-card .sc-lbl{font-size:12px;color:rgba(255,255,255,.7);margin-top:4px}

/* feature tick bar (dark, directly under hero) */
.feature-bar{background:var(--char-2);border-top:1px solid rgba(255,255,255,.07)}
.feature-bar .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;padding-top:30px;padding-bottom:30px}
.fb-item{display:flex;align-items:center;gap:14px;color:#fff}
.fb-item .fb-ic{width:38px;height:38px;border-radius:50%;background:var(--red);display:grid;place-items:center;flex:none}
.fb-item .fb-ic svg{width:19px;height:19px;color:#fff}
.fb-item span{font-family:'Archivo';font-weight:700;font-size:14px;letter-spacing:.01em;line-height:1.25}
@media(max-width:840px){.feature-bar .wrap{grid-template-columns:1fr 1fr;gap:18px}}
@media(max-width:460px){.feature-bar .wrap{grid-template-columns:1fr}}

/* projects — dark band on home */
.projects.dark{background:var(--char-2)}
.projects.dark .eyebrow{color:#C7251A}
.projects.dark .eyebrow::before{background:#C7251A}
.projects.dark h2{color:#fff}
.projects.dark .pcard-title{color:#fff}
.projects.dark .chip{color:rgba(255,255,255,.82);border-color:rgba(255,255,255,.24)}
.projects.dark .chip.on,.projects.dark .chip:hover{background:var(--red);border-color:var(--red);color:#fff}

/* FAQ split (home) */
.faq-split{display:grid;grid-template-columns:.82fr 1.18fr;gap:56px;align-items:start}
.faq-split .faq{max-width:none}
.faq-intro .eyebrow{display:inline-flex}
.faq-intro h2{margin-top:16px}
.faq-intro p{color:var(--ink-soft);margin:18px 0 26px;max-width:42ch}
@media(max-width:900px){.faq-split{grid-template-columns:1fr;gap:30px}}

/* home dark hero: stack content at the bottom (mockup) */
.hero-img .hero-inner > .wrap{justify-content:flex-end}

/* home dark hero — mobile sizing (no page used this hero before, so size it down) */
@media(max-width:640px){
  .hero-img h1{font-size:clamp(30px,9vw,46px);max-width:100%}
  .hero-img .hero-inner,.hero-img .hero-inner > .wrap{min-width:0;max-width:100%}
  .hero-img .lede{font-size:16px;max-width:100%}
}


/* ============================================================
   Startseite tweaks: restrained Archivo hero · project GRID gallery
   ============================================================ */
/* hero headline — Archivo, smaller + less heavy than before */
.hero-img h1{font-family:'Archivo';font-size:clamp(32px,3.9vw,58px);font-weight:700;letter-spacing:-.018em;line-height:1.04}
@media(max-width:1000px){.hero-img h1{font-size:clamp(30px,5vw,48px)}}
@media(max-width:640px){.hero-img h1{font-size:clamp(26px,7.2vw,38px)}}

/* project view: photo GRID (2 cols desktop, 1 col mobile) — not a slider */
.plb-gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:26px 44px 8px}
.plb-gallery .imgslot{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:var(--paper-3)}
.plb-gallery .imgslot img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:640px){
  .plb-gallery{grid-template-columns:1fr;gap:14px;padding:22px 22px 6px}
  .plb-gallery .imgslot{aspect-ratio:3/2}
}
/* center the single action button now that prev/next are gone */
.proj-lb-nav{justify-content:center}

/* fix: cookie banner must not overflow narrow viewports (caused mobile zoom-out) */
@media(max-width:640px){
  .ck-text{flex:1 1 auto;min-width:0}
  .ck-inner{max-width:100%}
  .ck-banner,.ck-inner,.ck-text,.ck-btns{max-width:100vw}
}

/* fix: footer bottom links + banner links must wrap on narrow screens (no overflow) */
.foot-bottom{flex-wrap:wrap;gap:10px 20px}
.foot-bottom .links{flex-wrap:wrap;gap:10px 20px}
@media(max-width:640px){
  .foot-bottom{justify-content:flex-start}
  .ck-text p,.ck-inner{overflow-wrap:break-word}
}
footer,.ck-banner{overflow-x:clip}

/* === Startseite rework v2: light feature bar · restrained split hero · project cover === */
/* feature bar -> light (footer stays dark, but this redesigned strip reverts to palette) */
.feature-bar{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.fb-item{color:var(--ink)}
.fb-item span{color:var(--ink)}

/* split hero headline: restrained Archivo size */
.hero h1{font-family:'Archivo';font-size:clamp(34px,4vw,60px);letter-spacing:-.028em}
@media(max-width:640px){.hero h1{font-size:clamp(28px,7.4vw,40px)}}

/* project view: large full-width COVER on top, rest of photos as GRID below */
.plb-cover{display:block;width:calc(100% - 88px);margin:24px 44px 0;height:min(54vh,470px);border-radius:14px;overflow:hidden;background:var(--paper-3);border:none}
.plb-cover img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:640px){.plb-cover{width:calc(100% - 44px);margin:16px 22px 0;height:auto;aspect-ratio:3/2}}

/* === Feature bar = floating card that overlaps the hero (variant C) === */
.feature-bar{background:transparent;border-top:none;border-bottom:none;position:relative;z-index:6;padding-bottom:8px}
.feature-bar .wrap{display:block;padding-top:0;padding-bottom:0}
.fb-card{background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:0 34px 64px -36px rgba(26,25,21,.5);
  display:grid;grid-template-columns:repeat(4,1fr);
  margin-top:-62px;position:relative;z-index:6;overflow:hidden}
.fb-item{display:flex;align-items:center;gap:14px;padding:26px 26px;border-left:1px solid var(--line);color:var(--ink)}
.fb-item:first-child{border-left:none}
.fb-item span{color:var(--ink)}
.fb-item .fb-ic{width:38px;height:38px;border-radius:50%;background:var(--red);display:grid;place-items:center;flex:none}
.fb-item .fb-ic svg{width:19px;height:19px;color:#fff}
@media(max-width:840px){
  .fb-card{grid-template-columns:1fr 1fr;margin-top:-44px}
  .fb-item:nth-child(2){border-left:none}
  .fb-item:nth-child(3),.fb-item:nth-child(4){border-top:1px solid var(--line)}
}
@media(max-width:480px){
  .fb-card{grid-template-columns:1fr;margin-top:-26px}
  .fb-item{border-left:none}
  .fb-item+.fb-item{border-top:1px solid var(--line)}
}

/* === Hero variant B: kicker (eyebrow) + compact headline === */
.hero-copy .eyebrow{margin-bottom:18px}
.hero h1{font-size:clamp(30px,3.3vw,46px);letter-spacing:-.022em;line-height:1.04;text-wrap:balance}
@media(max-width:640px){.hero h1{font-size:clamp(28px,7.2vw,38px)}}

/* === Leistungen: each sub-service card now carries a photo === */
.svc-card{display:block;padding:0;gap:0;overflow:hidden}
.svc-img{position:relative;height:150px}
.svc-img .imgslot{position:absolute;inset:0;width:100%;height:100%;border:none;border-radius:0}
.svc-img .imgslot img{width:100%;height:100%;object-fit:cover;display:block}
.svc-card .svc-no{position:absolute;top:12px;left:12px;background:#fff;color:var(--red);font-family:'Archivo';font-weight:800;font-size:11px;letter-spacing:.12em;padding:5px 10px;border-radius:7px;box-shadow:0 4px 12px -5px rgba(0,0,0,.35);z-index:2}
.svc-card .svc-name{display:block;padding:15px 16px 18px}
@media(max-width:760px){.svc-img{height:170px}}

/* fix: long single-word detail headings (RENOVIERUNGSARBEITEN) overflowed on mobile */
@media(max-width:640px){.introw h2{font-size:clamp(22px,6.2vw,30px);overflow-wrap:break-word}}

/* === FAQ accordion (click to expand) === */
.faq-item{padding:0;overflow:hidden}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;background:none;border:none;cursor:pointer;text-align:left;padding:20px 24px;font-family:'Archivo';font-weight:700;font-size:17px;text-transform:uppercase;letter-spacing:-.005em;color:var(--ink);transition:color .2s}
.faq-q:hover{color:var(--red)}
.faq-ic{position:relative;width:28px;height:28px;border-radius:50%;background:var(--red);flex:none;transition:background .2s}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;left:50%;top:50%;background:#fff;border-radius:2px;transform:translate(-50%,-50%)}
.faq-ic::before{width:12px;height:2px}
.faq-ic::after{width:2px;height:12px;transition:transform .25s ease}
.faq-item.open .faq-ic{background:var(--ink)}
.faq-item.open .faq-ic::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p{margin:0;padding:0 24px 20px;color:var(--ink-soft);font-size:15.5px;line-height:1.55}
.faq-item.open .faq-a{max-height:340px}
@media(max-width:640px){.faq-q{font-size:15.5px;padding:18px 18px}.faq-a p{padding:0 18px 18px}.faq-item.open .faq-a{max-height:460px}}

/* === Hero: USP checklist (4 points) === */
.hero-usps{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:11px 26px;margin:22px 0 2px;padding:0}
.hero-usps li{display:flex;align-items:center;gap:11px;font-family:'Manrope';font-weight:600;font-size:15px;color:var(--ink);line-height:1.2}
.hero-usps .u-ic{width:23px;height:23px;border-radius:50%;background:var(--red);display:grid;place-items:center;flex:none}
.hero-usps .u-ic svg{width:13px;height:13px}
@media(max-width:560px){.hero-usps{grid-template-columns:1fr;gap:12px}}

/* hero: clearer separation between USP checklist and the buttons */
.hero-copy .hero-usps{margin:22px 0 30px}
.hero-copy .hero-cta{margin-top:0}

/* placeholder fix: keep missing image hidden inside leistung photo cards (specificity override) */
.svc-img .imgslot img.missing{display:none}

/* ============================================================
   Hero-Typografie & Buttons — Feinschliff Mobil/Tablet
   (steht bewusst am Dateiende, damit es frühere .hero h1-Regeln
    in der Kaskade überschreibt — Überschrift dominiert die Buttons)
   ============================================================ */
@media (max-width:1000px){
  .hero h1{font-size:clamp(42px,6.6vw,62px);line-height:1.05;letter-spacing:-.03em}
  .hero .lede{font-size:18px}
}
@media (max-width:640px){
  .hero h1{font-size:clamp(34px,9vw,48px);line-height:1.07}
  .hero .lede{font-size:17px;margin:18px 0 26px}
  /* Buttons kompakter und volle Breite für bequeme Tap-Ziele */
  .hero-cta{gap:12px}
  .hero-cta .btn{width:100%;justify-content:center;gap:12px;font-size:13px;padding:16px 22px}
  .hero-cta .btn .arr{width:34px;height:34px}
  .hero-usps li{font-size:16px}
}
@media (max-width:380px){
  .hero h1{font-size:32px}
  .hero-cta .btn{font-size:12px;padding:15px 18px}
}

/* ===== WhatsApp-Anfrage-Pop-up ===== */
.wa-pop{position:fixed;inset:0;z-index:1200;display:none}
.wa-pop.show{display:block}
.wa-pop-ov{position:absolute;inset:0;background:rgba(26,25,21,.55);backdrop-filter:blur(2px)}
.wa-pop-box{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);width:min(94vw,380px);
  background:#fff;border-radius:16px;padding:24px 22px 22px;box-shadow:0 24px 60px -12px rgba(0,0,0,.4);max-height:88vh;overflow:auto}
.wa-pop-box h3{font-family:'Archivo';font-weight:800;font-size:20px;text-transform:none;letter-spacing:-.01em;margin-bottom:4px;color:var(--ink)}
.wa-pop-box>p{font-family:'Manrope';font-size:13.5px;color:var(--ink-soft);line-height:1.45;margin-bottom:16px}
.wa-pop-x{position:absolute;top:12px;right:14px;width:32px;height:32px;border:none;background:#f0eee8;border-radius:50%;font-size:22px;line-height:1;color:var(--ink);cursor:pointer}
.wa-pop-x:hover{background:var(--red);color:#fff}
.wa-pop-form{display:flex;flex-direction:column;gap:10px}
.wa-pop-form input,.wa-pop-form select,.wa-pop-form textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:12px 14px;font-family:'Manrope';font-size:14px;background:var(--paper);color:var(--ink)}
.wa-pop-form textarea{resize:vertical;min-height:80px}
.wa-pop-form select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23C7251A' stroke-width='2.6'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
.wa-pop-form input:focus,.wa-pop-form select:focus,.wa-pop-form textarea:focus{outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 3px rgba(199,37,26,.08)}
.wa-pop-check{display:flex;gap:9px;align-items:flex-start;font-family:'Manrope';font-size:12px;font-weight:400;color:var(--ink-soft);line-height:1.45}
.wa-pop-check input{width:auto;margin-top:2px;flex:none}
.wa-pop-check a{color:var(--red);text-decoration:underline}
.wa-pop-send{justify-content:center;gap:10px;margin-top:4px;padding:14px 18px}
.wa-pop-send svg{width:18px;height:18px}
@media(max-width:640px){.wa-pop-box{bottom:14px;padding:22px 18px 18px}}
