/* Lokale Google Fonts - DSGVO-konform */
@font-face {
  font-family: 'DM Serif Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/dm-serif-display-v17-latin-regular.woff2')
       format('woff2');
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/dm-sans-v17-latin-300.woff2')
       format('woff2');
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/dm-sans-v17-latin-regular.woff2')
       format('woff2');
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/dm-sans-v17-latin-500.woff2')
       format('woff2');
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/dm-sans-v17-latin-600.woff2')
       format('woff2');
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/dm-sans-v17-latin-700.woff2')
       format('woff2');
}

:root{--p:#1a3a4a;--pl:#2a5a6a;--a:#c87941;--al:#e0a06a;--bg:#faf8f5;--bga:#f0ece6;--t:#2d3436;--tl:#636e72;--ti:#faf8f5;--bd:#d4cfc7;--w:#fff;--hd:'DM Serif Display',Georgia,serif;--bs:'DM Sans',sans-serif;--mx:1100px;--tr:.3s cubic-bezier(.4,0,.2,1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:var(--bs);color:var(--t);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}a{color:var(--a);text-decoration:none;transition:var(--tr)}a:hover{color:var(--al)}
h1,h2,h3,h4{font-family:var(--hd);font-weight:400;line-height:1.2;color:var(--p)}
h1{font-size:clamp(2rem,5vw,3rem)}h2{font-size:clamp(1.6rem,3.5vw,2.3rem)}h3{font-size:clamp(1.1rem,2vw,1.4rem)}
p{margin-bottom:1em;font-size:1rem}.ctn{max-width:var(--mx);margin:0 auto;padding:0 24px}
/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(250,248,245,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:var(--tr)}
.nav.sc{border-bottom-color:var(--bd);box-shadow:0 2px 12px rgba(0,0,0,.04)}
.ni{max-width:var(--mx);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{font-family:var(--hd);font-size:1.2rem;color:var(--p)}.logo span{color:var(--a)}
.nl{display:flex;align-items:center;gap:24px;list-style:none}
.nl a{font-size:.88rem;font-weight:500;color:var(--t);position:relative}
.nl a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--a);transition:var(--tr)}
.nl a:hover::after,.nl a.act::after{width:100%}.nl a:hover{color:var(--p)}
.nc{background:var(--a)!important;color:var(--w)!important;padding:8px 20px;border-radius:6px;font-weight:600;font-size:.86rem!important}
.nc::after{display:none!important}.nc:hover{background:var(--al)!important}
.nt{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nt em{display:block;width:22px;height:2px;background:var(--p);transition:var(--tr);font-style:normal}
/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:6px;font-family:var(--bs);font-weight:600;font-size:.9rem;border:none;cursor:pointer;transition:var(--tr)}
.bp{background:var(--a);color:var(--w)}.bp:hover{background:var(--al);color:var(--w);transform:translateY(-2px);box-shadow:0 8px 20px rgba(200,121,65,.25)}
.bo{background:transparent;color:var(--p);border:2px solid var(--p)}.bo:hover{background:var(--p);color:var(--w);transform:translateY(-2px)}
.bw{background:var(--w);color:var(--p)}.bw:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.bg{display:flex;gap:12px;flex-wrap:wrap}
.arr{transition:transform .2s;display:inline-block}.btn:hover .arr{transform:translateX(4px)}
/* HERO */
.hero{padding:140px 0 80px;position:relative}
.hero::before{content:'';position:absolute;top:0;right:0;width:38%;height:100%;background:linear-gradient(135deg,transparent,var(--bga));z-index:0}
.hero .ctn{position:relative;z-index:1}
.hg{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.ht{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--a);margin-bottom:14px}
.hero h1{margin-bottom:18px}
.hs{font-size:1.08rem;color:var(--tl);line-height:1.8;max-width:480px;margin-bottom:28px}
.hiw{border-radius:12px;overflow:hidden;aspect-ratio:4/5;background:var(--bga);display:flex;align-items:center;justify-content:center;color:var(--tl);font-size:.85rem;position:relative}
.hiw img{width:100%;height:100%;object-fit:cover}
.hia{position:absolute;top:-12px;right:-12px;width:90px;height:90px;border:3px solid var(--a);border-radius:12px;z-index:-1}
/* CREDENTIALS */
.creds{display:flex;align-items:center;justify-content:center;gap:48px;flex-wrap:wrap;padding:48px 0;background:var(--bga)}
.cred{text-align:center}.cn{font-family:var(--hd);font-size:2.2rem;color:var(--a);display:block;line-height:1}.cl{font-size:.84rem;color:var(--tl);margin-top:4px}
/* SECTIONS */
.sec{padding:80px 0}.sec-a{background:var(--bga)}.sec-d{background:var(--p);color:var(--ti)}.sec-d h2,.sec-d h3{color:var(--ti)}
.sh{text-align:center;max-width:620px;margin:0 auto 40px}.sh p{color:var(--tl)}
/* TARGET CARDS */
.tc{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.tcd{background:var(--w);border-radius:12px;padding:40px 32px;border:1px solid var(--bd);transition:var(--tr);position:relative;overflow:hidden;text-decoration:none}
.tcd::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--a);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.4,0,.2,1)}
.tcd:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(26,58,74,.08);border-color:transparent}
.tcd:hover::before{transform:scaleX(1)}
.tci{width:48px;height:48px;border-radius:12px;background:var(--bga);display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:1.3rem}
.tcd h3{margin-bottom:12px}.tcd p{color:var(--tl);font-size:.95rem;margin-bottom:18px}
.tcl{font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:6px;color:var(--a)}
.tcd:hover .tcl .arr{transform:translateX(4px)}
/* SERVICES */
.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sv{padding:28px 22px;border-radius:10px;border:1px solid rgba(250,248,245,.1);transition:var(--tr)}
.sv:hover{border-color:var(--a)}
.svn{font-family:var(--hd);font-size:1.7rem;color:var(--a);opacity:.6;margin-bottom:10px;display:block}
.sv h3{margin-bottom:8px;font-size:1.1rem}.sv p{color:rgba(250,248,245,.65);font-size:.9rem;margin-bottom:0}
.sv-l{background:var(--w);border:1px solid var(--bd)}.sv-l h3{color:var(--p)}.sv-l p{color:var(--tl)}
/* CTA */
.cta{text-align:center;padding:64px 0}
.cta h2{color:var(--ti);margin-bottom:12px}
/* PAGE HEADER */
.ph{padding:130px 0 50px;background:linear-gradient(135deg,var(--bg),var(--bga))}
.pht{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--a);margin-bottom:12px}
.ph h1{max-width:680px;margin-bottom:12px}.ph p{font-size:1.08rem;color:var(--tl);max-width:580px}
/* HIGHLIGHT BOX */
.hb{background:var(--bga);border-left:4px solid var(--a);padding:20px 24px;border-radius:0 8px 8px 0;margin:24px 0}
.hb p{margin-bottom:0;font-style:italic;color:var(--p)}
/* ABOUT */
.ab{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:start}
.abimg{border-radius:12px;overflow:hidden;aspect-ratio:3/4;background:var(--bga);display:flex;align-items:center;justify-content:center;color:var(--tl);font-size:.85rem}
.abimg img{width:100%;height:100%;object-fit:cover}
.abt p{color:var(--tl)}.abt p:first-of-type{font-size:1.05rem;color:var(--t)}
/* TIMELINE */
.tl-item{display:grid;grid-template-columns:130px 1fr;gap:24px;padding:24px 0;border-bottom:1px solid var(--bd)}
.tl-yr{font-family:var(--hd);font-size:1rem;color:var(--a);padding-top:3px}
.tl-c h3{font-size:1.05rem;margin-bottom:2px}.tl-c .sub{font-weight:500;color:var(--tl);font-size:.88rem;margin-bottom:4px}.tl-c p{color:var(--tl);font-size:.88rem;margin-bottom:0}
/* CONTACT */
.cg{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.ci h2{margin-bottom:14px}.ci>p{color:var(--tl);margin-bottom:24px}
.cd{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.cdi{width:40px;height:40px;border-radius:10px;background:var(--bga);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}
.cdt strong{display:block;font-size:.86rem;color:var(--p);margin-bottom:1px}.cdt span,.cdt a{font-size:.9rem;color:var(--tl)}.cdt a:hover{color:var(--a)}
.cf{background:var(--w);padding:32px;border-radius:12px;border:1px solid var(--bd)}
.fg{margin-bottom:14px}.fg label{display:block;font-size:.86rem;font-weight:600;color:var(--p);margin-bottom:4px}
.fg input,.fg select,.fg textarea{width:100%;padding:10px 14px;border:1px solid var(--bd);border-radius:6px;font-family:var(--bs);font-size:.9rem;color:var(--t);background:var(--bg);transition:var(--tr)}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--a);box-shadow:0 0 0 3px rgba(200,121,65,.1)}
.fg textarea{resize:vertical;min-height:90px}.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
/* FOOTER */
.ft{background:var(--p);color:var(--ti);padding:48px 0 24px}
.ftg{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;margin-bottom:36px}
.ftb{font-family:var(--hd);font-size:1.15rem;color:var(--ti);margin-bottom:10px}.ftb span{color:var(--a)}
.ftd{color:rgba(250,248,245,.5);font-size:.86rem;line-height:1.7}
.ft h4{color:var(--ti);font-size:.9rem;margin-bottom:12px}
.fl{list-style:none}.fl li{margin-bottom:6px}.fl a{color:rgba(250,248,245,.5);font-size:.86rem}.fl a:hover{color:var(--al)}
.fbt{border-top:1px solid rgba(250,248,245,.1);padding-top:16px;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:rgba(250,248,245,.35)}
.fbt a{color:rgba(250,248,245,.35)}.fbt a:hover{color:var(--al)}
/* LEGAL */
.legal{padding:130px 0 60px}.legal h1{margin-bottom:24px}.legal p,.legal li{color:var(--tl)}.legal h2{font-size:1.3rem;margin:28px 0 12px}
/* ANIMATIONS */
.fi{opacity:0;transform:translateY(16px);transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1)}
.fi.vis{opacity:1;transform:translateY(0)}.fd1{transition-delay:.1s}.fd2{transition-delay:.2s}.fd3{transition-delay:.3s}
/* RESPONSIVE */
@media(max-width:900px){.hg{grid-template-columns:1fr;gap:32px}.hi{order:-1;max-width:300px}.hero::before{display:none}.tc,.sg{grid-template-columns:1fr}.ftg{grid-template-columns:1fr 1fr}.ab{grid-template-columns:1fr}.abimg{max-width:300px}.cg{grid-template-columns:1fr}.tl-item{grid-template-columns:1fr;gap:3px}.creds{gap:24px}}
@media(max-width:640px){.nl{display:none;position:absolute;top:68px;left:0;right:0;background:var(--bg);flex-direction:column;padding:18px 24px;gap:12px;border-bottom:1px solid var(--bd);box-shadow:0 8px 24px rgba(0,0,0,.06)}.nl.open{display:flex}.nt{display:flex}.bg{flex-direction:column}.bg .btn{text-align:center;justify-content:center}.ftg{grid-template-columns:1fr}.fbt{flex-direction:column;gap:5px;text-align:center}.creds{flex-direction:column;gap:18px}.fr{grid-template-columns:1fr}}
