:root{--cream:#FAF8F5;--nude:#EDE4D8;--blush:#C9A99A;--gold:#B8976A;--brown:#8B6B5E;--dark:#2C2420;--text:#3D302B;--muted:#8C7A74;--white:#fff;--line:rgba(180,160,140,0.22)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden}
img{display:block;max-width:100%}
section{padding:6rem 5vw}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
.kicker{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blush);display:flex;align-items:center;gap:.8rem;margin-bottom:.7rem}
.kicker::before{content:'';display:block;width:28px;height:1px;background:var(--blush)}
.sec-title{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,3.5vw,3.2rem);font-weight:300;color:var(--dark);line-height:1.15;margin-bottom:.8rem}
.sec-title em{font-style:italic;color:var(--blush)}
.sec-sub{font-size:.9rem;line-height:1.85;color:var(--muted);max-width:480px}
.quote{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-style:italic;color:var(--brown);line-height:1.65;border-left:2px solid var(--blush);padding-left:1.2rem;margin:1.8rem 0}
.btn-d{background:var(--dark);color:var(--cream);padding:.8rem 1.9rem;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;display:inline-block;transition:background .2s}
.btn-d:hover{background:var(--brown)}
.btn-o{background:transparent;color:var(--dark);padding:.8rem 1.9rem;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:1px solid var(--nude);display:inline-block;transition:border-color .2s,color .2s}
.btn-o:hover{border-color:var(--blush);color:var(--brown)}

nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 5vw;background:rgba(250,248,245,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;color:var(--dark);text-decoration:none;letter-spacing:.04em}
.logo em{font-style:italic;color:var(--gold)}
.navlinks{display:flex;gap:2rem;list-style:none}
.navlinks a{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s}
.navlinks a:hover{color:var(--brown)}
.navcta{background:var(--dark);color:var(--cream);padding:.5rem 1.3rem;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:background .2s}
.navcta:hover{background:var(--brown)}

#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:7rem 5vw 4rem;gap:5rem;position:relative;overflow:hidden}
#hero::before{content:'';position:absolute;right:-8%;top:-15%;width:54vw;height:115vh;background:var(--nude);border-radius:40% 0 0 50%;z-index:0}
.hero-text{position:relative;z-index:1}
.hero-kicker{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--blush);margin-bottom:1.2rem;display:flex;align-items:center;gap:.8rem}
.hero-kicker::before{content:'';display:block;width:28px;height:1px;background:var(--blush)}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,5vw,5.5rem);font-weight:300;line-height:1.08;color:var(--dark);margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:var(--blush)}
.hero-desc{font-size:.92rem;line-height:1.85;color:var(--muted);max-width:400px;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
.hero-img-col{position:relative;z-index:1}
.hero-frame{aspect-ratio:3/4;overflow:hidden;box-shadow:24px 24px 60px rgba(44,36,32,.13)}
.hero-frame img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;bottom:-1.2rem;left:-1.2rem;background:var(--white);padding:1rem 1.4rem;box-shadow:0 8px 32px rgba(44,36,32,.1)}
.hero-badge small{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:block}
.hero-badge strong{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:var(--dark);display:block}

#stats{background:var(--dark);padding:1.8rem 5vw;display:grid;grid-template-columns:repeat(4,1fr)}
.stat{text-align:center;padding:.8rem;border-right:1px solid rgba(255,255,255,.08)}
.stat:last-child{border-right:none}
.stat-n{font-family:'Cormorant Garamond',serif;font-size:2.4rem;font-weight:600;color:var(--cream);display:block}
.stat-l{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(250,248,245,.35)}

#leistungen{background:var(--cream)}
.leist-intro{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-bottom:3.5rem}
.leist-img{aspect-ratio:4/3;overflow:hidden;border-radius:2px}
.leist-img img{width:100%;height:100%;object-fit:cover}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;background:var(--nude)}
.svc-card{background:var(--white);padding:2.2rem 1.8rem;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(44,36,32,.1);z-index:1}
.svc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blush),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{font-size:1.6rem;margin-bottom:1rem}
.svc-name{font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:var(--dark);margin-bottom:.5rem}
.svc-desc{font-size:.82rem;line-height:1.8;color:var(--muted);margin-bottom:1rem}
.svc-price{font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--brown);font-weight:600}

#why{background:var(--white);display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
.why-img{aspect-ratio:3/2;overflow:hidden;border-radius:2px;box-shadow:0 12px 40px rgba(44,36,32,.1);margin-bottom:1.5rem}
.why-img img{width:100%;height:100%;object-fit:cover}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.why-item{padding:1.4rem;border:1px solid var(--nude);transition:border-color .2s}
.why-item:hover{border-color:var(--blush)}
.why-icon{font-size:1.3rem;margin-bottom:.7rem}
.why-item-title{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--dark);margin-bottom:.35rem}
.why-item-desc{font-size:.8rem;line-height:1.7;color:var(--muted)}

#referenzen{background:var(--cream)}
.ref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}@media(min-width:1200px){.ref-grid{grid-template-columns:repeat(5,1fr)}}
.ref-item{background:var(--white);overflow:hidden}

/* Compare Slider */
.compare-slider{position:relative;height:300px;overflow:hidden;cursor:ew-resize;user-select:none;-webkit-user-select:none}
.cs-after{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.cs-before-wrap{position:absolute;top:0;left:0;bottom:0;width:50%;overflow:hidden;flex-shrink:0}
.cs-before{position:absolute;top:0;left:0;height:100%;width:100%;max-width:none !important;object-fit:cover;display:block}
.cs-handle{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;z-index:10;pointer-events:none}
.cs-line{flex:1;width:2px;background:var(--white)}
.cs-btn{width:36px;height:36px;border-radius:50%;background:var(--white);box-shadow:0 2px 12px rgba(44,36,32,.25);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--dark);letter-spacing:-2px;flex-shrink:0}
.cs-label{position:absolute;bottom:.6rem;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;padding:.2rem .55rem;background:rgba(44,36,32,.55);color:var(--cream);z-index:5;pointer-events:none}
.cs-label-b{left:.6rem}
.cs-label-a{right:.6rem}
.ref-tag{position:absolute;top:.7rem;right:.7rem;background:var(--blush);color:var(--white);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .6rem;z-index:6}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.review{background:var(--white);padding:1.8rem;border-left:2px solid var(--blush)}
.review p{font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;color:var(--text);line-height:1.7;margin-bottom:1rem}
.review span{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

#about{background:var(--white);display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.about-img-wrap{position:relative}
.about-img{overflow:hidden;border-radius:2px}
.about-img img{width:100%;height:auto;display:block}
.about-acc{position:absolute;top:-1.5rem;right:-1.5rem;width:90px;height:90px;border:1.5px solid var(--nude);border-radius:50%;z-index:-1}
.about-acc2{position:absolute;bottom:-1rem;left:-1rem;width:55px;height:55px;border:1.5px solid var(--nude);z-index:-1}
.about-features{display:flex;flex-direction:column;gap:.8rem;margin-top:1.5rem}
.feat{display:flex;align-items:center;gap:.8rem;font-size:.88rem;color:var(--text)}
.feat::before{content:'✦';color:var(--blush);font-size:.6rem;flex-shrink:0}

#process{background:var(--cream)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:3rem;position:relative}
.steps::before{content:'';position:absolute;top:1.4rem;left:12%;right:12%;height:1px;background:var(--nude)}
.step{text-align:center;position:relative;z-index:1}
.step-n{width:2.8rem;height:2.8rem;border-radius:50%;background:var(--white);border:1px solid var(--nude);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--blush);font-weight:600}
.step-t{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--dark);margin-bottom:.4rem}
.step-d{font-size:.78rem;line-height:1.7;color:var(--muted)}

#kontakt{background:var(--dark);display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start}
#kontakt .kicker{color:var(--blush)}
#kontakt .sec-title{color:var(--cream)}
#kontakt .sec-sub{color:rgba(250,248,245,.5)}
.cinfo{display:flex;flex-direction:column;gap:1.8rem;margin-top:2.5rem}
.citem{display:flex;gap:1rem;align-items:flex-start}
.cicon{width:40px;height:40px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.citem h4{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(250,248,245,.4);margin-bottom:.25rem}
.citem p,.citem a{font-size:.92rem;color:var(--cream);text-decoration:none}
.citem a:hover{color:var(--blush)}
.bform{display:flex;flex-direction:column;gap:1.1rem}
.bform h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;color:var(--cream);margin-bottom:.5rem}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.fg{display:flex;flex-direction:column;gap:.35rem}
.fg label{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(250,248,245,.4)}
.fg input,.fg select,.fg textarea{background:rgba(250,248,245,.06);border:1px solid rgba(250,248,245,.12);color:var(--cream);padding:.78rem 1rem;font-family:'DM Sans',sans-serif;font-size:.88rem;outline:none;transition:border-color .2s;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blush)}
.fg select option{background:var(--dark)}
.fg textarea{resize:vertical;min-height:90px}
.fsubmit{background:var(--blush);color:var(--white);padding:.9rem;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;transition:background .2s;width:100%;margin-top:.4rem}
.fsubmit:hover{background:var(--brown)}
.fsuccess{display:none;background:rgba(250,248,245,.06);border:1px solid var(--blush);padding:1.2rem;text-align:center;margin-top:1rem}
.fsuccess p{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--cream)}

footer{background:#1a1008;color:rgba(250,248,245,.4);padding:2rem 5vw;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.flogo{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--cream);text-decoration:none}
.flogo em{font-style:italic;color:var(--gold)}
footer p{font-size:.75rem}
.flinks{display:flex;gap:1.5rem}
.flinks a{font-size:.72rem;color:rgba(250,248,245,.4);text-decoration:none;letter-spacing:.08em;text-transform:uppercase;transition:color .2s}
.flinks a:hover{color:var(--blush)}

.lang-switcher{display:flex;align-items:center;gap:.35rem;margin-left:.8rem}
.lang-switcher span{color:var(--nude);font-size:.8rem}
.lang-btn{background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:.2rem .25rem;transition:color .2s;line-height:1}
.lang-btn.active{color:var(--dark);font-weight:500}
.lang-btn:hover{color:var(--brown)}

/* Certificates */
#zertifikate{background:var(--nude)}
#zertifikate .cert-intro{text-align:center;max-width:540px;margin:0 auto 3rem}
#zertifikate .cert-intro .sec-sub{margin:0 auto}
.cert-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1.2rem}
.cert-card{cursor:pointer;overflow:hidden;border-radius:2px;background:var(--white);box-shadow:0 2px 16px rgba(44,36,32,.08);transition:transform .25s,box-shadow .25s}
.cert-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(44,36,32,.16)}
.cert-card img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;transition:transform .35s}
.cert-card:hover img{transform:scale(1.04)}
.cert-card-label{padding:.6rem .8rem;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);text-align:center;border-top:1px solid var(--nude)}
.cert-modal{display:none;position:fixed;inset:0;z-index:999;background:rgba(44,36,32,.88);align-items:center;justify-content:center;cursor:zoom-out}
.cert-modal.open{display:flex}
.cert-modal img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:2px;box-shadow:0 8px 48px rgba(0,0,0,.5)}
.cert-modal-close{position:fixed;top:1.2rem;right:1.4rem;background:none;border:none;color:var(--cream);font-size:2rem;cursor:pointer;line-height:1;opacity:.7;transition:opacity .2s}
.cert-modal-close:hover{opacity:1}

@media(max-width:900px){
  #hero,#why,#about,#kontakt,.leist-intro{grid-template-columns:1fr}
  #stats,.svc-grid,.ref-grid,.reviews,.why-grid{grid-template-columns:repeat(2,1fr)}
  .cert-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr 1fr}
  .steps::before,.about-acc,.about-acc2{display:none}
  #hero::before{display:none}
  .hero-img-col{order:-1}
  .navlinks{display:none}
  .frow{grid-template-columns:1fr}
}
