
:root {
  --primary: #0c254d;
  --primary-dark: #061123;
  --primary-soft: #5e82ba;
  --accent: #654b3c;
  --cream: #faf6ed;
  --sand: #e8d8b7;
  --ink: #1a2419;
  --ink-soft: #4a5249;
  --line: #d8d2c4;
  --bg: #fbfaf6;
  --white: #ffffff;
  --gold: var(--accent);
  --font: -apple-system, BlinkMacSystemFont, "Inter", "SF Pro Display", "Helvetica Neue", system-ui, sans-serif;
}

@page { size: A4; margin: 0; }
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  font-family: var(--font);
  color: var(--ink);
  background: #efe9dc;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body { padding: 0; }

h1, h2, h3, h4 {
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--ink);
  font-weight: 700;
}
h1 { font-size: 46pt; font-weight: 800; letter-spacing: -0.035em; }
h2 { font-size: 24pt; }
h3 { font-size: 13pt; }
h4 { font-size: 10.5pt; font-weight: 600; }
p, li, td, th { font-size: 9.5pt; line-height: 1.5; color: var(--ink-soft); }

.eyebrow {
  font-size: 8pt;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--primary);
  font-weight: 600;
}
.accent { color: var(--primary); }

/* ============= PAGE WRAPPER =============
   FIX (2026-05-15 MM): height: 297mm STATT min-height. min-height liess Content
   ueberlaufen + Page-Break-Geometry kaputt. Mit fester Hoehe + overflow:hidden
   bleibt jede Seite genau A4 hoch, Score-Cards leaken nicht auf next page. */
.page {
  width: 210mm;
  height: 297mm;
  /* FIX (2026-05-15 NN): padding-bottom 22mm reserviert Footer-Hoehe.
     Vorher kollidierte absolute-Footer mit Page-2 Score-Karten + Page-3
     Stats-Strip. 22mm = 5mm footer-bottom + ~17mm Footer-Inhalt (2 Zeilen + border-top + padding-top). */
  padding: 12mm 13mm 22mm 13mm;
  page-break-after: always;
  page-break-inside: avoid;
  break-after: page;
  break-inside: avoid;
  position: relative;
  background: var(--bg);
  overflow: hidden;
  box-sizing: border-box;
  margin: 14mm auto;
  box-shadow: 0 16px 60px rgba(0, 0, 0, 0.18);
}
/* Cover bleibt ohne padding-bottom (eigenes layout mit cover-copy/cover-recipient) */
.page.cover { padding-bottom: 0; }
.page:last-child { page-break-after: auto; break-after: auto; }

/* FIX (2026-05-15 MM): Print-only: kein margin + kein box-shadow.
   Screen-preview-margin (14mm auto) + box-shadow lassen das Page-Element
   ueber 297mm wachsen -> Chrome druckt jede Section auf 2 Seiten. */
@media print {
  html, body { background: #ffffff !important; }
  .page {
    margin: 0 !important;
    box-shadow: none !important;
    page-break-after: always;
    break-after: page;
  }
  .page:last-child { page-break-after: auto; break-after: auto; }
}

.footer {
  /* FIX (2026-05-15 NN): position absolute mit bottom 5mm kollidierte mit
     content-flow-elements (page 2 score-cards, page 3 stats-strip).
     Loesung: bottom auf 6mm, opaker Hintergrund + z-index, damit Footer
     IMMER klar lesbar bleibt selbst bei marginalen Content-Overlaps. */
  position: absolute;
  left: 13mm;
  right: 13mm;
  bottom: 6mm;
  font-size: 7pt;
  color: var(--ink-soft);
  border-top: 1px solid var(--line);
  padding-top: 2mm;
  background: var(--bg);
  z-index: 5;
}
.footer .row1 { display: flex; justify-content: space-between; }
.footer .row1 .brand { font-weight: 700; color: var(--primary); }
.footer .copy { font-size: 6pt; color: var(--ink-soft); margin-top: 2px; line-height: 1.4; opacity: 0.85; }
.footer .copy b { color: var(--primary); font-weight: 700; }

/* ============= COVER ============= */
.cover {
  background: linear-gradient(140deg, var(--primary-dark) 0%, var(--primary) 55%, var(--primary-soft) 100%);
  color: var(--cream);
  padding: 0;
  display: flex;
  flex-direction: column;
}
.cover::before {
  content: "";
  position: absolute;
  right: -60mm;
  top: -30mm;
  width: 200mm;
  height: 200mm;
  background: radial-gradient(circle, rgba(232,216,183,0.15) 0%, transparent 60%);
  pointer-events: none;
}
.cover::after {
  content: "";
  position: absolute;
  left: -50mm;
  bottom: -50mm;
  width: 160mm;
  height: 160mm;
  background: radial-gradient(circle, rgba(168,122,74,0.20) 0%, transparent 60%);
  pointer-events: none;
}
.cover-top {
  padding: 10mm 16mm 0 16mm;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 2;
  gap: 12px;
}
.cover-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 1 1 auto;
  min-width: 0;
}
.logo-plate {
  width: 64px;
  height: 64px;
  background: var(--cream);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
  flex-shrink: 0;
  font-size: 24pt;
  font-weight: 800;
  color: var(--primary-dark);
  letter-spacing: -0.02em;
}
.cover-brand .meta { line-height: 1.2; min-width: 0; }
.cover-brand .meta .name {
  font-size: 13pt;
  font-weight: 700;
  color: var(--cream);
  letter-spacing: -0.01em;
}
.cover-brand .meta .sub {
  font-size: 8pt;
  color: var(--sand);
  margin-top: 4px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.cover-tag {
  background: var(--gold);
  color: var(--primary-dark);
  padding: 7px 14px;
  border-radius: 99px;
  font-size: 8pt;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  flex-shrink: 0;
}

.cover-body {
  padding: 7mm 16mm 0 16mm;
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.18fr 0.82fr;
  gap: 10mm;
  align-items: start;
}
.cover-left .eye {
  color: var(--sand);
  font-size: 8pt;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
}
.cover-left h1 {
  color: var(--cream);
  margin-top: 8px;
  font-size: 38pt;
  line-height: 1.04;
}
.cover-left h1 .accent { color: var(--gold); }
.cover-left .lead {
  color: var(--cream);
  font-size: 10.5pt;
  line-height: 1.5;
  margin-top: 10px;
  opacity: 0.94;
}
.cover-left .pull {
  margin-top: 10px;
  padding: 10px 14px;
  border-left: 3px solid var(--gold);
  font-size: 10pt;
  color: var(--cream);
  font-style: italic;
  line-height: 1.4;
  background: rgba(0,0,0,0.18);
  border-radius: 0 8px 8px 0;
}
.cover-left .pull .who {
  display: block;
  margin-top: 6px;
  font-style: normal;
  font-size: 8pt;
  color: var(--sand);
  letter-spacing: 0.04em;
}
.cover-left .url {
  margin-top: 10px;
  font-size: 10pt;
  color: var(--gold);
  font-weight: 700;
  letter-spacing: 0.04em;
  word-break: break-all;
}

.cover-shot {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 70px rgba(0,0,0,0.45);
  border: 3px solid rgba(232,216,183,0.3);
  transform: rotate(0.6deg);
  background: var(--cream);
  height: 64mm;
  position: relative;
}
/* FIX (2026-05-15 MM): iframe -> img - X-Frame-Options blockierte Embedding
   bei file:// origin. Lokale WebP-Shots werden via render_site_shots.py erzeugt.
   Feste Hoehe + object-fit:cover damit Gregor-Aspect (1440x900 ~ 1.6:1) den
   Frame fuellt OHNE Verzerrung. */
.cover-shot img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
.cover-shot .shot-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-height: 70mm;
  text-align: center;
  padding: 20px;
  background: linear-gradient(135deg, var(--cream), var(--sand));
  color: var(--primary-dark);
}
.cover-shot .shot-placeholder strong {
  font-size: 14pt;
  margin-top: 6px;
  letter-spacing: -0.02em;
}
.cover-shot .shot-placeholder span {
  font-size: 9pt;
  color: var(--primary);
  margin-top: 4px;
  opacity: 0.8;
}
.cover-caption {
  color: var(--sand);
  font-size: 8.5pt;
  margin-top: 10px;
  text-align: right;
  letter-spacing: 0.04em;
}

.cover-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin: 6mm 16mm 0 16mm;
  position: relative;
  z-index: 2;
}
.cover-stat {
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(232,216,183,0.32);
  border-radius: 12px;
  padding: 10px 12px;
}
.cover-stat .num {
  font-size: 22pt;
  font-weight: 800;
  color: var(--cream);
  letter-spacing: -0.035em;
  line-height: 1;
}
.cover-stat .num small {
  font-size: 12pt;
  color: var(--gold);
  font-weight: 700;
}
.cover-stat .label {
  font-size: 7.5pt;
  color: var(--sand);
  margin-top: 6px;
  letter-spacing: 0.05em;
  line-height: 1.3;
}

.cover-services {
  margin: 5mm 16mm 0 16mm;
  position: relative;
  z-index: 2;
}
.cover-services-eye {
  font-size: 8pt;
  color: var(--sand);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 6px;
  opacity: 0.85;
}
.cover-services-row { display: flex; flex-wrap: wrap; gap: 6px; }
.cs-tag {
  display: inline-block;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(232,216,183,0.32);
  color: var(--cream);
  font-size: 8pt;
  padding: 5px 10px;
  border-radius: 99px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.cover-promise {
  margin: 5mm 16mm 0 16mm;
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.promise {
  background: rgba(0,0,0,0.18);
  border: 1px solid rgba(212,169,70,0.4);
  border-left: 3px solid var(--gold);
  border-radius: 10px;
  padding: 8px 12px;
}
.promise .ico { font-size: 14pt; line-height: 1; margin-bottom: 4px; }
.promise .ti {
  font-size: 9pt;
  color: var(--cream);
  font-weight: 700;
  letter-spacing: -0.005em;
  line-height: 1.2;
}
.promise .desc {
  font-size: 7.5pt;
  color: var(--sand);
  margin-top: 4px;
  line-height: 1.4;
  opacity: 0.92;
}

.cover-marquee {
  margin: 5mm 0 0 0;
  padding: 6px 16mm;
  position: relative;
  z-index: 2;
  background: linear-gradient(90deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.3) 100%);
  border-top: 1px solid rgba(212,169,70,0.35);
  border-bottom: 1px solid rgba(212,169,70,0.35);
  display: flex;
  align-items: center;
  gap: 16px;
  overflow: hidden;
  flex-wrap: wrap;
}
.cover-marquee span {
  color: var(--cream);
  font-size: 9pt;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
}
.cover-marquee .dot {
  display: inline-block;
  width: 5px;
  height: 5px;
  background: var(--gold);
  border-radius: 50%;
  margin: 0 4px;
}
.cover-tagline {
  margin: 6mm 16mm 0 16mm;
  position: relative;
  z-index: 2;
  text-align: center;
  font-size: 9pt;
  color: var(--sand);
  letter-spacing: 0.08em;
  font-style: italic;
}
.cover-tagline b {
  color: var(--cream);
  font-style: normal;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.cover-recipient {
  margin: auto 16mm 0 16mm;
  padding-top: 8px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  z-index: 2;
  border-top: 1px solid rgba(232,216,183,0.25);
  position: relative;
}
.cover-recipient .for { font-size: 10.5pt; color: var(--cream); font-weight: 700; }
.cover-recipient .by { font-size: 8pt; color: var(--sand); margin-top: 2px; opacity: 0.9; }
.cover-recipient .right { text-align: right; }
.cover-recipient .date { font-size: 9.5pt; color: var(--cream); font-weight: 600; }
.cover-recipient .pn { font-size: 7.5pt; color: var(--sand); margin-top: 2px; opacity: 0.75; }
.cover-copy {
  margin: 3mm 16mm 5mm 16mm;
  z-index: 2;
  font-size: 6pt;
  color: var(--sand);
  opacity: 0.7;
  text-align: center;
  line-height: 1.4;
  letter-spacing: 0.02em;
  position: relative;
}
.cover-copy b { color: var(--cream); font-weight: 600; opacity: 0.9; }

/* ============= PAGE-HEAD (inner pages) ============= */
.page-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 6mm;
  padding-bottom: 5mm;
  border-bottom: 1px solid var(--line);
  gap: 14px;
}
.page-head .title { flex: 1 1 auto; min-width: 0; }
.page-head .title h2 { color: var(--ink); font-size: 22pt; }
.page-head .title .eyebrow { display: block; margin-bottom: 4px; }
.page-head .small-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 8.5pt;
  color: var(--ink-soft);
  flex-shrink: 0;
  white-space: nowrap;
}
.small-brand .small-logo {
  width: 30px;
  height: 30px;
  background: var(--primary);
  color: var(--cream);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 10pt;
}

/* ============= VERGLEICH ============= */
.dual-shots {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4mm;
  margin-bottom: 5mm;
}
.dual-shot {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 6px 20px rgba(26,36,25,0.10);
  background: var(--white);
  position: relative;
  min-height: 70mm;
}
.dual-shot.alt { border-color: #d4cab2; }
.dual-shot.neu { border-color: var(--primary-soft); }
.dual-shot .shot-tag {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 7pt;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  z-index: 2;
}
.dual-shot.alt .shot-tag { background: #c4b896; color: #5a4f30; }
.dual-shot.neu .shot-tag { background: var(--primary); color: var(--cream); }
/* FIX (2026-05-15 MM): iframe -> img (X-Frame-Options Bug). */
.dual-shot img {
  display: block;
  width: 100%;
  height: 56mm;
  object-fit: cover;
  object-position: top center;
}
.dual-shot .placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 56mm;
  text-align: center;
  padding: 16px;
  background: repeating-linear-gradient(45deg, #f3efe6, #f3efe6 12px, #ede8dc 12px, #ede8dc 24px);
  color: var(--ink-soft);
}
.dual-shot .placeholder strong {
  font-size: 11pt;
  color: var(--ink);
  margin-top: 8px;
}
.dual-shot .cap {
  padding: 6px 12px;
  font-size: 7.5pt;
  color: var(--ink-soft);
  border-top: 1px solid var(--line);
  background: var(--bg);
  display: flex;
  justify-content: space-between;
  gap: 8px;
}
.dual-shot .cap b { color: var(--ink); font-weight: 700; word-break: break-all; }
.dual-shot.neu .cap b { color: var(--primary); }

.vs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5mm; }
.vs-col {
  background: var(--white);
  border-radius: 12px;
  padding: 6mm 6mm;
  border: 1px solid var(--line);
}
.vs-col.alt { background: #f3efe6; border-color: #d8d2c4; }
.vs-col.neu { background: linear-gradient(165deg, var(--cream) 0%, #fff 100%); border-color: var(--primary-soft); }
.vs-col h3 { color: var(--primary); font-size: 12pt; margin-bottom: 2px; }
.vs-col.alt h3 { color: var(--ink-soft); }
.vs-col .sub { font-size: 7.5pt; color: var(--ink-soft); margin-bottom: 8px; }
.vs-col .tag {
  display: inline-block;
  font-size: 7pt;
  padding: 3px 8px;
  border-radius: 99px;
  margin-bottom: 6px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
}
.vs-col.alt .tag { background: #d8d2c4; color: var(--ink-soft); }
.vs-col.neu .tag { background: var(--primary); color: var(--cream); }
.vs-col ul { list-style: none; margin-top: 6px; }
.vs-col li {
  padding: 5px 0 5px 20px;
  position: relative;
  font-size: 8.5pt;
  line-height: 1.42;
  border-bottom: 1px dashed var(--line);
}
.vs-col li:last-child { border-bottom: none; }
/* FIX (2026-05-15 MM): CSS content akzeptiert KEINE HTML-Entities - das ergab
   sichtbare "&#10003;" Strings als Schrift-auf-Schrift Bug. Direkte UTF-8 Glyphs
   ✗ und ✓ funktionieren wie bei Gregor's presentation.html (line 129/130). */
.vs-col.alt li::before { content: "\2717"; position: absolute; left: 0; top: 4px; color: #b85a4a; font-weight: 700; font-size: 11pt; }
.vs-col.neu li::before { content: "\2713"; position: absolute; left: 0; top: 4px; color: var(--primary); font-weight: 700; font-size: 11pt; }
.vs-col li b { color: var(--ink); font-weight: 700; }

.scores {
  margin-top: 4mm;
  background: var(--white);
  border-radius: 12px;
  padding: 4mm 7mm;
  border: 1px solid var(--line);
}
.scores .heading { display: flex; justify-content: space-between; align-items: center; margin-bottom: 3mm; flex-wrap: wrap; gap: 6px; }
.scores h4 { font-size: 10pt; color: var(--ink); }
.scores .src { font-size: 7.5pt; color: var(--ink-soft); letter-spacing: 0.04em; }
.score-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.score-card {
  text-align: center;
  padding: 7px 8px;
  border-radius: 10px;
  background: var(--bg);
  border: 1px solid var(--line);
}
.score-card .lbl {
  font-size: 8pt;
  color: var(--ink-soft);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 6px;
}
.score-card .row { display: flex; align-items: center; justify-content: center; gap: 6px; }
.score-card .val {
  font-size: 17pt;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
}
.score-card .val.bad { color: #b85a4a; }
.score-card .val.good { color: var(--primary); }
.score-card .arrow { color: var(--gold); font-weight: 800; font-size: 13pt; }

/* ============= LEISTUNGEN ============= */
.leistungen-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4mm;
  margin-bottom: 6mm;
}
.leistung {
  background: var(--white);
  border-radius: 12px;
  padding: 9px 12px;
  border-left: 3px solid var(--primary);
  border-top: 1px solid var(--line);
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.leistung .icon { font-size: 17pt; line-height: 1; flex-shrink: 0; padding-top: 2px; }
.leistung .body { flex: 1; min-width: 0; }
.leistung .body h4 { font-size: 9.5pt; color: var(--ink); margin-bottom: 3px; }
.leistung .body p { font-size: 8.2pt; line-height: 1.4; }

.svc-summary {
  background: var(--primary-dark);
  color: var(--cream);
  border-radius: 12px;
  padding: 10px 14px;
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
  margin-top: 1mm;
  flex-wrap: wrap;
}
.svc-summary .left { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.svc-summary .summary-num {
  font-size: 22pt;
  font-weight: 800;
  color: var(--gold);
  letter-spacing: -0.03em;
  line-height: 1;
}
.svc-summary .summary-lbl { font-size: 8pt; color: var(--sand); letter-spacing: 0.06em; line-height: 1.3; }
.svc-summary .right { font-size: 8pt; color: var(--sand); text-align: right; line-height: 1.4; flex: 1; min-width: 50mm; }
.svc-summary .right b { color: var(--cream); }

/* ============= BOTTOM MODULE (Page 3) =============
   FIX (2026-05-15 NN): Bug B Whitespace-Fix. Branchen-spezifisches Mini-Modul
   zwischen Stats-Strip und Footer.
*/
.bottom-mod {
  margin-top: 4mm;
  margin-bottom: 14mm;
  background: linear-gradient(165deg, var(--cream) 0%, #fff 100%);
  border-radius: 12px;
  padding: 5mm 6mm;
  border: 1px solid var(--primary-soft);
}
.bottom-mod .head { margin-bottom: 3mm; }
.bottom-mod .head .eyebrow { font-size: 7.5pt; }
.bottom-mod .head h3 { color: var(--primary-dark); font-size: 12pt; margin-top: 2px; letter-spacing: -0.01em; }
.bottom-mod-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4mm 6mm;
}
.bm-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 4px 0;
  border-bottom: 1px dashed var(--line);
}
.bm-item:nth-last-child(-n+2) { border-bottom: none; }
.bm-item .k {
  font-size: 8.5pt;
  color: var(--primary);
  font-weight: 700;
  letter-spacing: -0.005em;
}
.bm-item .v {
  font-size: 8.2pt;
  color: var(--ink-soft);
  line-height: 1.4;
}

/* ============= TRUST ============= */
.top-row {
  display: grid;
  grid-template-columns: 1fr 50mm;
  gap: 4mm;
  margin-bottom: 4mm;
}
.ready-strip {
  background: var(--white);
  border-radius: 12px;
  padding: 5mm 6mm;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.ready-strip .rs-row { display: flex; flex-wrap: wrap; gap: 5px; }
.ready-strip .rs-pill {
  display: inline-block;
  background: var(--cream);
  border: 1px solid var(--primary-soft);
  color: var(--primary-dark);
  font-size: 8pt;
  padding: 4px 9px;
  border-radius: 99px;
  font-weight: 600;
  line-height: 1.1;
}
.ready-strip .rs-foot { font-size: 8pt; color: var(--ink-soft); margin-top: 8px; padding-top: 8px; border-top: 1px dashed var(--line); }
.mobile-shot {
  background: var(--white);
  border-radius: 12px;
  padding: 5mm 5mm;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
}
.mobile-shot .phone {
  width: 32mm;
  height: 56mm;
  border-radius: 10px;
  overflow: hidden;
  border: 4px solid var(--ink);
  box-shadow: 0 10px 22px rgba(26,36,25,0.20);
  background: var(--bg);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 7pt;
  color: var(--ink-soft);
}
.mobile-shot .phone > div { padding: 8px; }
/* FIX (2026-05-15 MM): iframe -> img (X-Frame-Options Bug).
   img fuellt das phone-Frame komplett, kein padding. */
.mobile-shot .phone img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
.mobile-shot .cap { font-size: 7.5pt; color: var(--ink-soft); margin-top: 6px; text-align: center; line-height: 1.3; }
.mobile-shot .cap b { color: var(--primary); }

.guarantee {
  background: linear-gradient(135deg, var(--gold) 0%, var(--accent) 100%);
  color: var(--primary-dark);
  border-radius: 12px;
  padding: 4mm 6mm;
  margin-bottom: 3mm;
  display: flex;
  gap: 12px;
  align-items: center;
  box-shadow: 0 6px 18px rgba(0,0,0,0.18);
}
.guarantee .icon { font-size: 22pt; flex-shrink: 0; }
.guarantee h3 { color: var(--primary-dark); font-size: 12pt; margin-bottom: 2px; }
.guarantee p { color: var(--primary-dark); font-size: 8.5pt; line-height: 1.4; opacity: 0.9; }

.trust-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3mm;
  margin-top: 3mm;
  /* FIX (2026-05-15 NN): margin-bottom schuetzt vor Footer-Overlap auf Page 4. */
  margin-bottom: 14mm;
}
.trust-tile {
  background: var(--white);
  border-radius: 10px;
  padding: 10px 12px;
  border-top: 3px solid var(--primary);
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.trust-tile h4 { font-size: 9pt; color: var(--primary); margin-bottom: 4px; }
.trust-tile p { font-size: 8pt; color: var(--ink-soft); line-height: 1.4; }

/* ============= KONTAKT (Page 5) ============= */
.next {
  background: var(--primary-dark);
  color: var(--cream);
  border-radius: 12px;
  padding: 4mm 6mm;
}
.next h3 { color: var(--cream); font-size: 12pt; }
.next .sub { font-size: 8pt; color: var(--sand); margin-top: 2px; }
.next-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3mm; margin-top: 3mm; }
.next-block {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(232,216,183,0.25);
  border-radius: 8px;
  padding: 8px 12px;
}
.next-block h4 { color: var(--sand); font-size: 8pt; margin-bottom: 4px; letter-spacing: 0.05em; text-transform: uppercase; }
.next-block ol { list-style: decimal; padding-left: 14px; }
.next-block li { color: var(--cream); font-size: 8pt; line-height: 1.45; padding: 2px 0; }

.cta-row {
  background: linear-gradient(90deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: var(--cream);
  border-radius: 12px;
  padding: 4mm 6mm;
  margin-top: 3mm;
  /* FIX (2026-05-15 NN): margin-bottom schuetzt vor Footer-Overlap. */
  margin-bottom: 14mm;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 6px 18px rgba(0,0,0,0.18);
  flex-wrap: wrap;
  gap: 10px;
}
.cta-row .left h3 { color: var(--cream); font-size: 13pt; }
.cta-row .left p { color: var(--sand); font-size: 9pt; margin-top: 4px; }
.cta-row .right { text-align: right; font-size: 9.5pt; color: var(--cream); }
.cta-row .right .big { font-size: 14pt; font-weight: 800; color: var(--gold); letter-spacing: -0.01em; display: block; }
.cta-row .right small { font-size: 8pt; color: var(--sand); }

/* Timeline */
.timeline {
  background: linear-gradient(165deg, var(--cream) 0%, #fff 100%);
  border-radius: 12px;
  padding: 4mm 6mm 4mm 6mm;
  border: 1px solid var(--primary-soft);
  margin: 3mm 0;
}
.timeline .head { text-align: center; margin-bottom: 3mm; }
.timeline .head .eyebrow { color: var(--primary); font-size: 7.5pt; }
.timeline .head h3 { color: var(--primary-dark); font-size: 11pt; margin-top: 2px; }
.timeline-grid {
  display: grid;
  grid-template-columns: 1fr 16px 1fr 16px 1fr;
  gap: 6px;
  align-items: center;
}
.tl-step {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 10px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(26,36,25,0.06);
}
.tl-day {
  font-size: 7pt;
  color: var(--cream);
  font-weight: 800;
  letter-spacing: 0.08em;
  background: var(--primary);
  padding: 2px 8px;
  border-radius: 99px;
  display: inline-block;
  margin-bottom: 5px;
}
.tl-title {
  font-size: 9.5pt;
  color: var(--ink);
  font-weight: 700;
  margin-bottom: 3px;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.tl-desc { font-size: 7pt; color: var(--ink-soft); line-height: 1.35; }
.tl-arrow { font-size: 18pt; color: var(--gold); font-weight: 800; text-align: center; line-height: 1; }

/* ============= MOBILE RESPONSIVE ============= */
@media screen and (max-width: 820px) {
  body { background: var(--bg); }
  .page {
    width: 100%;
    min-height: auto;
    padding: 20px 18px 24px 18px;
    margin: 0 auto;
    box-shadow: none;
    page-break-after: always;
    border-bottom: 4px solid var(--primary);
  }
  h1 { font-size: 30pt; }
  h2 { font-size: 18pt; }
  .cover-top { padding: 16px 0 0 0; flex-direction: column; align-items: flex-start; gap: 12px; }
  .cover-body {
    padding: 12px 0 0 0;
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .cover-left h1 { font-size: 30pt; }
  .cover-stats { grid-template-columns: repeat(2, 1fr); margin: 18px 0 0 0; }
  .cover-services, .cover-promise, .cover-recipient, .cover-tagline, .cover-copy {
    margin: 14px 0 0 0;
  }
  .cover-promise { grid-template-columns: 1fr; }
  .cover-marquee { padding: 8px 14px; flex-wrap: wrap; }
  .dual-shots { grid-template-columns: 1fr; }
  .vs-grid { grid-template-columns: 1fr; }
  .score-grid { grid-template-columns: 1fr; }
  .leistungen-grid { grid-template-columns: 1fr; }
  .top-row { grid-template-columns: 1fr; }
  .mobile-shot { margin-top: 14px; }
  .next-grid { grid-template-columns: 1fr; }
  .timeline-grid { grid-template-columns: 1fr; }
  .tl-arrow { display: none; }
  .trust-grid { grid-template-columns: 1fr; }
  .cta-row { flex-direction: column; align-items: flex-start; text-align: left; }
  .cta-row .right { text-align: left; }
  .page-head { flex-direction: column; align-items: flex-start; }
  .footer { position: static; margin-top: 12px; }
}
