/* ===== Schriften (lokal, DSGVO-konform) ===== */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/inter-400.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url(fonts/inter-500.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/inter-600.woff2) format('woff2')}
@font-face{font-family:'Bree Serif';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/bree-serif-400.woff2) format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/ibm-plex-mono-400.woff2) format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url(fonts/ibm-plex-mono-500.woff2) format('woff2')}

:root{
  --ink:#1C1C1A;
  --ink-soft:#43423E;
  --muted:#6E6D67;
  --paper:#FBFAF7;
  --surface:#FFFFFF;
  --line:#E7E4DC;
  --line-strong:#D8D4CA;
  --red:#E30613;
  --red-dark:#B0040F;
  --maxw:1120px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.ic{width:1em;height:1em;display:inline-block;vertical-align:-0.125em;flex-shrink:0}
a{color:inherit;text-decoration:none}
.serif{font-family:'Bree Serif',Georgia,serif;font-weight:400}
.mono{font-family:'IBM Plex Mono',monospace}

/* ---- eyebrow / labels ---- */
.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--red);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);display:inline-block}

/* ---- NAV ---- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(251,250,247,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:13px}
.brand svg{width:42px;height:42px;flex-shrink:0}
.brand-name{line-height:1.05}
.brand-name .b1{font-family:'Bree Serif',serif;font-size:19px;color:var(--ink);display:block}
.brand-name .b2{font-family:'Bree Serif',serif;font-size:19px;color:var(--ink);display:block}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:15px;color:var(--ink-soft);transition:color .18s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  background:var(--red);color:#fff !important;
  padding:11px 22px;border-radius:2px;font-weight:500;font-size:15px;
  transition:background .18s;
}
.nav-cta:hover{background:var(--red-dark)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;color:var(--ink)}

/* ---- HERO ---- */
.hero{position:relative;padding:96px 0 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg img{display:block;width:100%;height:100%;object-fit:cover;object-position:right center}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
.hero h1{
  font-family:'Bree Serif',serif;font-weight:400;
  font-size:clamp(38px,6vw,62px);line-height:1.04;letter-spacing:-.5px;
  margin:22px 0 0;color:var(--ink);
}
.hero h1 .accent{color:var(--red)}
.hero .lede{
  font-size:19px;color:var(--ink-soft);margin-top:24px;max-width:30em;
}
.hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 26px;border-radius:2px;font-weight:500;font-size:16px;
  transition:all .18s;cursor:pointer;border:1px solid transparent;
}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-dark)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--ink);background:var(--surface)}

/* hero artwork: circuit board */
.hero-art{position:relative;display:flex;justify-content:center;align-items:center}
.hero-art .panel{
  width:100%;max-width:380px;aspect-ratio:4/5;position:relative;overflow:hidden;
  border-radius:8px;border:1px solid var(--line);box-shadow:0 16px 40px rgba(28,28,26,.18);
}
.hero-art .portrait{display:block;width:100%;height:100%;object-fit:cover;object-position:50% 14%}
.namechip{position:absolute;left:16px;bottom:16px;z-index:2;background:var(--surface);
  border:1px solid var(--line);border-radius:3px;padding:8px 14px;
  font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);
  display:flex;align-items:center;gap:9px;box-shadow:0 4px 14px rgba(28,28,26,.12)}
.namechip i{width:7px;height:7px;border-radius:50%;background:var(--red)}
.namechip b{font-family:'Bree Serif',serif;font-weight:400;color:var(--ink);font-size:14px}
.tag-chip{
  position:absolute;background:var(--surface);border:1px solid var(--line);
  font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ink-soft);
  padding:7px 13px;border-radius:2px;white-space:nowrap;
  display:flex;align-items:center;gap:7px;
}
.tag-chip i{width:6px;height:6px;border-radius:50%;background:var(--red)}
.tag-chip.t1{top:6%;left:-6%}
.tag-chip.t2{bottom:18%;right:-8%}
.tag-chip.t3{bottom:-3%;left:14%}

/* trace divider */
.trace{display:flex;align-items:center;gap:0;height:1px;background:var(--line);position:relative;margin:0}
.trace .node{position:absolute;width:9px;height:9px;border-radius:50%;background:var(--ink)}
.trace .node.red{background:var(--red)}

/* ---- SECTION SHELL ---- */
section{padding:84px 0}
.sec-head{max-width:680px;margin-bottom:52px}
.sec-head h2{
  font-family:'Bree Serif',serif;font-weight:400;
  font-size:clamp(28px,4vw,40px);line-height:1.1;letter-spacing:-.3px;
  margin-top:16px;color:var(--ink);
}
.sec-head p{color:var(--muted);margin-top:14px;font-size:17px}

/* ---- SERVICES ---- */
#leistungen{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.svc{
  padding:34px 30px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--surface);transition:background .2s;position:relative;
}
.svc:hover{background:var(--paper)}
.svc-num{
  font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted);
  display:flex;align-items:center;gap:9px;margin-bottom:20px;
}
.svc-num .dot{width:9px;height:9px;border-radius:50%;background:var(--ink);flex-shrink:0}
.svc:first-child .svc-num .dot{background:var(--red)}
.svc-icon{font-size:26px;color:var(--ink);margin-bottom:14px;line-height:1}
.svc h3{font-family:'Bree Serif',serif;font-weight:400;font-size:21px;line-height:1.2;margin-bottom:10px;color:var(--ink)}
.svc p{font-size:15px;color:var(--muted);line-height:1.6}

/* ---- AUDIENCE band ---- */
.band{background:var(--ink);color:#fff;padding:62px 0}
.band-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.band h2{font-family:'Bree Serif',serif;font-weight:400;font-size:clamp(26px,3.5vw,36px);line-height:1.15}
.band h2 .accent{color:var(--red)}
.band-points{display:flex;flex-direction:column;gap:18px}
.band-point{display:flex;gap:15px;align-items:flex-start}
.band-point i{color:var(--red);font-size:22px;margin-top:2px}
.band-point strong{font-weight:600;display:block;margin-bottom:2px}
.band-point span{color:#B9B7B0;font-size:15px}

/* ---- CONTACT ---- */
#kontakt{background:var(--paper)}
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:start}
.contact-lead h2{font-family:'Bree Serif',serif;font-weight:400;font-size:clamp(28px,4vw,42px);line-height:1.08;margin-top:16px}
.contact-lead p{color:var(--muted);margin-top:16px;max-width:24em}
.contact-actions{display:flex;gap:13px;margin-top:30px;flex-wrap:wrap}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:8px 0}
.crow{display:flex;align-items:center;gap:18px;padding:20px 26px;border-bottom:1px solid var(--line)}
.crow:last-child{border-bottom:0}
.crow-ic{width:44px;height:44px;border-radius:3px;background:var(--paper);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--red);flex-shrink:0}
.crow-label{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.crow-val{font-size:16px;color:var(--ink);font-weight:500}
.crow-val a:hover{color:var(--red)}

/* ---- FOOTER ---- */
footer{background:var(--ink);color:#C7C5BE;padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:42px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .brand-name .b1,.foot-brand .brand-name .b2{color:#fff}
.foot-brand p{font-size:14px;margin-top:18px;max-width:26em;color:#9C9A93}
.foot-col h4{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#fff;margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a,.foot-col li{font-size:14px;color:#9C9A93;transition:color .18s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;flex-wrap:wrap;gap:12px}
.foot-bottom span{font-size:13px;color:#7E7C76}
.foot-bottom .legal-links{display:flex;gap:22px}
.foot-bottom .legal-links a{font-size:13px;color:#9C9A93;cursor:pointer}
.foot-bottom .legal-links a:hover{color:#fff}

/* ---- LEGAL PAGES ---- */
.legal-page{display:block;padding:90px 0 90px;min-height:70vh}
.legal-back{margin-top:0}
.legal-back{display:inline-flex;align-items:center;gap:8px;font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--muted);margin-bottom:30px;cursor:pointer}
.legal-back:hover{color:var(--ink)}
.legal-page h1{font-family:'Bree Serif',serif;font-weight:400;font-size:clamp(30px,5vw,44px);margin-bottom:8px}
.legal-page .legal-sub{color:var(--muted);font-family:'IBM Plex Mono',monospace;font-size:13px;margin-bottom:40px}
.legal-block{max-width:760px;margin-bottom:32px}
.legal-block h2{font-family:'Bree Serif',serif;font-weight:400;font-size:22px;margin-bottom:12px;color:var(--ink)}
.legal-block h3{font-size:16px;font-weight:600;margin:18px 0 6px}
.legal-block p{color:var(--ink-soft);font-size:16px;margin-bottom:12px}
.legal-block a{color:var(--red)}
.legal-block a:hover{text-decoration:underline}
.legal-data{font-family:'IBM Plex Mono',monospace;font-size:15px;line-height:1.9;background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:22px 26px;color:var(--ink)}


/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-art{order:-1}
  .hero-art .panel{max-width:300px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .band-inner,.contact-grid,.foot-grid{grid-template-columns:1fr;gap:32px}
  .foot-grid{gap:36px}
}
@media (max-width:600px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  section{padding:60px 0}
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--surface);border-bottom:1px solid var(--line);padding:20px 28px;gap:18px;align-items:flex-start}
  .nav-toggle{display:block}
  .svc-grid{grid-template-columns:1fr}
  .svc{border-right:0}
  .hero{padding:60px 0 50px}
  .hero-bg{opacity:.4}
  .tag-chip{display:none}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}
