:root{--cream:#ede7d8}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
section[id]{scroll-margin-top:90px}
body{font-family:'Inter',sans-serif;background:#000;color:#fff;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
a:hover{color:inherit}
img{display:block;max-width:100%}
em{font-family:'Fraunces',serif;font-style:italic;font-weight:400}
.serif{font-family:'Fraunces',serif;font-style:italic;font-weight:400}
.cream{background:var(--cream);color:#111;border:none;border-radius:9999px;padding:14px 22px;font-size:14px;font-weight:500;display:inline-flex;gap:8px;align-items:center;cursor:pointer;text-decoration:none}
.glass{background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:9999px;padding:13px 20px;font-size:14px;display:inline-flex;gap:8px;align-items:center;cursor:pointer;text-decoration:none}
.wrap{width:min(1240px,92vw);margin:0 auto}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:22px 34px;transition:background .3s,backdrop-filter .3s}
nav .logo{display:flex;align-items:center;gap:8px;font-size:21px;font-weight:500;letter-spacing:-.01em;cursor:pointer;text-decoration:none;color:#fff}
nav .logo .bc{display:flex;gap:2px;align-items:center}
nav .logo .bc i{width:2px;background:#fff}
nav .logo .bc i:nth-child(1){height:15px}nav .logo .bc i:nth-child(2){height:10px}nav .logo .bc i:nth-child(3){height:17px}nav .logo .bc i:nth-child(4){height:8px}
nav .mid{display:flex;gap:30px;font-size:14px}
nav .mid a{color:rgba(255,255,255,.75);text-decoration:none;transition:color .25s}
nav .mid a:hover{color:#fff}
nav.scrolled{background:rgba(0,0,0,.55);backdrop-filter:blur(14px)}

.logo .logoimg{height:30px;width:auto;display:block}

/* hero */
.hero{height:100vh;position:relative;overflow:hidden}
.hero .bg{position:absolute;inset:0;background:url('../img/hero-wohnwand.webp') center/cover;transform:scale(1.05);animation:kb 18s ease-in-out infinite alternate}
@keyframes kb{to{transform:scale(1.15)}}
.hero .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.15) 40%,rgba(0,0,0,.8))}
.hero h1{position:absolute;left:34px;bottom:80px;z-index:2;font-size:clamp(50px,8.5vw,120px);line-height:.95;letter-spacing:-.04em;font-weight:500}
.hero .para{position:absolute;right:34px;bottom:96px;z-index:2;max-width:340px;color:rgba(255,255,255,.82);font-size:15px;line-height:1.55}
.hero .film{position:absolute;right:34px;bottom:40px;z-index:2}

/* mission + cards */
.mission{padding:160px 0 90px;text-align:center}
.mission h2{font-size:clamp(32px,4.6vw,64px);line-height:1.08;letter-spacing:-.03em;font-weight:500;max-width:20ch;margin:0 auto}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:50px 0 130px}
.card{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/6;display:flex;align-items:flex-end;color:inherit;text-decoration:none}
a.card{color:#fff}
.card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.card:hover img{transform:scale(1.06)}
.card::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(0,0,0,.85))}
.card .tag{position:absolute;top:16px;left:16px;z-index:4;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.28);border-radius:9999px;padding:6px 12px;font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:#fff}
.card .body{position:relative;z-index:2;padding:24px}
.card .body h3{font-size:clamp(20px,1.6vw,25px);font-weight:500;letter-spacing:-.02em;line-height:1.1}
.card .body p{color:rgba(255,255,255,.82);font-size:13px;line-height:1.5;margin:10px 0 16px}
.card .body .lnk{font-size:13px;color:var(--cream);font-weight:500}

/* PINNED manifesto */
.pin{height:460vh;position:relative}
.pin .sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.pin .bgs{position:absolute;inset:0}
.pin .bgs .b{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;background-size:cover;background-position:center}
.pin .bgs .b.on{opacity:1}
.pin .bgs::after{content:'';position:absolute;inset:0;z-index:2;background:rgba(0,0,0,.62)}
.pin .fg{position:relative;z-index:3;padding:0 24px}
.pin .eyebrow{font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:34px}
.pin .beats{position:relative;min-height:clamp(220px,34vh,360px);display:flex;align-items:center;justify-content:center}
.pin .beat{position:absolute;left:50%;top:50%;transform:translate(-50%,calc(-50% + 16px));width:min(20ch,90vw);font-size:clamp(32px,4.6vw,66px);line-height:1.08;letter-spacing:-.03em;font-weight:500;opacity:0;transition:opacity .6s ease,transform .6s ease}
.pin .beat.on{opacity:1;transform:translate(-50%,-50%)}
.pin .cta{margin-top:48px}

/* bento project proof */
.proof{padding:120px 0}
.proof h2{font-size:clamp(30px,4.4vw,60px);letter-spacing:-.03em;font-weight:500;max-width:16ch}
.proof .sub{color:rgba(255,255,255,.7);font-size:17px;margin:18px 0 26px;max-width:52ch}
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px;margin-top:30px}
.tile{border-radius:14px;overflow:hidden;position:relative;background:#161616}
.tile.v{grid-row:span 2}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.tile:hover img{transform:scale(1.05)}
.tile .nm{position:absolute;left:16px;bottom:14px;z-index:2;font-size:13px}
.tile .nm small{display:block;color:rgba(255,255,255,.65)}
.tile::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7))}
.qtile{background:#141414;border:1px solid #222;padding:24px;display:flex;flex-direction:column;justify-content:space-between}
.qtile .tg{font-size:10px;letter-spacing:.12em;color:rgba(255,255,255,.5)}
.qtile p{font-size:17px;line-height:1.4;margin-top:10px}
.qtile .who{font-size:11px;letter-spacing:.12em;color:rgba(255,255,255,.5);margin-top:14px}

/* stats */
.stats{padding:110px 0;text-align:center}
.stats h2{font-size:clamp(30px,4.4vw,60px);letter-spacing:-.03em;font-weight:500;max-width:16ch;margin:0 auto}
.stats .sub{color:rgba(255,255,255,.7);font-size:17px;margin:18px auto 0;max-width:60ch}
.statrow{display:grid;grid-template-columns:repeat(4,1fr);margin-top:70px}
.statrow .s{border-left:1px solid #262626;padding:0 20px}
.statrow .s:first-child{border-left:none}
.statrow .s b{font-size:clamp(40px,5vw,68px);font-weight:500;letter-spacing:-.03em;display:block}
.statrow .s span{color:rgba(255,255,255,.6);font-size:14px;margin-top:8px;display:block}

/* marquee */
.marq{padding:70px 0;overflow:hidden;border-top:1px solid #1a1a1a;border-bottom:1px solid #1a1a1a}
.marq .track{display:flex;gap:64px;width:max-content;animation:scroll 36s linear infinite;color:rgba(255,255,255,.55);font-size:20px;letter-spacing:.08em;font-weight:500;white-space:nowrap}
@keyframes scroll{to{transform:translateX(-50%)}}

/* closing */
.closing{padding:150px 0 170px;text-align:center}
.closing h2{font-size:clamp(34px,5vw,76px);letter-spacing:-.035em;font-weight:500;max-width:16ch;margin:0 auto}
.closing .sub{color:rgba(255,255,255,.7);font-size:17px;margin:22px auto 30px;max-width:58ch}

/* footer */
footer{border-top:1px solid #1a1a1a;padding:90px 0 50px}
footer .mega{font-size:clamp(56px,13vw,150px);line-height:.9;letter-spacing:-.04em;font-weight:500}
footer .cols{display:grid;grid-template-columns:1fr 1fr 2fr;gap:30px;margin-top:80px}
footer .col h4{font-size:11px;letter-spacing:.14em;color:rgba(255,255,255,.5);text-transform:uppercase;margin-bottom:16px}
footer .col a{display:block;color:rgba(255,255,255,.8);font-size:15px;margin-bottom:10px;text-decoration:none;cursor:pointer}
footer .offices{display:flex;gap:18px}
footer .office{flex:1;border:1px solid #222;border-radius:12px;padding:18px}
footer .office b{display:block;font-size:15px}
footer .office span{color:rgba(255,255,255,.55);font-size:13px}
footer .legal{display:flex;justify-content:space-between;margin-top:60px;color:rgba(255,255,255,.45);font-size:13px;flex-wrap:wrap;gap:16px}

@media(max-width:840px){
  nav .mid{display:none}
  .cards,.statrow{grid-template-columns:1fr 1fr}
  .bento{grid-template-columns:1fr 1fr}
  footer .cols{grid-template-columns:1fr}
  .hero .para,.hero .film{display:none}
}

/* ---------- shared page chrome ---------- */
.subhead{padding:150px 0 60px;border-bottom:1px solid #1a1a1a}
.subhead .eyebrow{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:22px}
.subhead h1{font-size:clamp(38px,6vw,84px);line-height:1.0;letter-spacing:-.03em;font-weight:500;max-width:18ch}
.subhead p{color:rgba(255,255,255,.7);font-size:18px;line-height:1.55;margin-top:24px;max-width:54ch}
.section{padding:90px 0}
.lead{color:rgba(255,255,255,.78);font-size:19px;line-height:1.6;max-width:60ch}
nav .cream{cursor:pointer}
.crumb{display:inline-flex;gap:8px;align-items:center;color:rgba(255,255,255,.5);font-size:13px;margin-bottom:30px}
.crumb a{color:rgba(255,255,255,.5);text-decoration:none}.crumb a:hover{color:#fff}

/* ---------- leistung blocks ---------- */
.lblock{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:70px 0;border-bottom:1px solid #161616}
.lblock:nth-child(even) .lmedia{order:2}
.lblock .lmedia{border-radius:16px;overflow:hidden;aspect-ratio:4/3}
.lblock .lmedia img{width:100%;height:100%;object-fit:cover}
.lblock h2{font-size:clamp(26px,3vw,40px);font-weight:500;letter-spacing:-.02em}
.lblock .num{font-family:'Fraunces',serif;font-style:italic;color:var(--cream);font-size:22px;margin-bottom:14px}
.lblock p{color:rgba(255,255,255,.72);font-size:16px;line-height:1.6;margin-top:16px}
.lblock ul{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:10px}
.lblock li{color:rgba(255,255,255,.8);font-size:15px;padding-left:18px;position:relative}
.lblock li::before{content:'—';position:absolute;left:0;color:var(--cream)}

/* ---------- product grid + konfigurator ---------- */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.pcard{border:1px solid #1c1c1c;border-radius:16px;overflow:hidden;background:#0c0c0c;display:flex;flex-direction:column}
.pcard .pimg{aspect-ratio:4/5;overflow:hidden;background:#141414}
.pcard .pimg img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.pcard:hover .pimg img{transform:scale(1.05)}
.pcard .pbody{padding:22px;display:flex;flex-direction:column;gap:8px;flex:1}
.pcard .brand{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.pcard h3{font-size:22px;font-weight:500;letter-spacing:-.02em}
.pcard .desc{color:rgba(255,255,255,.65);font-size:14px;line-height:1.5}
.pcard .swatches{display:flex;gap:8px;margin-top:6px}
.swatch{width:22px;height:22px;border-radius:50%;border:2px solid #2a2a2a;cursor:pointer;outline:2px solid transparent;outline-offset:2px;transition:outline-color .2s}
.swatch[aria-pressed="true"]{outline-color:var(--cream)}
.pcard .price{color:rgba(255,255,255,.85);font-size:14px;margin-top:6px}
.pcard .price b{font-weight:500}
.pcard .pcta{margin-top:auto;padding-top:16px}
.pcard .pcta .cream{width:100%;justify-content:center}
.pmeta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.chip{font-size:11px;color:rgba(255,255,255,.6);border:1px solid #262626;border-radius:9999px;padding:4px 10px}

/* ---------- form ---------- */
.formwrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:50px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.field label{font-size:13px;letter-spacing:.04em;color:rgba(255,255,255,.7)}
.field input,.field textarea,.field select{background:#0c0c0c;border:1px solid #262626;border-radius:10px;padding:14px 16px;color:#fff;font:inherit;font-size:15px;transition:border-color .2s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--cream)}
.field textarea{min-height:140px;resize:vertical}
.field.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-aside{color:rgba(255,255,255,.7)}
.form-aside h3{font-size:22px;font-weight:500;margin-bottom:14px}
.form-aside p{font-size:15px;line-height:1.6;margin-bottom:18px}
.form-aside .row{border-top:1px solid #1a1a1a;padding:14px 0;font-size:14px}
.form-note{font-size:12px;color:rgba(255,255,255,.45);margin-top:6px;line-height:1.5}
.form-status{margin-top:18px;font-size:14px;min-height:20px}
.form-status.ok{color:#9fdcb4}.form-status.err{color:#e7a3a3}
button[disabled]{opacity:.5;cursor:default}
.cf-turnstile{margin:8px 0 18px}

/* ---------- legal pages ---------- */
.legal{max-width:760px}
.legal h2{font-size:24px;font-weight:500;margin:38px 0 14px;letter-spacing:-.01em}
.legal h3{font-size:17px;font-weight:500;margin:24px 0 8px}
.legal p,.legal li{color:rgba(255,255,255,.72);font-size:15px;line-height:1.7}
.legal ul{margin:10px 0 10px 20px}
.legal a{color:var(--cream)}
.legal .ph{color:#e7c06a}  /* markierte Platzhalter [..] sichtbar */

@media(max-width:840px){
  .lblock{grid-template-columns:1fr;gap:24px}
  .lblock:nth-child(even) .lmedia{order:0}
  .pgrid{grid-template-columns:1fr 1fr}
  .formwrap{grid-template-columns:1fr;gap:30px}
}
@media(max-width:560px){ .pgrid{grid-template-columns:1fr} }
