/* ================================================================
   NEXT MONTAGESERVICE — Design System v2.0
   Organized, token-driven, no override stacking.
   ================================================================ */

/* ================================================================
   1. DESIGN TOKENS
   ================================================================ */
:root {
  /* Brand palette */
  --cyan:     #22c7d9;
  --cyan-hi:  #5be1ec;
  --green:    #2fbf71;

  /* Neutral scale */
  --deep:       #1e2328;
  --deep-2:     #151a1e;
  --anthracite: #30373b;
  --muted:      #66727b;
  --line:       #dbe2e7;
  --soft:       #f4f6f8;
  --blueprint:  #eaf3f6;
  --paper:      #ffffff;

  /* Typography */
  --font:      'Inter', 'Segoe UI', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', 'SFMono-Regular', Consolas, monospace;

  /* Spacing (4px base) */
  --s-1:  4px;  --s-2:  8px;  --s-3: 12px;  --s-4: 16px;
  --s-5: 20px;  --s-6: 24px;  --s-7: 28px;  --s-8: 32px;
  --s-10: 40px; --s-12: 48px; --s-14: 56px; --s-16: 64px;
  --s-20: 80px; --s-24: 96px;

  /* Radii */
  --r-sm:   8px;
  --r:     14px;
  --r-lg:  20px;
  --r-pill: 999px;

  /* Shadows */
  --sh-sm: 0 4px 16px rgba(20,28,34,.08);
  --sh:    0 16px 44px rgba(20,28,34,.12);
  --sh-lg: 0 24px 70px rgba(20,28,34,.18);

  /* Layout */
  --container:  minmax(20px, 1fr) minmax(0, 1480px) minmax(20px, 1fr);
  --header-h:   116px;
}

/* ================================================================
   2. RESET & BASE
   ================================================================ */
*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 28px);
  overflow-x: hidden;
}

body {
  margin: 0;
  font-family: var(--font);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--anthracite);
  background: var(--paper);
  overflow-x: hidden;
}

body.menu-open { overflow: hidden; }

img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
p, ul, ol, dl, h1, h2, h3, h4, figure { margin: 0; }
p { color: var(--muted); }
button, input, textarea, select { font: inherit; }

:focus-visible {
  outline: 2px solid rgba(34,199,217,.65);
  outline-offset: 3px;
  border-radius: 4px;
}

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
}

/* ================================================================
   3. TYPOGRAPHY
   ================================================================ */
h1, h2, h3, h4 {
  color: var(--deep);
  line-height: 1.06;
  letter-spacing: -0.026em;
  font-weight: 760;
}

.hero-title {
  font-size: clamp(3.25rem, 5.4vw, 6.4rem);
  font-weight: 800;
  letter-spacing: -0.052em;
  max-width: 900px;
  margin-bottom: var(--s-5);
  text-wrap: balance;
}
.hero-title span { display: block; }

.page-title {
  font-size: clamp(2.8rem, 4.8vw, 5.4rem);
  font-weight: 780;
  letter-spacing: -0.044em;
  max-width: 980px;
  margin-bottom: var(--s-5);
  text-wrap: balance;
}

.section-title {
  font-size: clamp(2rem, 3.1vw, 3.7rem);
  font-weight: 760;
  letter-spacing: -0.032em;
  margin-bottom: var(--s-4);
  text-wrap: balance;
}

.recognition-title {
  font-size: clamp(1.9rem, 2.9vw, 3.4rem);
  font-weight: 760;
  letter-spacing: -0.032em;
  text-wrap: balance;
}

.detail-title {
  font-size: clamp(1.8rem, 2.6vw, 3.1rem);
  font-weight: 760;
  letter-spacing: -0.03em;
  margin-bottom: var(--s-4);
  text-wrap: balance;
}

.card-title  { font-size: clamp(1.25rem, 1.7vw, 1.7rem); font-weight: 760; margin-bottom: var(--s-3); }
.note-title  { font-size: clamp(1.4rem, 1.9vw, 2rem);    margin-bottom: var(--s-3); }
h3           { font-size: clamp(1.1rem, 1.5vw, 1.4rem);  font-weight: 730; margin-bottom: var(--s-3); }

/* Mono label system — applied once, no repetition */
.eyebrow, .card-label, .timeline span, .value-card span, .proof-card span,
.response-badge, .site-footer strong, label > span,
.hero-proof-strip, .leistung-badge-row span,
.service-card-media figcaption, .leistung-proof-strip figcaption,
.media-tile figcaption, .regional-meta span, .doc-status-card,
.leistung-primary-media figcaption span {
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .065em;
}

.eyebrow {
  display: block;
  margin-bottom: var(--s-4);
  color: var(--cyan);
  font-size: .73rem;
  font-weight: 700;
}

.eyebrow-strong {
  display: inline-flex;
  align-items: center;
  padding: var(--s-1) var(--s-3);
  color: var(--deep);
  background: rgba(34,199,217,.14);
  border: 1px solid rgba(34,199,217,.28);
  border-radius: var(--r-pill);
}

.hero-subline, .lead-copy p, .lead-statement {
  font-size: clamp(1.06rem, 1.3vw, 1.3rem);
  line-height: 1.6;
}

/* ================================================================
   4. LAYOUT
   ================================================================ */
.section, .hero, .page-hero-section, .site-footer {
  display: grid;
  grid-template-columns: var(--container);
}
.section > *, .hero > *, .page-hero-section > *, .site-footer > * { grid-column: 2; }

.section       { padding: 100px 0; }
.section-light { background: var(--soft); }

.section-dark {
  color: var(--paper);
  background:
    radial-gradient(circle at 78% 12%, rgba(34,199,217,.15), transparent 30%),
    linear-gradient(90deg, rgba(34,199,217,.07) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.06) 1px, transparent 1px),
    var(--deep);
  background-size: auto, 56px 56px, 56px 56px, auto;
}
.section-dark h1, .section-dark h2, .section-dark h3, .section-dark h4, .section-dark p { color: var(--paper); }

.section-grid  { display: grid; }
.section-heading { max-width: 980px; margin-bottom: var(--s-12); }
.narrow-heading  { max-width: 820px; }

.intro-grid, .about-intro-grid {
  grid-template-columns: .88fr 1.12fr;
  gap: var(--s-20);
  align-items: center;
}
.compact-intro { align-items: center; }

/* ================================================================
   5. HEADER & NAVIGATION
   ================================================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  overflow: visible;
  display: grid;
  grid-template-columns: minmax(160px, 180px) 1fr;
  align-items: center;
  height: var(--header-h);
  padding: 0 clamp(20px, 3vw, 52px);
  color: var(--paper);
  background:
    linear-gradient(90deg, rgba(34,199,217,.09) 0%, transparent 36%, rgba(34,199,217,.06) 100%),
    rgba(21,26,30,.56);
  border-bottom: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 20px 54px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.16);
  backdrop-filter: blur(22px) saturate(1.3);
  -webkit-backdrop-filter: blur(22px) saturate(1.3);
  transition: height .28s ease, background .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.site-header::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(34,199,217,.72), transparent);
  pointer-events: none;
}

.site-header.is-scrolled {
  height: 106px;
  align-items: start;
  color: var(--deep);
  background:
    linear-gradient(90deg, rgba(34,199,217,.09), transparent 40%, rgba(34,199,217,.05)),
    rgba(255,255,255,.9);
  border-bottom-color: rgba(30,35,40,.1);
  box-shadow: 0 12px 36px rgba(20,28,34,.13), inset 0 1px 0 rgba(255,255,255,.9);
}

.brand {
  display: flex;
  align-items: center;
  height: 100%;
  padding-right: var(--s-6);
  border-right: 1px solid rgba(255,255,255,.16);
  transition: border-color .28s ease;
}
.site-header.is-scrolled .brand {
  align-self: start;
  height: auto;
  padding-top: 2px;
  border-right-color: rgba(30,35,40,.12);
}
.site-header.is-scrolled .site-nav {
  align-self: center;
}

.brand img { object-fit: contain; transition: opacity .22s ease; }
.brand .logo-white { display: block; width: 176px; height: 106px; }
.brand .logo-color  { display: none;  width: 160px; height: 96px;  }
.site-header.is-scrolled .brand .logo-white { display: none; }
.site-header.is-scrolled .brand .logo-color  { display: block; }

.site-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-1);
  padding-left: var(--s-6);
  font-size: .875rem;
  font-weight: 720;
}

.site-nav a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: var(--s-2) var(--s-3);
  border-radius: var(--r-pill);
  opacity: .92;
  transition: color .16s, background .16s, transform .16s;
}
.site-nav a:hover, .site-nav a.is-active {
  color: var(--deep);
  background: rgba(255,255,255,.82);
}
.site-header.is-scrolled .site-nav a:hover,
.site-header.is-scrolled .site-nav a.is-active {
  color: var(--deep);
  background: rgba(34,199,217,.14);
}
.site-nav .nav-cta {
  color: var(--soft);
  background: var(--deep);
  border: 1px solid rgba(255,255,255,.18);
  font-weight: 780;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 6px 20px rgba(0,0,0,.32);
}
.site-nav .nav-cta:hover { color: var(--cyan); background: var(--anthracite); transform: translateY(-1px); }
.site-header.is-scrolled .site-nav .nav-cta {
  color: var(--paper);
  background: var(--deep);
  border-color: rgba(30,35,40,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 4px 14px rgba(0,0,0,.18);
}
.site-header.is-scrolled .site-nav .nav-cta:hover { color: var(--cyan); background: var(--anthracite); }

.menu-toggle { display: none; }

/* ================================================================
   6. HERO — VIDEO STAGE
   ================================================================ */
.hero-video-stage {
  position: relative;
  min-height: 92svh;
  padding: calc(var(--header-h) + 64px) 0 var(--s-20);
  overflow: hidden;
  isolation: isolate;
  background: var(--deep-2);
}

.hero-video-stage > .hero-media {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-background-video {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .9;
  filter: saturate(1.02) contrast(1.02);
}

.hero-video-stage::after {
  position: absolute;
  inset: 0;
  z-index: 1;
  content: '';
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(14,19,23,.94) 0%, rgba(14,19,23,.82) 34%, rgba(14,19,23,.38) 70%, rgba(14,19,23,.12) 100%),
    linear-gradient(0deg, rgba(14,19,23,.48), rgba(14,19,23,.04) 46%, rgba(14,19,23,.46));
}

.hero-video-stage .hero-overlay-grid {
  position: relative;
  z-index: 2;
  min-height: calc(92svh - var(--header-h) - 120px);
  align-items: center;
}

.hero-copy-overlay { max-width: 780px; }

.hero-video-stage .hero-title,
.hero-video-stage .hero-subline,
.hero-video-stage .hero-value,
.hero-video-stage .eyebrow { color: var(--paper); }

/* Copy reveal (JS adds classes) */
.hero-video-stage.is-video-intro .hero-copy-overlay {
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
  transition: opacity .78s ease, transform .78s ease;
}
.hero-video-stage.is-copy-visible .hero-copy-overlay {
  opacity: 1; transform: none; pointer-events: auto;
}

.hero-accent-line {
  display: block;
  width: min(340px, 70%);
  height: 2px;
  margin: var(--s-8) 0 0;
  transform-origin: left center;
  background: linear-gradient(90deg, var(--cyan), rgba(34,199,217,0));
}
.hero-video-stage.is-copy-visible .hero-accent-line {
  animation: accentDraw 1.2s ease .2s both;
}
.hero-video-stage.is-video-intro:not(.is-copy-visible) .hero-accent-line {
  transform: scaleX(.06); opacity: .3;
}
@keyframes accentDraw {
  from { transform: scaleX(.06); opacity: .3; }
  to   { transform: scaleX(1);   opacity: 1; }
}

.hero-value {
  width: fit-content;
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  color: rgba(255,255,255,.82);
  border-top: 2px solid var(--cyan);
  font-weight: 760;
}

/* Proof strip under CTAs */
.hero-proof-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-6);
  font-size: .71rem;
  letter-spacing: .05em;
}
.hero-proof-strip span {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-2) var(--s-3);
  color: rgba(255,255,255,.84);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,.07);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.hero-proof-strip strong { color: var(--cyan); font-weight: 800; }

/* ================================================================
   7. BUTTONS
   ================================================================ */
.button-row { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-8); }

.button {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  min-height: 50px;
  padding: var(--s-3) var(--s-6);
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  font-weight: 800;
  cursor: pointer;
  transition: transform .16s ease, background .16s ease, box-shadow .16s ease;
}
.button:hover { transform: translateY(-2px); }

.button-primary {
  color: var(--deep);
  background: var(--cyan);
  box-shadow: inset 0 -2px 0 rgba(0,0,0,.1), 0 12px 28px rgba(34,199,217,.28);
}
.button-primary:hover {
  background: var(--cyan-hi);
  box-shadow: inset 0 -2px 0 rgba(0,0,0,.1), 0 18px 38px rgba(34,199,217,.36);
}

.button-secondary {
  color: var(--paper);
  border-color: rgba(255,255,255,.3);
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(10px);
}
.button-secondary:hover { background: rgba(255,255,255,.1); }

.button-mark {
  width: 10px; height: 10px;
  display: inline-block;
  flex-shrink: 0;
  border: 2px solid currentColor;
  border-left-color: transparent;
  transform: rotate(45deg);
}

.text-link {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  margin-top: var(--s-6);
  color: var(--deep);
  font-weight: 800;
  transition: gap .16s ease;
}
.text-link::after { content: '→'; color: var(--cyan); }
.text-link:hover { gap: var(--s-3); }

.card-cta {
  display: block;
  margin-top: auto;
  padding-top: var(--s-4);
  color: var(--deep);
  font-weight: 800;
}
.card-cta::after { content: ' →'; color: var(--cyan); }

/* ================================================================
   8. SERVICE CARDS (HOME)
   ================================================================ */
.service-grid-home { grid-template-columns: repeat(2, 1fr); gap: var(--s-5); }

.service-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.service-card:hover { transform: translateY(-4px); border-color: rgba(34,199,217,.75); box-shadow: var(--sh); }

.service-card > div:last-child {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: var(--s-8);
  min-height: clamp(270px, 22vw, 320px);
}
.card-label { display: inline-block; margin-bottom: var(--s-4); color: var(--cyan); font-size: .71rem; }
.service-card h3 { margin-bottom: var(--s-3); }
.service-card p { line-height: 1.58; }

/* Card photo */
.service-card-media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3/2;
  background: var(--deep-2);
  isolation: isolate;
}
.service-card-media::after {
  position: absolute; inset: 0; z-index: 1;
  content: '';
  pointer-events: none;
  background:
    linear-gradient(0deg, rgba(14,19,23,.6) 0%, rgba(14,19,23,.05) 48%, transparent),
    linear-gradient(90deg, rgba(34,199,217,.1), transparent 44%);
}
.service-card-media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform .42s ease, filter .42s ease;
}
.service-card:hover .service-card-media img { transform: scale(1.05); filter: contrast(1.04) saturate(1.04); }

.service-card-media figcaption {
  position: absolute;
  left: var(--s-4); bottom: var(--s-3);
  z-index: 2;
  padding: 6px var(--s-3);
  color: #eef8fa;
  background: rgba(14,19,23,.72);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--r-pill);
  backdrop-filter: blur(12px);
  font-size: .64rem;
  line-height: 1.2;
}

/* ================================================================
   9. PROOF SECTION
   ================================================================ */
.proof-grid { grid-template-columns: repeat(4, 1fr); gap: var(--s-4); }

.proof-card {
  padding: var(--s-8);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.proof-card strong { display: block; color: var(--deep); font-size: clamp(1.3rem, 2vw, 2rem); line-height: 1.06; }
.proof-card span   { display: block; margin-top: var(--s-3); font-size: .76rem; }

.proof-card-counter {
  background: linear-gradient(135deg, #fff, #edf8fa);
  border-color: rgba(34,199,217,.3);
  box-shadow: var(--sh-sm);
}
.proof-card-counter strong { font-size: clamp(3.5rem, 6vw, 6.4rem); line-height: .9; letter-spacing: -.07em; }
.proof-card-counter .counter { display: inline; color: inherit; font: inherit; }

.proof-visual-grid { grid-template-columns: 1.1fr .9fr; gap: var(--s-5); margin-top: var(--s-6); align-items: stretch; }
.calm-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }

/* Regional panel */
.regional-proof-panel {
  position: relative;
  overflow: hidden;
  min-height: 420px;
  display: grid;
  align-content: end;
  padding: clamp(24px, 3vw, 34px);
  color: var(--paper);
  background:
    radial-gradient(circle at 66% 24%, rgba(34,199,217,.2), transparent 26%),
    linear-gradient(90deg, rgba(34,199,217,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.07) 1px, transparent 1px),
    linear-gradient(145deg, #151a1e, #263138);
  background-size: auto, 38px 38px, 38px 38px, auto;
  border: 1px solid rgba(34,199,217,.22);
  border-radius: var(--r);
  box-shadow: var(--sh);
}
.regional-proof-panel::before {
  position: absolute;
  inset: 16px;
  content: '';
  border: 1px solid rgba(255,255,255,.07);
  border-radius: calc(var(--r) - 4px);
  pointer-events: none;
}
.regional-map { position: absolute; inset: 24px 24px 120px; }
.region-line  { position: absolute; height: 2px; background: linear-gradient(90deg, transparent, rgba(34,199,217,.8), transparent); }
.line-one { left: 12%; right: 10%; top: 48%; transform: rotate(-16deg); }
.line-two { left: 18%; right: 18%; top: 64%; transform: rotate(12deg); opacity: .65; }
.region-pin { position: absolute; width: 13px; height: 13px; border-radius: var(--r-pill); background: var(--cyan); box-shadow: 0 0 0 6px rgba(34,199,217,.14), 0 0 26px rgba(34,199,217,.7); }
.pin-one { left: 18%; top: 50%; } .pin-two { left: 42%; top: 34%; }
.pin-three { left: 58%; top: 56%; } .pin-four { left: 73%; top: 42%; } .pin-five { left: 32%; top: 69%; }
.regional-panel-copy { position: relative; z-index: 2; }
.regional-panel-copy h3 { color: var(--paper); }
.regional-panel-copy p  { color: rgba(255,255,255,.72); }
.regional-meta { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-top: var(--s-4); }
.regional-meta span {
  padding: 5px var(--s-3);
  color: rgba(255,255,255,.8);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r-pill);
  font-size: .66rem;
}

/* Media tiles (proof gallery) */
.media-tile {
  position: relative;
  overflow: hidden;
  border-radius: var(--r);
  background: var(--deep-2);
  isolation: isolate;
}
.media-tile::after {
  position: absolute; inset: 0;
  content: '';
  pointer-events: none;
  background: linear-gradient(0deg, rgba(14,19,23,.5) 0%, transparent 48%);
}
.media-tile img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; transition: transform .42s ease; }
.media-tile:hover img { transform: scale(1.04); }
.media-tile figcaption {
  position: absolute;
  left: var(--s-4); bottom: var(--s-3);
  z-index: 2;
  padding: 5px var(--s-3);
  color: #eef8fa;
  background: rgba(14,19,23,.7);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--r-pill);
  backdrop-filter: blur(10px);
  font-size: .63rem;
}

/* Media cards (larger featured) */
.media-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--r);
  background: var(--deep-2);
  box-shadow: var(--sh);
}
.media-card img { width: 100%; height: 100%; object-fit: cover; }
.media-card figcaption {
  position: absolute;
  left: var(--s-6); right: var(--s-6); bottom: var(--s-6);
  z-index: 2;
  display: grid;
  gap: var(--s-2);
  max-width: 560px;
  padding: var(--s-4);
  color: var(--paper);
  background: rgba(14,19,23,.78);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: calc(var(--r) - 4px);
  backdrop-filter: blur(16px);
}
.media-card figcaption span   { color: var(--cyan); font-size: .67rem; }
.media-card figcaption strong { color: var(--paper); font-size: clamp(.95rem, 1.2vw, 1.14rem); line-height: 1.3; }
.detail-media-card  { aspect-ratio: 16/10; min-height: clamp(340px, 35vw, 500px); }
.documentation-media { min-height: clamp(300px, 30vw, 420px); }
.contact-proof-media { min-height: 240px; }

/* ================================================================
   10. CTA DARK SECTION
   ================================================================ */
.final-cta { padding: 92px 0; }
.final-cta-grid { grid-template-columns: 1fr .75fr; gap: var(--s-20); align-items: center; }
.cta-panel {
  padding: var(--s-8);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r);
  background: rgba(255,255,255,.055);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.1);
}
.cta-panel p { margin-bottom: var(--s-6); }

/* ================================================================
   11. TAGS, BADGES, STATUS
   ================================================================ */
.tag-list { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-6); }
.tag-list a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: var(--s-2) var(--s-3);
  color: var(--deep);
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(30,35,40,.12);
  border-radius: var(--r-pill);
  font-weight: 740;
  box-shadow: var(--sh-sm);
  transition: transform .16s, border-color .16s, background .16s;
}
.tag-list a:hover { transform: translateY(-2px); border-color: rgba(34,199,217,.7); background: rgba(34,199,217,.12); }

.response-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-3);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,.06);
  font-size: .73rem;
  color: rgba(255,255,255,.84);
  margin-top: var(--s-6);
}
.response-badge-light {
  color: #d8ffe8;
  background: rgba(21,90,55,.92);
  border-color: rgba(47,191,113,.62);
  font-weight: 760;
  margin-top: var(--s-4);
}

.status-dot {
  display: inline-block;
  width: 8px; height: 8px;
  flex-shrink: 0;
  border-radius: var(--r-pill);
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(47,191,113,.15);
}

/* ================================================================
   12. LEISTUNGEN — STICKY CHAPTER LAYOUT
   ================================================================ */
.leistungen-showcase-section { padding-top: 60px; padding-bottom: 60px; }

.showcase-intro-grid {
  grid-template-columns: 1fr 1fr;
  gap: var(--s-12);
  align-items: end;
  margin-bottom: var(--s-12);
}
.showcase-intro-grid p { font-size: 1.05rem; }

.leistung-chapter-stack { gap: 0; }

.leistung-chapter {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-16);
  align-items: start;
  padding: 72px 0;
  border-top: 1px solid var(--line);
}
.leistung-chapter:last-child { border-bottom: 1px solid var(--line); }

/* Sticky media dock */
.leistung-media-dock {
  position: sticky;
  top: calc(var(--header-h) + 20px);
  display: grid;
  gap: var(--s-3);
  min-width: 0;
}

/* Primary proof image */
.leistung-primary-media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
  border-radius: var(--r);
  background: var(--deep-2);
  margin: 0;
  isolation: isolate;
}
.leistung-primary-media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .44s ease;
}
.leistung-chapter:hover .leistung-primary-media img { transform: scale(1.025); }
.leistung-primary-media::after {
  position: absolute; inset: 0;
  content: '';
  pointer-events: none;
  background:
    linear-gradient(0deg, rgba(14,19,23,.72) 0%, rgba(14,19,23,.06) 46%, transparent),
    linear-gradient(90deg, rgba(34,199,217,.1), transparent 52%);
}
.leistung-primary-media figcaption {
  position: absolute;
  left: var(--s-5); right: var(--s-5); bottom: var(--s-5);
  z-index: 2;
  display: grid;
  gap: var(--s-2);
  padding: var(--s-4);
  color: var(--paper);
  background: rgba(14,19,23,.76);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: calc(var(--r) - 3px);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.leistung-primary-media figcaption span {
  color: var(--cyan);
  font-size: .66rem;
}
.leistung-primary-media figcaption strong {
  color: var(--paper);
  font-size: clamp(.9rem, 1.1vw, 1.08rem);
  font-weight: 700;
  line-height: 1.32;
}

/* Secondary proof thumbnails */
.leistung-proof-strip { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }
.leistung-proof-strip figure {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3/2;
  border-radius: var(--r-sm);
  background: var(--deep-2);
  margin: 0;
  isolation: isolate;
}
.leistung-proof-strip figure::after {
  position: absolute; inset: 0;
  content: '';
  background: linear-gradient(0deg, rgba(14,19,23,.52) 0%, transparent 52%);
}
.leistung-proof-strip img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.leistung-proof-strip figure:hover img { transform: scale(1.04); }
.leistung-proof-strip figcaption {
  position: absolute;
  left: var(--s-3); bottom: var(--s-2);
  z-index: 2;
  color: rgba(255,255,255,.88);
  font-size: .62rem;
}

/* Copy panel */
.leistung-copy-panel { padding-top: var(--s-2); min-width: 0; }

.leistung-lead {
  font-size: clamp(1.02rem, 1.24vw, 1.18rem);
  line-height: 1.62;
  margin-bottom: var(--s-6);
}

.leistung-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin: var(--s-5) 0 var(--s-8);
}
.leistung-badge-row span {
  padding: var(--s-1) var(--s-3);
  color: var(--deep);
  background: rgba(34,199,217,.1);
  border: 1px solid rgba(34,199,217,.28);
  border-radius: var(--r-pill);
  font-size: .68rem;
}

.leistung-scope-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}
.leistung-scope-grid article {
  padding: var(--s-5);
  background: var(--soft);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
}
.leistung-scope-grid h3 { font-size: 1rem; margin-bottom: var(--s-2); }
.leistung-scope-grid p  { font-size: .9rem; }
.leistung-check-list { margin-bottom: var(--s-6); }

/* ================================================================
   13. JUMPBAR & OVERVIEW
   ================================================================ */
.service-overview-section { padding: 28px 0; }
.leistungen-jumpbar { grid-template-columns: repeat(5, 1fr); }
.overview-grid { grid-template-columns: repeat(4, 1fr); gap: var(--s-3); }

.leistungen-jumpbar a, .overview-grid a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60px;
  padding: var(--s-3);
  color: var(--deep);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  font-weight: 760;
  font-size: .88rem;
  text-align: center;
  line-height: 1.3;
  transition: transform .16s, border-color .16s, background .16s;
}
.leistungen-jumpbar a:hover, .overview-grid a:hover {
  transform: translateY(-2px);
  border-color: rgba(34,199,217,.7);
  background: rgba(34,199,217,.09);
}

/* ================================================================
   14. PAGE HEROES
   ================================================================ */
.page-hero-section { padding: calc(var(--header-h) + 88px) 0 80px; }
.compact-page-hero { max-width: 1040px; }
.page-hero p { font-size: clamp(1.04rem, 1.28vw, 1.28rem); max-width: 780px; line-height: 1.62; }
.hero-value.page-value { color: rgba(255,255,255,.82); margin-top: var(--s-8); }
.contact-hero .response-badge { margin-top: var(--s-6); }

/* ================================================================
   15. CHECK LIST
   ================================================================ */
.check-list { display: grid; gap: var(--s-3); padding: 0; list-style: none; margin-top: var(--s-5); }
.check-list li { position: relative; padding-left: 20px; color: var(--muted); font-size: .96rem; }
.check-list li::before { position: absolute; left: 0; top: .8em; width: 8px; height: 2px; content: ''; background: var(--cyan); }
.compact-list { margin-top: 0; margin-bottom: var(--s-5); }

/* ================================================================
   16. ÜBER UNS — IDENTITY, VALUE, PROOF
   ================================================================ */
.identity-grid { grid-template-columns: 1.1fr .95fr .95fr; gap: var(--s-4); }
.identity-card {
  padding: var(--s-8);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.identity-dark {
  color: var(--paper);
  background: var(--deep);
  background-image:
    linear-gradient(90deg, rgba(34,199,217,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.07) 1px, transparent 1px);
  background-size: 42px 42px;
}
.identity-dark h2, .identity-dark p { color: var(--paper); }

.value-grid  { grid-template-columns: repeat(3, 1fr); gap: var(--s-4); }
.four-values { grid-template-columns: repeat(4, 1fr); }
.value-card  { padding: var(--s-8); background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); }
.value-card span { display: inline-block; margin-bottom: var(--s-6); color: var(--cyan); font-size: .76rem; }

.proof-about-grid { grid-template-columns: .85fr 1.15fr; gap: var(--s-16); align-items: center; }
.compact-proof-grid { grid-template-columns: repeat(2, 1fr); }

.partner-mini-grid { grid-template-columns: .9fr 1.1fr; gap: var(--s-14); align-items: start; }
.partner-card { padding: var(--s-8); background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); }

/* About visual proof stack */
.about-visual-grid { grid-template-columns: 1fr 1fr; gap: var(--s-16); align-items: start; }
.about-visual-stack { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }
.media-tile-large { grid-column: 1 / -1; }
.media-tile-large img { width: 100%; aspect-ratio: 16/7; }

/* ================================================================
   17. TIMELINE & DOCUMENTATION
   ================================================================ */
.timeline { grid-template-columns: repeat(5, 1fr); gap: var(--s-4); }
.timeline article { padding: var(--s-7); background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); }
.timeline span { display: inline-block; margin-bottom: var(--s-6); color: var(--cyan); font-size: .76rem; }
.timeline h3 { font-size: clamp(1rem, 1.1vw, 1.2rem); line-height: 1.2; }
.timeline p  { font-size: .92rem; line-height: 1.55; }

.doc-output-grid { grid-template-columns: .82fr 1.18fr; gap: var(--s-14); align-items: center; margin-top: var(--s-14); }
.documentation-panel { position: relative; }

.doc-status-card {
  position: absolute;
  right: var(--s-5); bottom: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-4);
  color: var(--paper);
  background: rgba(21,26,30,.88);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--r-sm);
  backdrop-filter: blur(14px);
  font-size: .7rem;
  letter-spacing: .06em;
}
.doc-status-card strong { color: var(--cyan); }
.doc-status-card ul {
  display: grid;
  gap: 6px;
  padding: 0;
  list-style: none;
  margin: var(--s-2) 0 0;
  color: rgba(255,255,255,.78);
  text-transform: none;
  letter-spacing: 0;
  font-family: var(--font);
  font-size: .82rem;
}

.interface-note-section { padding-top: 0; }
.slim-note {
  max-width: 980px;
  padding: var(--s-8);
  border-left: 3px solid var(--cyan);
  background: var(--soft);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
}
.note-box { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); }

.small-scope-card {
  margin-top: var(--s-6);
  padding: var(--s-6);
  border-left: 3px solid var(--cyan);
  background: var(--soft);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
}
.scope-note { font-size: .9rem; }

/* ================================================================
   18. FORMS
   ================================================================ */
.contact-form-section { padding-top: 80px; }
.contact-page-grid { grid-template-columns: 1.1fr .7fr; gap: var(--s-10); align-items: start; }

.themed-form {
  padding: var(--s-8);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--sh);
}
.form-header { padding-bottom: var(--s-6); margin-bottom: var(--s-6); border-bottom: 1px solid var(--line); }
.form-header h2 { margin: 0 0 var(--s-2); font-size: clamp(1.6rem, 2.1vw, 2.3rem); }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }

label { display: grid; gap: var(--s-2); color: var(--deep); font-weight: 700; }
label > span { color: var(--muted); font-size: .67rem; text-transform: uppercase; letter-spacing: .04em; }

input, select, textarea {
  width: 100%;
  color: var(--deep);
  background: var(--soft);
  border: 1px solid #cfd8de;
  border-radius: var(--r-sm);
  padding: var(--s-3) var(--s-4);
  transition: border .16s, background .16s, box-shadow .16s;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--cyan);
  background: var(--paper);
  box-shadow: 0 0 0 4px rgba(34,199,217,.1);
}
.full-field { margin-top: var(--s-4); }
textarea { resize: vertical; min-height: 180px; }
.required-mark { color: var(--cyan); font-style: normal; font-weight: 900; }
input::placeholder, textarea::placeholder { color: #9aa7ae; }
select:invalid { color: #9aa7ae; }

.consent-field {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: var(--s-3);
  align-items: start;
  margin: var(--s-4) 0 var(--s-5);
  padding: var(--s-4);
  background: var(--soft);
  border: 1px solid #d8e1e6;
  border-radius: var(--r-sm);
  color: var(--muted);
  font-weight: 600;
}
.consent-field input { width: 18px; height: 18px; margin: 2px 0 0; accent-color: var(--cyan); }
.consent-field span { font-size: .88rem; line-height: 1.45; }
.consent-field a { color: var(--deep); font-weight: 800; text-decoration: underline; text-decoration-color: rgba(34,199,217,.6); text-underline-offset: 3px; }
.consent-field:focus-within { border-color: var(--cyan); box-shadow: 0 0 0 4px rgba(34,199,217,.1); }

.technical-note {
  display: flex;
  gap: var(--s-3);
  align-items: flex-start;
  margin: var(--s-4) 0 var(--s-5);
  padding: var(--s-4);
  background: var(--blueprint);
  border: 1px solid rgba(34,199,217,.22);
  border-radius: var(--r-sm);
}
.technical-note p { margin: 0; font-size: .93rem; font-family: var(--font); text-transform: none; letter-spacing: 0; }
.note-dot { width: 10px; height: 10px; flex-shrink: 0; margin-top: 6px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 0 5px rgba(34,199,217,.12); }
.form-submit { width: 100%; }

.contact-aside { display: grid; gap: var(--s-4); }
.contact-card, .helper-card {
  padding: var(--s-8);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
}
.contact-card-strong {
  color: var(--paper);
  background: var(--deep);
  background-image:
    linear-gradient(90deg, rgba(34,199,217,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.07) 1px, transparent 1px);
  background-size: 42px 42px;
}
.contact-card-strong p, .contact-card-strong a, .contact-card-strong span { color: var(--paper); }
.contact-card span { display: block; font-size: 1.2rem; font-weight: 800; }
.contact-card a { display: block; margin-top: var(--s-3); font-weight: 760; }

/* ================================================================
   19. FOOTER
   ================================================================ */
.site-footer { padding: var(--s-16) 0; background: var(--paper); border-top: 1px solid var(--line); }
.footer-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: var(--s-14); }
.footer-logo { width: 200px; height: auto; object-fit: contain; margin-bottom: var(--s-4); }
.footer-claim { color: var(--deep); font-weight: 800; margin-bottom: var(--s-2); }
.footer-value { max-width: 400px; font-size: .94rem; }
.site-footer nav { display: grid; gap: var(--s-3); align-content: start; }
.site-footer strong { margin-bottom: var(--s-1); color: var(--deep); font-size: .73rem; }
.site-footer a { color: var(--muted); font-size: .93rem; transition: color .16s; }
.site-footer a:hover { color: var(--cyan); }

/* ================================================================
   20. LEGAL
   ================================================================ */
.legal-section { padding-top: 60px; }
.legal-shell { max-width: 920px; padding: var(--s-10); background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); }
.legal-shell h2, .legal-shell h3 { margin-top: var(--s-8); }

/* ================================================================
   21. RESPONSIVE — 1240px
   ================================================================ */
@media (max-width: 1240px) {
  .hero-video-stage .hero-overlay-grid { grid-template-columns: 1fr; }
  .intro-grid, .about-intro-grid,
  .proof-visual-grid, .final-cta-grid,
  .doc-output-grid, .identity-grid,
  .proof-about-grid, .partner-mini-grid,
  .contact-page-grid, .about-visual-grid { grid-template-columns: 1fr; }

  .proof-grid, .four-values { grid-template-columns: repeat(2, 1fr); }
  .overview-grid { grid-template-columns: repeat(2, 1fr); }
  .timeline { grid-template-columns: repeat(2, 1fr); }

  /* Leistungen: unstick on mid breakpoint */
  .leistung-chapter { grid-template-columns: 1fr; gap: var(--s-8); }
  .leistung-media-dock { position: static; }
  .showcase-intro-grid { grid-template-columns: 1fr; }
  .leistungen-jumpbar { grid-template-columns: repeat(3, 1fr); }
}

/* ================================================================
   22. RESPONSIVE — 980px (tablet/hamburger)
   ================================================================ */
@media (max-width: 980px) {
  html { scroll-padding-top: 96px; }
  :root { --container: 18px minmax(0, calc(100vw - 36px)) 18px; }
  .section { padding: 78px 0; }
  .page-hero-section { padding-top: calc(var(--header-h) + 68px); }

  /* Mobile header */
  .site-header {
    grid-template-columns: auto auto;
    justify-content: space-between;
    padding-inline: var(--s-4);
    height: 94px;
    --header-h: 94px;
  }
  .site-header.is-scrolled { height: 82px; }
  .brand { border-right: none; padding-right: 0; }
  .brand .logo-white { width: 140px; height: 84px; }
  .brand .logo-color  { width: 128px; height: 77px; }

  /* Hamburger button */
  .menu-toggle {
    display: grid;
    place-items: center;
    width: 48px; height: 48px;
    padding: 0;
    color: inherit;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.24);
    border-radius: var(--r-sm);
    cursor: pointer;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }
  .menu-toggle span:not(.sr-only) { display: block; width: 20px; height: 2px; background: currentColor; border-radius: 2px; }
  .site-header.is-scrolled .menu-toggle { background: rgba(30,35,40,.06); border-color: rgba(30,35,40,.14); }

  .site-nav {
    position: absolute;
    top: calc(100% + 8px);
    left: var(--s-3); right: var(--s-3);
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: var(--s-2);
    padding: var(--s-3);
    color: var(--deep);
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(30,35,40,.1);
    border-radius: var(--r-lg);
    box-shadow: 0 22px 52px rgba(20,28,34,.18);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
  }
  .site-nav.is-open { display: flex; }
  .site-nav a { min-height: 48px; justify-content: center; color: var(--deep); }
  .site-nav a:hover, .site-nav a.is-active { background: rgba(34,199,217,.13); }
  .site-nav .nav-cta { background: var(--cyan); }

  .hero-video-stage { padding-top: calc(var(--header-h) + 48px); }
  .service-grid-home { grid-template-columns: 1fr; }
  .value-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid, .form-grid { grid-template-columns: 1fr; }
  .calm-gallery { grid-template-columns: 1fr 1fr; }
  .about-visual-stack { grid-template-columns: 1fr; }
  .timeline { grid-template-columns: 1fr; }
  .leistung-scope-grid { grid-template-columns: 1fr; }
}

/* ================================================================
   23. RESPONSIVE — 620px (phone)
   ================================================================ */
@media (max-width: 620px) {
  :root { --container: 16px minmax(0, calc(100vw - 32px)) 16px; }
  .section { padding: 64px 0; }
  .hero-video-stage .hero-title { font-size: clamp(2.2rem, 10.5vw, 3.25rem); }
  .button-row .button { width: 100%; }
  .proof-grid, .compact-proof-grid { grid-template-columns: 1fr; }
  .leistungen-jumpbar, .overview-grid { grid-template-columns: 1fr 1fr; }
  .themed-form, .contact-card, .helper-card { padding: var(--s-6); }
  .footer-grid { gap: var(--s-8); }
  .identity-grid { grid-template-columns: 1fr; }
  .leistung-proof-strip { grid-template-columns: 1fr 1fr; }
}

/* ================================================================
   24. ACCESSIBILITY & MOTION
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  .hero-background-video { display: none; }
  .hero-video-stage {
    background: url('../video/hero-video-poster.jpg') center/cover no-repeat, var(--deep-2);
  }
  .hero-accent-line { animation: none !important; transform: none !important; opacity: 1 !important; }
  .hero-video-stage.is-video-intro .hero-copy-overlay {
    opacity: 1 !important; transform: none !important; pointer-events: auto !important;
  }
}


/* ================================================================
   LEISTUNGEN V3 — CLEAN SERVICE HIERARCHY
   Two primary service worlds + compact support models.
   ================================================================ */
.leistungen-hero-v3 .button-secondary {
  color: var(--paper);
  border-color: rgba(255,255,255,.34);
  background: rgba(255,255,255,.08);
}
.leistungen-hero-v3 .button-secondary:hover { background: rgba(255,255,255,.14); }

.leistungen-jumpbar-v3 { grid-template-columns: repeat(5, minmax(0, 1fr)); }

.anchor-offset {
  position: relative;
  top: calc(-1 * (var(--header-h) + 28px));
  display: block;
  height: 0;
  overflow: hidden;
  visibility: hidden;
}


.leistungen-principle-section { padding-top: 90px; padding-bottom: 82px; }
.leistungen-principle-grid {
  grid-template-columns: .95fr 1.05fr;
  gap: var(--s-16);
  align-items: end;
}
.principle-copy { display: grid; gap: var(--s-6); }
.principle-points {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
}
.principle-points span,
.mini-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: var(--s-1) var(--s-3);
  color: var(--deep);
  background: rgba(34,199,217,.1);
  border: 1px solid rgba(34,199,217,.26);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .055em;
  text-transform: uppercase;
}

.leistungen-worlds-section { padding-top: 96px; }
.service-world-stack {
  gap: var(--s-20);
}
.service-world-card {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(420px, .98fr);
  gap: clamp(36px, 5vw, 84px);
  align-items: center;
  padding: clamp(28px, 4vw, 56px);
  background: var(--paper);
  border: 1px solid rgba(30,35,40,.09);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
}
.service-world-card-reverse .service-world-copy { order: 2; }
.service-world-card-reverse .service-world-media { order: 1; }
.service-world-copy { min-width: 0; }
.service-capability-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-4);
  margin: var(--s-7) 0 var(--s-6);
}
.service-capability-grid article {
  min-height: 160px;
  padding: var(--s-5);
  background:
    linear-gradient(180deg, rgba(34,199,217,.055), transparent),
    var(--soft);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
}
.service-capability-grid h3 { font-size: 1.02rem; margin-bottom: var(--s-2); }
.service-capability-grid p { font-size: .92rem; line-height: 1.55; }
.service-note-inline {
  margin: 0 0 var(--s-6);
  padding: var(--s-4) var(--s-5);
  color: var(--muted);
  background: rgba(30,35,40,.035);
  border: 1px solid rgba(30,35,40,.08);
  border-radius: var(--r-sm);
  font-size: .95rem;
}
.service-note-inline strong { color: var(--deep); }
.service-world-media {
  display: grid;
  gap: var(--s-3);
  min-width: 0;
}
.world-hero-image,
.world-image-grid figure,
.support-model-card figure {
  position: relative;
  overflow: hidden;
  margin: 0;
  background: var(--deep-2);
  isolation: isolate;
}
.world-hero-image {
  aspect-ratio: 16 / 10;
  border-radius: var(--r);
  box-shadow: var(--sh);
}
.world-hero-image img,
.world-image-grid img,
.support-model-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.world-hero-image::after,
.world-image-grid figure::after {
  position: absolute;
  inset: 0;
  content: '';
  pointer-events: none;
  background: linear-gradient(0deg, rgba(14,19,23,.64) 0%, rgba(14,19,23,.08) 52%, transparent);
}
.world-hero-image figcaption {
  position: absolute;
  left: var(--s-5);
  right: var(--s-5);
  bottom: var(--s-5);
  z-index: 2;
  display: grid;
  gap: var(--s-2);
  padding: var(--s-4);
  color: var(--paper);
  background: rgba(14,19,23,.76);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: calc(var(--r) - 3px);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.world-hero-image figcaption span,
.world-image-grid figcaption {
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .065em;
}
.world-hero-image figcaption span {
  color: var(--cyan);
  font-size: .66rem;
  font-weight: 700;
}
.world-hero-image figcaption strong {
  color: var(--paper);
  line-height: 1.32;
}
.world-image-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
}
.world-image-grid figure {
  aspect-ratio: 4 / 3;
  border-radius: var(--r-sm);
}
.world-image-grid figcaption {
  position: absolute;
  left: var(--s-3);
  right: var(--s-3);
  bottom: var(--s-2);
  z-index: 2;
  color: rgba(255,255,255,.9);
  font-size: .58rem;
  font-weight: 700;
  line-height: 1.2;
}

.support-models-heading {
  grid-template-columns: 1.05fr .95fr;
  gap: var(--s-14);
  align-items: end;
  margin-bottom: var(--s-12);
}
.support-models-heading > p { font-size: 1.05rem; }
.support-model-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-5);
}
.support-model-card {
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
}
.support-model-card figure { aspect-ratio: 16 / 9; border-radius: 0; }
.support-model-card > div { padding: var(--s-6); }
.support-model-card h3 { font-size: clamp(1.15rem, 1.45vw, 1.45rem); }
.support-model-card p { font-size: .95rem; line-height: 1.57; }
.mini-tags { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-top: var(--s-5); }
.mini-tags span { min-height: 28px; font-size: .6rem; background: rgba(30,35,40,.04); border-color: rgba(30,35,40,.1); }

.client-fit-grid {
  grid-template-columns: .95fr 1.05fr;
  gap: var(--s-16);
  align-items: start;
}
.client-fit-list { display: grid; gap: var(--s-3); }
.client-fit-list article {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: var(--s-4);
  padding: var(--s-5);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
}
.client-fit-list span {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  color: var(--cyan);
  background: rgba(34,199,217,.1);
  border: 1px solid rgba(34,199,217,.22);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: .72rem;
  font-weight: 700;
}
.client-fit-list strong { color: var(--deep); font-size: 1.02rem; }
.client-fit-list p { grid-column: 2; font-size: .94rem; }
.cooperation-section .section-heading { margin-bottom: var(--s-10); }
.cooperation-timeline article { min-height: 220px; }
.partner-note-box { max-width: 1000px; }

@media (max-width: 1240px) {
  .leistungen-jumpbar-v3 { grid-template-columns: repeat(3, 1fr); }
  .leistungen-principle-grid,
  .support-models-heading,
  .client-fit-grid { grid-template-columns: 1fr; gap: var(--s-8); }
  .support-model-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .service-world-card,
  .service-world-card-reverse {
    grid-template-columns: 1fr;
  }
  .service-world-card-reverse .service-world-copy,
  .service-world-card-reverse .service-world-media { order: initial; }
}

@media (max-width: 980px) {
  .service-capability-grid,
  .support-model-grid { grid-template-columns: 1fr; }
  .world-image-grid { grid-template-columns: repeat(2, 1fr); }
  .service-world-card { padding: var(--s-6); }
}

@media (max-width: 620px) {
  .leistungen-jumpbar-v3 { grid-template-columns: 1fr; }
  .world-image-grid { grid-template-columns: 1fr 1fr; gap: var(--s-2); }
  .world-hero-image { aspect-ratio: 4 / 3; }
  .world-hero-image figcaption { left: var(--s-3); right: var(--s-3); bottom: var(--s-3); padding: var(--s-3); }
  .client-fit-list article { grid-template-columns: 1fr; }
  .client-fit-list span { grid-row: auto; }
  .client-fit-list p { grid-column: 1; }
}



/* ================================================================
   DACH PROOF MAP MODULE
   Standalone component integrated into the existing Next design tokens.
   ================================================================ */
:root {
  --nm-anthracite: var(--anthracite);
  --nm-anthracite-deep: var(--deep);
  --nm-anthracite-80: var(--muted);
  --nm-anthracite-60: #767b7e;
  --nm-anthracite-40: #a6a9ab;
  --nm-white: var(--paper);
  --nm-light-grey: var(--soft);
  --nm-light-grey-2: var(--line);
  --nm-light-grey-3: #d6dce0;
  --nm-cyan: var(--cyan);
  --nm-cyan-soft: #e6f8fb;
  --nm-cyan-deep: #178a98;
  --nm-blue: #1f6feb;
  --nm-green: var(--green);
  --bg-page: var(--paper);
  --bg-section: var(--soft);
  --bg-card: var(--paper);
  --bg-inverse: var(--deep);
  --bg-inverse-deep: var(--deep-2);
  --fg-1: var(--anthracite);
  --fg-2: var(--muted);
  --fg-3: #767b7e;
  --fg-mute: #a6a9ab;
  --fg-on-dark: var(--paper);
  --fg-on-dark-2: rgba(255,255,255,.72);
  --border: var(--line);
  --border-strong: #d6dce0;
  --accent: var(--cyan);
  --font-display: var(--font);
  --font-body: var(--font);
  --fs-xxs: 11px;
  --fs-xs: 12px;
  --fs-sm: 14px;
  --fs-base: 16px;
  --fs-md: 18px;
  --fs-lg: 20px;
  --fs-h2: 38px;
  --lh-tight: 1.08;
  --lh-snug: 1.22;
  --lh-normal: 1.5;
  --lh-relaxed: 1.65;
  --tracking-mono: .06em;
  --tracking-snug: -.01em;
  --space-1: var(--s-1);
  --space-2: var(--s-2);
  --space-3: var(--s-3);
  --space-4: var(--s-4);
  --space-5: var(--s-5);
  --space-6: var(--s-6);
  --space-8: var(--s-8);
  --space-10: var(--s-10);
  --space-12: var(--s-12);
  --space-16: var(--s-16);
  --space-20: var(--s-20);
  --radius-sm: 3px;
  --radius-lg: var(--r-lg);
  --radius-xl: var(--r-lg);
  --radius-pill: var(--r-pill);
  --dur-fast: 120ms;
  --dur-base: 180ms;
  --dur-slow: 280ms;
  --ease-standard: cubic-bezier(.2,0,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --shadow-focus: 0 0 0 3px rgba(34,199,217,.30);
}


/* ── Section header ─────────────────────────────────────── */
    .nm-section-head {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: var(--space-8);
      align-items: end;
      margin-bottom: var(--space-10);
      padding-bottom: var(--space-6);
      border-bottom: 1px solid var(--border);
    }
    .nm-eyebrow {
      display: flex;
      align-items: center;
      gap: var(--space-3);
      margin-bottom: var(--space-4);
    }
    .nm-eyebrow .nm-cyan-rule { margin-bottom: 0; }
    .nm-section-head h2 {
      max-width: 22ch;
      font-size: clamp(28px, 3.4vw, var(--fs-h2));
    }
    .nm-section-head .lead {
      max-width: 42ch;
      color: var(--fg-2);
      font-size: var(--fs-md);
      line-height: var(--lh-snug);
      margin-top: var(--space-3);
    }
    .nm-section-meta {
      display: grid;
      grid-template-columns: auto auto;
      gap: var(--space-6) var(--space-8);
      align-self: end;
      justify-self: end;
      padding-bottom: var(--space-1);
    }
    .nm-meta-item .nm-label { display: block; margin-bottom: 4px; }
    .nm-meta-item .v {
      font-family: var(--font-mono);
      font-weight: 500;
      font-size: var(--fs-md);
      color: var(--fg-1);
      letter-spacing: var(--tracking-mono);
    }
    .nm-meta-item .v small {
      color: var(--fg-3);
      font-size: var(--fs-xs);
      margin-left: 4px;
    }

    /* ── Filter strip ───────────────────────────────────────── */
    .nm-filter {
      display: flex;
      flex-wrap: wrap;
      gap: var(--space-2);
      align-items: center;
      margin-bottom: var(--space-6);
    }
    .nm-filter-label {
      font-family: var(--font-mono);
      font-size: var(--fs-xs);
      letter-spacing: var(--tracking-mono);
      text-transform: uppercase;
      color: var(--fg-3);
      margin-right: var(--space-3);
    }
    .nm-pill {
      appearance: none;
      background: var(--nm-white);
      border: 1px solid var(--border-strong);
      color: var(--fg-1);
      font-family: var(--font-body);
      font-size: var(--fs-sm);
      font-weight: 500;
      padding: 8px 14px 8px 30px;
      border-radius: var(--radius-pill);
      cursor: pointer;
      transition:
        background var(--dur-fast) var(--ease-standard),
        border-color var(--dur-fast) var(--ease-standard),
        color var(--dur-fast) var(--ease-standard);
      position: relative;
      letter-spacing: -0.005em;
    }
    .nm-pill::before {
      content: "";
      position: absolute;
      left: 12px;
      top: 50%;
      transform: translateY(-50%);
      width: 10px; height: 10px;
      border-radius: 999px;
      background: var(--cat-color, var(--fg-mute));
      box-shadow: inset 0 0 0 1px rgba(0,0,0,0.12);
    }
    .nm-pill:hover { border-color: var(--fg-2); }
    .nm-pill:focus-visible { outline: none; box-shadow: var(--shadow-focus); }
    .nm-pill[aria-pressed="true"] {
      background: var(--nm-anthracite);
      border-color: var(--nm-anthracite);
      color: var(--fg-on-dark);
    }
    .nm-pill .count {
      display: inline-block;
      margin-left: 6px;
      font-family: var(--font-mono);
      font-size: 11px;
      color: var(--fg-3);
      letter-spacing: var(--tracking-mono);
    }
    .nm-pill[aria-pressed="true"] .count { color: var(--fg-on-dark-2); }

    /* ── Map + card layout ──────────────────────────────────── */
    .nm-map-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
      gap: var(--space-8);
      align-items: stretch;
    }

    .nm-map-card {
      position: relative;
      background: var(--bg-section);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: var(--space-6);
      display: flex;
      flex-direction: column;
    }
    .nm-map-corner {
      position: absolute;
      font-family: var(--font-mono);
      font-size: 10px;
      color: var(--fg-3);
      letter-spacing: var(--tracking-mono);
      text-transform: uppercase;
      pointer-events: none;
    }
    .nm-map-corner.tl { top: var(--space-4); left: var(--space-4); }
    .nm-map-corner.tr { top: var(--space-4); right: var(--space-4); }
    .nm-map-corner.bl { bottom: var(--space-4); left: var(--space-4); }
    .nm-map-corner.br { bottom: var(--space-4); right: var(--space-4); }
    .nm-map-corner .b { color: var(--fg-2); margin-right: 6px; }

    .nm-map-stage {
      position: relative;
      margin: var(--space-8) auto var(--space-6);
      width: 100%;
      max-width: 620px;
      aspect-ratio: 1 / 1;
    }
    .nm-map-bg {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      object-fit: contain;
      display: block;
      user-select: none;
      -webkit-user-drag: none;
    }
    .nm-map-svg {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      pointer-events: none;
    }

    /* Light technical-drawing frame around the stage */
    .nm-frame {
      fill: none;
      stroke: var(--border-strong);
      stroke-width: 1;
      stroke-dasharray: 2 4;
    }
    .nm-graticule line { stroke: rgba(48,55,59,0.05); stroke-width: 1; }
    .nm-northarrow {
      fill: var(--fg-3);
      font-family: var(--font-mono);
      font-size: 11px;
      letter-spacing: 0.14em;
    }

    /* Region halo — drawn in SVG, sized per region cluster */
    .nm-halo {
      fill: rgba(34,199,217,0.10);
      stroke: var(--accent);
      stroke-width: 1.25;
      stroke-dasharray: 3 3;
      opacity: 0;
      transform-origin: center;
      transition: opacity var(--dur-base) var(--ease-out);
    }
    .nm-halo[data-active="true"] {
      opacity: 1;
      animation: nmHaloBreath 3s var(--ease-out) infinite;
    }
    @keyframes nmHaloBreath {
      0%, 100% { stroke-opacity: 0.85; }
      50%      { stroke-opacity: 0.45; }
    }
    @media (prefers-reduced-motion: reduce) {
      .nm-halo[data-active="true"] { animation: none; }
    }

    /* ── Pin buttons ────────────────────────────────────────── */
    .nm-pin {
      position: absolute;
      transform: translate(-50%, -50%);
      width: 22px; height: 22px;
      padding: 0;
      border: 0;
      background: transparent;
      cursor: pointer;
      z-index: 2;
    }
    .nm-pin:focus-visible { outline: none; }
    .nm-pin .dot {
      position: absolute;
      inset: 7px;          /* 8px dot inside 22px target */
      border-radius: 999px;
      background: var(--nm-white);
      box-shadow:
        0 0 0 1.25px var(--nm-anthracite-deep),
        0 1px 2px rgba(30,35,40,0.35);
      transition:
        inset var(--dur-base) var(--ease-out),
        background var(--dur-fast) var(--ease-standard),
        box-shadow var(--dur-fast) var(--ease-standard);
    }
    .nm-pin .ring {
      position: absolute;
      inset: 0;
      border-radius: 999px;
      border: 1.5px solid var(--accent);
      opacity: 0;
      transform: scale(0.4);
      transition: opacity var(--dur-base) var(--ease-out),
                  transform var(--dur-base) var(--ease-out);
    }
    .nm-pin:hover { z-index: 3; }
    .nm-pin:hover .dot { inset: 5px; }
    .nm-pin:focus-visible .dot { box-shadow: 0 0 0 2px var(--nm-white), var(--shadow-focus); }

    /* Filter-active: pin matches the filter category */
    .nm-pin[data-match="true"] .dot {
      background: var(--cat-color);
      box-shadow: 0 0 0 1.25px var(--nm-white), 0 1px 2px rgba(30,35,40,0.4);
    }
    /* Filter-active: pin does not match — dimmed but preserves scope */
    .nm-pin[data-match="false"] { opacity: 0.35; }
    .nm-pin[data-match="false"] .dot {
      background: rgba(255,255,255,0.5);
    }

    /* Region-active: every pin in the active region brightens to cyan */
    .nm-pin[data-in-region="true"] { z-index: 4; }
    .nm-pin[data-in-region="true"] .dot {
      background: var(--accent);
      inset: 6px;
      box-shadow: 0 0 0 1.5px var(--nm-white), 0 2px 6px rgba(34,199,217,0.55);
    }
    /* Anchor pin (specifically clicked) — biggest, with pulse ring */
    .nm-pin[data-anchor="true"] .dot {
      inset: 3px;
      background: var(--accent);
      box-shadow: 0 0 0 2px var(--nm-white), 0 4px 12px rgba(34,199,217,0.7);
    }
    .nm-pin[data-anchor="true"] .ring {
      opacity: 1;
      transform: scale(1.0);
      animation: nmPulse 1.8s var(--ease-out) infinite;
    }
    @keyframes nmPulse {
      0%   { transform: scale(0.9); opacity: 0.9; }
      80%  { transform: scale(2.2); opacity: 0; }
      100% { transform: scale(2.2); opacity: 0; }
    }
    @media (prefers-reduced-motion: reduce) {
      .nm-pin[data-anchor="true"] .ring { animation: none; }
      .nm-pin .dot, .nm-pin .ring { transition: none; }
    }

    /* Tooltip */
    .nm-pin-tip {
      position: absolute;
      bottom: calc(100% + 4px);
      left: 50%;
      transform: translateX(-50%) translateY(4px);
      background: var(--nm-anthracite-deep);
      color: var(--fg-on-dark);
      font-family: var(--font-mono);
      font-size: 10px;
      letter-spacing: 0.04em;
      padding: 4px 7px;
      border-radius: var(--radius-sm);
      white-space: nowrap;
      pointer-events: none;
      opacity: 0;
      transition: opacity var(--dur-fast) var(--ease-standard),
                  transform var(--dur-base) var(--ease-out);
    }
    .nm-pin:hover .nm-pin-tip,
    .nm-pin:focus-visible .nm-pin-tip {
      opacity: 1;
      transform: translateX(-50%) translateY(0);
    }
    .nm-pin-tip::after {
      content: "";
      position: absolute;
      top: 100%; left: 50%;
      transform: translateX(-50%);
      border: 4px solid transparent;
      border-top-color: var(--nm-anthracite-deep);
    }

    /* Map footer */
    .nm-map-footer {
      margin-top: var(--space-4);
      padding-top: var(--space-4);
      border-top: 1px solid var(--border);
      display: flex;
      flex-wrap: wrap;
      gap: var(--space-2) var(--space-4);
      align-items: center;
      font-family: var(--font-mono);
      font-size: var(--fs-xs);
      letter-spacing: var(--tracking-mono);
      text-transform: uppercase;
      color: var(--fg-3);
    }
    .nm-map-footer .sep { color: var(--border-strong); }
    .nm-map-footer .right { margin-left: auto; }
    .nm-map-footer b { color: var(--fg-1); font-weight: 500; }

    /* ── Content card (right column) ────────────────────────── */
    .nm-detail {
      display: flex;
      flex-direction: column;
      background: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: var(--space-6);
      position: relative;
      overflow: hidden;
    }
    .nm-detail::before {
      content: "";
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 4px;
      background: var(--cat-color, var(--accent));
      transition: background var(--dur-base) var(--ease-standard);
    }

    .nm-detail-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: var(--space-3);
      margin-bottom: var(--space-4);
    }
    .nm-detail-id {
      font-family: var(--font-mono);
      font-size: var(--fs-xs);
      letter-spacing: var(--tracking-mono);
      color: var(--fg-3);
      text-transform: uppercase;
    }
    .nm-detail-region {
      font-family: var(--font-display);
      font-weight: 700;
      font-size: var(--fs-h3);
      line-height: var(--lh-tight);
      letter-spacing: var(--tracking-tight);
      margin: var(--space-2) 0 var(--space-3);
      color: var(--fg-1);
      text-wrap: balance;
    }
    .nm-detail-meta-row {
      display: flex;
      align-items: center;
      gap: var(--space-3);
      flex-wrap: wrap;
      margin-bottom: var(--space-4);
    }
    .nm-detail-count {
      display: inline-flex;
      align-items: baseline;
      gap: 4px;
      font-family: var(--font-mono);
      font-size: var(--fs-xs);
      letter-spacing: var(--tracking-mono);
      text-transform: uppercase;
      color: var(--fg-2);
    }
    .nm-detail-count b {
      color: var(--fg-1);
      font-weight: 600;
      font-size: var(--fs-md);
    }

    /* Tiny bar chart of category breakdown within the region */
    .nm-breakdown {
      display: flex;
      flex: 1;
      min-width: 140px;
      height: 6px;
      border-radius: 999px;
      overflow: hidden;
      background: var(--bg-section);
    }
    .nm-breakdown span {
      height: 100%;
      transition: flex var(--dur-base) var(--ease-out);
    }

    .nm-detail-story {
      color: var(--fg-1);
      font-size: var(--fs-md);
      line-height: var(--lh-relaxed);
      margin: var(--space-3) 0 var(--space-5);
      text-wrap: pretty;
    }

    .nm-detail-attrs {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--space-4);
      padding: var(--space-4);
      background: var(--bg-section);
      border-radius: var(--radius-md);
      margin-bottom: var(--space-5);
    }
    .nm-detail-attr .nm-label { display: block; margin-bottom: 4px; }
    .nm-detail-attr .v {
      font-family: var(--font-body);
      font-size: var(--fs-sm);
      font-weight: 500;
      color: var(--fg-1);
      line-height: 1.35;
    }

    .nm-detail-services {
      margin-bottom: var(--space-5);
    }
    .nm-detail-services .nm-label { display: block; margin-bottom: var(--space-2); }
    .nm-detail-services ul {
      list-style: none; margin: 0; padding: 0;
      display: flex; flex-wrap: wrap; gap: 6px;
    }
    .nm-detail-services li {
      font-family: var(--font-mono);
      font-size: var(--fs-xs);
      font-weight: 500;
      letter-spacing: var(--tracking-mono);
      text-transform: uppercase;
      color: var(--fg-1);
      background: var(--nm-white);
      border: 1px solid var(--border-strong);
      padding: 4px 8px;
      border-radius: var(--radius-sm);
    }
    .nm-detail-services li .swatch {
      display: inline-block;
      width: 6px; height: 6px;
      border-radius: 999px;
      background: var(--cat-color);
      margin-right: 6px;
      vertical-align: middle;
    }

    .nm-detail-foot {
      margin-top: auto;
      padding-top: var(--space-4);
      border-top: 1px solid var(--border);
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: var(--space-3);
    }
    .nm-detail-step {
      font-family: var(--font-mono);
      font-size: var(--fs-xs);
      letter-spacing: var(--tracking-mono);
      color: var(--fg-3);
      text-transform: uppercase;
    }
    .nm-detail-step b { color: var(--fg-1); font-weight: 500; }

    .nm-nav { display: inline-flex; gap: 6px; }
    .nm-nav button {
      appearance: none;
      background: var(--nm-white);
      border: 1px solid var(--border-strong);
      width: 36px; height: 36px;
      border-radius: var(--radius-md);
      cursor: pointer;
      color: var(--fg-1);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: background var(--dur-fast) var(--ease-standard),
                  border-color var(--dur-fast) var(--ease-standard);
    }
    .nm-nav button:hover {
      background: var(--nm-anthracite);
      border-color: var(--nm-anthracite);
      color: var(--fg-on-dark);
    }
    .nm-nav button:focus-visible { outline: none; box-shadow: var(--shadow-focus); }
    .nm-nav button svg { width: 14px; height: 14px; }

    /* Empty state */
    .nm-detail[data-empty="true"] .nm-detail-region,
    .nm-detail[data-empty="true"] .nm-detail-meta-row,
    .nm-detail[data-empty="true"] .nm-detail-story,
    .nm-detail[data-empty="true"] .nm-detail-attrs,
    .nm-detail[data-empty="true"] .nm-detail-services { display: none; }
    .nm-detail-empty {
      display: none;
      flex-direction: column;
      align-items: flex-start;
      gap: var(--space-3);
      padding: var(--space-6) 0;
    }
    .nm-detail[data-empty="true"] .nm-detail-empty { display: flex; }
    .nm-detail-empty .big {
      font-family: var(--font-display);
      font-size: var(--fs-h4);
      font-weight: 600;
      color: var(--fg-1);
      line-height: var(--lh-tight);
      max-width: 20ch;
      letter-spacing: var(--tracking-snug);
    }
    .nm-detail-empty .hint {
      color: var(--fg-2);
      font-size: var(--fs-sm);
      line-height: var(--lh-normal);
      max-width: 38ch;
    }
    .nm-detail-legend {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--space-3);
      margin-top: var(--space-4);
      width: 100%;
    }
    .nm-detail-legend li {
      display: flex; align-items: center; gap: 8px;
      font-family: var(--font-mono);
      font-size: 11px;
      color: var(--fg-2);
      letter-spacing: 0.03em;
    }
    .nm-detail-legend ul { list-style: none; margin: 0; padding: 0; }
    .nm-detail-legend .sw {
      width: 12px; height: 12px;
      border-radius: 999px;
      border: 1.5px solid var(--nm-white);
      box-shadow: 0 0 0 1px var(--border-strong);
    }

    /* ── Disclaimer ─────────────────────────────────────────── */
    .nm-disclaimer {
      margin-top: var(--space-6);
      padding: var(--space-4) var(--space-5);
      border-left: 2px solid var(--accent);
      background: var(--nm-cyan-soft);
      font-size: var(--fs-sm);
      line-height: var(--lh-normal);
      color: var(--fg-2);
      max-width: 86ch;
    }
    .nm-disclaimer em {
      color: var(--fg-1);
      font-style: normal;
      font-weight: 500;
    }

    /* ── Responsive ─────────────────────────────────────────── */
    @media (max-width: 1000px) {
      .nm-section-head { grid-template-columns: 1fr; }
      .nm-section-meta { justify-self: start; }
      .nm-map-grid { grid-template-columns: 1fr; }
    }
    @media (max-width: 600px) {
      .nm-section-meta { grid-template-columns: 1fr 1fr; gap: var(--space-4); }
      .nm-detail-attrs { grid-template-columns: 1fr; }
      .nm-map-stage { margin-top: var(--space-6); }
      .nm-map-corner { display: none; }
      .nm-pin { width: 28px; height: 28px; } /* larger hit target on touch */
    }
  

.nm-dach-map-section .section-grid > .nm-section-head,
.nm-dach-map-section .section-grid > .nm-filter,
.nm-dach-map-section .section-grid > .nm-map-grid,
.nm-dach-map-section .section-grid > .nm-disclaimer { grid-column: 2; }
.nm-dach-map-section .nm-section-head { margin-bottom: var(--s-8); }
.nm-dach-map-section .nm-filter { margin-bottom: var(--s-6); }
.nm-dach-map-section .nm-map-bg { filter: drop-shadow(0 18px 28px rgba(20,28,34,.08)); }
.nm-dach-map-section .nm-detail { min-height: 100%; }
.nm-dach-map-section .nm-disclaimer { margin-top: var(--s-6); }
.nm-dach-map-section .nm-meta-item .v { color: var(--deep); }

.home-proof-link {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  margin-top: var(--s-5);
  color: var(--deep);
  font-weight: 720;
}
.home-proof-link::after { content: '>'; color: var(--cyan); }
.home-proof-link:hover { color: var(--cyan); }



/* ================================================================
   SHIPPING PATCH V4 — proof cards, subpage heroes and sticky services
   ================================================================ */
.proof-card-link { text-decoration: none; color: inherit; transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease; }
.proof-card-link:hover { transform: translateY(-3px); border-color: rgba(34,199,217,.42); box-shadow: var(--sh-sm); }
.proof-grid-compact { margin-bottom: var(--s-8); }
.experience-heading { max-width: 940px; }
.experience-showcase-grid {
  grid-template-columns: minmax(380px, .9fr) minmax(0, 1.1fr);
  gap: var(--s-6);
  align-items: stretch;
}
.map-reference-card {
  position: relative;
  display: grid;
  grid-template-rows: minmax(260px, 1fr) auto;
  overflow: hidden;
  min-height: 560px;
  color: var(--paper);
  text-decoration: none;
  background:
    linear-gradient(135deg, rgba(18,24,29,.96), rgba(30,44,52,.94));
  border: 1px solid rgba(34,199,217,.24);
  border-radius: var(--r-lg);
  box-shadow: var(--sh);
}
.map-reference-card::before {
  content: '';
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: calc(var(--r-lg) - 8px);
  pointer-events: none;
}
.map-reference-visual {
  position: relative;
  display: grid;
  place-items: center;
  padding: var(--s-8) var(--s-6) var(--s-3);
  background:
    radial-gradient(circle at 62% 35%, rgba(34,199,217,.2), transparent 31%),
    linear-gradient(90deg, rgba(34,199,217,.07) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.06) 1px, transparent 1px);
  background-size: auto, 36px 36px, 36px 36px;
}
.map-reference-visual img {
  width: min(84%, 520px);
  max-height: 330px;
  object-fit: contain;
  filter: drop-shadow(0 20px 28px rgba(0,0,0,.22));
  opacity: .96;
}
.map-reference-pin {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--cyan);
  box-shadow: 0 0 0 7px rgba(34,199,217,.16), 0 0 28px rgba(34,199,217,.75);
}
.map-reference-pin.pin-a { left: 48%; top: 39%; }
.map-reference-pin.pin-b { left: 55%; top: 55%; }
.map-reference-pin.pin-c { left: 61%; top: 64%; }
.map-reference-copy { position: relative; z-index: 2; padding: var(--s-7); }
.map-reference-copy h3 { color: var(--paper); }
.map-reference-copy p { color: rgba(255,255,255,.74); }
.map-reference-copy .text-link { color: var(--paper); }
.experience-picture-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--s-5);
}
.experience-picture-card {
  position: relative;
  display: block;
  overflow: hidden;
  min-height: 268px;
  color: var(--paper);
  text-decoration: none;
  background: var(--deep-2);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
  isolation: isolate;
}
.experience-picture-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(14,19,23,.64), rgba(14,19,23,.08) 58%, transparent);
  z-index: 1;
}
.experience-picture-card img { width: 100%; height: 100%; min-height: 268px; object-fit: cover; transition: transform .45s ease, filter .45s ease; }
.experience-picture-card:hover img { transform: scale(1.045); filter: contrast(1.04) saturate(1.04); }
.experience-picture-card span {
  position: absolute;
  left: var(--s-4);
  bottom: var(--s-4);
  z-index: 2;
  padding: 7px var(--s-3);
  color: var(--paper);
  background: rgba(14,19,23,.78);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--r-pill);
  backdrop-filter: blur(12px);
  font-family: var(--font-mono);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.subpage-hero {
  position: relative;
  overflow: hidden;
  background-color: var(--deep);
  isolation: isolate;
}
.subpage-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: var(--hero-img);
  background-size: cover;
  background-position: var(--hero-pos, center);
  opacity: .42;
  transform: scale(1.02);
}
.subpage-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 80% 20%, rgba(34,199,217,.22), transparent 30%),
    linear-gradient(90deg, rgba(14,19,23,.98) 0%, rgba(14,19,23,.82) 42%, rgba(14,19,23,.58) 100%);
}
.subpage-hero-camera { --hero-img: url('../visuals/seo/hero-leistungen-camera-table.webp'); --hero-pos: center right; }
.subpage-hero-stencil { --hero-img: url('../visuals/seo/hero-ueber-uns-stencil-table.webp'); --hero-pos: center right; }
.subpage-hero-contact { --hero-img: url('../visuals/seo/hero-kontakt-dokumentation.webp'); --hero-pos: center; }
.subpage-hero-minimal::before { opacity: .18; background-image: none; }

.leistung-unfold-layout {
  grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
  gap: clamp(28px, 4.2vw, 72px);
  align-items: start;
}
.leistung-sticky-panel {
  position: sticky;
  top: calc(var(--header-h) + 28px);
  display: grid;
  gap: var(--s-3);
  padding: var(--s-6);
  background: rgba(255,255,255,.84);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
  backdrop-filter: blur(18px);
}
.leistung-sticky-panel h3 { margin-bottom: var(--s-2); font-size: clamp(1.05rem, 1.25vw, 1.24rem); }
.leistung-sticky-link {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  min-height: 46px;
  padding: var(--s-3);
  color: var(--muted);
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  font-weight: 720;
  transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}
.leistung-sticky-link span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  color: var(--deep);
  background: rgba(34,199,217,.1);
  border: 1px solid rgba(34,199,217,.22);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: .64rem;
}
.leistung-sticky-link:hover,
.leistung-sticky-link.is-active {
  color: var(--deep);
  background: rgba(34,199,217,.08);
  border-color: rgba(34,199,217,.32);
  transform: translateX(2px);
}
.sticky-panel-note {
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: .88rem;
  line-height: 1.5;
}
.sticky-panel-note strong { color: var(--deep); }
.service-world-stack { display: grid; }
.service-world-card {
  scroll-margin-top: calc(var(--header-h) + 26px);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.service-world-card.is-active {
  border-color: rgba(34,199,217,.35);
  box-shadow: 0 24px 60px rgba(14,19,23,.12);
}
@media (min-width: 1241px) {
  .service-world-media { position: sticky; top: calc(var(--header-h) + 28px); align-self: start; }
  .service-world-card { align-items: start; }
}

.about-story-grid { grid-template-columns: minmax(0, .95fr) minmax(420px, 1.05fr); gap: var(--s-16); align-items: center; }
.about-story-media { min-height: 430px; }
.about-story-media img { min-height: 430px; }
.about-story-media figcaption span { font-family: var(--font-mono); color: var(--cyan); text-transform: uppercase; letter-spacing: .065em; font-size: .66rem; }
.about-role-grid { align-items: stretch; }
.about-map-tile { color: var(--paper); text-decoration: none; }
.about-map-tile img { object-fit: contain; padding: var(--s-4); background: linear-gradient(135deg, #151a1e, #263138); }

@media (max-width: 1240px) {
  .experience-showcase-grid,
  .leistung-unfold-layout,
  .about-story-grid { grid-template-columns: 1fr; }
  .leistung-sticky-panel { position: relative; top: auto; }
  .service-world-media { position: relative; top: auto; }
}
@media (max-width: 760px) {
  .experience-picture-grid { grid-template-columns: 1fr; }
  .map-reference-card { min-height: auto; }
  .experience-picture-card,
  .experience-picture-card img { min-height: 230px; }
}

/* ================================================================
   SHIPPING PATCH V5 — launch polish: clearer proof, visual Leistungen cards, mobile hero
   ================================================================ */
.map-reference-copy h3 {
  max-width: 620px;
}
.map-reference-pin.pin-d { left: 41%; top: 52%; }
.map-reference-pin.pin-e { left: 58%; top: 48%; }
.map-reference-pin.pin-f { left: 64%; top: 58%; }
.map-reference-pin.pin-g { left: 52%; top: 67%; }
.map-reference-pin.pin-h { left: 68%; top: 70%; }
.service-card-media img[src*="home-card-rollout-digitales-leitsystem"] {
  object-position: center center;
}
.experience-picture-card img[src*="home-proof-led-parkleitsystem-aussen"] {
  object-position: center center;
}
.service-capability-grid-visual article {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: var(--s-3);
  padding: 0;
  overflow: hidden;
}
.service-capability-grid-visual h3,
.service-capability-grid-visual p {
  padding-left: var(--s-5);
  padding-right: var(--s-5);
}
.service-capability-grid-visual h3 { margin-bottom: 0; }
.service-capability-grid-visual p { padding-bottom: var(--s-5); }
.capability-media {
  position: relative;
  overflow: hidden;
  margin: 0;
  aspect-ratio: 16 / 9;
  background: var(--deep-2);
}
.capability-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .42s ease, filter .42s ease;
}
.service-capability-grid-visual article:hover .capability-media img {
  transform: scale(1.035);
  filter: contrast(1.04) saturate(1.04);
}
.capability-media-tall { aspect-ratio: 4 / 5; }
.capability-media-tall img { object-position: center top; }
.capability-media-mast { aspect-ratio: 4 / 5; }
.capability-media-mast img { object-position: center center; }
.support-model-card img[src*="leistungen-rollout-logistik-led-leitsystem"] {
  object-position: center center;
}
@media (max-width: 900px) {
  .service-capability-grid-visual { grid-template-columns: 1fr; }
  .capability-media,
  .capability-media-tall,
  .capability-media-mast { aspect-ratio: 16 / 10; }
}
@media (max-width: 760px) {
  .hero-video-stage {
    min-height: auto;
    padding: calc(var(--header-h) + 40px) 0 72px;
    background: url('../video/hero-video-poster.jpg') center/cover no-repeat, var(--deep-2);
  }
  .hero-video-stage > .hero-media { display: none; }
  .hero-video-stage .hero-overlay-grid { min-height: auto; }
  .hero-video-stage.is-video-intro .hero-copy-overlay {
    opacity: 1;
    transform: none;
    pointer-events: auto;
    transition: none;
  }
  .hero-accent-line { animation: none !important; transform: none !important; opacity: 1 !important; }
  .map-reference-visual img { width: min(88%, 420px); max-height: 250px; }
  .map-reference-card { grid-template-rows: minmax(220px, auto) auto; }
  .service-card-media { aspect-ratio: 4 / 3; }
}
@media (min-width: 761px) {
  .experience-picture-card { min-height: 320px; }
  .experience-picture-card img { min-height: 320px; }
}

/* ================================================================
   SHIPPING PATCH V6 — Leistungen scrollytelling rebuild
   Large scenes, image-led service cards, controlled sticky context.
   ================================================================ */
.leistungen-scenes-section {
  padding-top: clamp(76px, 8vw, 120px);
  padding-bottom: clamp(82px, 9vw, 140px);
  overflow: clip;
}
.leistungen-scenes-heading {
  grid-template-columns: minmax(0, .92fr) minmax(360px, .78fr);
  gap: clamp(28px, 5vw, 84px);
  align-items: end;
  margin-bottom: clamp(48px, 7vw, 88px);
}
.scene-heading-copy {
  display: grid;
  gap: var(--s-5);
  color: var(--muted);
  font-size: clamp(1rem, 1.18vw, 1.12rem);
  line-height: 1.65;
}
.scene-selector {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--s-3);
}
.scene-selector a {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  min-height: 54px;
  padding: var(--s-3) var(--s-4);
  color: var(--muted);
  text-decoration: none;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(30,35,40,.1);
  border-radius: var(--r-sm);
  box-shadow: var(--sh-xs);
  font-weight: 760;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}
.scene-selector a span {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  flex: 0 0 30px;
  color: var(--deep);
  background: rgba(34,199,217,.1);
  border: 1px solid rgba(34,199,217,.22);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: .66rem;
}
.scene-selector a:hover,
.scene-selector a.is-active {
  color: var(--deep);
  background: rgba(34,199,217,.095);
  border-color: rgba(34,199,217,.34);
  transform: translateY(-2px);
}
.service-scene-stack {
  display: grid;
  gap: clamp(78px, 10vw, 150px);
}
.service-scroll-scene {
  display: grid;
  grid-template-columns: minmax(340px, .43fr) minmax(0, .57fr);
  gap: clamp(32px, 5.2vw, 88px);
  align-items: start;
  padding: clamp(28px, 4.8vw, 72px);
  background: linear-gradient(135deg, rgba(255,255,255,.94), rgba(244,246,248,.86));
  border: 1px solid rgba(30,35,40,.08);
  border-radius: clamp(26px, 3vw, 44px);
  box-shadow: 0 28px 90px rgba(14,19,23,.08);
  scroll-margin-top: calc(var(--header-h) + 26px);
  transition: border-color .25s ease, box-shadow .25s ease;
}
.service-scroll-scene.is-active {
  border-color: rgba(34,199,217,.28);
  box-shadow: 0 30px 100px rgba(14,19,23,.11);
}
.scene-sticky-visual {
  position: sticky;
  top: calc(var(--header-h) + 28px);
  align-self: start;
  display: grid;
  gap: var(--s-5);
  min-width: 0;
}
.scene-kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  width: fit-content;
  color: var(--cyan);
  font-family: var(--font-mono);
  font-size: .75rem;
  font-weight: 740;
  letter-spacing: .065em;
  text-transform: uppercase;
}
.scene-kicker span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  color: var(--deep);
  background: rgba(34,199,217,.12);
  border: 1px solid rgba(34,199,217,.26);
  border-radius: 999px;
}
.scene-sticky-visual h2 {
  max-width: 520px;
  font-size: clamp(2rem, 4.2vw, 4.2rem);
  line-height: .95;
  letter-spacing: -.065em;
}
.scene-sticky-visual p {
  max-width: 520px;
  color: var(--muted);
  font-size: clamp(1rem, 1.18vw, 1.12rem);
  line-height: 1.65;
}
.scene-hero-media {
  position: relative;
  overflow: hidden;
  margin: var(--s-3) 0 0;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  background: var(--deep-2);
  box-shadow: var(--sh);
  isolation: isolate;
}
.scene-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s ease, filter .7s ease;
}
.service-scroll-scene.is-active .scene-hero-media img { transform: scale(1.025); filter: contrast(1.04) saturate(1.04); }
.scene-hero-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(14,19,23,.72), rgba(14,19,23,.1) 55%, transparent);
}
.scene-hero-media figcaption {
  position: absolute;
  z-index: 2;
  left: var(--s-5);
  right: var(--s-5);
  bottom: var(--s-5);
  color: var(--paper);
  line-height: 1.35;
  font-weight: 750;
}
.button-small {
  width: fit-content;
  min-height: 42px;
  padding: 0 var(--s-5);
}
.scene-scroll-content {
  display: grid;
  gap: clamp(22px, 3vw, 36px);
  min-width: 0;
}
.scene-intro-card {
  display: grid;
  gap: var(--s-4);
  padding: clamp(22px, 3vw, 34px);
  background: var(--paper);
  border: 1px solid rgba(30,35,40,.08);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-xs);
}
.scene-intro-card h3 {
  max-width: 720px;
  font-size: clamp(1.55rem, 2.35vw, 2.55rem);
  line-height: 1.08;
  letter-spacing: -.045em;
}
.scene-intro-card p:not(.eyebrow) {
  max-width: 760px;
  color: var(--muted);
  font-size: clamp(1rem, 1.12vw, 1.12rem);
  line-height: 1.65;
}
.scene-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-2);
}
.scene-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: var(--s-1) var(--s-3);
  color: var(--deep);
  background: rgba(34,199,217,.08);
  border: 1px solid rgba(34,199,217,.22);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: .65rem;
  font-weight: 760;
  letter-spacing: .055em;
  text-transform: uppercase;
}
.service-visual-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 24px);
}
.service-visual-card {
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  min-height: 100%;
  background: var(--paper);
  border: 1px solid rgba(30,35,40,.09);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-xs);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.service-visual-card:hover {
  transform: translateY(-3px);
  border-color: rgba(34,199,217,.32);
  box-shadow: var(--sh-sm);
}
.service-visual-card figure {
  position: relative;
  overflow: hidden;
  margin: 0;
  aspect-ratio: 4 / 3;
  background: var(--deep-2);
}
.service-visual-card figure::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(0deg, rgba(14,19,23,.16), transparent 48%);
}
.service-visual-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .45s ease, filter .45s ease;
}
.service-visual-card:hover img { transform: scale(1.035); filter: contrast(1.04) saturate(1.04); }
.service-visual-card > div {
  display: grid;
  align-content: start;
  gap: var(--s-3);
  padding: clamp(18px, 2vw, 26px);
}
.service-visual-card h3 {
  font-size: clamp(1.2rem, 1.55vw, 1.55rem);
  line-height: 1.05;
  letter-spacing: -.035em;
}
.service-visual-card p:not(.eyebrow) {
  color: var(--muted);
  font-size: .98rem;
  line-height: 1.56;
}
.service-visual-card-wide {
  grid-column: 1 / -1;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  grid-template-rows: auto;
  min-height: 310px;
}
.service-visual-card-wide figure { aspect-ratio: auto; min-height: 100%; }
.service-visual-card-tall figure { aspect-ratio: 4 / 5; }
.service-visual-card-tall img[src*="golden-hour"] { object-position: center top; }
.service-visual-card-tall img[src*="kameramast"] { object-position: center center; }
.service-visual-card .mini-tags { margin-top: var(--s-2); }
[data-reveal] {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .58s ease, transform .58s ease;
}
[data-reveal].is-visible {
  opacity: 1;
  transform: none;
}
.support-model-card,
.client-fit-list article,
.cooperation-timeline article {
  scroll-margin-top: calc(var(--header-h) + 24px);
}
.support-model-card[data-reveal],
.cooperation-timeline article[data-reveal] { transition-delay: var(--reveal-delay, 0ms); }
@media (max-width: 1280px) {
  .leistungen-scenes-heading,
  .service-scroll-scene {
    grid-template-columns: 1fr;
  }
  .scene-sticky-visual {
    position: relative;
    top: auto;
    grid-template-columns: minmax(0, .95fr) minmax(320px, .75fr);
    align-items: center;
  }
  .scene-sticky-visual .button { grid-column: 1 / 2; }
  .scene-hero-media {
    grid-column: 2;
    grid-row: 1 / span 4;
    aspect-ratio: 16 / 10;
  }
}
@media (max-width: 880px) {
  .leistungen-scenes-section { padding-top: 64px; }
  .scene-selector,
  .service-visual-grid,
  .service-visual-card-wide,
  .scene-sticky-visual {
    grid-template-columns: 1fr;
  }
  .scene-sticky-visual .button,
  .scene-hero-media {
    grid-column: auto;
    grid-row: auto;
  }
  .service-scroll-scene {
    padding: var(--s-5);
    border-radius: var(--r-lg);
  }
  .scene-sticky-visual h2 { font-size: clamp(2rem, 10vw, 3.1rem); }
  .scene-hero-media { aspect-ratio: 16 / 10; }
  .service-visual-card-wide { min-height: 0; }
  .service-visual-card-wide figure { aspect-ratio: 16 / 10; }
  .service-visual-card-tall figure { aspect-ratio: 16 / 10; }
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
  .service-visual-card,
  .scene-hero-media img,
  .service-visual-card img { transition: none; }
}

/* ================================================================
   SHIPPING PATCH V7 — Layered Leistungen redesign
   Dark split scenes, contained image slots, alternating capability rows.
   ================================================================ */
.leistungen-layered-section {
  padding-top: clamp(72px, 8vw, 118px);
  padding-bottom: clamp(86px, 9vw, 140px);
  overflow: clip;
  background:
    linear-gradient(90deg, rgba(34,199,217,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.045) 1px, transparent 1px),
    linear-gradient(135deg, #fbfcfd 0%, #f4f7f9 100%);
  background-size: 72px 72px, 72px 72px, auto;
}
.layered-intro {
  grid-template-columns: minmax(0, .95fr) minmax(360px, .78fr);
  gap: clamp(28px, 5vw, 76px);
  align-items: end;
  margin-bottom: clamp(46px, 7vw, 90px);
}
.layered-intro > p {
  max-width: 650px;
  color: var(--muted);
  font-size: clamp(1.02rem, 1.18vw, 1.16rem);
  line-height: 1.66;
}
.service-layer {
  gap: clamp(42px, 6vw, 84px);
  margin-bottom: clamp(80px, 10vw, 150px);
  scroll-margin-top: calc(var(--header-h) + 24px);
}
.service-layer:last-of-type { margin-bottom: 0; }
.layer-opener {
  display: grid;
  grid-template-columns: minmax(340px, .44fr) minmax(0, .56fr);
  gap: clamp(24px, 4vw, 58px);
  align-items: stretch;
  overflow: hidden;
  min-height: clamp(430px, 50vw, 650px);
  border-radius: clamp(24px, 3vw, 42px);
  box-shadow: 0 30px 86px rgba(14,19,23,.17);
}
.layer-opener-dark {
  color: var(--paper);
  background:
    radial-gradient(circle at 18% 16%, rgba(34,199,217,.2), transparent 28%),
    linear-gradient(90deg, rgba(34,199,217,.075) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.055) 1px, transparent 1px),
    var(--deep-2);
  background-size: auto, 48px 48px, 48px 48px, auto;
}
.layer-opener-flip .layer-opener-copy { order: 2; }
.layer-opener-flip .layer-opener-media { order: 1; }
.layer-opener-copy {
  display: grid;
  align-content: center;
  gap: var(--s-5);
  padding: clamp(34px, 5.3vw, 88px);
}
.layer-opener-copy h2 {
  max-width: 690px;
  color: var(--paper);
  font-size: clamp(2.3rem, 5vw, 5.2rem);
  line-height: .96;
  letter-spacing: -.07em;
}
.layer-opener-copy p {
  max-width: 620px;
  color: rgba(255,255,255,.78);
  font-size: clamp(1.02rem, 1.25vw, 1.22rem);
  line-height: 1.62;
}
.layer-opener-copy .button { margin-top: var(--s-3); }
.scene-tags-dark span {
  color: var(--paper);
  background: rgba(34,199,217,.12);
  border-color: rgba(34,199,217,.34);
}
.layer-opener-media {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  margin: 0;
  background: var(--deep);
  isolation: isolate;
}
.layer-opener-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(14,19,23,.62), rgba(14,19,23,.1) 52%, transparent);
  pointer-events: none;
}
.layer-opener-media img {
  width: 100%;
  height: 100%;
  min-height: clamp(430px, 50vw, 650px);
  object-fit: cover;
  object-position: center center;
  filter: contrast(1.03) saturate(1.02);
  transform: scale(1.005);
}
.layer-opener-media figcaption {
  position: absolute;
  z-index: 2;
  left: var(--s-6);
  right: var(--s-6);
  bottom: var(--s-6);
  width: fit-content;
  max-width: calc(100% - 48px);
  padding: var(--s-2) var(--s-4);
  color: var(--paper);
  background: rgba(14,19,23,.74);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--r-pill);
  backdrop-filter: blur(14px);
  font-family: var(--font-mono);
  font-size: .7rem;
  font-weight: 740;
  letter-spacing: .055em;
  text-transform: uppercase;
}
.capability-stack {
  display: grid;
  gap: clamp(22px, 3.2vw, 38px);
  max-width: 1280px;
  margin-inline: auto;
}
.capability-row {
  display: grid;
  grid-template-columns: minmax(360px, .52fr) minmax(0, .48fr);
  align-items: center;
  overflow: hidden;
  min-height: clamp(330px, 32vw, 470px);
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(30,35,40,.085);
  border-radius: clamp(20px, 2vw, 30px);
  box-shadow: 0 18px 60px rgba(14,19,23,.08);
}
.capability-row-reverse {
  grid-template-columns: minmax(0, .48fr) minmax(360px, .52fr);
}
.capability-row-reverse .capability-row-media { order: 2; }
.capability-row-reverse .capability-row-copy { order: 1; }
.capability-row-media {
  position: relative;
  overflow: hidden;
  height: 100%;
  min-height: clamp(330px, 32vw, 470px);
  margin: 0;
  background: var(--deep-2);
}
.capability-row-media::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(0deg, rgba(14,19,23,.2), transparent 52%);
}
.capability-row-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: transform .7s ease, filter .7s ease;
}
.capability-row:hover .capability-row-media img {
  transform: scale(1.035);
  filter: contrast(1.04) saturate(1.04);
}
.capability-row-copy {
  display: grid;
  align-content: center;
  gap: var(--s-4);
  padding: clamp(30px, 4.5vw, 70px);
}
.capability-row-copy h3 {
  max-width: 520px;
  font-size: clamp(1.75rem, 2.6vw, 3rem);
  line-height: 1.02;
  letter-spacing: -.055em;
}
.capability-row-copy p:not(.eyebrow) {
  max-width: 560px;
  color: var(--muted);
  font-size: clamp(1rem, 1.15vw, 1.16rem);
  line-height: 1.62;
}
.capability-row-portrait .capability-row-media {
  display: grid;
  place-items: center;
  padding: clamp(18px, 2vw, 28px);
  background:
    radial-gradient(circle at 50% 18%, rgba(34,199,217,.11), transparent 32%),
    var(--deep-2);
}
.capability-row-portrait .capability-row-media img {
  width: auto;
  max-width: min(82%, 430px);
  height: min(100%, 560px);
  border-radius: var(--r-lg);
  box-shadow: 0 20px 54px rgba(0,0,0,.25);
  object-fit: cover;
}
.capability-row-portrait .capability-row-media img[src*="golden-hour"] { object-position: center top; }
.capability-row-portrait .capability-row-media img[src*="kameramast"] { object-position: center center; }
.scene-breaker {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--s-6);
  align-items: center;
  max-width: 1280px;
  margin-inline: auto;
  padding: clamp(26px, 4vw, 54px);
  color: var(--paper);
  background:
    radial-gradient(circle at 85% 18%, rgba(34,199,217,.18), transparent 28%),
    linear-gradient(90deg, rgba(34,199,217,.06) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.045) 1px, transparent 1px),
    var(--deep-2);
  background-size: auto, 44px 44px, 44px 44px, auto;
  border-radius: clamp(20px, 2vw, 30px);
  box-shadow: 0 24px 70px rgba(14,19,23,.18);
}
.scene-breaker h3 {
  max-width: 760px;
  color: var(--paper);
  font-size: clamp(1.55rem, 2.7vw, 3rem);
  line-height: 1.04;
  letter-spacing: -.045em;
  margin: 0;
}
.scene-breaker p { color: var(--cyan); }
.scene-breaker .button { white-space: nowrap; }
@media (max-width: 1180px) {
  .layered-intro,
  .layer-opener,
  .capability-row,
  .capability-row-reverse,
  .scene-breaker {
    grid-template-columns: 1fr;
  }
  .layer-opener-flip .layer-opener-copy,
  .layer-opener-flip .layer-opener-media,
  .capability-row-reverse .capability-row-media,
  .capability-row-reverse .capability-row-copy {
    order: initial;
  }
  .layer-opener { min-height: 0; }
  .layer-opener-media,
  .layer-opener-media img {
    min-height: auto;
  }
  .layer-opener-media { aspect-ratio: 16 / 9; }
  .capability-row-media,
  .capability-row { min-height: 0; }
  .capability-row-media { aspect-ratio: 16 / 10; }
  .capability-row-portrait .capability-row-media { aspect-ratio: auto; min-height: 430px; }
  .capability-row-portrait .capability-row-media img { max-height: 520px; }
}
@media (max-width: 760px) {
  .leistungen-layered-section {
    padding-top: 64px;
    background-size: 48px 48px, 48px 48px, auto;
  }
  .layered-intro { margin-bottom: 38px; }
  .service-layer { gap: 30px; margin-bottom: 72px; }
  .layer-opener,
  .capability-row,
  .scene-breaker { border-radius: var(--r-lg); }
  .layer-opener-copy,
  .capability-row-copy,
  .scene-breaker { padding: var(--s-6); }
  .layer-opener-copy h2 { font-size: clamp(2.15rem, 11vw, 3.1rem); }
  .layer-opener-media { aspect-ratio: 4 / 3; }
  .layer-opener-media figcaption { left: var(--s-4); right: var(--s-4); bottom: var(--s-4); max-width: calc(100% - 32px); }
  .capability-row-media { aspect-ratio: 4 / 3; }
  .capability-row-copy h3 { font-size: clamp(1.55rem, 8vw, 2.15rem); }
  .capability-row-portrait .capability-row-media { min-height: 360px; }
  .capability-row-portrait .capability-row-media img { max-width: min(84%, 320px); max-height: 420px; }
  .scene-breaker .button { width: 100%; justify-content: center; }
}

/* ================================================================
   LAUNCH PATCH V8 — curated assets, layered service rhythm, compact models
   ================================================================ */
.recognition-section-layered {
  position: relative;
  overflow: hidden;
  padding-top: clamp(82px, 8vw, 128px);
  padding-bottom: clamp(78px, 7vw, 112px);
}
.recognition-section-layered::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(34,199,217,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(34,199,217,.055) 1px, transparent 1px);
  background-size: 52px 52px;
  opacity: .62;
  pointer-events: none;
}
.recognition-section-layered .section-grid { position: relative; z-index: 1; }
.recognition-section-layered .recognition-title,
.recognition-section-layered .lead-copy p { color: var(--paper); }
.recognition-section-layered .tag-list a {
  color: rgba(255,255,255,.86);
  background: rgba(255,255,255,.055);
  border-color: rgba(255,255,255,.16);
}
.recognition-section-layered .tag-list a:hover {
  color: var(--paper);
  background: rgba(34,199,217,.13);
  border-color: rgba(34,199,217,.42);
}

.home-service-band {
  background:
    linear-gradient(180deg, #ffffff 0%, #f4f7f9 100%);
  border-top: 1px solid rgba(30,35,40,.07);
  border-bottom: 1px solid rgba(30,35,40,.07);
}
.home-service-band .section-heading {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(320px, .65fr);
  gap: clamp(22px, 4vw, 58px);
  align-items: end;
  max-width: none;
}
.home-service-band .section-heading p:not(.eyebrow) {
  max-width: 560px;
  justify-self: end;
}
.service-grid-home { align-items: stretch; }
.service-card {
  border-radius: var(--r-sm);
  box-shadow: 0 1px 0 rgba(30,35,40,.03);
}
.service-card > div:last-child {
  min-height: 300px;
  padding: clamp(24px, 2.3vw, 36px);
}
.service-card-media {
  aspect-ratio: 16 / 10;
  background: var(--deep-2);
}
.service-card-media img {
  min-height: 100%;
  object-position: center center;
}
.service-card-media img[src*="home-rollout-digital-signage"] { object-position: center 48%; }
.service-card-media img[src*="home-service-wartung-austausch"] { object-position: center 42%; }

.experience-proof-layered {
  position: relative;
  overflow: hidden;
}
.experience-proof-layered::before {
  content: '';
  position: absolute;
  inset: auto 0 0;
  height: 42%;
  background: var(--deep);
  pointer-events: none;
}
.experience-proof-layered > * { position: relative; z-index: 1; }
.experience-showcase-grid {
  gap: clamp(22px, 3.8vw, 52px);
}
.map-reference-card {
  border-radius: var(--r-sm);
  box-shadow: 0 20px 58px rgba(14,19,23,.18);
}
.map-reference-visual {
  min-height: 320px;
  padding: clamp(24px, 3vw, 42px);
}
.map-reference-visual img {
  width: min(76%, 470px);
  max-height: 300px;
}
.experience-picture-card {
  min-height: 280px;
  border-radius: var(--r-sm);
}
.experience-picture-card img {
  min-height: 280px;
  object-position: center center;
}

.service-overview-sticky {
  position: sticky;
  top: var(--header-h);
  z-index: 12;
  padding: 18px 0;
  border-bottom: 1px solid rgba(30,35,40,.08);
  box-shadow: 0 12px 28px rgba(20,28,34,.08);
}
.leistungen-jumpbar-v3 a {
  border-radius: var(--r-sm);
  min-height: 54px;
}
.leistungen-principle-section {
  background:
    linear-gradient(180deg, #ffffff 0%, #f6f8fa 100%);
}
.leistungen-layered-section {
  border-top: 1px solid rgba(30,35,40,.08);
}
.layered-intro {
  padding-bottom: clamp(22px, 3vw, 36px);
  border-bottom: 1px solid rgba(30,35,40,.1);
}
.layer-opener {
  border-radius: var(--r-lg);
  box-shadow: 0 24px 70px rgba(14,19,23,.16);
}
.layer-opener-media img[src*="leistungen-outdoor-opener"] { object-position: center center; }
.layer-opener-media img[src*="leistungen-indoor-opener"] { object-position: center center; }
.capability-stack {
  gap: clamp(18px, 2.4vw, 30px);
}
.capability-row {
  min-height: clamp(300px, 28vw, 420px);
  border-radius: var(--r-lg);
  box-shadow: 0 14px 42px rgba(14,19,23,.075);
}
.capability-row-media {
  min-height: clamp(300px, 28vw, 420px);
}
.capability-row-media img[src*="leistungen-outdoor-sensorik"] { object-position: center center; }
.capability-row-media img[src*="leistungen-outdoor-led"] { object-position: center center; }
.capability-row-media img[src*="leistungen-indoor-raumsensorik"] { object-position: center center; }
.capability-row-media img[src*="leistungen-indoor-controller"] { object-position: center 38%; }
.capability-row-portrait .capability-row-media {
  padding: 0;
}
.capability-row-portrait .capability-row-media img {
  width: 100%;
  max-width: none;
  height: 100%;
  max-height: none;
  border-radius: 0;
  box-shadow: none;
}
.capability-row-portrait .capability-row-media img[src*="leistungen-outdoor-mastsetzen"] { object-position: center center; }
.scene-breaker {
  border-radius: var(--r-lg);
}

.support-models-section {
  background:
    linear-gradient(180deg, var(--paper) 0%, var(--soft) 100%);
}
.support-model-grid {
  gap: var(--s-4);
}
.support-model-card-compact {
  grid-template-rows: 150px 1fr;
  border-radius: var(--r-sm);
  box-shadow: none;
}
.support-model-card-compact figure {
  aspect-ratio: auto;
  height: 150px;
  overflow: hidden;
  background: var(--deep-2);
}
.support-model-card-compact figure::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(14,19,23,.18), transparent 62%);
  pointer-events: none;
}
.support-model-card-compact img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.support-model-card-compact img[src*="home-service-wartung-austausch"] { object-position: center 40%; }
.support-model-card-compact img[src*="home-proof-dokumentation"] { object-position: center 44%; }
.support-model-card-compact > div {
  padding: var(--s-5);
}
.support-model-card-compact h3 {
  font-size: clamp(1.05rem, 1.2vw, 1.25rem);
  line-height: 1.16;
}
.support-model-card-compact p:not(.eyebrow) {
  font-size: .9rem;
  line-height: 1.52;
}
.client-fit-section {
  border-top: 1px solid rgba(30,35,40,.07);
}

@media (max-width: 1180px) {
  .home-service-band .section-heading {
    grid-template-columns: 1fr;
  }
  .home-service-band .section-heading p:not(.eyebrow) {
    justify-self: start;
  }
  .service-overview-sticky {
    position: static;
    box-shadow: none;
  }
}

@media (max-width: 760px) {
  .hero-title,
  .page-title {
    max-width: min(100%, 23rem);
    font-size: clamp(2.35rem, 11vw, 2.95rem);
    line-height: 1.08;
    letter-spacing: -.035em;
    overflow-wrap: normal;
  }
  .hero-title span {
    max-width: 100%;
  }
  .hero-subline,
  .page-hero p,
  .hero-value {
    max-width: min(100%, 22rem);
  }
  .recognition-section-layered {
    padding-top: 66px;
    padding-bottom: 66px;
  }
  .service-grid-home {
    grid-template-columns: 1fr;
  }
  .service-card > div:last-child {
    min-height: 0;
  }
  .service-card-media,
  .experience-picture-card,
  .experience-picture-card img {
    min-height: 0;
    aspect-ratio: 4 / 3;
  }
  .experience-proof-layered::before {
    height: 28%;
  }
  .map-reference-visual {
    min-height: 220px;
  }
  .capability-row {
    box-shadow: 0 10px 30px rgba(14,19,23,.07);
  }
  .capability-row-media,
  .capability-row-portrait .capability-row-media {
    min-height: 0;
    aspect-ratio: 4 / 3;
  }
  .support-model-card-compact {
    grid-template-rows: 170px auto;
  }
}

/* ================================================================
   MOBILE UI KIT ALIGNMENT
   Home page mobile controls, radii, surfaces, and sticky CTA.
   Source: design-system/mobile/mobile-ui-kit.html
   ================================================================ */
.mobile-action-bar {
  display: none;
}

.hero-mobile-poster {
  display: none;
}

@media (max-width: 760px) {
  :root {
    --header-h: 86px;
  }

  html {
    scroll-padding-top: 104px;
  }

  body {
    padding-bottom: 76px;
  }

  .site-header,
  .site-header.is-scrolled {
    height: 86px;
    align-items: center;
    padding: 0 18px;
    color: var(--deep);
    background: var(--paper);
    border-bottom: 1px solid rgba(30, 35, 40, .1);
    box-shadow: 0 1px 0 rgba(30, 35, 40, .04);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .site-header::after {
    display: none;
  }

  .brand,
  .site-header.is-scrolled .brand {
    height: 86px;
    padding: 0;
    border-right: 0;
  }

  .brand .logo-white {
    display: none;
  }

  .brand .logo-color,
  .site-header.is-scrolled .brand .logo-color {
    display: block;
    width: 112px;
    height: 60px;
  }

  .menu-toggle {
    width: 48px;
    height: 48px;
    border-radius: 4px;
    background: transparent;
    border-color: rgba(30, 35, 40, .9);
  }

  .site-nav {
    inset: 78px 12px auto;
    padding: 18px;
    background: var(--paper);
    border: 1px solid var(--line);
    border-radius: 6px;
    box-shadow: 0 1px 0 rgba(30, 35, 40, .04), 0 4px 12px rgba(30, 35, 40, .08);
  }

  .site-nav a {
    min-height: 48px;
    border-radius: 4px;
  }

  .site-nav .nav-cta {
    color: var(--deep);
    background: rgba(34, 199, 217, .12);
    border-color: rgba(34, 199, 217, .65);
    box-shadow: none;
  }

  .section {
    padding: 64px 0;
  }

  .hero-video-stage {
    min-height: auto;
    padding: 112px 0 54px;
  }

  .hero-mobile-poster {
    position: absolute;
    inset: 0;
    display: block;
  }

  .hero-mobile-poster img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .hero-video-stage.is-video-intro .hero-copy-overlay {
    opacity: 1;
    transform: none;
    pointer-events: auto;
  }

  .hero-proof-strip {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 22px;
  }

  .hero-proof-strip span {
    min-height: 38px;
    padding: 8px 10px;
    border-radius: 2px;
    background: rgba(255, 255, 255, .08);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .button,
  .leistungen-jumpbar-v3 a {
    min-height: 52px;
    border-radius: 4px;
  }

  .button-secondary {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .service-card,
  .proof-card,
  .map-reference-card,
  .experience-picture-card,
  .support-model-card,
  .support-model-card-compact,
  .capability-row,
  .scene-breaker,
  .layer-opener {
    border-radius: 6px;
    box-shadow: 0 1px 0 rgba(30, 35, 40, .04), 0 1px 2px rgba(30, 35, 40, .06);
  }

  .service-card-media,
  .map-reference-visual,
  .experience-picture-card img,
  .capability-row-media,
  .layer-opener-media {
    border-radius: 10px 10px 0 0;
  }

  .service-card-media picture,
  .map-reference-visual picture,
  .experience-picture-card picture {
    display: block;
    width: 100%;
    height: 100%;
  }

  .service-card-media picture img,
  .experience-picture-card picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .service-card-media figcaption,
  .layer-opener-media figcaption {
    border-radius: 2px;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .mobile-action-bar {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 45;
    display: block;
    padding: 12px 18px;
    background: var(--paper);
    border-top: 1px solid rgba(30, 35, 40, .12);
    opacity: 0;
    pointer-events: none;
    transform: translateY(100%);
    transition: opacity .18s ease, transform .18s ease;
  }

  body.show-mobile-action .mobile-action-bar {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  body.menu-open .mobile-action-bar {
    opacity: 0;
    pointer-events: none;
    transform: translateY(100%);
  }

  .mobile-action-bar .button {
    width: 100%;
    justify-content: center;
  }
}
