*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --black:#fafaf8;--white:#1a1a1a;--brown:#8B6F47;--brown-light:#8B6F47;
  --brown-dark:#5C462E;--cream:#ffffff;--gray:#666;--gray-dark:#333;
  --bg-dark:#f0ebe4;--bg-main:#fafaf8;--text:#1a1a1a;--text-muted:rgba(26,26,26,.55);
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Inter',sans-serif;background:var(--bg-main);color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:var(--brown);color:#fff}
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:400;color:var(--text)}
a{text-decoration:none;color:inherit}
img{max-width:100%}

/* Cursor */
.cursor{position:fixed;width:20px;height:20px;border:1.5px solid var(--brown);border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s,opacity .15s}
.cursor-dot{position:fixed;width:4px;height:4px;background:var(--brown);border-radius:50%;pointer-events:none;z-index:9999}
@media(max-width:1024px){.cursor,.cursor-dot{display:none}}

/* Loader */
.loader{position:fixed;inset:0;background:var(--bg-main);z-index:10000;display:flex;align-items:center;justify-content:center;flex-direction:column}
.loader-icon{width:80px;height:80px;opacity:0}
.loader-text{font-size:11px;letter-spacing:6px;text-transform:uppercase;margin-top:20px;opacity:.4;font-weight:300;color:var(--text)}
.loader-bar{width:200px;height:1px;background:rgba(0,0,0,.08);margin-top:30px;overflow:hidden}
.loader-bar-fill{width:0%;height:100%;background:var(--brown)}

/* Nav */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:30px 60px;display:flex;align-items:center;justify-content:space-between;transition:all .5s cubic-bezier(.25,.46,.45,.94)}
nav.scrolled{background:rgba(250,250,248,.95);backdrop-filter:blur(30px);padding:20px 60px;box-shadow:0 1px 0 rgba(0,0,0,.06)}
.nav-logo img{height:32px;transition:all .5s cubic-bezier(.25,.46,.45,.94)}
.nav-logo .nav-icon-large{height:70px}
nav.scrolled .nav-logo .nav-icon-large{height:45px}
.nav-links{display:flex;gap:40px;align-items:center}
.nav-links a{font-size:12px;letter-spacing:3px;text-transform:uppercase;font-weight:400;opacity:.5;transition:all .3s;position:relative;color:var(--text)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--brown);transition:width .4s cubic-bezier(.25,.46,.45,.94)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}
.nav-links a.active{opacity:1;color:var(--brown)}
.nav-cta{font-size:11px;letter-spacing:3px;text-transform:uppercase;padding:12px 28px;border:1px solid rgba(139,111,71,.3);transition:all .4s;background:transparent;color:var(--text);cursor:pointer;display:inline-block}
.nav-cta:hover{background:var(--brown);border-color:var(--brown);color:#fff}

/* Hero */
.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-dark)}
#hero-canvas{position:absolute;inset:0;z-index:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(250,250,248,.15) 0%,rgba(250,250,248,.7) 100%);z-index:2}
.hero-content{position:relative;z-index:3;text-align:center;max-width:900px;padding:0 40px}
.hero-tagline{font-size:13px;letter-spacing:8px;text-transform:uppercase;color:var(--brown);margin-bottom:30px;opacity:0}
.hero-title{font-size:clamp(42px,7vw,90px);line-height:1.05;margin-bottom:30px;opacity:0;color:var(--text)}
.hero-title em{font-style:italic;color:var(--brown)}
.hero-sub{font-size:16px;line-height:1.8;font-weight:300;opacity:0;max-width:600px;margin:0 auto 50px;color:var(--text-muted)}
.hero-btn{display:inline-block;font-size:11px;letter-spacing:4px;text-transform:uppercase;padding:18px 50px;border:1px solid var(--brown);color:var(--text);transition:all .5s;opacity:0;position:relative;overflow:hidden}
.hero-btn span{position:relative;z-index:1}
.hero-btn::before{content:'';position:absolute;inset:0;background:var(--brown);transform:scaleX(0);transform-origin:right;transition:transform .5s cubic-bezier(.25,.46,.45,.94);z-index:0}
.hero-btn:hover::before{transform:scaleX(1);transform-origin:left}
.hero-btn:hover{color:#fff}

/* Sections */
section{padding:160px 60px;position:relative}
.section-label{font-size:11px;letter-spacing:6px;text-transform:uppercase;color:var(--brown);margin-bottom:20px;display:block}
.section-title{font-size:clamp(36px,5vw,64px);line-height:1.15;margin-bottom:40px;color:var(--text)}
.section-title em{font-style:italic;color:var(--brown)}
.divider{width:60px;height:1px;background:var(--brown);margin:60px 0}
.text-link{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--brown);margin-top:30px;transition:gap .3s}
.text-link:hover{gap:18px}

/* About */
.about{background:var(--bg-main)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;max-width:1400px;margin:0 auto}
.about-text p{font-size:17px;line-height:2;font-weight:300;color:var(--text-muted);margin-bottom:25px}
.about-img{position:relative;overflow:hidden}
.about-img img{width:100%;height:600px;object-fit:cover;transition:transform 1.5s cubic-bezier(.25,.46,.45,.94)}
.about-img:hover img{transform:scale(1.05)}
.about-img::after{content:'';position:absolute;inset:0;border:1px solid rgba(139,111,71,.15);margin:20px;pointer-events:none;transition:margin .6s}
.about-img:hover::after{margin:30px}

/* Stats */
.stats{background:var(--bg-dark);color:var(--text);padding:120px 60px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:60px;max-width:1200px;margin:0 auto;text-align:center}
.stat-item{opacity:0;transform:translateY(40px)}
.stat-number{font-family:'Playfair Display',serif;font-size:clamp(48px,5vw,72px);font-weight:400;color:var(--brown-dark);line-height:1}
.stat-suffix{font-size:clamp(24px,2.5vw,36px)}
.stat-label{font-size:13px;letter-spacing:3px;text-transform:uppercase;margin-top:15px;color:var(--gray);font-weight:400}

/* Services */
.services{background:var(--bg-main)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1400px;margin:0 auto}
.service-card{padding:60px 40px;border:1px solid rgba(139,111,71,.1);transition:all .6s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;opacity:0;transform:translateY(60px);background:#fff}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--brown),transparent);transform:scaleX(0);transition:transform .6s}
.service-card:hover{border-color:rgba(139,111,71,.3);transform:translateY(-8px)!important;box-shadow:0 20px 60px rgba(0,0,0,.06)}
.service-card:hover::before{transform:scaleX(1)}
.service-num{font-family:'Playfair Display',serif;font-size:72px;color:rgba(139,111,71,.06);position:absolute;top:15px;right:25px;line-height:1}
.service-title{font-size:26px;margin-bottom:20px;position:relative;color:var(--text)}
.service-desc{font-size:15px;line-height:1.9;font-weight:300;color:var(--text-muted)}
.service-link{display:inline-flex;align-items:center;gap:10px;margin-top:30px;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--brown);transition:gap .3s}
.service-link:hover{gap:18px}
.service-link svg{width:20px;height:20px;stroke:var(--brown);fill:none;stroke-width:1.5}

/* Projects */
.projects{background:var(--bg-dark);color:var(--text)}
.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:1400px;margin:0 auto}
.project-card{position:relative;overflow:hidden;height:500px;cursor:pointer;opacity:0;transform:translateY(60px)}
.project-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.25,.46,.45,.94),filter .6s}
.project-card:hover img{transform:scale(1.08);filter:brightness(.6)}
.project-info{position:absolute;bottom:0;left:0;right:0;padding:40px;background:linear-gradient(transparent,rgba(10,10,10,.9));transform:translateY(20px);opacity:0;transition:all .5s}
.project-card:hover .project-info{transform:translateY(0);opacity:1}
.project-info h3{font-size:24px;color:#fff;margin-bottom:8px}
.project-info span{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--brown-light)}
.project-card.full{grid-column:1/-1;height:600px}

/* Geschäftsführung */
.gf-section{background:var(--bg-main);padding:160px 60px}
.gf-grid{display:grid;grid-template-columns:auto 1fr;gap:100px;align-items:center;max-width:1200px;margin:0 auto}
.gf-image{position:relative}
.gf-image img{width:380px;height:auto;object-fit:contain;border-radius:4px}
.gf-image::after{content:'';position:absolute;bottom:-15px;right:-15px;width:100%;height:100%;border:1px solid rgba(139,111,71,.15);z-index:-1}
.gf-content{max-width:550px}
.gf-content p{color:var(--text-muted)!important}

/* Philosophy */
.philosophy{background:var(--bg-dark);text-align:center;padding:180px 60px}
.philosophy-text{max-width:800px;margin:0 auto;font-size:clamp(24px,3vw,42px);font-family:'Playfair Display',serif;line-height:1.6;color:var(--text)}
.philosophy-text em{color:var(--brown);font-style:italic}
.philosophy-author{margin-top:40px;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--gray)}

/* Office */
.office{background:var(--bg-dark);color:var(--text)}
.office-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;max-width:1400px;margin:0 auto}
.office-img{overflow:hidden;height:500px;opacity:0;transform:translateY(40px)}
.office-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s}
.office-img:hover img{transform:scale(1.05)}

/* CTA Section */
.cta-section{background:var(--bg-main);padding:160px 60px}
.cta-section .section-title{color:var(--text)}
.cta-section p{color:var(--text-muted)!important}
.cta-section .hero-btn{color:var(--text);opacity:1}
.cta-section .hero-btn:hover{color:#fff}

/* Footer — dark footer for contrast */
footer{background:#1a1a1a;border-top:1px solid rgba(255,255,255,.06);padding:80px 60px 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;max-width:1400px;margin:0 auto;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-logo{height:80px;margin-bottom:25px;opacity:.8}
.footer-text{font-size:14px;line-height:1.8;color:rgba(255,255,255,.5);font-weight:300}
footer h4{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--brown);margin-bottom:20px}
footer a{display:block;font-size:14px;color:rgba(255,255,255,.5);font-weight:300;margin-bottom:10px;transition:color .3s}
footer a:hover{color:var(--brown)}
footer p{font-size:14px;color:rgba(255,255,255,.5);font-weight:300;line-height:1.8}
.footer-bottom{display:flex;justify-content:space-between;max-width:1400px;margin:30px auto 0;font-size:12px;color:rgba(255,255,255,.3);font-weight:300}
.footer-bottom a{display:inline;margin:0;font-size:12px;color:rgba(255,255,255,.3)}

/* Page Header */
.page-header{padding:200px 60px 100px;background:var(--bg-main);text-align:center}
.page-header .section-label{margin-bottom:20px}
.page-header .section-title{margin-bottom:20px;color:var(--text)}
.page-header p{font-size:17px;font-weight:300;color:var(--text-muted);max-width:600px;margin:0 auto}

/* Content */
.content-section{padding:120px 60px;max-width:1200px;margin:0 auto}
.content-section h3{font-size:32px;margin-bottom:25px;color:var(--text)}
.content-section p{font-size:17px;line-height:2;font-weight:300;color:var(--text-muted);margin-bottom:20px}

/* Services detail */
.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1400px;margin:0 auto;padding:100px 0}
.service-detail:nth-child(even){direction:rtl}
.service-detail:nth-child(even) > *{direction:ltr}
.service-detail img{width:100%;height:450px;object-fit:cover}
.service-detail p{color:var(--text-muted)!important}

/* Contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;max-width:1200px;margin:0 auto}
.contact-info h3{font-size:32px;margin-bottom:30px;color:var(--text)}
.contact-info-item{margin-bottom:30px}
.contact-info-item h4{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--brown);margin-bottom:10px}
.contact-info-item p{font-size:16px;font-weight:300;color:var(--text-muted);line-height:1.8}
.contact-info-item a{color:var(--brown)}
.contact-form{display:flex;flex-direction:column;gap:25px}
.form-group{position:relative}
.form-group input,.form-group textarea{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(139,111,71,.2);padding:15px 0;font-size:15px;font-family:'Inter',sans-serif;color:var(--text);font-weight:300;outline:none;transition:border-color .3s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--brown)}
.form-group textarea{resize:none;height:120px}
.form-group label{position:absolute;top:15px;left:0;font-size:13px;color:var(--gray);font-weight:300;pointer-events:none;transition:all .3s}
.form-group input:focus~label,.form-group input:not(:placeholder-shown)~label,
.form-group textarea:focus~label,.form-group textarea:not(:placeholder-shown)~label{top:-8px;font-size:10px;color:var(--brown);letter-spacing:2px;text-transform:uppercase}

/* Reveal */
.reveal{opacity:0;transform:translateY(50px)}
.reveal-left{opacity:0;transform:translateX(-50px)}
.reveal-right{opacity:0;transform:translateX(50px)}

/* ============ RESPONSIVE ============ */
@media(max-width:1200px){
  nav{padding:25px 40px}
  section{padding:120px 40px}
  .about-grid{gap:60px}
  .gf-grid{gap:60px}
}
@media(max-width:1024px){
  section{padding:100px 30px}
  nav{padding:20px 24px}
  nav.scrolled{padding:15px 24px}
  .nav-logo .nav-icon-large{height:50px}
  nav.scrolled .nav-logo .nav-icon-large{height:38px}
  .about-grid,.office-grid,.contact-grid,.service-detail{grid-template-columns:1fr;gap:40px}
  .about-img img{height:400px}
  .services-grid{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:40px}
  .nav-links{display:none}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .service-detail:nth-child(even){direction:ltr}
  .gf-grid{grid-template-columns:1fr;gap:40px;text-align:center}
  .gf-image{display:flex;justify-content:center}
  .gf-image img{width:280px}
  .gf-image::after{display:none}
  .gf-content{max-width:100%}
  .gf-content .divider{margin:30px auto}
  .philosophy{padding:120px 30px}
  .service-detail img{height:350px}
  .office-img{height:350px}
}
@media(max-width:768px){
  section{padding:80px 20px}
  nav{padding:15px 20px}
  nav.scrolled{padding:12px 20px}
  .nav-logo .nav-icon-large{height:42px}
  nav.scrolled .nav-logo .nav-icon-large{height:34px}
  .nav-cta{padding:10px 20px;font-size:10px;letter-spacing:2px}
  .hero-content{padding:0 20px}
  .hero-title{font-size:36px}
  .hero-sub{font-size:14px;margin-bottom:35px}
  .hero-btn{padding:15px 35px;font-size:10px}
  .hero-tagline{font-size:11px;letter-spacing:5px}
  .section-title{font-size:28px;margin-bottom:25px}
  .section-label{font-size:10px;letter-spacing:5px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:30px}
  .stat-number{font-size:42px}
  .stat-label{font-size:11px}
  .project-card{height:280px}
  .project-card.full{height:320px}
  .project-info{padding:25px}
  .project-info h3{font-size:20px}
  .service-card{padding:40px 25px}
  .service-num{font-size:48px}
  .service-title{font-size:22px}
  .page-header{padding:130px 20px 60px}
  .page-header .section-title{font-size:28px}
  .philosophy-text{font-size:22px}
  .philosophy{padding:80px 20px}
  .gf-image img{width:220px}
  .gf-section{padding:80px 20px}
  .office-img{height:260px}
  .office-grid{gap:15px}
  .about-img img{height:300px}
  .about-img::after{margin:10px}
  .divider{margin:30px 0}
  .service-detail{padding:60px 0;gap:40px}
  .service-detail img{height:260px}
  .contact-grid{gap:40px}
  footer{padding:50px 20px 30px}
  .footer-grid{padding-bottom:30px;gap:25px}
  .footer-bottom{flex-direction:column;gap:8px;align-items:center}
  .cta-section{padding:80px 20px}
}
@media(max-width:480px){
  .hero-title{font-size:28px}
  .section-title{font-size:24px}
  .stats-grid{grid-template-columns:1fr;gap:25px}
  .stat-number{font-size:36px}
  .project-card{height:220px}
  .project-card.full{height:260px}
  .gf-image img{width:180px}
  .office-img{height:200px}
  .about-img img{height:240px}
  .service-detail img{height:200px}
  .philosophy-text{font-size:18px}
}
