/* =================================================================
   SCAVI ABBRUCH — Stylesheet
   Übernommen 1:1 aus der genehmigten Design-Vorlage (Claude Design).
   Aufbau: 01 Tokens · 02 Reset/Base · 03 Typografie · 04 Layout
           05 Buttons · 06 Header · 07 Footer · 08 Komponenten
           09 Seitenspezifisch · 10 Formular · 11 Responsive
   ================================================================= */

/* ============================ 01 · TOKENS ======================= */
:root{
  /* Farben */
  --red:        #C8102E;   /* Akzent: CTAs, Linien, aktive Zustände, Icons */
  --red-700:    #A50D26;   /* Hover */
  --ink:        #111111;   /* Tiefschwarz */
  --white:      #FFFFFF;
  --gray-50:    #F4F4F5;   /* Sektionshintergründe */
  --gray-200:   #D1D1D6;   /* Linien / Rahmen */
  --text-body:  #2A2A2E;   /* Fließtext */
  --text-mid:   #55555A;
  --text-muted: #6B6B70;
  --text-faint: #88888E;
  --line:       #ECECEE;   /* feine Trennlinien */
  --ink-soft:   #B5B5BA;   /* Text auf Dunkel */
  --ink-soft2:  #9A9AA0;

  /* Typo */
  --f-head: 'Oswald', system-ui, sans-serif;        /* Headlines */
  --f-cond: 'Saira Condensed', system-ui, sans-serif;/* Labels, Buttons, Zahlen */
  --f-body: 'Inter', system-ui, sans-serif;          /* Fließtext */
  --f-mono: 'JetBrains Mono', ui-monospace, monospace;

  /* Maße */
  --radius: 2px;
  --container: 1240px;
  --shadow-card: 0 16px 30px -18px rgba(17,17,17,0.35);
  --shadow-lift: 0 30px 60px -40px rgba(17,17,17,0.40);
}

/* ============================ 02 · RESET/BASE =================== */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.6;
  color:var(--text-body);
  background:var(--white);
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:var(--red); text-decoration:none; }
a:hover{ color:var(--red-700); }
::selection{ background:var(--red); color:#fff; }
:focus-visible{ outline:3px solid rgba(200,16,46,0.45); outline-offset:2px; }

/* ============================ 03 · TYPOGRAFIE ================== */
h1,h2,h3,h4{ font-family:var(--f-head); color:var(--ink); margin:0; }
.h-display{ font-weight:700; font-size:clamp(40px,6vw,72px); line-height:0.96;
  letter-spacing:-0.015em; text-transform:uppercase; }
h1,.h1{ font-weight:700; font-size:clamp(34px,5vw,56px); line-height:0.98;
  letter-spacing:-0.015em; text-transform:uppercase; }
h2,.h2{ font-weight:700; font-size:clamp(28px,3.6vw,42px); line-height:1.0;
  letter-spacing:-0.01em; text-transform:uppercase; }
h3,.h3{ font-weight:600; font-size:22px; line-height:1.15; text-transform:uppercase; }
h4{ font-weight:600; font-size:17px; line-height:1.2; text-transform:uppercase; }
p{ margin:0 0 1em; }
.lead{ font-size:18px; line-height:1.6; color:var(--text-mid); }
strong{ color:var(--ink); font-weight:600; }
.accent{ color:var(--red); }

/* Eyebrow / Label mit rotem Strich */
.eyebrow{
  display:flex; align-items:center; gap:14px;
  font-family:var(--f-cond); text-transform:uppercase;
  letter-spacing:0.2em; font-weight:600; font-size:14px; color:var(--red);
}
.eyebrow::before{ content:""; width:48px; height:3px; background:var(--red); flex:none; }
.eyebrow.no-bar::before{ display:none; }

/* ============================ 04 · LAYOUT ===================== */
.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }
.section{ padding:84px 0; }
.section--gray{ background:var(--gray-50); }
.section--ink{ background:var(--ink); color:var(--ink-soft); }
.section--tight{ padding:56px 0; }
.section-head{ display:flex; flex-direction:column; gap:16px; margin-bottom:44px; }
.section-head .lead{ max-width:620px; }
.section-head--split{
  flex-direction:row; align-items:flex-end; justify-content:space-between;
  gap:32px; flex-wrap:wrap;
}
.section-head--split .lead{ max-width:380px; margin:0; }
.stack{ display:flex; flex-direction:column; gap:24px; }

/* Trenner-Akzente */
.divider-diamond{ display:flex; align-items:center; gap:16px; margin:8px 0; }
.divider-diamond::before,.divider-diamond::after{ content:""; flex:1; height:1px; background:var(--line); }
.divider-diamond span{ width:8px; height:8px; background:var(--red); transform:rotate(45deg); }

/* Rote Raute als Bullet */
.diamond{ width:11px; height:11px; background:var(--red); transform:rotate(45deg); flex:none; }

/* ============================ 05 · BUTTONS ==================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.06em;
  font-weight:600; font-size:16px; padding:15px 26px; border-radius:var(--radius);
  border:2px solid transparent; cursor:pointer; transition:.15s ease;
  text-decoration:none; line-height:1; white-space:nowrap;
}
.btn .arrow{ font-size:16px; line-height:1; }
.btn--primary{ background:var(--red); color:#fff; border-color:var(--red); }
.btn--primary:hover{ background:var(--red-700); border-color:var(--red-700); color:#fff; }
.btn--outline{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn--outline:hover{ background:var(--ink); color:#fff; }
.btn--dark{ background:var(--ink); color:#fff; border-color:var(--ink); }
.btn--dark:hover{ background:#000; color:#fff; }
.btn--dark .arrow{ color:var(--red); }
.btn--sm{ font-size:15px; padding:12px 20px; }
.btn--block{ width:100%; }
.btn[disabled],.btn--disabled{ background:var(--line); color:#A0A0A6; border-color:var(--line); cursor:not-allowed; }
.textlink{
  display:inline-flex; align-items:center; gap:8px; color:var(--red);
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.06em;
  font-weight:600; font-size:15px; border-bottom:2px solid var(--red); padding-bottom:3px;
}
.textlink:hover{ color:var(--red-700); border-color:var(--red-700); }

/* ============================ 06 · HEADER ==================== */
.site-header{ position:sticky; top:0; z-index:50; }
.utility-bar{ background:var(--ink); }
.utility-bar .container{
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 24px; gap:16px;
}
.utility-bar__left{ display:flex; gap:18px; align-items:center;
  font-size:13px; color:var(--ink-soft); flex-wrap:wrap; }
.utility-bar__left .geo{ display:flex; align-items:center; gap:8px; }
.utility-bar__left .geo::before{ content:""; width:7px; height:7px; background:var(--red); transform:rotate(45deg); }
.utility-bar__sep{ width:1px; height:13px; background:#39393E; }
.utility-bar__phone{
  display:flex; gap:9px; align-items:center; font-family:var(--f-cond);
  text-transform:uppercase; letter-spacing:0.08em; font-weight:600; font-size:14px; color:#fff;
}
.utility-bar__phone::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--red); }
.utility-bar__phone:hover{ color:#fff; }

.main-bar{ background:#fff; border-bottom:3px solid var(--red); }
.main-bar .container{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px; gap:24px;
}
.brand img{ height:38px; width:auto; }
.nav{ display:flex; align-items:center; gap:30px; }
.nav a{
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.06em;
  font-weight:600; font-size:16px; color:var(--text-mid);
  padding-bottom:4px; border-bottom:3px solid transparent;
}
.nav a:hover{ color:var(--ink); }
.nav a.is-active{ color:var(--ink); border-bottom-color:var(--red); }
.header-cta{ display:inline-flex; }

/* Hamburger */
.nav-toggle{
  display:none; flex-direction:column; gap:5px; width:28px; height:22px;
  background:none; border:none; padding:0; cursor:pointer; position:relative;
}
.nav-toggle span{ height:3px; width:100%; background:var(--ink); display:block; transition:.2s; }
.nav-toggle span:last-child{ background:var(--red); }

/* ============================ 07 · FOOTER ==================== */
.site-footer{ background:var(--ink); border-top:4px solid var(--red); color:var(--ink-soft); }
.site-footer .container{ padding-top:56px; padding-bottom:28px; }
.footer-grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px;
  padding-bottom:36px; border-bottom:1px solid #2A2A2E;
}
.footer-brand img{ height:40px; width:auto; margin-bottom:18px; }
.footer-brand p{ font-size:14px; line-height:1.6; color:var(--ink-soft2); max-width:280px; }
.footer-col h3{
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.12em;
  font-weight:600; font-size:13px; color:var(--red); margin-bottom:14px;
}
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer-col a{ font-size:14px; color:var(--ink-soft); }
.footer-col a:hover{ color:#fff; }
.footer-contact-phone{
  display:block; font-family:var(--f-cond); text-transform:uppercase;
  letter-spacing:0.04em; font-weight:600; font-size:20px; color:#fff; margin:4px 0;
}
.footer-contact-phone:hover{ color:#fff; }
.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:22px; flex-wrap:wrap; gap:12px;
  font-size:13px; color:#77777C;
}
.footer-bottom a{ color:#77777C; }
.footer-bottom a:hover{ color:#fff; }
.footer-bottom nav{ display:flex; gap:24px; flex-wrap:wrap; }

/* ============================ 08 · KOMPONENTEN =============== */

/* Bild-Platzhalter (austauschbar) — dunkle Baustellen-Optik mit rotem Eck-Akzent */
.ph{
  position:relative; overflow:hidden;
  background:
    linear-gradient(rgba(17,17,17,0.45),rgba(17,17,17,0.45)),
    repeating-linear-gradient(135deg,#2A2A2E,#2A2A2E 16px,#232327 16px,#232327 32px);
  display:flex; align-items:center; justify-content:center;
}
.ph__label{
  font-family:var(--f-mono); font-size:12px; color:rgba(255,255,255,0.85);
  text-align:center; line-height:1.7; border:1px dashed rgba(255,255,255,0.4);
  padding:16px 20px; max-width:80%;
}
.ph__corner{ /* rotes Dreieck unten rechts */
  position:absolute; bottom:0; right:0; width:0; height:0; border-style:solid;
  border-width:0 0 130px 130px; border-color:transparent transparent var(--red) transparent;
}
.ph__corner--tl{ top:0; left:0; bottom:auto; right:auto;
  border-width:120px 120px 0 0; border-color:var(--red) transparent transparent transparent; }
.ph__corner--tr{ top:0; right:0; bottom:auto; left:auto;
  border-width:0 130px 130px 0; border-color:transparent var(--red) transparent transparent; }
.ph__plus{ position:absolute; top:28px; left:28px; }
.ph__plus::before,.ph__plus::after{ content:""; position:absolute; background:var(--red); }
.ph__plus::before{ width:40px; height:4px; }
.ph__plus::after{ width:4px; height:40px; }

/* Echte Fotos füllen die Bild-Container (mit erhaltenem rotem Eck-Akzent) */
.hero__media > img,
.svc-block__media > img,
.why-media > img,
.ref-card__media > img,
.blog-card__media > img,
.article__hero > img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
}
.article__hero{ position:relative; overflow:hidden; }
.blog-card__media{ overflow:hidden; }
.ref-card__media{ position:relative; overflow:hidden; }
/* feiner dunkler Verlauf unten für Tiefe/Lesbarkeit der roten Ecke */
.img-shade::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(17,17,17,0) 55%,rgba(17,17,17,0.28)); pointer-events:none; }

/* Zertifizierungs-Trust-Strip */
.trust-strip{ background:var(--ink); color:#fff; }
.trust-strip .container{ display:flex; align-items:center; justify-content:center; gap:14px 40px; flex-wrap:wrap; padding:18px 24px; }
.trust-item{ display:flex; align-items:center; gap:12px; }
.trust-item .diamond{ background:var(--red); }
.trust-item b{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.06em; font-weight:600; font-size:16px; color:#fff; }
.trust-item span{ font-size:14px; color:var(--ink-soft); }
.trust-strip__sep{ width:1px; height:22px; background:#33333A; }
@media (max-width:700px){ .trust-strip__sep{ display:none; } }

/* Partner / Komplettlösung-Teaser */
.partner{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.partner__media{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.partner__media > img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.partner__tags{ display:flex; gap:10px; flex-wrap:wrap; margin-top:4px; }
.partner__tag{ display:inline-flex; align-items:center; gap:8px; border:1px solid var(--gray-200); padding:8px 14px;
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.05em; font-weight:600; font-size:14px; color:var(--ink); }
.partner__tag::before{ content:""; width:8px; height:8px; background:var(--red); transform:rotate(45deg); }
@media (max-width:860px){ .partner{ grid-template-columns:1fr; gap:28px; } .partner.is-reverse .partner__media{ order:0; } }

/* Service-Card */
.cards-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.cards-grid--3{ grid-template-columns:repeat(3,1fr); }
.svc-card{
  display:flex; flex-direction:column; gap:14px;
  background:#fff; border:1px solid var(--gray-200); border-top:3px solid var(--gray-200);
  padding:26px 22px; transition:.18s ease; position:relative;
}
a.svc-card{ color:inherit; }
.svc-card:hover{
  border-top-color:var(--red); box-shadow:var(--shadow-card); transform:translateY(-3px);
}
.svc-card.is-featured{ border-top-color:var(--red); }
.svc-card__icon{
  width:44px; height:44px; border:2px solid var(--ink);
  display:flex; align-items:center; justify-content:center; flex:none;
}
.svc-card__icon span{ width:18px; height:18px; border:2px solid var(--red); transform:rotate(45deg); }
.svc-card__title{ font-family:var(--f-head); text-transform:uppercase; font-weight:600;
  font-size:21px; color:var(--ink); line-height:1.1; }
.svc-card__text{ font-size:14px; line-height:1.55; color:var(--text-muted); }
.svc-card__more{
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.06em;
  font-weight:600; font-size:14px; color:var(--red); margin-top:auto;
}
.svc-card__badge{
  position:absolute; top:0; right:0; background:var(--red); color:#fff;
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.1em;
  font-weight:600; font-size:11px; padding:5px 10px;
}
/* invertierte (schwarze) Karte */
.svc-card--ink{ background:var(--ink); border-color:var(--ink); border-top-color:var(--ink); }
.svc-card--ink:hover{ border-top-color:var(--ink); transform:none; box-shadow:none; }
.svc-card--ink .svc-card__icon{ border-color:#fff; }
.svc-card--ink .svc-card__title{ color:#fff; }
.svc-card--ink .svc-card__text{ color:var(--ink-soft); }

/* Prozess-Steps (horizontal, nummeriert, mit Linie) */
.steps{ display:grid; grid-template-columns:repeat(5,1fr); position:relative; }
.steps::before{ content:""; position:absolute; top:23px; left:8%; right:8%; height:2px; background:var(--gray-200); }
.step{ position:relative; display:flex; flex-direction:column; gap:12px; padding-right:18px; }
.step:last-child{ padding-right:0; }
.step__num{
  width:48px; height:48px; border-radius:50%; background:#fff; border:2px solid var(--ink);
  color:var(--ink); display:flex; align-items:center; justify-content:center;
  font-family:var(--f-head); font-weight:700; font-size:22px; position:relative; z-index:1;
}
.step:first-child .step__num{ background:var(--red); border-color:var(--red); color:#fff; }
.step:last-child .step__num{ background:var(--ink); color:#fff; }
.step__title{ font-family:var(--f-head); text-transform:uppercase; font-weight:600; font-size:17px; color:var(--ink); line-height:1.1; }
.step__text{ font-size:13px; line-height:1.5; color:var(--text-muted); }

/* Blog-Card */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.blog-card{
  display:flex; flex-direction:column; background:#fff; border:1px solid var(--line);
  transition:.18s ease; color:inherit; height:100%;
}
.blog-card:hover{ box-shadow:0 16px 30px -18px rgba(17,17,17,0.30); color:inherit; }
.blog-card__media{
  aspect-ratio:16/10; position:relative; display:flex; align-items:center; justify-content:center;
  background:repeating-linear-gradient(135deg,#E7E7EA,#E7E7EA 10px,#EFEFF1 10px,#EFEFF1 20px);
}
.blog-card__media span.tag-bar{ position:absolute; top:12px; left:12px; width:24px; height:3px; background:var(--red); }
.blog-card__media .ph-note{ font-family:var(--f-mono); font-size:11px; color:#9A9AA0; }
.blog-card__body{ padding:22px 22px 26px; display:flex; flex-direction:column; gap:10px; flex:1; }
.blog-card__meta{ display:flex; gap:12px; align-items:center; }
.blog-card__cat{ font-weight:600; font-size:12px; text-transform:uppercase; letter-spacing:0.06em; color:var(--red); }
.blog-card__date{ font-size:12px; color:#A0A0A6; }
.blog-card__title{ font-family:var(--f-head); text-transform:uppercase; font-weight:600; font-size:20px; line-height:1.12; color:var(--ink); }
.blog-card__teaser{ font-size:14px; line-height:1.55; color:var(--text-muted); }
.blog-card__more{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.06em; font-weight:600; font-size:14px; color:var(--ink); margin-top:auto; }

/* Vorteils-Item (Raute + Titel + Text) */
.benefit{ display:flex; gap:14px; }
.benefit .diamond{ margin-top:5px; }
.benefit__title{ font-family:var(--f-head); text-transform:uppercase; font-weight:600; font-size:17px; color:var(--ink); }
.benefit__text{ font-size:14px; line-height:1.5; color:var(--text-muted); }
.benefits-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px 28px; }

/* Stat-Reihe */
.stats{ display:flex; gap:30px; flex-wrap:wrap; padding-top:24px; border-top:1px solid var(--line); }
.stat__num{ font-family:var(--f-head); font-weight:700; font-size:30px; line-height:1; color:var(--ink); }
.stat__num.accent{ color:var(--red); }
.stat__label{ font-size:13px; color:var(--text-muted); margin-top:4px; }

/* Eyebrow-Block mit rotem Balken */
.bar-block{ display:flex; align-items:stretch; min-height:30px; }
.bar-block::before{ content:""; width:6px; background:var(--red); flex:none; }
.bar-block span{ flex:1; background:var(--gray-50); display:flex; align-items:center; padding-left:16px;
  font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.1em; font-weight:600; font-size:13px; color:var(--ink); }

/* ============================ 09 · SEITENSPEZIFISCH ========= */

/* HERO */
.hero{ background:#fff; border-bottom:3px solid var(--red); }
.hero__grid{ display:grid; grid-template-columns:1fr 1fr; min-height:520px; }
.hero__content{ padding:64px 48px 56px; display:flex; flex-direction:column; justify-content:center; gap:24px; }
.hero__content .container{ padding:0; }
.hero h1{ margin:0; }
.hero p{ max-width:460px; margin:0; }
.hero__ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-top:6px; }
.hero__media{ position:relative; }
.hero__media .ph{ position:absolute; inset:0; }

/* Page-Hero (Innenseiten, dunkel) */
.page-hero{ background:var(--ink); color:#fff; position:relative; overflow:hidden;
  padding:88px 0 72px; border-bottom:3px solid var(--red); }
.page-hero::after{ content:""; position:absolute; top:0; right:0; width:0; height:0; border-style:solid;
  border-width:0 160px 160px 0; border-color:transparent var(--red) transparent transparent; opacity:0.9; }
.page-hero h1{ color:#fff; max-width:760px; }
.page-hero .eyebrow{ margin-bottom:18px; }
.page-hero p{ color:var(--ink-soft); max-width:620px; font-size:18px; margin:18px 0 0; position:relative; }
.breadcrumb{ font-size:13px; color:var(--ink-soft2); margin-bottom:22px; position:relative; }
.breadcrumb a{ color:var(--ink-soft2); }
.breadcrumb a:hover{ color:#fff; }

/* Warum-Sektion mit Bild-Card + Stat-Badge */
.why-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:56px; align-items:center; }
.why-media{ position:relative; aspect-ratio:4/5; }
.why-media .stat-badge{
  position:absolute; bottom:24px; left:24px; right:24px; background:#fff;
  padding:18px 20px; display:flex; gap:16px; align-items:center;
}
.why-media .stat-badge b{ font-family:var(--f-head); font-weight:700; font-size:40px; color:var(--red); line-height:1; }
.why-media .stat-badge span{ font-size:14px; line-height:1.4; color:var(--ink); }

/* Leistungs-Detailblöcke */
.svc-block{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; padding:56px 0; border-top:1px solid var(--line); }
.svc-block:first-of-type{ border-top:none; }
.svc-block.is-reverse .svc-block__media{ order:2; }
.svc-block__media{ position:relative; aspect-ratio:4/3; }
.svc-block h2{ margin:14px 0 0; }
.svc-block ul{ list-style:none; margin:14px 0 22px; padding:0; display:flex; flex-direction:column; gap:10px; }
.svc-block ul li{ display:flex; gap:12px; align-items:flex-start; font-size:15px; color:var(--text-mid); }
.svc-block ul li::before{ content:""; width:9px; height:9px; background:var(--red); transform:rotate(45deg); flex:none; margin-top:7px; }

/* CTA-Sektion */
.cta-band{ background:var(--ink); color:#fff; position:relative; overflow:hidden; }
.cta-band::after{ content:""; position:absolute; bottom:0; left:0; width:0; height:0; border-style:solid;
  border-width:120px 0 0 120px; border-color:transparent transparent transparent var(--red); opacity:0.85; }
.cta-band .container{ display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap; position:relative; z-index:1; }
.cta-band h2{ color:#fff; }
.cta-band p{ color:var(--ink-soft); margin:10px 0 0; max-width:520px; }
.cta-band__actions{ display:flex; gap:14px; flex-wrap:wrap; }

/* Einsatzgebiet-Chips */
.area-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; }
.area-chip{ display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--gray-200); padding:16px 18px; }
.area-chip::before{ content:""; width:9px; height:9px; background:var(--red); transform:rotate(45deg); flex:none; }
.area-chip span{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.04em; font-weight:600; font-size:16px; color:var(--ink); }
.area-chip small{ display:block; font-family:var(--f-body); font-size:12px; text-transform:none; letter-spacing:0; color:var(--text-muted); font-weight:400; }

/* Referenz-Karten */
.ref-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.ref-card{ background:#fff; border:1px solid var(--gray-200); display:flex; flex-direction:column; }
.ref-card__media{ aspect-ratio:4/3; }
.ref-card__body{ padding:22px 22px 26px; display:flex; flex-direction:column; gap:8px; }
.ref-card__cat{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.1em; font-weight:600; font-size:12px; color:var(--red); }
.ref-card__title{ font-family:var(--f-head); text-transform:uppercase; font-weight:600; font-size:20px; line-height:1.12; color:var(--ink); }
.ref-card__text{ font-size:14px; line-height:1.55; color:var(--text-muted); }

/* Artikel (Blog-Detail) */
.article{ max-width:760px; margin:0 auto; }
.article__meta{ display:flex; gap:14px; align-items:center; margin-bottom:18px; flex-wrap:wrap; }
.article__cat{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.1em; font-weight:600; font-size:13px; color:var(--red); }
.article__date{ font-size:13px; color:var(--text-muted); }
.article__hero{ aspect-ratio:16/8; margin:0 0 40px; }
.article__body{ font-size:17px; line-height:1.75; color:var(--text-body); }
.article__body h2{ font-size:28px; margin:44px 0 16px; }
.article__body h3{ font-size:21px; margin:32px 0 12px; }
.article__body p{ margin:0 0 18px; }
.article__body ul,.article__body ol{ margin:0 0 18px; padding-left:22px; }
.article__body li{ margin-bottom:9px; }
.article__body a{ border-bottom:1px solid var(--red); }
.article__cta{ background:var(--gray-50); border-left:4px solid var(--red); padding:26px 28px; margin:36px 0; }
.article__cta h3{ margin-bottom:8px; }
.article__cta p{ color:var(--text-mid); font-size:15px; }

/* Info-Liste (Impressum/Datenschutz) */
.legal{ max-width:820px; }
.legal h2{ font-size:26px; margin:40px 0 14px; }
.legal h3{ font-size:18px; margin:26px 0 10px; }
.legal p{ margin:0 0 14px; color:var(--text-body); font-size:16px; }
.legal .todo{ background:#FFF4F5; border-left:4px solid var(--red); padding:14px 16px; font-size:14px; color:var(--text-mid); margin:0 0 16px; }
.legal .todo strong{ color:var(--red); }

/* ============================ 10 · FORMULAR ================= */
.contact-card{ display:grid; grid-template-columns:0.9fr 1.1fr; border:1px solid var(--gray-200); }
.contact-info{ background:var(--ink); color:#fff; padding:56px 44px; display:flex; flex-direction:column; gap:28px; position:relative; overflow:hidden; }
.contact-info::after{ content:""; position:absolute; top:0; right:0; width:0; height:0; border-style:solid;
  border-width:0 130px 130px 0; border-color:transparent var(--red) transparent transparent; }
.contact-info h2{ color:#fff; }
.contact-info p{ color:var(--ink-soft); margin:0; }
.contact-info .eyebrow{ position:relative; }
.contact-detail{ display:flex; gap:16px; align-items:flex-start; position:relative; }
.contact-detail .diamond{ margin-top:6px; }
.contact-detail__label{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.1em; font-weight:600; font-size:12px; color:var(--text-faint); }
.contact-detail__big{ font-family:var(--f-head); font-weight:600; font-size:24px; color:#fff; line-height:1.2; }
.contact-detail a{ color:#fff; }
.contact-detail__text{ font-size:16px; color:#fff; line-height:1.5; }

.contact-form{ background:#fff; padding:48px; display:flex; flex-direction:column; gap:20px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field label{ font-family:var(--f-cond); text-transform:uppercase; letter-spacing:0.08em; font-weight:600; font-size:13px; color:var(--ink); }
.field input,.field select,.field textarea{
  font-family:var(--f-body); font-size:15px; padding:13px 15px;
  border:1px solid var(--gray-200); border-radius:var(--radius); background:var(--gray-50); color:var(--ink); outline:none; width:100%;
}
.field textarea{ resize:vertical; min-height:120px; }
.field select{ appearance:none; cursor:pointer; }
.field input:focus,.field select:focus,.field textarea:focus{ border:2px solid var(--red); background:#fff; padding:12px 14px; }
.field--select{ position:relative; }
.field--select .chevron{ position:absolute; right:16px; bottom:15px; color:var(--red); pointer-events:none; font-size:12px; }
.field input[type=file]{ padding:10px 12px; background:#fff; }
.field .hint{ font-size:12px; color:var(--text-muted); }
.consent{ display:flex; gap:12px; align-items:flex-start; }
.consent input{ width:20px; height:20px; flex:none; margin-top:2px; accent-color:var(--red); }
.consent label{ font-family:var(--f-body); text-transform:none; letter-spacing:0; font-weight:400; font-size:13px; line-height:1.5; color:var(--text-muted); }
.consent label a{ color:var(--ink); text-decoration:underline; }
.honeypot{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-note{ font-size:13px; color:var(--text-muted); }
.req{ color:var(--red); }
/* Bestätigung / Fehler */
.form-alert{ padding:16px 18px; border-radius:var(--radius); font-size:15px; margin-bottom:8px; }
.form-alert--ok{ background:#EAF7EE; border-left:4px solid #1E8E47; color:#155E2E; }
.form-alert--err{ background:#FFF4F5; border-left:4px solid var(--red); color:#8A1020; }

/* ============================ 11 · UTILITIES ================= */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:40px; }
.prose{ max-width:760px; }
.prose p{ margin:0 0 18px; font-size:17px; line-height:1.75; }
.prose h2{ margin:40px 0 14px; }
.prose ul{ padding-left:22px; }
.prose li{ margin-bottom:9px; }
.skip-link{ position:absolute; left:-9999px; top:0; background:var(--red); color:#fff; padding:10px 16px; z-index:100; }
.skip-link:focus{ left:8px; top:8px; }

/* ============================ 12 · RESPONSIVE =============== */
@media (max-width:1024px){
  .cards-grid{ grid-template-columns:repeat(2,1fr); }
  .hero__grid{ grid-template-columns:1fr; }
  .hero__media{ min-height:300px; }
  .hero__content{ padding:48px 24px; }
  .why-grid{ grid-template-columns:1fr; gap:36px; }
  .why-media{ aspect-ratio:16/10; max-width:520px; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:860px){
  .nav, .header-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .site-header.is-open .nav{
    display:flex; position:absolute; left:0; right:0; top:100%;
    flex-direction:column; gap:0; background:#fff; border-bottom:3px solid var(--red);
    box-shadow:var(--shadow-lift); padding:6px 0;
  }
  .site-header.is-open .nav a{
    padding:13px 24px; border-bottom:none; border-left:3px solid transparent; font-size:17px;
  }
  .site-header.is-open .nav a.is-active{ border-left-color:var(--red); background:var(--gray-50); }
  .site-header.is-open .header-cta{ display:flex; padding:14px 24px 18px; }
  .site-header.is-open .header-cta .btn{ width:100%; }
  .main-bar{ position:relative; }
  .steps{ grid-template-columns:1fr; gap:0; }
  .steps::before{ display:none; }
  .step{ flex-direction:row; align-items:flex-start; gap:16px; padding:0 0 22px; position:relative; }
  .step:not(:last-child)::after{ content:""; position:absolute; left:23px; top:48px; bottom:0; width:2px; background:var(--gray-200); }
  .step__num{ flex:none; }
  .step__body{ display:flex; flex-direction:column; gap:6px; }
  .svc-block{ grid-template-columns:1fr; gap:28px; }
  .svc-block.is-reverse .svc-block__media{ order:0; }
  .svc-block__media{ aspect-ratio:16/10; }
  .contact-card{ grid-template-columns:1fr; }
  .grid-2{ grid-template-columns:1fr; gap:28px; }
}
@media (max-width:560px){
  .cards-grid{ grid-template-columns:1fr 1fr; gap:12px; }
  .blog-grid,.ref-grid{ grid-template-columns:1fr; }
  .benefits-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .section{ padding:56px 0; }
  .contact-form,.contact-info{ padding:32px 22px; }
  .form-row{ grid-template-columns:1fr; }
  .cta-band .container{ flex-direction:column; align-items:flex-start; }
  .hero__content{ padding:36px 22px; }
  .utility-bar__left{ font-size:12px; gap:10px; }
}
@media (max-width:380px){
  .cards-grid{ grid-template-columns:1fr; }
}
