/* ============================================================
   pages.css — Premium-Feinschliff für die Unterseiten
   Lädt NACH styles.css und nutzt dessen globale Design-Tokens.
   Bewusst isoliert gehalten (parallele Arbeit an styles.css);
   kann später in styles.css zusammengeführt werden.
   ============================================================ */

/* ---- Typografie: ruhigere Absätze, weniger Schusterjungen ---- */
.page-hero .lead,
main .section-head p,
main .info-card p,
.about-intro p,
.b-item p,
.legal p,
.legal li,
.contact-info p { text-wrap: pretty; }

/* ---- about-intro-Heading: eigene Größe (kein styles.css-Pendant) ---- */
.about-intro > h2 {
  font-size: clamp(2rem, 3.6vw, 2.9rem);
  line-height: 1.02;
  letter-spacing: -0.01em;
  margin: 0 0 18px;
}

/* ============================================================
   Kontakt — Vertrauens-/Reassurance-Streifen über dem Formular
   (CRO: senkt Hemmschwelle, hebt die Antwort-Erwartung)
   ============================================================ */
.contact-grid > .contact-trust { grid-column: 1 / -1; }
.contact-trust {
  list-style: none;
  margin: 0 0 4px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.contact-trust li {
  position: relative;
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 13px 15px;
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0)) padding-box,
    var(--steel-soft, #1c1a1d);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 12px 26px -16px rgba(0, 0, 0, 0.8);
}
.contact-trust .ct-ic {
  flex: none;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  border: 1px solid rgba(226, 0, 26, 0.5);
  background: radial-gradient(120% 120% at 30% 22%, rgba(226, 0, 26, 0.24), rgba(0, 0, 0, 0.45));
  box-shadow: 0 0 0 4px rgba(226, 0, 26, 0.05), 0 8px 18px -8px rgba(226, 0, 26, 0.6);
}
.contact-trust .ct-ic svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: var(--red-bright, #ff2630);
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.contact-trust .ct-txt { display: flex; flex-direction: column; line-height: 1.15; min-width: 0; }
.contact-trust .ct-k {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.96rem;
  color: var(--ink, #f4f1f4);
}
.contact-trust .ct-s {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--ink-mute, #a39ea6);
  margin-top: 3px;
}
@media (max-width: 720px) {
  .contact-trust { grid-template-columns: 1fr; gap: 10px; }
}

/* ============================================================
   Kontakt — Interaktiver 3D-Hero (Pondruff-Medaillon, Three.js)
   Split-Layout: Copy links, 3D-Stage rechts. Fallback = Logo.
   ============================================================ */
/* Split-Hero nutzt die volle Breite (statt der schmalen 820px-Textspalte) */
.k3d-hero .inner { max-width: var(--maxw, 1200px); }
.k3d-grid {
  display: grid;
  grid-template-columns: 1.02fr 0.98fr;
  align-items: center;
  gap: clamp(24px, 5vw, 56px);
}
.k3d-copy { min-width: 0; }
/* Headline an die schmalere Split-Spalte anpassen (kein Wortbruch) */
.k3d-hero .k3d-copy h1 { font-size: clamp(2.1rem, 3.7vw, 3.5rem); line-height: 1.0; }
.k3d-hero .k3d-copy .lead { max-width: 46ch; }
.k3d-copy .hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }

/* Stage */
.k3d-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-height: 600px;
  display: grid;
  place-items: center;
  isolation: isolate;
}
.k3d-spotlight {
  position: absolute;
  inset: -8%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(42% 42% at 60% 38%, rgba(226, 0, 26, 0.4), rgba(226, 0, 26, 0) 70%),
    radial-gradient(70% 70% at 50% 50%, rgba(255, 90, 97, 0.12), transparent 72%);
  filter: blur(8px);
  animation: k3dGlow 7s ease-in-out infinite;
}
@keyframes k3dGlow {
  0%, 100% { opacity: 0.8; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.06); }
}
/* Maskottchen-Stage: Perspektive für den maus-reaktiven Tilt */
.k3d-mascot-stage { perspective: 1000px; }
.k3d-mascot-wrap {
  position: relative;
  z-index: 2;
  width: min(108%, 560px);
  transform-style: preserve-3d;
  animation: k3dFloat 6s ease-in-out infinite;
  will-change: transform;
}
/* Wrapper schwebt (nur translate); das Bild kippt (rotate) → kein Konflikt */
@keyframes k3dFloat {
  0%, 100% { transform: translateY(-11px); }
  50% { transform: translateY(11px); }
}
.k3d-mascot {
  display: block;
  width: 100%;
  height: auto;
  transform: rotateX(0deg) rotateY(0deg);
  transition: transform 0.2s var(--ease-out, ease-out);
  filter: drop-shadow(0 40px 48px rgba(0, 0, 0, 0.6)) drop-shadow(0 0 42px rgba(226, 0, 26, 0.3));
  will-change: transform;
  -webkit-user-select: none;
  user-select: none;
}

@media (max-width: 900px) {
  .k3d-grid { grid-template-columns: 1fr; gap: 8px; }
  .k3d-stage { order: -1; aspect-ratio: 4 / 3; max-height: 380px; margin-bottom: 6px; }
  .k3d-mascot-wrap { width: min(74%, 320px); }
}
@media (prefers-reduced-motion: reduce) {
  .k3d-spotlight, .k3d-mascot-wrap { animation: none; }
  .k3d-mascot { transition: none; }
}

/* ============================================================
   Über uns — WebGL2-Shader-Hero (rotes Energie-/Nebelfeld)
   + eingeblendetes Pondruff-Logo. Fallback: .hero-bg-Gradient.
   ============================================================ */
.shader-hero {
  position: relative;
  overflow: hidden;
  min-height: clamp(580px, 86vh, 820px);
  display: grid;
  place-items: center;
  padding-top: clamp(96px, 13vh, 136px);
  padding-bottom: clamp(48px, 8vh, 92px);
}
.shader-hero .hero-bg { z-index: 0; }
.shader-hero .hero-grid { z-index: 1; opacity: 0.5; }
.shader-bg {
  position: absolute; inset: 0; width: 100%; height: 100%;
  display: block; opacity: 0;
  transition: opacity 1.1s var(--ease-out, ease);
}
.shader-hero .shader-bg { z-index: 2; }
.shader-ready .shader-bg { opacity: 1; } /* generisch (Host bekommt .shader-ready) */
.shader-hero .shader-veil {
  position: absolute; inset: 0; z-index: 3; pointer-events: none;
  background:
    /* dunkle Lese-Zone hinter Headline + Lead (untere Mitte) */
    radial-gradient(72% 56% at 50% 66%, rgba(5,5,7,0.82), rgba(5,5,7,0.34) 68%, transparent 100%),
    radial-gradient(120% 80% at 50% 18%, transparent, rgba(5,5,7,0.34) 75%),
    linear-gradient(180deg, rgba(5,5,7,0.5) 0%, rgba(5,5,7,0.22) 24%, rgba(5,5,7,0.5) 62%, rgba(5,5,7,0.95) 100%);
}
/* Spiral-Galaxie-Hero (Über uns): Veil im Zentrum lockern, damit das
   additive Partikel-Glühen rund um Logo + Headline durchscheint
   (Headline trägt eigenen Text-Shadow → bleibt lesbar). */
.spiral-hero .shader-veil {
  background:
    radial-gradient(58% 46% at 50% 70%, rgba(5,5,7,0.66), rgba(5,5,7,0.22) 70%, transparent 100%),
    radial-gradient(130% 86% at 50% 14%, transparent, rgba(5,5,7,0.28) 78%),
    linear-gradient(180deg, rgba(5,5,7,0.32) 0%, rgba(5,5,7,0.06) 26%, rgba(5,5,7,0.4) 64%, rgba(5,5,7,0.96) 100%);
}

.shader-crumb {
  position: absolute; top: clamp(84px, 11vh, 118px); left: 0; right: 0;
  z-index: 5; justify-content: center; margin: 0;
  animation: shFade 1s var(--ease-out, ease) 0.1s both;
}
/* .page-hero .inner setzt z-index:2 (höhere Spezifität) → hier überstimmen,
   damit der Veil (z3) NICHT über dem Text liegt */
.shader-hero .shader-inner {
  position: relative; z-index: 6; text-align: center;
  display: flex; flex-direction: column; align-items: center;
  max-width: 920px;
}
.shader-inner .eyebrow { justify-content: center; animation: shUp 0.8s var(--ease-out, ease) 0.28s both; }
.shader-inner h1 {
  color: #fff;
  text-shadow: 0 2px 26px rgba(5,5,7,0.85), 0 0 6px rgba(5,5,7,0.5);
  animation: shUp 0.85s var(--ease-out, ease) 0.42s both;
}
.shader-inner h1 .accent { text-shadow: 0 0 22px rgba(226,0,26,0.65), 0 2px 18px rgba(5,5,7,0.7); }
.shader-inner .lead {
  max-width: 62ch; margin-inline: auto; color: var(--ink, #f0edf0);
  text-shadow: 0 1px 16px rgba(5,5,7,0.85);
  animation: shUp 0.85s var(--ease-out, ease) 0.56s both;
}

.hero-logo {
  width: clamp(120px, 15vw, 190px); height: auto; margin-bottom: 24px;
  filter: drop-shadow(0 16px 30px rgba(0,0,0,0.6)) drop-shadow(0 0 32px rgba(226,0,26,0.45));
  animation: shFade 0.9s var(--ease-out, ease) both, heroLogoFloat 6.5s ease-in-out 0.9s infinite;
}
@keyframes shFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes shUp { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: none; } }
@keyframes heroLogoFloat { 0%, 100% { transform: translateY(-7px); } 50% { transform: translateY(7px); } }

@media (max-width: 600px) {
  .shader-hero { min-height: clamp(520px, 82vh, 680px); }
  .hero-logo { margin-bottom: 18px; }
}
@media (prefers-reduced-motion: reduce) {
  .shader-bg { display: none; }
  .hero-logo, .shader-inner .eyebrow, .shader-inner h1, .shader-inner .lead, .shader-crumb { animation: none; opacity: 1; transform: none; }
}

/* ============================================================
   Shader-Background-Modus (.shaderbg) — Shader hinter bestehendem,
   linksbündigem Hero-Inhalt (Dienstleistungen, Schichtportfolio).
   ============================================================ */
.shaderbg { position: relative; overflow: hidden; }
.shaderbg .hero-bg, .shaderbg .hero-grid, .shaderbg .shader-bg { z-index: 0; }
.shaderbg .hero-grid { opacity: 0.35; }
.shaderbg .shader-veil {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(90deg, rgba(5,5,7,0.84) 0%, rgba(5,5,7,0.52) 40%, rgba(5,5,7,0.14) 72%, transparent 100%),
    linear-gradient(180deg, rgba(5,5,7,0.42) 0%, rgba(5,5,7,0.12) 28%, rgba(5,5,7,0.5) 100%);
}
.shaderbg .inner { position: relative; z-index: 2; }
@media (prefers-reduced-motion: reduce) { .shaderbg .shader-bg { display: none; } }

/* ============================================================
   Schichtportfolio-Hero — Headline links, Video oben rechts (Ecke),
   Ring-Shader im Hintergrund.
   ============================================================ */
.portfolio-hero .inner.pf-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: clamp(22px, 4vw, 60px);
  max-width: var(--maxw, 1200px);
}
.pf-copy { min-width: 0; }
.portfolio-hero .pf-copy h1 { font-size: clamp(1.85rem, 3.3vw, 3rem); line-height: 1.04; }
.portfolio-hero .pf-copy .lead { max-width: 56ch; }

.pf-video {
  position: relative; margin: 0; flex: none;
  width: clamp(188px, 23vw, 290px);
  aspect-ratio: 9 / 16;
  border-radius: 20px; overflow: hidden;
  background: #0b0a0c;
  box-shadow:
    0 36px 70px -24px rgba(0, 0, 0, 0.85),
    0 0 0 1px rgba(255, 255, 255, 0.08),
    0 0 46px -10px rgba(226, 0, 26, 0.5);
  animation: k3dFloat 7s ease-in-out infinite;
}
.pf-video video {
  width: 100%; height: 100%; object-fit: cover; display: block;
  filter: saturate(1.02) contrast(1.04);
}
/* roter Leucht-Rahmen */
.pf-video-ring {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  border-radius: 20px; border: 1px solid rgba(226, 0, 26, 0.5);
  box-shadow: inset 0 0 30px -6px rgba(226, 0, 26, 0.5);
}
.pf-video figcaption {
  position: absolute; z-index: 3; left: 0; right: 0; bottom: 0;
  display: flex; align-items: center; gap: 8px;
  padding: 26px 14px 12px;
  font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: #fff;
  background: linear-gradient(180deg, transparent, rgba(5, 5, 7, 0.88));
}
.pf-video .pf-dot {
  width: 7px; height: 7px; border-radius: 50%; flex: none;
  background: var(--red-bright, #ff2630);
  box-shadow: 0 0 10px 1px rgba(255, 38, 48, 0.9);
  animation: pfPulse 1.8s ease-in-out infinite;
}
@keyframes pfPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.35; } }

@media (max-width: 820px) {
  .portfolio-hero .inner.pf-grid { grid-template-columns: 1fr; gap: 14px; justify-items: start; }
  .pf-video { width: min(52%, 220px); align-self: center; }
}
@media (prefers-reduced-motion: reduce) {
  .pf-video, .pf-video .pf-dot { animation: none; }
}

/* ============================================================
   Dienstleistungen-Hero — Plasma-Shader, Chrom-Headline,
   Video rechts mit Ton-Schalter.
   ============================================================ */
/* .page-hero .inner cappt auf 820px (höhere Spezifität) → hier überstimmen,
   damit die Copy-Spalte breit genug für eine einzeilige Headline ist */
.page-hero .inner.dl-grid { max-width: var(--maxw, 1200px); }
.dl-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) auto;
  align-items: center;
  gap: clamp(22px, 4vw, 60px);
}
.dl-copy { min-width: 0; }
.dl-copy .chrome-head { font-size: clamp(2.2rem, 4.2vw, 3.6rem); line-height: 1.0; }

/* Chrom-/Silber-Headline mit kinoreifem Reveal (on-brand Chrom-Look) */
.chrome-head {
  background: linear-gradient(180deg, #ffffff 0%, #dfe2e7 40%, #9ba1a9 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.6)) drop-shadow(0 2px 4px rgba(0, 0, 0, 0.5));
  transform: translateZ(0);
  animation: chromeIn 1.05s var(--ease-out, ease) both;
}
@keyframes chromeIn {
  from { opacity: 0; transform: translateY(26px) scale(0.965); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ============================================================
   Über uns – Video im bestehenden .media-Rahmen (PVD-Anlage),
   füllt die Spalte (Hochformat-Video, object-fit cover) + Ton-Schalter.
   ============================================================ */
.media-video video {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; display: block;
  filter: saturate(1.06) contrast(1.05) brightness(0.96);
}
.media-video .pf-video-ring { border-radius: var(--radius); }
/* roter Soft-Light-Hauch, damit das Video zum Carbon/Rot-Look passt */
.media-video::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  border-radius: var(--radius); mix-blend-mode: soft-light;
  background: linear-gradient(150deg, rgba(226, 0, 26, 0.26), transparent 56%, rgba(120, 10, 16, 0.26));
}
/* Ton-Schalter oben rechts (unten sitzt die Bildunterschrift) */
.media-video .dl-sound { top: 12px; right: 12px; bottom: auto; }
.media-video .cap { z-index: 3; }

/* Video-Panel (erbt .pf-video) – farblich an Pondruff angepasst */
.dl-video { align-self: center; }
.dl-video video { filter: saturate(1.06) contrast(1.05) brightness(0.94); }
.dl-video::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  border-radius: 20px; mix-blend-mode: soft-light;
  background: linear-gradient(150deg, rgba(226, 0, 26, 0.32), transparent 55%, rgba(120, 10, 16, 0.3));
}

/* Ton-Schalter */
.dl-sound {
  position: absolute; z-index: 4; right: 10px; bottom: 10px;
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 12px 8px 10px; border-radius: 999px; cursor: pointer;
  font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: #fff;
  background: rgba(10, 9, 11, 0.66); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 8px 20px -8px rgba(0, 0, 0, 0.8);
  transition: background 0.3s var(--ease-out, ease), border-color 0.3s var(--ease-out, ease), transform 0.3s var(--ease-out, ease);
}
.dl-sound:hover { transform: translateY(-2px); border-color: rgba(226, 0, 26, 0.6); background: rgba(20, 8, 10, 0.78); }
.dl-sound svg { width: 16px; height: 16px; flex: none; }
.dl-sound .ic-on { display: none; }
.dl-sound.is-on { border-color: rgba(226, 0, 26, 0.7); background: rgba(40, 8, 10, 0.8); }
.dl-sound.is-on .ic-on { display: block; color: var(--red-bright, #ff2630); }
.dl-sound.is-on .ic-off { display: none; }

@media (max-width: 880px) {
  .dl-grid { grid-template-columns: 1fr; gap: 16px; }
  .dl-video { order: 2; justify-self: center; width: min(58%, 240px); }
}
@media (prefers-reduced-motion: reduce) {
  .chrome-head { animation: none; }
}

/* ============================================================
   Verfahrens-Detailseiten (Microstrahlen / Läppstrahlen / Polierstrahlen)
   – nutzen die globalen Tokens & Komponenten (page-hero, info-card,
   chips, statbox, cta-band) + diese kleinen Ergänzungen.
   ============================================================ */
.proc-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: clamp(18px, 3vw, 28px); align-items: start; }
@media (max-width: 900px) { .proc-grid { grid-template-columns: 1fr; } }
.proc-aside { display: grid; gap: 14px; position: sticky; top: 96px; }
@media (max-width: 900px) { .proc-aside { position: static; } }

/* Inhalts-Untertitel innerhalb der info-card */
.proc-sub { font-family: var(--font-display); font-weight: 700; font-size: 1.16rem;
  color: var(--ink); margin: 0 0 4px; display: flex; align-items: center; gap: 10px; }
.proc-sub svg { width: 18px; height: 18px; stroke: var(--red-bright, #ff2630); fill: none; flex: none; }
.proc-divider { height: 1px; margin: 22px 0; background: linear-gradient(90deg, transparent, rgba(226,0,26,0.32), transparent); }

/* „Perfekt geeignet für" – Liste mit roten Markern */
.spec-list { list-style: none; padding: 0; margin: 14px 0 0; display: grid; gap: 10px; }
.spec-list li { position: relative; padding: 13px 16px 13px 48px;
  border: 1px solid var(--hair); border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.02); color: var(--ink-soft); font-size: 1.0rem; line-height: 1.5; }
.spec-list li strong { color: var(--ink); font-weight: 600; }
.spec-list li::before { content: ""; position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
  width: 16px; height: 16px; border-radius: 5px;
  background: linear-gradient(135deg, var(--red-bright, #ff2630), var(--red, #e2001a));
  box-shadow: 0 0 16px -2px rgba(226,0,26,0.7); }

/* Callout-Box (z. B. max. Bauteilgröße) */
.callout { padding: 18px 20px; border-radius: var(--radius-sm);
  border: 1px solid rgba(226,0,26,0.42);
  background: linear-gradient(135deg, rgba(226,0,26,0.14), rgba(255,255,255,0.02));
  box-shadow: 0 18px 40px -22px rgba(0,0,0,0.8); }
.callout .callout-lbl { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono);
  font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px; }
.callout .callout-lbl svg { width: 15px; height: 15px; stroke: var(--red-bright, #ff2630); fill: none; }
.callout .callout-val { font-family: var(--font-display); font-weight: 700; font-size: 1.22rem; color: var(--ink); line-height: 1.2; }
.callout .callout-val .accent { color: var(--red-bright, #ff2630); }

/* Prozess-Bild (Läppstrahlen) */
.proc-figure { margin: 0; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--hair);
  box-shadow: 0 30px 60px -28px rgba(0,0,0,0.85), 0 0 40px -14px rgba(226,0,26,0.4); background: #0b0a0c; }
.proc-figure img { width: 100%; height: auto; display: block; filter: saturate(1.04) contrast(1.04); }

/* ============================================================
   Über uns – orchestrierter Intro-Auftritt über der Spiral-Galaxie.
   Reihenfolge ("nach und nach"): zuerst nur die Partikel der Spirale,
   dann bildet sich das Logo aus dem Partikelnebel heraus (Blur→scharf,
   "Coalesce"), danach gestaffelt Eyebrow → Headline → Lead → Brotkrume.
   Überschreibt die generischen .shader-hero-Timings (höhere Spezifität).
   ============================================================ */
/* Logo "formt sich" aus dem Partikelnebel: unscharf+dunkel → scharf.
   Nur opacity/filter animiert → kein Transform-Konflikt mit heroLogoFloat.
   Die Drop-Shadows bleiben im 100%-Keyframe erhalten (sonst gingen sie verloren). */
.spiral-hero .hero-logo {
  /* Partikel laufen ~1.15 s allein, dann blendet das Logo ein, danach sanftes Schweben.
     Reine Opacity-Einblendung (WebView-sicher): gestapelte blur()/brightness()-Filter auf dem
     transparenten Logo-PNG führten in In-App-Browsern (z. B. WhatsApp) zu einem weißen Kasten.
     Der rote Glow (drop-shadow) bleibt über die Basisregel .hero-logo erhalten. */
  animation:
    shFade 1.0s var(--ease-out, ease) 1.15s both,
    heroLogoFloat 6.5s ease-in-out 2.5s infinite;
}
.spiral-hero .shader-inner .eyebrow { animation: shUp 0.8s var(--ease-out, ease) 2.25s both; }
.spiral-hero .shader-inner h1       { animation: shUp 0.85s var(--ease-out, ease) 2.55s both; }
.spiral-hero .shader-inner .lead    { animation: shUp 0.9s var(--ease-out, ease) 2.85s both; }
.spiral-hero .shader-crumb          { animation: shFade 1s var(--ease-out, ease) 3.05s both; }

@media (prefers-reduced-motion: reduce) {
  .spiral-hero .hero-logo {
    animation: none; opacity: 1; transform: none;
    filter: drop-shadow(0 16px 30px rgba(0,0,0,0.6)) drop-shadow(0 0 32px rgba(226,0,26,0.45));
  }
  .spiral-hero .shader-inner .eyebrow,
  .spiral-hero .shader-inner h1,
  .spiral-hero .shader-inner .lead,
  .spiral-hero .shader-crumb { animation: none; opacity: 1; transform: none; }
}

/* ============================================================
   Kontakt – Cinematic-Veredelung (adaptiert aus einer React/GSAP-
   "CinematicHero"-Vorlage, auf Pondruff Carbon/Rot umgesetzt; KEIN
   iPhone-/App-Store-Showcase). Bringt: Film-Grain + maskiertes Grid,
   Premium-Depth-Card mit maus-getracktem Licht (Sheen), schwebende
   Glas-Badges, cinematischer Blur→Scharf-Auftritt der Hero-Copy.
   ============================================================ */
/* Film-Grain-Atmosphäre über dem Hero */
.cine-grain {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  opacity: 0.055; mix-blend-mode: overlay;
  background: url('data:image/svg+xml;utf8,<svg viewBox="0 0 200 200" xmlns="http://www.w3.org/2000/svg"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.82" numOctaves="3" stitchTiles="stitch"/></filter><rect width="100%" height="100%" filter="url(%23n)"/></svg>');
}
/* Grid mit radialer Maske (Fokus zur Mitte) – wie in der Vorlage */
.cine-hero .hero-grid {
  -webkit-mask-image: radial-gradient(ellipse at center, #000 0%, transparent 72%);
  mask-image: radial-gradient(ellipse at center, #000 0%, transparent 72%);
  opacity: 0.6;
}

/* Cinematischer Auftritt der Hero-Copy (Blur→scharf, gestaffelt) */
@keyframes cineRise {
  0%   { opacity: 0; transform: translateY(42px) scale(0.965); filter: blur(16px); }
  100% { opacity: 1; transform: none; filter: blur(0); }
}
.cine-hero .k3d-copy .breadcrumb   { animation: cineRise 0.8s var(--ease-out, ease) 0.05s both; }
.cine-hero .k3d-copy .eyebrow      { animation: cineRise 1s var(--ease-out, ease) 0.18s both; }
.cine-hero .k3d-copy h1            { animation: cineRise 1.15s var(--ease-out, ease) 0.32s both; }
.cine-hero .k3d-copy .lead         { animation: cineRise 1.1s var(--ease-out, ease) 0.52s both; }
.cine-hero .k3d-copy .hero-actions { animation: cineRise 1s var(--ease-out, ease) 0.72s both; }

/* Premium-Depth-Card: das Anfrageformular bekommt physische Tiefe +
   maus-getracktes Licht (Sheen). Basis-Hintergrund/Border bleiben,
   wir legen Tiefe (Schatten, Metallkante) + Sheen-Layer darüber. */
.cine-card { position: relative; overflow: hidden; isolation: isolate;
  box-shadow:
    0 44px 100px -28px rgba(0,0,0,0.92),
    0 22px 44px -26px rgba(0,0,0,0.85),
    inset 0 1px 1px rgba(255,255,255,0.10),
    inset 0 -2px 6px rgba(0,0,0,0.65);
}
.cine-card::before { /* roter Top-Glow, dezent */
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none; border-radius: inherit;
  background: radial-gradient(120% 60% at 50% -8%, rgba(226,0,26,0.12), transparent 58%);
}
.cine-card .card-sheen {
  position: absolute; inset: 0; z-index: 0; pointer-events: none; border-radius: inherit;
  background: radial-gradient(560px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
    rgba(255,255,255,0.075), rgba(226,0,26,0.05) 26%, transparent 46%);
  mix-blend-mode: screen; opacity: 0; transition: opacity 0.4s var(--ease-out, ease);
}
.cine-card:hover .card-sheen { opacity: 1; }
.cine-card > form { position: relative; z-index: 1; }

/* Schwebende Glas-Badges um die Maskottchen-Stage */
.k3d-stage .cine-badge {
  position: absolute; z-index: 4; display: flex; align-items: center; gap: 12px;
  padding: 11px 15px 11px 12px; border-radius: 16px; max-width: 70%;
  background: linear-gradient(135deg, rgba(255,255,255,0.09) 0%, rgba(255,255,255,0.012) 100%);
  -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.10),
    0 26px 50px -14px rgba(0,0,0,0.85),
    inset 0 1px 1px rgba(255,255,255,0.22),
    inset 0 -1px 1px rgba(0,0,0,0.5);
  opacity: 0; will-change: transform;
}
.cine-badge .cb-ic { flex: none; width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center;
  border: 1px solid rgba(226,0,26,0.45);
  background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.26), rgba(0,0,0,0.5));
  box-shadow: 0 0 0 4px rgba(226,0,26,0.05), inset 0 1px 1px rgba(255,255,255,0.18); }
.cine-badge .cb-ic svg { width: 18px; height: 18px; fill: none; stroke: var(--red-bright, #ff2630); stroke-width: 1.9; stroke-linecap: round; stroke-linejoin: round; }
.cine-badge .cb-dot { flex: none; width: 9px; height: 9px; border-radius: 50%; background: #28d07a;
  box-shadow: 0 0 10px 1px rgba(40,208,122,0.9); animation: cbPulse 1.8s ease-in-out infinite; }
.cine-badge .cb-txt { display: flex; flex-direction: column; line-height: 1.16; min-width: 0; }
.cine-badge .cb-k { font-family: var(--font-display); font-weight: 700; font-size: 0.98rem; color: #fff; letter-spacing: 0.01em; }
.cine-badge .cb-s { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-mute, #a39ea6); margin-top: 3px; }
@keyframes cbPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.35; } }
@keyframes cineBadgeIn { 0% { opacity: 0; transform: translateY(28px) scale(0.8); } 100% { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes cineBadgeFloat { 0%, 100% { transform: translateY(-7px); } 50% { transform: translateY(7px); } }
.cine-badge--tl { top: 2%; left: -6%; animation: cineBadgeIn 0.9s var(--ease-out, ease) 0.9s both, cineBadgeFloat 6.2s ease-in-out 1.8s infinite; }
.cine-badge--br { bottom: -1%; right: -6%; animation: cineBadgeIn 0.9s var(--ease-out, ease) 1.15s both, cineBadgeFloat 6.8s ease-in-out 2.1s infinite; }

@media (max-width: 900px) {
  .k3d-stage .cine-badge { max-width: 60%; padding: 9px 12px 9px 10px; }
  .cine-badge--tl { top: 2%; left: 2%; }
  .cine-badge--br { bottom: 4%; right: 2%; }
  .cine-badge .cb-ic { width: 32px; height: 32px; }
  .cine-badge .cb-k { font-size: 0.86rem; }
}
@media (prefers-reduced-motion: reduce) {
  .cine-hero .k3d-copy .breadcrumb, .cine-hero .k3d-copy .eyebrow, .cine-hero .k3d-copy h1,
  .cine-hero .k3d-copy .lead, .cine-hero .k3d-copy .hero-actions { animation: none; opacity: 1; transform: none; filter: none; }
  .k3d-stage .cine-badge { animation: none; opacity: 1; }
  .cine-badge .cb-dot { animation: none; }
}

/* ============================================================
   Schicht-Portfolio — Finder, Kennzahlen, Vergleich & Modal
   ============================================================ */

/* ---- Finder / Filterleiste ---- */
.pf-finder {
  display: flex; flex-direction: column; gap: 18px;
  padding: 22px; margin-bottom: 30px;
  border: 1px solid var(--hair); border-radius: var(--radius);
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
}
.pf-finder-row { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; justify-content: space-between; }
.pf-finder-group { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.pf-finder-label {
  font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--chrome-lo); margin-right: 4px;
}
.pf-pill {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.04em;
  color: var(--ink-soft); padding: 8px 14px; border-radius: 999px; cursor: pointer;
  background: rgba(255,255,255,0.03); border: 1px solid var(--hair);
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.pf-pill:hover { color: var(--ink); border-color: var(--hair-strong); }
.pf-pill.is-active {
  color: #fff; border-color: rgba(225,30,39,0.55);
  background: linear-gradient(135deg, var(--red-bright), var(--red));
}
.pf-search { position: relative; flex: 1 1 220px; max-width: 320px; }
.pf-search input {
  width: 100%; font-family: var(--font-body); font-size: 0.9rem; color: var(--ink);
  padding: 11px 14px 11px 38px; border-radius: var(--radius-sm);
  background: rgba(0,0,0,0.35); border: 1px solid var(--hair);
}
.pf-search input:focus { outline: none; border-color: rgba(225,30,39,0.5); }
.pf-search svg { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); width: 16px; height: 16px; stroke: var(--chrome-lo); fill: none; }
.pf-count { font-family: var(--font-mono); font-size: 0.72rem; color: var(--chrome-lo); }
.pf-empty {
  text-align: center; padding: 50px 20px; color: var(--ink-mute);
  border: 1px dashed var(--hair); border-radius: var(--radius);
}

/* ---- Karten-Erweiterung: Kennzahlen + Footer ---- */
.coat-card.is-hidden { display: none; }
.coat-card .pf-detail-trigger { cursor: pointer; }
.coat-card .img.pf-detail-trigger::after {
  content: "Details ansehen"; position: absolute; inset: auto 0 0 0; z-index: 2;
  font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase;
  text-align: center; padding: 9px; color: #fff;
  background: linear-gradient(0deg, rgba(8,8,10,0.9), transparent);
  opacity: 0; transform: translateY(6px); transition: opacity .3s var(--ease), transform .3s var(--ease);
}
.coat-card:hover .img.pf-detail-trigger::after { opacity: 1; transform: translateY(0); }
.coat-card h3.pf-detail-trigger:hover { color: var(--red-bright); }

.pf-kpis {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  padding: 12px 0; margin: 2px 0; border-block: 1px solid var(--hair);
}
.pf-kpi { display: flex; flex-direction: column; gap: 2px; }
.pf-kpi .k {
  font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--chrome-lo);
}
.pf-kpi .v {
  font-family: var(--font-display); font-weight: 700; font-size: 1.02rem;
  color: var(--ink); line-height: 1.1; font-variant-numeric: tabular-nums;
}
.coat-card .pf-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: auto;
}
.pf-compare {
  display: inline-flex; align-items: center; gap: 7px; cursor: pointer;
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.04em; color: var(--ink-mute);
  user-select: none;
}
.pf-compare:hover { color: var(--ink-soft); }
.pf-compare input { accent-color: var(--red); width: 15px; height: 15px; cursor: pointer; }
.coat-card .pf-foot .actions { margin-top: 0; flex: 1; }

/* ---- Vergleichs-Leiste (sticky) ---- */
.pf-comparebar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
  transform: translateY(120%); transition: transform .4s var(--ease-out);
  background: rgba(13,12,14,0.92); backdrop-filter: blur(14px);
  border-top: 1px solid var(--hair-strong); box-shadow: 0 -20px 50px -25px rgba(0,0,0,0.9);
}
.pf-comparebar.is-visible { transform: translateY(0); }
.pf-comparebar .inner {
  max-width: var(--maxw); margin: 0 auto; padding: 14px 24px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.pf-comparebar .pf-cb-label {
  font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--chrome-lo);
}
.pf-comparechips { display: flex; flex-wrap: wrap; gap: 8px; flex: 1; }
.pf-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 0.72rem; color: var(--ink);
  padding: 6px 6px 6px 12px; border-radius: 999px;
  background: rgba(255,255,255,0.05); border: 1px solid var(--hair);
}
.pf-chip button {
  width: 18px; height: 18px; border-radius: 50%; border: none; cursor: pointer;
  background: rgba(255,255,255,0.08); color: var(--ink-soft); font-size: 0.85rem; line-height: 1;
}
.pf-chip button:hover { background: var(--red); color: #fff; }
#pf-compare-open:disabled { opacity: 0.4; cursor: not-allowed; }

/* ---- Modal ---- */
.pf-modal { position: fixed; inset: 0; z-index: 120; display: none; }
.pf-modal.is-open { display: block; }
.pf-modal-scrim { position: absolute; inset: 0; background: rgba(6,6,8,0.78); backdrop-filter: blur(6px); }
.pf-modal-panel {
  position: relative; z-index: 1; max-width: 880px; width: calc(100% - 40px);
  max-height: calc(100vh - 60px); margin: 30px auto; overflow: auto;
  border: 1px solid var(--hair-strong); border-radius: var(--radius);
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
  box-shadow: var(--shadow);
  animation: pfModalIn .35s var(--ease-out);
}
@keyframes pfModalIn { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
.pf-modal-close {
  position: sticky; top: 0; float: right; margin: 14px 14px 0; z-index: 3;
  width: 38px; height: 38px; border-radius: 50%; cursor: pointer;
  background: rgba(255,255,255,0.06); border: 1px solid var(--hair); color: var(--ink); font-size: 1.2rem; line-height: 1;
}
.pf-modal-close:hover { background: var(--red); color: #fff; border-color: var(--red); }
.pf-modal-body { padding: 14px 34px 36px; }

.pf-detail-head { display: flex; gap: 24px; align-items: flex-start; padding-top: 8px; }
.pf-detail-thumb {
  position: relative; flex: none; width: 200px; height: 150px; border-radius: var(--radius-sm);
  display: grid; place-items: center; overflow: hidden; border: 1px solid var(--hair);
  background: radial-gradient(120% 120% at 30% 10%, #20232a, #0e0f12 72%);
}
.pf-detail-thumb img { max-height: 76%; max-width: 84%; object-fit: contain; filter: drop-shadow(0 14px 28px rgba(0,0,0,0.7)); }
.pf-detail-thumb .badge2 {
  position: absolute; top: 10px; right: 10px;
  font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 5px 10px; border-radius: 999px; background: rgba(225,30,39,0.16);
  border: 1px solid rgba(225,30,39,0.4); color: #ffb4b8;
}
.pf-detail-head h2 { margin: 4px 0 8px; }
.pf-detail-desc { color: var(--ink-soft); font-size: 0.96rem; margin: 0 0 12px; }
.pf-detail-head .tags { display: flex; flex-wrap: wrap; gap: 8px; }
.pf-detail-head .tag2 {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.04em; color: var(--ink-soft);
  padding: 5px 10px; border-radius: 999px; background: rgba(255,255,255,0.03); border: 1px solid var(--hair);
}
.pf-detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; margin: 28px 0 6px; }
.pf-sub {
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--red-bright); margin: 0 0 14px;
}
.pf-sub-note { color: var(--chrome-lo); }
.pf-specs { margin: 0; display: flex; flex-direction: column; gap: 0; }
.pf-spec { display: flex; justify-content: space-between; gap: 14px; padding: 9px 0; border-bottom: 1px solid var(--hair); }
.pf-spec dt { color: var(--ink-mute); font-size: 0.88rem; }
.pf-spec dd { margin: 0; color: var(--ink); font-weight: 600; font-size: 0.92rem; text-align: right; font-variant-numeric: tabular-nums; }
.pf-bar { margin-bottom: 14px; }
.pf-bar-head { display: flex; justify-content: space-between; font-size: 0.82rem; color: var(--ink-soft); margin-bottom: 6px; }
.pf-bar-note { font-family: var(--font-mono); font-size: 0.72rem; color: var(--chrome-mid); }
.pf-bar-track { height: 8px; border-radius: 999px; background: rgba(255,255,255,0.06); overflow: hidden; }
.pf-bar-track span { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--red), var(--red-bright)); animation: pfBar .8s var(--ease-out); }
@keyframes pfBar { from { width: 0 !important; } }
.pf-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.pf-list li { position: relative; padding-left: 18px; color: var(--ink-soft); font-size: 0.92rem; }
.pf-list li::before { content: ""; position: absolute; left: 0; top: 8px; width: 7px; height: 7px; border-radius: 2px; background: var(--red); }
.pf-list-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 26px; margin-top: 14px; }
.pf-detail-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }

/* ---- Vergleichstabelle ---- */
.pf-cmp-wrap { overflow-x: auto; margin: 22px 0 6px; }
.pf-cmp { width: 100%; border-collapse: collapse; min-width: 480px; }
.pf-cmp th, .pf-cmp td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--hair); font-size: 0.9rem; vertical-align: top; }
.pf-cmp thead th { border-bottom: 1px solid var(--hair-strong); }
.pf-cmp-name { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; color: var(--ink); }
.pf-cmp-type { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--chrome-lo); }
.pf-cmp tbody th { color: var(--ink-mute); font-weight: 500; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.04em; white-space: nowrap; }
.pf-cmp td { color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.pf-cmp td.is-best { color: var(--ink); font-weight: 700; background: rgba(225,30,39,0.08); }
.pf-cmp-star { color: var(--red-bright); }
.pf-cmp-small { font-size: 0.82rem; }
.pf-cmp-link { color: var(--red-bright); font-family: var(--font-mono); font-size: 0.8rem; }

@media (max-width: 760px) {
  .pf-detail-head { flex-direction: column; }
  .pf-detail-thumb { width: 100%; height: 170px; }
  .pf-detail-grid { grid-template-columns: 1fr; gap: 24px; }
  .pf-list-2col { grid-template-columns: 1fr; }
  .pf-modal-body { padding: 10px 20px 28px; }
}
@media (prefers-reduced-motion: reduce) {
  .pf-modal-panel, .pf-bar-track span { animation: none; }
}

/* ============================================================
   KONTAKT – Premium-Ausbau (Weltklasse-Kontaktseite)
   Expertenkontakt · Gründe · Beratungsprozess · Vertrauenszahlen ·
   Smart-Form · Branchen · FAQ · Standort · Final-CTA.
   Nutzt globale Tokens + bestehende Komponenten; nur Ergänzungen hier.
   ============================================================ */

/* ---- Direkter Expertenkontakt ---- */
.expert-wrap { display: grid; grid-template-columns: 1.15fr 1fr; gap: 20px; align-items: stretch; }
@media (max-width: 920px) { .expert-wrap { grid-template-columns: 1fr; } }

.expert-card { display: flex; gap: 22px; align-items: center; padding: clamp(20px, 3vw, 30px);
  border-radius: var(--radius); border: 1px solid var(--hair); position: relative; overflow: hidden;
  background: radial-gradient(120% 90% at 0% 0%, rgba(226,0,26,0.10), transparent 55%),
    linear-gradient(160deg, var(--graphite-2, #151316), var(--obsidian, #050505));
  box-shadow: 0 36px 80px -34px rgba(0,0,0,0.9), inset 0 1px 0 rgba(255,255,255,0.05); }
.expert-photo { flex: none; width: clamp(96px, 12vw, 132px); aspect-ratio: 1; border-radius: 50%;
  position: relative; display: grid; place-items: center; overflow: hidden;
  border: 1px solid rgba(226,0,26,0.45); box-shadow: 0 0 0 5px rgba(226,0,26,0.07), 0 18px 36px -16px rgba(0,0,0,0.85);
  background: radial-gradient(120% 120% at 30% 22%, #211d22, #0b0a0c); }
.expert-photo img { width: 100%; height: 100%; object-fit: cover; }
.expert-photo .ep-fallback { font-family: var(--font-display); font-weight: 800; font-size: 2.1rem;
  color: var(--chrome-hi, #e7e3ea); letter-spacing: 0.02em; }
.expert-meta { min-width: 0; }
.expert-meta .em-name { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--ink); line-height: 1.1; }
.expert-meta .em-role { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--red-bright, #ff2630); margin-top: 5px; }
.expert-meta .em-field { color: var(--ink-soft); font-size: 0.98rem; margin: 12px 0 14px; }
.expert-avail { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono);
  font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); }
.expert-avail .av-dot { width: 9px; height: 9px; border-radius: 50%; background: #28d07a;
  box-shadow: 0 0 10px 1px rgba(40,208,122,0.85); animation: cbPulse 1.9s ease-in-out infinite; }

/* Kontakt-Avatar als gebrandetes Logo (PP-Telefon, transparent) auf dunklem Rund-Frame */
.expert-photo--logo { background: radial-gradient(120% 120% at 30% 22%, #211d22, #0b0a0c); }
.expert-photo--logo img { object-fit: contain; padding: 9%; }

/* Branchen-Cards: Badge-Bild statt Icon, mit rotem Leuchten (Höhe fix, Breite je nach Format) */
.card-icon--img { width: auto; height: 92px; border: 0; background: none; border-radius: 16px;
  display: inline-flex; margin-bottom: 18px;
  overflow: visible; filter: drop-shadow(0 0 14px rgba(226,0,26,0.55)) drop-shadow(0 8px 18px rgba(0,0,0,0.6)); }
.card-icon--img img { width: auto; height: 100%; object-fit: contain; border-radius: 12px; }
.card:hover .card-icon--img { filter: drop-shadow(0 0 22px rgba(255,38,48,0.9)) drop-shadow(0 10px 22px rgba(0,0,0,0.7)); }

.contact-channels { display: grid; gap: 14px; align-content: stretch; }
.channel-tile { display: flex; gap: 16px; align-items: center; padding: 18px 20px; border-radius: var(--radius);
  border: 1px solid var(--hair); background: linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.012));
  box-shadow: 0 18px 40px -24px rgba(0,0,0,0.85); transition: transform 0.3s var(--ease-out, ease), border-color 0.3s var(--ease-out, ease), box-shadow 0.3s var(--ease-out, ease); }
.channel-tile:hover { transform: translateY(-3px); border-color: rgba(226,0,26,0.55);
  box-shadow: 0 26px 50px -22px rgba(0,0,0,0.9), 0 0 30px -12px rgba(226,0,26,0.5); }
.channel-tile .ch-ic { flex: none; width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center;
  border: 1px solid rgba(226,0,26,0.45); background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.26), rgba(0,0,0,0.5)); }
.channel-tile .ch-ic svg { width: 22px; height: 22px; fill: none; stroke: var(--red-bright, #ff2630); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.channel-tile .ch-k { display: block; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 4px; }
.channel-tile .ch-v { display: block; font-family: var(--font-display); font-weight: 700; font-size: 1.18rem; color: var(--ink); line-height: 1.15; word-break: break-word; }
.channel-tile .ch-arrow { margin-left: auto; flex: none; color: var(--ink-mute); transition: transform 0.3s var(--ease-out, ease), color 0.3s; }
.channel-tile:hover .ch-arrow { transform: translateX(4px); color: var(--red-bright, #ff2630); }
.channel-tile .ch-arrow svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ---- Beratungsprozess (5 Schritte) ---- */
.proc-steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; margin-top: 8px; }
@media (max-width: 980px) { .proc-steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .proc-steps { grid-template-columns: 1fr; } }
.proc-step { position: relative; padding: 22px 18px; border-radius: var(--radius); border: 1px solid var(--hair);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); overflow: hidden; }
.proc-step::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--red, #e2001a), transparent); opacity: 0.7; }
.proc-step .ps-num { font-family: var(--font-display); font-weight: 800; font-size: 0.9rem; color: #fff;
  width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; margin-bottom: 14px;
  border: 1px solid rgba(226,0,26,0.5); background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.3), rgba(0,0,0,0.5)); box-shadow: 0 0 0 4px rgba(226,0,26,0.05); }
.proc-step h3 { font-size: 1.12rem; margin: 0 0 6px; color: var(--ink); }
.proc-step p { font-size: 0.92rem; color: var(--ink-soft); line-height: 1.5; margin: 0; }

/* ---- Vertrauenszahlen ---- */
.trust-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 760px) { .trust-stats { grid-template-columns: repeat(2, 1fr); } }
.trust-stat { text-align: center; padding: 26px 16px; border-radius: var(--radius); border: 1px solid var(--hair);
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); }
.trust-stat .num { display: block; font-family: var(--font-display); font-weight: 800; line-height: 1;
  font-size: clamp(2.4rem, 5vw, 3.4rem); color: #fff; font-variant-numeric: tabular-nums; }
.trust-stat .num .accent { color: var(--red-bright, #ff2630); }
.trust-stat .lbl { display: block; margin-top: 10px; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); }

/* ---- Smart-Form ---- */
.sf-step-lbl { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono);
  font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); margin: 4px 0 12px; }
.sf-step-lbl b { width: 22px; height: 22px; border-radius: 7px; display: grid; place-items: center; color: #fff;
  font-family: var(--font-display); font-size: 0.74rem; border: 1px solid rgba(226,0,26,0.5);
  background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.32), rgba(0,0,0,0.5)); }
.sf-group { margin-bottom: 22px; }
.sf-chips { display: flex; flex-wrap: wrap; gap: 9px; }
.sf-chip { position: relative; cursor: pointer; }
.sf-chip input { position: absolute; opacity: 0; pointer-events: none; }
.sf-chip span { display: inline-flex; align-items: center; gap: 8px; padding: 9px 15px; border-radius: 999px;
  border: 1px solid var(--hair); background: rgba(255,255,255,0.02); color: var(--ink-soft);
  font-size: 0.9rem; transition: all 0.2s var(--ease-out, ease); }
.sf-chip span::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--ink-mute); transition: all 0.2s; }
.sf-chip:hover span { border-color: var(--chrome-mid); color: var(--ink); }
.sf-chip input:checked + span { border-color: rgba(226,0,26,0.65); color: var(--ink);
  background: linear-gradient(180deg, rgba(226,0,26,0.16), rgba(226,0,26,0.05)); box-shadow: 0 0 18px -6px rgba(226,0,26,0.6); }
.sf-chip input:checked + span::before { background: var(--red-bright, #ff2630); box-shadow: 0 0 8px 1px rgba(255,38,48,0.8); }
.sf-chip input:focus-visible + span { outline: 2px solid var(--red-bright, #ff2630); outline-offset: 2px; }

.sf-upload { display: flex; align-items: center; gap: 14px; padding: 18px; border-radius: var(--radius-sm);
  border: 1px dashed rgba(226,0,26,0.4); background: rgba(226,0,26,0.04); cursor: pointer; transition: all 0.25s var(--ease-out, ease); }
.sf-upload:hover { border-color: rgba(226,0,26,0.7); background: rgba(226,0,26,0.08); }
.sf-upload input { position: absolute; opacity: 0; width: 0; height: 0; }
.sf-upload .up-ic { flex: none; width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center;
  border: 1px solid rgba(226,0,26,0.45); background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.24), rgba(0,0,0,0.45)); }
.sf-upload .up-ic svg { width: 20px; height: 20px; fill: none; stroke: var(--red-bright, #ff2630); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.sf-upload .up-k { display: block; font-family: var(--font-display); font-weight: 700; color: var(--ink); font-size: 1.0rem; }
.sf-upload .up-s { display: block; font-size: 0.8rem; color: var(--ink-mute); margin-top: 3px; line-height: 1.4; }

/* ---- Standort / Karte ---- */
.map-grid { display: grid; grid-template-columns: 1.25fr 1fr; gap: 20px; align-items: stretch; }
@media (max-width: 900px) { .map-grid { grid-template-columns: 1fr; } }
.map-frame { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--hair);
  box-shadow: 0 30px 60px -30px rgba(0,0,0,0.85); min-height: 340px;
  background:
    radial-gradient(120% 90% at 30% 20%, rgba(226,0,26,0.14), transparent 60%),
    linear-gradient(160deg, var(--graphite-2, #151316), var(--obsidian, #050505)); }
.map-frame iframe { width: 100%; height: 100%; min-height: 340px; border: 0; display: block; filter: grayscale(0.35) contrast(1.04) brightness(0.92); }
.map-info { display: flex; flex-direction: column; justify-content: center; padding: clamp(20px, 3vw, 32px);
  border-radius: var(--radius); border: 1px solid var(--hair);
  background: radial-gradient(120% 90% at 100% 0%, rgba(226,0,26,0.10), transparent 55%), linear-gradient(160deg, var(--graphite-2, #151316), var(--obsidian, #050505)); }

/* ============================================================
   Schicht-Portfolio — Ausbau: Hero-Kennzahlen, Einsatzgebiete,
   Schichtaufbau, Download-Center, Experten-CTA
   ============================================================ */

/* ---- Hero: Vertrauenskennzahlen ---- */
.pf-stats {
  display: grid; grid-template-columns: repeat(4, auto); gap: 14px 30px;
  margin: 26px 0 4px; padding: 0;
}
.pf-stat { display: flex; flex-direction: column; gap: 2px; }
.pf-stat dd { margin: 0; }
.pf-stat .pf-num {
  font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 3vw, 2.4rem);
  line-height: 1; color: var(--ink); font-variant-numeric: tabular-nums;
}
.pf-stat dt {
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--chrome-lo); max-width: 18ch;
}
.pf-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }

/* ---- Einsatzgebiete ---- */
.pf-areas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.pf-area {
  text-align: left; cursor: pointer; padding: 0; overflow: hidden;
  display: flex; flex-direction: column; color: inherit;
  border: 1px solid var(--hair); border-radius: var(--radius);
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
  transition: transform 0.3s var(--ease), border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.pf-area:hover { transform: translateY(-5px); border-color: rgba(225,30,39,0.4); box-shadow: var(--shadow); }
.pf-area:focus-visible { outline: 2px solid var(--red-bright); outline-offset: 3px; }
.pf-area-img {
  position: relative; height: 160px; display: grid; place-items: center;
  color: rgba(255,255,255,0.5); border-bottom: 1px solid var(--hair);
  background:
    radial-gradient(120% 120% at 30% 10%, #20232a, #0e0f12 72%),
    repeating-linear-gradient(135deg, rgba(255,255,255,0.025) 0 2px, transparent 2px 9px);
}
.pf-area-img svg { width: 56px; height: 56px; opacity: 0.85; }
.pf-area-img::after {
  content: attr(data-ph) " · Bildplatzhalter"; position: absolute; left: 12px; bottom: 10px;
  font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--chrome-lo);
}
.pf-area:hover .pf-area-img { color: var(--red-bright); }

/* Echtes Branchen-Bild statt Platzhalter – überdeckt den kompletten oberen Bereich */
.pf-area-img--photo { background: #0b0c0f; }
.pf-area-img--photo::after { content: none; }
.pf-area-img--photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.45s var(--ease, ease); }
.pf-area:hover .pf-area-img--photo img { transform: scale(1.04); }

.pf-area-body { padding: 20px 20px 22px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.pf-area-name { font-family: var(--font-display); font-weight: 700; font-size: 1.32rem; color: var(--ink); }
.pf-area-desc { font-size: 0.92rem; color: var(--ink-soft); line-height: 1.5; }
.pf-area-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 2px; }
.pf-area-tags .tag2 {
  font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.03em; color: var(--ink-soft);
  padding: 4px 9px; border-radius: 999px; background: rgba(255,255,255,0.03); border: 1px solid var(--hair);
}
.pf-area-cta {
  margin-top: auto; padding-top: 6px; font-family: var(--font-mono); font-size: 0.72rem;
  letter-spacing: 0.04em; color: var(--red-bright);
  transform: translateX(0); transition: transform 0.25s var(--ease);
}
.pf-area:hover .pf-area-cta { transform: translateX(4px); }

/* ---- Schichtaufbau ---- */
.pf-build { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(28px, 5vw, 64px); align-items: center; }
.pf-build-stage {
  position: relative; aspect-ratio: 4/3; display: flex; flex-direction: column; justify-content: center;
  gap: 20px; padding: 30px; perspective: 1000px;
}
.pf-layer {
  position: relative; height: 16%; border-radius: 8px; transform-style: preserve-3d;
  transform: rotateX(52deg) rotateZ(-34deg) translateZ(calc(var(--i) * -26px));
  transition: transform 0.5s var(--ease-out), box-shadow 0.3s var(--ease);
  box-shadow: 0 18px 30px -16px rgba(0,0,0,0.8);
}
.pf-layer .pf-layer-bar { position: absolute; inset: 0; border-radius: 8px; border: 1px solid rgba(255,255,255,0.12); }
.pf-layer[data-layer="base"] .pf-layer-bar { background: linear-gradient(135deg, #3a3d44, #23262c); }
.pf-layer[data-layer="bond"] .pf-layer-bar { background: linear-gradient(135deg, #5a5f68, #3c4047); }
.pf-layer[data-layer="func"] .pf-layer-bar { background: linear-gradient(135deg, var(--red-bright), var(--red-deep)); }
.pf-layer[data-layer="top"] .pf-layer-bar { background: linear-gradient(135deg, #8c929c, #4c505a); }
.pf-build.in .pf-layer { transform: rotateX(52deg) rotateZ(-34deg) translateZ(calc(var(--i) * -26px)) translateY(calc(var(--i) * -14px)); }
.pf-build-stage:hover .pf-layer,
.pf-build-legend li:hover ~ * { /* placeholder, real highlight via JS-free hover below */ }
.pf-build-legend { list-style: none; margin: 0; padding: 0; counter-reset: l; display: flex; flex-direction: column; gap: 14px; }
.pf-build-legend li { display: flex; gap: 14px; align-items: flex-start; padding: 12px 14px; border-radius: var(--radius-sm); border: 1px solid transparent; transition: border-color 0.25s var(--ease), background 0.25s var(--ease); }
.pf-build-legend li:hover { border-color: var(--hair); background: rgba(255,255,255,0.02); }
.pf-build-legend .pf-dot4 { flex: none; width: 14px; height: 14px; border-radius: 4px; margin-top: 3px; border: 1px solid rgba(255,255,255,0.15); }
.pf-build-legend li[data-layer="base"] .pf-dot4 { background: #3a3d44; }
.pf-build-legend li[data-layer="bond"] .pf-dot4 { background: #5a5f68; }
.pf-build-legend li[data-layer="func"] .pf-dot4 { background: var(--red-bright); }
.pf-build-legend li[data-layer="top"] .pf-dot4 { background: #8c929c; }
.pf-build-legend strong { display: block; color: var(--ink); font-family: var(--font-display); font-weight: 700; font-size: 1.06rem; margin-bottom: 3px; }
.pf-build-legend p { margin: 0; font-size: 0.9rem; color: var(--ink-soft); line-height: 1.5; }

/* ---- Download-Center ---- */
.pf-dl-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.pf-dl-card {
  display: flex; flex-direction: column; gap: 10px; padding: 18px;
  border: 1px solid var(--hair); border-radius: var(--radius);
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease);
}
.pf-dl-card:hover { border-color: var(--hair-strong); transform: translateY(-3px); }
.pf-dl-top { display: flex; align-items: center; justify-content: space-between; }
.pf-dl-ic { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 9px; border: 1px solid rgba(225,30,39,0.35); color: var(--red-bright); background: rgba(225,30,39,0.08); }
.pf-dl-ic svg { width: 18px; height: 18px; }
.pf-dl-card h3 { font-size: 1.06rem; margin: 2px 0 0; }
.pf-dl-chem { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.02em; color: var(--chrome-lo); margin: 0; }
.pf-dl-specs { display: flex; gap: 14px; margin: 4px 0 2px; padding: 10px 0; border-block: 1px solid var(--hair); }
.pf-dl-specs div { display: flex; flex-direction: column; gap: 1px; }
.pf-dl-specs dt { font-family: var(--font-mono); font-size: 0.54rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--chrome-lo); }
.pf-dl-specs dd { margin: 0; font-family: var(--font-display); font-weight: 700; font-size: 0.92rem; color: var(--ink); font-variant-numeric: tabular-nums; }
.pf-dl-actions { display: flex; gap: 8px; margin-top: auto; }
.pf-dl-actions .btn { flex: 1; padding: 10px 12px; font-size: 0.7rem; }
.pf-dl-detail {
  flex: none; cursor: pointer; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.04em;
  color: var(--ink-soft); padding: 10px 14px; border-radius: 999px;
  background: rgba(255,255,255,0.03); border: 1px solid var(--hair);
}
.pf-dl-detail:hover { color: var(--ink); border-color: var(--hair-strong); }
.pf-dl-meta { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.06em; color: var(--ink-mute); }

/* ---- Experten-CTA ---- */
.pf-expert {
  display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(24px, 4vw, 48px); align-items: center;
  padding: clamp(26px, 4vw, 44px);
  border: 1px solid var(--hair); border-radius: var(--radius);
  background:
    radial-gradient(120% 90% at 100% 0%, rgba(226,0,26,0.12), transparent 55%),
    linear-gradient(160deg, var(--graphite-2), var(--graphite));
}
.pf-expert-person { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 16px; }
.pf-expert-photo {
  position: relative; width: 150px; height: 150px; border-radius: 50%;
  display: grid; place-items: center; overflow: hidden;
  border: 1px solid var(--hair-strong);
  background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.22), #15171c 70%);
  box-shadow: 0 20px 40px -20px rgba(0,0,0,0.8), inset 0 1px 0 rgba(255,255,255,0.06);
}
.pf-expert-initials { font-family: var(--font-display); font-weight: 800; font-size: 2.6rem; color: var(--ink); letter-spacing: 0.04em; }
.pf-expert-photo--logo img { width: 100%; height: 100%; object-fit: contain; padding: 12%; }
.pf-expert-ph-note { position: absolute; bottom: 16px; font-family: var(--font-mono); font-size: 0.52rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--chrome-lo); }
.pf-expert-id { display: flex; flex-direction: column; gap: 5px; }
.pf-expert-id strong { font-family: var(--font-display); font-weight: 700; font-size: 1.16rem; color: var(--ink); }
.pf-expert-role { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.04em; color: var(--chrome-lo); }
.pf-expert-badge { display: inline-flex; align-items: center; gap: 7px; justify-content: center; margin-top: 4px; font-family: var(--font-mono); font-size: 0.66rem; color: var(--ink-soft); }
.pf-expert-badge .pf-dot { width: 8px; height: 8px; border-radius: 50%; background: #36d07a; box-shadow: 0 0 0 4px rgba(54,208,122,0.15); }
.pf-expert-copy h2 { margin: 0 0 12px; }
.pf-expert-copy > p { color: var(--ink-soft); margin: 0 0 22px; max-width: 56ch; }
.pf-expert-copy .actions { display: flex; flex-wrap: wrap; gap: 12px; }
.pf-expert-contact { list-style: none; display: flex; flex-wrap: wrap; gap: 8px 24px; margin: 20px 0 0; padding: 0; }
.pf-expert-contact a { font-family: var(--font-mono); font-size: 0.8rem; color: var(--ink-soft); }
.pf-expert-contact a:hover { color: var(--red-bright); }

/* ---- Responsive ---- */
@media (max-width: 980px) {
  .pf-areas { grid-template-columns: repeat(2, 1fr); }
  .pf-dl-grid { grid-template-columns: repeat(2, 1fr); }
  .pf-build { grid-template-columns: 1fr; }
  .pf-build-stage { max-width: 420px; margin: 0 auto; }
  .pf-expert { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .pf-stats { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .pf-areas { grid-template-columns: 1fr; }
  .pf-dl-grid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .pf-area, .pf-dl-card { transition: none; }
  .pf-build .pf-layer { transition: none; }
}

/* ============================================================
   DIENSTLEISTUNGEN – Premium-Ausbau (Service-Erlebniswelt)
   Bestehende Inhalte bleiben; diese Sektionen ergänzen:
   Ergebnisse · Experten-Zitat · Branchen · Case-Studies ·
   Problem→Lösung→Ergebnis · Expertenwissen.
   Nutzt globale Tokens + bestehende Komponenten (trust-stats,
   services-grid, expert-card, proc-steps).
   ============================================================ */

/* Experteneinschätzung – Zitat-Panel */
.expert-quote { position: relative; border-radius: var(--radius); border: 1px solid var(--hair);
  padding: clamp(26px, 4vw, 44px); display: grid; grid-template-columns: auto 1fr; gap: clamp(18px, 3vw, 32px); align-items: center;
  background: radial-gradient(110% 90% at 0% 0%, rgba(226,0,26,0.10), transparent 55%),
    linear-gradient(160deg, var(--graphite-2, #151316), var(--obsidian, #050505));
  box-shadow: 0 36px 80px -34px rgba(0,0,0,0.9), inset 0 1px 0 rgba(255,255,255,0.05); overflow: hidden; }
@media (max-width: 720px) { .expert-quote { grid-template-columns: 1fr; text-align: center; } }
.eq-photo { width: clamp(92px, 11vw, 120px); aspect-ratio: 1; border-radius: 50%; overflow: hidden;
  display: grid; place-items: center; border: 1px solid rgba(226,0,26,0.45);
  box-shadow: 0 0 0 5px rgba(226,0,26,0.07); background: radial-gradient(120% 120% at 30% 22%, #211d22, #0b0a0c); margin-inline: auto; }
.eq-photo img { width: 100%; height: 100%; object-fit: cover; }
.eq-photo .ep-fallback { font-family: var(--font-display); font-weight: 800; font-size: 1.9rem; color: var(--chrome-hi, #e7e3ea); }
.eq-body blockquote { margin: 0; font-family: var(--font-display); font-weight: 700; letter-spacing: -0.01em;
  font-size: clamp(1.25rem, 2.4vw, 1.85rem); line-height: 1.32; color: var(--ink); }
.eq-body blockquote .accent { color: var(--red-bright, #ff2630); }
.eq-cite { display: block; margin-top: 16px; font-family: var(--font-mono); font-size: 0.66rem;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); font-style: normal; }
.eq-cite b { color: var(--ink); font-weight: 600; }

/* Branchen-Karten mit Bildwelt */
.branche-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 960px) { .branche-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .branche-grid { grid-template-columns: 1fr; } }
.branche-card { display: flex; flex-direction: column; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--hair); background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  box-shadow: 0 22px 48px -28px rgba(0,0,0,0.85); transition: transform 0.4s var(--ease-out, ease), border-color 0.4s var(--ease-out, ease), box-shadow 0.4s var(--ease-out, ease); }
.branche-card:hover { transform: translateY(-5px); border-color: rgba(226,0,26,0.5);
  box-shadow: 0 34px 64px -28px rgba(0,0,0,0.9), 0 0 36px -14px rgba(226,0,26,0.45); }
.bc-media { position: relative; aspect-ratio: 16 / 10; overflow: hidden;
  background: radial-gradient(120% 120% at 30% 10%, #23202a, #0c0b0e); }
.bc-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: saturate(1.04) contrast(1.05) brightness(0.92); transition: transform 0.6s var(--ease-out, ease); }
.branche-card:hover .bc-media img { transform: scale(1.06); }
.bc-media .ph { position: absolute; inset: 0; display: grid; place-items: center; opacity: 0.3; }
.bc-media .ph svg { width: 54px; height: 54px; stroke: var(--chrome-mid); fill: none; }
.bc-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(5,5,7,0.7)); }
.bc-media .bc-tag { position: absolute; z-index: 1; left: 14px; bottom: 12px; font-family: var(--font-display);
  font-weight: 800; font-size: 1.3rem; color: #fff; text-shadow: 0 2px 14px rgba(0,0,0,0.8); }
.bc-body { padding: 20px; display: grid; gap: 12px; }
.bc-row .bc-lbl { display: block; font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-mute); margin-bottom: 4px; }
.bc-row.bc-sol .bc-lbl { color: var(--red-bright, #ff2630); }
.bc-row p { margin: 0; color: var(--ink-soft); font-size: 0.95rem; line-height: 1.5; }

/* Case-Studies (Ausgangslage → Herausforderung → Lösung → Ergebnis) */
.case-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
@media (max-width: 820px) { .case-grid { grid-template-columns: 1fr; } }
.case-card { position: relative; border-radius: var(--radius); border: 1px solid var(--hair); overflow: hidden;
  padding: clamp(22px, 3vw, 30px); background: radial-gradient(120% 80% at 100% 0%, rgba(226,0,26,0.10), transparent 55%),
    linear-gradient(160deg, var(--graphite-2, #151316), var(--obsidian, #050505));
  box-shadow: 0 26px 54px -30px rgba(0,0,0,0.88); }
.case-tag { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--red-bright, #ff2630); }
.case-card h3 { font-size: 1.35rem; margin: 8px 0 18px; color: var(--ink); }
.case-steps { display: grid; gap: 12px; margin: 0; }
.case-steps .cs { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start; }
.case-steps .cs-k { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-mute); white-space: nowrap; padding-top: 3px; min-width: 104px; }
.case-steps .cs-v { color: var(--ink-soft); font-size: 0.96rem; line-height: 1.5; }
.case-result { margin-top: 20px; padding: 14px 18px; border-radius: var(--radius-sm); border: 1px solid rgba(226,0,26,0.4);
  background: linear-gradient(135deg, rgba(226,0,26,0.14), rgba(255,255,255,0.02)); display: flex; align-items: baseline; gap: 12px; }
.case-result .cr-num { font-family: var(--font-display); font-weight: 800; font-size: 1.6rem; color: var(--red-bright, #ff2630); line-height: 1; }
.case-result .cr-txt { color: var(--ink); font-size: 0.96rem; }

/* Problem → Lösung → Ergebnis */
.psr-list { display: grid; gap: 14px; }
.psr-row { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: stretch; gap: 0;
  border-radius: var(--radius); border: 1px solid var(--hair); overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.008)); }
@media (max-width: 820px) { .psr-row { grid-template-columns: 1fr; } }
.psr-cell { padding: 18px 20px; display: grid; gap: 5px; align-content: center; }
.psr-cell .psr-k { font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.14em; text-transform: uppercase; }
.psr-cell.is-problem .psr-k { color: #ff8a8a; }
.psr-cell.is-solution .psr-k { color: var(--ink-mute); }
.psr-cell.is-result .psr-k { color: var(--red-bright, #ff2630); }
.psr-cell p { margin: 0; color: var(--ink-soft); font-size: 0.96rem; line-height: 1.45; }
.psr-cell.is-result p { color: var(--ink); font-weight: 600; }
.psr-arrow { display: grid; place-items: center; padding: 0 10px; color: var(--red, #e2001a); }
.psr-arrow svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
@media (max-width: 820px) { .psr-arrow { transform: rotate(90deg); padding: 4px 0; } .psr-cell { border-top: 1px solid var(--hair); } .psr-cell:first-child { border-top: 0; } }

/* ============================================================
   Über uns — Premium-Ausbau: Hero-Zahlen, Mission, Timeline,
   Technologie, Werte, Team, Branchen, Qualitätsversprechen
   ============================================================ */

/* ---- Hero-Kennzahlen (zentriert im Shader-Hero) ---- */
.ueber-stats {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 18px 40px;
  margin: 30px 0 0; padding: 0;
}
.ueber-stat { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.ueber-stat dd { margin: 0; }
.ueber-stat .pf-num {
  font-family: var(--font-display); font-weight: 800; font-size: clamp(1.9rem, 3vw, 2.6rem);
  line-height: 1; color: #fff; font-variant-numeric: tabular-nums;
  text-shadow: 0 0 26px rgba(226,0,26,0.4);
}
.ueber-stat dt {
  font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--chrome-mid); max-width: 16ch; text-align: center;
}

/* ---- Mission ---- */
.ueber-mission-inner { max-width: 920px; }
.ueber-mission-inner h2 { font-size: clamp(1.9rem, 3.4vw, 2.9rem); line-height: 1.05; margin: 6px 0 18px; }
.ueber-mission-lead { font-size: clamp(1.05rem, 1.6vw, 1.28rem); color: var(--ink-soft); line-height: 1.6; max-width: 70ch; text-wrap: pretty; }

/* ---- Platzhalter-Hinweis ---- */
.ueber-ph-hint { color: var(--chrome-lo); font-style: italic; font-size: 0.92em; }

/* ---- Zeitstrahl ---- */
.ueber-timeline { list-style: none; margin: 0; padding: 0; position: relative; }
.ueber-timeline::before {
  content: ""; position: absolute; left: 9px; top: 6px; bottom: 6px; width: 2px;
  background: linear-gradient(180deg, var(--red-bright), var(--red) 40%, var(--hair) 100%);
}
.ueber-tl { position: relative; padding: 0 0 26px 42px; }
.ueber-tl:last-child { padding-bottom: 0; }
.ueber-tl::before {
  content: ""; position: absolute; left: 2px; top: 4px; width: 16px; height: 16px; border-radius: 50%;
  background: var(--graphite); border: 2px solid var(--red-bright);
  box-shadow: 0 0 0 4px rgba(226,0,26,0.12);
}
.ueber-tl.is-placeholder::before { border-color: var(--chrome-lo); box-shadow: 0 0 0 4px rgba(255,255,255,0.05); }
.ueber-tl.is-now::before { background: var(--red-bright); box-shadow: 0 0 0 4px rgba(226,0,26,0.22), 0 0 18px rgba(226,0,26,0.5); }
.ueber-tl.is-future::before { background: transparent; border-style: dashed; }
.ueber-tl-year {
  display: inline-block; font-family: var(--font-display); font-weight: 800; font-size: 1.34rem;
  color: var(--red-bright); letter-spacing: 0.01em; margin-bottom: 4px;
}
.ueber-tl.is-placeholder .ueber-tl-year { color: var(--chrome-lo); }
.ueber-tl.is-now .ueber-tl-year, .ueber-tl.is-future .ueber-tl-year { color: var(--ink); }
.ueber-tl-body h3 { font-size: 1.12rem; margin: 0 0 4px; }
.ueber-tl-body p { margin: 0; color: var(--ink-soft); font-size: 0.95rem; line-height: 1.55; max-width: 64ch; }
.ueber-tl-body em { color: var(--chrome-lo); font-style: italic; }

/* ---- Technologie & Werte & Branchen: gemeinsames Icon-Card-Grid ---- */
.ueber-tech-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.ueber-tech {
  padding: 24px 22px; border: 1px solid var(--hair); border-radius: var(--radius);
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
  transition: transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.ueber-tech:hover { transform: translateY(-5px); border-color: rgba(225,30,39,0.4); box-shadow: var(--shadow); }
.ueber-tech-ic, .ueber-value-ic, .ueber-branche-ic, .ueber-promise-ic {
  display: grid; place-items: center; width: 46px; height: 46px; border-radius: 12px; margin-bottom: 14px;
  border: 1px solid rgba(225,30,39,0.4); color: var(--red-bright);
  background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.22), rgba(0,0,0,0.4));
  box-shadow: 0 0 0 4px rgba(226,0,26,0.05);
}
.ueber-tech-ic svg, .ueber-value-ic svg, .ueber-branche-ic svg, .ueber-promise-ic svg { width: 22px; height: 22px; fill: none; stroke: currentColor; }
.ueber-tech h3 { font-size: 1.12rem; margin: 0 0 8px; }
.ueber-tech p { margin: 0; color: var(--ink-soft); font-size: 0.92rem; line-height: 1.55; }

/* ---- Werte (Icon-Grid, ersetzt values-2 optisch) ---- */
.ueber-values { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px 26px; }
.ueber-value { display: block; }
.ueber-value h4 { font-size: 1.08rem; color: var(--ink); margin: 0 0 5px; display: flex; align-items: center; gap: 4px; }
.ueber-value h4::before { content: none; }
.ueber-value p { margin: 0; color: var(--ink-soft); font-size: 0.94rem; line-height: 1.55; }
.ueber-value-ic { width: 40px; height: 40px; }

/* ---- Team ---- */
.ueber-team { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; max-width: 720px; margin-inline: auto; }
.ueber-member {
  padding: 26px 22px; text-align: center; border: 1px solid var(--hair); border-radius: var(--radius);
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
  transition: transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.ueber-member:hover { transform: translateY(-5px); border-color: rgba(225,30,39,0.4); box-shadow: var(--shadow); }
.ueber-member-photo {
  position: relative; width: 128px; height: 128px; border-radius: 50%; margin: 0 auto 16px;
  display: grid; place-items: center; overflow: hidden; border: 1px solid var(--hair-strong);
  background: radial-gradient(120% 120% at 30% 22%, rgba(226,0,26,0.2), #15171c 70%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 18px 36px -20px rgba(0,0,0,0.8);
}
.ueber-member-initials { font-family: var(--font-display); font-weight: 800; font-size: 2.2rem; color: var(--ink); letter-spacing: 0.03em; }
.ueber-member-ph { position: absolute; bottom: 14px; font-family: var(--font-mono); font-size: 0.5rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--chrome-lo); }
.ueber-member h3 { font-size: 1.18rem; margin: 0 0 3px; }
.ueber-member-role { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.04em; color: var(--red-bright); margin: 0 0 12px; text-transform: uppercase; }
.ueber-member-stmt { margin: 0; color: var(--ink-soft); font-size: 0.95rem; line-height: 1.6; font-style: italic; }
.ueber-member.is-placeholder .ueber-member-initials { color: var(--chrome-lo); }

/* ---- Branchen ---- */
.ueber-branchen { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.ueber-branche {
  display: flex; flex-direction: column; gap: 4px; padding: 20px;
  border: 1px solid var(--hair); border-radius: var(--radius);
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
  transition: transform .3s var(--ease), border-color .3s var(--ease);
}
.ueber-branche:hover { transform: translateY(-4px); border-color: rgba(225,30,39,0.4); }
.ueber-branche-ic { width: 42px; height: 42px; }
.ueber-branche h3 { font-size: 1.06rem; margin: 4px 0 2px; }
.ueber-branche p { margin: 0; color: var(--ink-soft); font-size: 0.9rem; line-height: 1.5; }

/* ---- Qualitätsversprechen ---- */
.ueber-promise { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px 26px; }
.ueber-promise-item { display: flex; gap: 16px; align-items: flex-start; }
.ueber-promise-ic { flex: none; }
.ueber-promise-item h3 { font-size: 1.1rem; margin: 4px 0 5px; }
.ueber-promise-item p { margin: 0; color: var(--ink-soft); font-size: 0.94rem; line-height: 1.55; }

/* ---- Responsive ---- */
@media (max-width: 980px) {
  .ueber-tech-grid { grid-template-columns: repeat(2, 1fr); }
  .ueber-team { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; }
  .ueber-branchen { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .ueber-stats { gap: 16px 26px; }
  .ueber-tech-grid, .ueber-values, .ueber-branchen, .ueber-promise { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .ueber-tech, .ueber-member, .ueber-branche { transition: none; }
}

/* ============================================================
   KINO-POLITUR (Kontakt + Dienstleistungen) — Tiefenwirkung:
   3D-Hover-Tilt + maus-getracktes Licht, Shine-Sweep-Lichtreflex,
   verfeinerte Reveal-Staffelung. GPU-only (transform/opacity),
   nur Pointer:fine, reduced-motion-sicher (siehe cinematic-polish.js).
   ============================================================ */
@media (hover: hover) and (pointer: fine) {
  .tilt-on { transition: transform 0.42s cubic-bezier(0.23, 1, 0.32, 1); transform-style: preserve-3d; will-change: transform; }
  .tilt-on.is-tilting { transition: transform 0.12s linear; }

  /* Shine-Sweep: diagonaler Lichtstreifen wandert beim Hover über die Karte */
  .shine-card { position: relative; }
  .shine-card::before {
    content: ""; position: absolute; inset: 0; z-index: 3; pointer-events: none; border-radius: inherit; overflow: hidden;
    background: linear-gradient(105deg, transparent 38%, rgba(255,255,255,0.10) 48%, rgba(255,90,97,0.08) 52%, transparent 62%);
    background-size: 250% 100%; background-position: 160% 0; opacity: 0;
  }
  .shine-card:hover::before { opacity: 1; animation: shineSweep 0.9s cubic-bezier(0.23, 1, 0.32, 1); }
  @keyframes shineSweep { 0% { background-position: 160% 0; opacity: 0; } 22% { opacity: 1; } 100% { background-position: -60% 0; opacity: 0; } }
}

@media (prefers-reduced-motion: reduce) {
  .tilt-on { transition: none !important; transform: none !important; }
  .shine-card::before { display: none; }
}

/* ============================================================
   Kinoreife Veredelung — Schicht-Portfolio & Über uns
   emil-design-eng: starke ease-out-Kurven, Press-Feedback,
   Icon-Micro-Motion, Chrom-Sheen, Modal-Blur; reduced-motion-safe.
   Nur pages.css (styles.css/script.js unberührt).
   ============================================================ */

/* --- Stärkere Hover-Kurve (Emil: built-in easings sind zu schwach) --- */
.coat-card, .pf-area, .pf-dl-card, .ueber-tech, .ueber-member, .ueber-branche {
  transition: transform .35s var(--ease-out), border-color .35s var(--ease-out), box-shadow .35s var(--ease-out);
}

/* --- Press-Feedback (Emil: pressable elements reagieren auf Druck) --- */
@media (hover: hover) and (pointer: fine) {
  .pf-area:active, .pf-dl-card:active, .ueber-tech:active, .ueber-member:active, .ueber-branche:active {
    transform: translateY(-2px) scale(0.985);
    transition-duration: .11s;
  }
  .btn-ghost:active, .pf-pill:active, .pf-dl-detail:active, .pf-modal-close:active, .pf-chip button:active {
    transform: scale(0.96);
    transition: transform .11s var(--ease-out);
  }
}

/* --- Icon-Badge Micro-Motion + Chrom-Sheen beim Hover --- */
.ueber-tech-ic, .ueber-value-ic, .ueber-branche-ic, .ueber-promise-ic, .pf-dl-ic {
  position: relative; overflow: hidden;
  transition: transform .3s var(--ease-out), box-shadow .3s var(--ease-out), border-color .3s var(--ease-out);
}
.ueber-tech-ic svg, .ueber-value-ic svg, .ueber-branche-ic svg, .ueber-promise-ic svg, .pf-dl-ic svg {
  position: relative; z-index: 1;
}
/* Chrom-Sheen-Sweep (metallische Marken-DNA), one-shot beim Hover */
.ueber-tech-ic::after, .ueber-value-ic::after, .ueber-branche-ic::after, .ueber-promise-ic::after, .pf-dl-ic::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0;
  background: linear-gradient(115deg, transparent 36%, rgba(255,255,255,0.55) 50%, transparent 64%);
}
@media (hover: hover) and (pointer: fine) {
  .ueber-tech:hover .ueber-tech-ic,
  .ueber-value:hover .ueber-value-ic,
  .ueber-branche:hover .ueber-branche-ic,
  .ueber-promise-item:hover .ueber-promise-ic,
  .pf-dl-card:hover .pf-dl-ic {
    transform: scale(1.08);
    border-color: rgba(225,30,39,0.65);
    box-shadow: 0 0 0 4px rgba(226,0,26,0.08), 0 0 22px rgba(226,0,26,0.4);
  }
  .ueber-tech:hover .ueber-tech-ic::after,
  .ueber-value:hover .ueber-value-ic::after,
  .ueber-branche:hover .ueber-branche-ic::after,
  .ueber-promise-item:hover .ueber-promise-ic::after,
  .pf-dl-card:hover .pf-dl-ic::after { animation: chromeSheen .7s var(--ease-out); }
}
@keyframes chromeSheen {
  0% { opacity: 0; transform: translateX(-70%); }
  30% { opacity: 1; }
  100% { opacity: 0; transform: translateX(70%); }
}

/* --- Einsatzgebiet-Kacheln: Icon-Lift beim Hover --- */
.pf-area-img svg { transition: transform .35s var(--ease-out); }
@media (hover: hover) and (pointer: fine) {
  .pf-area:hover .pf-area-img svg { transform: scale(1.12) translateY(-2px); }
}

/* --- Team-Avatar: Ring-Glow + leichter Zoom --- */
.ueber-member-photo { transition: box-shadow .35s var(--ease-out), transform .35s var(--ease-out); }
@media (hover: hover) and (pointer: fine) {
  .ueber-member:hover .ueber-member-photo {
    transform: scale(1.04);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 22px 44px -20px rgba(0,0,0,0.85), 0 0 26px rgba(226,0,26,0.35);
  }
}

/* --- Zeitstrahl: Linie zeichnet sich beim Reveal (Signature-Motion) --- */
.ueber-timeline::before { transform: scaleY(0); transform-origin: top; transition: transform .9s var(--ease-out); }
.ueber-timeline.in::before { transform: scaleY(1); }
.ueber-tl::before { transition: transform .45s var(--ease-out) .25s, box-shadow .3s var(--ease-out); transform: scale(0.55); }
.ueber-timeline.in .ueber-tl::before { transform: scale(1); }
.ueber-timeline.in .ueber-tl:nth-child(2)::before { transition-delay: .38s; }
.ueber-timeline.in .ueber-tl:nth-child(3)::before { transition-delay: .5s; }
.ueber-timeline.in .ueber-tl:nth-child(4)::before { transition-delay: .62s; }
.ueber-timeline.in .ueber-tl:nth-child(5)::before { transition-delay: .74s; }

/* --- Detail-Modal: Blur-Entrance (Emil: blur maskiert den Übergang) --- */
.pf-modal-panel { animation: pfModalInBlur .4s var(--ease-out); }
@keyframes pfModalInBlur {
  from { opacity: 0; transform: translateY(20px) scale(0.98); filter: blur(8px); }
  to { opacity: 1; transform: none; filter: blur(0); }
}

/* --- Hero-Kennzahlen: dezenter Glow-Puls beim Reveal-Ende (nur Über uns) --- */
.ueber-stat .pf-num { transition: text-shadow .4s var(--ease-out); }

@media (prefers-reduced-motion: reduce) {
  .pf-area:active, .pf-dl-card:active, .ueber-tech:active, .ueber-member:active, .ueber-branche:active,
  .btn-ghost:active, .pf-pill:active, .pf-dl-detail:active, .pf-modal-close:active, .pf-chip button:active { transform: none; }
  .ueber-tech-ic::after, .ueber-value-ic::after, .ueber-branche-ic::after, .ueber-promise-ic::after, .pf-dl-ic::after { display: none; }
  .ueber-tech:hover .ueber-tech-ic, .ueber-value:hover .ueber-value-ic, .ueber-branche:hover .ueber-branche-ic,
  .ueber-promise-item:hover .ueber-promise-ic, .pf-dl-card:hover .pf-dl-ic,
  .pf-area:hover .pf-area-img svg, .ueber-member:hover .ueber-member-photo { transform: none; }
  .ueber-timeline::before, .ueber-tl::before { transform: none; transition: none; }
  .pf-modal-panel { animation: none; }
}

/* ============================================================
   PREMIUM FOOTER — rein per CSS (lädt nach styles.css, überstimmt
   .site-footer/.footer-*). Signatur: überlebensgroße Wortmarke +
   metallische Kante + rote Energie-Naht + Underline-Reveals.
   ============================================================ */
.site-footer {
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--hair);
  background:
    radial-gradient(120% 130% at 50% -30%, rgba(226,0,26,0.13), transparent 55%),
    linear-gradient(180deg, var(--obsidian, #050505) 0%, #08070a 100%);
  padding-block: clamp(56px, 8vw, 84px) 28px;
}
/* metallische Oberkante + rote Energie-Naht mit Glühen */
.site-footer::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; z-index: 3;
  background: linear-gradient(90deg, transparent, rgba(226,0,26,0.65) 16%, rgba(255,90,97,0.95) 50%, rgba(226,0,26,0.65) 84%, transparent);
  box-shadow: 0 0 20px rgba(226,0,26,0.55);
}
/* überlebensgroße Wortmarke als Marken-„Boden" (solide + Maske, kein Gradient-Text) */
.site-footer::after {
  content: "PONDRUFF"; position: absolute; left: 50%; bottom: -0.16em; transform: translateX(-50%);
  z-index: 0; pointer-events: none; white-space: nowrap;
  font-family: var(--font-display); font-weight: 900; letter-spacing: -0.03em; line-height: 1;
  font-size: clamp(4rem, 17vw, 13rem); color: rgba(255,255,255,0.038);
  -webkit-mask-image: linear-gradient(180deg, #000 30%, transparent 92%);
  mask-image: linear-gradient(180deg, #000 30%, transparent 92%);
}
.site-footer > .wrap { position: relative; z-index: 1; }

/* Marken-Statement etwas präsenter + Logo-Glow */
.footer-brand p { font-size: 1rem; max-width: 360px; color: var(--ink-soft); line-height: 1.7; }
.footer-brand .brand img { transition: filter 0.4s var(--ease-out, ease), transform 0.4s var(--ease-out, ease); }
.footer-brand .brand:hover img { filter: drop-shadow(0 0 14px rgba(226,0,26,0.6)); transform: translateY(-1px); }

/* Spalten-Überschriften: roter Akzent-Dash + dezenter rot-Glow */
.footer-col h4 { position: relative; padding-bottom: 14px; margin-bottom: 20px; color: var(--ink); }
.footer-col h4::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 26px; height: 2px;
  background: linear-gradient(90deg, var(--red-bright, #ff2630), var(--red, #e2001a));
  box-shadow: 0 0 10px rgba(226,0,26,0.7);
}
.footer-col ul { gap: 13px; }

/* Link-Hover: animierte Underline-Reveal (statt nur Farbwechsel) */
.footer-col a, .footer-bottom .legal a {
  text-decoration: none; padding-bottom: 2px;
  background-image: linear-gradient(var(--red-bright, #ff2630), var(--red-bright, #ff2630));
  background-size: 0% 1.5px; background-position: 0 100%; background-repeat: no-repeat;
  transition: background-size 0.32s var(--ease-out, ease), color 0.28s var(--ease-out, ease);
}
.footer-col a:hover, .footer-bottom .legal a:hover { color: var(--red-bright, #ff2630); background-size: 100% 1.5px; }

/* untere Leiste: rot getönte Trennlinie mit zentralem Glühen */
.footer-bottom { position: relative; margin-top: 4px; }
.footer-bottom::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(226,0,26,0.4) 35%, rgba(255,90,97,0.55) 50%, rgba(226,0,26,0.4) 65%, transparent);
}
.footer-bottom .legal a { letter-spacing: 0.02em; }

@media (prefers-reduced-motion: reduce) {
  .footer-col a, .footer-bottom .legal a, .footer-brand .brand img { transition: none; }
}

/* ============================================================
   Geführter Schichtfinder (3-Schritt-Wizard)
   ============================================================ */
.pf-wizard {
  border: 1px solid var(--hair); border-radius: var(--radius); overflow: hidden;
  background: linear-gradient(180deg, var(--graphite-2), var(--graphite));
}
.pf-wiz-progress { height: 3px; background: rgba(255,255,255,0.06); }
.pf-wiz-bar {
  display: block; height: 100%; transform-origin: left; transform: scaleX(0.33);
  background: linear-gradient(90deg, var(--red), var(--red-bright));
  transition: transform .45s var(--ease-out);
}
.pf-wiz-steps { position: relative; padding: clamp(24px, 4vw, 40px); }
.pf-wiz-step { border: 0; margin: 0; padding: 0; display: none; }
.pf-wiz-step.is-active { display: block; animation: wizStepIn .32s var(--ease-out); }
@keyframes wizStepIn { from { opacity: 0; transform: translateX(14px); } to { opacity: 1; transform: none; } }
.pf-wiz-step legend {
  font-family: var(--font-display); font-weight: 700; font-size: clamp(1.3rem, 2.4vw, 1.8rem);
  color: var(--ink); line-height: 1.15; padding: 0; margin-bottom: 22px;
}
.pf-wiz-num {
  display: block; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--red-bright); margin-bottom: 8px;
}
.pf-wiz-options { display: flex; flex-wrap: wrap; gap: 12px; }
.pf-wiz-opt {
  cursor: pointer; font-family: var(--font-body); font-size: 0.96rem; color: var(--ink-soft);
  padding: 14px 20px; border-radius: var(--radius-sm); text-align: left;
  background: rgba(255,255,255,0.03); border: 1px solid var(--hair);
  transition: color .25s var(--ease-out), border-color .25s var(--ease-out), background .25s var(--ease-out), transform .12s var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .pf-wiz-opt:hover { color: var(--ink); border-color: var(--hair-strong); transform: translateY(-2px); }
  .pf-wiz-opt:active { transform: scale(0.97); }
}
.pf-wiz-opt.is-selected {
  color: #fff; border-color: rgba(225,30,39,0.6);
  background: linear-gradient(135deg, rgba(226,0,26,0.22), rgba(226,0,26,0.06));
  box-shadow: 0 0 0 3px rgba(226,0,26,0.12), 0 0 22px rgba(226,0,26,0.3);
}
.pf-wiz-nav {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 0 clamp(24px, 4vw, 40px) clamp(24px, 4vw, 40px);
}
.pf-wiz-nav .btn { min-width: 130px; }
.pf-wizard [hidden] { display: none !important; }

/* --- Ergebnis --- */
.pf-wiz-result { padding: clamp(24px, 4vw, 40px); }
.pf-wiz-result-head { margin-bottom: 22px; }
.pf-wiz-result-head h3 { font-size: clamp(1.5rem, 2.6vw, 2.1rem); margin: 4px 0 0; }
.pf-recs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.pf-rec {
  position: relative; display: flex; flex-direction: column; gap: 12px; padding: 22px 20px;
  border: 1px solid var(--hair); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
  animation: wizRecIn .4s var(--ease-out) both;
}
.pf-rec:nth-child(2) { animation-delay: .07s; }
.pf-rec:nth-child(3) { animation-delay: .14s; }
@keyframes wizRecIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.pf-rec.is-top { border-color: rgba(225,30,39,0.5); box-shadow: 0 0 0 1px rgba(225,30,39,0.25), 0 22px 44px -26px rgba(226,0,26,0.6); }
.pf-rec-flag {
  position: absolute; top: -10px; left: 20px; font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.12em; text-transform: uppercase; color: #fff; padding: 4px 10px; border-radius: 999px;
  background: linear-gradient(135deg, var(--red-bright), var(--red));
}
.pf-rec-head { display: flex; flex-direction: column; gap: 3px; position: relative; }
.pf-rec-head .badge2 {
  position: absolute; top: 0; right: 0; font-family: var(--font-mono); font-size: 0.56rem;
  letter-spacing: 0.16em; text-transform: uppercase; padding: 4px 9px; border-radius: 999px;
  background: rgba(225,30,39,0.16); border: 1px solid rgba(225,30,39,0.4); color: #ffb4b8;
}
.pf-rec-head h4 { font-family: var(--font-display); font-weight: 700; font-size: 1.24rem; color: var(--ink); margin: 0; padding-right: 56px; }
.pf-rec-chem { font-family: var(--font-mono); font-size: 0.66rem; color: var(--chrome-lo); }
.pf-rec .pf-kpis { margin: 0; }
.pf-rec-why { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.pf-rec-why li { position: relative; padding-left: 20px; font-size: 0.88rem; color: var(--ink-soft); line-height: 1.4; }
.pf-rec-why li::before {
  content: ""; position: absolute; left: 0; top: 6px; width: 11px; height: 7px;
  border-left: 2px solid var(--red-bright); border-bottom: 2px solid var(--red-bright); transform: rotate(-45deg);
}
.pf-rec-actions { display: flex; gap: 8px; margin-top: auto; padding-top: 4px; }
.pf-rec-actions .btn { flex: 1; padding: 11px 12px; font-size: 0.72rem; }
.pf-rec-detail { cursor: pointer; }
.pf-wiz-result-foot { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px; margin-top: 26px; }

@media (max-width: 860px) { .pf-recs { grid-template-columns: 1fr; } }
@media (prefers-reduced-motion: reduce) {
  .pf-wiz-step.is-active, .pf-rec { animation: none; }
  .pf-wiz-bar { transition: none; }
  .pf-wiz-opt:hover, .pf-wiz-opt:active { transform: none; }
}

/* ---- Header: dezentes Premium-Feedback (additiv, gilt allen Seiten) ---- */
.site-header .brand img { transition: transform .3s var(--ease-out), filter .3s var(--ease-out); }
@media (hover: hover) and (pointer: fine) {
  .site-header .brand:hover img { transform: scale(1.06) rotate(-2deg); filter: drop-shadow(0 0 14px rgba(226,0,26,0.45)); }
  .site-header .nav-cta:active { transform: scale(0.97); }
}
@media (prefers-reduced-motion: reduce) {
  .site-header .brand:hover img, .site-header .nav-cta:active { transform: none; }
}

/* ===== A11y / SEO Utility ===== */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ===== Startseite: Cine-Tagline auf Mobile nicht abschneiden ===== */
@media (max-width: 640px) {
  .cine-tag-static {
    white-space: normal;
    letter-spacing: 0.16em;
    font-size: 0.82rem;
    width: min(92vw, 380px);
    line-height: 1.55;
    bottom: 9%;
  }
}

/* ===== Team-Foto-Platzhalter (bis echte Fotos vorliegen) ===== */
.ueber-member-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ===== Breadcrumb: semantische Liste (visuell identisch) ===== */
.breadcrumb ol { list-style: none; margin: 0; padding: 0; display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.breadcrumb li { display: flex; align-items: center; gap: 10px; }
.breadcrumb li:not(:first-child)::before { content: "/"; color: var(--steel); }
.breadcrumb [aria-current="page"] { color: var(--ink-mute); }

/* ===== Formular-Status: Fehler-Variante ===== */
.form-status.err { background: rgba(225,30,39,0.12); border: 1px solid rgba(225,30,39,0.45); color: #ff9ba0; }

/* ===== Honeypot-Spamfeld (für Menschen unsichtbar, Bots füllen es) ===== */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; pointer-events: none; }

/* ===== WhatsApp-Kanal-Kachel auf der Kontaktseite ===== */
.ch-ic--wa { color: #25d366; }
.ch-ic--wa svg { fill: #25d366; stroke: none; }

/* ===== Floating WhatsApp-Button (Conversion, alle Inhaltsseiten) ===== */
.wa-fab {
  position: fixed; right: 20px; bottom: 20px; z-index: 70;
  display: grid; place-items: center;
  height: 56px; width: 56px; border-radius: 999px;
  background: #25d366; text-decoration: none;
  box-shadow: 0 10px 26px -8px rgba(0,0,0,0.6), inset 0 0 0 1px rgba(255,255,255,0.16), 0 0 22px -6px rgba(37,211,102,0.7);
  transition: transform .22s cubic-bezier(.22,1,.36,1), box-shadow .22s ease;
  animation: waFabIn .5s .8s cubic-bezier(.22,1,.36,1) both;
}
.wa-fab-ic { display: grid; place-items: center; }
.wa-fab-ic svg { width: 30px; height: 30px; fill: #fff; }
/* Sichtbares Label entfällt – Icon ist eindeutig; Text bleibt für Screenreader */
.wa-fab-label { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
@media (hover: hover) {
  .wa-fab:hover { transform: translateY(-2px) scale(1.06); box-shadow: 0 14px 30px -8px rgba(0,0,0,0.72), inset 0 0 0 1px rgba(255,255,255,0.2), 0 0 30px -4px rgba(37,211,102,0.85); }
}
.wa-fab:focus-visible { outline: 2px solid #fff; outline-offset: 3px; }
@keyframes waFabIn { from { opacity: 0; transform: translateY(14px) scale(.7); } to { opacity: 1; transform: none; } }
@media (max-width: 600px) { .wa-fab { right: 14px; bottom: 14px; height: 52px; width: 52px; } }
@media (prefers-reduced-motion: reduce) { .wa-fab { animation: none; transition: box-shadow .2s ease; } }

/* ===== Standzeit-/Kosten-Rechner (ROI, dienstleistungen.html) ===== */
.roi-card {
  max-width: 960px; margin: 0 auto; padding: clamp(20px, 4vw, 38px);
  border-radius: 18px;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(225,30,39,0.10), transparent 60%),
    linear-gradient(180deg, var(--graphite-2), var(--graphite));
  border: 1px solid rgba(255,255,255,0.07);
  box-shadow: 0 30px 60px -30px rgba(0,0,0,0.8), inset 0 1px 0 rgba(255,255,255,0.06);
}
.roi-inputs { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 22px; }
.roi-field { display: flex; flex-direction: column; gap: 8px; }
.roi-field--slider { grid-column: 1 / -1; margin-top: 4px; }
.roi-field label { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-mute); }
.roi-hint { text-transform: none; letter-spacing: 0; color: var(--steel); }
.roi-field input[type="number"] {
  width: 100%; background: rgba(0,0,0,0.35); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px; padding: 12px 14px; color: var(--ink);
  font: 600 1.05rem/1 var(--font-display, sans-serif); -moz-appearance: textfield;
}
.roi-field input[type="number"]::-webkit-outer-spin-button,
.roi-field input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.roi-field input[type="number"]:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 3px rgba(225,30,39,0.22); }
.roi-money { position: relative; display: flex; align-items: center; }
.roi-money > span { position: absolute; left: 14px; color: var(--ink-mute); font-weight: 600; pointer-events: none; }
.roi-money input { padding-left: 30px !important; }
.roi-field--slider label { display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; align-items: baseline; }
.roi-field--slider output { color: var(--red-bright); font-weight: 700; letter-spacing: 0; text-transform: none; font-size: 0.82rem; }
.roi-field--slider input[type="range"] { width: 100%; accent-color: var(--red); height: 6px; cursor: pointer; }
.roi-scale { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 0.62rem; color: var(--steel); }

.roi-results { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 26px; }
.roi-res { background: rgba(0,0,0,0.3); border: 1px solid rgba(255,255,255,0.06); border-radius: 12px; padding: 16px 18px; display: flex; flex-direction: column; gap: 6px; }
.roi-res-k { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-mute); }
.roi-res-v { font: 800 1.5rem/1 var(--font-display, sans-serif); color: var(--ink); font-variant-numeric: tabular-nums; }
.roi-res--hero {
  grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: space-between; gap: 16px;
  background: linear-gradient(160deg, rgba(225,30,39,0.16), rgba(0,0,0,0.34)); border-color: rgba(225,30,39,0.4);
}
.roi-res--hero .roi-res-k { font-size: 0.72rem; color: var(--ink-soft); }
.roi-res--hero .roi-res-v { font-size: clamp(2rem, 5vw, 2.8rem); color: #fff; text-shadow: 0 0 26px rgba(225,30,39,0.5); }

.roi-disclaimer { margin-top: 18px; font-size: 0.8rem; color: var(--ink-mute); line-height: 1.5; }
.roi-cta { margin-top: 18px; display: flex; gap: 12px; flex-wrap: wrap; }

@media (max-width: 640px) {
  .roi-inputs { grid-template-columns: 1fr; }
  .roi-results { grid-template-columns: 1fr 1fr; }
  .roi-res--hero { flex-direction: column; align-items: flex-start; gap: 6px; }
}

/* ===== Mobile-Kontaktleiste (Conversion, P1) – nur auf Mobil ===== */
.mcallbar { display: none; }
@media (max-width: 720px) {
  .mcallbar {
    display: flex; gap: 10px;
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
    padding: 9px 12px calc(9px + env(safe-area-inset-bottom, 0px));
    background: linear-gradient(180deg, rgba(8,8,10,0.86), rgba(8,8,10,0.97));
    -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
    border-top: 1px solid rgba(255,255,255,0.09);
    box-shadow: 0 -10px 30px -12px rgba(0,0,0,0.7);
  }
  .mcallbar-btn {
    flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    height: 46px; border-radius: 12px; text-decoration: none;
    font-family: var(--font-display, sans-serif); font-weight: 700; font-size: 0.98rem; letter-spacing: 0.02em;
  }
  .mcallbar-btn svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
  .mcallbar-call { color: var(--ink); border: 1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.04); }
  .mcallbar-cta { color: #fff; background: var(--red); box-shadow: 0 6px 18px -6px rgba(225,30,39,0.7); }
  /* Platz schaffen, damit die Leiste nichts verdeckt + FAB über die Leiste heben */
  body { padding-bottom: 74px; }
  .wa-fab { bottom: 80px; }
}

/* ============================================================
   P2/P3-Audit-Politur (2026-06-19, additiv – Codex-Dateien unberührt)
   ============================================================ */

/* P2.3 Touch-Targets >=44px (Best-Practice/AAA; WCAG AA=24px war bereits erfüllt).
   Rein additiv – nav-cta (.btn) ist bereits ~44px hoch und definiert die
   Header-Höhe, daher bleibt das Header-Layout unverändert. */
.nav-links a:not(.nav-cta) { min-height: 44px; display: inline-flex; align-items: center; }
.faq-tab { min-height: 44px; display: inline-flex; align-items: center; }
.pf-pill { min-height: 44px; display: inline-flex; align-items: center; }
.pf-wiz-opt { min-height: 44px; }
.sf-chip { min-height: 44px; }

/* P3.6 Sichtbarer Fokus-Ring für die Portfolio-Suche
   (styles.css setzte outline:none ohne Ersatz). */
.pf-search input:focus { box-shadow: 0 0 0 3px rgba(225,30,39,0.4); }

/* P2.4 IA: Eltern-Nav-Punkt auf Verfahrens-Unterseiten visuell aktiv markieren.
   Bewusst KEIN aria-current="page" (es ist nicht DIE Seite) – nur visuelle
   Sektions-Zugehörigkeit über die bestehende Unterstrich-Optik. */
.nav-links a.is-parent:not(.nav-cta) { color: var(--ink); }
.nav-links a.is-parent:not(.nav-cta)::after { transform: scaleX(1); }
