*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#bd0000;
  --red-dark:#8c1f1f;
  --red-light:rgba(189, 0, 0, 0.55);
  --red-mid:#e8c2c2;
  --ink:#111314;
  --ink2:#2d3035;
  --muted:#6b7280;
  --line:#e5e7eb;
  --bg:#ffffff;
  --bg2:#fafaf9;
  --font-d:'Instrument Serif',Georgia,serif;
  --font-b:'Inter',system-ui,sans-serif;
  --r:4px;
}
html{scroll-behavior:smooth}
body{font-family:var(--font-b);color:var(--ink);background:var(--bg);font-size:16px;line-height:1.6;overflow-x:hidden}

/* NAV */
nav{
  position:sticky;top:0;z-index:100;
  background:var(--bg);
  border-bottom:1px solid var(--line);
  padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  height:60px;
}
.logo{font-family:var(--font-d);font-size:21px;color:var(--ink);text-decoration:none;letter-spacing:-0.3px}
.logo span{color:var(--red)}
.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{font-size:13px;font-weight:500;color:var(--muted);text-decoration:none;transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  background:var(--red);color:#fff !important;
  padding:7px 18px;border-radius:var(--r);
  font-size:13px !important;font-weight:600 !important;
  transition:background .15s !important;
}
.nav-cta:hover{background:var(--red-dark) !important}

/* HERO */
.hero-wrap{background:var(--bg);padding:80px 5% 70px;max-width:1200px;margin:0 auto}
.hero{display:grid;grid-template-columns:1.1fr 0.9fr;gap:64px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--red);margin-bottom:18px;
}
.eyebrow-line{width:24px;height:1.5px;background:var(--red)}
h1{
  font-family:var(--font-d);
  font-size:clamp(36px,3.8vw,54px);
  line-height:1.13;letter-spacing:-0.8px;
  color:var(--ink);margin-bottom:20px;
}
h1 em{font-style:italic;color:var(--red)}
.hero-sub{font-size:16px;color:var(--muted);line-height:1.75;max-width:440px;margin-bottom:32px}
.btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-p{
  background:var(--red);color:#fff;
  padding:11px 24px;border-radius:var(--r);
  font-size:13px;font-weight:600;text-decoration:none;
  border:1.5px solid var(--red);transition:background .15s;cursor:pointer
}
.btn-p:hover{background:var(--red-dark);border-color:var(--red-dark)}
.btn-o{
  background:transparent;color:var(--ink);
  padding:11px 24px;border-radius:var(--r);
  font-size:13px;font-weight:500;text-decoration:none;
  border:1.5px solid var(--line);transition:border-color .15s;cursor:pointer
}
.btn-o:hover{border-color:#aaa}

/* HERO RIGHT */
.hero-right{display:flex;flex-direction:column;gap:14px}
.h-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:6px;
  padding:20px 22px;
}
.h-card.accent{
  background:var(--red);border-color:var(--red);
}
.h-card.light{background:var(--red-light);border-color:var(--red-mid)}
.card-label{font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:8px}
.card-title{font-family:var(--font-d);font-size:18px;color:#fff;margin-bottom:14px}
.pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{font-size:11px;font-weight:500;padding:4px 12px;border-radius:100px;background:rgba(255,255,255,0.15);color:rgba(255,255,255,0.85)}
.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mini-stat{text-align:center;padding:14px 10px}
.mini-stat .n{font-family:var(--font-d);font-size:28px;color:var(--red)}
.mini-stat .l{font-size:12px;color:var(--muted);margin-top:2px}
.quote-card p{font-size:13px;color:var(--muted);font-style:italic;line-height:1.6}
.quote-card cite{font-size:11px;color:var(--red);font-style:normal;font-weight:600;margin-top:6px;display:block}
.quote-card{border-left:3px solid var(--red) !important;border-radius:0 6px 6px 0 !important;padding-left:18px !important}

/* DIVIDER */
.kpi-bar{background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:28px 5%}
.kpi-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);text-align:center;gap:16px}
.kpi-n{font-family:var(--font-d);font-size:30px;color:var(--red)}
.kpi-l{font-size:13px;color:var(--muted);margin-top:2px}

/* SECTIONS */
section{padding:80px 5%}
.si{max-width:1200px;margin:0 auto}
.stag{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.stag::before{content:'';display:block;width:20px;height:1.5px;background:var(--red)}
.stitle{font-family:var(--font-d);font-size:clamp(26px,2.8vw,38px);line-height:1.2;letter-spacing:-0.5px;color:var(--ink);margin-bottom:14px}
.ssub{font-size:16px;color:var(--muted);max-width:520px;line-height:1.75;margin-bottom:44px}

/* LEISTUNGEN */
#leistungen{background:var(--bg)}
.l-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.l-card{
  border:1px solid var(--line);
  border-radius:6px;padding:28px 24px;
  transition:border-color .2s,box-shadow .2s;
  position:relative;overflow:hidden;
}
.l-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
}
.l-card.r1::after{background:var(--red)}
.l-card:hover{border-color:#ccc;box-shadow:0 6px 24px rgba(0,0,0,0.05)}
.l-ico{
  width:44px;height:44px;border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:16px;
  background:var(--red-light);
}
.l-card h3{font-family:var(--font-d);font-size:19px;color:var(--ink);margin-bottom:8px}
.l-card p{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:16px}
.ltags{display:flex;gap:6px;flex-wrap:wrap}
.ltag{font-size:11px;font-weight:500;padding:3px 10px;border-radius:100px;border:1px solid var(--line);color:var(--muted);background:var(--bg2)}

/* VORGEHEN */
#vorgehen{background:var(--bg2)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.steps::before{content:'';position:absolute;top:26px;left:12%;right:12%;height:1px;background:var(--line)}
.step{text-align:center;padding:0 14px;position:relative;z-index:1}
.snum{
  width:52px;height:52px;border-radius:50%;
  background:var(--bg);border:1.5px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
  font-family:var(--font-d);font-size:18px;color:var(--red);
}
.step h4{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:6px}
.step p{font-size:13px;color:var(--muted);line-height:1.6}

/* MANPOWER */
#manpower{background:var(--ink);color:#fff}
#manpower .stag{color:rgba(255,255,255,0.4)}
#manpower .stag::before{background:rgba(255,255,255,0.2)}
#manpower .stitle{color:#fff}
#manpower .ssub{color:rgba(255,255,255,0.55)}
.mp-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.mp-feats{display:flex;flex-direction:column;gap:16px}
.mp-feat{
  display:flex;gap:14px;
  padding:18px 18px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:6px;
}
.mp-feat-ico{font-size:18px;flex-shrink:0;margin-top:2px}
.mp-feat h4{font-size:14px;font-weight:600;color:#fff;margin-bottom:3px}
.mp-feat p{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.6}
.mp-vis{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:6px;padding:28px;
}
.mp-vis h3{font-family:var(--font-d);font-size:20px;color:#fff;margin-bottom:20px}
.profiles{display:flex;flex-direction:column;gap:10px}
.pcard{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,0.07);border-radius:4px;padding:11px 14px}
.pavatar{
  width:34px;height:34px;border-radius:50%;
  background:var(--red);display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:600;color:#fff;flex-shrink:0;
}
.pname{font-size:13px;font-weight:600;color:#fff}
.prole{font-size:11px;color:rgba(255,255,255,0.45);margin-top:1px}
.pbadge{font-size:11px;font-weight:500;padding:3px 10px;border-radius:100px;background:rgba(181,42,42,0.5);color:#f5b0b0;margin-left:auto;flex-shrink:0}

/* BRANCHEN */
#branchen{background:var(--bg)}
.b-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.b-item{
  display:flex;align-items:center;gap:12px;
  padding:16px 18px;border:1px solid var(--line);
  border-radius:6px;transition:all .2s;
}
.b-item:hover{background:var(--red-light);border-color:var(--red-mid)}
.b-dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0}
.b-item span{font-size:14px;font-weight:500;color:var(--ink2)}

/* KONTAKT */
#kontakt{background:var(--bg2)}
.k-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:56px;align-items:start}
.c-form{background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:28px}
.c-form h3{font-family:var(--font-d);font-size:20px;margin-bottom:18px;color:var(--ink)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.ff{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.ff label{font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--muted)}
.ff input,.ff textarea,.ff select{
  padding:9px 13px;border:1px solid var(--line);border-radius:var(--r);
  font-family:var(--font-b);font-size:13px;color:var(--ink);background:var(--bg);
  outline:none;transition:border-color .15s;
}
.ff input:focus,.ff textarea:focus,.ff select:focus{border-color:var(--red)}
.ff textarea{resize:vertical;min-height:80px}

/* FOOTER */
footer{background:var(--red);padding:40px 5%}
.footer-in{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.flogo{font-family:var(--font-d);font-size:18px;color:#fff}
.flinks{display:flex;gap:30px}
.flinks a{font-size:13px;color:rgba(255,255,255,0.80);font-weight:900;text-decoration:none;transition:color .15s}
.flinks a:hover{color:rgba(255,255,255,1.0)}
.fcopy{font-size:12px;color:rgba(255,255,255,0.70)}

/* HERO BG WRAPPER */
.hero-bg{background:var(--bg)}

/* COOKIE BANNER */
.cookie-banner{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:#fff;border-top:1px solid var(--line);
  padding:20px 5%;
  box-shadow:0 -4px 24px rgba(0,0,0,0.07);
  font-family:var(--font-b);
}
.cookie-banner-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
}
.cookie-banner-text{flex:1;min-width:260px}
.cookie-banner-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px}
.cookie-banner-desc{font-size:13px;color:var(--muted);line-height:1.6}
.cookie-banner-desc a{color:#b52a2a;text-decoration:underline;margin-left:4px}
.cookie-banner-actions{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}

/* MODAL OVERLAY */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:10000;
  background:rgba(17,19,20,0.5);
}

/* MODALS SHARED */
.modal{
  display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:10001;max-height:80vh;overflow-y:auto;
  background:#fff;border-radius:8px;border:1px solid var(--line);
  font-family:var(--font-b);
}
.modal-lg{width:min(720px,92vw)}
.modal-md{width:min(680px,92vw);max-height:82vh}
.modal-header{
  position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line);
  padding:20px 28px;display:flex;justify-content:space-between;align-items:center;
}
.modal-header-title{font-family:var(--font-d);font-size:22px;color:var(--ink)}
.modal-close-btn{background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);line-height:1}
.modal-body{padding:28px;font-size:14px;color:var(--ink2);line-height:1.75}
.modal-meta{color:var(--muted);font-size:13px;margin-bottom:24px}
.modal-footer{padding:16px 28px;border-top:1px solid var(--line);text-align:right}
.modal-footer-split{
  padding:16px 28px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
}

/* MODAL CONTENT */
.modal-section-title{font-size:15px;font-weight:600;color:var(--ink);margin:0 0 8px}
.modal-paragraph{margin-bottom:20px}
.modal-paragraph-sm{margin-bottom:12px}
.modal-list{padding-left:20px;margin-bottom:20px;color:var(--muted)}
.modal-list li{margin-bottom:4px}
.modal-link{color:#b52a2a}
.modal-note{font-size:12px;color:#9ca3af}
.modal-impressum-block{margin-bottom:15px}

/* COOKIE CATEGORY */
.cookie-cat{border:1px solid var(--line);border-radius:6px;padding:18px 20px;margin-bottom:12px}
.cookie-cat-last{margin-bottom:20px}
.cookie-cat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.cookie-cat-title{font-size:14px;font-weight:600;color:var(--ink)}
.cookie-badge{
  font-size:12px;font-weight:600;padding:3px 12px;border-radius:100px;
  background:#f9eded;color:#b52a2a;border:1px solid var(--red-mid);
}
.cookie-cat-desc{font-size:13px;color:var(--muted)}
.cookie-cat-examples{font-size:12px;color:#9ca3af;margin-top:8px}

/* COOKIE TOGGLE */
.cookie-toggle-wrap{display:flex;align-items:center;gap:8px;cursor:pointer}
.cookie-toggle-label{font-size:12px;color:var(--muted)}
.cookie-toggle-label.active{color:#b52a2a}
.cookie-toggle{
  width:40px;height:22px;border-radius:100px;background:var(--line);
  position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;
}
.cookie-toggle.active{background:#b52a2a}
.cookie-toggle-thumb{
  width:16px;height:16px;border-radius:50%;background:#fff;
  position:absolute;top:3px;left:3px;transition:left .2s;
  box-shadow:0 1px 3px rgba(0,0,0,0.2);
}
.cookie-toggle.active .cookie-toggle-thumb{left:21px}

/* BUTTONS */
.btn-outline{
  padding:9px 20px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;
  background:transparent;border:1.5px solid var(--line);color:var(--ink2);font-family:var(--font-b);
  transition:border-color .15s;
}
.btn-outline:hover{border-color:#aaa}
.btn-outline-red{
  padding:9px 20px;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;
  background:transparent;border:1.5px solid #b52a2a;color:#b52a2a;font-family:var(--font-b);
}
.btn-red{
  padding:9px 20px;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;
  background:#b52a2a;border:1.5px solid #b52a2a;color:#fff;font-family:var(--font-b);
  transition:background .15s;
}
.btn-red:hover{background:#8c1f1f}
.btn-red-lg{
  padding:9px 24px;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;
  background:#b52a2a;border:none;color:#fff;font-family:var(--font-b);
}
.btn-submit{width:100%;margin-top:6px;border:none;font-size:14px;padding:12px}

@media(max-width:768px){
  .nav-links{display:none}
  .hero{grid-template-columns:1fr;padding:50px 0 30px;gap:36px}
  .kpi-inner{grid-template-columns:repeat(2,1fr)}
  .l-grid,.steps,.b-grid{grid-template-columns:1fr 1fr}
  .mp-grid,.k-grid{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  section{padding:60px 4%}
}
@media(max-width:480px){
  .l-grid,.b-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
}
