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

/* Cursor */
.cursor{position:fixed;width:20px;height:20px;border:1.5px solid var(--brown-light);border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s,opacity .15s;mix-blend-mode:difference}
.cursor-dot{position:fixed;width:4px;height:4px;background:var(--brown-light);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(--black);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}
.loader-bar{width:200px;height:1px;background:rgba(255,255,255,.08);margin-top:30px;overflow:hidden}
.loader-bar-fill{width:0%;height:100%;background:var(--brown-light)}

/* 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(10,10,10,.92);backdrop-filter:blur(30px);padding:20px 60px}
.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:.7;transition:all .3s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--brown-light);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-light)}
.nav-cta{font-size:11px;letter-spacing:3px;text-transform:uppercase;padding:12px 28px;border:1px solid rgba(197,168,128,.4);transition:all .4s;background:transparent;color:var(--white);cursor:pointer;display:inline-block}
.nav-cta:hover{background:var(--brown);border-color:var(--brown)}

/* Hero */
.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
#hero-canvas{position:absolute;inset:0;z-index:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.2) 0%,rgba(10,10,10,.75) 100%);z-index:2}
.hero-content{position:relative;z-index:3;text-align:center;max-width:900px;padding:0 40px}
/* hero logo removed */
.hero-tagline{font-size:13px;letter-spacing:8px;text-transform:uppercase;color:var(--brown-light);margin-bottom:30px;opacity:0}
.hero-title{font-size:clamp(42px,7vw,90px);line-height:1.05;margin-bottom:30px;opacity:0}
.hero-title em{font-style:italic;color:var(--brown-light)}
.hero-sub{font-size:16px;line-height:1.8;font-weight:300;opacity:0;max-width:600px;margin:0 auto 50px;color:rgba(250,250,248,.6)}
.hero-btn{display:inline-block;font-size:11px;letter-spacing:4px;text-transform:uppercase;padding:18px 50px;border:1px solid var(--brown-light);color:var(--white);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}

/* Sections */
section{padding:160px 60px;position:relative}
.section-label{font-size:11px;letter-spacing:6px;text-transform:uppercase;color:var(--brown-light);margin-bottom:20px;display:block}
.section-title{font-size:clamp(36px,5vw,64px);line-height:1.15;margin-bottom:40px}
.section-title em{font-style:italic;color:var(--brown-light)}
.divider{width:60px;height:1px;background:var(--brown-light);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-light);margin-top:30px;transition:gap .3s}
.text-link:hover{gap:18px}

/* About */
.about{background:var(--black)}
.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:rgba(250,250,248,.7);margin-bottom:25px}
.about-img{position:relative;overflow:hidden}
.about-img img{width:100%;height:600px;object-fit:cover;filter:brightness(.9);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(197,168,128,.15);margin:20px;pointer-events:none;transition:margin .6s}
.about-img:hover::after{margin:30px}

/* Stats */
.stats{background:var(--cream);color:var(--black);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(--black)}
.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(197,168,128,.08);transition:all .6s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;opacity:0;transform:translateY(60px)}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--brown-light),transparent);transform:scaleX(0);transition:transform .6s}
.service-card:hover{border-color:rgba(197,168,128,.25);transform:translateY(-8px)!important}
.service-card:hover::before{transform:scaleX(1)}
.service-num{font-family:'Playfair Display',serif;font-size:72px;color:rgba(197,168,128,.08);position:absolute;top:15px;right:25px;line-height:1}
.service-title{font-size:26px;margin-bottom:20px;position:relative}
.service-desc{font-size:15px;line-height:1.9;font-weight:300;color:rgba(250,250,248,.5)}
.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-light);transition:gap .3s}
.service-link:hover{gap:18px}
.service-link svg{width:20px;height:20px;stroke:var(--brown-light);fill:none;stroke-width:1.5}

/* Projects */
.projects{background:var(--cream);color:var(--black)}
.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:var(--white);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(--black);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}
.gf-image::after{content:'';position:absolute;bottom:-15px;right:-15px;width:100%;height:100%;border:1px solid rgba(197,168,128,.15);z-index:-1}
.gf-content{max-width:550px}
@media(max-width:1024px){
  .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 */
.philosophy{background:var(--black);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:rgba(250,250,248,.85)}
.philosophy-text em{color:var(--brown-light);font-style:italic}
.philosophy-author{margin-top:40px;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--gray)}

/* Office */
.office{background:var(--cream);color:var(--black)}
.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(--black);padding:160px 60px}

/* Marquee */
.marquee{overflow:hidden;padding:60px 0;border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.marquee-track{display:flex;gap:60px;animation:marquee 18s linear infinite;width:max-content}
.marquee-track span{font-family:'Playfair Display',serif;font-size:clamp(48px,6vw,80px);white-space:nowrap;color:rgba(250,250,248,.03);font-weight:400}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Footer */
footer{background:var(--black);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,.06)}
.footer-logo{height:80px;margin-bottom:25px;opacity:.8}
.footer-text{font-size:14px;line-height:1.8;color:var(--gray);font-weight:300}
footer h4{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--brown-light);margin-bottom:20px}
footer a{display:block;font-size:14px;color:var(--gray);font-weight:300;margin-bottom:10px;transition:color .3s}
footer a:hover{color:var(--brown-light)}
footer p{font-size:14px;color:var(--gray);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,.4)}

/* Page Header (for subpages) */
.page-header{padding:200px 60px 100px;background:var(--black);text-align:center}
.page-header .section-label{margin-bottom:20px}
.page-header .section-title{margin-bottom:20px}
.page-header p{font-size:17px;font-weight:300;color:rgba(250,250,248,.5);max-width:600px;margin:0 auto}

/* Content sections for subpages */
.content-section{padding:120px 60px;max-width:1200px;margin:0 auto}
.content-section.dark{background:var(--black)}
.content-section.light{background:var(--cream);color:var(--black)}
.content-section h3{font-size:32px;margin-bottom:25px}
.content-section p{font-size:17px;line-height:2;font-weight:300;color:rgba(250,250,248,.7);margin-bottom:20px}
.content-section.light p{color:var(--gray-dark)}

/* Services detail page */
.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}

/* Projects detail grid */
.projects-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1400px;margin:0 auto}
.projects-detail-grid .project-card{height:400px}
.projects-detail-grid .project-card.tall{grid-row:span 2;height:100%}

/* Contact form area */
.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}
.contact-info-item{margin-bottom:30px}
.contact-info-item h4{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--brown-light);margin-bottom:10px}
.contact-info-item p{font-size:16px;font-weight:300;color:rgba(250,250,248,.6);line-height:1.8}
.contact-info-item a{color:var(--brown-light)}
.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(197,168,128,.2);padding:15px 0;font-size:15px;font-family:'Inter',sans-serif;color:var(--white);font-weight:300;outline:none;transition:border-color .3s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--brown-light)}
.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-light);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,.projects-detail-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}
}
