/* ── SELF-HOSTED FONTS (Latin Subset, woff2) ────────────────────────────── */
/* Lokale .woff2 in /fonts/ — kein Google CDN, kein DSGVO-Issue, kein FOUT-Risk. */

/* Barlow Condensed — Headlines */
@font-face { font-family: 'Barlow Condensed'; font-style: normal; font-weight: 300; font-display: swap;
  src: url('/fonts/barlow-condensed-300.woff2') format('woff2'); }
@font-face { font-family: 'Barlow Condensed'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('/fonts/barlow-condensed-400.woff2') format('woff2'); }
@font-face { font-family: 'Barlow Condensed'; font-style: normal; font-weight: 600; font-display: swap;
  src: url('/fonts/barlow-condensed-600.woff2') format('woff2'); }
@font-face { font-family: 'Barlow Condensed'; font-style: normal; font-weight: 700; font-display: swap;
  src: url('/fonts/barlow-condensed-700.woff2') format('woff2'); }
@font-face { font-family: 'Barlow Condensed'; font-style: italic; font-weight: 700; font-display: swap;
  src: url('/fonts/barlow-condensed-italic-700.woff2') format('woff2'); }
@font-face { font-family: 'Barlow Condensed'; font-style: normal; font-weight: 800; font-display: swap;
  src: url('/fonts/barlow-condensed-800.woff2') format('woff2'); }
@font-face { font-family: 'Barlow Condensed'; font-style: normal; font-weight: 900; font-display: swap;
  src: url('/fonts/barlow-condensed-900.woff2') format('woff2'); }

/* Barlow — Body */
@font-face { font-family: 'Barlow'; font-style: normal; font-weight: 300; font-display: swap;
  src: url('/fonts/barlow-300.woff2') format('woff2'); }
@font-face { font-family: 'Barlow'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('/fonts/barlow-400.woff2') format('woff2'); }
@font-face { font-family: 'Barlow'; font-style: normal; font-weight: 500; font-display: swap;
  src: url('/fonts/barlow-500.woff2') format('woff2'); }

/* IBM Plex Mono — Akzent / Mono */
@font-face { font-family: 'IBM Plex Mono'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('/fonts/ibm-plex-mono-400.woff2') format('woff2'); }
@font-face { font-family: 'IBM Plex Mono'; font-style: normal; font-weight: 500; font-display: swap;
  src: url('/fonts/ibm-plex-mono-500.woff2') format('woff2'); }

/* ── RESET + VARS ───────────────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --bg:        #0d0d0d;
  --surface:   #0d0d0d;
  --surface2:  #0f0f11;
  --border:    #1e1e24;
  --border2:   #2a2a32;
  --accent:    #3d5af1;
  --red:       #dc2626;  /* Status: kritisch / überfällig — sattes Rot, Dark-Theme-tauglich */
  --amber:     #f59e0b;  /* Status: bald fällig / Warnung — warmes klares Amber */
  --green:     #16a34a;  /* Status: erledigt / OK / Achievement — sattes Grün */

  /* Kategorie-Farben (Cost-Breakdown Donut/Bars) — Drei-Blau-Tonalität,
     bewusst NICHT die Status-Tokens red/amber/green. Reihenfolge nach
     Investitions-Tiefe: Service (hell) → Aufgaben (Patina-Blau) → Umbau (dunkel).
     Sprit bleibt neutral grau. */
  --cat-service: #b8d0f2;  /* hell — luftiges Pulverblau */
  --cat-repair:  #5577d5;  /* mittel — zwischen hell und dunkel, nicht der Accent */
  --cat-mod:     #1e40af;  /* dunkel — sattes Marineblau */
  --cat-fuel:    #6e6e7a;

  --txt:       #efefef;
  --txt2:      #d8d8d8;
  --txt3:      #aeaeae;
  --mono:      'IBM Plex Mono', monospace;
  --cond:      'Barlow Condensed', sans-serif;
  --body:      'Barlow', sans-serif;
  --r:         3px;
  --shadow:    0 4px 24px rgba(0,0,0,0.5);
}
html { scroll-behavior: smooth; background: var(--bg); }
body {
  background: var(--bg);
  color: var(--txt);
  font-family: var(--body);
  font-size: 15px;
  line-height: 1.5;
  overflow-x: hidden;
}

/* Mobile-Tap-Highlight global aus — wir haben überall eigene :active-Animationen
   (scale, opacity, color), der Browser-Default-Overlay wäre nur Doppelung und
   wirkt mit seiner fixed-color/duration nicht editorial. */
* {
  -webkit-tap-highlight-color: transparent;
}
/* Accessibility: Keyboard-Tab-Navigation behält sichtbaren Focus-Ring.
   :focus-visible greift NUR bei Keyboard, nicht bei Tap/Mouse — clean. */
button, a, [role="button"], [tabindex]:not([tabindex="-1"]) {
  outline: none;
}
button:focus-visible,
a:focus-visible,
[role="button"]:focus-visible,
[tabindex]:not([tabindex="-1"]):focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ── PAGE SYSTEM ────────────────────────────────────────────────────────── */
.page { display: none; min-height: 100vh; flex-direction: column; background: var(--bg); }
.page.active { display: flex; }


/* ══════════════════════════════════════════════════════════════════════════
   POLISH PRIMITIVES
   - Stagger: List-Items kommen versetzt rein (.list-stagger > *)
   - Skeleton: Pulsende Platzhalter (.skel)
   - Form-Focus: Globaler iOS-Style Focus-Ring (input/textarea/select)
   ══════════════════════════════════════════════════════════════════════════ */

/* ── STAGGER ─────────────────────────────────────────────────────────────── */
.list-stagger > * {
  animation: list-item-in 360ms cubic-bezier(0.32, 0.72, 0, 1) both;
  animation-delay: 0ms;
}
.list-stagger > *:nth-child(1)   { animation-delay:   0ms; }
.list-stagger > *:nth-child(2)   { animation-delay:  35ms; }
.list-stagger > *:nth-child(3)   { animation-delay:  70ms; }
.list-stagger > *:nth-child(4)   { animation-delay: 105ms; }
.list-stagger > *:nth-child(5)   { animation-delay: 140ms; }
.list-stagger > *:nth-child(6)   { animation-delay: 175ms; }
.list-stagger > *:nth-child(7)   { animation-delay: 210ms; }
.list-stagger > *:nth-child(8)   { animation-delay: 245ms; }
.list-stagger > *:nth-child(9)   { animation-delay: 280ms; }
.list-stagger > *:nth-child(n+10){ animation-delay: 310ms; }
@keyframes list-item-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0);   }
}

/* ── SKELETON ────────────────────────────────────────────────────────────── */
.skel {
  background: linear-gradient(90deg,
    rgba(255,255,255,0.04) 0%,
    rgba(255,255,255,0.08) 50%,
    rgba(255,255,255,0.04) 100%);
  background-size: 200% 100%;
  animation: skel-shimmer 1.4s ease-in-out infinite;
  border-radius: 8px;
}
@keyframes skel-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}


/* ── FORM-FOCUS GLOBAL ───────────────────────────────────────────────────── */
input:not([type="checkbox"]):not([type="radio"]),
textarea, select {
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}
input:not([type="checkbox"]):not([type="radio"]):focus,
textarea:focus, select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(61,90,241,0.18);
}

/* ── CARD PRESS FEEDBACK ─────────────────────────────────────────────────
   Tappable Karten/Buttons reagieren beim Drücken mit subtilem Scale-Down.
   Ergänzt bestehende :active-States (opacity/background) — addiert sich. */
.vehicle-card,
.dash-stat-tap,
.dash-attn-item,
.vic-stat-tap,
.acc-row:not(.acc-row-static),
.doc-row,
.add-vehicle-card {
  transition: transform 0.1s cubic-bezier(0.32,0.72,0,1),
              opacity 0.15s, background 0.15s, color 0.18s, border-color 0.18s;
}
.vehicle-card:active,
.dash-stat-tap:active,
.dash-attn-item:active,
.vic-stat-tap:active,
.acc-row:not(.acc-row-static):active,
.doc-row:active,
.add-vehicle-card:active {
  transform: scale(0.98);
}

/* ── UPLOAD PROGRESS ─────────────────────────────────────────────────────── */
.upload-progress {
  position: fixed; left: 50%; bottom: max(80px, calc(76px + env(safe-area-inset-bottom)));
  transform: translateX(-50%) translateY(8px);
  z-index: 5000;
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px;
  min-width: 220px; max-width: calc(100vw - 32px);
  background: rgba(15,15,17,0.95);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  opacity: 0; pointer-events: none;
  transition: transform 0.22s cubic-bezier(0.32,0.72,0,1), opacity 0.18s;
}
.upload-progress.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.upload-progress-spinner {
  width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--accent);
}
.upload-progress-spinner svg { animation: ptr-spin 0.9s linear infinite; }
.upload-progress.done .upload-progress-spinner {
  color: var(--green);
}
.upload-progress.done .upload-progress-spinner svg { animation: none; }
.upload-progress-body { flex: 1; min-width: 0; }
.upload-progress-text {
  font-family: var(--mono); font-size: 11px; color: var(--txt);
  letter-spacing: 0.04em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 5px;
}
.upload-progress-bar {
  height: 3px; border-radius: 2px;
  background: rgba(255,255,255,0.08);
  overflow: hidden;
}
.upload-progress-fill {
  height: 100%; width: 0%;
  background: var(--accent);
  transition: width 0.25s cubic-bezier(0.32,0.72,0,1);
}
.upload-progress.done .upload-progress-fill { background: var(--green); }

/* ── PULL-TO-REFRESH INDICATOR ──────────────────────────────────────────── */
.ptr-indicator {
  position: fixed;
  top: 0; left: 50%;
  transform: translateX(-50%) translateY(-30px);
  width: 38px; height: 38px;
  border-radius: 50%;
  background: rgba(15,15,17,0.92);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--txt2);
  z-index: 4000;
  opacity: 0; pointer-events: none;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.4);
}
.ptr-indicator.ready { color: var(--accent); border-color: rgba(61,90,241,0.5); }
.ptr-indicator.spinning svg {
  animation: ptr-spin 0.8s linear infinite;
}
@keyframes ptr-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* ── TOAST ───────────────────────────────────────────────────────────────── */
.toast-msg {
  position: fixed; left: 50%; bottom: max(24px, calc(20px + env(safe-area-inset-bottom)));
  transform: translateX(-50%) translateY(12px);
  z-index: 5000;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  background: rgba(15,15,17,0.95);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--txt);
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  opacity: 0; pointer-events: none;
  transition: transform 0.22s cubic-bezier(0.32,0.72,0,1), opacity 0.18s;
  max-width: calc(100vw - 32px);
}
.toast-msg.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.toast-success svg { color: var(--green); flex-shrink: 0; }
.toast-error svg, .toast-error span { color: var(--red); }

/* Toast mit Action-Button: pointer-events aktiv damit Button klickbar bleibt */
.toast-msg.toast-with-action { pointer-events: auto; padding: 8px 8px 8px 14px; gap: 14px; }
.toast-msg.toast-with-action.show { pointer-events: auto; }
.toast-text { display: inline-flex; align-items: center; }
.toast-action {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  padding: 6px 12px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.toast-action:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.15); }
.toast-action:active { transform: scale(0.96); }

/* ── DONE ANIMATION (Todo abhaken) ──────────────────────────────────────── */
/* Strike nur auf dem Titel — nicht auf ganzer Zeile (width: fit-content) */
.is-completing .el-title {
  position: relative;
  width: fit-content; max-width: 100%;
  animation: done-fade 0.5s ease-out forwards;
}
.is-completing .el-title::after {
  content: '';
  position: absolute; left: 0; top: 50%;
  height: 1.5px; width: 0;
  background: currentColor;
  animation: done-strike 0.4s cubic-bezier(0.32,0.72,0,1) forwards;
}
@keyframes done-strike {
  from { width: 0; opacity: 0.7; }
  to   { width: 100%; opacity: 0.7; }
}
@keyframes done-fade {
  0%   { opacity: 1; }
  60%  { opacity: 0.7; }
  100% { opacity: 0.55; }
}
.is-completing .todo-check {
  animation: done-check-glow 0.55s ease-out forwards;
  background: var(--green) !important;
  border-color: var(--green) !important;
}
@keyframes done-check-glow {
  0%   { box-shadow: 0 0 0 0 rgba(61,176,106,0.6); transform: scale(1); }
  50%  { box-shadow: 0 0 0 14px rgba(61,176,106,0); transform: scale(1.18); }
  100% { box-shadow: 0 0 0 0 rgba(61,176,106,0); transform: scale(1); }
}

/* ── CONTENT-VISIBILITY OPTIMIZATION ─────────────────────────────────────
   Native Browser-Optimization: Off-Screen-Items werden beim Rendern geskippt.
   contain-intrinsic-size sorgt für stabile Scrollbar-Höhen ohne Layout-Jumps.
   Spart bei 100+ Items deutlich Render- und Scroll-Performance.
   Browser-Support: Chrome/Edge (voll), Safari 18+, Firefox (in Arbeit) — bei
   älteren Browsern wird die Property ignoriert (graceful no-op). */
#task-todo-content .swipe-wrapper,
#task-done-content .swipe-wrapper {
  content-visibility: auto;
  contain-intrinsic-size: auto 80px;
}
#maint-list > .swipe-wrapper,
#maint-list > .maint-svc-card,
#maint-list > .maint-card {
  content-visibility: auto;
  contain-intrinsic-size: auto 90px;
}
#umbau-todo-content .el-entry,
#umbau-done-content .el-entry,
#umbau-todo-content .swipe-wrapper,
#umbau-done-content .swipe-wrapper {
  content-visibility: auto;
  contain-intrinsic-size: auto 80px;
}
.doc-group-list > .doc-row {
  content-visibility: auto;
  contain-intrinsic-size: auto 64px;
}
.dash-ungrouped-body > .vehicle-card,
.dash-group-body > .vehicle-card {
  content-visibility: auto;
  contain-intrinsic-size: auto 152px;
}

/* ── SERVICE-HISTORIE ──────────────────────────────────────────────────── */
.svc-hist-year-head {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 12px 18px 4px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--txt3);
}
.svc-hist-year-head:first-child { padding-top: 4px; }
.svc-hist-year { font-weight: 600; color: var(--txt2); }
.svc-hist-year-total {
  font-family: var(--mono); font-size: 10px;
  font-variant-numeric: tabular-nums;
  color: var(--txt3);
}
.svc-hist-card {
  display: block; width: 100%;
  text-align: left; cursor: pointer;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 0; border-left: 0; border-right: 0;
  padding: 14px 18px; min-height: 56px;
  color: var(--txt); font-family: inherit;
  border-top: none;
  transition: background 0.12s;
}
.svc-hist-card:hover { background: rgba(255,255,255,0.04); }
.svc-hist-card:active { transform: scale(0.99); }
.swipe-wrapper[data-source="maint-hist"]:first-of-type .svc-hist-card {
  border-top: 1px solid var(--border);
}
.svc-hist-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px; margin-bottom: 4px;
}
.svc-hist-title {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  color: var(--txt); line-height: 1.2;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  flex: 1; min-width: 0;
}
.svc-hist-cost {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  color: var(--txt); flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.svc-hist-meta {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.svc-hist-subs {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  margin-top: 4px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* ── VEHICLE SEARCH OVERLAY ──────────────────────────────────────────────── */
.vsrch-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: var(--bg);
  display: flex; flex-direction: column;
  animation: doc-slide-up 0.28s cubic-bezier(0.32,0.72,0,1);
}
.vsrch-head {
  display: flex; align-items: center; gap: 4px;
  padding: 18px 14px 16px;
  background: var(--bg);
  flex-shrink: 0;
  border-bottom: 1px solid var(--border);
}
.vsrch-back {
  width: 38px; height: 38px; flex-shrink: 0;
  border: 0; border-radius: 0;
  background: transparent; color: var(--txt3);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: color 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.vsrch-back:hover, .vsrch-back:active { color: var(--txt); }
/* Search input — nutzt App-weite Form-Input-DNA.
   Wrap = Container mit Border + Radius wie Form-Inputs.
   Input selber bekommt globale 16px Barlow + Akzent-Focus-State (border + glow). */
.vsrch-input-wrap {
  flex: 1; position: relative;
  display: flex; align-items: center;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 0 6px 0 36px;
  height: 42px;
  transition: border-color 0.18s, box-shadow 0.18s;
}
.vsrch-input-wrap:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(61,90,241,0.18);
}
.vsrch-icon {
  position: absolute; left: 12px; color: var(--txt3);
  pointer-events: none;
  transition: color 0.18s;
}
.vsrch-input-wrap:focus-within .vsrch-icon { color: var(--accent); }
.vsrch-input {
  flex: 1; background: none; border: none; outline: none;
  color: var(--txt);
  /* font-family/size erbt von globalem input-Style (Barlow 16px) */
  padding: 8px 0;
  /* Override globale Input-Focus-Chrome: das visuelle "Box" macht der Wrapper,
     nicht der Input selber. Sonst entstehen zwei verschachtelte blaue Boxen. */
  box-shadow: none !important;
}
.vsrch-input:focus {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}
.vsrch-input::placeholder {
  color: var(--txt3);
}
.vsrch-clear {
  background: none; border: none; padding: 6px 4px;
  color: var(--txt3); cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: color 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.vsrch-clear:hover, .vsrch-clear:active { color: var(--txt); }
.vsrch-body {
  flex: 1; overflow-y: auto;
  padding: 8px 14px calc(20px + env(safe-area-inset-bottom));
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
.vsrch-hint, .vsrch-empty {
  text-align: center; padding: 32px 16px;
  color: var(--txt3); font-size: 13px;
  font-family: var(--mono); letter-spacing: 0.04em;
}
.vsrch-empty { font-style: italic; }
/* Editorial Hairline-Pattern (matches svc-row + el-entry) */
.vsrch-group { margin-top: 24px; }
.vsrch-group:first-child { margin-top: 12px; }
.vsrch-group-label {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 0 4px 8px;
}
.vsrch-item {
  display: block; width: 100%; text-align: left;
  background: transparent; border: 0;
  border-top: 1px solid var(--border);
  border-radius: 0;
  padding: 14px 4px 12px;
  color: var(--txt); font-family: inherit;
  cursor: pointer;
  transition: background 0.15s;
}
.vsrch-group .vsrch-item:last-child { border-bottom: 1px solid var(--border); }
.vsrch-item:active { background: rgba(255,255,255,0.025); }
.vsrch-item-title {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  color: var(--txt); line-height: 1.1;
  letter-spacing: -0.005em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.vsrch-item-meta {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  letter-spacing: 0.14em; text-transform: uppercase;
  margin-top: 6px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* ── Global Search additions ── */
.gsrch-summary {
  font-family: var(--mono); font-size: 10px; color: var(--accent);
  letter-spacing: 0.22em; text-transform: uppercase;
  padding: 14px 4px 6px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 18px;
}
.gsrch-vehicle-block { margin-top: 24px; }
.gsrch-vehicle-block:first-of-type { margin-top: 0; }
.gsrch-vehicle-head {
  padding: 6px 4px 14px;
  border-bottom: 1px solid var(--border);
}
.gsrch-vehicle-name {
  font-family: var(--cond); font-weight: 700; font-size: 24px;
  letter-spacing: -0.01em; color: var(--txt);
  line-height: 1.05;
}
.gsrch-vehicle-sub {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 5px;
}
.gsrch-vehicle-block .vsrch-item {
  border-top: 0;
  border-bottom: 1px solid var(--border);
}
.gsrch-vehicle-block .vsrch-item:last-child {
  border-bottom: 0;
}
.vsrch-mark {
  background: rgba(61,90,241,0.28); color: var(--txt);
  border-radius: 3px; padding: 0 2px;
}
/* Highlight für angeklicktes Result-Item nach Navigation.
 * Kombi aus inset-Glow + Border-Tint + leichtem BG-Wash:
 * — inset funktioniert immer, auch wenn ein Ancestor overflow:hidden hat
 * — outline-Variante würde an .swipe-wrapper / accordion-body geclippt
 */
.vsrch-flash {
  animation: vsrch-flash 1.4s ease-out;
  position: relative;
  z-index: 2;
}
@keyframes vsrch-flash {
  0% {
    box-shadow: inset 0 0 0 2px var(--accent), 0 0 18px rgba(61,90,241,0.32);
    background-color: rgba(61,90,241,0.10);
  }
  55% {
    box-shadow: inset 0 0 0 2px rgba(61,90,241,0.55), 0 0 8px rgba(61,90,241,0.12);
    background-color: rgba(61,90,241,0.05);
  }
  100% {
    box-shadow: inset 0 0 0 0 transparent, 0 0 0 0 transparent;
    background-color: transparent;
  }
}

/* ── TÜV-HUB ─────────────────────────────────────────────────────────────── */
.tuev-hero {
  padding: 18px 22px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--surface2);
}
.tuev-hero-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--txt3);
  margin-bottom: 8px;
}
.tuev-hero-date {
  font-family: var(--cond); font-size: 32px; font-weight: 800;
  letter-spacing: 0.005em; line-height: 1.05;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.tuev-hero-date.overdue { color: var(--red); }
.tuev-hero-date.soon    { color: var(--amber); }
.tuev-hero-date.ok      { color: var(--txt); }
.tuev-hero-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 6px;
}
.tuev-hero-meta.overdue { color: var(--red); }
.tuev-hero-meta.soon    { color: var(--amber); }
.tuev-hero-bar {
  height: 4px; margin-top: 12px;
  background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden;
}
.tuev-hero-bar-fill {
  height: 100%; background: var(--txt2);
  transition: width 0.4s ease;
}
.tuev-hero-bar-fill.overdue { background: var(--red); }
.tuev-hero-bar-fill.soon    { background: var(--amber); }
.tuev-hero-bar-fill.ok      { background: var(--green); }

.tuev-section {
  padding: 14px 22px 16px;
  border-bottom: 1px solid var(--border);
}
.tuev-section:last-of-type { border-bottom: 0; }
.tuev-section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 10px;
}
.tuev-section-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--txt3);
  margin-bottom: 10px;
  display: block;
}
.tuev-section-head .tuev-section-label { margin-bottom: 0; }
.tuev-section-action {
  background: none; border: 0;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--accent);
  cursor: pointer; padding: 4px 8px;
  border-radius: 6px;
  transition: background 0.15s;
}
.tuev-section-action:hover { background: rgba(61,90,241,0.08); }

/* Letzter TÜV — tappable Card → öffnet Maintenance-Detail */
.tuev-last {
  display: block; width: 100%; text-align: left;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.tuev-last:hover { border-color: var(--border2); background: var(--surface); }
.tuev-last-date {
  font-family: var(--cond); font-size: 17px; font-weight: 700;
  color: var(--txt);
}
.tuev-last-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--txt3); margin-top: 4px;
  font-variant-numeric: tabular-nums;
}
.tuev-last-empty {
  font-family: var(--cond); font-size: 17px; color: var(--txt2);
}
.tuev-last-empty-sub {
  display: block;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--txt3); margin-top: 4px;
  font-weight: 400; text-transform: none;
}

/* Berichte-Liste */
.tuev-doc {
  display: block; width: 100%; text-align: left;
  background: none; border: 0;
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
  cursor: pointer;
  transition: background 0.15s;
}
.tuev-doc:last-of-type { border-bottom: 0; }
.tuev-doc:hover { background: rgba(255,255,255,0.025); }
.tuev-doc-name {
  font-family: var(--body); font-size: 14px; font-weight: 500;
  color: var(--txt);
}
.tuev-doc-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  color: var(--txt3); margin-top: 3px;
  font-variant-numeric: tabular-nums;
}
.tuev-empty-line {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--txt3); padding: 6px 0;
}

/* TÜV-Aufgaben-Liste */
.tuev-todo {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; gap: 10px;
  background: none; border: 0;
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
  cursor: pointer; text-align: left;
  transition: background 0.15s;
}
.tuev-todo:last-of-type { border-bottom: 0; }
.tuev-todo:hover { background: rgba(255,255,255,0.025); }
.tuev-todo-title {
  font-family: var(--body); font-size: 14px; color: var(--txt);
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.tuev-todo-prio {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--red);
  flex-shrink: 0;
}
.tuev-todo-prio.prio-med { color: var(--amber); }

/* Footer mit Edit-Button */
.tuev-footer {
  padding: 14px 22px 18px;
}
.tuev-footer .btn-secondary {
  width: 100%;
}

/* ── COST BREAKDOWN SHEET ────────────────────────────────────────────────── */
/* Modal-Body padding-top auf 0 — sonst entsteht beim Scrollen eine Lücke
 * über dem sticky cost-header (16px aus .modal-body padding bleiben sichtbar).
 * cost-header hat eigenen 14px top-padding — ist genug Breathing Room am Anfang.
 * Horizontales padding bleibt für Sektionen.
 */
#modal-info-body { padding: 0 0 16px; }
.cost-header {
  padding: 14px 20px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 5;
  background: var(--surface2);
  box-shadow: 0 1px 0 0 transparent;
  transition: box-shadow 0.22s ease;
}
.cost-panel.is-scrolled .cost-header {
  box-shadow: 0 4px 12px rgba(0,0,0,0.32);
}
.cost-header-total {
  font-family: var(--cond); font-size: 38px; font-weight: 800;
  letter-spacing: 0.01em; line-height: 1; color: var(--txt);
  font-variant-numeric: tabular-nums;
  transition: font-size 0.22s cubic-bezier(0.32,0.72,0,1);
}
.cost-panel.is-scrolled .cost-header-total { font-size: 26px; }
.cost-header-meta {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  margin-top: 6px; letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  max-height: 24px; opacity: 1;
  overflow: hidden;
  transition: max-height 0.22s ease, opacity 0.18s ease, margin-top 0.22s ease;
}
.cost-panel.is-scrolled .cost-header-meta {
  max-height: 0; opacity: 0; margin-top: 0;
}
.cost-header-label {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.12em;
  margin-bottom: 6px;
}

/* Footer-Hinweis unter Sektionen (z.B. „Sprit zählt nicht zum Projektbudget") */
.cost-section-note {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  letter-spacing: 0.04em; line-height: 1.45;
  padding: 10px 16px 4px;
}

/* Range-Filter-Chips über dem Cost-Body */
.cost-range-chips,
.fuel-range-chips {
  display: flex; gap: 6px;
  padding: 12px 16px 4px;
  overflow-x: auto; scrollbar-width: none;
}
.cost-range-chips::-webkit-scrollbar,
.fuel-range-chips::-webkit-scrollbar { display: none; }
.cost-range-chip,
.fuel-range-chip {
  padding: 6px 14px;
  background: transparent;
  border: 1px solid var(--border2); border-radius: 16px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--txt2); cursor: pointer;
  white-space: nowrap; flex-shrink: 0;
  transition: all 0.15s;
}
.cost-range-chip:hover,
.fuel-range-chip:hover { color: var(--txt); border-color: var(--txt3); }
.cost-range-chip.active,
.fuel-range-chip.active {
  background: var(--accent); border-color: var(--accent); color: #fff;
}

/* Custom-Range Date-Picker (zwischen Chips und Body) — analog zu cost-range-custom */
.fuel-range-custom {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 16px 4px;
}
.fuel-range-custom input[type="date"] {
  flex: 1; min-width: 0;
  padding: 8px 10px;
  background: var(--surface2); border: 1px solid var(--border2);
  border-radius: 8px;
  color: var(--txt); font-family: var(--mono); font-size: 12px;
}
.fuel-range-custom input[type="date"]:focus {
  outline: none; border-color: var(--accent);
}
.fuel-range-custom-sep {
  font-family: var(--mono); font-size: 14px; color: var(--txt3);
}
.fuel-range-custom-err {
  font-family: var(--mono); font-size: 10px;
  color: var(--amber); padding: 4px 16px 0;
  letter-spacing: 0.06em; text-transform: uppercase;
}

/* Empty-Range-Hint im Fuel-Tab (Filter aktiv aber leer) */
.fuel-empty-range {
  margin: 16px;
  padding: 28px 20px;
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  text-align: center;
}
.fuel-empty-range-title {
  font-family: var(--cond); font-weight: 700; font-size: 18px;
  color: var(--txt); margin-bottom: 8px;
}
.fuel-empty-range-text {
  font-family: var(--body); font-size: 13px; line-height: 1.5;
  color: var(--txt2);
}

/* Custom-Range Date-Picker (zwischen Chips und Body) */
.cost-range-custom {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 16px 4px;
}
.cost-range-custom input[type="date"] {
  flex: 1; min-width: 0;
  padding: 8px 10px;
  background: var(--surface2); border: 1px solid var(--border2);
  border-radius: 8px;
  font-family: var(--mono); font-size: 12px; color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.cost-range-custom input[type="date"]:focus {
  outline: none; border-color: var(--accent);
}
.cost-range-custom .cost-range-dash {
  color: var(--txt3); font-family: var(--mono); font-size: 14px;
  flex-shrink: 0;
}
/* Inline-Validierungs-Hinweise unter dem Date-Range */
.cost-range-err {
  padding: 6px 16px 0;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  line-height: 1.4;
}
.cost-range-err.cost-range-err-warn { color: var(--amber); }
.cost-range-err.cost-range-err-info { color: var(--txt3); }

/* Donut-Chart */
.cost-donut-wrap {
  display: flex; align-items: center; gap: 18px;
  padding: 8px 0 4px;
}
.cost-donut {
  width: 120px; height: 120px; flex-shrink: 0;
}
.cost-donut circle {
  transition: stroke-dasharray 0.4s ease, stroke-dashoffset 0.4s ease;
}
.cost-donut-legend {
  flex: 1; display: flex; flex-direction: column; gap: 8px; min-width: 0;
}
.cost-donut-leg-item {
  display: flex; align-items: center; gap: 8px;
  min-width: 0;
}
.cost-donut-leg-dot {
  width: 10px; height: 10px; border-radius: 50%;
  flex-shrink: 0;
}
.cost-donut-leg-label {
  font-family: var(--body); font-size: 13px; color: var(--txt);
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cost-donut-leg-pct {
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  color: var(--txt2); flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}

/* ── BUDGET (Cost-Breakdown Block) ─────────────────────────────────────── */
.cost-budget {
  padding: 16px 20px 18px;
  border-top: 1px solid var(--border);
}

/* Kompakter Einzeiler — wenn Zeitraum-Filter aktiv ist.
   Visuell Meta-Caption-Level: nicht mehr Hero-Block, aber klar lesbar.
   Tap → Filter zurücksetzen auf „Alle". */
.cost-budget-compact {
  display: flex; align-items: center; gap: 12px;
  width: 100%;
  padding: 10px 16px 11px;
  border: none; border-top: 1px solid var(--border);
  background: transparent;
  cursor: pointer;
  text-align: left;
  font-family: var(--mono);
  transition: background 0.15s;
}
.cost-budget-compact:hover { background: rgba(255,255,255,0.025); }
.cost-budget-compact-label {
  font-size: 11px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--txt3);
  flex-shrink: 0;
}
.cost-budget-compact-amount {
  font-size: 12px; font-weight: 600;
  color: var(--txt2);
  font-variant-numeric: tabular-nums;
  flex: 1; text-align: right;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cost-budget-compact-amount.soon    { color: var(--amber); }
.cost-budget-compact-amount.overdue { color: var(--red); }
.cost-budget-compact-amount .cost-budget-of {
  font-size: 12px; color: var(--txt3); font-weight: 500;
}
.cost-budget-compact-cta {
  font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--accent);
  flex-shrink: 0;
}
.cost-budget-head {
  display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
  margin-bottom: 10px;
}
.cost-budget-label {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.12em;
}
.cost-budget-amount {
  font-family: var(--cond); font-size: 20px; font-weight: 800;
  letter-spacing: 0.005em; color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.cost-budget-amount.soon    { color: var(--amber); }
.cost-budget-amount.overdue { color: var(--red); }
.cost-budget-of {
  font-family: var(--cond); font-weight: 500; color: var(--txt3);
  font-size: 16px; letter-spacing: 0;
}
.cost-budget-bar {
  height: 4px; background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden;
}
.cost-budget-bar-fill {
  height: 100%; background: var(--txt2); border-radius: 2px;
  transition: width 0.4s ease;
}
.cost-budget-bar-fill.soon    { background: var(--amber); }
.cost-budget-bar-fill.overdue { background: var(--red); }
.cost-budget-sub {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.10em;
  margin-top: 8px;
  font-variant-numeric: tabular-nums;
}
.cost-budget-sub.soon    { color: var(--amber); }
.cost-budget-sub.overdue { color: var(--red); }

/* CTA wenn kein Budget gesetzt — dezent, einladend */
.cost-budget-cta {
  display: flex; align-items: center; gap: 10px;
  cursor: pointer;
  color: var(--txt3); transition: color 0.15s, background 0.15s;
}
.cost-budget-cta:hover { color: var(--txt2); background: rgba(255,255,255,0.02); }
.cost-budget-cta-icon {
  width: 24px; height: 24px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px dashed var(--border2); border-radius: 50%;
  font-size: 14px; font-weight: 600; color: var(--txt2);
}
.cost-budget-cta-text {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Input mit Suffix-Label (€ / Jahr) */
.input-with-suffix {
  position: relative;
}
.input-with-suffix input {
  padding-right: 78px !important;
}
.input-with-suffix .input-suffix {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  letter-spacing: 0.06em; text-transform: uppercase;
  pointer-events: none;
}
.cost-section { padding: 16px 20px 4px; }
.cost-section + .cost-section { border-top: 1px solid var(--border); padding-top: 16px; }
.cost-section-label {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.12em;
  margin-bottom: 14px;
}
.cost-empty {
  padding: 20px 20px 4px; color: var(--txt3); font-size: 13px;
  text-align: center; font-style: italic;
}
/* Ausklappbare Kategorie-Zeile */
.cost-cat-row { margin-bottom: 16px; }
.cost-cat-row:last-child { margin-bottom: 4px; }
.cost-cat-head {
  display: flex; align-items: baseline;
  width: 100%; padding: 0 0 7px;
  background: none; border: none; cursor: pointer;
  font-family: inherit; color: var(--txt);
  text-align: left;
  transition: opacity 0.15s;
}
.cost-cat-head:active { opacity: 0.7; }
.cost-cat-chev {
  flex-shrink: 0; color: var(--txt3); margin-right: 8px;
  transition: transform 0.22s cubic-bezier(0.32,0.72,0,1);
  transform: rotate(-90deg); align-self: center;
}
.cost-cat-row.expanded .cost-cat-chev { transform: rotate(0deg); color: var(--txt2); }
.cost-cat-label {
  flex: 1; min-width: 0;
  font-size: 14px; color: var(--txt);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cost-cat-amount {
  flex-shrink: 0; margin-left: 12px;
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  color: var(--txt); font-variant-numeric: tabular-nums;
}
.cost-cat-bar {
  display: flex; align-items: center; gap: 10px;
}
.cost-cat-bar-track {
  flex: 1;
  height: 6px; border-radius: 3px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
}
.cost-cat-bar-fill {
  height: 100%; border-radius: 3px;
  transition: width 0.4s cubic-bezier(0.32,0.72,0,1);
}
.cost-cat-bar-pct {
  flex-shrink: 0; min-width: 32px; text-align: right;
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}
/* Items-Wrap mit Grid-Animation für unbekannte Höhen */
.cost-cat-items-wrap {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.28s cubic-bezier(0.32,0.72,0,1);
}
.cost-cat-row.expanded .cost-cat-items-wrap {
  grid-template-rows: 1fr;
}
.cost-cat-items {
  overflow: hidden; min-height: 0;
}
.cost-cat-row.expanded .cost-cat-items {
  margin-top: 10px;
}
.cost-cat-item {
  display: flex; align-items: baseline; gap: 10px;
  padding: 8px 12px; min-height: 36px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px; margin-bottom: 4px;
  width: 100%; text-align: left; font-family: inherit; color: inherit;
}
.cost-cat-item:last-child { margin-bottom: 0; }
/* Klickbare Variante (button.cost-cat-item.is-clickable) — Hover/Active-Feedback */
button.cost-cat-item.is-clickable {
  cursor: pointer; transition: border-color .15s, background .15s, transform .1s;
}
button.cost-cat-item.is-clickable:hover {
  border-color: var(--border2);
  background: rgba(255,255,255,0.04);
}
button.cost-cat-item.is-clickable:active { transform: scale(0.99); }
.cost-cat-item-label {
  flex: 1; min-width: 0;
  font-size: 13px; color: var(--txt);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cost-cat-item-meta {
  display: flex; align-items: baseline; gap: 10px;
  flex-shrink: 0;
}
.cost-cat-item-date {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.04em; font-variant-numeric: tabular-nums;
}
.cost-cat-item-amount {
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  color: var(--txt2); font-variant-numeric: tabular-nums;
}
.cost-chart {
  display: flex; align-items: flex-end; gap: 6px;
  height: 130px; overflow-x: auto;
  scrollbar-width: none;
  padding: 0 2px;
}
.cost-chart::-webkit-scrollbar { display: none; }
.cost-chart-col {
  flex: 1 0 44px; min-width: 44px;
  display: flex; flex-direction: column; align-items: center;
  height: 100%;
}
.cost-chart-amount {
  font-family: var(--mono); font-size: 9px; color: var(--txt3);
  margin-bottom: 4px; height: 14px;
  font-variant-numeric: tabular-nums; letter-spacing: 0.02em;
}
.cost-chart-bar-wrap {
  flex: 1; width: 100%;
  display: flex; align-items: flex-end; justify-content: center;
}
.cost-chart-bar {
  width: 100%; max-width: 32px;
  background: linear-gradient(180deg, var(--accent) 0%, rgba(61,90,241,0.6) 100%);
  border-radius: 4px 4px 0 0;
  min-height: 3px;
  transition: height 0.5s cubic-bezier(0.32,0.72,0,1);
}
.cost-chart-year {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  margin-top: 6px; letter-spacing: 0.04em;
}
.cost-actions { padding: 16px 20px 4px; }
.cost-close-btn {
  width: 100%; min-height: 46px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 12px; color: var(--txt);
  font-family: var(--cond); font-size: 16px; font-weight: 600;
  letter-spacing: 0.02em; cursor: pointer;
  transition: background 0.15s;
}
.cost-close-btn:hover { background: rgba(255,255,255,0.04); }
.cost-close-btn:active { transform: scale(0.98); }

/* ── REDUCED MOTION RESPECT ─────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .list-stagger > * { animation: none !important; }
  .skel { animation: none !important; }
}

/* ── SLIDE-UP / SLIDE-DOWN page transitions ──────────────────────────────
   Wird via Web Animations API gesteuert; CSS sorgt nur für Overlay-Position.
   !important nötig weil ID-Selektoren wie #pg-vehicle-detail höhere Specificity
   haben und sonst position:relative gewinnt. */
.page.slide-overlay {
  display: flex !important;
  position: fixed !important;
  inset: 0 !important;
  z-index: 50 !important;
  will-change: transform;
  background: var(--bg);
  overflow: hidden auto;
}
/* Dashboard hat während Slide-Animationen Transform-Origin oben mittig
   damit das "Wegzoomen" sich nach hinten/oben anfühlt, nicht zur Seite */
#pg-dashboard {
  transform-origin: center top;
  will-change: transform, filter;
  /* Browser-PTR aus auf Dashboard, eigene PTR übernimmt.
     KEINE globale html-Regel — sonst wird native PTR auf
     Landing, Intro etc. überall blockiert. */
  overscroll-behavior-y: contain;
}

/* ── APP LOADER (Splash bei Initial-Load / Cloud-Sync) ─────────────────── */
#app-loader {
  position: fixed; inset: 0; z-index: 100000;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: var(--bg);
  gap: 18px;
  opacity: 1; transition: opacity 0.45s ease;
}
#app-loader.hide { opacity: 0; pointer-events: none; }
.app-loader-svg {
  width: 128px; height: 128px;
  color: var(--txt);
  filter: drop-shadow(0 6px 18px rgba(0,0,0,0.35));
}
.app-loader-needle {
  transform-box: fill-box;
  transform-origin: 6% 96%;
  animation: tacho-sweep 1.6s cubic-bezier(.55,.05,.45,.95) infinite alternate;
  will-change: transform;
}
@keyframes tacho-sweep {
  from { transform: rotate(-38deg); }
  to   { transform: rotate(28deg); }
}
.app-loader-wordmark {
  font-family: var(--cond); font-size: 26px; font-weight: 700;
  color: var(--txt); letter-spacing: 0.02em;
  margin-top: 6px;
}
.app-loader-hint {
  font-family: var(--mono); font-size: 9px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.22em;
}
@media (prefers-reduced-motion: reduce) {
  .app-loader-needle { animation-duration: 3s; }
}

/* ── APP HEADER ─────────────────────────────────────────────────────────── */
.app-header {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: 12px;
  padding: 0 20px; height: 56px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  flex-shrink: 0;
}
.logo {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  letter-spacing: 0; text-transform: none; white-space: nowrap; font-style: italic;
}
.logo .accent { color: var(--accent); }
.logo .dim { color: var(--txt2); font-weight: 400; }
.header-title {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.header-spacer { flex: 1; }

/* ── Vehicle-Detail Header: Reveal-Kontext (Titel + Sub) beim Scrollen ─── */
.vd-hdr-ctx {
  flex: 1;
  min-width: 0;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.28s ease, transform 0.28s ease;
  pointer-events: none;
  padding: 0 4px;
}
#vd-header.reveal .vd-hdr-ctx {
  opacity: 1;
  transform: translateY(0);
}
#vd-header.reveal {
  background: rgba(13,13,13,0.82);
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border-bottom: 1px solid var(--border);
}
.vd-hdr-title {
  font-family: var(--cond);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.05;
  color: var(--txt);
  letter-spacing: 0.01em;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.vd-hdr-sub {
  font-family: var(--mono);
  font-size: 9.5px;
  color: var(--txt3);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.btn-back {
  display: grid; place-items: center;
  width: 40px; height: 40px;
  margin-left: -8px;            /* optisch bündig mit Container-Padding */
  background: none; border: none; color: var(--txt);
  border-radius: 12px;
  cursor: pointer;
  transition: background 0.15s ease, color 0.2s;
  flex-shrink: 0;
}
.btn-back svg { display: block; }
.btn-back:hover, .btn-back:active { background: var(--surface2, rgba(255,255,255,0.06)); }

/* ── BUTTONS ─────────────────────────────────────────────────────────────── */
.btn-primary {
  background: var(--accent); color: #fff; border: none;
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 12px 22px; border-radius: 10px; cursor: pointer;
  transition: opacity 0.2s, transform 0.1s, box-shadow 0.2s;
  white-space: nowrap; min-height: 44px;
  box-shadow: 0 4px 14px rgba(61,90,241,0.25);
}
.btn-primary:hover { opacity: 0.92; box-shadow: 0 6px 18px rgba(61,90,241,0.35); }
.btn-primary:active { transform: scale(0.97); }
.btn-secondary {
  background: transparent; color: var(--txt2);
  border: 1px solid var(--border2);
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 12px 20px; border-radius: 10px; cursor: pointer;
  transition: all 0.18s; white-space: nowrap; min-height: 44px;
}
.btn-secondary:hover {
  border-color: var(--txt2);
  color: var(--txt);
  background: rgba(255,255,255,0.03);
}
.btn-danger {
  background: transparent; color: var(--red);
  border: 1px solid rgba(224,53,53,0.35);
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 12px 18px; border-radius: 10px; cursor: pointer; min-height: 44px;
  transition: all 0.18s;
}
.btn-danger:hover {
  background: rgba(224,53,53,0.12);
  border-color: var(--red);
}
.btn-success {
  background: transparent; color: var(--green);
  border: 1px solid rgba(55,211,153,0.4);
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 12px 18px; border-radius: 10px; cursor: pointer; min-height: 44px;
  transition: all 0.18s, transform 0.1s;
  white-space: nowrap;
}
.btn-success:hover {
  background: rgba(55,211,153,0.1);
  border-color: var(--green);
  color: #fff;
  background: var(--green);
  box-shadow: 0 4px 14px rgba(55,211,153,0.3);
}
.btn-success:active { transform: scale(0.97); }
.btn-icon {
  background: none; border: none; color: var(--txt2); font-size: 16px;
  cursor: pointer; padding: 10px 12px; min-width: 44px; min-height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: color 0.2s; border-radius: var(--r);
}
.btn-icon:hover { color: var(--txt); background: var(--surface2); }
.btn-sm { padding: 5px 10px !important; font-size: 10px !important; }

/* ── DASHBOARD ──────────────────────────────────────────────────────────── */
.dash-content { flex: 1; padding: 24px 20px; max-width: 880px; width: 100%; margin: 0 auto; background: var(--bg); }
.section-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--txt2); margin-bottom: 16px;
}
.dash-grid {
  display: flex; flex-direction: column;
  gap: 12px; margin-bottom: 40px;
}
.vehicle-card {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden; cursor: pointer;
  display: flex; align-items: stretch;
  transition: border-color 0.2s, opacity 0.15s;
  position: relative;
}
.vehicle-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.vehicle-card:hover { border-color: var(--border2); }
.vehicle-card:active { opacity: 0.82; }
.vehicle-card.vc-dragging { opacity: 0.25; pointer-events: none; }
.vc-drag-ghost {
  position: fixed; z-index: 9999; pointer-events: none; margin: 0;
  box-shadow: 0 20px 48px rgba(0,0,0,0.7); border-radius: 14px;
  transform: scale(1.025); opacity: 0.97; will-change: transform, top, left;
}
.vc-grip {
  display: flex; align-items: center; justify-content: center;
  width: 28px; flex-shrink: 0; color: var(--txt3); opacity: 0.35;
  padding-right: 6px;
}
.sort-hint-toast {
  position: fixed; bottom: max(84px, calc(72px + env(safe-area-inset-bottom)));
  left: 50%; transform: translateX(-50%);
  background: rgba(30,30,36,0.95); backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.1); border-radius: 20px;
  padding: 9px 18px; z-index: 8000; pointer-events: none;
  font-family: var(--mono); font-size: 12px; color: var(--txt2);
  white-space: nowrap; display: flex; align-items: center; gap: 8px;
  animation: hintIn 0.3s ease, hintOut 0.4s ease 3s forwards;
}
@keyframes hintIn { from { opacity:0; transform:translateX(-50%) translateY(8px); } to { opacity:1; transform:translateX(-50%) translateY(0); } }
@keyframes hintOut { to { opacity:0; transform:translateX(-50%) translateY(6px); } }
.vc-image {
  width: 120px; aspect-ratio: 4 / 5; flex-shrink: 0;
  background: var(--surface2);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.vc-image img { width: 100%; height: 100%; object-fit: cover; }
.vc-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: var(--txt3); opacity: 0.35;
}
.vc-placeholder svg { width: 38px; height: 38px; }
.vc-body {
  flex: 1; padding: 16px 18px;
  display: flex; flex-direction: column; justify-content: center;
  gap: 0; min-width: 0;
  position: relative; z-index: 1;
}
.vc-name {
  font-family: var(--cond); font-size: 24px; font-weight: 800;
  letter-spacing: 0.01em; line-height: 1.1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.vc-meta {
  font-family: var(--mono); font-size: 13px; color: var(--txt2);
  margin-top: 4px; margin-bottom: 10px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* Status-Marker im editorial Stil — kleiner Dot + Mono-Caps Label.
   Kein Background, keine gefüllten Pills. Konsistent zu .dash-attn-status. */
.vc-markers {
  display: flex; gap: 14px; flex-wrap: wrap; align-items: center;
  position: relative; z-index: 1;
}
.vc-marker {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--txt2);
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
}
.vc-marker-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor; display: inline-block; flex-shrink: 0;
  opacity: 0.9;
}
.vc-marker.ok      { color: var(--green); }
.vc-marker.soon    { color: var(--amber); }
.vc-marker.overdue { color: var(--red); }
.vc-marker.attn    { color: var(--txt2); }

/* Letzte-Aktivität-Footer auf der Card — Mono-Caps, sehr dezent.
   Signalisiert Aktualität ohne mit den Status-Markern zu konkurrieren. */
.vc-last {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
  margin-top: 8px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  position: relative; z-index: 1;
}
.vc-last-empty { opacity: 0.65; font-style: italic; letter-spacing: 0.08em; }

/* Add vehicle card */
.add-vehicle-card {
  background: transparent; border: 1px dashed var(--border2);
  border-radius: 8px; min-height: 64px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  gap: 12px; transition: border-color 0.2s;
}
.add-vehicle-card:hover { border-color: var(--accent); }
.add-vehicle-card .add-icon { font-size: 22px; opacity: 0.4; color: var(--txt2); }
.add-vehicle-card span { font-family: var(--mono); font-size: 12px; color: var(--txt2); letter-spacing: 0.04em; }

/* Dashboard groups */
.dash-ungrouped-body {
  display: flex; flex-direction: column; gap: 12px;
}
.dash-ungrouped-body.drag-show-hint::after {
  content: 'Ohne Gruppe';
  display: block; font-family: var(--mono); font-size: 11px; color: var(--txt3);
  padding: 10px 4px; letter-spacing: 0.04em; text-align: center;
  border: 1px dashed var(--border); border-radius: 8px;
}
.dash-group {
  border: 1px solid var(--border); border-radius: 10px; overflow: hidden;
}
.dash-group-header {
  display: flex; align-items: center; gap: 6px; justify-content: space-between;
  padding: 10px 10px 10px 6px; cursor: pointer; user-select: none;
  background: var(--surface2); transition: background 0.15s;
}
.dash-group-header:hover { background: rgba(255,255,255,0.04); }
.dash-group-grip {
  display: flex; align-items: center; justify-content: center;
  width: 26px; height: 32px; flex-shrink: 0;
  color: var(--txt3); cursor: grab; opacity: 0.5;
  transition: opacity 0.15s, color 0.15s; touch-action: none;
}
.dash-group-grip:hover { opacity: 1; color: var(--txt2); }
.dash-group-grip:active { cursor: grabbing; }
.dash-group-title-wrap {
  display: flex; align-items: center; gap: 6px; flex: 1; min-width: 0;
}
.dash-group-chevron {
  flex-shrink: 0; color: var(--txt3);
  transition: transform 0.2s ease;
  transform: rotate(-90deg);
}
.dash-group-chevron.open { transform: rotate(0deg); }
.dash-group-title {
  font-family: var(--cond); font-size: 13px; font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--txt2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dash-group-edit-btn {
  background: none; border: none; padding: 3px 4px; margin-left: 1px;
  color: var(--txt3); cursor: pointer; flex-shrink: 0; line-height: 1;
  opacity: 0.45; transition: opacity 0.15s, color 0.15s; display: flex; align-items: center;
}
.dash-group-edit-btn:hover { opacity: 1; color: var(--txt); }
.dash-group-count {
  font-family: var(--mono); font-size: 11px; color: var(--txt3); flex-shrink: 0;
}
.dash-group-body {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--border);
}
.dash-group-body .vehicle-card {
  border-radius: 0; border-left: none; border-right: none; border-top: none;
  border-bottom: 1px solid var(--border);
}
.dash-group-body .vehicle-card:last-child { border-bottom: none; }
.dash-group-body.closed { display: none; }
.dash-ungrouped-body.drag-target-active,
.dash-group-body.drag-target-active {
  outline: 2px solid var(--accent); outline-offset: 4px;
  background: rgba(37,99,235,0.04); border-radius: 10px;
}
#dash-new-group-zone {
  margin: 2px 0 4px; padding: 13px 16px;
  border: 2px dashed rgba(255,255,255,0.12); border-radius: 10px;
  text-align: center; font-family: var(--cond); font-size: 12px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--txt3);
  transition: border-color 0.15s, color 0.15s, background 0.15s; pointer-events: none;
}
#dash-new-group-zone.drag-over {
  border-color: var(--accent); color: var(--accent); background: rgba(37,99,235,0.07);
}

/* Knowledge section */
.dash-knowledge {
  border-top: 1px solid var(--border); padding-top: 24px; margin-top: 8px;
}

/* ── VEHICLE DETAIL ──────────────────────────────────────────────────────── */
.detail-hero {
  display: flex; align-items: flex-start; gap: 20px;
  padding: 20px 20px 0; border-bottom: 1px solid var(--border);
  background: var(--surface); flex-shrink: 0;
  max-width: 880px;
  margin: 0 auto;
  width: 100%;
}
.detail-hero-img {
  width: 100px; height: 70px; border-radius: var(--r);
  background: var(--surface2); overflow: hidden; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; opacity: 0.3;
}
.detail-hero-img img { width: 100%; height: 100%; object-fit: cover; opacity: 1; }
.detail-hero-text { flex: 1; padding-bottom: 16px; }
.detail-title { font-family: var(--cond); font-size: 24px; font-weight: 800; line-height: 1.1; }
.detail-subtitle { font-family: var(--mono); font-size: 11px; color: var(--txt2); margin-top: 4px; }
.detail-hero-actions { display: flex; gap: 8px; align-items: flex-start; padding-bottom: 16px; }

/* Detail-Nav-Section: enthält Big-Pills + Small-Pills, sticky beim Scrollen */
.detail-nav-section {
  background: var(--surface); flex-shrink: 0;
  padding: 12px 16px 8px;
  position: sticky; top: 56px; z-index: 99;
  transition: background 0.25s ease, backdrop-filter 0.25s ease;
}
.detail-nav-section.is-sticky {
  /* Beim Sticky bleiben ALLE Pills sichtbar — User soll immer sehen in welchem
     Tab er ist (auch wenn der aktive Tab in den Small-Pills steht). */
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  background: rgba(13, 13, 13, 0.78);
  box-shadow: 0 6px 18px rgba(0,0,0,0.32);
  border-bottom: none;
}

.tab-pane { display: none; flex: 1; flex-direction: column; overflow-y: auto; background: var(--bg); padding-bottom: max(96px, calc(84px + env(safe-area-inset-bottom))); }
.tab-pane.active { display: flex; }

/* Sub-tabs (intern in der detail-nav-section, daher KEIN eigenes sticky/glass —
   erbt die Sticky-Box-Optik vom Eltern-Container, sodass alles ein zusammen-
   hängender Glas-Layer ist (kein Subpixel-Bruch zwischen zwei sticky-Layern). */
.sub-tab-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 0 0;
  flex-shrink: 0;
}
.task-toggle-track {
  display: flex; background: var(--surface2);
  border-radius: 20px; border: 1px solid var(--border2);
  padding: 3px; gap: 2px; margin-left: auto; flex-shrink: 0;
}
.sub-tab-btn {
  padding: 6px 22px; border-radius: 16px; border: none;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  cursor: pointer; background: none; color: var(--txt3);
  transition: background 0.18s, color 0.18s; min-height: 32px;
  white-space: nowrap;
}
.sub-tab-btn.active { background: var(--accent); color: #fff; }
.sub-tab-btn:hover:not(.active) { color: var(--txt2); }
.task-toggle-count {
  display: inline-block; font-size: 9px; font-weight: 700;
  min-width: 16px; padding: 0 4px; height: 16px; line-height: 16px;
  border-radius: 8px; text-align: center; margin-left: 4px;
  background: rgba(255,255,255,0.2); vertical-align: middle;
}
.sub-tab-btn:not(.active) .task-toggle-count {
  background: var(--border2); color: var(--txt2);
}
.task-toggle-count:empty { display: none; }
@keyframes task-count-pop {
  0%   { transform: scale(1); }
  28%  { transform: scale(1.5); }
  100% { transform: scale(1); }
}
.task-toggle-count {
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.25s ease;
}
.task-toggle-count.task-count-flash {
  animation: task-count-pop 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}
.task-toggle-count.task-count-green {
  background: var(--green) !important;
  color: #0d0d0d !important;
  box-shadow: 0 0 0 4px rgba(74,222,128,0.22);
}

#task-todo-content, #task-done-content { flex: 1; overflow-y: auto; }

/* FAB */
.fab-container {
  position: fixed; bottom: 28px; right: 20px; z-index: 500;
  display: none; /* shown only on vehicle detail page */
}
.pg-vehicle-detail-active .fab-container { display: block; }
/* FAB ausblenden, sobald ein Overlay/Modal offen ist — sonst überdeckt er
   die Modal-Action-Buttons (z.B. Speichern). */
body:has(.doc-add-overlay) .fab-container,
body:has(.doc-viewer-overlay) .fab-container,
body:has(#modal-overlay.active) .fab-container,
body:has(.bottom-sheet-overlay.active) .fab-container { display: none !important; }
.fab-btn {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--accent); color: #fff; border: none;
  font-size: 26px; line-height: 1; cursor: pointer;
  box-shadow: 0 4px 20px rgba(61,90,241,0.45);
  display: flex; align-items: center; justify-content: center;
  transition: transform 0.15s, opacity 0.15s;
}
.fab-btn:active { transform: scale(0.93); opacity: 0.9; }

/* FAB Mini-Menu wurde durch Bottom-Sheet ersetzt — eine konsistente Sprache
   für alle FAB-Multi-Action-Auswahlen (Aufgaben/Service/Umbau + Foto/Datei). */

.tab-actions {
  display: flex; gap: 8px; padding: 14px 20px; flex-shrink: 0;
  border-bottom: 1px solid var(--border);
}

/* Maintenance entries */
.maint-list { flex: 1; overflow-y: auto; }
.maint-entry {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background 0.15s;
}
.maint-entry:hover { background: var(--surface); }
.me-icon { display: none; }
.me-body { flex: 1; min-width: 0; }
.me-title { font-weight: 500; margin-bottom: 2px; }
.me-meta { font-family: var(--mono); font-size: 11px; color: var(--txt2); margin-bottom: 4px; }
.me-notes { font-size: 13px; color: var(--txt2); margin-top: 4px; }
.me-due { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; }
.due-badge {
  font-family: var(--mono); font-size: 10px; padding: 2px 6px;
  border-radius: var(--r); background: var(--surface2); color: var(--txt2);
}
.due-badge.soon { background: rgba(176,144,32,0.15); color: var(--amber); }
.due-badge.overdue { background: rgba(224,53,53,0.12); color: var(--red); }
.el-interval { margin-top: 4px; }
.interval-badge { font-family: var(--mono); font-size: 10px; color: var(--txt3); letter-spacing: 0.01em; }
.el-entry.maint-soon { border-left-color: var(--amber); }
.el-entry.maint-overdue { border-left-color: var(--red); }

/* ── Service Schedule Cards ─────────────────────────────────────── */
/* ── Service-Items v2 — Editorial Hairline-Pattern ── */
.svc-row {
  display: grid;
  grid-template-columns: 1fr 56px;
  align-items: stretch;
  border-top: 1px solid var(--border);
  background: transparent;
  cursor: pointer;
  transition: background 0.15s ease;
}
.swipe-wrapper:last-child .svc-row,
#maint-list .swipe-wrapper:last-child .svc-row {
  border-bottom: 1px solid var(--border);
}
.svc-row:active { background: rgba(255,255,255,0.025); }

.svc-row-body {
  padding: 16px 8px 14px 16px;
  display: flex; flex-direction: column;
  min-width: 0;
}
.svc-row-title {
  font-family: var(--cond); font-weight: 700; font-size: 18px;
  letter-spacing: -0.005em; color: var(--txt);
  line-height: 1.1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
/* Status leads the meta line — same family/size as meta but stronger weight + color */
.svc-row-status {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; font-weight: 500;
  color: var(--txt2);
}
.svc-row-status.svc-overdue { color: var(--red); }
.svc-row-status.svc-soon    { color: var(--amber); }
.svc-row-status.svc-ok      { color: var(--txt2); }
.svc-row-meta-rest { color: var(--txt3); }

.svc-row-spec {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 6px;
}
.svc-row-subs {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 4px;
  opacity: 0.75;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.svc-row-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 8px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.svc-row-bar {
  margin-top: 10px; height: 2px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
  border-radius: 1px;
}
.svc-row-bar-fill {
  height: 100%; background: var(--accent);
  transition: width 0.3s ease;
}
.svc-row-bar-fill.svc-overdue { background: var(--red); }
.svc-row-bar-fill.svc-soon    { background: var(--amber); }
.svc-row-bar-fill.svc-ok      { background: var(--green); }

/* Reset action — icon-only, vertical-aligned to title */
.svc-row-action {
  background: transparent; border: 0;
  color: var(--txt3); cursor: pointer;
  padding: 18px 16px 0 8px;
  display: flex; align-items: flex-start; justify-content: center;
  transition: color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.svc-row-action:hover, .svc-row-action:active { color: var(--txt); }
.svc-row-action.svc-overdue { color: var(--red); }
.svc-row-action.svc-soon    { color: var(--amber); }
.svc-row-action.svc-ok      { color: var(--txt3); }
.svc-row-action.svc-ok:hover { color: var(--green); }

.svc-reset-btn {
  border: none;
  border-left: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
  color: var(--txt2);
  padding: 6px 10px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  min-width: 56px;
  transition: background 0.15s, color 0.15s;
}
.svc-reset-btn:hover, .svc-reset-btn:active { background: rgba(255,255,255,0.06); color: var(--txt); }
.svc-reset-btn svg { opacity: 0.7; }
.svc-reset-ok      { color: var(--txt2); }
.svc-reset-soon    { color: var(--amber); background: rgba(176,144,32,0.06); }
.svc-reset-overdue { color: var(--red);   background: rgba(224,53,53,0.06); }
.svc-reset-soon:hover, .svc-reset-overdue:hover { background: rgba(255,255,255,0.10); }

/* Sub-Items Editor (im Item-Modal) */
.svc-sub-edit {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.svc-sub-edit-row {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 6px 10px;
}
.svc-sub-edit-row input[type="checkbox"] { width: 16px; height: 16px; cursor: pointer; }
.svc-sub-edit-row input[type="text"] {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--txt1);
  font-size: 13px;
  padding: 4px 0;
}
.svc-sub-edit-row input[type="text"]:focus { outline: none; }
.svc-sub-empty {
  color: var(--txt3);
  font-size: 12px;
  font-style: italic;
  padding: 4px 0;
}

/* Reset-Modal: Flüssigkeits-Felder (editierbar) */
.sr-fluids {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-left: 2px solid var(--green, var(--green));
  border-radius: 4px;
  padding: 10px 12px 12px;
  margin-bottom: 12px;
}
.sr-fluids-head {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 8px;
}
.sr-fluids-title {
  font-size: 11px;
  color: var(--txt3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.sr-fluids-hint {
  font-size: 11px;
  color: var(--txt3);
  line-height: 1.35;
}
.sr-fluids-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 10px;
}
.sr-fluid-field { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.sr-fluid-field label {
  font-size: 11px;
  color: var(--txt3);
  letter-spacing: 0.02em;
}
.sr-fluid-field input {
  width: 100%;
  background: var(--card, rgba(0,0,0,0.2));
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 6px 8px;
  color: var(--txt1);
  font-size: 13px;
  font-family: var(--mono);
}
.sr-fluid-field input:focus { outline: none; border-color: var(--green, var(--green)); }
.sr-fluid-num { }

.sr-save-default {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  cursor: pointer;
  font-size: 13px;
  color: var(--txt2);
}
.sr-save-default input[type="checkbox"] { width: 16px; height: 16px; cursor: pointer; }
.sr-subitems {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 10px 12px;
  margin-bottom: 12px;
}
.sr-sub-label {
  font-size: 11px;
  color: var(--txt3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 6px;
  display: block;
}
.sr-sub-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  cursor: pointer;
  color: var(--txt1);
  font-size: 14px;
}
.sr-sub-row input[type="checkbox"] { width: 18px; height: 18px; cursor: pointer; }

/* Preset picker */
.svc-preset-main { flex: 1; min-width: 0; }
.svc-preset-sub  { font-size: 11px; color: var(--txt3); margin-top: 2px; }

.svc-preset-list {
  display: flex;
  flex-direction: column;
  max-height: 60vh;
  overflow-y: auto;
}
.svc-preset-row {
  padding: 12px 4px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.svc-preset-row:hover { background: rgba(255,255,255,0.03); }
.svc-preset-row.svc-preset-used { opacity: 0.55; }
.svc-preset-label { font-size: 14px; color: var(--txt1); }
.svc-preset-check { color: var(--green, var(--green)); font-size: 12px; margin-left: 4px; }
.svc-preset-int { font-family: var(--mono); font-size: 11px; color: var(--txt3); }

/* Todo entries */
.todo-list { flex: 1; overflow-y: auto; }
.todo-entry {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 20px; border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}
.todo-entry:hover { background: var(--surface); }
.todo-entry.done { opacity: 0.5; }
.todo-check {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--border2); background: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 12px;
  flex-shrink: 0; margin-top: 1px; transition: border-color 0.15s, background 0.15s;
}
.todo-check:hover { border-color: var(--green); }
.todo-check.done {
  border-color: var(--green); background: var(--green);
  color: #0d0d0d; font-size: 11px; font-weight: 700; cursor: default;
}
.todo-body { flex: 1; min-width: 0; }
.todo-title { font-weight: 500; margin-bottom: 2px; }
.todo-ref { font-family: var(--mono); font-size: 11px; color: var(--txt2); margin-bottom: 2px; }
.todo-notes { font-size: 13px; color: var(--txt2); }
.todo-done-section { border-top: 1px solid var(--border); margin-top: 8px; padding-top: 8px; }
.todo-done-header { font-family: var(--mono); font-size: 10px; color: var(--txt2); padding: 8px 20px; }

/* Severity dots */
.sev-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.sev-dot.s-high, .sev-high { background: var(--red); }
.sev-dot.s-medium, .sev-medium { background: var(--amber); }
.sev-dot.s-none, .sev-none { background: var(--txt3); }

/* ── TEMPLATE BROWSE ─────────────────────────────────────────────────────── */

/* ── MODAL SYSTEM ───────────────────────────────────────────────────────── */
#modal-overlay {
  display: none; position: fixed; inset: 0; z-index: 10500;
  background: rgba(0,0,0,0.62);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  align-items: flex-end; justify-content: center;
  /* JS sets bottom = keyboard height via visualViewport, so modal stays above keyboard.
     Längere Transition (220ms) → kein hartes Snap, smooth slide wenn Tastatur kommt/geht. */
  transition: bottom 0.22s cubic-bezier(0.2, 0.7, 0.2, 1);
  /* Touch-Scroll-Chaining auf Page darunter blockieren */
  overscroll-behavior: none;
  touch-action: none;
}
/* Modal-Body braucht touch-action: pan-y damit der Body-interne Scroll funktioniert */
#modal-overlay .modal-body { touch-action: pan-y; }
#modal-overlay.active  { display: flex; animation: modal-overlay-in  260ms ease both; }
#modal-overlay.closing {                animation: modal-overlay-out 240ms ease both; }
@media (min-width: 600px) {
  #modal-overlay { align-items: center; }
}
.modal {
  display: none; flex-direction: column;
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.08);
  border-bottom: none;
  border-radius: 24px 24px 0 0;
  box-shadow: 0 -30px 80px rgba(0,0,0,0.65);
  width: 100%; max-width: 520px;
  max-height: 92%; overflow: hidden;
}
@media (min-width: 600px) {
  .modal {
    border-radius: 16px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 30px 80px rgba(0,0,0,0.65);
  }
}
/* Konsistent mit Bottom-Sheet: gleiche Easing-Curve (Apple-iOS-spring),
   kein Overshoot. Smoother Open, snappy Close. */
.modal.active  { display: flex; animation: modal-sheet-up   320ms cubic-bezier(0.22, 0.9, 0.24, 1) both; }
.modal.closing { display: flex; animation: modal-sheet-down 240ms cubic-bezier(0.4, 0.0, 1, 1)     both; }

/* Wenn ein Stacked-Modal aktiv ist, das darunterliegende Modal optisch
 * zurückpushen (iOS-Sheet-Pattern: blur + scale-down + dim). */
#modal-overlay.has-stacked .modal.active:not(.is-stacked) {
  transform: scale(0.96);
  filter: blur(8px) brightness(0.55);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1),
              filter    0.28s ease;
  pointer-events: none;
}

/* Stacked-Modal: liegt absolut über einem bereits offenen Modal (z.B. Detail
 * über Activity-Feed). Eigene Animation, die die Positions-Transforms erhält. */
.modal.is-stacked {
  position: absolute; z-index: 5;
  bottom: 0; left: 0; right: 0; margin: 0 auto;
}
.modal.is-stacked.active  { animation: modal-stack-in-mobile  220ms cubic-bezier(0.2, 0, 0, 1.05) both !important; }
.modal.is-stacked.closing { animation: modal-stack-out-mobile 220ms cubic-bezier(0.4, 0, 1, 1)    both !important; }
@keyframes modal-stack-in-mobile  { from { opacity: 0; transform: translateY(40%); } to { opacity: 1; transform: translateY(0); } }
@keyframes modal-stack-out-mobile { from { opacity: 1; transform: translateY(0); }   to { opacity: 0; transform: translateY(40%); } }
@media (min-width: 600px) {
  .modal.is-stacked {
    bottom: auto; top: 50%; left: 50%; right: auto;
    margin: 0;
  }
  .modal.is-stacked.active  { animation: modal-stack-in-desktop  220ms ease both !important; }
  .modal.is-stacked.closing { animation: modal-stack-out-desktop 200ms ease both !important; }
  @keyframes modal-stack-in-desktop  { from { opacity: 0; transform: translate(-50%, calc(-50% + 12px)) scale(0.97); } to { opacity: 1; transform: translate(-50%, -50%) scale(1); } }
  @keyframes modal-stack-out-desktop { from { opacity: 1; transform: translate(-50%, -50%) scale(1); }                  to { opacity: 0; transform: translate(-50%, calc(-50% + 12px)) scale(0.97); } }
}
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 18px;
  border-bottom: 1px solid var(--border);
  font-family: var(--cond); font-size: 20px; font-weight: 800;
  letter-spacing: -0.005em;
  color: var(--txt);
  flex-shrink: 0;
}
.modal-header .btn-icon {
  margin: -4px -8px -4px 0; /* optisch näher an die Kante ranziehen */
}
.modal-body {
  flex: 1; overflow-y: auto;
  padding: 22px 24px;
  -webkit-overflow-scrolling: touch;
  /* Verhindert Scroll-Chaining: wenn Modal-Body am Top/Bottom angekommen ist,
     soll der Touch-Scroll NICHT auf die Page darunter durchschlagen.
     Klassischer iOS-Safari-Bug ohne diesen Hint. */
  overscroll-behavior: contain;
}
.modal-footer {
  display: flex; gap: 10px;
  padding: 18px 24px;
  border-top: 1px solid var(--border); flex-shrink: 0;
  justify-content: flex-end; align-items: center;
  flex-wrap: wrap;
}
.modal-footer-right { display: flex; gap: 8px; }
/* Mobile: Buttons vertikal stacken — kein Text-Truncate, kein Layout-Crunch.
   Reihenfolge via order: Primary oben, danach Secondary/etc., Löschen ganz unten.
   Kompakte Maße + Safe-Area damit + Nächste nicht unter Tastatur/Home-Indicator
   verschwindet. */
@media (max-width: 600px) {
  .modal-footer {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    padding: 10px 16px calc(10px + env(safe-area-inset-bottom, 0px));
  }
  .modal-footer button {
    width: 100%;
    margin: 0 !important;
    letter-spacing: 0.1em;
    /* Kompakter als Default — passt mehr Buttons in den verfügbaren Raum,
       behält aber die 44px Touch-Target-Höhe nach Apple HIG. */
    padding: 10px 16px !important;
    font-size: 11px !important;
    min-height: 44px;
  }
  .modal-footer .btn-primary { order: 1; }
  .modal-footer .btn-primary.btn-secondary,
  .modal-footer #tm-save-next-btn { order: 2; }
  .modal-footer .btn-success { order: 3; }
  .modal-footer .btn-secondary:not(.btn-primary) { order: 4; }
  .modal-footer .btn-danger { order: 99; margin-top: 2px !important; }

  /* Aufgabe-Modal: ein Row-Layout statt Column.
     Speichern nimmt den Hauptraum (flex:1), + Nächste daneben als 44px Icon-Square,
     Löschen (Edit-Mode only) als 44px Trash-Icon links. Eine Zeile, kompakt. */
  .modal-footer.modal-footer-tm {
    flex-direction: row;
    align-items: stretch;
    gap: 6px;
    padding: 10px 14px calc(10px + env(safe-area-inset-bottom, 0px));
    flex-wrap: nowrap;
  }
  .modal-footer.modal-footer-tm .btn-primary:not(.tm-plus) {
    flex: 1; width: auto;
    order: 2;
  }
  .modal-footer.modal-footer-tm .tm-plus {
    flex: 0 0 44px;
    width: 44px; height: 44px;
    padding: 0 !important;
    display: grid; place-items: center;
    order: 3;
  }
  .modal-footer.modal-footer-tm .tm-plus svg { display: block; }
  .modal-footer.modal-footer-tm .btn-danger {
    /* Edit-Mode: Löschen bleibt als Text-Button links — kompakter Padding */
    margin: 0 !important;
    order: 1;
    padding: 10px 12px !important;
  }
}

/* Desktop ≥ 600px: gleiche Row-Logik fürs Aufgabe-Modal — Konsistenz */
@media (min-width: 600px) {
  .modal-footer.modal-footer-tm .btn-primary:not(.tm-plus) { flex: 1; }
  .modal-footer.modal-footer-tm .tm-plus {
    flex: 0 0 44px;
    width: 44px; height: 44px;
    padding: 0;
    display: grid; place-items: center;
  }
  .modal-footer.modal-footer-tm .tm-plus svg { display: block; }
}

/* ── Onboarding-Tour — S-Tier Spotlight (Backdrop-Blur, Pulse-Glow, Arrow, Progress) ────── */
/* Overlay-Container: nur Layer-Halter, kein eigener visueller Effekt.
   Die Dim+Blur passieren in 4 separaten Strips (top/right/bottom/left)
   die um den Cutout herum positioniert werden. So ist der Cutout-Bereich
   physikalisch frei von Blur — Apple/Linear-Pattern. */
.onb-tour-overlay {
  position: fixed; inset: 0;
  background: transparent;
  z-index: 99999;
  opacity: 0;
  pointer-events: none;
  animation: onb-tour-fade-in 0.45s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.onb-tour-overlay > * { pointer-events: auto; }

/* Die 4 Blur-Strips — bilden zusammen den dim/blur-Bereich AUSSERHALB des Cutouts */
.onb-tour-strip {
  position: fixed;
  background: rgba(8,8,10,0.62);
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  pointer-events: auto;
  transition:
    top 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    left 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    width 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    height 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes onb-tour-fade-in { to { opacity: 1; } }
.onb-tour-overlay.closing { animation: onb-tour-fade-out 0.32s cubic-bezier(0.55, 0, 0.6, 1) forwards; }
@keyframes onb-tour-fade-out { to { opacity: 0; } }

/* Cutout: nur Glow-Ring um den Target. KEIN Box-Shadow-Dim mehr — Dim kommt
   von den 4 Strips drumherum. Cutout-Bereich selbst ist komplett klar/sharp. */
.onb-tour-cutout {
  position: fixed;
  border-radius: 12px;
  pointer-events: none;
  /* Cleaner: nur ein dünner Ring + ein weicher Halo. Kein Mehrfach-Layer-Stack. */
  box-shadow:
    0 0 0 1.5px rgba(61,90,241,0.95),
    0 0 32px 6px rgba(61,90,241,0.28);
  transition: top 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              left 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              width 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              height 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              opacity 0.3s ease;
  animation: onb-tour-pulse 2.6s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}
@keyframes onb-tour-pulse {
  0%, 100% { box-shadow: 0 0 0 1.5px rgba(61,90,241,0.95), 0 0 32px 6px rgba(61,90,241,0.28); }
  50%      { box-shadow: 0 0 0 1.5px rgba(61,90,241,1),    0 0 44px 10px rgba(61,90,241,0.4); }
}

/* Click-Target-to-Advance Layer: unsichtbar, aber clickbar genau im Cutout-Bereich */
.onb-tour-target-clicker {
  position: fixed;
  z-index: 99999;
  cursor: pointer;
  border-radius: 12px;
  transition: top 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              left 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              width 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              height 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Tooltip: Glas-Karte mit Backdrop-Blur, Premium-Feel */
.onb-tour-tooltip {
  position: fixed;
  background: rgba(20,20,24,0.92);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 18px 20px 16px;
  max-width: 320px;
  z-index: 100000;
  box-shadow:
    0 24px 48px rgba(0,0,0,0.55),
    0 8px 16px rgba(0,0,0,0.35),
    0 0 0 1px rgba(255,255,255,0.04) inset;
  transition: top 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              left 0.45s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  animation: onb-tooltip-enter 0.42s cubic-bezier(0.22, 1, 0.36, 1) backwards;
}
@keyframes onb-tooltip-enter {
  from { opacity: 0; transform: translateY(8px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Tooltip-Arrow: kleines Dreieck zur Highlight-Box, Glass-konsistent */
.onb-tour-tooltip::before,
.onb-tour-tooltip::after {
  content: '';
  position: absolute;
  width: 0; height: 0;
  border-style: solid;
  pointer-events: none;
}
.onb-tour-tooltip[data-arrow="up"]::before,
.onb-tour-tooltip[data-arrow="up"]::after {
  bottom: 100%;
  border-width: 0 8px 9px 8px;
  border-color: transparent transparent rgba(255,255,255,0.08) transparent;
}
.onb-tour-tooltip[data-arrow="up"]::after {
  border-color: transparent transparent rgba(20,20,24,0.92) transparent;
  margin-bottom: -1px;
}
.onb-tour-tooltip[data-arrow="down"]::before,
.onb-tour-tooltip[data-arrow="down"]::after {
  top: 100%;
  border-width: 9px 8px 0 8px;
  border-color: rgba(255,255,255,0.08) transparent transparent transparent;
}
.onb-tour-tooltip[data-arrow="down"]::after {
  border-color: rgba(20,20,24,0.92) transparent transparent transparent;
  margin-top: -1px;
}

/* Progress-Dots oben im Tooltip — subtil, nicht aufdringlich */
.onb-tour-progress {
  display: flex; align-items: center; gap: 4px;
  margin-bottom: 12px;
}
.onb-tour-progress-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: rgba(255,255,255,0.15);
  transition: background 0.3s, width 0.3s;
}
.onb-tour-progress-dot.done { background: rgba(61,90,241,0.55); }
.onb-tour-progress-dot.active {
  background: var(--accent);
  width: 18px; border-radius: 3px;
  box-shadow: 0 0 8px rgba(61,90,241,0.55);
}

.onb-tour-step-counter {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
  font-weight: 600;
}

.onb-tour-title {
  font-family: var(--cond); font-size: 19px; font-weight: 800;
  color: var(--txt); margin: 0 0 8px; line-height: 1.2;
  letter-spacing: -0.01em;
}

.onb-tour-text {
  font-size: 13px; line-height: 1.55;
  color: var(--txt2);
  margin: 0 0 16px;
}
.onb-tour-text strong { color: var(--txt); font-weight: 600; }
.onb-tour-text em { color: var(--accent); font-style: normal; font-family: var(--mono); font-size: 12px; }

.onb-tour-actions {
  display: flex; align-items: center; gap: 8px;
}

.onb-tour-skip {
  background: none; border: none;
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); padding: 6px 8px;
  cursor: pointer;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: color 0.15s;
}
.onb-tour-skip:hover { color: var(--txt2); }

.onb-tour-next {
  margin-left: auto;
  background: var(--accent); color: #fff;
  border: none; border-radius: 8px;
  padding: 10px 16px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 4px 12px rgba(61,90,241,0.35);
  transition: filter 0.15s, transform 0.1s, box-shadow 0.2s;
}
.onb-tour-next:hover { filter: brightness(1.1); box-shadow: 0 6px 16px rgba(61,90,241,0.45); }
.onb-tour-next:active { transform: scale(0.97); }
.onb-tour-next.is-final { animation: onb-final-pulse 2s ease-in-out infinite; }
@keyframes onb-final-pulse {
  0%, 100% { box-shadow: 0 4px 12px rgba(61,90,241,0.35); }
  50%      { box-shadow: 0 6px 20px rgba(61,90,241,0.6); }
}

/* Vehicle delete row — lives at bottom of modal body, above the footer */
.vf-delete-row {
  border-top: 1px solid var(--border);
  padding: 4px 0 2px;
  display: flex; justify-content: center;
}
.vf-delete-row button {
  display: flex; align-items: center; gap: 6px;
  background: none; border: none; cursor: pointer;
  color: var(--red); opacity: 0.6;
  font-size: 13px; padding: 10px 20px;
  transition: opacity 0.15s;
}
.vf-delete-row button:hover, .vf-delete-row button:active { opacity: 1; }

/* ── FORMS ──────────────────────────────────────────────────────────────── */
.form-group { margin-bottom: 18px; }
.form-group:last-child { margin-bottom: 0; }
.form-group label {
  display: block; font-family: var(--mono); font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--txt2);
  margin-bottom: 7px;
}
.form-label-meta {
  font-family: var(--mono); font-size: 9px;
  font-weight: 400;
  letter-spacing: 0.08em;
  color: var(--txt3);
  margin-left: 4px;
  text-transform: lowercase;
  font-variant: normal;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%; background: var(--bg); border: 1px solid var(--border2);
  border-radius: 10px; color: var(--txt);
  font-family: var(--body); font-size: 14px;
  padding: 11px 14px; outline: none;
  transition: border-color 0.2s, background 0.2s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--accent);
  background: rgba(61,90,241,0.03);
}
.form-group textarea { resize: vertical; min-height: 80px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-hint { font-family: var(--mono); font-size: 10px; color: var(--txt3); letter-spacing: 0.06em; margin-top: 6px; }
select option { background: var(--surface2); }

/* ── MODAL SECTIONS ────────────────────────────────────────────────────────
   Pattern für visuell gruppierte Form-Bereiche im Modal-Body. Mono-Caps
   Section-Label oben, optional mit Hairline drunter, dann Form-Groups. */
.modal-section {
  margin-bottom: 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}
.modal-section:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.modal-section-label {
  font-family: var(--mono); font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt3);
  margin-bottom: 14px;
}
.modal-section-label-accent {
  color: var(--accent);
}

/* ── SCAN-CTA (Schein/Beleg-Scan-Hook) ─────────────────────────────────────
   Editorial Akzent-Card am Anfang relevanter Modals. AI-Magic-Hook für
   Auto-Fill — Premium-Trigger + Activation-Beschleuniger. */
.scan-cta {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 14px 18px;
  margin-bottom: 22px;
  background: linear-gradient(135deg, rgba(61,90,241,0.1), rgba(61,90,241,0.03));
  border: 1px solid rgba(61,90,241,0.3);
  border-radius: 12px;
  color: var(--txt);
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.18s ease;
}
.scan-cta:hover {
  background: linear-gradient(135deg, rgba(61,90,241,0.16), rgba(61,90,241,0.05));
  border-color: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(61,90,241,0.18);
}
.scan-cta:active { transform: scale(0.99); }
.scan-cta-icon {
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(61,90,241,0.15);
  border: 1px solid rgba(61,90,241,0.4);
  color: var(--accent);
  flex-shrink: 0;
}
.scan-cta-text {
  display: flex; flex-direction: column; gap: 3px; min-width: 0;
}
.scan-cta-label {
  font-family: var(--cond);
  font-weight: 700; font-size: 15px;
  letter-spacing: -0.005em;
  color: var(--txt);
}
.scan-cta-sub {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--txt2);
  letter-spacing: 0.06em;
}
.scan-cta-chev {
  color: var(--accent);
  font-family: var(--cond);
  font-size: 18px;
  font-weight: 800;
  flex-shrink: 0;
  transition: transform 0.18s ease;
}
.scan-cta:hover .scan-cta-chev { transform: translateX(3px); }

/* ── QUICK-PHOTO MODAL (Werkstatt-Reference-Capture) ─────────────────────
   Nach File-Capture öffnet kleines Modal mit Thumbnail + Caption-Input.
   1-line caption optional, Save-on-Enter für maximale Geschwindigkeit. */
.qp-thumb-wrap {
  margin-bottom: 18px;
  display: flex; justify-content: center;
}
.qp-thumb {
  width: 100%; max-width: 360px;
  background: #000;
  border-radius: 12px;
  border: 1px solid var(--border);
  overflow: hidden;
  aspect-ratio: 4/3;
  display: flex; align-items: center; justify-content: center;
}
.qp-thumb img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
}

/* Kategorie-Picker im Quick-Photo-Modal — Segmented Control Style */
.qp-tag-picker {
  display: flex;
  gap: 4px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 3px;
}
.qp-tag-btn {
  flex: 1;
  padding: 9px 12px;
  background: transparent;
  border: none;
  border-radius: 7px;
  color: var(--txt2);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.qp-tag-btn:hover { color: var(--txt); }
.qp-tag-btn.active {
  background: rgba(255,255,255,0.08);
  color: var(--txt);
}

/* Aufgaben-Verlinkungs-Dropdown im Quick-Photo-Modal */
.qp-link-select {
  width: 100%;
  padding: 10px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--txt);
  font-family: var(--body);
  font-size: 14px;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23999' stroke-width='1.6'><polyline points='1 1 6 6 11 1'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  cursor: pointer;
}
.qp-link-select:focus { outline: none; border-color: var(--accent); }

/* Werkstatt-Foto in Aufgaben-Detail mit Caption darunter */
.ed-werkstatt-photo {
  position: relative;
  display: flex; flex-direction: column; gap: 4px;
}
.ed-werkstatt-photo img {
  width: 100%; border-radius: 8px; cursor: pointer; display: block;
}
.ed-werkstatt-caption {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--txt3);
  text-transform: uppercase;
}

/* ── SCAN-OVERLAY (Loading-State während AI-Analyse) ───────────────────── */
.scan-overlay {
  position: fixed; inset: 0; z-index: 12500;
  background: rgba(0,0,0,0.78);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s cubic-bezier(0.32,0.72,0,1);
}
.scan-overlay.active { opacity: 1; pointer-events: auto; }
.scan-overlay-card {
  text-align: center;
  padding: 32px 28px 26px;
  max-width: 320px;
}
.scan-overlay-spinner {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(61,90,241,0.15);
  border: 1px solid rgba(61,90,241,0.4);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  margin: 0 auto 18px;
  animation: scan-spin 1.2s linear infinite;
}
@keyframes scan-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.scan-overlay-text {
  font-family: var(--cond);
  font-weight: 700; font-size: 19px;
  color: var(--txt);
  margin-bottom: 8px;
}
.scan-overlay-sub {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--txt3);
}

/* ── SCAN REVIEW MODAL ─────────────────────────────────────────────────── */
.scan-review-hint {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--txt3);
  margin-bottom: 16px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.025);
  border-radius: 8px;
  border-left: 2px solid var(--accent);
}

/* ── EMPTY STATE (Premium — Typo + CTA, keine Icons) ───────────────────── */
.empty-state {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px;
  padding: 56px 24px; text-align: center;
}
.empty-state-title {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(20px, 4.5vw, 24px);
  line-height: 1.15; letter-spacing: -0.005em;
  color: var(--txt); margin: 0;
}
.empty-state-text {
  font-size: 13px; line-height: 1.6; color: var(--txt2);
  max-width: 320px; margin: 0;
}
.empty-state-text strong { color: var(--txt); font-weight: 500; }
.empty-state-cta {
  font-family: var(--cond); font-weight: 700;
  font-size: 14px; letter-spacing: 0.02em; text-transform: uppercase;
  background: linear-gradient(180deg, #4863f5, #2f4ce0);
  color: #fff; border: none;
  padding: 12px 22px; border-radius: var(--r);
  cursor: pointer;
  margin-top: 8px;
  box-shadow:
    0 12px 28px rgba(61,90,241,0.40),
    0 0 0 1px rgba(255,255,255,0.06) inset;
  transition: transform 0.15s, box-shadow 0.2s;
  display: inline-flex; align-items: center; gap: 6px;
}
.empty-state-cta:hover {
  transform: translateY(-1px);
  box-shadow:
    0 16px 32px rgba(61,90,241,0.55),
    0 0 0 1px rgba(255,255,255,0.08) inset;
}
.empty-state-cta:active { transform: translateY(0); }

/* Legacy: kleine Empty-States ohne CTA (z.B. in Tabellen/Sidebars) */
.empty-state p { color: var(--txt2); font-size: 13px; }
.empty-icon { font-size: 48px; opacity: 0.2; }

/* ── STATS / OVERVIEW PAGE ──────────────────────────────────────────────── */
#pg-stats { background: var(--bg); }
.stats-content {
  flex: 1; padding: 16px 16px 80px;
  max-width: 760px; width: 100%; margin: 0 auto;
}

/* ── Studio (Kreations-Hub) ──────────────────────────────────────────────
   Vollbild-Hub für alle Share-/Export-Tools. Editorial Grid, Premium-Vibe. */
.studio-content {
  flex: 1; padding: 16px 16px 80px;
  max-width: 760px; width: 100%; margin: 0 auto;
}
.studio-intro {
  margin-bottom: 18px;
  padding: 0 2px;
}
.studio-intro-kicker {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.18em;
  margin-bottom: 4px;
}
.studio-intro-vehicle {
  font-family: var(--cond); font-size: 26px; font-weight: 700;
  color: var(--txt); letter-spacing: 0.005em; line-height: 1.1;
}
.studio-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.studio-card {
  display: flex; flex-direction: column;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer; padding: 0;
  text-align: left; font-family: inherit;
  color: var(--txt);
  transition: border-color 0.18s, transform 0.12s cubic-bezier(0.32,0.72,0,1);
  position: relative;
}
.studio-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.studio-card:hover { border-color: var(--border2); }
.studio-card:active { transform: scale(0.98); }
.studio-card-preview {
  height: 140px;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.studio-preview-showroom {
  background: linear-gradient(135deg, #1a2233, #0e1422);
  color: #c5cfe0;
}
.studio-preview-showroom .studio-preview-watermark {
  position: absolute; top: 12px; right: 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  color: rgba(255,255,255,0.18); text-transform: uppercase;
}
.studio-preview-showroom .studio-preview-content {
  display: flex; flex-direction: column; gap: 4px;
  padding: 14px;
}
.studio-preview-kicker {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(255,255,255,0.55);
}
.studio-preview-title {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  color: #fff; line-height: 1;
}
.studio-preview-insta {
  background: linear-gradient(135deg, #2a1a3a, #1a0e22);
  position: relative;
}
.studio-preview-insta .studio-preview-slide {
  position: absolute; top: 50%; left: 50%;
  width: 56px; height: 70px; border-radius: 4px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  transform: translate(-50%, -50%);
}
.studio-preview-insta .studio-preview-slide-1 { transform: translate(-150%, -50%) rotate(-6deg); }
.studio-preview-insta .studio-preview-slide-3 { transform: translate(50%, -50%)  rotate(6deg); }
.studio-preview-insta .studio-preview-fmt {
  position: absolute; bottom: 10px; right: 12px;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.14em;
  color: rgba(255,255,255,0.4); text-transform: uppercase;
}
.studio-preview-pdf,
.studio-preview-sale {
  background: var(--surface);
  color: var(--txt3);
}
.studio-card-text { padding: 12px 14px 14px; position: relative; z-index: 1; }
.studio-card-title {
  font-family: var(--cond); font-size: 17px; font-weight: 700;
  color: var(--txt); line-height: 1.15; margin-bottom: 4px;
}
.studio-card-sub {
  font-size: 12px; color: var(--txt2); line-height: 1.45;
}
.studio-footer {
  margin-top: 32px; padding: 18px;
  border-top: 1px dashed var(--border);
  text-align: center;
}
.studio-footer-kicker {
  font-family: var(--mono); font-size: 9px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.2em; margin-bottom: 4px;
}
.studio-footer-text {
  font-size: 12px; color: var(--txt2);
}

/* ── Studio · Showroom-Editor (Vollbild-Sub-Page) ──────────────────────── */
.ssh-content {
  flex: 1; padding: 16px 16px 80px;
  max-width: 760px; width: 100%; margin: 0 auto;
}
.ssh-intro {
  margin-bottom: 22px;
  padding: 18px 18px 20px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  position: relative; overflow: hidden;
}
.ssh-intro::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.ssh-intro-kicker {
  font-family: var(--mono); font-size: 10px; color: var(--accent);
  text-transform: uppercase; letter-spacing: 0.22em;
  margin-bottom: 6px; position: relative;
}
.ssh-intro-title {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  color: var(--txt); line-height: 1.15; margin-bottom: 10px;
  position: relative;
}
.ssh-intro-text {
  font-size: 13px; color: var(--txt2); line-height: 1.55;
  margin: 0; max-width: 560px; position: relative;
}
.ssh-section {
  margin-top: 22px;
}
.ssh-section-title {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.18em;
  margin: 0 0 12px; padding: 0 2px;
}
.ssh-create-btn {
  width: 100%; margin-top: 8px;
}
.ssh-result {
  margin-top: 14px;
}
.ssh-result-err {
  padding: 12px 14px; border-radius: 10px;
  background: rgba(224,53,53,0.08); color: var(--red);
  font-size: 13px; line-height: 1.45;
  border: 1px solid rgba(224,53,53,0.18);
}
.ssh-result-ok .share-result-label { color: var(--green); }

/* Section-Liste: Toggle-Cards die Showroom-Inhalt kuratieren. */
.ssh-section-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin: 0 0 12px; padding: 0 2px;
}
.ssh-section-head .ssh-section-title { margin: 0; }
.ssh-section-count {
  font-family: var(--mono); font-size: 10px; color: var(--accent);
  letter-spacing: 0.14em; text-transform: uppercase;
}
.ssh-sections-list {
  display: flex; flex-direction: column; gap: 0;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}
.ssh-section-row {
  display: flex; align-items: center; gap: 14px;
  width: 100%; padding: 14px 16px;
  background: none; border: none;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  color: var(--txt); text-align: left; cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.ssh-section-row:last-child { border-bottom: none; }
.ssh-section-row:hover { background: rgba(255,255,255,0.025); }
.ssh-section-row:active { background: rgba(255,255,255,0.05); }
.ssh-section-row-text { flex: 1; min-width: 0; }
.ssh-section-row-label {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  color: var(--txt); line-height: 1.15; margin-bottom: 3px;
  letter-spacing: 0.005em;
}
.ssh-section-row-sub {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.12em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ssh-section-row.is-on .ssh-section-row-label { color: var(--txt); }
.ssh-section-row:not(.is-on) .ssh-section-row-label { color: var(--txt3); }
.ssh-section-row:not(.is-on) .ssh-section-row-sub { opacity: 0.7; }

/* iOS-Style Toggle (kompakt, editorial — kein Material Switch) */
.ssh-section-toggle {
  display: inline-block; flex-shrink: 0;
  width: 38px; height: 22px; border-radius: 11px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.08);
  position: relative;
  transition: background 0.18s, border-color 0.18s;
}
.ssh-section-toggle-thumb {
  position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--txt3);
  transition: transform 0.18s cubic-bezier(0.32,0.72,0,1), background 0.18s;
}
.ssh-section-row.is-on .ssh-section-toggle,
.ssh-section-toggle.is-on {
  background: var(--accent);
  border-color: var(--accent);
}
.ssh-section-row.is-on .ssh-section-toggle-thumb,
.ssh-section-toggle.is-on .ssh-section-toggle-thumb {
  transform: translateX(16px);
  background: #fff;
}

.ssh-sections-hint {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
  padding: 10px 4px 0;
}

/* Insta Slide-Curation — Slot-Nummer-Prefix vor dem Label */
.ssh-slide-num {
  display: inline-block; margin-right: 8px;
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  color: var(--txt3); letter-spacing: 0.12em;
  vertical-align: 2px;
}
.ssh-section-row.is-on .ssh-slide-num { color: var(--accent); }
/* Locked-State: letzter aktiver Slide kann nicht aus — Toggle wirkt "gefroren" */
.ssh-section-row.is-locked .ssh-section-toggle-btn { cursor: not-allowed; opacity: 0.78; }
.ssh-section-row.is-locked .ssh-section-toggle { box-shadow: 0 0 0 1px rgba(255,255,255,0.06); }

/* ── Step 4: Preset-Liste + Editor-Name + Danger-Zone ─────────────────── */
.ssh-preset-list {
  display: flex; flex-direction: column; gap: 10px;
}
.ssh-preset-card {
  position: relative;
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 6px;
  width: 100%; padding: 18px 44px 18px 18px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  color: var(--txt); text-align: left; cursor: pointer;
  font-family: inherit;
  transition: border-color 0.18s, transform 0.12s cubic-bezier(0.32,0.72,0,1), background 0.15s;
}
.ssh-preset-card:hover { border-color: var(--border2); }
.ssh-preset-card:active { transform: scale(0.99); background: rgba(255,255,255,0.025); }
.ssh-preset-card-name {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  color: var(--txt); line-height: 1.15;
  letter-spacing: 0.005em;
}
.ssh-preset-card-meta {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
}
.ssh-preset-card-chev {
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  font-family: var(--mono); font-size: 14px;
  color: var(--txt3); opacity: 0.6;
  transition: color 0.15s, opacity 0.15s, transform 0.15s;
}
.ssh-preset-card:hover .ssh-preset-card-chev {
  color: var(--accent); opacity: 1;
  transform: translate(2px, -50%);
}
.ssh-preset-add {
  display: flex; align-items: center; justify-content: center;
  gap: 8px;
  width: 100%; padding: 16px;
  background: transparent; border: 1px dashed var(--border2);
  border-radius: 14px;
  color: var(--txt2); cursor: pointer;
  font-family: inherit;
  transition: border-color 0.18s, color 0.18s, background 0.15s;
}
.ssh-preset-add:hover {
  border-color: var(--accent); color: var(--accent);
  background: rgba(61,90,241,0.04);
}
.ssh-preset-add-icon {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  line-height: 1;
}
.ssh-preset-add-text {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
}

/* Preset-Name-Input am Editor-Anfang */
.ssh-name-section {
  margin-bottom: 22px;
}
.ssh-name-label {
  display: block;
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.18em;
  margin-bottom: 8px;
}
.ssh-name-input {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  color: var(--txt); letter-spacing: 0.005em;
  transition: border-color 0.15s, background 0.15s;
}
.ssh-name-input:hover { border-color: var(--border2); }
.ssh-name-input:focus { border-color: var(--accent); outline: none; background: var(--surface); }

/* Danger-Zone für Delete */
.ssh-danger-zone {
  margin-top: 32px; padding-top: 24px;
  border-top: 1px dashed var(--border);
  text-align: center;
}
.ssh-delete-btn {
  background: none; border: 1px solid rgba(224,53,53,0.25);
  color: var(--red);
  padding: 10px 20px; border-radius: 10px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.ssh-delete-btn:hover {
  background: rgba(224,53,53,0.08);
  border-color: rgba(224,53,53,0.45);
}

/* ── Live-Preview Sticky-Bar (im Editor) ─────────────────────────────── */
.ssh-preview-bar {
  position: sticky;
  bottom: 16px;
  margin-top: 32px;
  padding-bottom: env(safe-area-inset-bottom, 0);
  display: flex; justify-content: center;
  z-index: 5;
  pointer-events: none; /* nur Button selbst clickable */
}
.ssh-preview-btn {
  pointer-events: auto;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 24px;
  background: rgba(20, 22, 28, 0.92);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--border2);
  border-radius: 999px;
  color: var(--txt);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 12px 32px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.04) inset;
  transition: transform 0.18s cubic-bezier(0.32,0.72,0,1),
              background 0.18s, border-color 0.18s, box-shadow 0.18s;
}
.ssh-preview-btn:hover {
  transform: translateY(-2px);
  background: rgba(28, 31, 40, 0.95);
  border-color: var(--accent);
  box-shadow: 0 18px 42px rgba(61,90,241,0.25), 0 0 0 1px rgba(255,255,255,0.06) inset;
}
.ssh-preview-btn:active { transform: translateY(-1px) scale(0.98); }
.ssh-preview-btn svg { color: var(--accent); flex-shrink: 0; }

/* Pulse wenn Editor-State seit letzter Vorschau geändert wurde */
.ssh-preview-btn.is-dirty {
  animation: ssh-preview-pulse 2.4s ease-in-out infinite;
}
.ssh-preview-btn.is-dirty::after {
  content: '';
  position: absolute; top: 4px; right: 14px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent), 0 0 4px var(--accent);
  animation: ssh-preview-dot 1.4s ease-in-out infinite;
}
@keyframes ssh-preview-pulse {
  0%, 100% { box-shadow: 0 12px 32px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.04) inset; }
  50%      { box-shadow: 0 12px 32px rgba(0,0,0,0.4), 0 0 0 2px rgba(61,90,241,0.4), 0 0 24px rgba(61,90,241,0.25); }
}
@keyframes ssh-preview-dot {
  0%, 100% { opacity: 0.8; }
  50%      { opacity: 1; }
}

/* ── Showroom-Preview-Page Floating-Back-Button ─────────────────────── */
#pg-studio-showroom-preview {
  position: relative;
}
.ssh-preview-back {
  position: fixed;
  bottom: calc(20px + env(safe-area-inset-bottom, 0));
  left: 50%; transform: translateX(-50%);
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  background: rgba(20, 22, 28, 0.92);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--border2);
  border-radius: 999px;
  color: var(--txt);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 12px 32px rgba(0,0,0,0.5);
  z-index: 1000;
  transition: transform 0.18s, background 0.18s, border-color 0.18s;
}
.ssh-preview-back:hover {
  background: rgba(28, 31, 40, 0.95);
  border-color: var(--accent);
  transform: translateX(-50%) translateY(-2px);
}
.ssh-preview-back:active { transform: translateX(-50%) translateY(-1px) scale(0.97); }
.ssh-preview-back svg { color: var(--accent); flex-shrink: 0; }

/* Disclaimer-Banner oben in der Preview (subtil, blendet weg beim Scrollen) */
#pg-studio-showroom-preview::before {
  content: 'Live-Vorschau · noch nicht gespeichert';
  position: fixed; top: 12px; left: 50%; transform: translateX(-50%);
  padding: 8px 16px;
  background: rgba(20, 22, 28, 0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--txt2);
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  z-index: 1000;
  pointer-events: none;
  white-space: nowrap;
}

/* ── Step 5: Section-Row-Update — Click=Edit, Toggle=eigener Button ─── */
.ssh-section-row {
  position: relative;
}
.ssh-section-row-chev {
  font-family: var(--mono); font-size: 16px;
  color: var(--txt3); opacity: 0.5; flex-shrink: 0;
  transition: color 0.15s, opacity 0.15s, transform 0.15s;
  margin-right: 6px;
}
.ssh-section-row:hover .ssh-section-row-chev {
  color: var(--accent); opacity: 1;
  transform: translateX(2px);
}
.ssh-section-toggle-btn {
  background: none; border: none; padding: 0;
  cursor: pointer; flex-shrink: 0;
  display: inline-flex; align-items: center;
  border-radius: 11px;
  transition: transform 0.1s;
}
.ssh-section-toggle-btn:active { transform: scale(0.92); }

/* ── Step 5: Section-Editor-Page ────────────────────────────────────── */
.ssec-head {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 18px 16px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  margin-bottom: 20px;
  position: relative; overflow: hidden;
}
.ssec-head::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.ssec-head-text { flex: 1; min-width: 0; position: relative; }
.ssec-head-label {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  color: var(--txt); line-height: 1.15; letter-spacing: 0.005em;
  margin-bottom: 4px;
}
.ssec-head-sub {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
}
.ssec-head-toggle { position: relative; z-index: 1; }
.ssec-disabled-hint {
  font-size: 12px; color: var(--txt3);
  background: rgba(255,255,255,0.025);
  border: 1px dashed var(--border);
  border-radius: 10px;
  padding: 10px 14px;
  margin-bottom: 18px;
  line-height: 1.5;
}
.ssec-body { /* container für Editor-spezifischen Body */ }

/* Stub-Editor für noch nicht implementierte Sections */
.ssec-stub {
  text-align: center; padding: 48px 24px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  color: var(--txt2);
}
.ssec-stub-icon { color: var(--txt3); margin-bottom: 12px; }
.ssec-stub-title {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  color: var(--txt); margin-bottom: 6px;
}
.ssec-stub-text { font-size: 13px; line-height: 1.55; max-width: 400px; margin: 0 auto; }

.ssec-empty {
  text-align: center; padding: 32px 18px;
  background: var(--surface2);
  border: 1px dashed var(--border);
  border-radius: 12px;
}
.ssec-empty-title {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  margin-bottom: 6px; color: var(--txt);
}
.ssec-empty-text { font-size: 13px; color: var(--txt2); line-height: 1.5; }

/* ── Editor: Gallery-Picker ─────────────────────────────────────────── */
.ssec-gallery-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 12px 4px 10px;
}
.ssec-gallery-count {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  color: var(--accent); line-height: 1;
}
.ssec-gallery-count-sep { color: var(--txt3); margin: 0 4px; }
.ssec-gallery-count-label {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em; margin-left: 6px;
}
.ssec-gallery-actions { display: flex; gap: 6px; }
.ssec-mini-btn {
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--txt2);
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  padding: 7px 12px; border-radius: 8px;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
.ssec-mini-btn:hover { border-color: var(--accent); color: var(--accent); }
.ssec-gallery-hint {
  font-size: 12px; color: var(--txt3);
  margin-bottom: 12px; padding: 0 4px;
}
.ssec-gallery-grid {
  display: grid; gap: 6px;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
}
.ssec-cover-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
.ssec-photo-tile {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--surface2);
  border: 2px solid var(--border);
  border-radius: 10px;
  padding: 0; overflow: hidden;
  cursor: pointer;
  transition: border-color 0.15s, transform 0.1s;
}
.ssec-photo-tile img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: opacity 0.15s;
}
.ssec-photo-tile:hover { border-color: var(--border2); }
.ssec-photo-tile:active { transform: scale(0.97); }
.ssec-photo-tile.is-selected {
  border-color: var(--accent);
}
.ssec-photo-tile:not(.is-selected) img { opacity: 0.6; }
.ssec-photo-badge {
  position: absolute; top: 6px; right: 6px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--accent); color: #fff;
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: 0;
}

/* ── Editor: Story / Hero Form ──────────────────────────────────────── */
.ssec-form .form-group { margin-bottom: 16px; }
.ssec-input,
.ssec-textarea {
  width: 100%;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  font-family: inherit; font-size: 14px;
  color: var(--txt);
  resize: vertical;
  transition: border-color 0.15s;
}
.ssec-input:focus,
.ssec-textarea:focus { border-color: var(--accent); outline: none; }
.ssec-textarea { min-height: 140px; line-height: 1.55; }
.ssec-form-hint,
.ssec-section-hint {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
  padding: 4px 0 14px;
}

/* ── Editor: Timeline / Service Multi-Select-Liste ──────────────────────
   Vertikale Liste statt Foto-Grid. Selected-Reihenfolge via Badge. */
.ssec-list {
  display: flex; flex-direction: column;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden;
}
.ssec-list-row {
  position: relative;
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 12px 16px 13px;
  background: none; border: none;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  color: var(--txt); text-align: left; cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.ssec-list-row:last-child { border-bottom: none; }
.ssec-list-row:hover { background: rgba(255,255,255,0.025); }
.ssec-list-row:active { background: rgba(255,255,255,0.05); }
.ssec-list-row.is-selected {
  background: rgba(61,90,241,0.06);
}
.ssec-list-row.is-selected::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--accent);
}
.ssec-list-text { flex: 1; min-width: 0; }
.ssec-list-label {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  color: var(--txt); line-height: 1.2; margin-bottom: 3px;
  letter-spacing: 0.005em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ssec-list-row:not(.is-selected) .ssec-list-label { color: var(--txt2); }
.ssec-list-meta {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.12em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ssec-list-badge {
  flex-shrink: 0;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--accent); color: #fff;
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

/* Action-Sheet "Studio öffnen" Eintrag */
.bs-share-icon-studio {
  background: linear-gradient(135deg, rgba(61,90,241,0.18), rgba(61,90,241,0.06));
  color: var(--accent);
}
.bs-share-studio { position: relative; }
.bs-share-studio .bs-option-chev {
  position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
  font-family: var(--mono); color: var(--accent); opacity: 0.7;
  transition: transform 0.15s, opacity 0.15s;
}
.bs-share-studio:hover .bs-option-chev { opacity: 1; transform: translate(2px, -50%); }

/* Period filter (segment-bar) */
.stats-filter {
  display: flex; gap: 4px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px; padding: 4px;
  margin-bottom: 22px;
}
.stats-filter-btn {
  flex: 1; padding: 9px 8px;
  border: none; background: none;
  color: var(--txt3);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  cursor: pointer; border-radius: 7px;
  transition: all 0.18s;
}
.stats-filter-btn:hover { color: var(--txt2); }
.stats-filter-btn.active {
  background: var(--bg);
  color: var(--accent);
  box-shadow: 0 1px 4px rgba(0,0,0,0.4);
}

/* Hero */
.stats-hero {
  text-align: center;
  padding: 32px 20px 28px;
  margin-bottom: 22px;
  background: linear-gradient(180deg, rgba(61,90,241,0.08), rgba(61,90,241,0.0));
  border: 1px solid var(--border);
  border-radius: 16px;
  position: relative;
  overflow: hidden;
}
.stats-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 0%, rgba(61,90,241,0.10) 0%, transparent 70%);
  pointer-events: none;
}
.stats-hero-label {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); letter-spacing: 0.18em;
  text-transform: uppercase; margin-bottom: 8px;
  position: relative; z-index: 1;
}
.stats-hero-value {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(40px, 9vw, 64px);
  line-height: 1; letter-spacing: -0.01em;
  color: var(--txt);
  position: relative; z-index: 1;
}
.stats-hero-delta {
  margin-top: 10px;
  font-family: var(--mono); font-size: 11px;
  color: var(--txt2); letter-spacing: 0.04em;
  position: relative; z-index: 1;
  display: inline-flex; align-items: center; gap: 5px;
}
.stats-hero-delta:empty { display: none; }
.stats-hero-delta.up   { color: #f87171; }
.stats-hero-delta.down { color: var(--green); }

/* KPI Strip */
.stats-kpi-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 8px; margin-bottom: 28px;
}
@media (max-width: 480px) {
  .stats-kpi-row { grid-template-columns: repeat(2, 1fr); }
}
.stats-kpi {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 12px;
  text-align: center;
}
.stats-kpi-num {
  display: block;
  font-family: var(--cond); font-weight: 800;
  font-size: 26px; line-height: 1.1;
  color: var(--txt);
  margin-bottom: 3px;
}
.stats-kpi-lbl {
  font-family: var(--mono); font-size: 9px;
  color: var(--txt3); letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* Section */
.stats-section { margin-bottom: 26px; }
.stats-section-title {
  font-family: var(--cond); font-weight: 800;
  font-size: 18px; color: var(--txt);
  margin-bottom: 12px;
  letter-spacing: -0.005em;
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 8px;
}
.stats-section-title-meta {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); letter-spacing: 0.06em;
  font-weight: 400;
}
.stats-section-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}

/* Liste-Items in Stats (TÜV, Anstehend, Werkstätten) */
.stats-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  /* Button-Reset: <button class="stats-row"> soll wie <div> aussehen */
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  font: inherit;
  color: inherit;
}
.stats-row + .stats-row { border-top: 1px solid var(--border); }
.stats-row-dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0;
}
.stats-row-dot.ok      { background: var(--green); box-shadow: 0 0 8px rgba(74,222,128,0.5); }
.stats-row-dot.soon    { background: var(--amber); box-shadow: 0 0 8px rgba(251,191,36,0.5); }
.stats-row-dot.overdue { background: var(--red); box-shadow: 0 0 8px rgba(239,68,68,0.5);
  animation: stats-pulse 2.2s ease-in-out infinite;
}
@keyframes stats-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.7; }
}
.stats-row-main {
  min-width: 0;
}
.stats-row-title {
  font-size: 14px; font-weight: 600; color: var(--txt);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.stats-row-sub {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); margin-top: 2px;
  letter-spacing: 0.04em;
}
.stats-row-value {
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  color: var(--txt2);
  text-align: right; white-space: nowrap;
}
.stats-row.clickable { cursor: pointer; transition: background 0.18s; }
.stats-row.clickable:hover,
.stats-row.clickable:active { background: rgba(255,255,255,0.03); }

/* Bar-Chart (horizontal, Kosten nach Fahrzeug / Kategorie) */
.stats-bars {
  padding: 16px;
  display: flex; flex-direction: column; gap: 12px;
}
.stats-bar-item {}
.stats-bar-row {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 5px;
  gap: 8px;
}
.stats-bar-label {
  font-size: 13px; color: var(--txt);
  font-weight: 500;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.stats-bar-value {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  color: var(--txt2); white-space: nowrap;
}
.stats-bar-track {
  height: 6px; background: var(--bg);
  border-radius: 100px; overflow: hidden;
  border: 1px solid var(--border);
}
.stats-bar-fill {
  height: 100%; border-radius: 100px;
  background: linear-gradient(90deg, var(--accent), #6e8af5);
  animation: stats-bar-fill 0.9s cubic-bezier(0.32, 0.72, 0.16, 1) backwards;
}
@keyframes stats-bar-fill { from { width: 0 !important; } }
/* Kategorie-Farben */
.stats-bar-fill.cat-service { background: linear-gradient(90deg, var(--green), #6ee098); }
.stats-bar-fill.cat-repair  { background: linear-gradient(90deg, var(--amber), #fcd34d); }
.stats-bar-fill.cat-mod     { background: linear-gradient(90deg, var(--accent), #6e8af5); }

/* Monatlicher Bar-Chart (12 vertikale Bars) */
.stats-monthly {
  padding: 18px 16px 12px;
}
.stats-monthly-bars {
  display: flex; align-items: stretch; gap: 4px;
  height: 100px; margin-bottom: 10px;
}
.stats-monthly-bar {
  flex: 1; min-width: 0;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 3px 3px 0 0;
  position: relative;
  transition: background 0.18s;
  height: 100%;
}
.stats-monthly-bar-fill {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(180deg, var(--accent), #2f4ce0);
  border-radius: 2px 2px 0 0;
  animation: stats-monthly-grow 0.8s cubic-bezier(0.32, 0.72, 0.16, 1) backwards;
}
@keyframes stats-monthly-grow { from { height: 0 !important; } }
.stats-monthly-bar:hover { background: rgba(61,90,241,0.08); }
.stats-monthly-labels {
  display: flex; gap: 4px;
  font-family: var(--mono); font-size: 9px;
  color: var(--txt3); letter-spacing: 0.04em;
  text-transform: uppercase;
}
.stats-monthly-labels > span {
  flex: 1; text-align: center; min-width: 0;
  overflow: hidden; text-overflow: ellipsis;
}

/* ── BIG-PILLS (3 operative Kern-Funktionen) ──────────────────────────── */
.nav-bigpills {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 10px;
}
.nav-bigpill {
  position: relative;
  background: linear-gradient(165deg, rgba(20,20,26,0.85), rgba(12,12,16,0.85));
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 12px 11px;
  cursor: pointer;
  text-align: left;
  font: inherit; color: inherit;
  display: flex; flex-direction: column; gap: 4px;
  transition: background 0.22s, border-color 0.22s, transform 0.15s, box-shadow 0.22s;
  overflow: hidden;
}
.nav-bigpill::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(61,90,241,0) 0%, transparent 70%);
  pointer-events: none;
  transition: background 0.32s;
}
.nav-bigpill:hover { border-color: var(--border2); }
.nav-bigpill:active { transform: translateY(1px); }
.nav-bigpill.active {
  background: linear-gradient(180deg, rgba(61,90,241,0.16), rgba(61,90,241,0.04));
  border-color: var(--accent);
  box-shadow:
    0 0 24px rgba(61,90,241,0.18) inset,
    0 12px 28px rgba(61,90,241,0.18);
}
.nav-bigpill.active::before {
  background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(61,90,241,0.20) 0%, transparent 70%);
}
.nav-bigpill-kicker {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  color: var(--txt3); letter-spacing: 0.18em; text-transform: uppercase;
  position: relative; z-index: 1;
  transition: color 0.22s;
}
.nav-bigpill.active .nav-bigpill-kicker { color: var(--accent); }
.nav-bigpill-row {
  display: flex; align-items: baseline; gap: 6px;
  position: relative; z-index: 1;
  min-width: 0;
}
.nav-bigpill-value {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(24px, 7vw, 30px);
  color: var(--txt); line-height: 1;
  letter-spacing: -0.01em;
  flex-shrink: 0;
}
.nav-bigpill-caption {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); letter-spacing: 0.04em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  min-width: 0;
}
.nav-bigpill-alert {
  position: absolute; top: 11px; right: 11px;
  width: 7px; height: 7px; border-radius: 50%;
  z-index: 2;
}
.nav-bigpill-alert.critical {
  background: var(--red); box-shadow: 0 0 8px rgba(224,53,53,0.7);
}
.nav-bigpill-alert.overdue {
  background: var(--red); box-shadow: 0 0 8px rgba(239,68,68,0.6);
  animation: bigpill-pulse 2.2s ease-in-out infinite;
}
.nav-bigpill-alert.soon {
  background: var(--amber); box-shadow: 0 0 8px rgba(251,191,36,0.5);
}
@keyframes bigpill-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.65; }
}

/* ── SMALL-PILLS (sekundäre Bereiche — Card-Look, kompakter als Big-Pills) ──
   Horizontal scrollable mit Snap-Points (iPhone-Wallet-Pattern).
   Bei 3 Pills (passt) wird automatisch ausgefüllt; bei 4+ scrollt der Strip.
   Min-Width pro Tile sorgt für lesbare Größe auch wenn 4 Pills im Viewport sind. */
.detail-hub-strip {
  display: flex;
  gap: 8px;
  padding: 2px 2px 8px;
  margin-bottom: 4px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.detail-hub-strip::-webkit-scrollbar { display: none; }
.detail-hub-strip > .detail-hub-tile {
  flex: 1 1 0; /* gleichmäßig die Breite teilen — 3 Pills füllen den Strip aus */
  min-width: 92px;
  scroll-snap-align: start;
}
.detail-hub-tile {
  /* Same gradient base wie Big-Pills für Modul-Look */
  background: linear-gradient(165deg, rgba(20,20,26,0.85), rgba(12,12,16,0.85));
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px 14px 11px;
  cursor: pointer;
  font: inherit; color: inherit;
  /* Vertikal-Layout konsistent mit Big-Pills: Label oben, Wert drunter */
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 4px;
  text-align: left;
  white-space: nowrap;
  transition: background 0.22s, border-color 0.22s, color 0.22s, transform 0.15s, box-shadow 0.22s;
  position: relative;
  overflow: hidden;
}
.detail-hub-tile::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(61,90,241,0) 0%, transparent 70%);
  pointer-events: none;
  transition: background 0.32s;
}
.detail-hub-tile:hover { border-color: var(--border2); }
.detail-hub-tile:active { transform: translateY(1px); }
.detail-hub-tile.active {
  background: linear-gradient(180deg, rgba(61,90,241,0.16), rgba(61,90,241,0.04));
  border-color: var(--accent);
  box-shadow:
    0 0 18px rgba(61,90,241,0.15) inset,
    0 8px 18px rgba(61,90,241,0.18);
}
.detail-hub-tile.active::before {
  background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(61,90,241,0.18) 0%, transparent 70%);
}
.detail-hub-tile.locked { opacity: 0.5; cursor: not-allowed; }
.detail-hub-tile-kicker {
  /* Mono Caps Label oben, kompakt — exakt wie Big-Pill-Kicker */
  font-family: var(--mono);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--txt3);
  position: relative; z-index: 1;
  transition: color 0.22s;
  line-height: 1;
}
.detail-hub-tile.active .detail-hub-tile-kicker { color: var(--accent); }
.detail-hub-tile-value {
  /* Wert als prominentere Zeile drunter — Cond Bold matcht Big-Pill-Value */
  font-family: var(--cond);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: -0.005em;
  color: var(--txt);
  text-transform: none;
  position: relative; z-index: 1;
  transition: color 0.22s;
  line-height: 1.05;
  display: inline-flex; align-items: baseline; gap: 4px;
  flex-wrap: wrap;
}
.detail-hub-tile.active .detail-hub-tile-value { color: var(--txt); }
/* Einheit (z.B. l/100km) inline neben Wert — Mono kleiner gedämpft */
.detail-hub-tile-unit {
  font-family: var(--mono);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--txt3);
  text-transform: none;
}
.detail-hub-tile-lock {
  width: 11px; height: 11px;
  color: var(--txt3); margin-left: 2px;
  position: relative; z-index: 1;
}

/* ── ACTIVITY FEED (im Form-Modal — nur noch Body-Stile, eigenes Sheet entfernt) ── */
.afeed-body {
  /* Kein eigener overflow — der äußere .modal-body ist der Scroll-Container.
     Sonst gibt's geschachtelte Scroll-Areas und sticky group-heads kollidieren. */
  padding: 8px 0 calc(20px + env(safe-area-inset-bottom));
}

.afeed-row {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center; gap: 14px;
  padding: 14px 22px;
  /* Tappable: ist jetzt ein <button> */
  width: 100%; background: none; border: 0;
  text-align: left; color: var(--txt); cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.afeed-row:hover  { background: rgba(255,255,255,0.025); }
.afeed-row:active { background: rgba(255,255,255,0.05); }
.afeed-row + .afeed-row { border-top: 1px solid var(--border); }

/* Filter-Chips über der Liste */
.afeed-filters {
  display: flex; gap: 6px;
  padding: 14px 22px 6px;
  overflow-x: auto; scrollbar-width: none;
}
.afeed-filters::-webkit-scrollbar { display: none; }
.afeed-chip {
  padding: 6px 14px;
  background: transparent;
  border: 1px solid var(--border2); border-radius: 16px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--txt2); cursor: pointer;
  white-space: nowrap; flex-shrink: 0;
  transition: all 0.15s;
}
.afeed-chip:hover { color: var(--txt); border-color: var(--txt3); }
.afeed-chip.active {
  background: var(--accent); border-color: var(--accent); color: #fff;
}

/* Summary-Zeile: Anzahl + Gesamtkosten */
.afeed-summary {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 8px 22px 12px;
  border-bottom: 1px solid var(--border);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--txt3);
}
.afeed-summary-cost {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  letter-spacing: 0; text-transform: none; color: var(--txt);
  font-variant-numeric: tabular-nums;
}

/* Date-Group-Header — Hero-Hierarchie wie auf Vehicle-Stats:
   Label Cond Bold prominent · Meta Mono Caps rechts. Sticky am Modal-Body Top. */
.afeed-group + .afeed-group { margin-top: 0; }
.afeed-group-head {
  position: sticky; top: 0; z-index: 2;
  display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
  padding: 18px 22px 10px;
  background: var(--surface);
  border-top: 1px solid var(--border);
}
.afeed-group:first-child .afeed-group-head { border-top: 0; padding-top: 14px; }
.afeed-group-label {
  font-family: var(--cond); font-size: 20px; font-weight: 800;
  letter-spacing: 0.005em; line-height: 1.05; color: var(--txt);
}
.afeed-group-meta {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--txt3);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}

.afeed-main { min-width: 0; }
.afeed-kicker {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  color: var(--accent); letter-spacing: 0.18em; text-transform: uppercase;
  margin-bottom: 3px;
}
.afeed-title {
  font-size: 14px; font-weight: 600; color: var(--txt);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.afeed-meta {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.04em; margin-top: 2px;
}
.afeed-cost {
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  color: var(--txt2); white-space: nowrap;
}
.afeed-empty {
  padding: 48px 24px; text-align: center;
  font-size: 13px; color: var(--txt2); line-height: 1.6;
  max-width: 380px; margin: 0 auto;
}

/* ── SEKUNDÄR-TABS (Tank/Dokumente/Notizen) — gemeinsame Container-Styles ─
   Kein eigenes max-width — der äußere pg-vehicle-detail-Container constraint
   schon auf 880px. So sind alle Tabs (Primär + Sekundär) gleich breit. */
#fuel-tab-content,
#docs-tab-content,
#notes-tab-content {
  padding: 16px 16px 0;
  width: 100%;
}

/* ── FUEL TAB — Premium-Iteration (Mai 2026) ─────────────────────────────
   Hero-Card mit letzter Tankung + Trend, Aggregate-Stats darunter, Sparkline,
   Liste im Activity-Feed-Stil. Form wandert ins Modal (FAB-Trigger). */

.fuel-checkbox {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px;
  color: var(--txt2); cursor: pointer;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.fuel-checkbox input { accent-color: var(--accent); }

/* ── FUEL MODAL — S-Tier Polish ────────────────────────────────────────── */
/* Input mit Suffix-Tag (km / l / €) — Suffix sitzt rechts im Input-Feld */
.fmod-input-wrap {
  position: relative;
  display: flex; align-items: stretch;
}
.fmod-input-wrap input {
  width: 100%;
  padding-right: 38px;
}
.fmod-input-suffix {
  position: absolute;
  right: 12px; top: 50%; transform: translateY(-50%);
  pointer-events: none;
  font-family: var(--mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--txt3);
}

/* Hint unter Input (KM-Vorschlag) */
.fmod-hint {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--txt3);
  margin-top: 6px;
  min-height: 14px;
}
.fmod-hint:empty { display: none; }

/* Live-Calc Hint (Preis pro Liter) — kleines Akzent-Banner */
.fmod-calc-hint {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  margin: 0 0 18px;
  background: rgba(61,90,241,0.06);
  border: 1px solid rgba(61,90,241,0.18);
  border-radius: 8px;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: opacity 0.2s, max-height 0.25s, margin 0.2s, padding 0.2s;
}
.fmod-calc-hint.active {
  opacity: 1;
  max-height: 60px;
  padding: 10px 14px;
  margin: 0 0 18px;
}
.fmod-calc-label {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt2);
}
.fmod-calc-val {
  font-family: var(--cond);
  font-weight: 700; font-size: 16px;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}

/* Sorten-Pills — Custom statt Native-Select */
.fmod-pill-row {
  display: flex; flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}
.fmod-pill {
  padding: 8px 14px;
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 100px;
  color: var(--txt2);
  font-family: var(--cond);
  font-weight: 600; font-size: 13px;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: all 0.15s ease;
  white-space: nowrap;
}
.fmod-pill:hover {
  background: rgba(255,255,255,0.04);
  color: var(--txt);
  border-color: var(--txt3);
}
.fmod-pill.active {
  background: rgba(61,90,241,0.12);
  border-color: var(--accent);
  color: var(--accent);
}

/* Vollgetankt / Teil-Tank Segmented Toggle — Akzent-Fill für klare Erkennbarkeit */
.fmod-segment {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 3px;
  margin-top: 4px;
}
.fmod-seg-btn {
  padding: 11px 14px;
  background: transparent;
  border: none;
  border-radius: 7px;
  color: var(--txt3);
  font-family: var(--cond);
  font-weight: 700; font-size: 14px;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: all 0.18s ease;
}
.fmod-seg-btn:hover:not(.active) { color: var(--txt2); }
.fmod-seg-btn.active {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 2px 8px rgba(61,90,241,0.35);
}

/* Daten-Health-Banner: KM/Datum-Inkonsistenz */
.fuel-health-warn {
  display: flex; gap: 12px; align-items: flex-start;
  background: rgba(220, 100, 80, 0.10);
  border: 1px solid rgba(220, 100, 80, 0.35);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 14px;
}
.fuel-health-icon {
  flex-shrink: 0;
  font-size: 18px;
  line-height: 1.4;
  color: #e89070;
}
.fuel-health-body { flex: 1; min-width: 0; }
.fuel-health-title {
  font-family: var(--cond); font-weight: 700; font-size: 15px;
  color: #f0a888; letter-spacing: 0.005em;
  margin-bottom: 4px;
}
.fuel-health-text {
  font-family: var(--body); font-size: 13px; line-height: 1.45;
  color: var(--txt2);
}

/* Hero-Card: letzte Tankung */
.fuel-hero-card {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 20px 22px;
  margin-bottom: 10px;
}
.fuel-hero-kicker {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.fuel-hero-row {
  display: flex; align-items: baseline; gap: 8px;
  margin-bottom: 6px;
}
.fuel-hero-num {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(44px, 9vw, 64px);
  line-height: 1; letter-spacing: -0.02em;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.fuel-hero-unit {
  font-family: var(--mono); font-size: 13px; font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--txt3);
}
.fuel-hero-sub {
  font-size: 13px; color: var(--txt2);
  line-height: 1.4; margin-bottom: 12px;
}
/* Trend-Zeile: Text in normaler Body-Farbe. Nur das Delta (Pfeil + Wert)
   wird farblich markiert — minimal-invasiv, kein Pill-Background-Drama. */
.fuel-hero-trend {
  display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
  font-family: var(--body); font-size: 13px; font-weight: 500;
  letter-spacing: 0;
  color: var(--txt2);
  margin-bottom: 12px;
}
.fhtr-delta {
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.04em;
}
.fhtr-better { color: var(--green); }
.fhtr-worse  { color: var(--red); }
.fhtr-stable { color: var(--txt3); font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; }
.fuel-hero-trend-sub {
  font-weight: 400; letter-spacing: 0.02em; opacity: 0.8;
  text-transform: none;
}
.fuel-hero-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  color: var(--txt3); padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.05);
}

/* Hero-Stat-Row: 4 kompakte Stats unter der Meta-Zeile (km · Liter · Ø €/L · Kosten).
   Auf engen Screens (<360px) wickelt das Grid in 2×2 um damit die Zahlen nicht zerquetscht werden. */
.fuel-hero-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 10px 8px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.05);
}
@media (max-width: 380px) {
  .fuel-hero-stats { grid-template-columns: repeat(2, 1fr); }
}
.fuel-hero-stat {
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
}
.fuel-hero-stat-v {
  font-family: var(--cond); font-weight: 700; font-size: 20px;
  line-height: 1; color: var(--txt);
  letter-spacing: -0.005em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fuel-hero-stat-l {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3);
}

/* Best/Worst-Story-Container: Zeilen für Verbrauch + Preis untereinander.
   Macht aus „Zahlen" eine Erzählung — wann lief's am besten, wann krass. */
.fuel-hero-bestworst {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.05);
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.04em;
}
.fhbw-row {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px;
}
.fhbw-item {
  display: flex; align-items: baseline; gap: 5px;
  min-width: 0;
}
.fhbw-arrow {
  font-family: var(--body); font-weight: 700;
  font-size: 13px;
}
.fhbw-best  { color: var(--green); }
.fhbw-worst { color: var(--red); }
.fhbw-label {
  font-weight: 600;
  color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
  font-size: 10px;
}
.fhbw-val {
  font-weight: 700;
  color: var(--txt);
}
.fhbw-val small {
  font-weight: 500;
  font-size: 9px;
  color: var(--txt3);
  letter-spacing: 0.08em;
  margin-left: 1px;
}
.fhbw-date {
  color: var(--txt3);
  font-size: 10px;
  text-transform: uppercase;
}

/* Generischer Card-Label (Mono-Caps mit Akzent-Farbe) für alle Fuel-Cards */
.fuel-card-label {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}

/* Saison-Card: 2x2-Grid mit km/Ø/Tankungen/Kosten + Trend-Pill */
.fuel-season-card {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 10px;
}
.fuel-season-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 16px 12px;
  margin-bottom: 14px;
}
.fuel-season-stat {
  border-left: 2px solid var(--accent);
  padding-left: 12px;
}
.fuel-season-num {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(20px, 4vw, 24px);
  line-height: 1.1; letter-spacing: -0.01em;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
  margin-bottom: 4px;
}
.fuel-season-lbl {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--txt3);
}
.fuel-season-trend {
  display: inline-flex; align-items: center;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em;
  padding: 6px 12px;
  border-radius: 99px;
  border: 1px solid;
}
.fuel-season-trend.better  { background: rgba(80,180,120,0.10); color: var(--green); border-color: rgba(80,180,120,0.25); }
.fuel-season-trend.worse   { background: rgba(209,72,72,0.10);  color: var(--red);   border-color: rgba(209,72,72,0.25); }
.fuel-season-trend.neutral { background: rgba(255,255,255,0.04); color: var(--txt2);  border-color: rgba(255,255,255,0.08); }
.fuel-season-foot {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  color: var(--txt3);
}

/* Sorten-Verteilung: Stacked-Bar + Liste */
.fuel-types-card {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 14px;
}
.fuel-types-bar {
  display: flex; height: 8px; border-radius: 99px; overflow: hidden;
  background: rgba(255,255,255,0.04);
  margin-bottom: 14px;
}
.fuel-types-seg {
  height: 100%;
  transition: width 0.4s cubic-bezier(0.22, 0.9, 0.24, 1);
}
.fuel-types-list {
  display: flex; flex-direction: column; gap: 8px;
}
.fuel-types-item {
  display: grid; grid-template-columns: auto 1fr auto auto;
  align-items: baseline; gap: 12px;
}
.fuel-types-dot {
  width: 8px; height: 8px; border-radius: 50%;
  align-self: center;
}
.fuel-types-name {
  font-family: var(--cond); font-size: 14px; font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--txt);
}
.fuel-types-pct {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--txt2);
  font-variant-numeric: tabular-nums;
}
.fuel-types-liters {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--txt3);
  font-variant-numeric: tabular-nums;
}

/* Aggregate-Stats: kompakte 4-Spalten-Card unter Hero */
.fuel-agg-card {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 14px 18px;
  margin-bottom: 10px;
}
.fuel-agg-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 480px) {
  .fuel-agg-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
.fuel-agg-cell {
  text-align: left;
  border-left: 2px solid var(--accent);
  padding-left: 10px;
}
.fuel-agg-num {
  font-family: var(--cond); font-weight: 700;
  font-size: 18px; line-height: 1.1;
  color: var(--txt); margin-bottom: 4px;
  letter-spacing: -0.005em;
  font-variant-numeric: tabular-nums;
}
.fuel-agg-lbl {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--txt3);
}

/* Verbrauchs-Chart (Linien-Graph mit Datum-Achse, Ø-Linie, Tap-Tooltips) */
.fuel-chart-card {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 16px 18px 14px;
  margin-bottom: 14px;
}
.fuel-chart-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
  margin-bottom: 12px;
}
.fuel-chart-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt2);
}
.fuel-chart-meta {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--mono); font-size: 11px;
  color: var(--txt2);
  font-variant-numeric: tabular-nums;
}
.fc-meta-item {
  display: inline-flex; align-items: center; gap: 5px;
  letter-spacing: 0.04em;
}
.fc-meta-dot {
  width: 6px; height: 6px; border-radius: 50%;
  display: inline-block;
}
.fc-meta-dot.fc-dot-min { background: var(--green); }
.fc-meta-dot.fc-dot-avg { background: var(--accent); box-shadow: 0 0 4px var(--accent); }
.fc-meta-dot.fc-dot-max { background: var(--red); }

/* Body: Y-Labels links + Plot-Area daneben */
.fuel-chart-body {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 10px;
  align-items: stretch;
}
.fc-y-labels {
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 4px 0;
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); letter-spacing: 0.04em;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.fuel-chart-frame {
  position: relative;
  width: 100%;
  height: 160px;
}
.fuel-chart-svg {
  width: 100%; height: 100%;
  display: block;
  position: absolute; inset: 0;
}
.fc-dots-layer {
  position: absolute; inset: 0;
  pointer-events: none;
}
.fc-dot-html {
  position: absolute;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--surface);
  border: 1.5px solid var(--accent);
  transform: translate(-50%, -50%);
  pointer-events: auto;
  cursor: pointer;
  transition: transform 0.15s, background 0.15s;
}
.fc-dot-html:hover {
  background: var(--accent);
  transform: translate(-50%, -50%) scale(1.4);
}
/* Min/Max Highlight matcht Legende oben */
.fc-dot-html.fc-dot-is-min {
  border-color: var(--green);
  background: var(--green);
  box-shadow: 0 0 8px rgba(55,211,153,0.5);
}
.fc-dot-html.fc-dot-is-max {
  border-color: var(--red);
  background: var(--red);
  box-shadow: 0 0 8px rgba(209,72,72,0.5);
}
.fc-dot-html.fc-dot-is-min:hover,
.fc-dot-html.fc-dot-is-max:hover {
  transform: translate(-50%, -50%) scale(1.4);
}
.fc-avg-line {
  stroke: rgba(61,90,241,0.4);
  stroke-dasharray: 3 4;
}
/* X-Labels unter Chart, ausgerichtet auf Plot-Area */
.fc-x-labels {
  display: flex; justify-content: space-between;
  padding-left: 42px; padding-right: 4px;
  margin-top: 8px;
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); letter-spacing: 0.04em;
}

/* Empty-State des Charts (zu wenig Daten) */
.fuel-chart-empty {
  text-align: center;
  padding: 22px 18px;
  background: transparent;
  border-style: dashed;
  border-color: var(--border);
}
.fuel-chart-empty-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3);
  margin-bottom: 8px;
}
.fuel-chart-empty-text {
  font-family: var(--body);
  font-size: 13px; line-height: 1.5;
  color: var(--txt2);
  max-width: 380px;
  margin: 0 auto 10px;
}
.fuel-chart-empty-hint {
  font-family: var(--mono);
  font-size: 10px; line-height: 1.5;
  color: var(--txt3);
  letter-spacing: 0.04em;
  max-width: 380px;
  margin: 0 auto;
}

/* Liste: Activity-Feed-Stil */
.fuel-list-section { margin-bottom: 24px; }
.fuel-list-header {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 18px 4px 10px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}
.fuel-list-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
}
.fuel-list-count {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); letter-spacing: 0.06em;
}
.fuel-list { display: flex; flex-direction: column; }

.fuel-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 4px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  cursor: pointer;
  transition: background 0.15s;
}
.fuel-row:hover  { background: rgba(255,255,255,0.025); }
.fuel-row:active { background: rgba(255,255,255,0.05); }
.fuel-row:last-child { border-bottom: none; }
.fuel-row-main { flex: 1; min-width: 0; }
.fuel-row-kicker {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 2px;
}
.fuel-row-title {
  font-family: var(--cond); font-weight: 700; font-size: 17px;
  letter-spacing: -0.005em;
  color: var(--txt); margin-bottom: 3px;
}
.fuel-row-sub {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--txt2);
  word-break: break-word;
}
.fuel-row-right {
  display: flex; align-items: center; gap: 10px;
  flex-shrink: 0;
}
.fuel-row-cons-pill {
  display: inline-flex; flex-direction: column; align-items: center;
  background: rgba(61,90,241,0.10);
  border: 1px solid rgba(61,90,241,0.22);
  color: var(--accent);
  padding: 5px 9px; border-radius: 8px;
  font-family: var(--cond); font-weight: 800; font-size: 15px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  min-width: 48px;
}
.fuel-row-cons-pill span {
  font-family: var(--mono); font-weight: 500; font-size: 8px;
  letter-spacing: 0.08em; opacity: 0.75;
  margin-top: 3px; text-transform: uppercase;
}
.fuel-row-cost {
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  color: var(--txt2); white-space: nowrap;
}
.fuel-row-del {
  background: none; border: none;
  color: var(--txt3); cursor: pointer; padding: 4px;
  transition: color 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.fuel-row-del:hover { color: var(--red); }

/* ── LANDING PAGE ───────────────────────────────────────────────────────── */
#pg-landing { background: var(--bg); overflow-x: hidden; }
#pg-dashboard { background: var(--bg); }
#pg-vehicle-detail {
  background: var(--bg);
  height: 100dvh;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
/* Inner-Wrap: alles unter dem App-Header wird auf Lese-Breite zentriert.
   Der Header bleibt edge-zu-edge wie auf dem Dashboard (Linear/Notion-Pattern). */
.vd-content {
  max-width: 880px;
  width: 100%;
  margin: 0 auto;
}

/* Sub-Tab Slide-In Animation (CSS-only, beim Tap auf anderen Sub-Tab-Button).
   Translate + Opacity-Fade — kein Gesten-Konflikt mit Row-Swipes weil rein optisch
   nach dem Render-Switch. Distance 20px = subtil, Apple-Style. */
@keyframes subtab-slide-in-right {
  from { opacity: 0; transform: translate3d(20px, 0, 0); }
  to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
@keyframes subtab-slide-in-left {
  from { opacity: 0; transform: translate3d(-20px, 0, 0); }
  to   { opacity: 1; transform: translate3d(0, 0, 0); }
}
.subtab-anim-from-right { animation: subtab-slide-in-right 0.28s cubic-bezier(0.32, 0.72, 0.16, 1); }
.subtab-anim-from-left  { animation: subtab-slide-in-left  0.28s cubic-bezier(0.32, 0.72, 0.16, 1); }
@media (prefers-reduced-motion: reduce) {
  .subtab-anim-from-right,
  .subtab-anim-from-left { animation: none; }
}

#pg-vehicle-detail .tab-pane,
#pg-vehicle-detail #task-todo-content,
#pg-vehicle-detail #task-done-content {
  overflow: visible;
}
#pg-vehicle-detail .maint-list,
#pg-vehicle-detail .todo-list {
  overflow: visible;
  flex: 0 0 auto;
}

/* Nav */
.l-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: 60px;
  border-bottom: 1px solid var(--border);
  background: rgba(13,13,13,0.90);
  backdrop-filter: blur(12px);
}
.l-nav-container {
  display: flex;
  align-items: center;
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 48px;
  height: 100%;
}
.l-nav-logo {
  font-family: var(--cond); font-weight: 700; font-size: 20px;
  letter-spacing: 0; text-transform: none; font-style: italic;
  display: flex; align-items: center; gap: 4px;
}
.l-nav-logo .accent { color: var(--accent); }
.l-nav-logo-icon {
  height: 32px; width: 32px; object-fit: contain;
  border-radius: 8px; flex-shrink: 0;
}
.l-nav-links { display: flex; gap: 28px; list-style: none; margin-left: 8px; }
.l-nav-links a {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  text-decoration: none; letter-spacing: 0.06em; transition: color 0.2s;
}
.l-nav-links a:hover { color: var(--txt); }
.l-nav-spacer { flex: 1; }
.l-nav-cta {
  font-family: var(--cond); font-weight: 700; font-size: 13px;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--accent); text-decoration: none;
  border: 1px solid rgba(61,90,241,0.4); padding: 8px 16px;
  border-radius: var(--r); cursor: pointer; background: none;
  white-space: nowrap;
  transition: background 0.2s, color 0.2s, border-color 0.2s, box-shadow 0.2s;
}
.l-nav-cta:hover {
  background: var(--accent); color: #fff; border-color: var(--accent);
  box-shadow: 0 6px 18px rgba(61,90,241,0.35);
}
@media (max-width: 640px) {
  .l-nav-container { padding: 0 20px; gap: 12px; }
  .l-nav-links { display: none; }
}

/* ── HERO ── */
.l-hero {
  min-height: 100vh;
  display: flex; justify-content: center; align-items: center;
  padding: 100px 48px 60px;
  position: relative; overflow: hidden; gap: 48px;
}

/* FOUC-Schutz: Hero-Elemente sind anfangs invisible, GSAP animiert rein.
   Klasse .intro-pending wird in landing.js entfernt, bevor GSAP läuft.
   Safety-Fallback: nach 2s automatisch sichtbar (falls JS nicht lädt). */
.l-hero.intro-pending .l-hero-left > *,
.l-hero.intro-pending .l-stage,
.l-hero.intro-pending .l-phone-mockup,
.l-hero.intro-pending .l-phone-glow {
  opacity: 0;
  animation: l-hero-fallback-reveal 0.001s 2s forwards;
}
@keyframes l-hero-fallback-reveal { to { opacity: 1; } }
@media (prefers-reduced-motion: reduce) {
  .l-hero.intro-pending .l-hero-left > *,
  .l-hero.intro-pending .l-stage,
  .l-hero.intro-pending .l-phone-mockup,
  .l-hero.intro-pending .l-phone-glow { opacity: 1; animation: none; }
}
.l-hero-container {
  display: grid; grid-template-columns: 1fr 1fr;
  align-items: center; gap: 48px;
  width: 100%; max-width: 1000px; margin: 0 auto;
  position: relative; z-index: 10;
}
@media (max-width: 760px) {
  .l-hero { padding: 100px 20px 60px; }
  .l-hero-container { grid-template-columns: 1fr; }
}
.l-hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 0.20;
  mask-image: radial-gradient(ellipse 80% 90% at 30% 50%, black 20%, transparent 78%);
}
.l-hero::after {
  content: '';
  position: absolute; top: 5%; left: -20%; width: 60%; height: 90%;
  background: radial-gradient(ellipse, rgba(61,90,241,0.07) 0%, transparent 70%);
  pointer-events: none;
}
.l-hero-left { position: relative; z-index: 2; }
.l-hero-tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent);
  border: 1px solid rgba(61,90,241,0.3); padding: 5px 10px;
  border-radius: var(--r); display: inline-block; margin-bottom: 28px;
}
.l-hero-h1 {
  font-family: var(--cond); font-weight: 800; line-height: 1;
  font-size: clamp(48px, 7vw, 88px);
  letter-spacing: -0.01em; margin-bottom: 24px;
}
.l-hero-h1 .dim { color: var(--txt2); }
.l-hero-h1 .acc { color: var(--accent); }
.l-hero-sub {
  font-size: 15px; color: var(--txt2); line-height: 1.7;
  max-width: 420px; margin-bottom: 36px;
}
.l-hero-sub strong { color: var(--txt); font-weight: 500; }
.l-hero-actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.l-hero-note { font-family: var(--mono); font-size: 10px; color: var(--txt2); letter-spacing: 0.06em; }
.l-hero-trust {
  display: flex; gap: 20px; flex-wrap: wrap;
  margin-top: 28px; padding-top: 24px;
  border-top: 1px solid var(--border);
  max-width: 460px;
}
.l-hero-trust-item {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  letter-spacing: 0.06em; display: inline-flex; align-items: center; gap: 7px;
}
.l-hero-trust-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 8px var(--accent);
}

/* Section intro text */
.l-section-h2 {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(32px, 4.5vw, 56px); line-height: 1.05;
  letter-spacing: -0.01em; margin: 14px 0 18px;
}
.l-section-h2 .acc { color: var(--accent); }
.l-section-intro {
  font-size: 15px; color: var(--txt2); line-height: 1.6;
  max-width: 640px; margin-bottom: 48px;
}

/* How it works */
.l-how {
  padding: 80px 48px;
  max-width: 1100px; margin: 0 auto;
}
@media (max-width: 640px) { .l-how { padding: 60px 20px; } }
.l-how-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px; margin-top: 8px; position: relative;
}
.l-how-step {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r); padding: 28px 24px;
  position: relative; transition: border-color 0.2s, transform 0.2s;
}
.l-how-step:hover { border-color: var(--accent); transform: translateY(-2px); }
.l-how-num {
  font-family: var(--cond); font-weight: 800; font-size: 42px;
  line-height: 1; color: var(--accent); margin-bottom: 14px;
  display: inline-block;
  background: linear-gradient(135deg, var(--accent) 0%, #6b8cff 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.l-how-title {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  margin-bottom: 10px; letter-spacing: -0.01em;
}
.l-how-text { font-size: 13px; color: var(--txt2); line-height: 1.6; }

/* For whom */
.l-who {
  padding: 80px 48px;
  max-width: 1100px; margin: 0 auto;
}
@media (max-width: 640px) { .l-who { padding: 60px 20px; } }
.l-who-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px; margin-top: 8px;
}
.l-who-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r); padding: 24px 22px;
  transition: border-color 0.2s, background 0.2s;
}
.l-who-card:hover { border-color: var(--accent); background: var(--surface2); }
.l-who-icon { font-size: 28px; margin-bottom: 14px; }
.l-who-title {
  font-family: var(--cond); font-size: 20px; font-weight: 700;
  margin-bottom: 8px; letter-spacing: -0.01em;
}
.l-who-text { font-size: 13px; color: var(--txt2); line-height: 1.6; }

/* FAQ */
.l-faq {
  padding: 80px 48px;
  max-width: 800px; margin: 0 auto;
}
@media (max-width: 640px) { .l-faq { padding: 60px 20px; } }
.l-faq-list {
  display: flex; flex-direction: column; gap: 8px; margin-top: 8px;
}
.l-faq-item {
  border: 1px solid var(--border); border-radius: var(--r);
  background: var(--surface); overflow: hidden;
  transition: border-color 0.2s;
}
.l-faq-item[open] { border-color: var(--accent); background: var(--surface2); }
.l-faq-q {
  font-family: var(--cond); font-size: 18px; font-weight: 600;
  padding: 18px 22px; cursor: pointer; list-style: none;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  user-select: none; color: var(--txt);
  letter-spacing: -0.005em;
}
.l-faq-q::-webkit-details-marker { display: none; }
.l-faq-q::after {
  content: '+'; font-family: var(--mono); font-size: 20px; font-weight: 400;
  color: var(--txt2); transition: transform 0.2s, color 0.2s;
  line-height: 1; flex-shrink: 0;
}
.l-faq-item[open] .l-faq-q::after { transform: rotate(45deg); color: var(--accent); }
.l-faq-a {
  padding: 0 22px 20px; font-size: 14px;
  color: var(--txt2); line-height: 1.6;
}

/* CTA */
.l-cta-actions { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.l-cta-h2 .acc { color: var(--accent); }

/* Hero Stage (right side) — Floating UI über atmosphärischem Hintergrund */
.l-hero-right {
  position: relative; z-index: 2;
  display: flex; justify-content: center; align-items: center;
}

.l-stage {
  position: relative;
  width: 100%; max-width: 460px;
  height: 760px;
  margin: 0 auto;
  perspective: 1600px;
  display: flex; align-items: center; justify-content: center;
}

/* Single soft brand-tinted glow behind the phone (kein Bokeh, kein Frame, kein BG-Card) */
.l-phone-glow {
  --bg-hue: 220;
  position: absolute;
  top: 50%; left: 50%;
  width: 700px; height: 700px;
  transform: translate(-50%, -50%);
  background: radial-gradient(
    circle,
    hsla(var(--bg-hue), 90%, 58%, 0.45) 0%,
    hsla(var(--bg-hue), 80%, 48%, 0.22) 22%,
    hsla(var(--bg-hue), 70%, 38%, 0.10) 45%,
    transparent 70%
  );
  filter: blur(50px);
  pointer-events: none;
  transition: --bg-hue 0.8s cubic-bezier(0.22, 0.9, 0.24, 1);
  z-index: 0;
}

/* iPhone 14 Pro Mockup — gerendertes 3D-PNG, Content via Matrix3D im Screen */
.l-phone-mockup {
  position: relative;
  width: 420px;
  height: 725px;            /* aspect 920:1588 = 0.5793 */
  margin: 0 auto;
  filter: drop-shadow(0 30px 40px rgba(0,0,0,0.4));
  animation: l-phone-mockup-float 6s ease-in-out infinite;
}

.l-phone-mockup-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  user-select: none;
  pointer-events: none;
  display: block;
}

/* Screen-Content: 320x952 (Mittelweg — Aspect 2.97, Inhalt ~10% größer als bei 350) */
.l-phone-screen {
  position: absolute;
  top: 0; left: 0;
  /* Box ist 420 wide (full container) → Content rechts vom Matrix-Bereich (350)
     wird extrapoliert hinter den Bezel verschoben. Höhe bleibt explizit 1040. */
  width: 420px; height: 1040px;
  transform-origin: 0 0;
  z-index: 1;
  transform: matrix3d(
    0.5871807143, -0.1108395345, 0, -0.000014172047,
    0.0964257085,  0.5888612509, 0, -0.000005232015,
    0,             0,            1,  0,
    44.328261,     73.317391,    0,  1
  );
  background: var(--bg);
  border-radius: 50px;
  overflow: hidden;
  display: flex; flex-direction: column;
}

@keyframes l-phone-mockup-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* Reduced-Motion respektieren */
@media (prefers-reduced-motion: reduce) {
  .l-phone-mockup { animation: none; }
}

/* Floating glass cards — premium [DEAD CODE, kept for safety] */
/* Stats card — top right */
.l-stage-stats .l-green { color: var(--green); }

/* Nächste Wartung — middle left */
.l-stage-next-bar-fill.l-bar-soon    { background: var(--amber); }
.l-stage-next-bar-fill.l-bar-overdue { background: var(--red); }

/* Open Task — bottom right */
/* Floating idle animations — different tilts/phases for organic feel */
/* Responsive: kleiner skalieren auf schmalen Tablets */
@media (max-width: 1024px) {
  .l-stage { max-width: 380px; }
  .l-phone-mockup { width: 380px; height: 656px; }
  .l-phone-screen {
    top: 0; left: 0;
    width: 380px; height: 1040px;
    border-radius: 50px;
    transform: matrix3d(
      0.5312587415, -0.1002833884, 0, -0.000014172047,
      0.0872423077,  0.5327792270, 0, -0.000005232015,
      0,             0,            1,  0,
      40.106522,     66.334783,    0,  1
    );
  }
}
@media (max-width: 760px) {
  /* Mobile-Reihenfolge: Tag → Phone → Headline → rest. Tightere Gaps zwischen Phone & Text. */
  .l-hero-container {
    display: flex; flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  .l-hero-left { display: contents; }
  .l-hero-tag     { order: 1; margin-bottom: 0; }
  .l-hero-right   { order: 2; align-self: center; display: flex; justify-content: center; }
  .l-hero-h1      { order: 3; margin-bottom: 0; margin-top: -50px; position: relative; z-index: 3; }
  .l-rot-meta     { order: 4; }
  .l-hero-sub     { order: 5; margin-top: 8px; }
  .l-hero-actions { order: 6; }
  .l-hero-trust   { order: 7; }
  .l-stage {
    max-width: 100%;
    height: 600px;
    overflow: hidden;
  }
  .l-phone-mockup { width: 320px; height: 552px; }
  .l-phone-screen {
    top: 0; left: 0;
    width: 420px; height: 1040px;
    border-radius: 50px;
    transform: matrix3d(
      0.4473757823, -0.0844491691, 0, -0.000014172047,
      0.0734672065,  0.4486561912, 0, -0.000005232015,
      0,             0,            1,  0,
      33.773913,     55.860870,    0,  1
    );
  }
  .l-phone-glow {
    width: 640px; height: 640px;
    top: 60%; left: 50%;
    transform: translate(-50%, -50%);
    /* Größerer Glow der unten in den Headline-Bereich bleedet — verbindet Phone & Text visuell */
    background: radial-gradient(
      circle,
      hsla(var(--bg-hue), 90%, 58%, 0.50) 0%,
      hsla(var(--bg-hue), 80%, 48%, 0.25) 18%,
      hsla(var(--bg-hue), 70%, 38%, 0.10) 38%,
      transparent 60%
    );
  }
  .l-stage { overflow: visible; }
  /* l-hero darf kein overflow:hidden mehr haben damit Glow in Headline-Bereich reicht */
  .l-hero { overflow: visible; }
}

/* ── Scroll Reveal — subtiles Fade-in-up beim Scrollen ── */
[data-reveal] {
  opacity: 0;
  transform: translateY(32px);
  transition:
    opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}
[data-reveal].is-revealed {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal] {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* App header — Header-Bar wie auf der Vehicle-Detail-Seite */
.l-app-header {
  display: flex; align-items: center; gap: 10px;
  padding: 50px 18px 14px; flex-shrink: 0;
  background: var(--bg);
}
.l-app-back {
  width: 32px; height: 32px; display: inline-flex;
  align-items: center; justify-content: center;
  color: var(--txt2);
}
.l-app-hdr-spacer { flex: 1; }
.l-app-hdr-icon {
  width: 30px; height: 30px; display: inline-flex;
  align-items: center; justify-content: center;
  color: var(--txt2);
}
.l-app-hdr-sync {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px rgba(74,222,128,0.6);
  margin: 0 2px;
}

/* Tabs */
.l-app-tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--border);
  padding: 0 10px; flex-shrink: 0;
}
.l-app-tab {
  flex: 1; text-align: center; padding: 18px 10px;
  font-family: var(--cond); font-size: 18px; font-weight: 600;
  color: var(--txt3); letter-spacing: 0.04em;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  text-transform: uppercase;
}
.l-app-tab.active { color: var(--txt); border-bottom-color: var(--accent); }

/* Sub-bar */
.l-app-subbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 14px; border-bottom: 1px solid var(--border);
  background: var(--surface); flex-shrink: 0;
}
.l-app-sort {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  letter-spacing: 0.04em;
}
.l-app-toggle {
  display: inline-flex; background: var(--surface2);
  border: 1px solid var(--border2); border-radius: 16px;
  padding: 2px; gap: 2px;
}
.l-app-toggle-btn {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 13px; color: var(--txt3);
  display: inline-flex; align-items: center; gap: 4px;
}
.l-app-toggle-btn.active { background: var(--accent); color: #fff; }
.l-app-badge {
  background: rgba(255,255,255,0.2); color: inherit;
  font-size: 8px; padding: 0 5px; border-radius: 8px; min-width: 14px;
  text-align: center;
}
.l-app-toggle-btn:not(.active) .l-app-badge { background: var(--border2); color: var(--txt2); }

/* Body / list */
.l-app-body {
  flex: 1; overflow: hidden; padding: 0;
  background: var(--bg); position: relative;
}
.l-app-group-head {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--txt2);
  padding: 10px 16px 6px; background: var(--bg);
}
.l-app-group-head.sub { padding-top: 14px; }
.l-app-list { display: flex; flex-direction: column; }

/* Swipe wrapper (like real app) */
.l-app-list .swipe-wrapper {
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--border);
}
.l-app-list .swipe-bg-done, .l-app-list .swipe-bg-del {
  position: absolute; inset: 0; display: flex; align-items: center;
  font-family: var(--cond); font-weight: 700; font-size: 13px;
  letter-spacing: 0.04em; color: #fff; padding: 0 18px;
}
.l-app-list .swipe-bg-done {
  background: #3db06a; justify-content: flex-start;
}
.l-app-list .swipe-bg-del {
  background: #c44; justify-content: flex-end;
}
.l-app-list .swipe-content {
  position: relative; background: var(--bg);
  will-change: transform;
}

.l-el-entry {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px; background: var(--bg);
  border-left: 3px solid transparent;
}
.l-el-entry[data-prio="high"]   { border-left-color: var(--red, #e25555); }
.l-el-entry[data-prio="medium"] { border-left-color: var(--orange, var(--amber)); }
.l-el-entry[data-prio="low"]    { border-left-color: var(--yellow, #d4b843); }

.l-todo-check {
  width: 20px; height: 20px; border-radius: 50%;
  border: 1.8px solid var(--border2); background: none;
  flex-shrink: 0; position: relative;
  transition: border-color 0.2s, background 0.2s;
  cursor: pointer;
}
.l-todo-check.done {
  background: var(--green); border-color: var(--green);
}
.l-todo-check.done::after {
  content: ''; position: absolute; left: 5.5px; top: 2.5px;
  width: 5px; height: 9px; border: solid #0d0d0d;
  border-width: 0 2px 2px 0; transform: rotate(45deg);
}
.l-el-body { flex: 1; min-width: 0; }
.l-el-title { font-size: 13px; font-weight: 600; color: var(--txt); line-height: 1.3; }
.l-el-meta { font-family: var(--mono); font-size: 10px; color: var(--txt2); margin-top: 2px; }
.l-el-grip { color: var(--txt3); opacity: 0.5; display: flex; align-items: center; }

.l-el-entry.done .l-el-title { text-decoration: line-through; color: var(--txt2); }

/* FAB */
.l-app-fab {
  position: absolute; bottom: 26px; right: 20px; z-index: 5;
  width: 60px; height: 60px; border-radius: 50%;
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; line-height: 1;
  box-shadow: 0 6px 20px rgba(61,90,241,0.5);
}

/* Mockup-Hero (synced mit Wort-Rotation) */
.l-mock-hero {
  --bg-hue: 220;
  position: relative;
  height: 200px;
  overflow: hidden;
  background: var(--surface2);
  display: flex; align-items: center; justify-content: center;
}
.l-mock-hero-pdf,
.l-mock-hero-gallery {
  position: absolute; bottom: 12px; z-index: 4;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--txt); padding: 6px 12px;
  border-radius: 8px;
  background: rgba(0,0,0,0.5);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.l-mock-hero-pdf      { right: 10px; }
.l-mock-hero-gallery  { left: 10px; }
.l-mock-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 30% 30%, hsla(var(--bg-hue), 60%, 32%, 0.35) 0%, transparent 60%),
    radial-gradient(circle at 70% 70%, hsla(var(--bg-hue), 50%, 18%, 0.55) 0%, transparent 70%),
    linear-gradient(135deg, rgba(255,255,255,0.04), transparent 60%);
  transition: --bg-hue 0.8s cubic-bezier(0.22, 0.9, 0.24, 1);
}
.l-mock-hero-content {
  position: relative;
  z-index: 4;
  text-align: center;
  transition: opacity 0.22s, transform 0.22s;
}
.l-mock-hero.swapping .l-mock-hero-content {
  opacity: 0; transform: translateY(4px);
}
.l-mock-hero-model {
  font-family: var(--cond);
  font-size: 50px; font-weight: 800;
  color: var(--txt);
  letter-spacing: 0.02em; line-height: 1.05;
  margin-bottom: 4px;
}
.l-mock-hero-meta {
  font-family: var(--mono);
  font-size: 12px; color: var(--txt2);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.l-mock-hero-fade {
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 28px;
  background: linear-gradient(180deg, transparent, rgba(13,13,13,0.55) 70%, var(--bg) 100%);
  pointer-events: none;
}

/* Mockup Name-Block (Vehicle-Name + Meta-Line wie in der App) */
.l-mock-name {
  padding: 14px 18px 8px;
}
.l-mock-name-title {
  font-family: var(--cond); font-weight: 800;
  font-size: 26px; line-height: 1.05; color: var(--txt);
  letter-spacing: 0.01em;
}
.l-mock-name-sub {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.04em; color: var(--txt2);
  margin-top: 6px; display: flex; gap: 5px; flex-wrap: wrap;
  align-items: center;
}
.l-mock-name-d { color: var(--txt3); opacity: 0.5; }

/* Toggle-Row: Fahrzeugdaten (collapsed) + Edit-Icon */
.l-mock-toggle-row {
  display: flex; align-items: center; gap: 10px;
  padding: 0 18px 14px;
}
.l-mock-toggle {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: space-between;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--txt2); padding: 10px 14px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px;
}
.l-mock-toggle-edit {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--txt2);
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px;
}

/* Mockup Stats-Card (wie auf der Vehicle-Detail-Seite — 2x2 + full-width Wartung) */
.l-mock-stats {
  margin: 0 18px 14px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 16px; overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr;
}
.l-mock-stat {
  padding: 14px 16px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.l-mock-stat:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.05); }
.l-mock-stat-label {
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--txt3); margin-bottom: 6px;
  display: inline-flex; align-items: center; gap: 4px;
}
.l-mock-stat-label svg { opacity: 0.85; }
.l-mock-stat-val {
  font-family: var(--cond); font-size: 28px; font-weight: 800;
  line-height: 1; color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.l-mock-stats .l-green { color: var(--green); }
.l-stat-soon { color: var(--amber) !important; }
.l-stat-overdue { color: var(--red) !important; }

/* Stat full-width — Nächste Wartung */
.l-mock-stat-full {
  grid-column: 1 / -1;
  padding: 14px 16px 16px;
  border-top: 1px solid rgba(255,255,255,0.05);
}
.l-mock-stat-full .l-mock-stat-label { margin-bottom: 5px; }
.l-mock-next-row {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 10px; margin-bottom: 10px;
}
.l-mock-next-title {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  color: var(--txt); line-height: 1.1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  flex: 1; min-width: 0;
}
.l-mock-next-primary {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  color: var(--txt); flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.l-mock-next-bar {
  height: 5px; border-radius: 2px;
  background: rgba(255,255,255,0.08); overflow: hidden;
}
.l-mock-next-bar-fill {
  height: 100%; background: var(--accent);
  transition: width 0.4s cubic-bezier(0.32,0.72,0,1);
}
.l-mock-next-bar-fill.l-bar-soon    { background: var(--amber); }
.l-mock-next-bar-fill.l-bar-overdue { background: var(--red); }

/* Sub-tab bar: Sort + To-Do/Erledigt Toggle */
.l-mock-subbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.l-mock-subbar-sort {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  letter-spacing: 0.06em; color: var(--txt2);
}
.l-mock-subbar-toggle {
  display: inline-flex; gap: 3px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 20px; padding: 3px;
}
.l-mock-subbar-btn {
  font-family: var(--mono); font-size: 13px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 8px 14px; border-radius: 16px; color: var(--txt3);
  display: inline-flex; align-items: center; gap: 4px;
  background: transparent; border: 0;
}
.l-mock-subbar-btn.active {
  background: var(--accent); color: #fff;
}
.l-mock-subbar-badge {
  font-size: 12px; padding: 1px 7px;
  border-radius: 7px; background: rgba(255,255,255,0.22);
  color: inherit;
}
.l-mock-subbar-btn:not(.active) .l-mock-subbar-badge {
  background: var(--border2); color: var(--txt2);
}

/* Task-List (1-2 Beispieleinträge wie in der App) */
.l-mock-tasklist {
  display: flex; flex-direction: column;
  flex: 1; overflow: hidden;
}
.l-mock-task {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 18px;
  border-bottom: 1px solid var(--border);
  border-left: 3px solid transparent;
}
.l-mock-task[data-prio="high"]   { border-left-color: var(--red, #e25555); }
.l-mock-task[data-prio="medium"] { border-left-color: var(--orange, var(--amber)); }
.l-mock-task[data-prio="low"]    { border-left-color: var(--yellow, #d4b843); }
.l-mock-task-check {
  width: 26px; height: 26px; border-radius: 50%;
  border: 1.6px solid var(--border2); background: none;
  flex-shrink: 0;
}
.l-mock-task-body { flex: 1; min-width: 0; }
.l-mock-task-title {
  font-size: 18px; font-weight: 600; color: var(--txt);
  line-height: 1.25;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.l-mock-task-meta {
  font-family: var(--mono); font-size: 13px;
  color: var(--txt2); margin-top: 4px;
}
.l-mock-task.l-task-empty { display: none; }

/* Mockup-Texte: Fade-Bloom (Scale + Blur). Mockup hat Single-Element OUT+IN sequentiell,
   daher Durations halbiert damit Total-Cycle ~600ms = Headline-Cycle matcht. */
#l-stage .l-mock-hero-model,
#l-stage .l-mock-hero-meta,
#l-stage .l-mock-name-title,
#l-stage .l-mock-name-sub,
#l-stage .l-mock-tuev,
#l-stage .l-mock-next-title,
#l-stage .l-mock-next-primary,
#l-stage .l-mock-task1-title,
#l-stage .l-mock-task1-meta,
#l-stage .l-mock-task2-title {
  transition:
    opacity 0.3s ease,
    transform 0.3s cubic-bezier(.22, .9, .24, 1),
    filter 0.25s;
  transform-origin: center;
}
#l-stage.swapping .l-mock-hero-model,
#l-stage.swapping .l-mock-hero-meta,
#l-stage.swapping .l-mock-name-title,
#l-stage.swapping .l-mock-name-sub,
#l-stage.swapping .l-mock-tuev,
#l-stage.swapping .l-mock-next-title,
#l-stage.swapping .l-mock-next-primary,
#l-stage.swapping .l-mock-task1-title,
#l-stage.swapping .l-mock-task1-meta,
#l-stage.swapping .l-mock-task2-title {
  opacity: 0;
  transform: scale(0.94);
  filter: blur(5px);
}

/* Glow-Hue smooth animieren via @property — animatable CSS variable */
@property --bg-hue {
  syntax: '<number>';
  inherits: true;
  initial-value: 220;
}

/* Ripple effect on tap (legacy, used by todos done-anim eventuell) */
.l-tap-ripple {
  position: absolute; width: 40px; height: 40px;
  border-radius: 50%; background: rgba(74,222,128,0.5);
  transform: translate(-50%,-50%) scale(0);
  pointer-events: none; z-index: 29;
}

@media (max-width: 760px) { .l-phone { transform: scale(0.9); transform-origin: top center; } }

/* ── PROBLEM ── */
.l-problem {
  padding: 80px 48px;
  border-top: 1px solid var(--border);
  max-width: 1100px; margin: 0 auto;
}
@media (max-width: 640px) { .l-problem { padding: 60px 20px; } }
.l-problem-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px; margin-top: 40px;
}
.l-problem-item { }
.l-problem-num {
  font-family: var(--mono); font-size: 32px; font-weight: 500;
  color: var(--border2); line-height: 1; margin-bottom: 12px;
}
.l-problem-title {
  font-family: var(--cond); font-size: 20px; font-weight: 700;
  margin-bottom: 8px;
}
.l-problem-text { font-size: 13px; color: var(--txt2); line-height: 1.6; }

/* ── FEATURES ── */
.l-features {
  padding: 96px 48px 80px;
  max-width: 1100px; margin: 0 auto;
}
@media (max-width: 640px) { .l-features { padding: 64px 20px 60px; } }
.l-feat-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  border: 1px solid var(--border); border-radius: var(--r);
  overflow: hidden; background: var(--border); gap: 1px;
  margin-top: 40px;
}
.l-feat-card {
  background: var(--surface); padding: 28px 24px;
}
.l-feat-icon { font-size: 22px; margin-bottom: 14px; display: block; }
.l-feat-title {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  margin-bottom: 8px;
}
.l-feat-text { font-size: 12px; color: var(--txt2); line-height: 1.6; }
.l-feat-text strong { color: var(--txt); font-weight: 500; }

/* ── MODELS ── */
.l-models-section {
  border-top: 1px solid var(--border);
  padding: 80px 48px;
  max-width: 1100px; margin: 0 auto;
}
@media (max-width: 640px) { .l-models-section { padding: 60px 20px; } }
.l-models-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 8px; margin-top: 40px;
}
.l-model-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r); padding: 16px 18px; cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
}
.l-model-card:hover { border-color: var(--accent); background: var(--surface2); }
.l-model-brand { font-family: var(--mono); font-size: 9px; color: var(--txt2); text-transform: uppercase; letter-spacing: 0.08em; }
.l-model-name { font-family: var(--cond); font-size: 20px; font-weight: 700; margin: 2px 0; }
.l-model-years { font-family: var(--mono); font-size: 10px; color: var(--txt2); }

/* ── HERO: rotating word (amplified) ── */
.l-rotate-wrap {
  display: inline-flex;
  align-items: baseline;
  position: relative;
  color: var(--accent);
}
.l-rotate-wrap::before {
  content: '';
  position: absolute;
  left: -8px; right: -8px;
  top: 14%; bottom: 6%;
  background: radial-gradient(ellipse at center, rgba(61,90,241,0.35) 0%, rgba(61,90,241,0) 70%);
  filter: blur(18px);
  z-index: -1;
  pointer-events: none;
  animation: rotGlow 3s ease-in-out infinite;
}
@keyframes rotGlow {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}
.l-rotate {
  display: inline-block;
  position: relative;
  min-width: 2ch;
  vertical-align: baseline;
  height: 1em;
}
.l-rot-word {
  display: inline-block;
  position: absolute;
  left: 0; top: 0;
  opacity: 0;
  transform: translateY(18px) skewY(6deg);
  filter: blur(6px);
  transition: opacity 0.55s ease, transform 0.6s cubic-bezier(.22,.9,.24,1), filter 0.45s;
  white-space: nowrap;
  color: var(--accent);
  text-shadow: 0 0 32px rgba(61,90,241,0.5);
  will-change: transform, opacity, filter;
}
.l-rot-word.active {
  opacity: 1;
  transform: translateY(0) skewY(0);
  filter: blur(0);
  position: relative;
}
.l-rot-word.leaving {
  opacity: 0;
  transform: translateY(-18px) skewY(-6deg);
  filter: blur(6px);
}
.l-rot-dot {
  color: var(--accent);
  text-shadow: 0 0 32px rgba(61,90,241,0.5);
}

/* Meta label that changes with the rotating word */
.l-rot-meta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  margin: 16px 0 28px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 100px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--txt2);
  transition: opacity 0.25s, transform 0.25s;
}
.l-rot-meta.swapping {
  opacity: 0;
  transform: translateY(-4px);
}
.l-rot-meta-brand { color: var(--txt); font-weight: 500; }
.l-rot-meta-sep   { opacity: 0.4; }
.l-rot-meta-years { color: var(--accent); }

/* ── MODELS MARQUEE ── */
#l-models {
  padding: 80px 0 72px;
  overflow: hidden;
  position: relative;
}
@media (max-width: 640px) { #l-models { padding: 60px 0 54px; } }
.l-models-wrap {
  max-width: 900px; margin: 0 auto;
  padding: 0 48px 44px;
  text-align: center;
}
@media (max-width: 640px) { .l-models-wrap { padding: 0 20px 32px; } }
.l-section-label.centered,
.l-section-h2.centered,
.l-section-intro.centered { text-align: center; }
.l-section-intro.centered { margin-left: auto; margin-right: auto; }

.l-marquee {
  position: relative;
  width: 100%;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  padding: 8px 0;
}
.l-marquee-track {
  display: inline-flex;
  gap: 14px;
  white-space: nowrap;
  will-change: transform;
  animation: marqLeft 48s linear infinite;
}
.l-marq-b { animation: marqRight 54s linear infinite; }
.l-marq-c { animation: marqLeft 60s linear infinite; }
.l-marquee:hover .l-marquee-track { animation-play-state: paused; }

@keyframes marqLeft {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes marqRight {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}

.l-mm-plate {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  font-family: var(--cond);
  flex-shrink: 0;
  transition: all 0.25s;
  position: relative;
  overflow: hidden;
}
.l-mm-plate::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--accent);
  transform: scaleY(0);
  transition: transform 0.25s;
  transform-origin: center;
}
.l-mm-plate:hover {
  border-color: var(--accent);
  background: var(--surface2);
  transform: translateY(-2px);
  cursor: default;
}
.l-mm-plate:hover::before { transform: scaleY(1); }

.l-mm-plate .brand {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--txt2);
  font-weight: 500;
}
.l-mm-plate .model {
  font-family: var(--cond);
  font-weight: 700;
  font-size: 20px;
  color: var(--txt);
  letter-spacing: -0.01em;
}
.l-mm-plate .years {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--accent);
  letter-spacing: 0.06em;
  padding-left: 10px;
  border-left: 1px solid var(--border2);
}

.l-models-foot {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--txt2);
  letter-spacing: 0.06em;
  text-align: center;
  margin: 0;
}
.l-models-foot-accent { color: var(--accent); }

/* ── PROBLEM: asymmetric quote wall ── */
.l-prob-wall {
  margin-top: 48px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
@media (max-width: 760px) { .l-prob-wall { grid-template-columns: 1fr; } }
.l-prob-quote {
  position: relative;
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: var(--r);
  padding: 26px 28px 22px;
  overflow: hidden;
  transition: border-color 0.25s, transform 0.25s;
}
.l-prob-quote:hover { border-color: var(--accent); transform: translateY(-2px); }
.l-prob-mark {
  position: absolute;
  top: -18px; left: 14px;
  font-family: var(--cond);
  font-style: italic;
  font-weight: 700;
  font-size: 140px;
  color: var(--accent);
  opacity: 0.18;
  line-height: 1;
  pointer-events: none;
}
.l-prob-q-text {
  font-family: var(--cond);
  font-weight: 700;
  font-size: 24px;
  line-height: 1.2;
  color: var(--txt);
  position: relative;
  margin-bottom: 14px;
}
.l-prob-q-text em {
  color: var(--accent);
  font-style: normal;
}
.l-prob-q-meta {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--txt2);
  text-transform: uppercase;
}

/* ── FEATURES: alternating rows ── */
.l-feat-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  padding: 80px 0;
  border-top: 1px dashed var(--border);
}
.l-feat-row:first-of-type { border-top: none; padding-top: 56px; }
.l-feat-row.reverse .l-feat-txt { order: 2; }
.l-feat-row.reverse .l-feat-visual { order: 1; }
.l-feat-row.highlight .l-feat-visual { position: relative; }
.l-feat-row.highlight .l-feat-visual::before {
  content: '';
  position: absolute; inset: -40px;
  background: radial-gradient(ellipse, rgba(61,90,241,0.18) 0%, transparent 65%);
  pointer-events: none; z-index: 0;
}
@media (max-width: 860px) {
  .l-feat-row { grid-template-columns: 1fr; gap: 28px; padding: 48px 0; }
  .l-feat-row.reverse .l-feat-txt { order: 1; }
  .l-feat-row.reverse .l-feat-visual { order: 2; }
}
.l-feat-kicker {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 14px;
}
.l-feat-h3 {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(26px, 3.2vw, 40px);
  line-height: 1.05; letter-spacing: -0.01em;
  margin-bottom: 16px;
}
.l-feat-p { font-size: 14px; color: var(--txt2); line-height: 1.7; margin-bottom: 18px; }
.l-feat-p em { color: var(--txt); font-style: normal; font-weight: 500; }
.l-feat-ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.l-feat-ul li {
  font-size: 13px; color: var(--txt2);
  padding-left: 20px; position: relative;
  font-family: var(--mono);
}
.l-feat-ul li::before {
  content: '→'; position: absolute; left: 0; top: 0;
  color: var(--accent); font-weight: 600;
}
.l-feat-ul li em { color: var(--txt); font-style: normal; font-weight: 500; }

.l-feat-visual { position: relative; z-index: 1; }
.mkp {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: calc(var(--r) * 1.5);
  padding: 22px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3), 0 0 0 1px rgba(255,255,255,0.02) inset;
  position: relative;
}

/* Service mockup */
.mkp-svc-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}
.mkp-svc-clock-label {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
  display: flex; align-items: center; gap: 6px;
}
.mkp-svc-clock-label::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 6px var(--accent);
  animation: pulseDot 1.2s ease-in-out infinite;
}
@keyframes pulseDot {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.25; }
}
.mkp-svc-clock {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  color: var(--txt); letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
}

.mkp-service .mkp-row {
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
  position: relative;
  transition: background 0.3s;
}
.mkp-service .mkp-row:last-child { border-bottom: none; }
.mkp-service .mkp-row.resetting {
  background: rgba(61,90,241,0.07);
}
.mkp-svc-reset-flash {
  position: absolute;
  top: 50%; right: 0;
  transform: translateY(-50%) translateX(12px);
  opacity: 0;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.14em;
  color: var(--accent);
  background: rgba(61,90,241,0.12);
  border: 1px solid rgba(61,90,241,0.4);
  padding: 5px 10px; border-radius: 4px;
  pointer-events: none;
  transition: opacity 0.25s, transform 0.3s;
}
.mkp-svc-reset-flash span {
  color: var(--accent);
  display: inline-block;
  margin-right: 4px;
  animation: pulseDot 0.6s ease-in-out infinite;
}
.mkp-service .mkp-row.resetting .mkp-svc-reset-flash {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}
.mkp-svc-label { font-family: var(--cond); font-weight: 700; font-size: 15px; margin-bottom: 2px; }
.mkp-svc-sub { font-family: var(--mono); font-size: 10px; color: var(--txt2); margin-bottom: 8px; }
.mkp-svc-bar {
  height: 5px; border-radius: 3px;
  background: var(--border); overflow: hidden; margin-bottom: 6px;
}
.mkp-svc-fill {
  height: 100%; background: linear-gradient(90deg, var(--accent), #6b84ff);
  border-radius: 3px;
  transition: width 0.3s linear, background 0.4s;
}
.mkp-svc-fill.warn { background: linear-gradient(90deg, var(--amber), var(--amber)); }
.mkp-svc-fill.overdue { background: linear-gradient(90deg, var(--red), #ff6b6b); animation: overduePulse 0.9s ease-in-out infinite; }
.mkp-svc-fill.resetting { transition: width 0.6s cubic-bezier(.4,0,.2,1); }
@keyframes overduePulse {
  0%, 100% { box-shadow: 0 0 0 rgba(255,78,78,0); }
  50%      { box-shadow: 0 0 8px rgba(255,78,78,0.7); }
}
.mkp-dot.overdue { background: var(--red); box-shadow: 0 0 6px var(--red); }
.mkp-svc-foot {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  display: inline-flex; align-items: center; gap: 6px;
}
.mkp-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); box-shadow: 0 0 6px var(--green); }
.mkp-dot.warn { background: var(--amber); box-shadow: 0 0 6px var(--amber); }

/* Todo mockup */
.mkp-todo-head {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 10px;
}
.mkp-todo-item {
  display: flex; gap: 12px; align-items: center;
  padding: 12px 14px; background: var(--surface2);
  border: 1px solid var(--border); border-radius: var(--r);
  margin-bottom: 8px; position: relative; overflow: hidden;
  border-left: 3px solid var(--border2);
}
.mkp-todo-item.hi { border-left-color: var(--red); }
.mkp-todo-item.md { border-left-color: var(--amber); }
.mkp-todo-item.lo { border-left-color: var(--green); }
.mkp-check {
  width: 18px; height: 18px; border-radius: 50%;
  border: 1.5px solid var(--border2); flex-shrink: 0;
}
.mkp-todo-t { font-family: var(--cond); font-weight: 600; font-size: 14px; }
.mkp-todo-m { font-family: var(--mono); font-size: 10px; color: var(--txt2); margin-top: 2px; }
.mkp-todo-item.swipe-demo .mkp-todo-front {
  display: flex; gap: 12px; align-items: center;
  background: var(--surface2);
  padding: 12px 14px; margin: -12px -14px;
  transform: translateX(-32%);
  transition: transform 1.6s ease-in-out;
  animation: swipeDemo 4s ease-in-out infinite;
}
.mkp-todo-item.swipe-demo .mkp-swipe-bg {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(55,211,153,0.25));
  display: flex; align-items: center; justify-content: flex-end;
  padding-right: 16px;
  font-family: var(--mono); font-size: 11px; color: var(--green);
  letter-spacing: 0.1em;
}
@keyframes swipeDemo {
  0%, 15% { transform: translateX(0); }
  40%, 60% { transform: translateX(-32%); }
  85%, 100% { transform: translateX(0); }
}

/* Repair log mockup */
.mkp-log-entry {
  padding: 14px 0; border-bottom: 1px solid var(--border);
  position: relative; padding-left: 22px;
}
.mkp-log-entry::before {
  content: ''; position: absolute; left: 4px; top: 22px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 0 3px rgba(61,90,241,0.2);
}
.mkp-log-entry::after {
  content: ''; position: absolute; left: 6.5px; top: 28px;
  width: 1px; bottom: -14px; background: var(--border);
}
.mkp-log-entry:last-child { border-bottom: none; }
.mkp-log-entry:last-child::after { display: none; }
.mkp-log-date { font-family: var(--mono); font-size: 9px; color: var(--txt2); letter-spacing: 0.08em; text-transform: uppercase; }
.mkp-log-title { font-family: var(--cond); font-weight: 700; font-size: 15px; margin: 3px 0 3px; }
.mkp-log-parts { font-family: var(--mono); font-size: 10px; color: var(--txt2); }
.mkp-log-pics { display: flex; gap: 4px; margin-top: 8px; }
.mkp-log-pics span {
  width: 32px; height: 32px; border-radius: 4px;
  background: linear-gradient(135deg, var(--border2) 25%, var(--surface2) 50%, var(--border2) 75%);
  background-size: 200% 200%;
  border: 1px solid var(--border);
}
.mkp-log-pics span:nth-child(2) { background-position: 100% 100%; }
.mkp-log-pics span:nth-child(3) { background-position: 50% 50%; }

/* PDF mockup */
.mkp-pdf {
  background: #f6f3ed;
  color: #1a1a1a;
  padding: 24px 22px 18px;
  transform: perspective(1000px) rotateY(-6deg) rotateX(2deg);
  transition: transform 0.6s;
}
.mkp-pdf:hover { transform: perspective(1000px) rotateY(0) rotateX(0); }
.mkp-pdf::before {
  content: ''; position: absolute;
  top: 12px; right: 0; width: 24px; height: calc(100% - 24px);
  background: linear-gradient(90deg, rgba(0,0,0,0.08), transparent);
  pointer-events: none;
}
.mkp-pdf-corner {
  position: absolute; top: 14px; right: 14px;
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.1em; color: var(--red);
  border: 1px solid var(--red); padding: 2px 6px; border-radius: 3px;
}
.mkp-pdf-logo {
  font-family: var(--cond); font-weight: 800; font-size: 14px;
  color: #1a1a1a; letter-spacing: -0.01em;
}
.mkp-pdf-logo span { color: var(--red); }
.mkp-pdf-title {
  font-family: var(--cond); font-weight: 700; font-size: 20px;
  margin: 10px 0 3px;
}
.mkp-pdf-sub { font-family: var(--mono); font-size: 9px; color: #666; letter-spacing: 0.04em; }
.mkp-pdf-head { border-bottom: 1.5px solid #1a1a1a; padding-bottom: 12px; margin-bottom: 14px; }
.mkp-pdf-section { margin-bottom: 14px; }
.mkp-pdf-h {
  font-family: var(--cond); font-weight: 700; font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--red); margin-bottom: 6px;
  border-left: 2px solid var(--red); padding-left: 6px;
}
.mkp-pdf-line {
  height: 3px; background: #1a1a1a; opacity: 0.18;
  border-radius: 2px; margin-bottom: 5px; width: 100%;
}
.mkp-pdf-line.w90 { width: 90%; }
.mkp-pdf-line.w85 { width: 85%; }
.mkp-pdf-line.w80 { width: 80%; }
.mkp-pdf-line.w70 { width: 70%; }
.mkp-pdf-line.w60 { width: 60%; }
.mkp-pdf-line.w50 { width: 50%; }

/* Galerie mockup (Mosaic) */
.mkp-gal { padding: 18px 18px 20px; }
.mkp-gal-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-bottom: 14px;
  padding-bottom: 12px; border-bottom: 1px solid var(--border);
}
.mkp-gal-tabs {
  display: inline-flex; gap: 4px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px; padding: 3px;
}
.mkp-gal-tabs span {
  font-family: var(--cond); font-weight: 600; font-size: 11px;
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 6px;
  color: var(--txt2); transition: all 0.2s;
}
.mkp-gal-tabs span.active {
  background: var(--surface); color: var(--txt);
  box-shadow: 0 1px 4px rgba(0,0,0,0.25);
}
.mkp-gal-sort {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  letter-spacing: 0.06em;
}
.mkp-gal-section {
  font-family: var(--cond); font-weight: 700; font-size: 12px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--txt2); margin: 14px 0 8px;
  padding-bottom: 6px; border-bottom: 1px solid var(--border);
  position: sticky; top: 0; background: var(--surface);
}
.mkp-gal-section:first-of-type { margin-top: 0; }
.mkp-gal-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 44px;
  gap: 4px;
}
.mkp-gal-cell {
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,0.06);
  position: relative; overflow: hidden;
  background: #1a1d24;
}
.mkp-gal-cell::before {
  content: ''; position: absolute; inset: 0;
  background-size: cover; background-position: center;
  filter: saturate(0.85) brightness(0.95);
}
.mkp-gal-cell::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.4) 100%);
}
/* Verschiedene "Foto"-Looks pro Zelle (synthetisch, kein realer Asset) */
.mkp-gal-cell:nth-child(1)::before {
  background: radial-gradient(circle at 30% 40%, #4a5568, transparent 60%),
              radial-gradient(circle at 70% 70%, #2d3748, transparent 60%),
              linear-gradient(160deg, #3d5aa1 0%, #1a2540 100%);
}
.mkp-gal-cell:nth-child(2)::before {
  background: linear-gradient(135deg, #6b4423 0%, #2c1810 70%, #1a0d05 100%);
}
.mkp-gal-cell:nth-child(3)::before {
  background: radial-gradient(ellipse at center, #5a6d8a 0%, #2a3445 70%, #15191f 100%);
}
.mkp-gal-cell:nth-child(4)::before {
  background: linear-gradient(110deg, #2d3748 0%, #4a5d7a 50%, #1e2532 100%);
}
.mkp-gal-cell:nth-child(5)::before {
  background: radial-gradient(circle at 60% 30%, #7a5530 0%, #3d2a18 60%, #1a0f08 100%);
}
.mkp-gal-cell:nth-child(6)::before {
  background: linear-gradient(45deg, #1f3a5f 0%, #4d6a8e 50%, #1a2840 100%);
}
.mkp-gal-cell:nth-child(7)::before {
  background: radial-gradient(ellipse at 40% 60%, #5d4a3a 0%, #2a1f15 70%, #120b06 100%);
}
.mkp-gal-cell:nth-child(8)::before {
  background: linear-gradient(190deg, #3a4d6e 0%, #1e2940 100%);
}
.mkp-gal-cell.tall { grid-row: span 2; }
.mkp-gal-cell.wide { grid-column: span 2; }

/* Share / Teilen mockup — drei echte UI-Previews */
.mkp-share { padding: 16px; display: flex; flex-direction: column; gap: 14px; }

.shr-prev {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  position: relative;
}

/* Header-Bar (Browser-Fenster Look) */
.shr-prev-head {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  background: rgba(0,0,0,0.25);
  border-bottom: 1px solid var(--border);
}
.shr-prev-dots { display: flex; gap: 4px; }
.shr-prev-dots span {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--border2);
}
.shr-prev-dots span:nth-child(1) { background: #ff5f57; }
.shr-prev-dots span:nth-child(2) { background: #febc2e; }
.shr-prev-dots span:nth-child(3) { background: #28c840; }
.shr-prev-url {
  flex: 1;
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  background: var(--surface); border: 1px solid var(--border);
  padding: 3px 10px; border-radius: 4px;
  letter-spacing: 0.02em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.shr-prev-tag {
  font-family: var(--mono); font-size: 8px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--green);
  border: 1px solid var(--green);
  padding: 2px 6px; border-radius: 3px;
  background: rgba(55,211,153,0.1);
}
.shr-prev-tag-beta {
  color: var(--accent); border-color: var(--accent);
  background: rgba(61,90,241,0.12);
}
.shr-prev-foot {
  padding: 8px 14px;
  font-family: var(--mono); font-size: 9px; color: var(--txt2);
  letter-spacing: 0.04em;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.15);
}

/* Werkstatt-Link Body */
.shr-prev-body { padding: 12px 14px 4px; }
.shr-ws-title {
  font-family: var(--cond); font-weight: 700; font-size: 13px;
  margin-bottom: 10px;
  padding-bottom: 8px; border-bottom: 1px solid var(--border);
}
.shr-ws-row {
  display: grid;
  grid-template-columns: auto auto 1fr auto;
  align-items: center; gap: 10px;
  padding: 6px 0;
  font-family: var(--mono); font-size: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.shr-ws-row:last-child { border-bottom: none; }
.shr-ws-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 6px rgba(55,211,153,0.6);
}
.shr-ws-date { color: var(--txt2); letter-spacing: 0.02em; }
.shr-ws-label {
  font-family: var(--cond); font-weight: 600; font-size: 12px;
  color: var(--txt);
}
.shr-ws-meta { color: var(--txt2); font-size: 9px; }

/* Showroom Hero */
.shr-sr-hero {
  position: relative;
  height: 100px;
  overflow: hidden;
  background:
    radial-gradient(circle at 70% 30%, rgba(61,90,241,0.35), transparent 60%),
    linear-gradient(135deg, #1a2540 0%, #0d1428 100%);
}
.shr-sr-watermark {
  position: absolute;
  right: -8px; top: 50%; transform: translateY(-50%);
  font-family: var(--cond); font-weight: 800; font-size: 90px;
  letter-spacing: -0.04em;
  color: rgba(255,255,255,0.06);
  line-height: 1;
}
.shr-sr-content {
  position: relative; z-index: 1;
  padding: 14px 16px; height: 100%;
  display: flex; flex-direction: column; justify-content: flex-end;
}
.shr-sr-kicker {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 4px;
}
.shr-sr-title {
  font-family: var(--cond); font-weight: 800; font-size: 20px;
  letter-spacing: -0.01em;
  margin-bottom: 6px;
}
.shr-sr-stats {
  display: flex; gap: 8px; align-items: center;
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
}
.shr-sr-stats b {
  font-family: var(--cond); font-weight: 700;
  color: var(--txt); font-size: 12px;
}
.shr-sr-sep { color: var(--border2); }

/* Insta-Carousel Stack */
.shr-insta-tag {
  flex: 1;
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  letter-spacing: 0.04em;
}
.shr-insta-stack {
  position: relative;
  padding: 18px 14px 14px;
  height: 130px;
  perspective: 800px;
}
.shr-slide {
  position: absolute;
  width: 88px; height: 110px;
  border-radius: 6px;
  border: 1px solid var(--border2);
  padding: 12px 10px;
  background: linear-gradient(160deg, #1f2329 0%, #0e1014 100%);
  box-shadow: 0 8px 20px rgba(0,0,0,0.5);
  overflow: hidden;
}
.shr-s1 {
  left: 50%; top: 14px;
  transform: translateX(-50%) rotate(-6deg);
  z-index: 3;
  background: linear-gradient(160deg, #2a1f3d 0%, #0e0818 100%);
  border-color: rgba(221,42,123,0.4);
}
.shr-s2 {
  left: 50%; top: 14px;
  transform: translateX(calc(-50% + 26px)) rotate(2deg);
  z-index: 2;
  background: linear-gradient(160deg, #1a2540 0%, #050a18 100%);
  border-color: rgba(61,90,241,0.4);
  opacity: 0.85;
}
.shr-s3 {
  left: 50%; top: 14px;
  transform: translateX(calc(-50% + 50px)) rotate(8deg);
  z-index: 1;
  background: linear-gradient(160deg, #3d2a18 0%, #1a0f08 100%);
  opacity: 0.6;
}
.shr-slide-kicker {
  font-family: var(--mono); font-size: 7px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-bottom: 8px;
}
.shr-slide-title {
  font-family: var(--cond); font-weight: 800; font-size: 13px;
  line-height: 1.1; letter-spacing: -0.01em;
  color: #fff;
}
.shr-slide-meta {
  font-family: var(--mono); font-size: 7px;
  color: rgba(255,255,255,0.5);
  margin-top: 6px;
  letter-spacing: 0.04em;
}
.shr-insta-dots {
  display: flex; justify-content: center; gap: 4px;
  padding: 0 0 12px;
}
.shr-insta-dots span {
  width: 16px; height: 2px; border-radius: 1px;
  background: var(--border2);
}
.shr-insta-dots span.active { background: var(--accent); }

/* Inline beta tag in feature list */
.l-feat-beta {
  display: inline-block;
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent);
  padding: 1px 6px; border-radius: 3px;
  background: rgba(61,90,241,0.1);
  margin-left: 4px;
  vertical-align: 1px;
}

/* Feature extras strip */
.l-feat-extras {
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center;
  margin-top: 48px; padding-top: 36px;
  border-top: 1px solid var(--border);
}
.l-feat-extra {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 18px 10px 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 13px; color: var(--txt2);
  transition: border-color 0.2s, color 0.2s;
}
.l-feat-extra::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  box-shadow: 0 0 6px rgba(61,90,241,0.5);
}
.l-feat-extra:hover { border-color: var(--accent); color: var(--txt); }

/* ── HOW: vertical stack with mini UI mockups ── */
.l-how-stack {
  margin-top: 48px;
  display: flex; flex-direction: column;
  gap: 0;
}
.l-how-item {
  display: grid;
  grid-template-columns: 80px 1fr 1.1fr;
  gap: 32px;
  align-items: center;
  padding: 36px 0;
  border-top: 1px solid var(--border);
}
.l-how-item:first-child { border-top: none; padding-top: 0; }
.l-how-item.reverse .l-how-body { order: 3; }
.l-how-item.reverse .l-how-visual { order: 2; }

@media (max-width: 860px) {
  .l-how-item {
    grid-template-columns: 56px 1fr;
    grid-template-areas:
      "num body"
      "vis vis";
    gap: 18px 16px;
  }
  .l-how-item .l-how-num    { grid-area: num; }
  .l-how-item .l-how-body   { grid-area: body; order: unset; }
  .l-how-item .l-how-visual { grid-area: vis; order: unset; }
  .l-how-item.reverse .l-how-body   { order: unset; }
  .l-how-item.reverse .l-how-visual { order: unset; }
}

.l-how-item .l-how-num {
  font-family: var(--cond);
  font-weight: 800;
  font-size: 64px;
  line-height: 0.9;
  color: var(--accent);
  letter-spacing: -0.03em;
  text-shadow: 0 0 40px rgba(61,90,241,0.35);
}
@media (max-width: 860px) {
  .l-how-item .l-how-num { font-size: 44px; }
}

.l-how-item .l-how-title {
  font-family: var(--cond); font-size: 26px; font-weight: 700;
  margin-bottom: 10px; letter-spacing: -0.01em;
}
.l-how-item .l-how-text { font-size: 14px; color: var(--txt2); line-height: 1.7; max-width: 380px; }

/* Mini UI mockups inside How */
.mini-ui {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 18px 18px 20px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
  max-width: 420px;
}
.mini-ui-head {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--txt2);
  padding-bottom: 10px; margin-bottom: 10px;
  border-bottom: 1px solid var(--border);
}

/* Form mini-ui (Step 1) */
.mini-ui-row {
  display: flex; align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.mini-ui-row:last-child { border-bottom: none; }
.mini-ui-lab {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt2);
  letter-spacing: 0.06em;
  width: 100px;
  text-transform: uppercase;
}
.mini-ui-val {
  font-family: var(--cond); font-size: 16px; font-weight: 600;
  color: var(--txt);
  min-height: 1.2em;
}
.mini-ui-val-pending {
  color: var(--border2);
  font-weight: 400;
}
.mini-ui-caret {
  display: inline-block;
  width: 2px; height: 14px;
  background: var(--accent);
  margin-left: 3px;
  vertical-align: middle;
  animation: miniCaret 1s steps(2) infinite;
}
@keyframes miniCaret {
  0%, 50% { opacity: 1; }
  51%, 100% { opacity: 0; }
}

/* History mini-ui (Step 2) */
.mini-ui-entry {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  opacity: 0;
  transform: translateX(-8px);
  animation: miniEntryIn 0.5s cubic-bezier(.2,.9,.3,1) forwards;
}
.mini-ui-entry:nth-child(2) { animation-delay: 0.1s; }
.mini-ui-entry:nth-child(3) { animation-delay: 0.25s; }
.mini-ui-entry:nth-child(4) { animation-delay: 0.4s; }
.mini-ui-entry:nth-child(5) { animation-delay: 0.55s; }
.mini-ui-entry:last-child { border-bottom: none; }
@keyframes miniEntryIn {
  to { opacity: 1; transform: translateX(0); }
}
.mini-ui-date {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.1em;
  color: var(--accent);
  width: 60px;
}
.mini-ui-ttl {
  font-family: var(--cond); font-size: 14px; font-weight: 500;
  color: var(--txt);
}

/* Service mini-ui (Step 3) */
.mini-ui-svc { padding-top: 2px; }
.mini-ui-svc-row {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 0;
}
.mini-ui-svc-lab {
  font-family: var(--cond); font-size: 13px; font-weight: 600;
  color: var(--txt); width: 75px;
}
.mini-ui-svc-bar {
  flex: 1; height: 5px; background: var(--border);
  border-radius: 3px; overflow: hidden;
}
.mini-ui-svc-bar > div {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), #6b84ff);
  border-radius: 3px;
  transition: width 0.6s;
}
.mini-ui-svc-bar > div.warn {
  background: linear-gradient(90deg, var(--amber), var(--amber));
}
.mini-ui-foot {
  margin-top: 12px; padding-top: 12px;
  border-top: 1px solid var(--border);
  font-family: var(--mono); font-size: 10px;
  color: var(--txt2); letter-spacing: 0.06em;
  display: flex; align-items: center; gap: 8px;
}
.mini-ui-foot .dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--green);
  box-shadow: 0 0 6px var(--green);
}
.mini-ui-foot .dot.warn { background: var(--amber); box-shadow: 0 0 6px var(--amber); }

/* ── WHO: persona cards ── */
.l-who-personas {
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
}
@media (max-width: 900px) { .l-who-personas { grid-template-columns: 1fr; } }

.l-who-persona {
  background: var(--surface);
  padding: 36px 32px 32px;
  display: flex; flex-direction: column;
  position: relative;
  transition: background 0.25s;
}
.l-who-persona:hover { background: var(--surface2); }

.l-who-persona-idx {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--accent);
  margin-bottom: 16px;
}
.l-who-persona-name {
  font-family: var(--cond);
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
}
.l-who-persona-name .acc { color: var(--accent); }
.l-who-persona-quote {
  font-family: var(--cond);
  font-style: italic;
  font-size: 16px;
  line-height: 1.5;
  color: var(--txt);
  margin: 0 0 22px;
  flex: 1;
  position: relative;
  padding-left: 16px;
  border-left: 2px solid var(--accent);
}
.l-who-persona-meta {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--txt2);
  letter-spacing: 0.06em;
  line-height: 1.7;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}
.l-who-persona-meta em {
  color: var(--txt);
  font-style: normal;
  font-weight: 500;
}
/* ── ARCHITEKTUR / TRUST ── */
.l-arch {
  padding: 80px 48px;
  max-width: 1100px; margin: 0 auto;
}
@media (max-width: 640px) { .l-arch { padding: 60px 20px; } }

.l-arch-grid {
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
}
@media (max-width: 760px) { .l-arch-grid { grid-template-columns: 1fr; } }

.l-arch-card {
  background: var(--surface);
  padding: 36px 32px 32px;
  display: flex; flex-direction: column;
  position: relative;
  transition: background 0.25s;
}
.l-arch-card:hover { background: var(--surface2); }

.l-arch-icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, rgba(61,90,241,0.18), rgba(61,90,241,0.04));
  border: 1px solid rgba(61,90,241,0.3);
  color: var(--accent);
  margin-bottom: 22px;
  flex-shrink: 0;
}

.l-arch-kicker {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}

.l-arch-h3 {
  font-family: var(--cond);
  font-weight: 800;
  font-size: clamp(20px, 2.2vw, 26px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 0 0 16px;
  color: var(--txt);
}

.l-arch-p {
  font-family: var(--body);
  font-size: 14px;
  line-height: 1.6;
  color: var(--txt2);
  margin: 0;
}

.l-arch-foot {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; align-items: center;
  gap: 14px;
  text-align: center;
}
.l-arch-foot-keys {
  display: inline-flex; flex-wrap: wrap;
  justify-content: center; align-items: center;
  gap: 22px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--txt);
}
.l-arch-foot-keys > span {
  display: inline-flex; align-items: center; gap: 8px;
}
.l-arch-foot-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
}
.l-arch-foot-note {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--txt2);
}

.l-who-quote {
  margin: 60px auto 0;
  max-width: 640px;
  text-align: center;
  font-family: var(--cond);
  font-style: italic;
  font-size: clamp(18px, 2.2vw, 24px);
  line-height: 1.5;
  color: var(--txt);
  padding: 36px 20px 0;
  border-top: 1px solid var(--border);
}

/* ── CTA SECTION ── */
.l-cta-section {
  border-top: 1px solid var(--border);
  padding: 80px 48px;
  text-align: center;
  background: var(--surface);
}
@media (max-width: 640px) { .l-cta-section { padding: 60px 20px; } }
.l-cta-h2 {
  font-family: var(--cond); font-size: clamp(32px, 5vw, 56px);
  font-weight: 800; margin-bottom: 16px; line-height: 1.1;
}
.l-cta-sub { font-size: 14px; color: var(--txt2); margin-bottom: 32px; }
.l-cta-note { font-family: var(--mono); font-size: 10px; color: var(--txt2); margin-top: 16px; letter-spacing: 0.06em; }

/* Buttons — Premium Cond style (matcht .auth-cta / .intro-cta) */
.l-btn-primary {
  font-family: var(--cond); font-weight: 700;
  font-size: 16px; letter-spacing: 0.02em; text-transform: uppercase;
  background: linear-gradient(180deg, #4863f5, #2f4ce0);
  color: #fff; border: none;
  padding: 13px 28px; border-radius: var(--r); cursor: pointer;
  text-decoration: none; display: inline-flex; align-items: center; gap: 8px;
  box-shadow:
    0 14px 32px rgba(61,90,241,0.40),
    0 0 0 1px rgba(255,255,255,0.06) inset;
  transition: transform 0.15s, box-shadow 0.2s;
}
.l-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow:
    0 18px 38px rgba(61,90,241,0.55),
    0 0 0 1px rgba(255,255,255,0.08) inset;
}
.l-btn-primary:active { transform: translateY(0); }
.l-btn-ghost {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em;
  background: none; color: var(--txt2); border: 1px solid var(--border2);
  padding: 11px 20px; border-radius: var(--r); cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
}
.l-btn-ghost:hover { color: var(--txt); border-color: var(--txt2); }

/* Section label */
.l-section-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--txt2);
}

/* Footer */
.l-footer {
  border-top: 1px solid var(--border);
  padding: 24px 48px;
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px;
}
@media (max-width: 640px) { .l-footer { padding: 20px; } }
.l-footer-logo { display: flex; align-items: center; }
.l-footer-logo-img { height: 56px; object-fit: contain; }
.l-footer-note { font-family: var(--mono); font-size: 10px; color: var(--txt2); letter-spacing: 0.04em; }
.l-footer-links {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em;
  display: flex; align-items: center; gap: 0;
}
.l-footer-links a {
  color: var(--txt2); text-decoration: none;
  transition: color 0.18s;
}
.l-footer-links a:hover { color: var(--txt); }
.l-footer-sep { color: var(--txt3); margin: 0 8px; opacity: 0.5; }

/* ── LEGAL PAGES (Impressum, Datenschutz) ──────────────────────────────── */
.legal-body { background: var(--bg); color: var(--txt); min-height: 100vh; }
.legal-page {
  padding: calc(60px + 32px) 24px 64px;
  display: flex; justify-content: center;
}
.legal-container {
  max-width: 720px; width: 100%;
  font-family: var(--body); font-size: 15px; line-height: 1.6;
  color: var(--txt2);
}
.legal-back {
  display: inline-block; margin-bottom: 22px;
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  text-decoration: none; letter-spacing: 0.06em;
  transition: color 0.18s;
}
.legal-back:hover { color: var(--accent); }
.legal-h1 {
  font-family: var(--cond); font-size: 42px; font-weight: 800;
  color: var(--txt); margin: 0 0 26px;
  letter-spacing: 0.01em; line-height: 1.05;
}
.legal-h2 {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  color: var(--txt); margin: 32px 0 10px;
  letter-spacing: 0.01em;
}
.legal-page p { margin: 0 0 14px; }
.legal-page ul { margin: 0 0 18px; padding-left: 20px; }
.legal-page ul li { margin-bottom: 6px; }
.legal-page strong { color: var(--txt); font-weight: 600; }
.legal-placeholder {
  background: rgba(176,144,32,0.08);
  border: 1px solid rgba(176,144,32,0.32);
  color: var(--amber);
  padding: 14px 16px; border-radius: 10px;
  font-size: 13px; line-height: 1.5;
  margin-bottom: 28px;
}
.legal-foot-note {
  font-family: var(--mono); font-size: 10px;
  color: var(--txt3); letter-spacing: 0.06em;
  margin-top: 40px; text-transform: uppercase;
}
@media (max-width: 640px) {
  .legal-page { padding: calc(60px + 24px) 18px 48px; }
  .legal-h1 { font-size: 32px; }
  .legal-h2 { font-size: 18px; margin-top: 26px; }
}


/* ── MOBILE OPTIMIERUNG ─────────────────────────────────────────────────── */

/* Touch targets */
button, .vehicle-card, .maint-entry, .todo-entry, .tb-card, .l-model-card, .kb-card {
  -webkit-tap-highlight-color: transparent;
}

/* Prevent iOS font size bump */
input, select, textarea {
  font-size: 16px !important;
}

@media (max-width: 640px) {
  /* ── Header ── */
  .app-header {
    padding: 0 14px;
    height: 50px;
    gap: 8px;
  }
  .logo { font-size: 16px; }
  .btn-back { font-size: 10px; }
  .header-title { font-size: 14px; }

  /* ── Dashboard ── */
  .dash-content { padding: 16px 14px; }
  .section-label { font-size: 10px; }
  .dash-grid { gap: 10px; margin-bottom: 28px; }
  .vc-placeholder svg { width: 32px; height: 32px; }
  .vc-body { padding: 9px 10px; }
  .vc-meta { font-size: 12px; margin-bottom: 4px; }
  .vc-name { font-size: 20px; }
  .vc-marker { font-size: 10px; letter-spacing: 0.1em; }
  .vc-markers { gap: 12px; }
  .vc-image { width: 100px; }
  .knowledge-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-top: 10px;
  }
  .kb-card { padding: 10px 12px; }
  .kb-name { font-size: 15px; }

  /* ── Vehicle Detail ── */
  .detail-hero {
    padding: 12px 14px 0;
    gap: 10px;
    flex-wrap: nowrap;
  }
  .detail-hero-img {
    width: 68px;
    height: 48px;
    font-size: 22px;
    flex-shrink: 0;
  }
  .detail-hero-text { padding-bottom: 12px; }
  .detail-title { font-size: 20px; line-height: 1.1; }
  .detail-subtitle { font-size: 12px; margin-top: 3px; }
  .detail-hero-actions { padding-bottom: 12px; }

  /* ── Pills (Detail-Nav, replaces old tabs on mobile) ── */
  .detail-nav-section {
    top: 50px; /* mobile app-header is 50px base */
    padding: 10px 14px 6px;
  }
  /* (sub-tab-bar nicht mehr sticky individuell — sitzt in detail-nav-section) */
  .tab-actions {
    padding: 10px 14px;
    gap: 8px;
  }

  /* ── Maintenance ── */
  .maint-entry { padding: 14px 14px; gap: 10px; }
  .me-title { font-size: 15px; }
  .me-meta { font-size: 11px; }
  .me-notes { font-size: 13px; }
  .due-badge { font-size: 11px; padding: 3px 7px; }

  /* ── Todos ── */
  .todo-entry { padding: 14px 14px; gap: 10px; }
  .todo-check { width: 28px; height: 28px; }
  .todo-title { font-size: 15px; }
  .todo-ref { font-size: 11px; }
  .todo-notes { font-size: 13px; }
  .todo-done-header { padding: 10px 14px; font-size: 12px; }

  /* ── Template Browse ── */
  .tb-content { padding: 14px 12px; }
  .tb-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 6px;
  }
  .tb-card { padding: 11px 12px; }
  .tb-name { font-size: 15px; }
  .tb-years { font-size: 9px; }

  /* ── Template Car View ── */
  .tc-content { padding: 12px 14px; }
  .tc-zone { margin-bottom: 16px; }
  .tc-zone-title { font-size: 12px; padding: 6px 0; }
  .tc-issue { margin-bottom: 5px; }
  .tc-issue-header {
    padding: 10px 12px;
    gap: 6px;
    flex-wrap: wrap;
  }
  .tc-issue-title { font-size: 13px; flex: 1 1 auto; min-width: 0; }
  .tc-issue-sev { font-size: 9px; }
  .btn-import {
    font-size: 10px;
    padding: 5px 10px;
    min-height: 32px;
  }
  .tc-issue-detail { padding: 0 12px 10px; }
  .tc-issue-text { font-size: 12px; }
  .tc-cp { font-size: 11px; }
  .meta-chip { font-size: 9px; padding: 2px 5px; }

  /* ── Modals (bottom sheet) ── */
  .modal { border-radius: 10px 10px 0 0; }
  .modal-header { padding: 16px 16px; font-size: 16px; }
  .modal-body { padding: 14px 16px; }
  .modal-footer {
    padding: 14px 16px;
    padding-bottom: max(16px, env(safe-area-inset-bottom));
  }
  /* Full-width stacked buttons on small modals */
  .modal-footer { flex-wrap: wrap; }
  .modal-footer .btn-primary,
  .modal-footer .btn-secondary { flex: 1; text-align: center; min-height: 48px; font-size: 14px; }

  /* ── Forms ── */
  .form-group { margin-bottom: 14px; }
  .form-group label { font-size: 11px; margin-bottom: 5px; }
  .form-group input,
  .form-group select,
  .form-group textarea { padding: 12px 12px; border-radius: 3px; font-size: 16px !important; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .form-hint { font-size: 11px; }

  /* ── Empty states ── */
  .empty-state { padding: 32px 16px; }
  .empty-icon { font-size: 36px; }

  /* ── Buttons ── */
  .btn-primary, .btn-secondary { min-height: 44px; font-size: 13px; }
  .btn-sm { padding: 8px 14px !important; font-size: 12px !important; min-height: 44px !important; }

  /* Dashboard header on mobile */

  /* Safe area insets for notched iPhones */
  .app-header { padding-top: env(safe-area-inset-top); }
  #pg-landing .l-footer,
  .l-cta-section {
    padding-bottom: max(24px, env(safe-area-inset-bottom));
  }
}

/* Very small phones (SE, etc.) */

  /* Dashboard header: hide secondary btn on mobile (KB is visible on page) */
  /* Make + Fahrzeug fit */
  .app-header .btn-primary.btn-sm { padding: 7px 14px !important; }

@media (max-width: 380px) {
  .dash-grid { grid-template-columns: 1fr; }
  .tb-grid { grid-template-columns: 1fr; }
  .detail-hero { flex-wrap: wrap; }
  .detail-hero-img { display: none; }
}

/* ── VEHICLE INFO CARD (redesign) ────────────────────────────────────── */
.vehicle-info-card {
  background: var(--surface);
  border-bottom: 2px solid var(--border);
  flex-shrink: 0;
}

/* Hero image */
.vic-hero {
  position: relative; height: 180px;
  background: var(--bg); overflow: hidden;
  /* touch-action: pan-y → vertikale Scroll-Geste bleibt der Page,
     horizontale Geste wird der Swipe-Engine überlassen (kein Page-Back-Swipe-Konflikt). */
  touch-action: pan-y;
  user-select: none;
  /* iOS-Default-Context-Menu beim Long-Press unterdrücken — wir haben eigenes Action-Sheet. */
  -webkit-touch-callout: none;
}
.vh-track { touch-action: pan-y; }
.vic-hero img {
  -webkit-touch-callout: none;
  -webkit-user-drag: none;
  user-select: none;
  pointer-events: none; /* Verhindert dass Bild den Pointer-Event vom Hero-Container "stiehlt" */
}
@media (min-width: 760px)  { .vic-hero { height: 280px; } }
@media (min-width: 1100px) { .vic-hero { height: 360px; } }
.vic-hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Weicher Übergang vom Titelbild in den schwarzen Hintergrund —
   wird beim Scrollen progressiv eingeblendet (über --hero-fade aus JS) */
.vic-hero::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 55%;
  background: linear-gradient(180deg,
    rgba(13,13,13,0) 0%,
    rgba(13,13,13,0.16) 50%,
    rgba(13,13,13,0.44) 82%,
    rgba(13,13,13,0.62) 100%);
  pointer-events: none;
  z-index: 1;
  opacity: var(--hero-fade, 0);
  transition: opacity 0.12s linear;
}
/* Hero-Overlays (Dots, Galerie-Badge, Buttons) bleiben über dem Fade */
.vh-dots, .vh-count, .vic-hero-btns { z-index: 2; }
.vic-hero-empty {
  display: flex; align-items: center; justify-content: center;
  height: 100%; cursor: pointer;
  color: var(--txt3); opacity: 0.3;
}
.vic-hero-empty svg { width: 56px; height: 56px; }
/* Hero slider */
.vh-track {
  display: flex; height: 130%;
  position: relative; top: -15%;
  transition: transform 0.32s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.vh-slide { flex-shrink: 0; width: 100%; height: 100%; }
.vh-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.vh-dots {
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 5px; pointer-events: none;
}
.vh-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,0.45); transition: background 0.2s, width 0.2s;
}
.vh-dot.active { background: #fff; width: 14px; border-radius: 3px; }
/* Einheitlicher Glas-Pill-Stil für alle Hero-Overlay-Buttons.
   Subtil, modern, konsistent — passt zur Patina-Brand-Sprache. */
.vh-count,
.vic-hero-btn {
  background: rgba(13,13,13,0.55);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
          backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.14);
  color: #fff;
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.10em; text-transform: uppercase;
  padding: 0 12px; height: 30px;
  border-radius: 99px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  gap: 7px; white-space: nowrap;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.vh-count:hover,
.vic-hero-btn:hover {
  background: rgba(13,13,13,0.78);
  border-color: rgba(255,255,255,0.26);
}
.vh-count:active,
.vic-hero-btn:active { transform: scale(0.96); }
.vic-hero-btn svg { display: block; opacity: 0.9; }

.vh-count {
  position: absolute; bottom: 12px; right: 12px; z-index: 2;
}

/* S-Tier Hero Foto-Pill — primärer Foto-Capture-Touchpoint pro Fahrzeug.
   Editorial DNA: Mono-Caps, Hairline-Border, ruhiges Glas, dezenter Glow.
   Icon-Bubble setzt Akzent ohne bunt zu werden — Inset-Hairline + leichte Lift. */
.vh-add-photo-pill {
  position: absolute; bottom: 12px; left: 12px; z-index: 2;
  display: inline-flex; align-items: center; gap: 8px;
  height: 32px; padding: 0 14px 0 4px;
  border-radius: 99px;
  background: rgba(15,15,15,0.58);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
          backdrop-filter: blur(18px) saturate(150%);
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 6px 18px rgba(0,0,0,0.28);
  color: #fff;
  font-family: var(--mono);
  font-size: 10px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  cursor: pointer; white-space: nowrap;
  transition:
    background 0.22s ease,
    border-color 0.22s ease,
    transform 0.22s cubic-bezier(.2,.7,.2,1),
    box-shadow 0.22s ease;
}
.vh-add-photo-pill .vh-add-photo-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px;
  border-radius: 99px;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04));
  border: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
  transition: background 0.22s ease, border-color 0.22s ease, transform 0.22s ease;
}
.vh-add-photo-pill .vh-add-photo-icon svg { display: block; opacity: 0.95; }
.vh-add-photo-pill .vh-add-photo-label {
  display: inline-block;
  opacity: 0.92;
}
.vh-add-photo-pill:hover {
  background: rgba(15,15,15,0.78);
  border-color: rgba(255,255,255,0.28);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.10),
    0 8px 22px rgba(0,0,0,0.35);
}
.vh-add-photo-pill:hover .vh-add-photo-icon {
  background: linear-gradient(180deg, rgba(255,255,255,0.16), rgba(255,255,255,0.06));
  border-color: rgba(255,255,255,0.30);
}
.vh-add-photo-pill:active {
  transform: scale(0.97);
}
.vh-add-photo-pill:active .vh-add-photo-icon {
  transform: scale(0.94);
}
@media (prefers-reduced-motion: reduce) {
  .vh-add-photo-pill,
  .vh-add-photo-pill .vh-add-photo-icon { transition: none; }
}
.vic-hero-btns {
  position: absolute; top: 12px; right: 12px;
  display: flex; gap: 6px; z-index: 2;
}
.vic-hero-btn.icon {
  width: 30px; padding: 0;
}

/* Hero crop mode */
.hero-crop-overlay {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  display: none; align-items: center; justify-content: center; flex-direction: column; gap: 10px;
  background: rgba(0,0,0,0.28);
}
.hero-crop-overlay.active { display: flex; }
.hero-crop-ring {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.85);
  position: relative;
}
.hero-crop-ring::before, .hero-crop-ring::after {
  content: ''; position: absolute; background: rgba(255,255,255,0.85);
  border-radius: 1px;
}
.hero-crop-ring::before { width: 1px; height: 18px; left: 50%; top: 50%; transform: translate(-50%,-50%); }
.hero-crop-ring::after  { width: 18px; height: 1px; left: 50%; top: 50%; transform: translate(-50%,-50%); }
.hero-crop-hint {
  color: rgba(255,255,255,0.92); font-size: 11px; font-family: var(--mono);
  letter-spacing: 0.04em; background: rgba(0,0,0,0.55);
  padding: 4px 10px; border-radius: 20px;
}

/* Name block */
.vic-name-block {
  padding: 14px 20px 12px;
  border-bottom: 1px solid var(--border);
}
.vic-name-row {
  display: flex; align-items: flex-start; gap: 10px;
}
.vic-name {
  font-family: var(--cond); font-size: 28px; font-weight: 800;
  letter-spacing: 0.02em; line-height: 1.1; color: var(--txt);
  flex: 1;
}
.vic-edit-btn {
  flex-shrink: 0; background: var(--surface2); border: 1px solid var(--border2);
  color: var(--txt2); font-size: 16px; width: 34px; height: 34px;
  border-radius: 50%; cursor: pointer; display: flex; align-items: center;
  justify-content: center; transition: color 0.2s, border-color 0.2s;
  margin-top: 2px;
}
.vic-edit-btn:hover { color: var(--accent); border-color: var(--accent); }
.vic-sub {
  font-family: var(--mono); font-size: 12px; color: var(--txt2);
  margin-top: 5px; letter-spacing: 0.02em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.vic-sub-i { color: var(--txt); }
.vic-sub-d { color: var(--txt3); opacity: 0.55; margin: 0 7px; }

/* ── Stats Card ──────────────────────────────────────────────────────────── */
.vic-stats-card {
  margin: 10px 16px 10px;
  border-radius: 14px;
  background: var(--surface2);
  border: 1px solid var(--border);
  overflow: hidden;
  position: relative;
}
.vic-stats-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.vic-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
}
.vic-stat {
  padding: 12px 14px;
  display: flex; flex-direction: column; justify-content: center;
}
.vic-stat-tap { cursor: pointer; transition: background 0.15s; }
.vic-stat-tap:active { background: rgba(255,255,255,0.05); }
.vic-stats-grid .vic-stat:nth-child(1),
.vic-stats-grid .vic-stat:nth-child(2) { border-bottom: 1px solid rgba(255,255,255,0.07); }
.vic-stats-grid .vic-stat:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.07); }

/* 3-Spalten Variante (im Preview verwendet — 3 Zellen statt 4) */
.vic-stats-grid.vic-stats-grid-3 {
  grid-template-columns: 1fr 1fr 1fr;
}
.vic-stats-grid.vic-stats-grid-3 .vic-stat { border-bottom: none; border-right: none; }
.vic-stats-grid.vic-stats-grid-3 .vic-stat:not(:last-child) {
  border-right: 1px solid rgba(255,255,255,0.07);
}
.vic-stat-icon { display: none; }
.vic-stat-label {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.18em;
  margin-bottom: 5px;
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 4px;
}
.vic-stat-tap-arrow {
  display: inline-block;
  font-size: 11px; line-height: 1;
  color: var(--txt3); opacity: 0.7;
  transform: translateY(-1px);
  transition: opacity .15s, color .15s, transform .15s;
}
.vic-stat-tap:hover .vic-stat-tap-arrow,
.vic-stat-tap:active .vic-stat-tap-arrow {
  color: var(--accent); opacity: 1;
  transform: translate(1px, -2px);
}
.vic-stat-val {
  font-family: var(--cond); font-size: 24px; font-weight: 800;
  line-height: 1; color: var(--txt);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  letter-spacing: -0.005em;
}
.vic-stat-val.overdue { color: var(--red); }
.vic-stat-val.soon    { color: var(--amber); }
.vic-stat-val.ok      { color: var(--txt); }
.vic-stat-empty       { color: var(--txt3); font-weight: 300; }
.vic-stat-done-pos    { color: var(--green); }
.vic-stat-sub {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 3px; line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.vic-stat-sub.overdue { color: var(--red); }
.vic-stat-sub.soon    { color: var(--amber); }
.vic-stat-sub.ok      { color: var(--txt3); }

/* Mini-Bar unter Stat-Wert (z.B. Projektbudget-Fortschritt unter „Kosten") */
.vic-stat-mini-bar {
  height: 3px; margin-top: 8px;
  background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden;
}
.vic-stat-mini-bar-fill {
  height: 100%; background: var(--txt2); border-radius: 2px;
  transition: width 0.4s ease;
}
.vic-stat-mini-bar-fill.soon    { background: var(--amber); }
.vic-stat-mini-bar-fill.overdue { background: var(--red); }
.vic-stat-mini-bar-fill.ok      { background: var(--txt2); }
.vic-stat-full {
  grid-column: 1 / -1;
  padding: 9px 14px 11px;
  border-top: 1px solid rgba(255,255,255,0.07);
  position: relative;
}
.vic-next { padding: 12px 14px 14px; }
/* Wenn .vic-next direkt unter dem 3er-Stats-Grid sitzt, trennt ein border-top sie visuell. */
.vic-stats-card > .vic-next {
  border-top: 1px solid rgba(255,255,255,0.07);
}
/* Hero-Hierarchie: prominenter Title, kompakte Mono-Status-Line, dezenter Bar */
.vic-next-title {
  font-family: var(--cond); font-size: 24px; font-weight: 700;
  color: var(--txt); line-height: 1.05;
  letter-spacing: -0.005em;
  margin-top: 1px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.vic-next-title.overdue { color: var(--red); }
.vic-next-title.soon    { color: var(--amber); }
.vic-next-title.ok      { color: var(--txt); }
.vic-next-status {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 5px; line-height: 1.2;
  font-variant-numeric: tabular-nums;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.vic-next-status.overdue { color: var(--red); }
.vic-next-status.soon    { color: var(--amber); }
.vic-next-status.ok      { color: var(--txt2); }
.vic-next-bar {
  margin-top: 9px; height: 3px; border-radius: 2px;
  background: rgba(255,255,255,0.07); overflow: hidden;
}
.vic-next-bar-fill {
  height: 100%; background: var(--accent);
  transition: width 0.4s cubic-bezier(.4,0,.2,1);
}
.vic-next-bar-fill.overdue { background: var(--red); }
.vic-next-bar-fill.soon    { background: var(--amber); }
.vic-next-bar-fill.ok      { background: var(--green); }
/* keep old classes for anything that might still reference them */
.vic-km-edit {
  background: none; border: none; color: var(--accent);
  font-size: 13px; cursor: pointer; padding: 0 4px; vertical-align: middle;
}

.vic-toggle-row {
  display: flex; align-items: stretch;
  border-bottom: 1px solid var(--border);
}
.vic-toggle {
  display: flex; align-items: center; justify-content: space-between;
  flex: 1; background: none; border: none;
  color: var(--txt2); font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.06em;
  padding: 12px 20px; cursor: pointer; transition: color 0.2s;
  min-height: 44px;
}
.vic-toggle:hover { color: var(--txt); }
.vic-toggle-edit {
  flex-shrink: 0; background: none; border: none;
  border-left: 1px solid var(--border);
  padding: 0 14px; cursor: pointer; line-height: 1;
  color: var(--txt3); opacity: 0.5;
  display: flex; align-items: center;
  transition: opacity 0.15s, color 0.15s;
}
.vic-toggle-edit:hover { opacity: 1; color: var(--txt); }
.vic-chevron { flex-shrink: 0; color: var(--txt3); transition: transform 0.2s ease; transform: rotate(-90deg); }
.vic-chevron.open { transform: rotate(0deg); }
.vic-details-panel { padding: 14px 20px 16px; border-bottom: 1px solid var(--border); }

/* ── ENTRY ROWS: priority / type accent borders ──────────────────────── */
/* ── UNIFIED ENTRY STYLE ─────────────────────────────────────────── */
/* ── Editorial Hairline-Pattern (matches svc-row) ── */
.el-entry {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 16px 16px 14px;
  /* Border am Item selbst — Standard-Pfad. */
  border-bottom: 1px solid var(--border2);
  cursor: pointer; transition: background 0.15s;
  border-left: 2px solid transparent;
  background: transparent;
}
/* Robuster Trenner zwischen Swipe-Wrappern via Sibling-Selector.
   Umgeht Sub-Pixel-Render-Probleme die durch content-visibility:auto auf
   den Wrappern bei manchen Einträgen entstehen (Border-Bottom wurde
   dann gelegentlich auf 0.5px gerundet → unsichtbar). */
#task-done-content .swipe-wrapper + .swipe-wrapper,
#task-todo-content .swipe-wrapper + .swipe-wrapper {
  border-top: 1px solid var(--border2);
}
/* Doppellinie vermeiden: wenn ein swipe-wrapper NICHT das letzte Kind ist, hat
   das nachfolgende Element bereits seinen eigenen Trenner (Sibling-border-top
   oder Sub-Accordion-border-top) — also Item-Border am vorigen entfernen. */
#task-done-content > .swipe-wrapper:not(:last-child) .el-entry,
#task-todo-content > .swipe-wrapper:not(:last-child) .el-entry,
.todo-accordion-body > .swipe-wrapper:not(:last-child) .el-entry,
.todo-accordion-body > .swipe-wrapper:has(+ .todo-accordion) .el-entry {
  border-bottom-color: transparent;
}
/* Letzte Zeile in einem Accordion-Body: Accordion selbst hat einen border-bottom,
   also Item-Border am letzten Eintrag ausblenden — sonst Doppellinie an Group-Grenze. */
.todo-accordion-body > .swipe-wrapper:last-child .el-entry {
  border-bottom-color: transparent;
}
/* Sub-Accordion innerhalb Main-Group: border-top dezent halten, sonst Doppellinie
   wenn Spurstangen oben drüber ihre Border auch noch hätte (jetzt entfernt). */
.todo-accordion-body .todo-accordion {
  border-top-color: var(--border2);
}
.el-entry:active { background: rgba(255,255,255,0.025); }
.el-body { flex: 1; min-width: 0; }
.el-title {
  font-family: var(--cond); font-weight: 700; font-size: 18px;
  letter-spacing: -0.005em; color: var(--txt);
  line-height: 1.1;
}
.el-badge {
  display: inline-block; font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 2px 8px; background: transparent;
  border: 1px solid var(--border);
  color: var(--txt3); margin-left: 8px; vertical-align: 2px; font-weight: 500;
}
.el-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt3);
  line-height: 1.5;
  margin-top: 6px;
}
.el-due { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 5px; }
.el-notes {
  font-family: var(--body); font-size: 14px; color: var(--txt2);
  margin-top: 6px; line-height: 1.45;
}
.el-images { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 8px; }
.el-images .img-thumb { width: 52px; height: 52px; }

/* Todo-specific: priority border-left as glanceable cue */
.el-entry[data-prio="high"]     { border-left-color: var(--red); }
.el-entry[data-prio="medium"]   { border-left-color: var(--amber); }
.el-entry[data-prio="none"]     { border-left-color: transparent; }

/* Mehr-Details Toggle im Todo+Completion-Modal */
.cm-more-details {
  margin-top: 8px;
  border-top: 1px solid var(--border);
  padding-top: 14px;
}
.cm-more-details > summary {
  list-style: none;
  cursor: pointer;
  padding: 8px 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--txt2);
  display: flex; align-items: center; gap: 8px;
  user-select: none;
  -webkit-tap-highlight-color: transparent; /* iOS-Tap-Highlight-Bar weg */
  outline: none;
  transition: color 0.15s;
}
.cm-more-details > summary::-webkit-details-marker { display: none; }
.cm-more-details > summary:focus-visible { color: var(--txt); }
.cm-more-details > summary:hover { color: var(--txt); }
.cm-more-details > summary::-webkit-details-marker { display: none; }
.cm-more-details > summary::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(-45deg);
  transition: transform 0.18s;
}
.cm-more-details[open] > summary::before {
  transform: rotate(45deg);
}
.cm-more-body {
  padding-top: 8px;
  /* Smoother fade-in beim Aufklappen — natives <details> snapt sonst hart */
  animation: cm-more-fade 0.26s cubic-bezier(0.22, 0.9, 0.24, 1) both;
}
@keyframes cm-more-fade {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0);    }
}
@media (prefers-reduced-motion: reduce) {
  .cm-more-body { animation: none; }
}

/* Legacy — keep for compat */
.todo-entry { display: flex; align-items: flex-start; gap: 12px; padding: 14px 20px; border-bottom: 1px solid var(--border); transition: background 0.15s; border-left: 3px solid transparent; cursor: pointer; }
.todo-entry:hover { background: var(--surface); }
.todo-entry.done { opacity: 0.45; }
.todo-entry[data-prio="high"]     { border-left-color: var(--red); }
.todo-entry[data-prio="medium"]   { border-left-color: var(--amber); }
.todo-entry[data-prio="none"]     { border-left-color: var(--txt3); }
.maint-entry { display: flex; align-items: flex-start; gap: 12px; padding: 14px 20px; border-bottom: 1px solid var(--border); cursor: pointer; transition: background 0.15s; }
.maint-entry:hover { background: var(--surface); }

/* ── KM QUICK EDIT ──────────────────────────────────────────────────── */
.km-quick { display: inline-flex; align-items: center; gap: 6px; }
.km-quick input {
  font-family: var(--mono); font-size: 16px; width: 100px;
  padding: 3px 8px; border-radius: var(--r);
  border: 1px solid var(--accent); background: var(--surface2);
  color: var(--txt); text-align: right;
}
.km-quick button {
  font-family: var(--mono); font-size: 11px; padding: 4px 10px;
  border-radius: var(--r); border: 1px solid var(--accent);
  background: var(--accent); color: #fff; cursor: pointer;
}

/* ── EDITORIAL ENTRY-DETAIL (Magazin-Spec-Sheet, Petrolicious-Tonalität) ─────
   Hero-Title prominent + Mono-Caps-Meta-Line + Spec-Sheet-Layout für Daten.
   Hairlines + Whitespace statt Boxen. Keine Bunten Pills, sparsame Akzente. */
.modal-editorial .modal-body {
  padding: 0;
}
/* Header-Bar verschwindet visuell — Buttons werden zu floating Icons
   die über dem Hero schweben. Cleaner Magazine-Look ohne separaten Balken. */
.modal-editorial .modal-header-minimal {
  position: absolute;
  top: 0; right: 0; left: 0;
  padding: 10px 12px;
  background: transparent;
  border-bottom: none;
  z-index: 5;
  min-height: 0;
  display: flex; align-items: center; justify-content: flex-end;
  gap: 8px;
}
.modal-editorial .modal-header-minimal .btn-icon {
  margin: 0;
  width: 32px; height: 32px;
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--txt2);
  transition: background .15s, color .15s;
}
.modal-editorial .modal-header-minimal .btn-icon:hover {
  background: rgba(255,255,255,0.08);
  color: var(--txt);
}
/* Modal-Body fängt direkt am Top an — Header schwebt drüber */
.modal-editorial .modal-body { position: relative; }

/* Kebab-Button (3 Punkte) — gleicher Stil wie X-Close (erbt von btn-icon) */
.ed-kebab-btn { /* nichts zusätzlich nötig — erbt von .modal-editorial .modal-header-minimal .btn-icon */ }

/* Kebab-Dropdown — floated direkt unter dem Button, blur Hintergrund */
.ed-kebab-menu {
  position: absolute;
  top: 50px; right: 56px;  /* unter dem Kebab-Button (X liegt rechts daneben) */
  z-index: 6;
  min-width: 180px;
  background: rgba(20,20,24,0.92);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
  animation: edKebabIn 0.16s cubic-bezier(0.16, 1, 0.3, 1);
}
.ed-kebab-menu[hidden] { display: none; }
@keyframes edKebabIn {
  from { opacity: 0; transform: translateY(-4px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.ed-kebab-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 10px 12px;
  background: none; border: none; cursor: pointer;
  font-family: var(--cond); font-weight: 500; font-size: 14px;
  color: var(--txt); text-align: left;
  border-radius: 6px;
  transition: background .12s, color .12s;
}
.ed-kebab-item:hover { background: rgba(255,255,255,0.06); }
.ed-kebab-item-danger { color: var(--red); }
.ed-kebab-item-danger:hover { background: rgba(224,53,53,0.12); }

/* Footer — zwei Varianten: solo (nur Bearbeiten) oder dual (Bearbeiten + Aktion) */
.modal-footer-solo,
.modal-footer-dual {
  padding: 14px 26px 18px;
  border-top: 1px solid var(--border);
  display: flex; gap: 10px;
}
@media (max-width: 480px) {
  .modal-footer-solo,
  .modal-footer-dual { padding: 12px 18px 16px; }
}
/* Solo: Bearbeiten nimmt volle Breite */
.modal-footer-solo .ed-secondary-btn {
  flex: 1; padding: 13px 16px;
  font-family: var(--cond); font-weight: 600; font-size: 15px;
  letter-spacing: 0.01em;
}
/* Dual: Bearbeiten links (secondary), Primary rechts (1.4× Gewicht) */
.modal-footer-dual .ed-secondary-btn {
  flex: 1; padding: 13px 16px;
  font-family: var(--cond); font-weight: 600; font-size: 14px;
  letter-spacing: 0.01em;
}
.modal-footer-dual .ed-primary-btn {
  flex: 1.4; padding: 13px 16px;
  font-family: var(--cond); font-weight: 600; font-size: 15px;
  letter-spacing: 0.01em;
}
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Hero — Editorial Magazine Cover-Look. Pro Modal-Typ + Status ein eigenes
   Akzent-Glow (subtle linear-gradient) am Top-Rand. Damit fühlt sich jedes
   Detail individuell aber konsistent an — Petrolicious-DNA.
   Padding-Top groß genug für floating Header-Buttons (X + Kebab). */
.entry-detail-task .ed-hero,
.entry-detail-mod  .ed-hero,
.entry-detail-maint .ed-hero,
.entry-detail-fuel  .ed-hero {
  position: relative;
  padding: 60px 26px 20px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 22px;
}
/* Status-driven Glow am Top (z-stacking via pseudo-element für sauberen Layout) */
.entry-detail-task.is-done .ed-hero,
.entry-detail-mod.is-done   .ed-hero,
.entry-detail-fuel          .ed-hero {
  background: linear-gradient(180deg, rgba(74,222,128,0.06), transparent 80%);
}
/* Geplant (Mod) + Offen (Task) — gemeinsame neutrale Glow-Optik.
   Subtiles Weiß damit's sichtbar bleibt, aber keine Urgency suggeriert. */
.entry-detail-mod.is-planned .ed-hero,
.entry-detail-task:not(.is-done) .ed-hero {
  background: linear-gradient(180deg, rgba(255,255,255,0.05), transparent 80%);
}
/* Maint: Status aus dem Hero-Pill ableiten (CSS-Container-Query-Light via :has) */
.entry-detail-maint .ed-hero:has(.ed-hero-pill-overdue) {
  background: linear-gradient(180deg, rgba(224,53,53,0.07), transparent 80%);
}
.entry-detail-maint .ed-hero:has(.ed-hero-pill-soon) {
  background: linear-gradient(180deg, rgba(201,168,76,0.07), transparent 80%);
}
.entry-detail-maint .ed-hero:has(.ed-hero-pill-done) {
  background: linear-gradient(180deg, rgba(74,222,128,0.06), transparent 80%);
}
.ed-hero-title {
  margin: 0 0 12px;
  font-family: var(--cond);
  font-size: 30px; font-weight: 800;
  letter-spacing: -0.012em;
  color: var(--txt);
  line-height: 1.08;
}
@media (max-width: 480px) {
  .ed-hero-title { font-size: 26px; }
  .entry-detail-task .ed-hero,
  .entry-detail-mod  .ed-hero,
  .entry-detail-maint .ed-hero,
  .entry-detail-fuel  .ed-hero {
    padding: 56px 18px 18px;
  }
}
.ed-hero-meta {
  display: flex; flex-wrap: wrap; align-items: center;
  gap: 8px;
}
.ed-hero-pill {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--mono); font-size: 10.5px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt2);
}
.ed-hero-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--txt3);
  box-shadow: 0 0 8px currentColor;
}
.ed-hero-pill-prio-high   { color: var(--red); }
.ed-hero-pill-prio-high   .ed-hero-dot { background: var(--red); }
.ed-hero-pill-prio-medium { color: var(--amber); }
.ed-hero-pill-prio-medium .ed-hero-dot { background: var(--amber); }
.ed-hero-pill-done        { color: var(--green); }
.ed-hero-pill-done        .ed-hero-dot { background: var(--green); }
.ed-hero-pill-overdue     { color: var(--red); }
.ed-hero-pill-overdue     .ed-hero-dot { background: var(--red); }
.ed-hero-pill-soon        { color: var(--amber); }
.ed-hero-pill-soon        .ed-hero-dot { background: var(--amber); }
/* "Geplant" (Mod) matched die "Offen"-Optik bei Tasks — neutral, kein
   Akzent-Blau. Beides "noch nicht erledigt" → konsistent grau. */
.ed-hero-pill-planned     { color: var(--txt2); }
.ed-hero-pill-planned     .ed-hero-dot { background: var(--txt3); }
.ed-hero-sep {
  color: var(--txt3); opacity: 0.5;
  font-family: var(--mono); font-size: 11px;
}
.ed-hero-group {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3);
}

/* SPECS — Magazin-Spec-Sheet: Label klein Mono-Caps oben, Value groß Cond unten.
   Gemeinsam für alle Detail-Modal-Varianten (task/mod/maint/fuel). */
.entry-detail-task .ed-specs,
.entry-detail-mod  .ed-specs,
.entry-detail-maint .ed-specs,
.entry-detail-fuel  .ed-specs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 18px 24px;
  padding: 0 26px 22px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border);
}
@media (max-width: 480px) {
  .entry-detail-task .ed-specs,
  .entry-detail-mod  .ed-specs,
  .entry-detail-maint .ed-specs,
  .entry-detail-fuel  .ed-specs {
    padding-left: 18px; padding-right: 18px;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px 18px;
  }
}
.ed-spec {
  display: flex; flex-direction: column; gap: 4px;
  min-width: 0;
}
.ed-spec-label {
  font-family: var(--mono); font-size: 9.5px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt3);
}
.ed-spec-value {
  font-family: var(--cond); font-size: 19px; font-weight: 700;
  color: var(--txt);
  letter-spacing: -0.005em;
  line-height: 1.15;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ed-spec-value-accent { color: var(--accent); }
.entry-detail-task.is-done .ed-spec-value-accent { color: var(--green); }

/* Block-Sections für Teile / Notizen / Fotos — generous padding, hairline-divided.
   Konsistent für alle Detail-Modal-Typen (task/mod/maint/fuel). */
.entry-detail-task .ed-section,
.entry-detail-mod  .ed-section,
.entry-detail-maint .ed-section,
.entry-detail-fuel  .ed-section {
  padding: 18px 26px;
  margin-bottom: 0;
  border-bottom: 1px solid var(--border);
}
.entry-detail-task .ed-section:last-child,
.entry-detail-mod  .ed-section:last-child,
.entry-detail-maint .ed-section:last-child,
.entry-detail-fuel  .ed-section:last-child { border-bottom: none; }
@media (max-width: 480px) {
  .entry-detail-task .ed-section,
  .entry-detail-mod  .ed-section,
  .entry-detail-maint .ed-section,
  .entry-detail-fuel  .ed-section {
    padding-left: 18px; padding-right: 18px;
  }
}
.entry-detail-task .ed-label,
.entry-detail-mod  .ed-label,
.entry-detail-maint .ed-label,
.entry-detail-fuel  .ed-label {
  font-family: var(--mono); font-size: 9.5px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt3);
  margin-bottom: 10px;
}
.entry-detail-task .ed-value,
.entry-detail-mod  .ed-value,
.entry-detail-maint .ed-value,
.entry-detail-fuel  .ed-value {
  font-family: var(--cond); font-size: 16px; font-weight: 500;
  color: var(--txt2);
  line-height: 1.5;
  letter-spacing: -0.003em;
}

/* ── ENTRY DETAIL / MODAL LABELS ──────────────────────────────────────── */
.ed-label {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 5px;
}
.ed-value { font-size: 15px; color: var(--txt); line-height: 1.5; }
.ed-meta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ed-section { margin-bottom: 18px; }
.ed-section:last-child { margin-bottom: 0; }
.ed-images { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
.ed-images img {
  width: 100px; height: 100px; object-fit: cover; border-radius: 6px; cursor: pointer;
  -webkit-tap-highlight-color: transparent; outline: none;
}
.ed-images img:focus, .ed-images img:focus-visible { outline: none; }
.ed-badge {
  display: inline-block; padding: 4px 10px; border-radius: 20px;
  font-family: var(--mono); font-size: 11px;
  background: var(--surface2); color: var(--txt2);
}
.ed-badge.overdue { background: rgba(224,53,53,0.15); color: var(--red); }
.ed-badge.soon { background: rgba(201,168,76,0.15); color: var(--amber); }

/* Task-Preview Header: Prio + Gruppe als Mono-Caps Zeile mit Hairline-Trenner */
.ed-task-head {
  display: flex; flex-wrap: wrap; align-items: center; gap: 12px;
  padding-bottom: 14px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.ed-task-status {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt2);
}
.ed-task-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--txt3);
  box-shadow: 0 0 6px currentColor;
}
.ed-task-prio-high   { color: var(--red); }
.ed-task-prio-high   .ed-task-dot { background: var(--red); }
.ed-task-prio-medium { color: var(--amber); }
.ed-task-prio-medium .ed-task-dot { background: var(--amber); }
.ed-task-prio-none   { color: var(--txt2); }
.ed-task-prio-none   .ed-task-dot { background: var(--txt3); }
.ed-task-status-open { color: var(--txt2); }
.ed-task-status-open .ed-task-dot { background: var(--txt3); }
.ed-task-status-done { color: var(--green); }
.ed-task-status-done .ed-task-dot { background: var(--green); }
.ed-task-group {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--txt3);
}

@media (max-width: 640px) {
  .vic-hero { height: 200px; }
  .vic-name { font-size: 26px; }
  .ed-meta-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .ed-images img { width: 80px; height: 80px; }
}

/* ── IMAGE GALLERY / LIGHTBOX ──────────────────────────────────────── */
.gallery-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: #000; overflow: hidden;
  display: flex; flex-direction: column;
  touch-action: none; outline: none;
}
.gallery-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; flex-shrink: 0; z-index: 2;
}
.gallery-counter {
  font-family: var(--mono); font-size: 13px; color: rgba(255,255,255,0.7);
  letter-spacing: 0.04em;
}
.gallery-close {
  background: none; border: none; color: #fff; font-size: 24px;
  width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; border-radius: 50%; transition: background 0.2s;
}
.gallery-close:hover { background: rgba(255,255,255,0.1); }
#gallery-track {
  flex: 1; position: relative; overflow: hidden;
}
.gallery-slide {
  position: absolute; inset: 0; width: 100%;
  display: flex; align-items: center; justify-content: center;
  padding: 0 16px; box-sizing: border-box;
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.gallery-slide img {
  max-width: 100%; max-height: 100%; object-fit: contain;
  border-radius: 4px; user-select: none; -webkit-user-drag: none;
  transition: transform 0.3s;
}
.gallery-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,0.1); border: none; color: #fff;
  font-size: 32px; width: 48px; height: 48px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background 0.2s, opacity 0.2s; z-index: 2;
}
.gallery-nav:hover { background: rgba(255,255,255,0.2); }
.gallery-prev { left: 12px; }
.gallery-next { right: 12px; }
.gallery-dots {
  display: flex; justify-content: center; gap: 8px;
  padding: 16px; flex-shrink: 0; z-index: 2;
}
.gallery-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,0.3); transition: all 0.3s;
}
.gallery-dot.active {
  background: #fff; transform: scale(1.3);
}

/* Lightbox-Caption: Quelle + Datum, optional klickbar zum Detail */
.gallery-caption {
  position: absolute; bottom: 56px; left: 50%; transform: translateX(-50%);
  z-index: 4; pointer-events: auto;
  display: flex; align-items: center; gap: 10px;
  max-width: calc(100% - 32px);
  padding: 10px 16px;
  background: rgba(13,13,13,0.62);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
          backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 99px;
  color: #fff;
  transition: background 0.18s, border-color 0.18s, transform 0.18s;
  cursor: default;
}
.gallery-caption.navable { cursor: pointer; }
.gallery-caption.navable:hover {
  background: rgba(13,13,13,0.82);
  border-color: rgba(255,255,255,0.24);
}
.gallery-caption.navable:active { transform: translateX(-50%) scale(0.97); }
.gallery-caption-text {
  display: flex; align-items: center; gap: 10px;
  min-width: 0; overflow: hidden; flex: 1;
}
.gallery-caption-source {
  font-family: var(--cond); font-size: 13px; font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.gallery-caption-date {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  color: rgba(255,255,255,0.7);
  white-space: nowrap; flex-shrink: 0;
  padding-left: 10px;
  border-left: 1px solid rgba(255,255,255,0.18);
}
.gallery-caption-arrow {
  flex-shrink: 0; opacity: 0.7; margin-right: -2px;
}

@media (max-width: 640px) {
  .gallery-nav { display: none; }
  .gallery-header { padding: 12px 16px; }
  .gallery-dots { padding: 12px; gap: 6px; }
  .gallery-dot { width: 6px; height: 6px; }
  .gallery-caption {
    bottom: 36px;
    padding: 8px 14px;
    max-width: calc(100% - 24px);
  }
  .gallery-caption-source { font-size: 12px; }
}

/* ── PHOTO OVERVIEW ──────────────────────────────────────────────── */
.pov-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: var(--bg);
  overflow-y: auto; overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  animation: pov-slide-up 0.34s cubic-bezier(0.22, 0.9, 0.24, 1);
  transform-origin: bottom;
}
.pov-overlay.pov-closing {
  animation: pov-slide-down 0.22s cubic-bezier(0.4, 0, 1, 1) forwards;
  pointer-events: none;
}
@keyframes pov-slide-up {
  from { opacity: 0; transform: translateY(32px) scale(0.985); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
@keyframes pov-slide-down {
  from { opacity: 1; transform: translateY(0); }
  to   { opacity: 0; transform: translateY(36px); }
}
@media (prefers-reduced-motion: reduce) {
  .pov-overlay { animation: fadeIn 0.18s ease; }
  .pov-overlay.pov-closing { animation: fadeOut 0.18s ease forwards; }
}
@keyframes fadeOut {
  to { opacity: 0; }
}
/* Single sticky wrapper — one blur, no seam */
.pov-sticky-wrap {
  position: sticky; top: 0; z-index: 10;
  background: var(--bg);
  transition: background 0.25s, box-shadow 0.25s;
}
.pov-sticky-wrap.is-sticky {
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  background: rgba(13,13,13,0.82);
  box-shadow: 0 4px 16px rgba(0,0,0,0.35);
}
.pov-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--border);
  max-width: 880px; width: 100%; margin: 0 auto;
}
.pov-sticky-wrap.is-sticky .pov-header { border-bottom-color: rgba(255,255,255,0.07); }
.pov-title { font-family: var(--cond); font-size: 18px; font-weight: 700; letter-spacing: 0.02em; }
.pov-close {
  background: var(--surface2); border: none; color: var(--txt);
  width: 36px; height: 36px; border-radius: 50%; font-size: 18px;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.pov-filters {
  display: flex; gap: 8px; padding: 12px 16px; border-bottom: 1px solid var(--border);
  overflow-x: auto; scrollbar-width: none;
  max-width: 880px; width: 100%; margin: 0 auto; box-sizing: border-box;
}
.pov-filters::-webkit-scrollbar { display: none; }
.pov-sticky-wrap.is-sticky .pov-filters {
  border-bottom-color: rgba(30,30,36,0.5);
}
.pov-filter {
  flex-shrink: 0; background: var(--surface2); border: 1px solid var(--border2);
  color: var(--txt2); font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 6px 14px; border-radius: 20px; cursor: pointer; transition: all 0.15s;
}
.pov-filter.active {
  background: var(--accent); border-color: var(--accent); color: #fff;
}

/* Sortier-Reihe unter den Filtern */
.pov-sort {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-bottom: 1px solid var(--border);
  overflow-x: auto; scrollbar-width: none;
  max-width: 880px; width: 100%; margin: 0 auto; box-sizing: border-box;
}
.pov-sort::-webkit-scrollbar { display: none; }
.pov-sort-label {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.10em;
  color: var(--txt3); margin-right: 4px;
  flex-shrink: 0;
}
.pov-sort-btn {
  flex-shrink: 0; background: transparent;
  border: 1px solid transparent; color: var(--txt2);
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.05em;
  padding: 4px 10px; border-radius: 14px;
  cursor: pointer; transition: all 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.pov-sort-btn:hover { color: var(--txt); }
.pov-sort-btn.active {
  background: var(--surface2); border-color: var(--border2);
  color: var(--txt);
}
.pov-sticky-wrap.is-sticky .pov-sort {
  border-bottom-color: rgba(30,30,36,0.5);
}
.pov-scroll {
  padding: 16px;
  max-width: 880px; width: 100%; margin: 0 auto; box-sizing: border-box;
}
.pov-section { margin-bottom: 36px; }
/* Sticky Section-Header — wechselt beim Scrollen automatisch zur nächsten Sektion.
   Apple-Photos-Manier. top wird via CSS-Var --pov-wrap-h dynamisch von JS
   gesetzt (Höhe vom darüberliegenden sticky Header+Filter-Wrap). */
.pov-section-head {
  display: flex; align-items: center; gap: 10px;
  margin: 0 -16px 14px;       /* überlappt scroll-padding für volle Breite */
  padding: 12px 16px 10px;
  position: sticky;
  top: var(--pov-wrap-h, 110px);
  z-index: 5;
  background: rgba(13,13,13,0.78);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
          backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background 0.18s, border-color 0.18s;
}
.pov-section-icon { font-size: 14px; }
.pov-section-title {
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--accent);
  flex: 1;
}
.pov-section-count {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.06em;
}
.pov-group { margin-bottom: 22px; }
/* Sticky Sub-Group-Label: kleben unterhalb des Section-Headers, wechseln
   beim Scrollen zur nächsten Sub-Group (z.B. "Bremsen · 12. Mai" → "Öl · 8. Apr"). */
.pov-group-label {
  position: sticky;
  top: calc(var(--pov-wrap-h, 110px) + var(--pov-section-h, 44px));
  z-index: 4;
  margin: 0 -16px 9px;
  padding: 8px 16px;
  background: rgba(13,13,13,0.62);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
          backdrop-filter: blur(12px) saturate(140%);
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 12px; color: var(--txt2);
  letter-spacing: 0.02em;
}
.pov-group-label .pov-group-link {
  /* Volle Klickbarkeit der ganzen Sub-Group-Label-Zeile */
  width: 100%; padding: 0;
  background: transparent;
}

/* Mosaic-Grid via column-count — Bilder respektieren ihre Aspect-Ratio,
   Pinterest-/BAT-Stil. Aspekt-vielfältige Galerien sehen kuratiert aus. */
.pov-grid {
  column-count: 3;
  column-gap: 4px;
}
@media (max-width: 600px) {
  .pov-grid { column-count: 2; column-gap: 4px; }
}
@media (min-width: 1100px) {
  .pov-grid { column-count: 4; }
}
.pov-thumb {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  margin: 0 0 4px;
  display: block;
  position: relative;
  overflow: hidden; cursor: pointer;
  border-radius: 6px;
  /* Tap-Feedback unterdrücken: kein blauer iOS-Highlight, kein Focus-Outline */
  -webkit-tap-highlight-color: transparent;
  outline: none;
  /* Skeleton-Shimmer solange Bild lädt */
  background: linear-gradient(
    90deg,
    var(--surface) 0%,
    var(--surface2) 50%,
    var(--surface) 100%
  );
  background-size: 200% 100%;
  animation: pov-shimmer 1.5s ease-in-out infinite;
  transition: transform 0.22s cubic-bezier(0.22, 0.9, 0.24, 1),
              box-shadow 0.22s ease;
  will-change: transform;
}
.pov-thumb:focus,
.pov-thumb:focus-visible { outline: none; }
/* Lightbox offen → Hover-Lift am Thumb sofort zurücksetzen, sodass kein
   Schatten/Outline durch den Lightbox-Backdrop schimmern kann */
body.gallery-open .pov-thumb {
  transform: none !important;
  box-shadow: none !important;
  z-index: auto !important;
  transition: none !important;
}
.pov-thumb.loaded {
  background: var(--surface);
  animation: none;
}
@keyframes pov-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.pov-thumb img {
  width: 100%; height: auto; display: block;
  opacity: 0;
  transition: opacity 0.4s ease-out;
}
.pov-thumb img.loaded { opacity: 1; }
@media (hover: hover) {
  .pov-thumb:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 32px rgba(0,0,0,0.45);
    z-index: 1;
  }
  .pov-thumb:hover .pov-del-btn { opacity: 1; }
}
.pov-thumb:active {
  transform: scale(0.97);
  transition-duration: 0.1s;
}
.pov-del-btn {
  position: absolute; top: 6px; right: 6px;
  background: rgba(0,0,0,0.7);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fff;
  width: 26px; height: 26px; border-radius: 50%;
  font-size: 13px; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.18s, background 0.18s; z-index: 2;
}
.pov-del-btn:hover { background: rgba(209,72,72,0.85); }
@media (hover: none) { .pov-del-btn { opacity: 1; } }
.pov-group-link {
  display: flex; align-items: center; justify-content: space-between; gap: 6px;
  width: 100%; background: none; border: none; padding: 0;
  font-size: 12px; color: var(--txt2); cursor: pointer; text-align: left;
}
.pov-group-link svg { flex-shrink: 0; opacity: 0.45; }
.pov-empty {
  text-align: center; padding: 40px 20px;
  color: var(--txt3); font-size: 14px;
}

/* ── ENTRY DETAIL VIEW ─────────────────────────────────────────────── */
.entry-detail { padding: 0; }

/* ── DRAG HANDLE & RECEIPT ──────────────────────────────────────────────── */
.me-drag-handle {
  font-size: 18px; color: var(--txt3); cursor: grab; padding: 0 6px 0 0;
  display: flex; align-items: center; touch-action: none; flex-shrink: 0;
  user-select: none; -webkit-user-select: none;
}
.drag-over { border-top: 2px solid var(--accent) !important; }
.drag-over-after { border-bottom: 2px solid var(--accent) !important; }
.me-badges { margin-top: 3px; display: flex; gap: 4px; flex-wrap: wrap; }
.me-badge {
  font-size: 11px; color: var(--txt2); background: var(--surface2);
  border-radius: 4px; padding: 2px 6px;
}
.me-badge-receipt { color: var(--accent); }
.receipt-upload-area {
  border: 2px dashed var(--border2); border-radius: var(--r); padding: 12px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  min-height: 56px; transition: border-color 0.2s;
}
.receipt-upload-area:hover { border-color: var(--accent); }
.receipt-placeholder { color: var(--txt2); font-size: 13px; }

/* ── FAHRZEUG TAB ───────────────────────────────────────────────────────── */
.vic-img-clickable { cursor: pointer; }
.vic-img-clickable:hover img { opacity: 0.85; }
/* (vfz-section / vfz-section-header — entfernt mit Premium-Detail-Panel-Refactor Mai 2026) */
.vehicle-photo-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
  margin-bottom: 0;
}
.vehicle-photo-thumb {
  aspect-ratio: 1; border-radius: 6px; overflow: hidden;
  background: var(--surface2); cursor: pointer; position: relative;
}
.vehicle-photo-thumb img {
  width: 100%; height: 100%; object-fit: cover; transition: opacity 0.15s;
}
.vehicle-photo-thumb:hover img { opacity: 0.85; }
.vph-delete {
  position: absolute; top: 4px; right: 4px;
  background: rgba(0,0,0,0.6); border: none; color: #fff;
  width: 22px; height: 22px; border-radius: 50%; font-size: 11px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
}
/* ── VEHICLE MODAL TABS ─────────────────────────────────────────────────── */
.vm-tab-bar {
  flex-shrink: 0; padding: 8px 16px;
  border-bottom: 1px solid var(--border); background: var(--bg);
  display: flex; align-items: center;
}
.vm-tab-toggle {
  display: flex; border-radius: 20px; border: 1px solid var(--border2);
  padding: 3px; gap: 2px;
}
/* 3-tab variant stretches the toggle to full bar width */
.vm-tab-toggle--3 {
  flex: 1;
}
.vm-tab-toggle--3 .vm-tab-btn {
  flex: 1; padding: 5px 8px;
}
.vm-tab-btn {
  padding: 5px 22px; border-radius: 16px; border: none;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  background: transparent; color: var(--txt3); cursor: pointer;
  transition: background 0.18s, color 0.18s; min-height: 30px;
  white-space: nowrap;
}
.vm-tab-btn.active { background: var(--accent); color: #fff; }
.vm-tab-btn:hover:not(.active) { color: var(--txt2); }

/* ── VIC PANEL TABS (Basis / Technik) ──────────────────────────────────── */
.vic-panel-tabs {
  display: flex; gap: 0; margin-bottom: 14px;
  border-radius: 20px; border: 1px solid var(--border2);
  padding: 3px; background: transparent; width: fit-content;
}
/* 3-tab variant stretches to full width so all labels fit */
.vic-panel-tabs--3 {
  width: 100%;
}
.vic-panel-tabs--3 .vic-panel-tab-btn {
  flex: 1; padding: 5px 8px;
}
.vic-panel-tab-btn {
  --vic-pill-progress: 0;
  padding: 5px 20px; border-radius: 16px; border: none;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  cursor: pointer;
  transition: background 0.18s, color 0.18s; min-height: 30px;
  white-space: nowrap;
  /* Fallback für ältere Browser (Samsung Internet < 2023, iOS Safari < 16.2) */
  background: transparent;
  color: var(--txt3);
}
/* Modern: color-mix mit Live-Drag-Sync. Wird automatisch ignoriert wenn
   Browser color-mix() nicht unterstützt → fallback oben greift. */
@supports (background: color-mix(in srgb, red, blue)) {
  .vic-panel-tab-btn {
    background: color-mix(in srgb, var(--accent) calc(var(--vic-pill-progress) * 100%), transparent);
    color: color-mix(in srgb, #fff calc(var(--vic-pill-progress) * 100%), var(--txt3));
  }
}
/* Active-Fallback: für ältere Browser ohne color-mix sichtbar (solid accent) */
.vic-panel-tab-btn.active { --vic-pill-progress: 1; background: var(--accent); color: #fff; }
@supports (background: color-mix(in srgb, red, blue)) {
  .vic-panel-tab-btn.active { background: color-mix(in srgb, var(--accent) 100%, transparent); }
}
.vic-panel-tab-btn:hover:not(.active) { color: var(--txt2); }
/* Während Live-Drag: Transition aus, damit Pill 1:1 dem Finger folgt */
.vic-panel-tabs.is-vic-dragging .vic-panel-tab-btn { transition: none !important; }

/* (vfz-section-label entfernt — Cards haben eigene .vfz-card-label) */

/* Modal techSpecs section */
.form-section-divider {
  font-family: var(--cond); font-size: 11px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--txt3);
  border-top: 1px solid var(--border); margin: 18px 0 14px; padding-top: 14px;
}
.form-section-sub-label {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--txt3);
  margin-bottom: 8px;
}

/* Tech fluid groups in modal */
.tech-fluid-group {
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 10px 10px 4px;
  margin-bottom: 8px;
  background: var(--surface2);
}
.tech-fluid-group-title {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--txt3);
  margin-bottom: 8px;
}
.tech-fluid-group .form-group { margin-bottom: 6px; }
.tech-fluid-group .form-row { gap: 8px; }

/* Custom tech fields in modal */
.tech-custom-add-btn {
  width: 100%; margin-top: 4px; padding: 9px 0;
  border-radius: var(--r); border: 1px dashed var(--border2);
  background: transparent; color: var(--txt3);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  cursor: pointer; transition: border-color 0.15s, color 0.15s;
}
.tech-custom-add-btn:hover { border-color: var(--accent); color: var(--accent); }

/* editable rows — same visual rhythm as vfz-info-grid */
.tech-custom-grid {
  border: 1px solid var(--border2); border-radius: var(--r);
  overflow: hidden; margin-bottom: 8px;
}
.tech-custom-item {
  display: flex; align-items: stretch;
  border-bottom: 1px solid var(--border);
}
.tech-custom-item:last-child { border-bottom: none; }
.tech-custom-label-input {
  width: 130px; flex-shrink: 0; padding: 10px 12px;
  background: transparent; border: none; outline: none;
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.tech-custom-label-input:focus { color: var(--txt); }
.tech-custom-value-input {
  flex: 1; min-width: 0; padding: 10px 12px;
  background: transparent; border: none; outline: none;
  border-left: 1px solid var(--border);
  font-family: var(--body); font-size: 14px; color: var(--txt);
}
.tech-custom-del {
  flex-shrink: 0; padding: 0 12px;
  background: none; border: none; border-left: 1px solid var(--border);
  color: var(--txt3); cursor: pointer; font-size: 16px;
  transition: color 0.15s;
}
.tech-custom-del:hover { color: var(--red); }

.vfz-empty { color: var(--txt3); font-size: 13px; padding: 16px 0 8px; line-height: 1.6; text-align: center; }

/* ── DOCUMENTS TAB — Editorial Hairline-Pattern ──────────────────────────── */

/* Group: TÜV / Gutachten / Rechnung / Sonstiges (or Monat / Buchstabe) */
.doc-group { margin-bottom: 24px; }
.doc-group:last-of-type { margin-bottom: 16px; }

.doc-group-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 10px 0 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2px;
}
.doc-group-label {
  font-family: var(--mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt2);
}
.doc-group-count {
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.14em;
  color: var(--txt3);
}
/* Origin-Badge für virtuelle Einträge (Rechnungen aus Aufgaben/Service) */
.doc-row-origin {
  font-family: var(--mono);
  font-size: 9px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent);
  border: 1px solid rgba(61,90,241,0.4);
  padding: 1px 5px; border-radius: 3px;
  background: rgba(61,90,241,0.08);
}

.doc-group-list {
  display: flex; flex-direction: column;
}

.doc-row {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 4px;
  border-bottom: 1px solid var(--border);
  background: transparent;
  border-left: 0; border-right: 0; border-top: 0;
  cursor: pointer;
  text-align: left;
  color: var(--txt); font-family: inherit;
  width: 100%;
}
.doc-row:last-child { border-bottom: none; }
.doc-row:hover { background: rgba(255,255,255,0.025); }

.doc-row-thumb {
  position: relative;
  width: 44px; height: 44px; border-radius: 6px;
  background: var(--surface2);
  border: 1px solid var(--border);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.doc-row-thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.doc-row-thumb-fallback {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: var(--txt3); opacity: 0.45;
}
.doc-row-thumb-fallback svg { width: 20px; height: 20px; }
.doc-row-thumb-fallback em {
  display: block; font-style: normal;
  font-family: var(--mono); font-size: 8px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  margin-top: 2px;
}
/* Wenn Cover ein PDF ist: rötlicher Akzent statt grauem Fallback */
.doc-row-thumb-pdf {
  background: linear-gradient(180deg, rgba(220,38,38,0.10), rgba(220,38,38,0.04));
}
.doc-row-thumb-pdf .doc-row-thumb-fallback {
  color: rgba(248,113,113,0.95); opacity: 1;
}
.doc-row-thumb-count {
  position: absolute; right: 2px; bottom: 2px;
  background: rgba(0,0,0,0.78); color: #fff;
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  padding: 1px 5px; border-radius: 4px; line-height: 1.4;
  letter-spacing: 0.04em;
}

.doc-row-body { min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.doc-row-name {
  font-family: var(--cond);
  font-size: 17px; font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--txt);
  line-height: 1.15;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.doc-row-meta {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--txt3);
  display: flex; align-items: center; gap: 6px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.doc-row-sep { color: var(--border2); }
.doc-row-cat { color: var(--txt2); }

.doc-row-chev {
  color: var(--txt3); opacity: 0.4;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.doc-row:hover .doc-row-chev { opacity: 0.75; color: var(--txt2); }

/* Add-Trigger (bleibt Akzent-Dashed-CTA) */
.doc-add-trigger {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%;
  padding: 12px 16px;
  margin-top: 8px;
  background: transparent;
  border: 1px dashed rgba(61,90,241,0.45);
  border-radius: 10px;
  cursor: pointer;
  color: var(--accent);
  font-family: var(--mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  transition: background 0.18s, border-color 0.18s, color 0.18s;
}
.doc-add-trigger:hover {
  background: rgba(61,90,241,0.08);
  border-color: var(--accent);
  border-style: solid;
}

/* ── DOC ADD/EDIT MODAL ──────────────────────────────────────────────────── */
.doc-add-overlay {
  position: fixed; inset: 0; z-index: 600; /* > FAB (500) */
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: flex-end; justify-content: center;
  animation: doc-fade-in 0.18s ease-out;
}
@keyframes doc-fade-in { from { opacity: 0; } to { opacity: 1; } }
.doc-add-sheet {
  width: 100%; max-width: 560px;
  background: var(--surface); border-radius: 18px 18px 0 0;
  border: 1px solid var(--border2); border-bottom: none;
  display: flex; flex-direction: column; max-height: 92vh;
  animation: doc-slide-up 0.28s cubic-bezier(0.32,0.72,0,1);
  padding-bottom: env(safe-area-inset-bottom);
  /* Keyboard-Aware: margin-bottom smooth animieren statt hart springen */
  transition: margin-bottom 0.22s cubic-bezier(0.22, 0.9, 0.24, 1);
}
@keyframes doc-slide-up {
  from { transform: translateY(100%); }
  to   { transform: translateY(0);    }
}
.doc-add-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px 12px; border-bottom: 1px solid var(--border);
}
.doc-add-title { font-family: var(--cond); font-size: 20px; font-weight: 800; color: var(--txt); }
.doc-add-close {
  background: none; border: none; color: var(--txt3); font-size: 18px;
  cursor: pointer; width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.doc-add-close:hover { color: var(--txt); background: rgba(255,255,255,0.06); }
.doc-add-body { padding: 14px 18px 4px; overflow-y: auto; }
.doc-add-thumbs {
  display: flex; gap: 8px; margin-bottom: 14px; overflow-x: auto;
  scrollbar-width: none;
}
.doc-add-thumbs::-webkit-scrollbar { display: none; }
.doc-add-thumb {
  flex-shrink: 0; width: 88px; height: 110px;
  border-radius: 8px; overflow: hidden; background: var(--surface2);
}
.doc-add-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* PDF-Tile in Doc-Add-Modal — Editorial Treatment, dezenter PDF-Akzent */
.doc-add-thumb-pdf {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px;
  background: linear-gradient(180deg, rgba(220,38,38,0.10), rgba(220,38,38,0.04));
  border: 1px solid rgba(220,38,38,0.20);
  color: rgba(255,255,255,0.85);
}
.doc-add-thumb-pdf svg { color: rgba(248,113,113,0.95); }
.doc-add-thumb-pdf span {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: rgba(248,113,113,0.95);
}
/* Wenn PDF.js gerendert hat: Bild ersetzt das Icon — Akzent-BG fällt weg */
.doc-add-thumb-pdf[data-pdf-rendered="1"] {
  background: #fff;
  border-color: var(--border2);
  padding: 0;
}
.doc-add-thumb-pdf .pdf-preview-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top;
  display: block;
}
.doc-add-label {
  display: block; font-family: var(--mono); font-size: 10px;
  color: var(--txt3); text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 6px; margin-top: 12px;
}
.doc-add-input {
  width: 100%; padding: 10px 12px; box-sizing: border-box;
  background: var(--surface2); border: 1px solid var(--border2);
  border-radius: 8px; color: var(--txt);
  font-family: var(--cond); font-size: 16px;
}
.doc-add-input:focus { border-color: var(--accent); outline: none; }
.doc-add-cats {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.doc-cat-btn {
  padding: 7px 12px; border-radius: 16px;
  background: var(--surface2); border: 1px solid var(--border2);
  color: var(--txt2); font-family: var(--mono); font-size: 11px;
  font-weight: 600; letter-spacing: 0.04em; cursor: pointer;
  transition: all 0.15s;
}
.doc-cat-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.doc-cat-btn:not(.active):hover { color: var(--txt); border-color: var(--border); }
.doc-add-actions {
  display: flex; gap: 8px; padding: 14px 18px 16px;
  border-top: 1px solid var(--border);
}
.doc-add-cancel,
.doc-add-save {
  flex: 1; padding: 12px; border-radius: 10px; cursor: pointer;
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  letter-spacing: 0.02em; border: none;
  transition: background 0.15s;
}
.doc-add-cancel { background: var(--surface2); color: var(--txt2); }
.doc-add-cancel:hover { background: var(--border2); color: var(--txt); }
.doc-add-save { background: var(--accent); color: #fff; }
.doc-add-save:hover { background: #5a72f5; }

/* Doc-Add: Workshop / Betrag / Aufgaben-Verknüpfung — alles optional */
.doc-add-label-meta {
  font-family: var(--mono); font-size: 9px;
  color: var(--txt3); opacity: 0.7;
  letter-spacing: 0.10em; text-transform: uppercase;
  margin-left: 6px;
  font-weight: 400;
}
.doc-add-cost-row {
  display: flex; align-items: center; gap: 8px;
}
.doc-add-cost-row input { flex: 1; }
.doc-add-cost-unit {
  font-family: var(--mono); font-size: 14px;
  color: var(--txt3);
}

/* ── DOC VIEWER ─────────────────────────────────────────────────────────── */
.doc-viewer-overlay {
  position: fixed; inset: 0; z-index: 600; /* > FAB (500) */
  background: var(--bg); display: flex; flex-direction: column;
  animation: doc-slide-up 0.28s cubic-bezier(0.32,0.72,0,1);
  padding-bottom: env(safe-area-inset-bottom);
}
/* Desktop: zentrierter Sheet statt full-screen, mit dunklem Backdrop-Halo */
@media (min-width: 600px) {
  .doc-viewer-overlay {
    left: 50%; right: auto;
    width: 100%; max-width: 560px;
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border);
    box-shadow: 0 0 0 100vmax rgba(0,0,0,0.65);
    animation: doc-fade-scale 0.26s cubic-bezier(0.32,0.72,0,1);
    transform: translateX(-50%);
  }
}
@keyframes doc-fade-scale {
  from { opacity: 0; transform: translateX(-50%) scale(0.97); }
  to   { opacity: 1; transform: translateX(-50%) scale(1); }
}
.doc-viewer-head {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
/* Icon-Buttons im Doc-Viewer-Header — minimal, ohne Circle-Bubble.
   Matched .btn-icon-Pattern aus Modal-Headern (transparent + hover-tint). */
.doc-viewer-back,
.doc-viewer-menu {
  width: 38px; height: 38px;
  background: none; border: none;
  border-radius: 8px;
  color: var(--txt2); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
.doc-viewer-back:hover,
.doc-viewer-menu:hover {
  background: rgba(255,255,255,0.06);
  color: var(--txt);
}
.doc-viewer-back:active,
.doc-viewer-menu:active { transform: scale(0.94); }
.doc-viewer-titles { flex: 1; min-width: 0; }
.doc-viewer-name {
  font-family: var(--cond); font-size: 18px; font-weight: 800;
  color: var(--txt); line-height: 1.1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.doc-viewer-meta {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.06em; margin-top: 3px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
/* Photo-Stack: full-width Fotos vertikal scrollbar, Tap → Lightbox.
   Ein Foto = Vollbild-Look, mehrere = Scroll-Stack (TÜV-Berichte mehrseitig lesbar). */
.doc-viewer-grid {
  flex: 1; overflow-y: auto; padding: 14px;
  display: flex; flex-direction: column; gap: 12px;
  align-items: stretch;
}
.doc-viewer-photo {
  position: relative;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  background: #000;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  aspect-ratio: auto;
}
.doc-viewer-photo img {
  width: 100%;
  height: auto;
  max-height: 75vh;
  object-fit: contain;
  display: block;
  cursor: pointer;
}
/* Origin-Pill im Header-Meta */
.doc-viewer-meta-origin {
  display: inline-block;
  margin-left: 8px;
  font-family: var(--mono);
  font-size: 9px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--accent);
  border: 1px solid rgba(61,90,241,0.4);
  padding: 1px 5px; border-radius: 3px;
  background: rgba(61,90,241,0.08);
  vertical-align: 1px;
}
/* Primary-Action „Zur Quelle öffnen" */
.doc-viewer-source {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 16px; border-radius: 10px; cursor: pointer;
  background: rgba(61,90,241,0.14);
  border: 1px solid rgba(61,90,241,0.5);
  color: var(--accent);
  font-family: var(--mono); font-size: 11px;
  font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  transition: background 0.18s, border-color 0.18s;
}
.doc-viewer-source:hover {
  background: rgba(61,90,241,0.22);
  border-color: var(--accent);
}
.doc-viewer-source svg { flex-shrink: 0; }
.doc-viewer-photo-del {
  position: absolute; top: 6px; right: 6px;
  width: 26px; height: 26px; border-radius: 50%;
  background: rgba(0,0,0,0.7); color: #fff; border: none;
  font-size: 13px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0.85;
}
.doc-viewer-photo-del:hover { opacity: 1; background: rgba(220,38,38,0.85); }

/* PDF-Tile im Doc-Viewer — gerenderte erste Seite via PDF.js.
   Editorial: weißer Page-BG (Papier-Feeling), Hairline, dezenter Schatten.
   Klick öffnet Vollansicht im neuen Tab via openDocItem. */
.doc-viewer-photo-pdf {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--border2);
  box-shadow: 0 4px 14px rgba(0,0,0,0.18);
  aspect-ratio: 1 / var(--pdf-aspect, 1.414); /* A4-Default, dynamisch nach Render */
  max-height: 78vh;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.doc-viewer-photo-pdf:hover {
  box-shadow: 0 6px 22px rgba(0,0,0,0.28);
}
.doc-viewer-photo-pdf:active {
  transform: scale(0.99);
}
.doc-viewer-photo-pdf .pdf-preview-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top;
  display: block;
  background: #fff;
}
.doc-viewer-photo-pdf.pdf-render-failed {
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, rgba(220,38,38,0.10), rgba(220,38,38,0.03));
  border-color: rgba(220,38,38,0.22);
}
.doc-viewer-photo-pdf.pdf-render-failed::after {
  content: 'Vorschau nicht verfügbar — Öffnen für Vollansicht';
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(248,113,113,0.95);
  text-align: center; padding: 0 24px;
}

/* Loading-Placeholder — bevor PDF.js die erste Seite gerendert hat */
.pdf-preview-loading {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px;
  background: linear-gradient(180deg, #fafafa, #f0f0f0);
  color: rgba(0,0,0,0.45);
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
}
.pdf-preview-spinner {
  animation: pdf-spin 1s linear infinite;
  color: rgba(0,0,0,0.5);
}
@keyframes pdf-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  .pdf-preview-spinner { animation: none; }
}

/* PDF-Badge oben rechts: zeigt "PDF" oder Seitenzahl */
.pdf-preview-badge {
  position: absolute; top: 8px; right: 8px;
  z-index: 2; pointer-events: none;
}
.pdf-preview-pages {
  display: inline-block;
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: #fff;
  background: rgba(13,13,13,0.78);
  padding: 4px 9px; border-radius: 99px;
  border: 1px solid rgba(255,255,255,0.16);
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
}

.doc-viewer-pdf-open {
  position: absolute; top: 8px; left: 8px; z-index: 3;
  display: inline-flex; align-items: center; gap: 6px;
  height: 28px; padding: 0 11px 0 9px;
  border-radius: 99px;
  background: rgba(13,13,13,0.82);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
          backdrop-filter: blur(12px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.10em; text-transform: uppercase;
  cursor: pointer;
  transition: background 0.18s ease, transform 0.18s ease;
}
.doc-viewer-pdf-open:hover { background: rgba(13,13,13,0.92); }
.doc-viewer-pdf-open:active { transform: scale(0.96); }
.doc-viewer-pdf-open svg { display: block; opacity: 0.95; }

/* PDF-Cover-Thumbnail in Doc-Liste — gerendert via PDF.js (200px) */
.doc-row-thumb-pdf .pdf-preview-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top;
  display: block;
}
.doc-row-thumb-pdf:not([data-pdf-rendered="1"]) {
  /* Während Render läuft: rötlicher Akzent-Fallback bleibt sichtbar */
}
.doc-viewer-actions {
  display: flex; flex-direction: column; gap: 8px;
  padding: 12px 14px 14px; border-top: 1px solid var(--border);
}
.doc-viewer-add {
  padding: 11px; border-radius: 10px; cursor: pointer;
  background: rgba(61,90,241,0.10); border: 1px dashed rgba(61,90,241,0.45);
  color: var(--accent); font-family: var(--mono); font-size: 11px;
  font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
}
.doc-viewer-add:hover { background: rgba(61,90,241,0.18); border-color: var(--accent); }
.doc-viewer-delete {
  padding: 11px; border-radius: 10px; cursor: pointer;
  background: transparent; border: 1px solid var(--border2);
  color: var(--red); font-family: var(--mono); font-size: 11px;
  font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
}
.doc-viewer-delete:hover { background: rgba(220,38,38,0.08); border-color: var(--red); }

/* ── SONSTIGES TAB ──────────────────────────────────────────────────────── */
/* ── BORDBUCH ──────────────────────────────────────────────────────────── */
.lb-head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 12px;
  padding: 4px 0 14px;
  border-bottom: 1px solid var(--border);
}
.lb-head-title {
  font-family: var(--cond); font-size: 24px; font-weight: 800;
  letter-spacing: 0.005em; color: var(--txt);
  line-height: 1;
}
.lb-head-sub {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--txt3);
  margin-top: 4px;
}
.lb-list {
  display: flex; flex-direction: column;
  padding: 14px 0 24px;
  gap: 12px;
}
/* Inline editable Notiz-Karte: visuell klar als Eingabefeld erkennbar, mit
 * Auto-Save on Blur. Hover/Focus heben das Feld an, dass es tappable ist. */
.lb-entry-card {
  display: flex; flex-direction: column;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px 14px;
  transition: border-color 0.18s, background 0.18s;
}
.lb-entry-card:hover {
  border-color: var(--border2);
}
/* Edit-State: ruhig — nur leichter BG-Heller-Wechsel, keine Akzent-Border,
   kein Glow. Fühlt sich wie Apple Notes an, nicht wie Form-Validation. */
.lb-entry-card:focus-within {
  background: var(--surface);
  border-color: var(--border2);
}
.lb-entry-card-head {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 8px;
}
.lb-entry-card-date {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--txt3);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
  background: none; border: 0; padding: 2px 4px;
  margin-left: -4px;
  border-radius: 4px;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}
.lb-entry-card-date.is-editable:hover {
  color: var(--txt2);
  background: rgba(255,255,255,0.04);
}
.lb-entry-card-date-input {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em;
  background: var(--surface); border: 1px solid var(--accent);
  color: var(--txt);
  padding: 2px 6px; border-radius: 4px;
  outline: none;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
  margin-left: -4px;
}
/* Save-Indikator — Apple-Notes-Stil: „Gespeichert · 14:32" */
.lb-entry-card-saved {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--txt3);
  margin-left: auto;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  opacity: 0.75;
  transition: opacity 0.2s;
}
.lb-entry-card-saved:empty { display: none; }
.lb-entry-card-saved.is-pulse {
  animation: lb-saved-pulse 1.4s ease-out forwards;
}
@keyframes lb-saved-pulse {
  0%   { opacity: 0;    transform: translateY(-2px); color: var(--green); }
  18%  { opacity: 1;    transform: translateY(0);    color: var(--green); }
  55%  { opacity: 1;                                color: var(--green); }
  100% { opacity: 0.75; transform: translateY(0);    color: var(--txt3); }
}
.lb-entry-card-photo,
.lb-entry-card-del {
  background: none; border: 0;
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--txt3); cursor: pointer; border-radius: 8px;
  opacity: 0.55; flex-shrink: 0;
  transition: opacity 0.15s, color 0.15s, background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.lb-entry-card:hover .lb-entry-card-photo,
.lb-entry-card:hover .lb-entry-card-del,
.lb-entry-card:focus-within .lb-entry-card-photo,
.lb-entry-card:focus-within .lb-entry-card-del {
  opacity: 1;
}
.lb-entry-card-photo:hover { color: var(--accent); background: rgba(255,255,255,0.04); }
.lb-entry-card-del:hover   { color: var(--red);    background: rgba(255,255,255,0.04); }

/* Foto-Thumbnails unter dem Text */
.lb-photos {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(78px, 1fr));
  gap: 6px;
  margin-top: 12px;
}
.lb-photo {
  position: relative;
  aspect-ratio: 1;
  border-radius: 6px;
  overflow: hidden;
  background: var(--surface);
}
.lb-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  cursor: zoom-in;
  display: block;
}
.lb-photo img.lb-photo-broken {
  object-fit: contain;
  padding: 12px;
  background: var(--surface2);
  color: var(--txt3);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.04em;
  text-align: center;
}
.lb-photo-del {
  position: absolute; top: 4px; right: 4px;
  width: 26px; height: 26px;
  background: rgba(0,0,0,0.7);
  border: 0; color: #fff;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; cursor: pointer;
  /* Auf Touch-Devices: immer sichtbar (kein Hover möglich).
     Auf Desktop: nur bei Hover (cleaner Look). */
  opacity: 1;
  transition: opacity 0.15s, background 0.15s;
}
@media (hover: hover) and (pointer: fine) {
  .lb-photo-del { opacity: 0; }
  .lb-photo:hover .lb-photo-del { opacity: 1; }
}
.lb-photo-del:hover { background: var(--red); }
.lb-entry-card-text {
  width: 100%;
  background: none;
  border: 0;
  resize: none;
  padding: 0;
  font-family: var(--body); font-size: 14px; line-height: 1.5;
  color: var(--txt);
  outline: none;
  overflow: hidden;
  cursor: text;
}
.lb-entry-card-text::placeholder { color: var(--txt3); font-style: italic; }

/* Detail-Modal Bordbuch-Eintrag */
.lb-detail-date {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--txt2); margin-bottom: 14px;
}
.lb-detail-text {
  font-family: var(--body); font-size: 15px; line-height: 1.6;
  color: var(--txt);
  white-space: pre-wrap; word-break: break-word;
}
/* ── VEHICLE-DATA PANEL (Premium-Stil seit Mai 2026) ──────────────────────
   Identity-Header + thematische Cards statt Settings-App-Tabelle.
   Schrauber-orientiert: Drehmomente/Reifen Mono-Zahlen, Flüssigkeiten als
   Card-Grid mit Volumen als Hero-Zahl. */

.vfz-identity {
  padding: 4px 4px 18px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.vfz-identity-kicker {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 8px;
}
.vfz-identity-title {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(26px, 5vw, 34px);
  line-height: 1.05; letter-spacing: -0.015em;
  color: var(--txt); margin: 0 0 10px;
}
.vfz-identity-sub {
  font-family: var(--cond); font-size: 15px; font-weight: 500;
  color: var(--txt2); margin-bottom: 6px; letter-spacing: 0.005em;
}
.vfz-identity-meta {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.06em; color: var(--txt3);
  word-break: break-all;
}

/* Stat-Card (KM, TÜV) und Themed-Card (Antrieb/Reifen/Drehmomente) — gleicher Container */
.vfz-stat-card,
.vfz-card {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 10px;
}
.vfz-card-label {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 12px;
}

/* Stat-Hero — KM als große Mono-Zahl + dezenter Edit-Button */
.vfz-stat-hero {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  font-family: var(--mono); font-weight: 500;
  font-size: clamp(24px, 4.5vw, 30px);
  letter-spacing: -0.005em;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.vfz-stat-foot {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--txt3); margin-top: 8px;
}

/* TÜV-Card mit Timeline-Bar */
.vfz-tuev-hero {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px; margin-bottom: 10px;
}
.vfz-tuev-date {
  font-family: var(--cond); font-weight: 800; font-size: 24px;
  letter-spacing: -0.01em; color: var(--txt);
  line-height: 1;
}
.vfz-tuev-status {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--txt2);
}
.vfz-tuev-status.overdue { color: var(--red); }
.vfz-tuev-status.soon    { color: var(--amber); }
.vfz-tuev-status.ok      { color: var(--green); }

.vfz-tuev-bar {
  position: relative;
  height: 4px; border-radius: 99px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
  margin-bottom: 10px;
}
.vfz-tuev-bar-fill {
  height: 100%; border-radius: 99px;
  background: var(--green);
  transition: width 0.4s cubic-bezier(0.22, 0.9, 0.24, 1);
}
.vfz-tuev-bar-fill.overdue { background: var(--red); }
.vfz-tuev-bar-fill.soon    { background: var(--amber); }
.vfz-tuev-bar-fill.ok      { background: var(--accent); }

.vfz-tuev-foot {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--txt3);
}

/* Reifen-Card — technisches Datasheet-Layout */
.vfz-tyre-size {
  font-family: var(--mono); font-size: 14px; font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--txt); margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.vfz-tyre-axles {
  display: grid; grid-template-columns: 1fr 1px 1fr;
  align-items: center;
  gap: 16px;
}
.vfz-tyre-axle {
  text-align: center;
}
.vfz-tyre-axle-label {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 8px;
}
.vfz-tyre-axle-val {
  font-family: var(--mono); font-weight: 500;
  font-size: clamp(28px, 5vw, 36px);
  letter-spacing: -0.005em;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.vfz-tyre-axle-unit {
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  color: var(--txt3); margin-left: 4px; letter-spacing: 0.04em;
}
.vfz-tyre-axle-divider {
  align-self: stretch;
  background: rgba(255,255,255,0.06);
}
.vfz-tyre-spare {
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.05);
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--txt3);
  display: flex; justify-content: space-between; align-items: baseline;
}
.vfz-tyre-spare span {
  color: var(--txt); font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  text-transform: none;
}
.vfz-stat-edit {
  flex-shrink: 0;
  width: 32px; height: 32px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--txt2);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, color 0.18s;
  -webkit-tap-highlight-color: transparent;
}
.vfz-stat-edit:hover {
  color: var(--txt);
  border-color: rgba(61,90,241,0.35);
  background: rgba(61,90,241,0.08);
}

/* Daten-Liste in einer Card — klare Zeilen, Hairline-Trenner, kein Spalten-Look */
.vfz-data-list {
  display: flex; flex-direction: column;
}
.vfz-data-row {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 14px; padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.vfz-data-row:first-child { padding-top: 0; }
.vfz-data-row:last-child { border-bottom: none; padding-bottom: 0; }
.vfz-data-row-label {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--txt3);
  flex-shrink: 0;
}
.vfz-data-row-val {
  font-family: var(--cond); font-size: 16px; font-weight: 600;
  color: var(--txt); text-align: right;
  letter-spacing: -0.005em;
  word-break: break-word;
}
.vfz-data-row-val-mono {
  font-family: var(--mono); font-size: 14px; font-weight: 500;
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
}
.vfz-data-row-val-accent { color: var(--accent); }
.vfz-data-unit {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  margin-left: 2px; letter-spacing: 0.04em;
}

/* Notizen-Card — Patina-Akzent (Amber) zur visuellen Trennung */
.vfz-notes-card {
  background: rgba(217,164,72,0.05);
  border-left: 3px solid var(--amber);
  border-radius: 0 12px 12px 0;
  padding: 14px 16px;
  margin-bottom: 10px;
}
.vfz-notes-card-label {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--amber); margin-bottom: 8px;
}
.vfz-notes-card-text {
  font-size: 14px; line-height: 1.55; color: var(--txt);
}

/* Ausstattung-Chips */
.vfz-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.vfz-chip {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 99px;
  padding: 4px 12px;
  font-family: var(--cond); font-size: 13px; font-weight: 500;
  color: var(--txt);
  letter-spacing: 0.005em;
}

/* ── FLÜSSIGKEITEN-CARDS — pro Flüssigkeit eine Karte mit Volumen-Hero ─── */
.vfz-fluid-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
}
@media (max-width: 480px) {
  .vfz-fluid-grid { grid-template-columns: 1fr; }
}
.vfz-fluid-card {
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  padding: 14px 16px;
}
.vfz-fluid-label {
  font-family: var(--mono); font-size: 9px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 8px;
}
.vfz-fluid-hero {
  font-family: var(--cond); font-weight: 800;
  font-size: 28px; line-height: 1;
  color: var(--txt);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
  margin-bottom: 6px;
}
.vfz-fluid-hero-unit {
  font-family: var(--mono); font-size: 13px; font-weight: 500;
  color: var(--txt3); margin-left: 2px; letter-spacing: 0.04em;
}
.vfz-fluid-specs {
  font-family: var(--mono); font-size: 11px;
  color: var(--txt2); line-height: 1.5;
  letter-spacing: 0.02em;
  margin-bottom: 4px;
}
.vfz-fluid-brand {
  font-size: 12px; color: var(--txt3); line-height: 1.4;
  font-style: italic;
}

/* ── FEATURES TAG INPUT ─────────────────────────────────────────────────── */
.features-input {
  border: 1px solid var(--border2); border-radius: var(--r);
  background: var(--surface2); padding: 10px;
}
.features-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.features-tags:not(:empty) { margin-bottom: 8px; }
.feature-tag {
  display: flex; align-items: center; gap: 6px;
  background: var(--surface); border: 1px solid var(--border2); border-radius: 20px;
  padding: 5px 8px 5px 12px; font-size: 13px; color: var(--txt); line-height: 1.2;
}
.feature-tag-remove {
  background: none; border: none; color: var(--txt2); cursor: pointer;
  font-size: 17px; line-height: 1; padding: 0; width: 20px; height: 20px;
  display: flex; align-items: center; justify-content: center; border-radius: 50%;
  transition: background 0.15s, color 0.15s;
}
.feature-tag-remove:hover { background: var(--border2); color: var(--txt); }
.features-add-row {
  display: flex; gap: 8px; align-items: center;
}
.features-add-row input {
  flex: 1; background: none; border: none; outline: none;
  color: var(--txt); font-size: 14px; padding: 2px 0; min-height: 32px;
}
.features-add-btn {
  background: var(--accent); border: none; border-radius: var(--r);
  color: #fff; font-size: 22px; width: 34px; height: 34px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  line-height: 1;
}

/* ── TOGGLE GROUP ───────────────────────────────────────────────────────── */
.toggle-group {
  display: flex; gap: 0;
  border: 1px solid var(--border2); border-radius: var(--r); overflow: hidden;
}
.toggle-btn {
  flex: 1; background: none; border: none; color: var(--txt2);
  font-size: 13px; padding: 10px 8px; cursor: pointer; transition: background 0.15s, color 0.15s;
  min-height: 44px;
}
.toggle-btn:first-child { border-right: 1px solid var(--border2); }
.toggle-btn.active { background: var(--accent); color: #fff; }

/* ── PRIORITY SELECTOR ──────────────────────────────────────────────────── */
.prio-group {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
}
.prio-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 11px 12px; border-radius: 10px;
  border: 1px solid var(--border2); background: transparent;
  color: var(--txt3);
  font-family: var(--cond);
  font-weight: 600; font-size: 14px;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: all 0.18s ease;
}
.prio-btn:hover:not(.active) { color: var(--txt2); background: rgba(255,255,255,0.025); }
/* "Keine" als neutraler Default — kein Highlight, nur leicht erkennbar */
.prio-btn.active[data-val="none"] {
  color: var(--txt2);
  border-color: var(--border2);
  background: rgba(255,255,255,0.03);
}
/* "Mittel" und "Hoch" mit Akzent-Fill bei active — klare visuelle Hierarchie */
.prio-btn.active[data-val="medium"] {
  color: #fff;
  border-color: var(--amber);
  background: var(--amber);
  box-shadow: 0 2px 8px rgba(234,88,12,0.3);
}
.prio-btn.active[data-val="medium"] .prio-dot { background: #fff; box-shadow: 0 0 4px rgba(255,255,255,0.6); }
.prio-btn.active[data-val="high"] {
  color: #fff;
  border-color: var(--red);
  background: var(--red);
  box-shadow: 0 2px 8px rgba(220,38,38,0.35);
}
.prio-btn.active[data-val="high"] .prio-dot { background: #fff; box-shadow: 0 0 4px rgba(255,255,255,0.6); }
.prio-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  transition: background 0.15s, box-shadow 0.15s;
}
.prio-dot.d-high   { background: var(--red); }
.prio-dot.d-medium { background: var(--amber); }
.prio-dot.d-none   { background: var(--txt3); opacity: 0.5; }

/* ── TODO MODAL: Group / Subgroup Pills (replaces native datalist) ──────── */
.tm-group-pills,
.tm-subgroup-pills {
  display: flex; flex-wrap: wrap;
  gap: 6px;
  margin-top: 4px;
}
.tm-pill {
  padding: 8px 14px;
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 100px;
  color: var(--txt2);
  font-family: var(--cond);
  font-weight: 600; font-size: 13px;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: all 0.15s ease;
  white-space: nowrap;
}
.tm-pill:hover:not(.active) {
  background: rgba(255,255,255,0.04);
  color: var(--txt);
  border-color: var(--txt3);
}
.tm-pill.active {
  background: rgba(61,90,241,0.12);
  border-color: var(--accent);
  color: var(--accent);
}
.tm-pill-custom {
  border-style: dashed;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  font-weight: 600;
}
.tm-pill-custom.active {
  border-style: solid;
}
/* Custom-Input direkt unter den Pills wenn aktiv */
#tm-group-main, #tm-group-sub {
  margin-top: 8px;
}

/* ── TUEV NEXT DISPLAY ──────────────────────────────────────────────────── */
.tuev-next-display {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--surface2);
  border: 1px solid var(--border2); border-radius: var(--r);
}
.tuev-next-val {
  flex: 1; font-size: 15px; color: var(--txt);
}
.tuev-next-edit-btn {
  background: none; border: 1px solid var(--border2); border-radius: var(--r);
  color: var(--txt2); font-size: 12px; padding: 4px 10px; cursor: pointer;
  white-space: nowrap;
}
.tuev-next-edit-btn:hover { border-color: var(--accent); color: var(--accent); }
.tuev-next-reset-btn {
  background: none; border: none; color: var(--txt2); font-size: 12px;
  padding: 4px 0; cursor: pointer; margin-top: 4px;
}
.tuev-next-reset-btn:hover { color: var(--txt); }

/* ── IMAGE UPLOAD AREA ──────────────────────────────────────────────────── */
.img-upload-area {
  border: 2px dashed var(--border2); border-radius: 8px;
  overflow: hidden; cursor: pointer; transition: border-color 0.2s;
  position: relative; min-height: 120px;
  display: flex; align-items: center; justify-content: center;
}
.img-upload-area:hover { border-color: var(--accent); }
.img-upload-placeholder {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 24px; color: var(--txt2);
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em;
}
.img-upload-icon { font-size: 28px; }
.img-upload-preview {
  display: none; width: 100%; height: 160px; overflow: hidden;
  position: relative; cursor: grab; touch-action: none;
}
.img-upload-preview.crop-active { cursor: grabbing; }
.img-upload-preview img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  object-position: 50% 50%; pointer-events: none;
}
.img-upload-crop-hint {
  position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%);
  background: rgba(0,0,0,0.55); color: rgba(255,255,255,0.9);
  font-size: 10px; font-family: var(--mono); letter-spacing: 0.04em;
  padding: 3px 9px; border-radius: 12px; pointer-events: none;
  white-space: nowrap; opacity: 0.9;
}
.vf-change-photo-btn {
  position: absolute; top: 8px; right: 8px;
  background: rgba(0,0,0,0.6); border: none; color: #fff;
  width: 36px; height: 36px; border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s; -webkit-tap-highlight-color: transparent;
}
.vf-change-photo-btn:hover, .vf-change-photo-btn:active { background: rgba(0,0,0,0.88); }

/* ── FILTER PILLS ───────────────────────────────────────────────────────── */
.filter-pills {
  display: flex; gap: 6px; padding: 10px 14px 10px;
  border-bottom: 1px solid var(--border); flex-wrap: wrap; flex-shrink: 0;
}
.pill {
  font-family: var(--mono); font-size: 12px; padding: 9px 16px;
  border-radius: 20px; border: 1px solid var(--border2);
  background: none; color: var(--txt2); cursor: pointer; transition: all 0.2s;
  white-space: nowrap; min-height: 40px;
}
.pill.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ── SORT BAR ────────────────────────────────────────────────────────────── */
.tab-sort-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-bottom: 1px solid var(--border);
  flex-wrap: wrap; flex-shrink: 0;
}
.sort-label { display: none; }
.sort-icon { color: var(--txt2); display: flex; align-items: center; flex-shrink: 0; }
.sort-select {
  font-family: var(--mono); font-size: 12px; padding: 4px 10px;
  border-radius: 8px; border: 1px solid var(--border2);
  background: var(--surface2); color: var(--txt); cursor: pointer;
  outline: none; width: 108px;
}
.sort-btn {
  font-family: var(--mono); font-size: 12px; padding: 8px 14px;
  border-radius: 20px; border: 1px solid var(--border2);
  background: none; color: var(--txt2); cursor: pointer; transition: all 0.15s;
  min-height: 36px;
}
.sort-btn.active { background: var(--surface2); color: var(--txt); border-color: var(--txt2); }

/* ── GROUP ACCORDION ────────────────────────────────────────────────────── */
.todo-accordion { border-bottom: 1px solid var(--border); }
.todo-accordion-header {
  display: flex; align-items: center; gap: 6px;
  padding: 12px 16px 12px 8px; cursor: pointer;
  border-top: 1px solid var(--border);
  transition: background 0.15s;
}
.todo-accordion-header:hover { background: var(--surface2); }
.todo-group-grip {
  display: flex; align-items: center; justify-content: center;
  width: 24px; height: 32px; flex-shrink: 0;
  color: var(--txt3); cursor: grab; opacity: 0.5;
  transition: opacity 0.15s, color 0.15s; touch-action: none;
}
.todo-group-grip:hover { opacity: 1; color: var(--txt2); }
.todo-group-grip:active { cursor: grabbing; }
.todo-acc-title-group {
  display: flex; align-items: center; flex: 1; min-width: 0;
}
.todo-accordion-title {
  font-family: var(--cond); font-size: 13px; font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase; color: var(--txt2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.todo-accordion-count {
  font-family: var(--mono); font-size: 11px; color: var(--txt3); flex-shrink: 0;
}
.todo-accordion-chevron {
  flex-shrink: 0; color: var(--txt3);
  transition: transform 0.2s ease;
  transform: rotate(-90deg);
}
.todo-accordion-chevron.open { transform: rotate(0deg); }
.todo-accordion-body .el-entry { border-left-width: 3px; }
.todo-grip {
  display: flex; align-items: center; justify-content: center;
  width: 22px; flex-shrink: 0; color: var(--txt3); opacity: 0.3;
  cursor: grab; touch-action: none; padding: 0 2px;
}
#task-todo-content.no-drag .todo-grip,
#task-done-content.no-drag .todo-grip { display: none; }
.done-card-right {
  display: flex; flex-direction: row; align-items: center;
  gap: 2px; flex-shrink: 0; align-self: center;
}
.todo-accordion-body[data-group]:empty,
.todo-accordion-body[data-group].drop-empty {
  min-height: 40px;
  display: flex; align-items: center; justify-content: center;
}
.todo-accordion-body[data-group]:empty::after,
.todo-accordion-body[data-group].drop-empty::after {
  content: 'Hierher ziehen …';
  font-size: 12px; color: var(--txt3); opacity: 0.4; pointer-events: none;
}
.todo-drag-ghost {
  position: fixed; z-index: 9999; pointer-events: none; margin: 0;
  box-shadow: 0 12px 32px rgba(0,0,0,0.65); border-radius: 8px; opacity: 0.97;
}
.todo-accordion-body.drag-target-active {
  background: rgba(61,90,241,0.06);
  outline: 1px dashed rgba(61,90,241,0.35);
}
/* Collapsed bodies shown as drop zones during drag */
.todo-accordion-body.drag-drop-zone {
  min-height: 0 !important; overflow: hidden;
}
/* Highlight the header of a collapsed group when dragging over it */
.todo-accordion-body.drag-drop-zone.drag-target-active + * ,
.todo-accordion-body.drag-target-active.drag-drop-zone {
  outline: none;
}
.todo-accordion-header.drag-target-header {
  background: rgba(61,90,241,0.12);
  outline: 1px dashed rgba(61,90,241,0.4);
}
/* New-group drop zone shown at bottom of list during drag */
#todo-new-group-zone {
  margin: 6px 16px 14px;
  padding: 13px 16px;
  border: 2px dashed rgba(255,255,255,0.12);
  border-radius: 10px;
  text-align: center;
  font-family: var(--cond);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--txt3);
  transition: border-color 0.15s, color 0.15s, background 0.15s;
  pointer-events: none;
}
#todo-new-group-zone.drag-over {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(61,90,241,0.07);
}
/* Group rename edit button */
.todo-group-edit-btn {
  background: none; border: none; padding: 3px 4px; margin-left: 3px;
  color: var(--txt3); cursor: pointer; flex-shrink: 0; line-height: 1;
  opacity: 0.45; transition: opacity 0.15s, color 0.15s;
  display: flex; align-items: center;
}
.todo-group-edit-btn:active, .todo-group-edit-btn:hover { opacity: 1; color: var(--txt); }
/* Per-group subgroup drop zones */
.todo-new-subgroup-zone {
  margin: 4px 12px 6px 20px;
  padding: 7px 12px;
  border: 1px dashed rgba(255,255,255,0.1);
  border-radius: 7px;
  text-align: center;
  font-family: var(--cond);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.2);
  transition: border-color 0.15s, color 0.15s, background 0.15s;
  pointer-events: none;
}
.todo-new-subgroup-zone.drag-over {
  border-color: rgba(61,90,241,0.6);
  color: var(--accent);
  background: rgba(61,90,241,0.07);
}
.todo-subgroup-header {
  padding: 9px 16px 5px 20px;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  color: var(--txt2); text-transform: uppercase; letter-spacing: 0.1em;
  border-bottom: 1px solid var(--border);
  border-top: 1px solid var(--border);
}
/* Nested sub-accordions */
.todo-accordion-body .todo-accordion { border-bottom: none; border-top: 1px solid var(--border); }
.todo-accordion-body .todo-accordion-header {
  padding: 9px 16px 9px 40px;
  background: rgba(255,255,255,0.015);
  border-top: 1px solid var(--border);
  position: relative;
}
.todo-accordion-body .todo-accordion-header::before {
  content: '↳';
  position: absolute;
  left: 18px;
  top: 50%; transform: translateY(-50%);
  color: var(--txt); font-size: 13px; opacity: 0.4;
  font-style: normal;
}
.todo-accordion-body .todo-accordion-title {
  font-family: var(--cond); font-size: 13px; font-weight: 600; letter-spacing: 0.02em;
  color: var(--txt); text-transform: none;
}
.todo-accordion-body .todo-accordion-body { padding-left: 16px; }
.todo-accordion-body .todo-accordion-body .el-entry { border-left-width: 2px; }

/* ── TODO PARTS ──────────────────────────────────────────────────────────── */
.todo-parts { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 7px; }
.todo-part-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 11px; padding: 3px 10px 3px 9px;
  border-radius: 20px; border: 1px solid var(--border2);
  background: var(--surface2); color: var(--txt2);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.1s ease;
  user-select: none;
}
.todo-part-chip:active { transform: scale(0.96); }
.todo-part-chip:focus,
.todo-part-chip:focus-visible { outline: none; }
.todo-part-chip:hover { border-color: var(--txt3); }
.todo-part-chip.ordered {
  background: rgba(74,222,128,0.1); border-color: rgba(74,222,128,0.35); color: var(--green);
}
.todo-part-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--border2); flex-shrink: 0; transition: background 0.15s;
}
.todo-part-chip.ordered .todo-part-dot { background: var(--green); }
.todo-part-name { font-weight: 500; }
.todo-part-price {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  color: var(--txt2);
  letter-spacing: 0.02em;
  padding-left: 4px;
  border-left: 1px solid rgba(255,255,255,0.15);
  white-space: nowrap;
}
.todo-part-chip.ordered .todo-part-price {
  color: var(--green);
  border-left-color: rgba(74,222,128,0.30);
}

/* Vertikale Teile-Liste in Entry-Detail — übersichtlicher als Chips, Preise rechts */
.ed-parts-list {
  display: flex; flex-direction: column;
  margin-top: 10px;
}
.ed-parts-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  -webkit-tap-highlight-color: transparent;
}
.ed-parts-row:last-child { border-bottom: none; }

/* Tappable Row für offene Aufgaben — ganze Zeile ist Click-Target */
.ed-parts-row-tappable {
  width: 100%;
  background: none;
  border: none;
  border-bottom: 1px solid var(--border);
  padding: 10px 0;
  margin: 0;
  text-align: left;
  cursor: pointer;
  font: inherit;
  color: inherit;
  transition: background 0.15s ease;
}
.ed-parts-row-tappable:hover { background: rgba(255,255,255,0.02); }
.ed-parts-row-tappable:active { background: rgba(255,255,255,0.04); }
.ed-parts-row-tappable:last-child { border-bottom: none; }

/* Name nimmt Hauptraum, ellipsis bei Overflow */
.ed-parts-row-name {
  flex: 1 1 auto; min-width: 0;
  font-family: var(--cond);
  font-size: 15px; font-weight: 600;
  color: var(--txt);
  letter-spacing: -0.005em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Preis rechtsbündig in Mono */
.ed-parts-row-price {
  flex: 0 0 auto;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  color: var(--txt);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.ed-parts-row-price-empty {
  color: var(--txt3);
  opacity: 0.5;
}

/* State-Pill rechts neben Preis — Hairline-Outline-Style macht Tappability klar */
.ed-parts-row-state {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 78px;
  padding: 4px 10px;
  border-radius: 99px;
  border: 1px solid var(--border2);
  font-family: var(--mono); font-size: 9.5px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3);
  transition: all 0.18s ease;
}
.ed-parts-row.is-ordered .ed-parts-row-state {
  color: var(--green);
  border-color: rgba(74,222,128,0.40);
  background: rgba(74,222,128,0.10);
}
/* Hover am Row-Button stylt die Pill mit — visuelles Feedback dass tappable */
.ed-parts-row-tappable:hover .ed-parts-row-state {
  border-color: var(--txt3);
  color: var(--txt2);
}
.ed-parts-row-tappable.is-ordered:hover .ed-parts-row-state {
  border-color: rgba(74,222,128,0.60);
  color: var(--green);
}

/* Σ-Zeile unter Teile-Liste */
.ed-parts-total {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-top: 6px;
  padding-top: 12px;
  border-top: 2px solid var(--border2);
}
.ed-parts-total-label {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt2);
}
.ed-parts-total-value {
  font-family: var(--mono); font-size: 16px; font-weight: 700;
  color: var(--txt);
  letter-spacing: 0.02em;
}
/* Status-Suffix als kleiner Mono-Caps-Text — explizit "bestellen" / "bestellt"
   damit User auf einen Blick weiß was zu tun bzw. erledigt ist. */
.todo-part-state {
  font-size: 9px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  opacity: 0.55;
  padding-left: 4px;
  border-left: 1px solid currentColor;
  border-left-color: rgba(255,255,255,0.15);
}
.todo-part-chip.ordered .todo-part-state {
  opacity: 0.7;
  border-left-color: rgba(74,222,128,0.30);
}
/* Kein Unicode-Checkmark — Status-Farbe (grün) + grüner Dot reichen als Signal,
   passend zur editorial Tonalität (keine Stock-Glyphs). */

/* Truncation: per JS gemessen via offsetTop. Chips auf Zeile 2+ bekommen .is-hidden. */
.todo-part-chip.is-hidden { display: none; }

/* "+N"-Pill am Ende von Zeile 1 — kompakt, nur Zahl, klar als Disclosure erkennbar */
.todo-parts-more {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 30px; height: 24px;
  padding: 0 8px;
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 99px;
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--txt2);
  cursor: pointer;
  transition: all 0.18s ease;
  -webkit-tap-highlight-color: transparent;
}
.todo-parts-more:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* Zuklappen-Pill (sichtbar wenn User expandiert hat) — nur Chevron, dezent */
.todo-parts-collapse {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 99px;
  color: var(--txt3);
  cursor: pointer;
  transition: all 0.18s ease;
  -webkit-tap-highlight-color: transparent;
}
.todo-parts-collapse:hover {
  color: var(--txt2);
  border-color: var(--border2);
}
.todo-parts-collapse svg { display: block; }
/* ── PARTS LIST (S-Tier, Apple-Reminders-Look) ──────────────────────────────
   Hairline-Trenner pro Item, kein Card-Stack. Status-Circle links toggleable,
   Name + Preis inline, Delete subtle. Editorial: ruhige Hierarchie, sparsamer
   Akzent nur beim Status-Toggle. */
.parts-stack {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--border);
  margin-bottom: 0;
}
.parts-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 2px;
  border-bottom: 1px solid var(--border);
  -webkit-tap-highlight-color: transparent;
}
/* Bestellt-State: nur die Status-Pill ändert sich, Name/Preis bleiben normal lesbar.
   Kein Durchstreichen, kein Ausfaden — der Pill kommuniziert den Status klar genug. */

/* Status-Pill mit Text — "Bestellen" / "Bestellt ✓".
   Bestellt = Grün (konsistent mit todo-part-chip.ordered in der Aufgaben-Liste). */
.parts-item-status {
  flex: 0 0 auto;
  padding: 5px 11px;
  border-radius: 99px;
  background: transparent;
  border: 1px solid var(--border2);
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--txt2);
  cursor: pointer; white-space: nowrap;
  transition: all 0.18s ease;
  -webkit-tap-highlight-color: transparent;
}
.parts-item-status.is-open:hover {
  border-color: var(--green);
  color: var(--green);
  background: rgba(74,222,128,0.06);
}
.parts-item-status.is-ordered {
  color: var(--green);
  border-color: rgba(74,222,128,0.40);
  background: rgba(74,222,128,0.10);
}
.parts-item-status:active { transform: scale(0.96); }

/* Name — editierbar als Input, dominante Spalte. Specificity-Bump via .parts-item-Prefix
   damit globale .form-group input Regel nicht überschreibt. */
.parts-item .parts-item-name {
  flex: 1 1 auto; min-width: 0;
  padding: 4px 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid transparent;
  border-radius: 0;
  font-family: var(--cond);
  font-size: 15px; font-weight: 600;
  color: var(--txt);
  letter-spacing: -0.005em;
  outline: none;
  width: auto;
  -webkit-tap-highlight-color: transparent;
  transition: border-color 0.15s ease;
}
.parts-item .parts-item-name:focus {
  border-bottom-color: var(--accent);
  outline: none;
  background: transparent;
}

/* Inline-Preis — schmaler als Name, fix-content-sized */
.parts-item-price-wrap {
  display: inline-flex; align-items: baseline; gap: 3px;
  flex: 0 0 auto;
}
.parts-item .parts-item-price {
  width: 56px; min-width: 56px; max-width: 56px;
  padding: 4px 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid transparent;
  border-radius: 0;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  color: var(--txt);
  text-align: right;
  -moz-appearance: textfield;
  -webkit-tap-highlight-color: transparent;
  transition: border-color 0.15s ease;
}
.parts-item .parts-item-price::-webkit-outer-spin-button,
.parts-item .parts-item-price::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.parts-item .parts-item-price:focus {
  border-bottom-color: var(--accent);
  outline: none;
  background: transparent;
}
.parts-item .parts-item-price::placeholder { color: var(--txt3); opacity: 0.45; }
.parts-item-currency {
  font-family: var(--mono); font-size: 11px;
  color: var(--txt3);
}

/* Delete — sehr dezent, wird sichtbarer beim Hover des Items */
.parts-item-del {
  flex: 0 0 22px;
  width: 22px; height: 22px;
  padding: 0; line-height: 1;
  background: transparent;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  display: grid; place-items: center;
  color: var(--txt3);
  opacity: 0.4;
  transition: opacity 0.15s ease, color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.parts-item:hover .parts-item-del { opacity: 0.7; }
.parts-item-del:hover { opacity: 1 !important; color: var(--red); }

/* Quick-Add Row — Name + Preis + expliziter Button. Klar erkennbar als CTA-Zeile. */
.parts-add-row {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 2px 4px;
  margin-top: 6px;
}
.parts-add-input {
  flex: 1; min-width: 0;
  padding: 8px 10px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 8px;
  font-family: var(--cond);
  font-size: 14px; font-weight: 500;
  color: var(--txt);
  outline: none;
  -webkit-tap-highlight-color: transparent;
  transition: border-color 0.15s ease;
}
.parts-add-input:focus { border-color: var(--accent); }
.parts-add-input::placeholder {
  color: var(--txt3);
  opacity: 0.55;
}
.parts-add-price-wrap {
  flex: 0 0 64px;
  display: inline-flex; align-items: center;
}
.parts-add-price {
  width: 100%;
  padding: 8px 10px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 8px;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  color: var(--txt);
  text-align: right;
  outline: none;
  -moz-appearance: textfield;
  transition: border-color 0.15s ease;
}
.parts-add-price::-webkit-outer-spin-button,
.parts-add-price::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.parts-add-price:focus { border-color: var(--accent); }
.parts-add-price::placeholder { color: var(--txt3); opacity: 0.55; }
.parts-add-btn {
  flex: 0 0 auto;
  padding: 8px 14px;
  background: var(--accent); color: #fff;
  border: none; border-radius: 8px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  cursor: pointer; white-space: nowrap;
  box-shadow: 0 2px 8px rgba(61,90,241,0.25);
  transition: opacity 0.15s ease, transform 0.15s ease, box-shadow 0.18s ease;
  -webkit-tap-highlight-color: transparent;
}
.parts-add-btn:hover {
  box-shadow: 0 4px 14px rgba(61,90,241,0.35);
}
.parts-add-btn:active { transform: scale(0.96); }
/* (Old .modal-part-* classes entfernt — wurden durch .parts-item-* (S-Tier) ersetzt) */

/* Gesamt-Kosten als Footer-Row der Teile-Liste — matcht parts-item-Layout:
   Label links (wo Name), Preis-Input rechts (wo Preis). Dickere Hairline oben
   signalisiert "Summe-Zeile". */
.parts-total-row {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 2px 10px;
  margin-top: 4px;
  border-top: 2px solid var(--border2);
}
.parts-total-label {
  flex: 1 1 auto;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt2);
}
.parts-total-price-wrap {
  flex: 0 0 auto;
  display: inline-flex; align-items: baseline; gap: 3px;
}
/* Total-Input klar als editierbar erkennbar — sichtbares Border + Hover-State */
.parts-total-row input.parts-total-input {
  width: 100px; min-width: 100px; max-width: 100px;
  padding: 7px 10px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 8px;
  font-family: var(--mono); font-size: 16px; font-weight: 700;
  color: var(--txt);
  text-align: right;
  outline: none;
  -moz-appearance: textfield;
  -webkit-tap-highlight-color: transparent;
  cursor: text;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.parts-total-row input.parts-total-input::-webkit-outer-spin-button,
.parts-total-row input.parts-total-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.parts-total-row input.parts-total-input:hover {
  border-color: var(--txt3);
}
.parts-total-row input.parts-total-input:focus {
  border-color: var(--accent);
  background: rgba(61,90,241,0.04);
}
.parts-total-row input.parts-total-input::placeholder { color: var(--txt3); opacity: 0.45; }
.parts-total-currency {
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  color: var(--txt2);
}

/* ── COMPLETED ENTRIES ───────────────────────────────────────────────────── */
.ce-entry {
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}
.ce-entry:hover { background: var(--surface); }
.ce-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 4px;
}
.ce-title { flex: 1; font-weight: 600; font-size: 15px; color: var(--txt); }
.ce-meta { font-family: var(--mono); font-size: 11px; color: var(--txt2); margin-bottom: 4px; }
.ce-parts { font-size: 13px; color: var(--txt2); margin-bottom: 4px; }
.ce-parts::before { content: '🔩 '; }
.ce-notes { font-size: 12px; color: var(--txt3); margin-bottom: 6px; }
.ce-images { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
/* ── PDF OPTIONS ─────────────────────────────────────────────────────────── */
.pdf-opt-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--txt3); margin-bottom: 8px;
}
.pdf-opt-list {
  background: var(--surface2); border-radius: 10px; overflow: hidden;
}
.pdf-opt-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px; cursor: pointer; border-bottom: 1px solid var(--border);
  user-select: none;
}
.pdf-opt-row:last-child { border-bottom: none; }
.pdf-opt-row input[type="checkbox"] { display: none; }
.pdf-opt-text {
  display: flex; align-items: center; gap: 10px;
  font-size: 15px; color: var(--txt);
}
.pdf-opt-icon { font-size: 17px; width: 24px; text-align: center; }
.pdf-toggle {
  width: 44px; height: 26px; border-radius: 13px;
  background: var(--border2); position: relative; flex-shrink: 0;
  transition: background 0.2s;
}
.pdf-toggle::after {
  content: ''; position: absolute; top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%;
  background: #fff; transition: transform 0.2s;
}
input[type="checkbox"]:checked + .pdf-toggle { background: var(--accent); }
input[type="checkbox"]:checked + .pdf-toggle::after { transform: translateX(18px); }
.pdf-toggle-disabled { opacity: 0.4; cursor: not-allowed; }
input[type="checkbox"]:checked + .pdf-toggle-disabled { background: var(--accent); }

.img-thumb {
  width: 72px; height: 72px; object-fit: cover;
  border-radius: var(--r); cursor: pointer;
  border: 1px solid var(--border2); transition: border-color 0.2s;
  /* Kein iOS-Tap-Highlight, kein Focus-Outline beim Klick */
  -webkit-tap-highlight-color: transparent;
  outline: none;
}
.img-thumb:focus,
.img-thumb:focus-visible { outline: none; }
@media (hover: hover) {
  .img-thumb:hover { border-color: var(--accent); }
}
/* Lightbox offen → Hover-Border am Thumb sofort zurücksetzen */
body.gallery-open .img-thumb {
  border-color: var(--border2) !important;
  transition: none !important;
}
.img-thumb-container {
  position: relative;
  border-radius: 6px;
  overflow: hidden;
}
.img-thumb-del {
  position: absolute; top: 4px; right: 4px;
  background: rgba(0,0,0,0.7); color: #fff; border: none; border-radius: 50%;
  width: 24px; height: 24px; font-size: 11px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; line-height: 1;
  /* Always-visible auf Touch, hover-revealed auf Desktop */
  opacity: 1;
  transition: opacity 0.15s, background 0.15s;
}
@media (hover: hover) and (pointer: fine) {
  .img-thumb-del { opacity: 0; }
  .img-thumb-container:hover .img-thumb-del { opacity: 1; }
}
.img-thumb-del:hover { background: var(--red); }
.btn-add-photo {
  font-family: var(--mono); font-size: 10px; color: var(--accent);
  border: 1px dashed rgba(61,90,241,0.4); background: none;
  padding: 4px 10px; border-radius: var(--r); cursor: pointer; margin-top: 6px;
}
.btn-add-photo:hover { background: rgba(61,90,241,0.08); }
.img-preview-grid { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }

/* ── UNIFIED PHOTO UPLOAD AREA ──────────────────────────────────────────── */
.photo-upload-area {
  border: 2px dashed var(--border2); border-radius: var(--r);
  padding: 10px 12px; transition: border-color 0.2s; min-height: 58px;
}
.photo-upload-area:hover { border-color: var(--accent); }
.photo-preview-grid { display: flex; gap: 6px; flex-wrap: wrap; }
.photo-preview-grid:not(:empty) { margin-bottom: 10px; }
.photo-upload-placeholder {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  color: var(--txt2); font-size: 13px; cursor: pointer; min-height: 36px;
}
.photo-upload-placeholder:hover { color: var(--txt); }
.photo-upload-add {
  display: none; color: var(--accent); font-size: 11px; cursor: pointer;
  font-family: var(--mono); letter-spacing: 0.04em; padding-top: 2px;
}
.photo-upload-add:hover { opacity: 0.7; }

/* ── TODO EDIT BUTTON ────────────────────────────────────────────────────── */
.todo-edit-btn {
  background: none; border: none; color: var(--txt2); font-size: 12px;
  cursor: pointer; padding: 4px 6px; border-radius: var(--r); transition: color 0.2s;
  opacity: 0; flex-shrink: 0;
}
.todo-entry:hover .todo-edit-btn { opacity: 1; }

@media (max-width: 640px) {
  .todo-edit-btn { opacity: 1; }
  .filter-pills { padding: 10px 14px; gap: 8px; }
  .tab-sort-bar { padding: 10px 14px; gap: 8px; }
  .ce-entry { padding: 14px 14px; }
  .img-thumb { width: 70px; height: 70px; }
}


/* ── BACKUP BUTTONS ────────────────────────────────────────────────────── */
.dash-footer { padding: 24px 20px; border-top: 1px solid var(--border); margin-top: 24px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.dash-footer .section-label { width: 100%; margin-bottom: 4px; }
/* ── INTRO PAGE (First Start Onboarding — Landing-aligned) ──────────────── */
.intro-page {
  min-height: 100vh; min-height: 100dvh;
  display: flex; flex-direction: column;
  background: var(--bg); position: relative;
  padding: max(env(safe-area-inset-top), 12px) 0 max(env(safe-area-inset-bottom), 18px);
  overflow: hidden;
  isolation: isolate;
  font-family: var(--body);
}

/* ── Atmospheric BG: blueprint grid + soft blue glow (Landing-Style) ───── */
.intro-bg {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  overflow: hidden;
}
.intro-bg::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 0.20;
  mask-image: radial-gradient(ellipse 80% 90% at 30% 40%, black 20%, transparent 78%);
  -webkit-mask-image: radial-gradient(ellipse 80% 90% at 30% 40%, black 20%, transparent 78%);
}
.intro-bg::after {
  content: '';
  position: absolute; top: 6%; left: -18%; width: 70%; height: 90%;
  background: radial-gradient(ellipse, rgba(61,90,241,0.10) 0%, transparent 65%);
  pointer-events: none;
  transition: transform 700ms cubic-bezier(0.32, 0.72, 0.16, 1);
}
[data-intro-slide="1"] .intro-bg::after { transform: translate(18%, -3%); }
[data-intro-slide="2"] .intro-bg::after { transform: translate(36%, 3%); }
[data-intro-slide="3"] .intro-bg::after { transform: translate(54%, -2%); }
[data-intro-slide="4"] .intro-bg::after { transform: translate(70%, 2%); }

/* ── Skip ───────────────────────────────────────────────────────────────── */
.intro-skip {
  position: absolute; top: max(env(safe-area-inset-top), 16px); right: 18px;
  background: transparent; border: 1px solid var(--border2);
  color: var(--txt2);
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 7px 12px; border-radius: var(--r); cursor: pointer; z-index: 4;
  transition: color 0.18s, border-color 0.18s;
}
.intro-skip:hover, .intro-skip:active { color: var(--txt); border-color: var(--txt2); }
.intro-skip[hidden] { display: none; }

/* ── Track + Slides ─────────────────────────────────────────────────────── */
.intro-track {
  flex: 1; display: flex; width: 500%;
  transform: translateX(0);
  transition: transform 520ms cubic-bezier(0.32, 0.72, 0.16, 1);
  touch-action: pan-y;
  position: relative; z-index: 1;
}
.intro-slide {
  flex: 0 0 20%;
  display: flex; align-items: center; justify-content: center;
  padding: 24px 28px;
  position: relative;
  overflow: hidden;
}

/* ── Big ghost number (poster watermark, Landing-vibe) ─────────────────── */
.intro-bignum {
  position: absolute;
  top: 50%; right: -4%;
  transform: translateY(-52%);
  font-family: var(--cond); font-weight: 900;
  font-size: clamp(280px, 60vw, 440px);
  line-height: 0.9;
  color: transparent;
  -webkit-text-stroke: 1px var(--border2);
  letter-spacing: 0.04em;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  opacity: 0.55;
  mask-image: linear-gradient(180deg, black 30%, transparent 95%);
  -webkit-mask-image: linear-gradient(180deg, black 30%, transparent 95%);
}
.intro-slide-inner {
  width: 100%; max-width: 460px;
  display: flex; flex-direction: column;
  position: relative; z-index: 1;
}

/* ── Welcome Mark (Slide 1 Logo) ────────────────────────────────────────── */
.intro-mark { margin-bottom: 32px; display: flex; justify-content: flex-start; }
.intro-logo { height: 72px; object-fit: contain; }

/* ── Tag pill (mirrors .l-hero-tag) ─────────────────────────────────────── */
.intro-tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent);
  border: 1px solid rgba(61,90,241,0.3); padding: 5px 10px;
  border-radius: var(--r); display: inline-block;
  margin-bottom: 24px;
  align-self: flex-start;
}

/* ── Headline (mirrors .l-hero-h1) ──────────────────────────────────────── */
.intro-h1 {
  font-family: var(--cond); font-weight: 800; line-height: 1;
  font-size: clamp(40px, 11vw, 72px);
  letter-spacing: -0.01em;
  color: var(--txt);
  margin-bottom: 22px;
  text-transform: none;
}
.intro-h1 .acc { color: var(--accent); }
.intro-h1 .dim { color: var(--txt2); }

/* ── Sub (mirrors .l-hero-sub) ──────────────────────────────────────────── */
.intro-sub {
  font-family: var(--body);
  font-size: 15px; color: var(--txt2); line-height: 1.7;
  max-width: 420px; margin-bottom: 28px;
}
.intro-sub strong { color: var(--txt); font-weight: 500; }

/* ── Trust row (mirrors .l-hero-trust) ──────────────────────────────────── */
.intro-trust {
  display: flex; gap: 18px; flex-wrap: wrap;
  padding-top: 20px;
  border-top: 1px solid var(--border);
  max-width: 460px;
}
.intro-trust-item {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  letter-spacing: 0.06em; display: inline-flex; align-items: center; gap: 7px;
}
.intro-trust-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 8px var(--accent);
}

/* ── Footer (dots + CTA) ────────────────────────────────────────────────── */
.intro-footer {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  padding: 14px 28px 4px;
}
.intro-dots { display: flex; gap: 8px; }
.intro-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--border2);
  transition: background 0.3s, width 0.3s;
}
.intro-dot.active {
  background: var(--accent); width: 22px; border-radius: 100px;
}
.intro-cta {
  font-family: var(--cond); font-weight: 700;
  letter-spacing: 0.02em; text-transform: uppercase;
  font-size: 16px;
  width: 100%; max-width: 360px;
}

/* ── Entry-Animation pro Slide ──────────────────────────────────────────── */
.intro-slide.is-active .intro-mark,
.intro-slide.is-active .intro-tag,
.intro-slide.is-active .intro-h1,
.intro-slide.is-active .intro-sub,
.intro-slide.is-active .intro-trust,
.intro-slide.is-active .intro-bignum {
  animation: intro-rise 720ms cubic-bezier(0.32, 0.72, 0.16, 1) both;
}
.intro-slide.is-active .intro-mark    { animation-delay:  60ms; }
.intro-slide.is-active .intro-tag     { animation-delay: 120ms; }
.intro-slide.is-active .intro-h1      { animation-delay: 200ms; }
.intro-slide.is-active .intro-sub     { animation-delay: 300ms; }
.intro-slide.is-active .intro-trust   { animation-delay: 380ms; }
.intro-slide.is-active .intro-bignum  { animation-delay:   0ms; animation-duration: 1100ms; }
@keyframes intro-rise {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.intro-slide.is-active .intro-bignum {
  animation-name: intro-bignum-rise;
}
@keyframes intro-bignum-rise {
  from { opacity: 0; transform: translateY(-52%) translateX(20px); }
  to   { opacity: 0.55; transform: translateY(-52%) translateX(0); }
}

@media (prefers-reduced-motion: reduce) {
  .intro-track { transition: none; }
  .intro-bg::after { transition: none; }
  .intro-slide.is-active * { animation: none !important; opacity: 1 !important; transform: none !important; }
  .intro-slide.is-active .intro-bignum { opacity: 0.55 !important; transform: translateY(-52%) !important; }
}

/* ── Mobile Optimierung ─────────────────────────────────────────────────── */
@media (max-height: 720px) {
  .intro-h1 { font-size: clamp(36px, 9.5vw, 56px); margin-bottom: 16px; }
  .intro-sub { font-size: 14px; margin-bottom: 22px; line-height: 1.6; }
  .intro-trust { padding-top: 16px; gap: 14px; }
  .intro-mark { margin-bottom: 24px; }
  .intro-logo { height: 60px; }
  .intro-tag { margin-bottom: 18px; }
  .intro-bignum { font-size: clamp(220px, 50vw, 340px); }
}

/* ── AUTH PAGE (Landing-aligned premium) ────────────────────────────────── */
.auth-page {
  min-height: 100vh; min-height: 100dvh;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg); padding: 48px 20px;
  position: relative; overflow: hidden;
  isolation: isolate;
}

/* Atmospheric BG: Blueprint grid + radial blue glow (mirrors landing) */
.auth-bg {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  overflow: hidden;
}
.auth-bg::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 0.20;
  mask-image: radial-gradient(ellipse 80% 90% at 50% 40%, black 20%, transparent 78%);
  -webkit-mask-image: radial-gradient(ellipse 80% 90% at 50% 40%, black 20%, transparent 78%);
}
.auth-bg::after {
  content: '';
  position: absolute; top: 0%; left: 50%; width: 80%; height: 90%;
  transform: translateX(-50%);
  background: radial-gradient(ellipse, rgba(61,90,241,0.10) 0%, transparent 65%);
  pointer-events: none;
}

.auth-page-inner {
  width: 100%; max-width: 420px;
  display: flex; flex-direction: column; align-items: stretch;
  position: relative; z-index: 1;
}

.auth-page-logo {
  display: flex; justify-content: center;
  margin-bottom: 28px;
  text-decoration: none;
  transition: opacity 0.18s, transform 0.18s;
}
.auth-page-logo:hover { opacity: 0.85; transform: translateY(-1px); }
.auth-page-logo:active { transform: translateY(0); }
.auth-page-logo-img { height: 64px; object-fit: contain; pointer-events: none; }

/* Mono kicker pill (mirrors .l-hero-tag / .intro-tag) */
.auth-tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent);
  border: 1px solid rgba(61,90,241,0.3); padding: 5px 10px;
  border-radius: var(--r); display: inline-block;
  margin: 0 auto 22px;
  align-self: center;
}

/* Condensed headline (mirrors .l-hero-h1 / .intro-h1) */
.auth-h1 {
  font-family: var(--cond); font-weight: 800; line-height: 1;
  font-size: clamp(36px, 9vw, 56px);
  letter-spacing: -0.01em;
  color: var(--txt);
  margin: 0 0 14px;
  text-align: center;
}
.auth-h1 .acc { color: var(--accent); }

.auth-sub {
  font-family: var(--body);
  font-size: 14px; color: var(--txt2); line-height: 1.6;
  text-align: center;
  max-width: 360px; margin: 0 auto 32px;
}

/* Card with subtle accent inner-glow */
.auth-page-card {
  width: 100%;
  background: linear-gradient(165deg, rgba(20,20,26,0.85), rgba(12,12,16,0.85));
  border: 1px solid var(--border);
  border-radius: 16px; padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
  box-shadow:
    0 24px 60px rgba(0,0,0,0.45),
    0 0 0 1px rgba(61,90,241,0.05) inset,
    0 0 24px rgba(61,90,241,0.04) inset;
  backdrop-filter: blur(8px);
  position: relative;
}

/* OAuth Provider Button (Google) */
.auth-oauth-btn {
  width: 100%;
  display: flex; align-items: center; justify-content: center; gap: 12px;
  padding: 13px 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border2);
  border-radius: var(--r);
  color: var(--txt);
  font-family: var(--cond); font-weight: 700;
  font-size: 15px; letter-spacing: 0.02em; text-transform: uppercase;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, transform 0.15s;
}
.auth-oauth-btn:hover {
  background: rgba(255,255,255,0.07);
  border-color: var(--txt3);
}
.auth-oauth-btn:active { transform: translateY(1px); }
.auth-oauth-btn:disabled {
  opacity: 0.5; cursor: not-allowed; transform: none;
}
.auth-oauth-btn.loading .auth-oauth-label::after {
  content: '…';
  animation: oauth-loading-dots 1.2s steps(4, end) infinite;
}
@keyframes oauth-loading-dots {
  0%   { content: '.'; }
  25%  { content: '..'; }
  50%  { content: '...'; }
  75%  { content: '....'; }
  100% { content: '.'; }
}
.auth-oauth-icon {
  width: 18px; height: 18px; flex-shrink: 0;
}

/* Divider with "oder" label */
.auth-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 4px 0 2px;
  color: var(--txt3);
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
}
.auth-divider::before,
.auth-divider::after {
  content: ''; flex: 1; height: 1px;
  background: var(--border);
}

/* Tabs as underline indicator (premium tab-bar style) */
.auth-tabs {
  display: flex; gap: 0; background: none;
  border-bottom: 1px solid var(--border);
  padding: 0; margin: -4px -4px 12px;
  position: relative;
}
.auth-tab {
  flex: 1; padding: 12px 8px;
  border: none; background: none;
  color: var(--txt3);
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  cursor: pointer;
  transition: color 0.18s;
  position: relative; z-index: 1;
}
.auth-tab:hover { color: var(--txt2); }
.auth-tab.active { color: var(--accent); background: none; box-shadow: none; }
.auth-tab-indicator {
  position: absolute;
  bottom: -1px; left: 0;
  width: 50%; height: 1px;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(61,90,241,0.6);
  transition: transform 0.32s cubic-bezier(0.32, 0.72, 0.16, 1);
  transform: translateX(0);
}
.auth-tabs[data-tab="register"] .auth-tab-indicator {
  transform: translateX(100%);
}

/* Error message */
.auth-error {
  color: var(--red); font-size: 12px; font-family: var(--mono);
  letter-spacing: 0.04em;
  display: none;
  padding: 8px 10px;
  background: rgba(224,53,53,0.08);
  border: 1px solid rgba(224,53,53,0.2);
  border-radius: var(--r);
}

.auth-forgot-msg {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em;
  display: none;
  padding: 8px 10px;
  background: rgba(61,90,241,0.06);
  border: 1px solid rgba(61,90,241,0.2);
  border-radius: var(--r);
  color: var(--txt2);
}

/* Primary CTA — gleicher Stil wie intro-cta */
.auth-cta {
  width: 100%;
  font-family: var(--cond); font-weight: 700;
  letter-spacing: 0.02em; text-transform: uppercase;
  font-size: 16px;
  margin-top: 4px;
}

/* Trust row (mirrors .l-hero-trust / .intro-trust) */
.auth-trust {
  display: flex; gap: 18px; flex-wrap: wrap; justify-content: center;
  padding-top: 26px; margin-top: 24px;
  border-top: 1px solid var(--border);
}
.auth-trust-item {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  letter-spacing: 0.06em; display: inline-flex; align-items: center; gap: 7px;
}
.auth-trust-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 8px var(--accent);
}

/* Legal-Footer mit Impressum/Datenschutz Links */
.auth-legal {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; flex-wrap: wrap;
  margin-top: 18px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.06em;
}
.auth-legal-link {
  color: var(--txt3); text-decoration: none;
  transition: color 0.15s;
}
.auth-legal-link:hover { color: var(--txt); }
.auth-legal-sep { color: var(--border2); }

/* Mobile tweaks */
@media (max-height: 720px) {
  .auth-page { padding: 24px 20px; }
  .auth-page-logo { margin-bottom: 18px; }
  .auth-page-logo-img { height: 52px; }
  .auth-tag { margin-bottom: 16px; }
  .auth-h1 { font-size: clamp(30px, 7vw, 44px); margin-bottom: 10px; }
  .auth-sub { margin-bottom: 22px; font-size: 13px; }
  .auth-page-card { padding: 20px; gap: 12px; }
  .auth-trust { padding-top: 18px; margin-top: 18px; }
}
/* ── AUTH HEADER ─────────────────────────────────────────────────────────── */
.sync-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; background: var(--border2); transition: background 0.3s, opacity 0.4s, width 0.3s, margin 0.3s; cursor: default; }
.sync-dot.sync-synced { background: var(--green); }
.sync-dot.sync-syncing { background: var(--accent); animation: syncpulse 1s infinite; }
.sync-dot.sync-error { background: var(--red); }
.sync-dot.sync-offline { background: var(--amber); }
@keyframes syncpulse { 0%,100%{opacity:1} 50%{opacity:0.3} }

/* Header-Sync-Dot nur sichtbar bei Problemen oder während Sync.
   Synced (Default 99% der Zeit) = unsichtbar — Apple-Pattern für Premium-Apps.
   Account-Page-Sync-Dot bleibt sichtbar weil dedizierter Status-Bereich. */
.sync-dot-header.sync-synced:not(#acc-profile-sync-dot) {
  opacity: 0;
  width: 0;
  margin: 0 -4px; /* keine Lücke im Layout wenn unsichtbar */
  pointer-events: none;
}
.btn-ghost { font-family: var(--mono); font-size: 10px; color: var(--txt2); background: none; border: 1px solid var(--border2); padding: 6px 14px; border-radius: var(--r); cursor: pointer; transition: all 0.2s; }
.btn-ghost:hover { color: var(--txt); border-color: var(--txt2); }

/* ── MENU DRAWER ─────────────────────────────────────────────────────────── */
.menu-btn {
  width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0;
  background: none; border: none; color: var(--txt); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.menu-btn:active { background: rgba(255,255,255,0.07); }
.menu-backdrop {
  position: fixed; inset: 0; z-index: 9700;
  background: rgba(0,0,0,0.5); backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none; transition: opacity 0.25s;
}
.menu-backdrop.open { opacity: 1; pointer-events: all; }
.menu-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(300px, 82vw);
  background: var(--surface); border-left: 1px solid var(--border2);
  z-index: 9800; display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
}
.menu-drawer.open { transform: translateX(0); }
.menu-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 16px; height: 56px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.menu-drawer-title { font-family: var(--cond); font-size: 18px; font-weight: 700; letter-spacing: 0.02em; }
.menu-close-btn {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--surface2); border: none; color: var(--txt);
  display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 16px;
}
.menu-body { flex: 1; overflow-y: auto; padding: 8px 0; }
.menu-section { padding: 16px 16px 8px; }
.menu-section + .menu-section { border-top: 1px solid var(--border); }
.menu-section-label {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--txt3); margin-bottom: 10px;
}
.menu-account-email {
  font-family: var(--mono); font-size: 12px; color: var(--txt2);
  margin-bottom: 6px; word-break: break-all; padding: 0 4px;
}
.menu-sync-row {
  display: flex; align-items: center; gap: 8px; padding: 4px 4px 12px;
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
}
.menu-item {
  display: flex; align-items: center; gap: 12px;
  width: 100%; background: none; border: none;
  color: var(--txt2); font-family: var(--mono); font-size: 13px;
  padding: 11px 12px; border-radius: 10px; cursor: pointer;
  text-align: left; transition: background 0.15s;
}
.menu-item:active { background: rgba(255,255,255,0.06); }
.menu-item svg { flex-shrink: 0; opacity: 0.55; }
.menu-item-danger { color: var(--red); }
.menu-item-danger svg { opacity: 0.7; }
#import-file { display: none; }

/* ── KM QUICK UPDATE ───────────────────────────────────────────────────── */
.km-quick { display: inline-flex; align-items: center; gap: 6px; margin-left: 8px; }
.km-quick input { font-family: var(--mono); font-size: 12px; width: 90px; padding: 2px 6px; border-radius: var(--r); border: 1px solid var(--border2); background: var(--surface); color: var(--txt); text-align: right; }
.km-quick button { font-family: var(--mono); font-size: 10px; padding: 3px 8px; border-radius: var(--r); border: 1px solid var(--accent); background: none; color: var(--accent); cursor: pointer; }
.km-quick button:hover { background: var(--accent); color: #fff; }
.km-editable { cursor: pointer; border-bottom: 1px dashed var(--txt2); }
.km-editable:hover { color: var(--accent); border-color: var(--accent); }

/* ── COST SUMMARY ──────────────────────────────────────────────────────── */
.cost-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; padding: 14px; border-bottom: 1px solid var(--border); }
.cost-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 12px; text-align: center; }
.cost-value { font-family: var(--cond); font-size: 22px; font-weight: 700; color: var(--txt); line-height: 1.2; }
.cost-label { font-family: var(--mono); font-size: 9px; color: var(--txt2); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 4px; }

/* ── MAINT PHOTOS ──────────────────────────────────────────────────────── */
.me-images { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 6px; }
.me-images .img-thumb { width: 48px; height: 48px; }

/* ── VEHICLE PHOTO GALLERY (in Fahrzeugdaten) ─────────────────────────── */
.vic-photos-section { margin-top: 14px; }
.vic-photos-label {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 8px;
  display: flex; align-items: center; justify-content: space-between;
}
.vic-photo-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px;
}
.vic-photo-thumb {
  aspect-ratio: 1; border-radius: var(--r); overflow: hidden;
  background: var(--surface2); position: relative; cursor: pointer;
}
.vic-photo-thumb img { width: 100%; height: 100%; object-fit: cover; }
.vic-photo-thumb .vph-del {
  position: absolute; top: 3px; right: 3px;
  background: rgba(0,0,0,0.7); color: #fff; border: none;
  width: 20px; height: 20px; border-radius: 50%; font-size: 10px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.15s;
}
.vic-photo-thumb:hover .vph-del { opacity: 1; }

@media (max-width: 640px) {
  .cost-summary { grid-template-columns: repeat(2, 1fr); gap: 8px; padding: 10px; }
  .cost-value { font-size: 18px; }
  .cost-card { padding: 8px; }
  .km-quick input { width: 80px; }
  .dash-footer { padding: 16px 14px; }
}


/* ── SWIPE GESTURES ────────────────────────────────────────────────────── */
.swipe-wrapper {
  position: relative; overflow: hidden;
}
.swipe-bg {
  position: absolute; inset: 0; display: flex; align-items: center;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  padding: 0 20px; opacity: 0; transition: opacity 0.15s;
}
.swipe-bg.left { justify-content: flex-end; background: var(--red); color: #fff; }
.swipe-bg.right { justify-content: flex-start; background: #2d8a4e; color: #fff; }
.swipe-bg.revealed { opacity: 1; }
.swipe-content {
  position: relative; background: var(--bg);
  transition: transform 0.25s cubic-bezier(0.2, 0, 0, 1);
  z-index: 1;
}
.swipe-content.dragging { transition: none; }

/* ── BOTTOM SHEET ──────────────────────────────────────────────────────── */
/* ── BOTTOM SHEET ──────────────────────────────────────────────────────────
   Patina-Floating-Panel-Sprache: dunkle Surface, Hairlines statt Cards,
   monochrome Icons mit Akzent-Tint, Barlow Condensed Hierarchie.
   Konsistent mit Modal-Overlay (selber Backdrop-Blur, selbe Surface-Ebene). */
.bottom-sheet-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.62);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  /* Über allem inkl. POV (9000), Lightbox (9999), Modal (10500), Lightbox-aus-Modal (11000). */
  z-index: 11500; opacity: 0; transition: opacity 0.22s ease;
  display: none;
}
.bottom-sheet-overlay.active { display: block; opacity: 1; }
.bottom-sheet {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--surface);
  border-top: 1px solid rgba(255,255,255,0.08);
  border-radius: 24px 24px 0 0;
  box-shadow: 0 -30px 80px rgba(0,0,0,0.65);
  z-index: 11501; transform: translateY(100%);
  /* Margin-bottom (Keyboard-Aware) smooth animieren statt hart springen */
  transition: transform 0.32s cubic-bezier(0.22, 0.9, 0.24, 1),
              margin-bottom 0.22s cubic-bezier(0.22, 0.9, 0.24, 1);
  max-height: 82vh; overflow-y: auto;
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.bottom-sheet-overlay.active .bottom-sheet { transform: translateY(0); }

/* Desktop: zentrieren mit max-width wie die anderen Modals — sonst spannt
 * sich das Sheet über die volle Bildschirmbreite (sieht falsch aus). */
@media (min-width: 600px) {
  .bottom-sheet {
    left: 50%; right: auto;
    width: calc(100% - 48px);
    max-width: 520px;
    border-radius: 16px;
    margin-bottom: 24px;
    border: 1px solid rgba(255,255,255,0.08);
    transform: translateX(-50%) translateY(110%);
    box-shadow: 0 30px 80px rgba(0,0,0,0.65);
  }
  .bottom-sheet-overlay.active .bottom-sheet {
    transform: translateX(-50%) translateY(0);
  }
}
.bs-handle {
  width: 38px; height: 4px;
  background: rgba(255,255,255,0.18);
  border-radius: 4px; margin: 10px auto 0;
}
.bs-title {
  font-family: var(--cond); font-size: 22px; font-weight: 800;
  letter-spacing: -0.01em;
  padding: 16px 24px 14px;
  text-align: center;
  color: var(--txt);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.bs-section-label {
  font-family: var(--mono); font-size: 9px; text-transform: uppercase;
  letter-spacing: 0.14em; color: var(--accent);
  padding: 18px 24px 6px;
  font-weight: 700;
}
/* Standard-Option: schlichte Zeile, Hairline-Divider zwischen */
.bs-option {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 24px;
  background: transparent; border: none; border-radius: 0;
  margin: 0;
  cursor: pointer;
  transition: background 0.15s ease;
  font-size: 14px; color: var(--txt);
  -webkit-tap-highlight-color: transparent;
}
.bs-option + .bs-option { border-top: 1px solid rgba(255,255,255,0.04); }
@media (hover: hover) {
  .bs-option:hover { background: rgba(255,255,255,0.035); }
}
.bs-option:active { background: rgba(255,255,255,0.06); }
.bs-option .bs-icon {
  width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 16px; color: var(--txt2);
}
.bs-option.active { color: var(--accent); }
.bs-option.active .bs-icon { color: var(--accent); }
.bs-option.danger { color: var(--red); }

/* ── APP MENU (Overflow im Header) ────────────────────────────────────────
   Eigenes Overlay — responsive:
   Mobile = Side-Drawer von rechts (full-height), Desktop = Dropdown top-right. */
.app-menu-overlay {
  position: fixed; inset: 0; z-index: 11500;
  background: rgba(0,0,0,0.62);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s cubic-bezier(0.32,0.72,0,1);
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
}
.app-menu-overlay.active {
  opacity: 1;
  pointer-events: auto;
}
.app-menu-panel {
  width: 86%;
  max-width: 360px;
  background: var(--surface);
  border-left: 1px solid rgba(255,255,255,0.08);
  box-shadow: -30px 0 80px rgba(0,0,0,0.65);
  padding: 18px 0 calc(18px + env(safe-area-inset-bottom));
  padding-top: calc(18px + env(safe-area-inset-top));
  transform: translateX(100%);
  transition: transform 0.32s cubic-bezier(0.32,0.72,0,1);
  display: flex; flex-direction: column;
  height: 100%; overflow-y: auto;
}
.app-menu-overlay.active .app-menu-panel {
  transform: translateX(0);
}
/* Desktop: Dropdown am Trigger top-right */
@media (min-width: 600px) {
  .app-menu-overlay {
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    align-items: flex-start;
    justify-content: flex-end;
    padding: 60px 16px 0 0;
  }
  .app-menu-panel {
    width: 320px;
    max-width: 320px;
    height: auto;
    border: 1px solid rgba(255,255,255,0.08);
    border-left: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    box-shadow: 0 24px 60px rgba(0,0,0,0.6);
    padding: 8px 0 10px;
    max-height: calc(100vh - 80px);
    transform: translateY(-8px) scale(0.97);
    transform-origin: top right;
    transition: transform 0.22s cubic-bezier(0.32,0.72,0,1), opacity 0.18s;
    opacity: 0;
  }
  .app-menu-overlay.active .app-menu-panel {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

.appmenu {
  display: flex; flex-direction: column;
}
/* User-Section */
.appmenu-user {
  display: flex; align-items: center; gap: 14px;
  padding: 4px 24px 18px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 6px;
}
.appmenu-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(61,90,241,0.2), rgba(61,90,241,0.05));
  border: 1px solid rgba(61,90,241,0.3);
  color: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--cond);
  font-size: 16px; font-weight: 700;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.appmenu-user-text {
  flex: 1; min-width: 0;
}
.appmenu-user-name {
  font-family: var(--cond);
  font-weight: 700; font-size: 17px;
  letter-spacing: -0.005em;
  color: var(--txt);
  line-height: 1.15;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.appmenu-user-email {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--txt3);
  letter-spacing: 0.04em;
  margin-top: 3px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.appmenu-user-anon .appmenu-user-name { color: var(--txt2); }
.appmenu-signin-btn {
  font-family: var(--mono);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
  background: rgba(61,90,241,0.1);
  border: 1px solid rgba(61,90,241,0.4);
  padding: 8px 14px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
}
.appmenu-signin-btn:hover { background: rgba(61,90,241,0.2); }

/* Menu-Items */
.appmenu-items {
  display: flex; flex-direction: column;
}
.appmenu-item {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 24px;
  background: transparent;
  border: 0; border-radius: 0;
  color: var(--txt);
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
  width: 100%;
}
.appmenu-item:hover { background: rgba(255,255,255,0.03); }
.appmenu-item:active { background: rgba(255,255,255,0.06); }
.appmenu-item-icon {
  display: flex; align-items: center; justify-content: center;
  color: var(--txt2);
}
.appmenu-item-text {
  display: flex; flex-direction: column; gap: 2px;
  min-width: 0;
}
.appmenu-item-label {
  font-family: var(--cond);
  font-weight: 700; font-size: 16px;
  letter-spacing: -0.005em;
  color: var(--txt);
}
.appmenu-item-sub {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--txt3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.appmenu-item-chev {
  color: var(--txt3);
  opacity: 0.4;
  display: flex; align-items: center;
}
.appmenu-item:hover .appmenu-item-chev { opacity: 0.8; color: var(--txt2); }

/* Footer / Logout */
.appmenu-footer {
  margin-top: 8px;
  padding: 12px 24px 4px;
  border-top: 1px solid var(--border);
}
.appmenu-logout {
  display: flex; align-items: center; gap: 10px;
  width: 100%;
  padding: 12px 14px;
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 10px;
  color: var(--txt2);
  font-family: var(--mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  cursor: pointer;
  justify-content: center;
  transition: all 0.18s;
}
.appmenu-logout:hover {
  background: rgba(220,38,38,0.08);
  border-color: var(--red);
  color: var(--red);
}

/* Desktop-Dropdown: kompakter padding/sizing */
@media (min-width: 600px) {
  .app-menu-panel .appmenu-user {
    padding: 14px 18px 14px;
    margin-bottom: 4px;
  }
  .app-menu-panel .appmenu-avatar {
    width: 36px; height: 36px;
    font-size: 13px;
  }
  .app-menu-panel .appmenu-user-name { font-size: 15px; }
  .app-menu-panel .appmenu-user-email { font-size: 10px; }
  .app-menu-panel .appmenu-item {
    padding: 11px 18px;
    grid-template-columns: 24px 1fr auto;
    gap: 12px;
  }
  .app-menu-panel .appmenu-item-label { font-size: 14px; }
  .app-menu-panel .appmenu-item-sub { font-size: 9px; }
  .app-menu-panel .appmenu-footer {
    padding: 10px 18px 4px;
  }
  .app-menu-panel .appmenu-logout {
    padding: 10px 12px;
    font-size: 10px;
  }
}
.bs-cancel {
  padding: 16px 24px;
  margin: 0;
  text-align: center;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--txt2);
  background: transparent;
  border: none;
  border-top: 1px solid rgba(255,255,255,0.05);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.bs-cancel:hover { color: var(--txt); background: rgba(255,255,255,0.025); }

/* ── SWIPE HINT ────────────────────────────────────────────────────────── */
.swipe-hint {
  font-family: var(--mono); font-size: 9px; color: var(--txt3);
  text-align: center; padding: 6px; letter-spacing: 0.04em;
}

@media (min-width: 641px) {
  .swipe-hint { display: none; }
}

/* ── MODAL ANIMATIONS ─────────────────────────────────────────────────── */

/* Overlay: pure opacity fade so the dark bg + blur appear gradually */
@keyframes modal-overlay-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes modal-overlay-out { from { opacity: 1; } to { opacity: 0; } }

/* Mobile (default): sheet slides up from below the viewport edge.
   Easing in = cubic spring → opens with energy.
   Easing out = accelerating gravity curve → "falls away". */
@keyframes modal-sheet-up {
  from { transform: translateY(60%); opacity: 0; }
  to   { transform: translateY(0);   opacity: 1; }
}
@keyframes modal-sheet-down {
  from { transform: translateY(0);   opacity: 1; }
  to   { transform: translateY(60%); opacity: 0; }
}

/* Desktop (≥600px): modal is centered — full-screen slide looks too
   dramatic. Use a shorter float-up + scale instead (feels like a dialog
   appearing from just below its resting position). */
@media (min-width: 600px) {
  @keyframes modal-sheet-up {
    from { transform: translateY(18px) scale(0.97); opacity: 0; }
    to   { transform: translateY(0)    scale(1);    opacity: 1; }
  }
  @keyframes modal-sheet-down {
    from { transform: translateY(0)    scale(1);    opacity: 1; }
    to   { transform: translateY(18px) scale(0.97); opacity: 0; }
  }
}

/* ═══════════ DASHBOARD HERO ═════════════════════════════════════════════ */
.dash-hero { margin-bottom: 24px; }
.dash-hero:empty { display: none; }

/* Greeting */
.dash-greet {
  margin-bottom: 12px;
  padding: 0 2px;
}
.dash-greet-title {
  font-family: var(--cond); font-size: 26px; font-weight: 700;
  color: var(--txt); letter-spacing: 0.01em; line-height: 1.1;
}
.dash-greet-title .dg-accent { color: var(--accent); }
.dash-greet-sub {
  font-family: var(--mono); font-size: 9px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.1em; margin-top: 5px;
}

/* ── Welcome-Hero (First-Time Empty State) ──────────────────────────────
   Editorial Premium: Big Cond-Headline + Mono-Caps Kicker + großer CTA.
   Surface2 + Glow-Card-Frame, identische DNA wie Stats/Carousel-Cards. */
.dash-welcome {
  margin-top: 14px;
  padding: 28px 22px 24px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  position: relative; overflow: hidden;
}
.dash-welcome::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.dash-welcome-kicker {
  font-family: var(--mono); font-size: 10px; color: var(--accent);
  text-transform: uppercase; letter-spacing: 0.22em;
  margin-bottom: 12px;
  position: relative;
}
.dash-welcome-title {
  font-family: var(--cond); font-size: 28px; font-weight: 700;
  color: var(--txt); line-height: 1.15;
  letter-spacing: 0.005em;
  margin-bottom: 10px;
  position: relative;
}
.dash-welcome-sub {
  font-size: 14px; color: var(--txt2);
  line-height: 1.55;
  margin-bottom: 22px;
  position: relative;
  max-width: 440px;
}
.dash-welcome-cta {
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--accent); color: #fff;
  border: none; padding: 12px 20px;
  border-radius: 10px;
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  cursor: pointer; position: relative;
  transition: background 0.18s, transform 0.15s;
}
.dash-welcome-cta:hover { background: color-mix(in srgb, var(--accent) 88%, white); }
.dash-welcome-cta:active { transform: scale(0.97); }
.dash-welcome-cta svg { transition: transform 0.18s; pointer-events: none; }
.dash-welcome-cta span { pointer-events: none; }
.dash-welcome-cta:hover svg { transform: translateX(2px); }
@media (max-width: 520px) {
  .dash-welcome { padding: 22px 18px 20px; }
  .dash-welcome-title { font-size: 22px; }
  .dash-welcome-sub { font-size: 13px; margin-bottom: 18px; }
}

/* Stats strip — matches .vic-stats-card */
.dash-stats-card {
  margin-bottom: 12px;
  border-radius: 14px;
  background: var(--surface2);
  border: 1px solid var(--border);
  overflow: hidden;
  position: relative;
}
.dash-stats-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.dash-stats-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  position: relative;
}
.dash-stat {
  padding: 12px 14px;
  min-width: 0;
  display: flex; flex-direction: column; justify-content: center;
}
.dash-stats-grid .dash-stat + .dash-stat {
  border-left: 1px solid rgba(255,255,255,0.07);
}
.dash-stat-label {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.18em;
  margin-bottom: 5px;
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 4px;
}
.dash-stat-val {
  font-family: var(--cond); font-size: 24px; font-weight: 800;
  line-height: 1; color: var(--txt);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  letter-spacing: -0.005em;
}
.dash-stat-val.overdue { color: var(--red); }
.dash-stat-val.soon    { color: var(--amber); }
.dash-stat-val.ok      { color: var(--green); }
.dash-stat-val.attn    { color: var(--txt); }
/* Re-statet die VIC-Farbklassen mit doppelter Spezifität — sonst überschreibt
   .dash-stat-val { color: var(--txt) } die globalen .vic-stat-* Klassen. */
.dash-stat-val.vic-stat-done-pos { color: var(--green); }
.dash-stat-val.vic-stat-empty    { color: var(--txt3); font-weight: 300; }
/* Tappable Stat (z.B. Dashboard-„Erledigt") — Cursor + Pfeil-Hinweis identisch zur VIC-Variante */
.dash-stat-tap { cursor: pointer; transition: background 0.15s; }
.dash-stat-tap:active { background: rgba(255,255,255,0.05); }
.dash-stat-tap-arrow {
  display: inline-block;
  font-size: 11px; line-height: 1;
  color: var(--txt3); opacity: 0.7;
  transform: translateY(-1px);
  transition: opacity .15s, color .15s, transform .15s;
}
.dash-stat-tap:hover .dash-stat-tap-arrow,
.dash-stat-tap:active .dash-stat-tap-arrow {
  color: var(--accent); opacity: 1;
  transform: translate(1px, -2px);
}

/* ── Dashboard-Carousel: Transform-basiert wie Vehicle-Hero (.vh-track) für
   konsistentes Premium-Feeling — snappy, smooth, ohne native Scroll-Inertia.
   Touch-Handler im JS detektiert Threshold und setzt translateX direkt. */
.dash-carousel {
  position: relative;
  overflow: hidden; /* clipt nicht-aktive Slides */
}
.dash-carousel-slide {
  flex: 0 0 100%;
  min-width: 0;
  width: 100%;
}
/* Track: Live-Drag mit Rubber-Band + Velocity wie .vic-tab-track. Easing
   und Dauer 1:1 — gleiches Premium-Feeling. Touch-action: pan-y damit
   vertikales Scrollen frei bleibt, horizontaler Swipe via Pointer-Events. */
.dash-carousel-track {
  display: flex;
  align-items: flex-start;
  will-change: transform, height;
  transition: transform 0.42s cubic-bezier(0.32, 0.72, 0.16, 1),
              height    0.42s cubic-bezier(0.32, 0.72, 0.16, 1);
  touch-action: pan-y;
  cursor: grab;
}
.dash-carousel-track:active { cursor: grabbing; }
/* Letzter Row in der Liste: kein Border (clean unten) */
.dash-attn-grid > .dash-attn-item:last-child { border-bottom: none; }
/* Carousel-Nav: Pfeile + Dots in einer Zeile unten. Editorial — keine
   Floating-Buttons über Content. Dots-Pattern matcht .vh-dots im
   Vehicle-Hero (6×6 → 14px Pille active) für app-weite Konsistenz. */
.dash-carousel-nav {
  display: flex; align-items: center; justify-content: center;
  gap: 14px;
  padding: 14px 0 4px;
}
.dash-carousel-dots {
  display: flex; align-items: center; gap: 5px;
}
.dash-dot {
  /* 1:1 wie .vh-dot: 6×6 inactive → 14px Pille active. Inline-Button ohne
     Tap-Target-Aufblähung — visueller Abstand matcht Vehicle-Hero exakt.
     Touch-User swipen primär, Click ist sekundär. */
  width: 6px; height: 6px; padding: 0; margin: 0;
  background: var(--txt3); opacity: 0.55;
  border: none; border-radius: 50%;
  cursor: pointer; flex-shrink: 0;
  transition: background 0.2s, opacity 0.2s, width 0.2s, border-radius 0.2s;
}
.dash-dot:hover { opacity: 0.85; }
.dash-dot.active {
  background: var(--accent); opacity: 1;
  width: 14px; border-radius: 3px;
}

/* Pfeile: dezent, nur auf Desktop sichtbar — Mobile swiped nativ */
.dash-arrow {
  width: 24px; height: 24px; padding: 0;
  background: none; border: none;
  display: none; align-items: center; justify-content: center;
  color: var(--txt3); cursor: pointer;
  border-radius: 6px;
  transition: color 0.15s, background 0.15s, transform 0.15s, opacity 0.15s;
}
.dash-arrow:not(:disabled):hover { color: var(--txt); background: rgba(255,255,255,0.04); }
.dash-arrow:not(:disabled):active { transform: scale(0.92); }
.dash-arrow:disabled { opacity: 0.25; cursor: default; }
@media (hover: hover) and (pointer: fine) {
  .dash-arrow { display: inline-flex; }
}

/* ── Investiert-Slide ──────────────────────────────────────────────────
   Reuses .dash-attn frame (surface2 + glow + 14px border-radius) für
   visuelle Konsistenz mit „Das steht an". */
/* Empty-Marker neutral grau (für Historie-Slide ohne Aktivität) */
.dash-attn-empty-marker.dash-empty-neutral { color: var(--txt3); }

/* Attention list — matches .vic-stats-card */
.dash-attn {
  border-radius: 14px;
  background: var(--surface2);
  border: 1px solid var(--border);
  overflow: hidden;
  position: relative;
}
.dash-attn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.dash-attn-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  position: relative;
}
.dash-attn-label {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.18em;
}
.dash-attn-count {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.18em;
}
.dash-attn-grid {
  display: flex;
  flex-direction: column;
  position: relative;
}
.dash-attn-grid .dash-attn-item:last-child {
  border-bottom: none;
}
.dash-attn-item {
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 12px 16px 13px;
  background: none; border: none;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  color: var(--txt); text-align: left; cursor: pointer;
  transition: background 0.15s;
  font-family: inherit;
  position: relative;
}
.dash-attn-row-main {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column; align-items: flex-start;
}
.dash-attn-chev {
  display: inline-block;
  font-size: 13px; line-height: 1;
  color: var(--txt3); opacity: 0.55;
  flex-shrink: 0;
  transform: translateY(-1px);
  transition: opacity .15s, color .15s, transform .15s;
}
.dash-attn-item:hover { background: rgba(255,255,255,0.025); }
.dash-attn-item:hover .dash-attn-chev,
.dash-attn-item:active .dash-attn-chev {
  color: var(--accent); opacity: 1;
  transform: translate(1px, -2px);
}
.dash-attn-item:active { background: rgba(255,255,255,0.05); }

/* „+ N weitere" Link unten in der Liste — dezent, mono caps */
.dash-attn-more {
  display: block; width: 100%;
  padding: 12px 16px 14px;
  background: none; border: none; border-top: 1px solid rgba(255,255,255,0.07);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt3);
  text-align: center; cursor: pointer;
  transition: color 0.15s, background 0.15s;
}
.dash-attn-more:hover { color: var(--txt); background: rgba(255,255,255,0.03); }
.dash-attn-more:active { color: var(--accent); }

.dash-attn-label-row {
  display: flex; align-items: center; gap: 5px;
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
  margin-bottom: 5px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 100%;
}
.dash-attn-label-row svg { flex-shrink: 0; color: var(--txt2); }
.dash-attn-vehicle { color: var(--txt2); }
.dash-attn-sep     { color: var(--border2); }
.dash-attn-status  { color: var(--txt2); font-weight: 500; }

/* Nur Status-Label + Icon einfärben — Fahrzeug-Name bleibt neutral.
   Macht es subtiler und der User weiß SOFORT warum die Farbe da ist. */
.dash-attn-item.overdue .dash-attn-label-row svg,
.dash-attn-item.overdue .dash-attn-status { color: var(--red); }

.dash-attn-item.soon    .dash-attn-label-row svg,
.dash-attn-item.soon    .dash-attn-status { color: var(--amber); }

.dash-attn-item.prio    .dash-attn-label-row svg,
.dash-attn-item.prio    .dash-attn-status { color: var(--red); }

/* „medium" = Mittlere Priorität — gleicher Code wie data-prio="medium" Border-Left */
.dash-attn-item.medium  .dash-attn-label-row svg,
.dash-attn-item.medium  .dash-attn-status { color: var(--amber); }

/* „open" = Offene To-Dos ohne Dringlichkeitsgrad — neutral, kein Farbcode */
.dash-attn-item.open    .dash-attn-label-row svg,
.dash-attn-item.open    .dash-attn-status { color: var(--txt2); }
.dash-attn-title {
  font-family: var(--cond); font-size: 18px; font-weight: 700;
  color: var(--txt); line-height: 1.2;
  letter-spacing: 0.005em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 100%;
}

/* Empty state — editorial Status-Marker (Dot + Mono-Caps), keine Material-Bubble */
.dash-attn-empty {
  padding: 22px 14px 24px; text-align: center;
  position: relative;
}
.dash-attn-empty-marker {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--green);
}
.dash-attn-empty-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor; display: inline-block;
  opacity: 0.9;
}

@media (max-width: 520px) {
  .dash-greet-title { font-size: 23px; }
  .dash-stat { padding: 12px; }
  .dash-stat-val { font-size: 24px; }
  .dash-stat-label { font-size: 9px; }
  .dash-attn-title { font-size: 16px; }
}

/* ═══════════ SETTINGS RADIOS ════════════════════════════════════════════ */
.settings-group { margin-bottom: 18px; }
.settings-group:last-child { margin-bottom: 4px; }
.settings-group-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--txt3);
  margin-bottom: 8px; padding-left: 2px;
}
.settings-radio {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px; margin-bottom: 4px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 8px; cursor: pointer;
  transition: border-color 0.12s, background 0.12s;
  font-size: 13.5px; color: var(--txt);
}
.settings-radio:hover { border-color: var(--border2); }
.settings-radio input[type="radio"] { accent-color: var(--accent); margin: 0; }
.settings-radio:has(input:checked) {
  border-color: var(--accent);
  background: rgba(61,90,241,0.06);
}

/* ═══════════ LEGAL CONTENT ═══════════════════════════════════════════════ */
.legal-content {
  font-size: 13px; line-height: 1.6; color: var(--txt);
}
.legal-content h3 {
  font-size: 14px; margin: 18px 0 8px; color: var(--txt);
  font-weight: 600;
}
.legal-content h3:first-child { margin-top: 0; }
.legal-content p { margin: 0 0 10px; color: var(--txt2); }
.legal-content strong { color: var(--txt); font-weight: 500; }
.legal-content .legal-placeholder {
  background: var(--surface2); border: 1px dashed var(--border2);
  border-radius: 8px; padding: 14px 16px; margin: 12px 0;
  font-family: var(--mono); font-size: 11px;
  color: var(--txt3); line-height: 1.6;
}

/* ═══════════ AUTH: FORGOT PASSWORD LINK ════════════════════════════════ */
.auth-link {
  display: block; width: 100%; text-align: center;
  background: none; border: none;
  color: var(--txt2); font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.04em; padding: 12px 0 2px;
  cursor: pointer; transition: color 0.12s;
}
.auth-link:hover { color: var(--accent); }
.auth-forgot-title {
  font-size: 16px; font-weight: 600; color: var(--txt);
  margin-bottom: 8px; text-align: center;
}
.auth-forgot-sub {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  line-height: 1.5; margin-bottom: 18px; text-align: center;
}

/* ═══════════ ACCOUNT PAGE ═══════════════════════════════════════════════ */
.acc-content {
  flex: 1; padding: 20px 16px 60px; max-width: 640px; width: 100%;
  margin: 0 auto; background: var(--bg);
}

/* Profile card */
.acc-profile {
  display: flex; align-items: center; gap: 14px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px; margin-bottom: 28px;
}
.acc-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), #5a72f5);
  color: #fff; font-family: var(--mono); font-size: 18px;
  font-weight: 600; letter-spacing: 0.02em;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.acc-profile-info { flex: 1; min-width: 0; }
.acc-profile-name {
  font-size: 16px; font-weight: 600; color: var(--txt);
  margin-bottom: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.acc-profile-email {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  margin-bottom: 6px;
}
.acc-profile-sync {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  letter-spacing: 0.04em; text-transform: uppercase;
}

/* Section */
.acc-section { margin-bottom: 24px; }
.acc-section-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--txt3);
  padding: 0 4px 8px; font-weight: 500;
}

/* Grouped rows */
.acc-group {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden;
}
.acc-row {
  display: flex; align-items: center; gap: 12px;
  width: 100%; padding: 14px 16px;
  background: none; border: none; border-bottom: 1px solid var(--border);
  color: var(--txt); font-size: 14px; text-align: left;
  cursor: pointer; transition: background 0.12s;
  font-family: inherit;
}
.acc-row:last-child { border-bottom: none; }
.acc-row:hover { background: rgba(255,255,255,0.025); }
.acc-row:active { background: rgba(255,255,255,0.05); }
.acc-row-static { cursor: default; }
.acc-row-static:hover { background: none; }
.acc-row-label { flex: 1; min-width: 0; }
.acc-row-value {
  color: var(--txt2); font-family: var(--mono); font-size: 12px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 55%;
}
.acc-row-hint {
  color: var(--txt3); font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase;
}
.acc-chevron { color: var(--txt3); flex-shrink: 0; }

/* Storage block */
.acc-storage {
  padding: 14px 16px; border-bottom: 1px solid var(--border);
}
.acc-storage-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.acc-storage-head .acc-row-label { font-size: 14px; color: var(--txt); }
.acc-storage-bar {
  height: 4px; background: var(--border); border-radius: 2px;
  overflow: hidden;
}
.acc-storage-fill {
  height: 100%; background: linear-gradient(90deg, var(--accent), #5a72f5);
  border-radius: 2px; transition: width 0.4s ease;
}

/* Actions */
.acc-actions { margin: 28px 0 12px; }
.acc-btn-logout {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--txt); font-size: 14px; font-weight: 500;
  cursor: pointer; transition: background 0.12s, border-color 0.12s;
  font-family: inherit;
}
.acc-btn-logout:hover { background: rgba(255,255,255,0.03); border-color: var(--border2); }
.acc-btn-logout:active { background: rgba(255,255,255,0.06); }

/* Danger zone */
.acc-danger-section { margin-top: 36px; }
.acc-section-label-danger { color: #8a4040; }
.acc-row-danger { color: var(--danger, #d14848); }
.acc-row-danger .acc-chevron { color: var(--danger, #d14848); opacity: 0.6; }
.acc-row-danger:hover { background: rgba(209,72,72,0.06); }
.acc-danger-hint {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  line-height: 1.5; padding: 10px 4px 0; letter-spacing: 0.02em;
}

@media (max-width: 520px) {
  .acc-content { padding: 16px 12px 40px; }
  .acc-avatar { width: 46px; height: 46px; font-size: 16px; }
  .acc-profile-name { font-size: 15px; }
  .acc-row { padding: 13px 14px; font-size: 13.5px; }
  .acc-storage { padding: 13px 14px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   WERKSTATT-SHARE: Modal-Styling + Read-Only Werkstatt-View
   ════════════════════════════════════════════════════════════════════════════ */

/* Share-Modal */
.share-desc {
  font-size: 13px; color: var(--txt2); line-height: 1.5;
  margin: 0 0 18px;
}
.share-result-box {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px;
}
.share-result-label {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  text-transform: uppercase; letter-spacing: 0.06em;
  margin-bottom: 10px;
}
.share-result-url {
  width: 100%; padding: 10px 12px;
  font-family: var(--mono); font-size: 12px;
  background: var(--surface2); color: var(--txt);
  border: 1px solid var(--border2); border-radius: 6px;
  word-break: break-all;
  margin-bottom: 10px;
}
.share-result-actions {
  display: flex; gap: 8px;
}
.share-result-actions button { flex: 1; }
.share-list-section { margin-top: 24px; }
.share-list-heading {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  text-transform: uppercase; letter-spacing: 0.06em;
  margin: 0 0 10px;
}
.share-list-loading, .share-list-empty {
  padding: 16px; text-align: center; color: var(--txt3);
  font-size: 13px; background: var(--surface); border-radius: 8px;
}
.share-list-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; background: var(--surface);
  border: 1px solid var(--border); border-radius: 8px;
  margin-bottom: 8px;
}
.share-list-info { flex: 1; min-width: 0; }
.share-list-meta {
  font-family: var(--mono); font-size: 10px; color: var(--txt2);
  text-transform: uppercase; letter-spacing: 0.05em;
  margin-bottom: 4px;
}
.share-list-url {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.share-list-actions { display: flex; gap: 6px; flex-shrink: 0; }
.btn-mini {
  padding: 6px 10px; font-size: 11px;
  font-family: var(--mono); text-transform: uppercase; letter-spacing: 0.05em;
  background: var(--surface2); color: var(--txt2);
  border: 1px solid var(--border2); border-radius: 5px;
  cursor: pointer; transition: all 0.15s;
}
.btn-mini:hover { color: var(--txt); border-color: var(--accent); }
.btn-mini-danger { color: var(--red); border-color: rgba(209,72,72,0.3); }
.btn-mini-danger:hover { background: rgba(209,72,72,0.08); border-color: var(--red); }
.btn-mini-renew { color: var(--accent); border-color: rgba(61,90,241,0.3); }
.btn-mini-renew:hover { background: rgba(61,90,241,0.08); border-color: var(--accent); }

/* ── Custom-URL-Slug-Input (Premium-Feature) ───────────────────────── */
.ssh-premium-badge {
  display: inline-block;
  font-family: var(--mono); font-size: 8px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent);
  background: rgba(61,90,241,0.12);
  border: 1px solid rgba(61,90,241,0.3);
  padding: 3px 7px; border-radius: 4px;
  vertical-align: middle;
  margin-left: 8px;
}
.ssh-slug-row {
  display: flex; align-items: stretch;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color 0.15s;
}
.ssh-slug-row:focus-within { border-color: var(--accent); }
.ssh-slug-prefix {
  display: inline-flex; align-items: center;
  padding: 0 12px;
  font-family: var(--mono); font-size: 13px;
  color: var(--txt3); white-space: nowrap;
  border-right: 1px solid var(--border);
  background: rgba(0,0,0,0.15);
  user-select: none;
  letter-spacing: 0.02em;
}
.ssh-slug-input {
  flex: 1; min-width: 0;
  background: transparent; border: none;
  padding: 12px 14px;
  font-family: var(--mono); font-size: 14px;
  color: var(--txt);
  letter-spacing: 0.02em;
}
.ssh-slug-input:focus { outline: none; }
.ssh-slug-hint {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
  margin-top: 8px;
  transition: color 0.15s;
}
.ssh-slug-hint.is-error    { color: var(--red); }
.ssh-slug-hint.is-checking { color: var(--amber); }
.ssh-slug-hint.is-ok       { color: var(--green); }
.ssh-slug-preview {
  font-family: var(--mono); font-size: 12px;
  color: var(--accent);
  margin-top: 6px;
  word-break: break-all;
  letter-spacing: 0.01em;
  font-weight: 500;
}

/* Werkstatt-View: komplett isoliertes Layout — keine App-Chrome */
body.workshop-mode {
  background: var(--bg);
  overflow: auto !important;
}
body.workshop-mode .l-nav,
body.workshop-mode #app-loader,
body.workshop-mode .modal-overlay { display: none !important; }

.workshop-view {
  min-height: 100vh; background: var(--bg); color: var(--txt);
  font-family: var(--cond), system-ui, sans-serif;
}
.workshop-loading, .workshop-error {
  min-height: 100vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 40px 20px; text-align: center; gap: 12px;
}
.workshop-error h1 {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  margin: 0 0 4px; color: var(--txt);
}
.workshop-error p { color: var(--txt2); font-size: 14px; }
.workshop-error-detail {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  margin-top: 12px;
}

/* ── Share-Error-Page (Link nicht gefunden / abgelaufen) ─────────────────
   Editorial-Error mit patinaLog-Akquise-CTA. Wenn jemand einen kaputten
   Link bekommt, ist das ein Touchpoint für Lead-Generation. */
.share-error-page {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: 40px 20px;
  background: var(--bg);
  font-family: var(--cond), system-ui, sans-serif;
}
.share-error-content {
  max-width: 520px; width: 100%;
  text-align: center;
}
.share-error-brand {
  font-family: var(--cond); font-size: 22px; font-weight: 800;
  color: var(--txt); margin-bottom: 32px;
  letter-spacing: 0.01em;
}
.share-error-brand span { color: var(--accent); }
.share-error-title {
  font-family: var(--cond); font-size: clamp(28px, 5vw, 36px); font-weight: 700;
  color: var(--txt); margin: 0 0 12px;
  line-height: 1.15;
}
.share-error-msg {
  font-size: 15px; color: var(--txt2);
  line-height: 1.55; margin: 0;
}
.share-error-detail {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  margin-top: 12px;
  letter-spacing: 0.04em;
}
.share-error-divider {
  height: 1px; background: var(--border);
  margin: 48px auto 36px; max-width: 200px;
}
.share-error-pitch {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 28px 24px;
  position: relative; overflow: hidden;
}
.share-error-pitch::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, transparent 60%);
  pointer-events: none;
}
.share-error-pitch-kicker {
  font-family: var(--mono); font-size: 10px; color: var(--accent);
  text-transform: uppercase; letter-spacing: 0.22em;
  margin-bottom: 10px; position: relative;
}
.share-error-pitch-title {
  font-family: var(--cond); font-size: 22px; font-weight: 700;
  color: var(--txt); line-height: 1.2; margin-bottom: 12px;
  position: relative;
}
.share-error-pitch-text {
  font-size: 14px; color: var(--txt2); line-height: 1.55;
  margin: 0 0 22px; position: relative;
}
.share-error-cta {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #fff; text-decoration: none;
  padding: 12px 24px; border-radius: 10px;
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  transition: transform 0.15s, box-shadow 0.18s;
  box-shadow: 0 8px 24px rgba(61,90,241,0.25);
  position: relative;
}
.share-error-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 32px rgba(61,90,241,0.4);
}
.share-error-cta:active { transform: translateY(0); }

.workshop-header {
  background: var(--surface); border-bottom: 1px solid var(--border);
  padding: 14px 0; position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(10px);
}
.workshop-header-inner {
  max-width: 760px; margin: 0 auto; padding: 0 20px;
  display: flex; align-items: center; justify-content: space-between;
}
.workshop-brand {
  font-family: var(--cond); font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--txt);
}
.workshop-expires {
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--txt2);
}

.workshop-content {
  max-width: 760px; margin: 0 auto; padding: 24px 20px 80px;
}
.workshop-hero {
  display: flex; gap: 18px; align-items: center;
  margin-bottom: 32px; padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}
.workshop-hero-img,
.workshop-hero-placeholder {
  width: 140px; height: 90px; flex-shrink: 0;
  border-radius: 10px; background: var(--surface2);
  object-fit: cover; object-position: center;
}
.workshop-hero-text { flex: 1; min-width: 0; }
.workshop-hero-text h1 {
  font-family: var(--cond); font-size: 26px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.02em;
  margin: 0 0 4px; color: var(--txt); line-height: 1.1;
}
.workshop-hero-sub {
  font-family: var(--mono); font-size: 12px;
  color: var(--txt2); letter-spacing: 0.04em;
}

.workshop-section {
  margin-bottom: 36px;
}
.workshop-section h2 {
  font-family: var(--cond); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--txt2); margin: 0 0 14px;
  padding-bottom: 8px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.workshop-section-count {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  color: var(--txt3); letter-spacing: 0.04em;
}
.workshop-grid {
  display: grid; grid-template-columns: 1fr; gap: 0;
}
.workshop-row {
  display: flex; padding: 10px 0;
  border-bottom: 1px solid var(--border);
  gap: 16px;
}
.workshop-row:last-child { border-bottom: none; }
.workshop-row-label {
  flex: 0 0 40%; font-family: var(--mono); font-size: 12px;
  color: var(--txt2); letter-spacing: 0.04em;
}
.workshop-row-val {
  flex: 1; font-size: 14px; color: var(--txt); text-align: right;
}

.workshop-note {
  background: rgba(217,164,72,0.06);
  border: 1px solid rgba(217,164,72,0.25);
  border-left: 3px solid var(--amber);
  border-radius: 8px;
  padding: 14px 16px;
  margin-bottom: 32px;
}
.workshop-note-label {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--amber); margin-bottom: 6px;
}
.workshop-note-text {
  font-size: 14px; color: var(--txt); line-height: 1.5;
}
.form-label-meta {
  font-weight: 400; color: var(--txt3); font-size: 11px;
  letter-spacing: 0.04em;
}

.workshop-chips {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.workshop-chip {
  padding: 5px 12px; border-radius: 14px;
  background: var(--surface); border: 1px solid var(--border);
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  letter-spacing: 0.04em;
}

.workshop-list {
  display: flex; flex-direction: column; gap: 10px;
}
.workshop-item {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px;
}
.workshop-item[data-prio="high"]   { border-left: 3px solid var(--red); }
.workshop-item[data-prio="medium"] { border-left: 3px solid var(--amber); }
.workshop-item[data-prio="none"]   { border-left: 3px solid transparent; }
.workshop-item-header {
  display: flex; gap: 10px; align-items: baseline;
  justify-content: space-between; margin-bottom: 6px;
}
.workshop-item-title {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  color: var(--txt); flex: 1; min-width: 0;
}
.workshop-item-date {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  letter-spacing: 0.04em; flex-shrink: 0;
}
.workshop-item-prio {
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  padding: 3px 8px; border-radius: 10px;
  background: rgba(255,255,255,0.05); color: var(--txt2);
  flex-shrink: 0;
}
.workshop-item-prio.prio-high { background: rgba(209,72,72,0.12); color: var(--red); }
.workshop-item-prio.prio-medium { background: rgba(217,164,72,0.12); color: var(--amber); }
.workshop-item-meta {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  margin-bottom: 6px; letter-spacing: 0.04em;
}
.workshop-item-notes {
  font-size: 13px; color: var(--txt2); line-height: 1.5;
  margin-top: 8px;
}
.workshop-images {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px;
}
.workshop-images img {
  width: 80px; height: 80px; object-fit: cover; object-position: center;
  border-radius: 6px; background: var(--surface2);
  cursor: zoom-in; transition: transform 0.15s;
}
.workshop-images img:hover { transform: scale(1.04); }
.workshop-hero-img { cursor: zoom-in; }

/* Lightbox: Bild-Vergrößerung im Werkstatt-View */
.workshop-lightbox {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0,0,0,0.94);
  display: none; align-items: center; justify-content: center;
  padding: 24px;
  animation: workshopLbFade 0.18s ease-out;
}
.workshop-lightbox.open { display: flex; }
@keyframes workshopLbFade {
  from { opacity: 0; }
  to { opacity: 1; }
}
.workshop-lightbox-img {
  max-width: 100%; max-height: 100%; object-fit: contain;
  border-radius: 6px; cursor: zoom-out;
  user-select: none;
}
.workshop-lightbox-close {
  position: absolute; top: 16px; right: 16px;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.12); color: #fff; border: none;
  font-size: 18px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
  z-index: 2;
}
.workshop-lightbox-close:hover { background: rgba(255,255,255,0.2); }
.workshop-lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,0.12); color: #fff; border: none;
  font-size: 32px; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s, opacity 0.15s;
  z-index: 2; padding: 0; padding-bottom: 4px;
  font-family: -apple-system, system-ui, sans-serif;
}
.workshop-lightbox-prev { left: 16px; }
.workshop-lightbox-next { right: 16px; }
.workshop-lightbox-nav:hover { background: rgba(255,255,255,0.2); }
.workshop-lightbox-counter {
  position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%);
  background: rgba(0,0,0,0.5); color: #fff;
  padding: 6px 14px; border-radius: 14px;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.06em;
  z-index: 2;
}
@media (max-width: 520px) {
  .workshop-lightbox-nav {
    /* Auf Mobile: kleinere Buttons, weil primär gewischt wird */
    width: 40px; height: 40px; font-size: 26px;
    background: rgba(255,255,255,0.08);
  }
  .workshop-lightbox-prev { left: 8px; }
  .workshop-lightbox-next { right: 8px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   SHOWROOM-VIEW: Premium-Präsentation, Patina-Landing-Stil
   ════════════════════════════════════════════════════════════════════════════ */

body.workshop-mode .workshop-view.sr-mode {
  background: var(--bg);
}
.workshop-view.sr-mode { font-family: 'Barlow', var(--cond), system-ui, sans-serif; }

/* ─── Scroll-Progress (minimal, fixed-top) ────────────────────────── */
.sr-progress {
  position: fixed; top: 0; left: 0; right: 0;
  height: 1px; z-index: 50;
  background: rgba(255,255,255,0.85);
  transform-origin: left;
  transform: scaleX(0);
  transition: transform 0.05s linear;
}

/* ─── HERO — Confident, photo-led, restraint ──────────────────────── */
.sr-hero {
  position: relative; width: 100%;
  overflow: hidden; background: #060606;
}
.sr-hero-cinema {
  height: 100vh; min-height: 720px;
}
.sr-hero-img-wrap {
  position: absolute; inset: 0;
  overflow: hidden;
}
.sr-hero-img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  transform: scale(1.04);
  filter: contrast(1.04) saturate(0.92) brightness(0.92);
  cursor: zoom-in;
}
.sr-hero-grad-bottom {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.78) 100%);
  pointer-events: none;
}
.sr-hero-cinema .sr-hero-content {
  position: absolute; inset: 0;
  padding: 0; margin: 0; max-width: none;
  z-index: 5;
}
.sr-hero-corner-l, .sr-hero-corner-r {
  position: absolute; top: 32px;
  font-family: var(--mono); font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.36em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.sr-hero-corner-l { left: 32px; }
.sr-hero-corner-r { right: 32px; font-variant-numeric: tabular-nums; }

.sr-hero-bottom {
  position: absolute;
  bottom: 80px; left: 32px; right: 32px;
  max-width: 1200px;
  margin: 0 auto;
}
.sr-hero-kicker {
  font-family: var(--mono); font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.42em; text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  margin-bottom: 28px;
  overflow: hidden;
}
.sr-hero-cinema .sr-hero-title {
  font-family: var(--cond); font-weight: 900;
  font-size: clamp(80px, 18vw, 240px);
  line-height: 0.82;
  letter-spacing: -0.045em;
  color: #fff;
  margin: 0;
  text-transform: none;
  display: block;
}
.sr-hero-title .sr-tc {
  display: inline-block;
  white-space: pre;
}
.sr-hero-cinema .sr-hero-engine {
  font-family: var(--mono); font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.30em; text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-top: 32px;
  display: block;
}
.sr-scroll-hint {
  position: absolute;
  bottom: 24px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  pointer-events: none;
}
.sr-scroll-line {
  display: block; width: 1px; height: 32px;
  background: rgba(255,255,255,0.4);
}
.sr-scroll-text { display: none; }

/* ─── POSTER-PIN — clean black, type as hero ──────────────────────── */
.sr-poster-pin {
  width: 100%; min-height: 100vh; height: 100vh;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  overflow: hidden;
  background: #060606;
}
.sr-poster-content {
  text-align: center;
  padding: 0 32px;
  max-width: 1200px;
}
.sr-poster-kicker {
  font-family: var(--mono); font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.42em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: 40px;
}
.sr-poster-num {
  font-family: var(--cond); font-weight: 900;
  font-size: clamp(160px, 28vw, 360px);
  line-height: 0.86; letter-spacing: -0.055em;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.sr-poster-rule {
  width: 48px; height: 1px;
  background: rgba(255,255,255,0.6);
  margin: 40px auto;
  transform-origin: center;
}
.sr-poster-sub {
  font-family: var(--mono); font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.40em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.sr-hero-img-wrap {
  position: absolute; inset: 0;
  overflow: hidden;
}
.sr-hero-img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  transform: scale(1.05); /* GSAP übersteuert das auf scrub */
  cursor: zoom-in;
}
.sr-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    180deg,
    rgba(10,10,10,0.55) 0%,
    rgba(10,10,10,0.30) 30%,
    rgba(10,10,10,0.40) 60%,
    rgba(10,10,10,0.85) 100%
  );
  pointer-events: none;
}
.sr-hero-content {
  position: relative; z-index: 2;
  padding: 0 48px 80px; max-width: 1100px; width: 100%; margin: 0 auto;
}
.sr-hero-tag {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: rgba(255,255,255,0.7);
  border: 1px solid rgba(255,255,255,0.2);
  padding: 6px 12px; border-radius: var(--r);
  display: inline-block; margin-bottom: 24px;
}
.sr-hero-title {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(56px, 11vw, 160px);
  line-height: 0.92;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0 0 18px;
  text-transform: uppercase;
  text-shadow: 0 4px 30px rgba(0,0,0,0.5);
}
.sr-hero-engine {
  font-family: var(--mono); font-size: 14px; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgba(255,255,255,0.85);
}
.sr-scroll-hint {
  position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: rgba(255,255,255,0.6);
  animation: sr-scroll-bob 2s ease-in-out infinite;
}
@keyframes sr-scroll-bob {
  0%, 100% { transform: translate(-50%, 0); opacity: 0.6; }
  50%      { transform: translate(-50%, 6px); opacity: 1; }
}

/* Sektion-Layout: zentriert, max-width, GROßZÜGIGES Spacing für Premium-Atem */
.sr-section {
  max-width: 1100px; margin: 0 auto;
  padding: 180px 48px;
}
.sr-section-label {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.36em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: 32px;
}
.sr-section-title {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(48px, 7vw, 88px);
  line-height: 0.95; letter-spacing: -0.025em;
  margin: 0 0 80px;
  color: var(--txt);
}
@media (max-width: 600px) {
  .sr-section { padding: 120px 28px; }
  .sr-section-title { margin-bottom: 60px; }
}

/* Intro-Quote: Owner-Notiz */
.sr-intro {
  padding: 80px 48px;
}
/* Step 7: Tagline (oberhalb des Quote-Blocks in Story-Section) */
.sr-tagline {
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  color: var(--accent); letter-spacing: 0.18em; text-transform: uppercase;
  text-align: center; margin-bottom: 24px;
  max-width: 760px; margin-left: auto; margin-right: auto;
}

/* Step 7: Service-Liste (kuratierte Wartungs-Einträge) */
.sr-service-list {
  margin-top: 32px;
  display: flex; flex-direction: column;
  max-width: 760px; margin-left: auto; margin-right: auto;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.sr-service-row {
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.sr-service-row:last-child { border-bottom: none; }
.sr-service-row-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px; margin-bottom: 4px;
}
.sr-service-row-title {
  font-family: var(--cond); font-size: 16px; font-weight: 700;
  color: var(--txt);
}
.sr-service-row-date {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  letter-spacing: 0.1em; flex-shrink: 0;
}
.sr-service-row-meta {
  font-family: var(--mono); font-size: 10px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.14em;
}

/* Step 7: Contact-Section (mit optional Sale-Mode) */
.sr-contact-section { padding-top: 80px; padding-bottom: 80px; text-align: center; }
.sr-contact-price {
  display: inline-flex; align-items: baseline; gap: 8px;
  margin-bottom: 14px;
}
.sr-contact-price-num {
  font-family: var(--cond); font-size: clamp(48px, 8vw, 80px);
  font-weight: 800; line-height: 1; color: var(--txt);
  letter-spacing: -0.02em; font-variant-numeric: tabular-nums;
}
.sr-contact-price-cur {
  font-family: var(--cond); font-size: 32px; font-weight: 700;
  color: var(--txt2);
}
.sr-contact-price-status {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent); margin-left: 12px;
  border: 1px solid var(--accent);
  padding: 6px 10px; border-radius: 6px;
  align-self: center;
}
.sr-contact-reason {
  font-size: 14px; line-height: 1.6; color: var(--txt2);
  max-width: 540px; margin: 0 auto 24px;
}
.sr-contact-info {
  display: flex; flex-direction: column; gap: 8px;
  align-items: center; margin-bottom: 28px;
}
.sr-contact-link {
  font-family: var(--mono); font-size: 14px; color: var(--txt);
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,0.2);
  transition: color 0.18s, border-color 0.18s;
}
.sr-contact-link:hover { color: var(--accent); border-bottom-color: var(--accent); }
.sr-contact-location {
  font-family: var(--mono); font-size: 11px; color: var(--txt3);
  text-transform: uppercase; letter-spacing: 0.16em; margin-top: 4px;
}
.sr-contact-cta {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--accent); color: #fff; text-decoration: none;
  padding: 14px 28px; border-radius: 10px;
  font-family: var(--mono); font-size: 12px; font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase;
  transition: transform 0.15s, box-shadow 0.18s;
  box-shadow: 0 8px 24px rgba(61,90,241,0.25);
}
.sr-contact-cta:hover { transform: translateY(-1px); box-shadow: 0 12px 32px rgba(61,90,241,0.4); }
.sr-contact-cta:active { transform: translateY(0); }

.sr-quote {
  position: relative;
  max-width: 760px; margin: 0 auto;
  padding: 24px 0 24px 60px;
}
.sr-quote-mark {
  position: absolute; left: 0; top: -10px;
  font-family: var(--cond); font-size: 110px; font-weight: 800;
  color: var(--accent); line-height: 1;
  opacity: 0.7;
}
.sr-quote-text {
  font-family: var(--cond); font-size: clamp(22px, 3vw, 30px);
  line-height: 1.4; color: var(--txt);
  font-style: italic; font-weight: 500;
  letter-spacing: -0.005em;
}

/* Stats: count-up Karten */
.sr-stats-section { padding-top: 60px; padding-bottom: 60px; }
.sr-stats-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 20px;
}
.sr-stat {
  border-left: 2px solid var(--accent);
  padding: 8px 0 8px 18px;
}
.sr-stat-num {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--txt);
  margin-bottom: 6px;
  font-variant-numeric: tabular-nums;
}
.sr-stat-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--txt2);
}

/* Specs: 3-Spalten-Grid */
.sr-specs {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 28px 36px;
}
.sr-spec {
  border-top: 1px solid var(--border);
  padding-top: 14px;
}
.sr-spec-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--txt2);
  margin-bottom: 6px;
}
.sr-spec-val {
  font-family: var(--cond); font-size: 22px; font-weight: 600;
  color: var(--txt); letter-spacing: -0.005em;
}

/* Modifikationen: alternierende Layouts */
.sr-mods-list {
  max-width: 1100px; margin: 0 auto;
  padding: 0 48px;
}
.sr-mod {
  display: grid; grid-template-columns: 1.2fr 1fr;
  gap: 60px; align-items: center;
  padding: 80px 0;
  border-top: 1px solid var(--border);
}
.sr-mod-right {
  grid-template-columns: 1fr 1.2fr;
}
.sr-mod-right .sr-mod-img-wrap { order: 2; }
.sr-mod-right .sr-mod-text     { order: 1; }
.sr-mod-img-wrap {
  position: relative; aspect-ratio: 4 / 3;
  border-radius: 14px; overflow: hidden;
  background: var(--surface2);
  cursor: zoom-in;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.sr-mod-img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  transition: transform 0.6s cubic-bezier(0.22, 0.9, 0.24, 1);
}
.sr-mod-img-wrap:hover .sr-mod-img { transform: scale(1.04); }
.sr-mod-img-empty {
  background: linear-gradient(135deg, var(--surface) 0%, var(--surface2) 100%);
  cursor: default;
}
.sr-mod-img-count {
  position: absolute; bottom: 12px; right: 12px;
  background: rgba(0,0,0,0.7); color: #fff;
  padding: 6px 12px; border-radius: 14px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.05em;
}
.sr-mod-text { display: flex; flex-direction: column; gap: 14px; }
.sr-mod-date {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--accent);
}
.sr-mod-title {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(28px, 3.5vw, 44px); line-height: 1.05;
  letter-spacing: -0.01em; margin: 0;
  color: var(--txt);
}
.sr-mod-notes {
  font-size: 15px; line-height: 1.65; color: var(--txt2);
  margin: 0; max-width: 520px;
}

/* Build-Story Timeline */
.sr-story-section {
  background: rgba(255,255,255,0.015);
}
.sr-timeline {
  position: relative; max-width: 720px; margin: 0 auto;
  padding-left: 40px;
}
.sr-timeline::before {
  content: ''; position: absolute;
  left: 11px; top: 6px; bottom: 6px;
  width: 1px; background: linear-gradient(
    180deg,
    transparent 0%,
    var(--border) 8%,
    var(--border) 92%,
    transparent 100%
  );
}
.sr-timeline-item {
  position: relative; padding-bottom: 50px;
}
.sr-timeline-item:last-child { padding-bottom: 0; }
.sr-timeline-marker {
  position: absolute; left: -34px; top: 8px;
  width: 13px; height: 13px; border-radius: 50%;
  background: var(--bg);
  border: 2px solid var(--accent);
  box-shadow: 0 0 0 4px rgba(61,90,241,0.10);
}
.sr-timeline-content { padding-left: 4px; }
.sr-timeline-date {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: 6px;
}
.sr-timeline-title {
  font-family: var(--cond); font-weight: 700;
  font-size: 22px; line-height: 1.2;
  letter-spacing: -0.005em; margin: 0 0 8px;
  color: var(--txt);
}
.sr-timeline-notes {
  font-size: 14px; line-height: 1.6; color: var(--txt2);
  margin: 0 0 12px;
}
.sr-timeline-images {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.sr-timeline-images img {
  width: 100px; height: 100px; object-fit: cover; object-position: center;
  border-radius: 8px; cursor: zoom-in;
  transition: transform 0.2s;
}
.sr-timeline-images img:hover { transform: scale(1.04); }

/* Service-Excellence: einfaches Statement */
.sr-service-section {
  text-align: center;
  padding: 100px 48px;
}
.sr-service-statement {
  font-family: var(--cond); font-weight: 500;
  font-size: clamp(22px, 3vw, 32px);
  line-height: 1.5; letter-spacing: -0.005em;
  color: var(--txt2); max-width: 720px; margin: 0 auto;
}
.sr-service-statement strong {
  color: var(--txt); font-weight: 800;
}

/* Galerie */
.sr-gallery-section { padding-bottom: 120px; }
.sr-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 6px;
}
.sr-gallery-item {
  aspect-ratio: 1;
  overflow: hidden; border-radius: 4px;
  background: var(--surface2); cursor: zoom-in;
}
.sr-gallery-item img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  transition: transform 0.4s cubic-bezier(0.22, 0.9, 0.24, 1);
}
.sr-gallery-item:hover img { transform: scale(1.06); }

/* Footer */
.sr-footer {
  padding: 80px 48px 60px; text-align: center;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.4);
}
.sr-footer-brand {
  font-family: var(--cond); font-weight: 800;
  font-size: 24px; letter-spacing: -0.01em;
  margin-bottom: 8px;
}
.sr-footer-brand span { color: var(--accent); }
.sr-footer-text {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--txt3);
  margin-bottom: 22px;
}
.sr-footer-cta {
  display: inline-block;
  font-family: var(--cond); font-size: 14px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 12px 28px; border-radius: 24px;
  background: var(--accent); color: #fff; text-decoration: none;
  transition: background 0.2s, transform 0.2s;
}
.sr-footer-cta:hover {
  background: #5470ff; transform: translateY(-1px);
}
.sr-footer-meta {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em;
  color: var(--txt3); margin-top: 22px;
}

/* Reveal-Fallback ohne GSAP */
.sr-mode [data-sr-reveal] { opacity: 1; }
.sr-mode.fallback-reveal [data-sr-reveal]:not(.sr-revealed) {
  opacity: 0; transform: translateY(40px);
  transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}
.sr-mode.fallback-reveal [data-sr-reveal].sr-revealed {
  opacity: 1; transform: translateY(0);
}

/* Reduced motion: alle Animationen aus */
@media (prefers-reduced-motion: reduce) {
  .sr-hero-img { transform: none !important; }
  .sr-scroll-hint { animation: none; }
  .sr-mode [data-sr-reveal] { opacity: 1 !important; transform: none !important; }
}

/* Responsive: Mobile-Anpassungen */
@media (max-width: 760px) {
  .sr-hero-content { padding: 0 24px 60px; }
  .sr-section { padding: 70px 24px; }
  .sr-mods-list { padding: 0 24px; }
  .sr-mod {
    grid-template-columns: 1fr; gap: 26px; padding: 50px 0;
  }
  .sr-mod-right .sr-mod-img-wrap,
  .sr-mod-right .sr-mod-text { order: initial; }
  .sr-quote { padding-left: 36px; }
  .sr-quote-mark { font-size: 80px; }
  .sr-service-section { padding: 70px 24px; }
  .sr-footer { padding: 60px 24px; }
  .sr-gallery { grid-template-columns: repeat(2, 1fr); }
}

/* Share-Bottom-Sheet (Werkstatt/Showroom/PDF) */
/* Action-Sheet-Variante: Title + Sub + monochromes Icon, Apple-Stil mit Patina-Tint.
   Keine Boxes / Cards um die Icons — pures Glyph mit Akzent-Farbe. */
.bs-share-option {
  display: flex; gap: 18px; align-items: center;
  padding: 16px 24px;
}
.bs-share-icon {
  width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  background: transparent; border: none;
  color: var(--txt2);
  transition: transform 0.18s ease;
}
.bs-share-icon svg { width: 22px; height: 22px; display: block; }
@media (hover: hover) {
  .bs-share-option:hover .bs-share-icon { transform: scale(1.08); }
}
/* Alle Icons monochrom in einer neutralen Farbe — Patina/Apple-Stil ohne
   semantische Farb-Codierung. Nur "Danger" wirklich rot, weil semantisch
   relevant (Warnung bei Lösch-Aktion). */
.bs-share-icon-workshop,
.bs-share-icon-showroom,
.bs-share-icon-sale,
.bs-share-icon-pdf,
.bs-share-icon-cover,
.bs-share-icon-download   { color: var(--txt2); }
.bs-share-icon-danger     { color: var(--red); }
.bs-share-icon-disabled   { color: var(--txt3); opacity: 0.45; }
.bs-option-text { flex: 1; min-width: 0; }
.bs-option-title {
  font-family: var(--cond); font-weight: 700; font-size: 16px;
  color: var(--txt); margin-bottom: 3px; letter-spacing: -0.005em;
  line-height: 1.25;
}
.bs-option-sub {
  font-size: 12px; color: var(--txt2); line-height: 1.45;
  letter-spacing: 0.005em;
}
.bs-option-title-danger { color: var(--red); }
.bs-badge-beta {
  display: inline-block; vertical-align: middle;
  margin-left: 8px; padding: 2px 7px;
  font-family: var(--mono); font-size: 9px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent); border: 1px solid var(--accent);
  background: rgba(61, 90, 241, 0.08);
  line-height: 1.2;
}
.bs-option-disabled {
  cursor: default !important;
  opacity: 0.5;
  pointer-events: none;
}
.bs-option-disabled .bs-option-title { color: var(--txt2); }

/* Share-Type Badges in der Liste */
.share-badge {
  display: inline-block; padding: 2px 7px; border-radius: 4px;
  font-family: var(--mono); font-size: 9px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  margin-right: 8px;
}
.share-badge-workshop { background: rgba(61,90,241,0.15); color: var(--accent); }
.share-badge-showroom { background: rgba(217,164,72,0.15); color: var(--amber); }
.share-badge-sale     { background: rgba(22,163,74,0.18);  color: var(--green); }

/* Share-Toggle */
.share-toggle-row {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px; margin: 0 0 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; cursor: pointer;
  font-size: 13px; color: var(--txt);
}
.share-toggle-row input[type="checkbox"] {
  margin-top: 2px; flex-shrink: 0;
}

.workshop-footer {
  margin-top: 60px; padding-top: 24px; padding-bottom: 16px;
  border-top: 1px solid var(--border);
  text-align: center; font-family: var(--mono); font-size: 11px;
  color: var(--txt3); letter-spacing: 0.04em;
}
.workshop-footer a { color: var(--txt2); text-decoration: none; }
.workshop-footer a:hover { color: var(--accent); }

@media (max-width: 520px) {
  .workshop-hero { flex-direction: column; align-items: flex-start; gap: 14px; }
  .workshop-hero-img, .workshop-hero-placeholder { width: 100%; height: 180px; }
  .workshop-hero-text h1 { font-size: 22px; }
  .workshop-row { flex-direction: column; gap: 4px; }
  .workshop-row-label { flex: 0 0 auto; }
  .workshop-row-val { text-align: left; }
}


/* ========================================================================
   CAROUSEL EXPORT — Storyteller v5
   Full-screen overlay shown via openCarouselDialog().
   Native canvas authored at 5400×1350; visible window is one slice (1080×1350)
   scaled to fit screen; user swipes between 5 slices.
   ======================================================================== */

.carousel-export {
  position: fixed; inset: 0; z-index: 11800;
  background: #000;
  display: flex; flex-direction: column;
  -webkit-font-smoothing: antialiased;
  font-family: var(--body);
  color: #ececec;
}
body.carousel-export-open { overflow: hidden; }

/* Top bar with close + title */
.cex-bar {
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; gap: 12px;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  position: relative; z-index: 5;
}
.cex-bar-title {
  font-family: var(--cond); font-weight: 600; font-size: 18px; letter-spacing: 0;
  color: #ececec; flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cex-bar-sub {
  display: block; font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(255,255,255,0.55); margin-top: 2px;
}
.cex-bar-btn {
  width: 36px; height: 36px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid rgba(255,255,255,0.18);
  color: #ececec; cursor: pointer; transition: all .15s;
}
.cex-bar-btn:hover { background: rgba(255,255,255,0.08); }
.cex-bar-btn svg { width: 18px; height: 18px; }

/* Slice viewport */
.cex-stage {
  flex: 1; min-height: 0;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; position: relative;
  padding: 16px;
}
.cex-viewport {
  position: relative;
  width: min(82vw, 520px);
  aspect-ratio: 1080 / 1350;
  max-height: calc(100vh - 200px);
  background: #0a0a0a;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.7);
}
/* Container that holds the wide canvas, translates per slice */
.cex-canvas {
  position: absolute; left: 0; top: 0;
  width: 5400px; height: 1350px;
  transform-origin: top left;
  transition: transform .35s cubic-bezier(0.5, 0, 0.2, 1);
  /* dynamic transform set via JS — combines scale + translateX */
}
.cex-canvas.cex-no-anim { transition: none; }

/* Touch swipe area */
.cex-touch {
  position: absolute; inset: 0; z-index: 4;
  touch-action: pan-y; cursor: grab;
}
.cex-touch:active { cursor: grabbing; }

/* Pagination dots */
.cex-dots {
  flex-shrink: 0;
  display: flex; justify-content: center; align-items: center; gap: 10px;
  padding: 14px 18px 22px;
  background: #000;
}
.cex-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,0.22);
  cursor: pointer; transition: all .2s;
  border: 0; padding: 0;
}
.cex-dot.is-active { background: #ececec; transform: scale(1.3); }
.cex-dot:hover { background: rgba(255,255,255,0.45); }

/* Hint text below dots */
.cex-hint {
  text-align: center;
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(255,255,255,0.4);
  padding: 0 18px 14px;
  background: #000;
}

/* Bottom action bar (export buttons) */
.cex-actions {
  flex-shrink: 0;
  display: flex; gap: 10px; padding: 14px 18px 22px;
  background: #000; border-top: 1px solid rgba(255,255,255,0.06);
}
.cex-btn {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--cond); font-weight: 600; font-size: 16px; letter-spacing: 0;
  text-transform: uppercase;
  background: rgba(255,255,255,0.06); color: #ececec;
  border: 1px solid rgba(255,255,255,0.12);
  padding: 14px 16px; cursor: pointer; transition: all .15s;
}
.cex-btn:hover { background: rgba(255,255,255,0.12); }
.cex-btn-primary {
  background: var(--accent); color: #fff; border-color: var(--accent);
}
.cex-btn-primary:hover { background: #2d4ad9; }
.cex-btn-secondary {
  background: rgba(255,255,255,0.06); color: #ececec;
  border: 1px solid rgba(255,255,255,0.16);
}
.cex-btn-secondary:hover { background: rgba(255,255,255,0.12); }
/* Instagram-Brand-Button — offizieller Insta-Gradient (Sunset). Wird primary
   wenn beide Buttons sichtbar — Share-First UX auf Mobile. */
.cex-btn-insta {
  background: linear-gradient(135deg, #feda75 0%, #fa7e1e 25%, #d62976 50%, #962fbf 75%, #4f5bd5 100%);
  color: #fff; border: none;
  font-weight: 700;
  box-shadow: 0 4px 18px rgba(214, 41, 118, 0.25);
}
.cex-btn-insta:hover {
  filter: brightness(1.08);
  box-shadow: 0 6px 22px rgba(214, 41, 118, 0.35);
}
.cex-btn-insta:active { filter: brightness(0.95); }
.cex-btn[disabled] { opacity: .45; cursor: not-allowed; }
.cex-btn svg { width: 16px; height: 16px; }
/* Wenn Insta-Button sichtbar, gibt's eine klare Hierarchie:
   Insta (primary visual) | Save (sekundär). Save bleibt schmaler. */
.cex-actions .cex-btn-insta { flex: 1.4; }

/* ============================================================
   CANVAS CONTENT — Storyteller v5 (native 5400×1350)
   ============================================================ */
.cex-canvas {
  background: #0a0a0a; color: #ececec;
  font-family: var(--body);
  --cex-bg: #0a0a0a;
  --cex-txt: #ececec;
  --cex-txt2: #7a7a7a;
  --cex-txt3: #3f3f3f;
  --cex-hairline: rgba(255,255,255,0.14);
  --cex-accent: #3d5af1;
}
.cex-canvas * { box-sizing: border-box; margin: 0; padding: 0; }

.cex-canvas .cex-top-rule {
  position: absolute; left: 80px; right: 80px; top: 120px; height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--cex-hairline) 4%, var(--cex-hairline) 96%, transparent 100%);
  z-index: 5;
}
.cex-canvas .cex-corner-marks {
  position: absolute; left: 0; right: 0; bottom: 60px; height: 18px; z-index: 5;
}
.cex-canvas .cex-corner-marks::before,
.cex-canvas .cex-corner-marks::after {
  content: ''; position: absolute; top: 8px; height: 1px; background: var(--cex-hairline);
}
.cex-canvas .cex-corner-marks::before { left: 80px; width: 380px; }
.cex-canvas .cex-corner-marks::after { right: 80px; width: 380px; }
.cex-canvas .cex-cm-label {
  position: absolute; left: 50%; transform: translateX(-50%); top: -2px;
  font-family: var(--mono); font-size: 14px; letter-spacing: .36em; text-transform: uppercase;
  color: var(--cex-txt3); white-space: nowrap;
}
.cex-canvas .cex-folio {
  position: absolute; top: 80px; right: 80px;
  font-family: var(--mono); font-size: 14px; letter-spacing: .36em; text-transform: uppercase;
  color: var(--cex-txt3); z-index: 10;
}
.cex-canvas .cex-folio b { color: var(--cex-txt2); font-weight: 400; }
.cex-canvas .cex-slice-line {
  position: absolute; top: 0; bottom: 0; width: 1px;
  background: rgba(255,255,255,0.04); pointer-events: none; z-index: 0;
}

/* Slice 1 — Cover */
.cex-canvas .cex-hero-photo {
  position: absolute; left: 0; top: 0; width: 1920px; height: 1350px;
  overflow: hidden; z-index: 1; background: #1a1a1a;
}
.cex-canvas .cex-hero-photo img {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  min-width: 100%; min-height: 100%; object-fit: cover;
  filter: contrast(1.04) saturate(0.94);
}
.cex-canvas .cex-hero-photo::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.4) 0, transparent 22%, transparent 55%, rgba(0,0,0,0.85) 100%),
    linear-gradient(90deg, transparent 0%, transparent 65%, rgba(10,10,10,0.55) 82%, rgba(10,10,10,0.96) 100%);
}
.cex-canvas .cex-b-cover {
  position: absolute; left: 0; top: 0; width: 1080px; height: 1350px; z-index: 8;
}
.cex-canvas .cex-cov-top {
  position: absolute; left: 80px; top: 80px;
  font-family: var(--mono); font-size: 14px; letter-spacing: .36em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.cex-canvas .cex-cov-folio {
  position: absolute; top: 80px; right: 80px;
  font-family: var(--mono); font-size: 14px; letter-spacing: .36em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.cex-canvas .cex-cov-folio b { color: rgba(255,255,255,0.85); font-weight: 400; }
.cex-canvas .cex-cov-bottom { position: absolute; left: 80px; right: 80px; bottom: 130px; }
.cex-canvas .cex-cov-marque {
  font-family: var(--mono); font-size: 18px; letter-spacing: .4em; text-transform: uppercase;
  color: rgba(255,255,255,0.7); margin-bottom: 18px;
}
.cex-canvas .cex-cov-year-row {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 24px;
  border-top: 1px solid rgba(255,255,255,0.25); padding-top: 24px; margin-top: 24px;
}
.cex-canvas .cex-cov-year {
  font-family: var(--cond); font-weight: 300; font-size: 42px; line-height: 1;
  color: rgba(255,255,255,0.85); text-transform: uppercase; letter-spacing: .06em;
}
.cex-canvas .cex-cov-plate {
  font-family: var(--mono); font-size: 16px; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.cex-canvas .cex-model-wordmark {
  position: absolute; left: 80px; top: 520px;
  font-family: var(--cond); font-weight: 800; font-size: 480px; line-height: 0.84;
  letter-spacing: -.028em; text-transform: uppercase; color: #fff;
  white-space: nowrap; z-index: 9;
}
.cex-canvas .cex-wm-thin { font-weight: 200; color: rgba(255,255,255,0.85); }

/* Slice 2 — Specs */
.cex-canvas .cex-b-specs {
  position: absolute; left: 1080px; top: 0; width: 1080px; height: 1350px; z-index: 8;
}
.cex-canvas .cex-sp-photo {
  position: absolute; right: 80px; top: 230px; width: 340px; height: 340px;
  overflow: hidden; z-index: 1; border: 1px solid var(--cex-hairline); background: #1a1a1a;
}
.cex-canvas .cex-sp-photo img {
  width: 100%; height: 100%; object-fit: cover; object-position: 30% 50%;
  transform: scale(1.25); filter: contrast(1.05) saturate(0.85) brightness(0.92);
}
.cex-canvas .cex-sp-photo-cap {
  position: absolute; right: 80px; top: 585px;
  font-family: var(--mono); font-size: 13px; letter-spacing: .3em; text-transform: uppercase;
  color: var(--cex-txt3); width: 340px; text-align: right;
}
.cex-canvas .cex-sp-pad { position: absolute; left: 80px; right: 80px; top: 230px; bottom: 130px; z-index: 5; }
.cex-canvas .cex-sp-kicker {
  font-family: var(--mono); font-size: 16px; letter-spacing: .36em; text-transform: uppercase;
  color: var(--cex-txt2); margin-bottom: 36px;
}
.cex-canvas .cex-sp-hero {
  display: flex; flex-direction: column; gap: 8px;
  border-top: 1px solid var(--cex-hairline); padding-top: 36px; margin-bottom: 48px; max-width: 560px;
}
.cex-canvas .cex-sp-hero-l {
  font-family: var(--mono); font-size: 15px; letter-spacing: .32em; text-transform: uppercase;
  color: var(--cex-txt2);
}
.cex-canvas .cex-sp-hero-v {
  font-family: var(--cond); font-weight: 200; font-size: 240px; line-height: 0.86;
  letter-spacing: -.025em; color: var(--cex-txt);
}
.cex-canvas .cex-sp-hero-sub {
  font-family: var(--cond); font-weight: 300; font-size: 38px; line-height: 1;
  color: var(--cex-txt2); text-transform: uppercase; letter-spacing: .02em;
}
.cex-canvas .cex-sp-list {
  position: absolute; left: 80px; right: 80px; bottom: 130px;
  display: grid; grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--cex-hairline);
}
.cex-canvas .cex-sp-aux {
  padding: 24px 18px 24px 0;
  display: flex; flex-direction: column; gap: 6px;
  border-right: 1px solid var(--cex-hairline);
}
.cex-canvas .cex-sp-aux:last-child { border-right: 0; padding-right: 0; }
.cex-canvas .cex-sp-aux:not(:first-child) { padding-left: 24px; }
.cex-canvas .cex-sp-aux-l {
  font-family: var(--mono); font-size: 13px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--cex-txt3);
}
.cex-canvas .cex-sp-aux-v {
  font-family: var(--cond); font-weight: 600; font-size: 42px; line-height: 0.96;
  color: var(--cex-txt); text-transform: uppercase; letter-spacing: -.005em;
}

/* Slice 3 — Stats */
.cex-canvas .cex-b-stats {
  position: absolute; left: 2160px; top: 0; width: 1080px; height: 1350px; z-index: 8;
  background: var(--cex-bg);
}
.cex-canvas .cex-st-pad {
  position: absolute; left: 80px; right: 80px; top: 230px; bottom: 130px;
  display: flex; flex-direction: column;
}
.cex-canvas .cex-st-kicker {
  font-family: var(--mono); font-size: 16px; letter-spacing: .36em; text-transform: uppercase;
  color: var(--cex-txt2); margin-bottom: 24px;
}
.cex-canvas .cex-st-h {
  font-family: var(--cond); font-weight: 300; font-size: 64px; line-height: 1.02;
  letter-spacing: -.005em; text-transform: uppercase; color: var(--cex-txt2); margin-bottom: auto;
}
.cex-canvas .cex-st-h em { font-style: normal; color: var(--cex-txt); font-weight: 600; }
.cex-canvas .cex-st-hero { margin-top: 24px; }
.cex-canvas .cex-st-hero-l {
  font-family: var(--mono); font-size: 16px; letter-spacing: .36em; text-transform: uppercase;
  color: var(--cex-accent); margin-bottom: 8px;
}
.cex-canvas .cex-st-hero-v {
  font-family: var(--cond); font-weight: 800; font-size: 360px; line-height: 0.84;
  letter-spacing: -.03em; color: var(--cex-txt);
}
.cex-canvas .cex-st-hero-v sup {
  font-family: var(--cond); font-weight: 300; font-size: 0.18em; line-height: 1;
  letter-spacing: .18em; color: var(--cex-accent); vertical-align: super; text-transform: uppercase;
  margin-left: 14px; top: -0.7em; position: relative;
}
.cex-canvas .cex-st-tickers {
  margin-top: 48px; display: grid; grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--cex-hairline);
}
.cex-canvas .cex-st-tk {
  padding: 24px 24px 24px 0; border-right: 1px solid var(--cex-hairline);
  display: flex; flex-direction: column; gap: 6px;
}
.cex-canvas .cex-st-tk:last-child { border-right: 0; padding-right: 0; }
.cex-canvas .cex-st-tk:not(:first-child) { padding-left: 24px; }
.cex-canvas .cex-st-tk-l {
  font-family: var(--mono); font-size: 13px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--cex-txt3);
}
.cex-canvas .cex-st-tk-v {
  font-family: var(--cond); font-weight: 600; font-size: 54px; line-height: 0.96;
  color: var(--cex-txt);
}
.cex-canvas .cex-st-tk-v small {
  font-family: var(--cond); font-weight: 300; font-size: 0.42em;
  color: var(--cex-txt2); margin-left: 6px;
}

/* Slice 4 — Eigenleistung */
.cex-canvas .cex-b-diy {
  position: absolute; left: 3240px; top: 0; width: 1080px; height: 1350px; z-index: 8;
  background: var(--cex-bg);
}
.cex-canvas .cex-dy-pad {
  position: absolute; left: 80px; right: 80px; top: 230px; bottom: 130px;
  display: flex; flex-direction: column;
}
.cex-canvas .cex-dy-kicker {
  font-family: var(--mono); font-size: 16px; letter-spacing: .36em; text-transform: uppercase;
  color: var(--cex-txt2); margin-bottom: 24px;
}
.cex-canvas .cex-dy-h {
  font-family: var(--cond); font-weight: 300; font-size: 64px; line-height: 1.02;
  letter-spacing: -.005em; text-transform: uppercase; color: var(--cex-txt2); margin-bottom: auto;
}
.cex-canvas .cex-dy-h em { font-style: normal; color: var(--cex-txt); font-weight: 600; }
.cex-canvas .cex-dy-hero { margin-top: 24px; }
.cex-canvas .cex-dy-hero-l {
  font-family: var(--mono); font-size: 16px; letter-spacing: .36em; text-transform: uppercase;
  color: var(--cex-accent); margin-bottom: 8px;
}
.cex-canvas .cex-dy-hero-row {
  display: flex; align-items: flex-end; gap: 32px; margin-bottom: 32px;
}
.cex-canvas .cex-dy-hero-v {
  font-family: var(--cond); font-weight: 800; font-size: 360px; line-height: 0.84;
  letter-spacing: -.03em; color: var(--cex-txt);
}
.cex-canvas .cex-dy-hero-v sup {
  font-family: var(--cond); font-weight: 300; font-size: 0.18em; line-height: 1;
  letter-spacing: .18em; color: var(--cex-accent); vertical-align: super;
  margin-left: 14px; top: -0.7em; position: relative;
}
.cex-canvas .cex-dy-hero-side {
  font-family: var(--cond); font-weight: 300; font-size: 38px; line-height: 1.05;
  color: var(--cex-txt2); text-transform: uppercase; letter-spacing: .005em; padding-bottom: 48px;
}
.cex-canvas .cex-dy-hero-side strong { color: var(--cex-txt); font-weight: 600; }
.cex-canvas .cex-dy-bar-wrap { display: flex; flex-direction: column; gap: 14px; margin-bottom: 48px; }
.cex-canvas .cex-dy-bar {
  position: relative; height: 14px; background: rgba(255,255,255,0.06);
  border: 1px solid var(--cex-hairline); overflow: hidden;
}
.cex-canvas .cex-dy-bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0; background: var(--cex-accent);
}
.cex-canvas .cex-dy-bar-legend {
  display: flex; justify-content: space-between;
  font-family: var(--mono); font-size: 13px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--cex-txt3);
}
.cex-canvas .cex-dy-bar-legend .cex-ratio-l { color: var(--cex-accent); }
.cex-canvas .cex-dy-bar-legend .cex-ratio-r { color: var(--cex-txt2); }
.cex-canvas .cex-dy-cats {
  margin-top: auto; display: grid; grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--cex-hairline);
}
.cex-canvas .cex-dy-cat {
  padding: 24px 24px 24px 0; border-right: 1px solid var(--cex-hairline);
  display: flex; flex-direction: column; gap: 6px;
}
.cex-canvas .cex-dy-cat:last-child { border-right: 0; padding-right: 0; }
.cex-canvas .cex-dy-cat:not(:first-child) { padding-left: 24px; }
.cex-canvas .cex-dy-cat-l {
  font-family: var(--mono); font-size: 13px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--cex-txt3);
}
.cex-canvas .cex-dy-cat-v {
  font-family: var(--cond); font-weight: 600; font-size: 54px; line-height: 0.96; color: var(--cex-txt);
}
.cex-canvas .cex-dy-cat-v small {
  font-family: var(--cond); font-weight: 300; font-size: 0.4em; color: var(--cex-txt2); margin-left: 6px;
}

/* Slice 5 — Closing photo */
.cex-canvas .cex-b-end {
  position: absolute; left: 4320px; top: 0; width: 1080px; height: 1350px; z-index: 8;
  background: #000; overflow: hidden;
}
.cex-canvas .cex-e-photo { position: absolute; inset: 0; overflow: hidden; }
.cex-canvas .cex-e-photo img {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  min-width: 100%; min-height: 100%; object-fit: cover; object-position: 60% 55%;
  filter: contrast(1.04) saturate(0.94);
}
.cex-canvas .cex-e-photo::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, transparent 25%, transparent 60%, rgba(0,0,0,0.88) 100%);
}
.cex-canvas .cex-e-pad {
  position: absolute; left: 80px; right: 80px; top: 80px; bottom: 60px; z-index: 5;
  display: flex; flex-direction: column; justify-content: space-between;
}
.cex-canvas .cex-e-folio {
  font-family: var(--mono); font-size: 14px; letter-spacing: .36em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); text-align: right;
}
.cex-canvas .cex-e-bottom {
  display: flex; justify-content: space-between; align-items: flex-end; gap: 48px;
}
.cex-canvas .cex-e-cap {
  font-family: var(--cond); font-weight: 300; font-size: 46px; line-height: 1.1;
  color: rgba(255,255,255,0.92); text-transform: uppercase; letter-spacing: .005em;
  max-width: 520px;
}
.cex-canvas .cex-e-cap em { font-style: normal; color: #fff; font-weight: 600; }
.cex-canvas .cex-e-wm {
  font-family: var(--mono); font-size: 13px; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); text-align: right; line-height: 1.6;
}
.cex-canvas .cex-e-wm b {
  display: block; font-family: var(--cond); font-weight: 700; font-size: 24px;
  letter-spacing: -.005em; text-transform: lowercase;
  color: rgba(255,255,255,0.85); margin-bottom: 4px;
}
.cex-canvas .cex-e-wm b i { color: var(--cex-accent); font-style: normal; }

/* ========================================================================
   CAROUSEL SETUP — Pre-flight customization (accent + font)
   Shown via openCarouselSetup() in a bottom-sheet before openCarouselDialog
   ======================================================================== */
.cex-setup { display: flex; flex-direction: column; gap: 28px; padding: 4px 2px 8px; }
.cex-setup-section { display: flex; flex-direction: column; gap: 12px; }
.cex-setup-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--txt2);
}

.cex-swatches {
  display: grid; grid-template-columns: repeat(8, 1fr); gap: 8px;
}
.cex-swatch {
  width: 100%; aspect-ratio: 1 / 1; padding: 0;
  background: var(--sw, #888); border: 2px solid transparent;
  cursor: pointer; transition: all .15s;
  position: relative;
}
.cex-swatch:hover { transform: scale(1.05); }
.cex-swatch.is-active {
  border-color: #fff;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.6), 0 0 0 3px var(--sw);
}
.cex-swatch.is-active::after {
  content: ''; position: absolute; inset: 4px;
  border: 1.5px solid rgba(255,255,255,0.85);
}

.cex-custom-color {
  display: flex; align-items: center; gap: 12px; cursor: pointer;
  padding: 10px 12px; border: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--txt2);
  align-self: flex-start;
}
.cex-custom-color:hover { color: var(--txt); border-color: var(--border2); }
.cex-custom-color input[type="color"] {
  width: 22px; height: 22px; padding: 0; border: 0;
  background: transparent; cursor: pointer;
}
.cex-custom-color input[type="color"]::-webkit-color-swatch-wrapper { padding: 0; }
.cex-custom-color input[type="color"]::-webkit-color-swatch { border: 1px solid rgba(255,255,255,0.2); }

.cex-fonts {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
}
.cex-font-card {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 10px; cursor: pointer; transition: all .15s;
  background: rgba(255,255,255,0.02); border: 1px solid var(--border);
}
.cex-font-card:hover { background: rgba(255,255,255,0.05); border-color: var(--border2); }
.cex-font-card.is-active {
  background: rgba(61,90,241,0.08); border-color: var(--accent);
}
.cex-font-preview {
  font-size: 38px; line-height: 1; color: var(--txt);
}
.cex-font-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--txt2);
}
.cex-font-card.is-active .cex-font-label { color: var(--accent); }

.cex-setup-cta {
  margin-top: 8px; width: 100%;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: var(--accent); color: #fff; border: 0;
  font-family: var(--cond); font-weight: 700; font-size: 17px;
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 16px; cursor: pointer; transition: all .15s;
}
.cex-setup-cta:hover { background: #2d4ad9; }

/* ========================================================================
   CAROUSEL FONT VARIANTS — applied via data-font on .cex-canvas
   Default ('editorial') = current Barlow Condensed 800 — no rule needed.
   ======================================================================== */
.cex-canvas[data-font="modern"] .cex-model-wordmark,
.cex-canvas[data-font="modern"] .cex-st-hero-v,
.cex-canvas[data-font="modern"] .cex-dy-hero-v,
.cex-canvas[data-font="modern"] .cex-sp-hero-v {
  font-family: 'Barlow', system-ui, sans-serif;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.cex-canvas[data-font="modern"] .cex-st-h,
.cex-canvas[data-font="modern"] .cex-dy-h,
.cex-canvas[data-font="modern"] .cex-e-cap {
  font-family: 'Barlow', system-ui, sans-serif;
}

.cex-canvas[data-font="schmal"] .cex-model-wordmark,
.cex-canvas[data-font="schmal"] .cex-st-hero-v,
.cex-canvas[data-font="schmal"] .cex-dy-hero-v,
.cex-canvas[data-font="schmal"] .cex-sp-hero-v {
  font-weight: 200;
  letter-spacing: -0.018em;
}
.cex-canvas[data-font="schmal"] .cex-cov-marque,
.cex-canvas[data-font="schmal"] .cex-cov-year {
  font-weight: 200;
}

/* ========================================================================
   CAROUSEL ENTRANCE — Brand-Splash + Viewport reveal
   ======================================================================== */

/* Splash layer: overlays everything before reveal */
.cex-splash {
  position: absolute; inset: 0; z-index: 100;
  background: #0a0a0a;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 28px; padding: 24px;
  cursor: pointer;
  animation: cex-splash-in 280ms ease-out both;
  isolation: isolate;
}
.cex-splash::before {
  /* subtle vignette + brand glow */
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 40% at 50% 50%, rgba(61,90,241,0.10) 0%, transparent 65%),
    radial-gradient(ellipse 100% 100% at 50% 100%, rgba(0,0,0,0.4) 0%, transparent 50%);
  pointer-events: none;
}
.cex-splash.is-leaving {
  animation: cex-splash-out 380ms cubic-bezier(0.4, 0, 0.2, 1) forwards;
  pointer-events: none;
}
.cex-splash-mark {
  font-family: var(--cond); font-weight: 800; font-size: 64px;
  letter-spacing: -0.005em; text-transform: lowercase; color: #ececec;
  line-height: 1;
  animation: cex-splash-mark-in 700ms cubic-bezier(0.16, 1, 0.3, 1) 100ms both;
}
.cex-splash-mark i { color: var(--accent); font-style: normal; }
.cex-splash-meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.32em;
  text-transform: uppercase; color: var(--txt3);
  text-align: center; line-height: 1.7;
  max-width: 80vw;
  animation: cex-splash-meta-in 700ms cubic-bezier(0.16, 1, 0.3, 1) 280ms both;
}
.cex-splash-meta b {
  display: block; color: var(--txt2); font-weight: 500; font-size: 13px;
  margin-bottom: 8px;
}
.cex-splash-rule {
  width: 80px; height: 1px; background: rgba(255,255,255,0.18);
  animation: cex-splash-rule-in 600ms ease-out 200ms both;
}

@keyframes cex-splash-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes cex-splash-out {
  from { opacity: 1; transform: scale(1); }
  to   { opacity: 0; transform: scale(1.03); }
}
@keyframes cex-splash-mark-in {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes cex-splash-meta-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes cex-splash-rule-in {
  from { width: 0; opacity: 0; }
  to   { width: 80px; opacity: 1; }
}

/* Viewport entrance — full-height slide up from below ("magazine opens") */
.cex-viewport {
  opacity: 0;
  transform: translateY(110%);
}
.cex-viewport.is-revealed {
  animation: cex-viewport-in 820ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@keyframes cex-viewport-in {
  0% {
    opacity: 0;
    transform: translateY(110%);
  }
  18% { opacity: 1; }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ========================================================================
   CUTOUT — Background removal progress overlay + sheet icon
   ======================================================================== */
.bs-share-icon-cutout {
  background: linear-gradient(135deg, rgba(61,90,241,0.15), rgba(61,90,241,0.05));
  color: var(--accent);
  border: 1px solid rgba(61,90,241,0.3);
}

.cutout-progress {
  position: fixed; inset: 0; z-index: 12000;
  background: rgba(0,0,0,0.78); backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: cutout-bg-in 220ms ease-out both;
}
.cutout-progress-card {
  background: var(--surface2); border: 1px solid var(--border2);
  padding: 28px 26px; max-width: 380px; width: 100%;
  display: flex; flex-direction: column; gap: 20px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6);
  animation: cutout-card-in 320ms cubic-bezier(0.16, 1, 0.3, 1) both;
}
.cutout-progress-title {
  font-family: var(--cond); font-weight: 600; font-size: 22px;
  color: var(--txt); letter-spacing: -0.005em;
}
.cutout-progress-bar {
  height: 4px; background: rgba(255,255,255,0.08);
  border-radius: 2px; overflow: hidden;
}
.cutout-progress-fill {
  height: 100%; background: var(--accent);
  width: 5%; transition: width 280ms cubic-bezier(0.4, 0, 0.2, 1);
}
.cutout-progress-status {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--txt2); line-height: 1.6;
  min-height: 18px;
}
.cutout-progress-cancel {
  align-self: flex-start;
  background: transparent; color: var(--txt2);
  border: 1px solid var(--border);
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 8px 14px; cursor: pointer; transition: all .15s;
}
.cutout-progress-cancel:hover { color: var(--txt); border-color: var(--border2); }

/* Action row in error state */
.cutout-progress-actions {
  display: flex; flex-direction: column; gap: 8px; margin-top: 6px;
}
.cutout-progress-btn {
  background: rgba(255,255,255,0.04); color: var(--txt);
  border: 1px solid var(--border);
  font-family: var(--cond); font-weight: 600; font-size: 14px; letter-spacing: 0.02em;
  text-transform: uppercase; padding: 12px 14px; cursor: pointer;
  transition: all .15s;
}
.cutout-progress-btn:hover { background: rgba(255,255,255,0.08); border-color: var(--border2); }
.cutout-progress-btn-primary {
  background: var(--accent); border-color: var(--accent); color: #fff;
}
.cutout-progress-btn-primary:hover { background: #2d4ad9; border-color: #2d4ad9; }

@keyframes cutout-bg-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes cutout-card-in {
  from { opacity: 0; transform: translateY(20px) scale(0.96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ========================================================================
   LAYERED TEMPLATE — scoped to .cex-canvas[data-template="layered"]
   ======================================================================== */

/* Template-cards mit handgemachten CSS-Mockups als Vollbreite-Vorschau.
   container-query-units (cqw) skalieren Type/Padding proportional zur Card-Breite,
   damit jede Card unabhängig vom Viewport sauber aussieht. */
.cex-tpls { display: flex; flex-direction: column; gap: 14px; }
.cex-tpl-card {
  display: block; width: 100%; padding: 0; cursor: pointer;
  background: rgba(255,255,255,0.02); border: 1px solid var(--border);
  border-radius: 14px; overflow: hidden;
  transition: border-color .18s, transform .18s;
}
.cex-tpl-card:hover { border-color: var(--border2); }
.cex-tpl-card.is-active { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(61,90,241,0.15); }
.cex-tpl-card.is-active .cex-tpl-sub { color: var(--accent); }

.cex-tpl-preview {
  position: relative; width: 100%; aspect-ratio: 4 / 5;
  overflow: hidden; container-type: inline-size;
}

.cex-tpl-info {
  padding: 12px 16px; display: flex; flex-direction: column; gap: 4px;
}
.cex-tpl-name {
  font-family: var(--cond); font-weight: 700; font-size: 19px;
  color: var(--txt); letter-spacing: -0.005em;
}
.cex-tpl-sub {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--txt2);
}
.cex-tpl-cta {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent);
  margin-top: 6px; opacity: 0.85;
}

/* Step-2 Aktionen unter Template-Preview-Card */
.cex-step2-tpl-actions {
  display: flex; gap: 8px; margin-top: 10px; align-items: center;
}
.cex-step2-tpl-actions .cex-setup-back { margin: 0; }
.cex-setup-preview {
  margin-left: auto;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  color: var(--accent); background: rgba(61,90,241,0.08);
  border: 1px solid rgba(61,90,241,0.2); border-radius: 8px;
  padding: 8px 14px; cursor: pointer; transition: all .15s;
}
.cex-setup-preview:hover { background: rgba(61,90,241,0.14); border-color: var(--accent); }

/* Foto-Picker: horizontaler Strip von Thumbs */
.cex-photos {
  display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.cex-photos::-webkit-scrollbar { display: none; }
.cex-photo-thumb {
  flex: 0 0 auto; width: 88px; height: 110px;
  padding: 0; border-radius: 8px; overflow: hidden;
  background: var(--surface2); border: 2px solid var(--border);
  cursor: pointer; transition: border-color .15s, transform .15s;
  scroll-snap-align: start;
}
.cex-photo-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cex-photo-thumb:hover { border-color: var(--border2); }
.cex-photo-thumb.is-active { border-color: var(--accent); transform: scale(0.97); }
.cex-photo-empty {
  font-family: var(--mono); font-size: 11px; color: var(--txt2);
  padding: 14px; text-align: center;
  background: var(--surface2); border-radius: 8px;
}

/* ── Mockup-Basis ───────────────────────────────────────────────── */
.cex-mock { position: absolute; inset: 0; overflow: hidden; }
.cex-mock-photo { position: absolute; inset: 0; overflow: hidden; }
.cex-mock-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cex-mock-photo-empty {
  background:
    radial-gradient(120% 80% at 30% 40%, rgba(255,255,255,0.06), transparent 60%),
    linear-gradient(135deg, #1a1a20, #0a0a0c);
}

/* ── Storyteller ── editorial cover ─────────────────────────────── */
.cex-mock-st { background: #0a0a0c; padding: 7cqw 8cqw; }
.cex-mock-st .cex-mock-photo {
  inset: 56% 8cqw 7cqw 8cqw; border-radius: 1.2cqw;
}
.cex-mock-st-rule {
  height: 0.3cqw; background: var(--mock-accent, var(--accent));
  margin-bottom: 4cqw; width: 28%;
}
.cex-mock-st-vol {
  font-family: var(--mono); font-size: 3.2cqw; color: #6a6a78;
  letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 5cqw;
}
.cex-mock-st-brand {
  font-family: var(--cond); font-weight: 800;
  font-size: 18cqw; line-height: 0.86; color: #efefef;
  letter-spacing: -0.03em; margin-bottom: 3cqw;
}
.cex-mock-st-folio {
  font-family: var(--mono); font-size: 3.4cqw; color: #999;
  letter-spacing: 0.18em; text-transform: uppercase;
}
.cex-mock-st-folio b { color: #efefef; font-weight: 600; }

/* ── Layered ── type-hero mit Car-Bleed ─────────────────────────── */
.cex-mock-lf {
  background: linear-gradient(135deg, var(--mock-accent, var(--accent)) 0%, #0a0a0c 75%);
}
.cex-mock-lf .cex-mock-photo {
  inset: 35% 0 0 0; opacity: 0.92;
  mask-image: linear-gradient(180deg, transparent, #000 25%, #000);
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 25%, #000);
}
.cex-mock-lf-type {
  position: absolute; left: 6cqw; right: 6cqw; top: 8cqw;
  font-family: var(--cond); font-weight: 800;
  font-size: 26cqw; line-height: 0.82; color: #fff;
  letter-spacing: -0.04em;
  text-shadow: 0 2cqw 4cqw rgba(0,0,0,0.3);
  z-index: 2;
}
.cex-mock-lf-sub {
  position: absolute; left: 7cqw; bottom: 7cqw;
  font-family: var(--mono); font-size: 2.8cqw; color: #fff;
  letter-spacing: 0.22em; text-transform: uppercase; opacity: 0.85;
  z-index: 2;
}

/* ── Timeline ── drei Meilensteine ──────────────────────────────── */
.cex-mock-tl { background: #0a0a0c; padding: 8cqw; }
.cex-mock-tl-head {
  font-family: var(--cond); font-weight: 700;
  font-size: 8cqw; color: #efefef; line-height: 1; letter-spacing: -0.02em;
  margin-bottom: 8cqw;
}
.cex-mock-tl-line {
  position: absolute; left: 14cqw; top: 28cqw; bottom: 14cqw; width: 0.4cqw;
  background: var(--mock-accent, var(--accent));
}
.cex-mock-tl-events {
  position: absolute; left: 8cqw; right: 8cqw; top: 24cqw; bottom: 8cqw;
  display: flex; flex-direction: column; justify-content: space-between;
}
.cex-mock-tl-evt { display: flex; align-items: center; gap: 5cqw; }
.cex-mock-tl-dot {
  width: 3cqw; height: 3cqw; border-radius: 50%;
  background: var(--mock-accent, var(--accent));
  flex-shrink: 0; margin-left: 4.4cqw;
}
.cex-mock-tl-evt-txt {
  display: flex; flex-direction: column; gap: 0.6cqw;
}
.cex-mock-tl-year {
  font-family: var(--mono); font-size: 3.4cqw; color: #efefef;
  letter-spacing: 0.18em; font-weight: 600;
}
.cex-mock-tl-label {
  font-family: var(--mono); font-size: 2.6cqw; color: #6a6a78;
  letter-spacing: 0.16em; text-transform: uppercase;
}

/* ── Setup-Sheet Step-Navigation ────────────────────────────────── */
.cex-setup-back {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  color: var(--txt2); background: none; border: none; padding: 4px 0;
  margin: 0 0 14px; cursor: pointer; transition: color .15s;
}
.cex-setup-back:hover { color: var(--accent); }
.cex-setup-back svg { width: 14px; height: 14px; }

/* Background photo blurred (under everything) */
.cex-canvas[data-template="layered"] .cex-lf-bg { position: absolute; inset: 0; z-index: 1; overflow: hidden; }
.cex-canvas[data-template="layered"] .cex-lf-bg img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  filter: blur(60px) brightness(0.32) saturate(0.55) contrast(1.15);
  transform: scale(1.1);
}
.cex-canvas[data-template="layered"] .cex-lf-bg::after {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 25% 40%, rgba(0,0,0,0) 0%, rgba(0,0,0,0.5) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.3) 0%, transparent 25%, transparent 60%, rgba(0,0,0,0.7) 100%);
}
.cex-canvas[data-template="layered"] .cex-lf-grain {
  position: absolute; inset: 0; z-index: 2; opacity: 0.06; pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85'/></filter><rect width='220' height='220' filter='url(%23n)' opacity='0.6'/></svg>");
}

/* Slide 1 — Type-Hero */
.cex-canvas[data-template="layered"] .cex-lf-s1-kickerL {
  position: absolute; left: 80px; top: 80px; z-index: 3;
  font-family: var(--mono); font-size: 18px; letter-spacing: 0.4em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.cex-canvas[data-template="layered"] .cex-lf-s1-kickerR {
  position: absolute; top: 80px; right: 4400px; z-index: 3;
  font-family: var(--mono); font-size: 18px; letter-spacing: 0.4em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.cex-canvas[data-template="layered"] .cex-lf-wordmark {
  position: absolute; left: 60px; top: 200px; z-index: 3;
  font-family: var(--cond); font-weight: 800; font-size: 380px; line-height: 0.84;
  letter-spacing: -0.03em; text-transform: uppercase; color: #ffffff;
  text-shadow: 0 24px 80px rgba(0,0,0,0.55);
}
.cex-canvas[data-template="layered"] .cex-lf-wm-line { display: block; }
.cex-canvas[data-template="layered"] .cex-lf-wm-line.l2 { margin-top: -8px; }
.cex-canvas[data-template="layered"] .cex-lf-wm-thin { font-weight: 200; color: rgba(255,255,255,0.92); }
.cex-canvas[data-template="layered"] .cex-lf-s1-bottom {
  position: absolute; left: 80px; bottom: 60px; right: 4400px; z-index: 5;
  border-top: 1px solid rgba(255,255,255,0.18); padding-top: 18px;
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--mono); font-size: 16px; letter-spacing: 0.32em;
  text-transform: uppercase; color: rgba(255,255,255,0.7);
}

/* Slide 2 — Specs (sits in window x=1080..2160) */
.cex-canvas[data-template="layered"] .cex-lf-s2-pad {
  position: absolute; left: 1080px; top: 0; width: 1080px; height: 1350px; z-index: 3;
}
.cex-canvas[data-template="layered"] .cex-lf-s2-kicker {
  position: absolute; left: 80px; top: 80px;
  font-family: var(--mono); font-size: 18px; letter-spacing: 0.4em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.cex-canvas[data-template="layered"] .cex-lf-s2-folio {
  position: absolute; right: 80px; top: 80px;
  font-family: var(--mono); font-size: 14px; letter-spacing: 0.36em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.cex-canvas[data-template="layered"] .cex-lf-s2-content {
  position: absolute; left: 80px; right: 80px; top: 200px;
}
.cex-canvas[data-template="layered"] .cex-lf-s2-spec-kicker {
  font-family: var(--mono); font-size: 16px; letter-spacing: 0.36em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); margin-bottom: 18px;
}
.cex-canvas[data-template="layered"] .cex-lf-s2-hero {
  font-family: var(--cond); font-weight: 200; font-size: 280px; line-height: 0.88;
  letter-spacing: -0.025em; color: #ffffff;
  border-top: 1px solid rgba(255,255,255,0.18); padding-top: 24px;
}
.cex-canvas[data-template="layered"] .cex-lf-s2-hero-sub {
  font-family: var(--cond); font-weight: 300; font-size: 42px; line-height: 1.05;
  letter-spacing: 0.005em; text-transform: uppercase; color: rgba(255,255,255,0.7); margin-top: 14px;
}
.cex-canvas[data-template="layered"] .cex-lf-s2-aux {
  position: absolute; left: 80px; right: 80px; bottom: 60px;
  border-top: 1px solid rgba(255,255,255,0.18); padding-top: 18px;
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 0;
}
.cex-canvas[data-template="layered"] .cex-lf-s2-aux > div {
  padding: 12px 14px 12px 0; border-right: 1px solid rgba(255,255,255,0.10);
  display: flex; flex-direction: column; gap: 6px;
}
.cex-canvas[data-template="layered"] .cex-lf-s2-aux > div:last-child { border-right: 0; padding-right: 0; }
.cex-canvas[data-template="layered"] .cex-lf-s2-aux > div:not(:first-child) { padding-left: 14px; }
.cex-canvas[data-template="layered"] .cex-lf-s2-aux .l {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.cex-canvas[data-template="layered"] .cex-lf-s2-aux .v {
  font-family: var(--cond); font-weight: 600; font-size: 30px; line-height: 0.96;
  color: #ffffff; text-transform: uppercase; letter-spacing: -0.005em;
}

/* Slide 3 — Stats (window x=2160..3240) */
.cex-canvas[data-template="layered"] .cex-lf-s3-pad {
  position: absolute; left: 2160px; top: 0; width: 1080px; height: 1350px; z-index: 3;
  padding: 200px 80px 60px;
}
.cex-canvas[data-template="layered"] .cex-lf-s3-kicker {
  position: absolute; left: 80px; top: 80px;
  font-family: var(--mono); font-size: 18px; letter-spacing: 0.4em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.cex-canvas[data-template="layered"] .cex-lf-s3-folio {
  position: absolute; right: 80px; top: 80px;
  font-family: var(--mono); font-size: 14px; letter-spacing: 0.36em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.cex-canvas[data-template="layered"] .cex-lf-s3-h {
  font-family: var(--cond); font-weight: 300; font-size: 88px; line-height: 0.96;
  letter-spacing: -0.012em; text-transform: uppercase;
  color: rgba(255,255,255,0.7); margin-bottom: 36px;
}
.cex-canvas[data-template="layered"] .cex-lf-s3-h em { font-style: normal; color: #ffffff; font-weight: 600; }
.cex-canvas[data-template="layered"] .cex-lf-s3-hero-l {
  font-family: var(--mono); font-size: 16px; letter-spacing: 0.36em; text-transform: uppercase;
  color: var(--cex-accent); margin-bottom: 8px;
}
.cex-canvas[data-template="layered"] .cex-lf-s3-hero {
  font-family: var(--cond); font-weight: 800; font-size: 280px; line-height: 0.84;
  letter-spacing: -0.03em; color: #ffffff; margin-bottom: 36px;
}
.cex-canvas[data-template="layered"] .cex-lf-s3-hero sup {
  font-family: var(--cond); font-weight: 300; font-size: 0.18em;
  letter-spacing: 0.18em; color: var(--cex-accent); vertical-align: super;
  margin-left: 14px; top: -0.7em; position: relative; text-transform: uppercase;
}
.cex-canvas[data-template="layered"] .cex-lf-s3-tickers {
  position: absolute; left: 80px; right: 80px; bottom: 80px;
  border-top: 1px solid rgba(255,255,255,0.18); padding-top: 18px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
}
.cex-canvas[data-template="layered"] .cex-lf-s3-tickers > div {
  padding: 12px 18px 12px 0; border-right: 1px solid rgba(255,255,255,0.10);
  display: flex; flex-direction: column; gap: 6px;
}
.cex-canvas[data-template="layered"] .cex-lf-s3-tickers > div:last-child { border-right: 0; padding-right: 0; }
.cex-canvas[data-template="layered"] .cex-lf-s3-tickers > div:not(:first-child) { padding-left: 18px; }
.cex-canvas[data-template="layered"] .cex-lf-s3-tickers .l {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.cex-canvas[data-template="layered"] .cex-lf-s3-tickers .v {
  font-family: var(--cond); font-weight: 600; font-size: 48px; line-height: 0.96; color: #ffffff;
}

/* Slide 4 — Eigenleistung (window x=3240..4320) */
.cex-canvas[data-template="layered"] .cex-lf-s4-pad {
  position: absolute; left: 3240px; top: 0; width: 1080px; height: 1350px; z-index: 3;
  padding: 200px 80px 60px;
}
.cex-canvas[data-template="layered"] .cex-lf-s4-kicker {
  position: absolute; left: 80px; top: 80px;
  font-family: var(--mono); font-size: 18px; letter-spacing: 0.4em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.cex-canvas[data-template="layered"] .cex-lf-s4-folio {
  position: absolute; right: 80px; top: 80px;
  font-family: var(--mono); font-size: 14px; letter-spacing: 0.36em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.cex-canvas[data-template="layered"] .cex-lf-s4-h {
  font-family: var(--cond); font-weight: 300; font-size: 88px; line-height: 0.96;
  letter-spacing: -0.012em; text-transform: uppercase;
  color: rgba(255,255,255,0.7); margin-bottom: 36px;
}
.cex-canvas[data-template="layered"] .cex-lf-s4-h em { font-style: normal; color: #ffffff; font-weight: 600; }
.cex-canvas[data-template="layered"] .cex-lf-s4-hero {
  font-family: var(--cond); font-weight: 800; font-size: 320px; line-height: 0.84;
  letter-spacing: -0.03em; color: #ffffff;
}
.cex-canvas[data-template="layered"] .cex-lf-s4-hero sup {
  font-family: var(--cond); font-weight: 300; font-size: 0.18em;
  letter-spacing: 0.18em; color: var(--cex-accent); vertical-align: super;
  margin-left: 14px; top: -0.7em; position: relative;
}
.cex-canvas[data-template="layered"] .cex-lf-s4-side {
  font-family: var(--cond); font-weight: 300; font-size: 30px; line-height: 1.2;
  color: rgba(255,255,255,0.7); margin-top: 16px; max-width: 600px;
}
.cex-canvas[data-template="layered"] .cex-lf-s4-side strong { color: #ffffff; font-weight: 600; }
.cex-canvas[data-template="layered"] .cex-lf-s4-bar {
  position: absolute; left: 80px; right: 80px; bottom: 130px;
  height: 14px; background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18); overflow: hidden;
}
.cex-canvas[data-template="layered"] .cex-lf-s4-bar-fill {
  position: absolute; left: 0; top: 0; bottom: 0; background: var(--cex-accent);
}
.cex-canvas[data-template="layered"] .cex-lf-s4-bar-legend {
  position: absolute; left: 80px; right: 80px; bottom: 80px;
  display: flex; justify-content: space-between;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
.cex-canvas[data-template="layered"] .cex-lf-s4-bar-legend .ratio-l { color: var(--cex-accent); }
.cex-canvas[data-template="layered"] .cex-lf-s4-bar-legend .ratio-r { color: rgba(255,255,255,0.6); }

/* Slide 5 — Closing (window x=4320..5400) */
.cex-canvas[data-template="layered"] .cex-lf-s5-pad {
  position: absolute; left: 4320px; top: 0; width: 1080px; height: 1350px; z-index: 3;
  padding: 80px;
}
.cex-canvas[data-template="layered"] .cex-lf-s5-folio {
  position: absolute; right: 80px; top: 80px;
  font-family: var(--mono); font-size: 14px; letter-spacing: 0.36em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); text-align: right;
}
.cex-canvas[data-template="layered"] .cex-lf-s5-cutout {
  position: absolute; left: 80px; right: 80px; top: 200px; bottom: 280px;
  z-index: 2;
}
.cex-canvas[data-template="layered"] .cex-lf-s5-cutout img {
  width: 100%; height: 100%;
  object-fit: contain; object-position: center bottom;
  filter: drop-shadow(0 30px 50px rgba(0,0,0,0.6));
}
.cex-canvas[data-template="layered"] .cex-lf-s5-cap {
  position: absolute; left: 80px; bottom: 130px;
  font-family: var(--cond); font-weight: 300; font-size: 46px; line-height: 1.1;
  color: rgba(255,255,255,0.92); text-transform: uppercase; letter-spacing: 0.005em;
  z-index: 4;
}
.cex-canvas[data-template="layered"] .cex-lf-s5-cap em { font-style: normal; color: #fff; font-weight: 600; }
.cex-canvas[data-template="layered"] .cex-lf-s5-wm {
  position: absolute; right: 80px; bottom: 80px; z-index: 4;
  font-family: var(--mono); font-size: 13px; letter-spacing: 0.3em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); text-align: right; line-height: 1.6;
}
.cex-canvas[data-template="layered"] .cex-lf-s5-wm b {
  display: block; font-family: var(--cond); font-weight: 700; font-size: 24px;
  letter-spacing: -0.005em; text-transform: lowercase;
  color: rgba(255,255,255,0.85); margin-bottom: 4px;
}
.cex-canvas[data-template="layered"] .cex-lf-s5-wm b i { color: var(--cex-accent); font-style: normal; }

/* THE BIG SPANNING CUTOUT — over slide 1+2, above type */
.cex-canvas[data-template="layered"] .cex-lf-cutout {
  position: absolute;
  left: 280px; top: 380px;
  width: 1620px; height: 780px;
  z-index: 4;
  pointer-events: none;
}
.cex-canvas[data-template="layered"] .cex-lf-cutout img {
  width: 100%; height: 100%;
  object-fit: contain;
  object-position: center bottom;
  filter: drop-shadow(0 40px 60px rgba(0,0,0,0.7));
}

/* ========================================================================
   TIMELINE TEMPLATE — scoped to .cex-canvas[data-template="timeline"]
   5 Slides, 5400×1350 canvas. Slide 1 Intro, 2/3/4 Meilensteine, 5 Closing.
   Editorial DNA: Hairlines, Mono-Caps, Barlow Condensed, sparse Accent.
   ======================================================================== */
.cex-canvas[data-template="timeline"] { background: #0a0a0a; }

/* ── SLIDE 1: Intro ───────────────────────────────────────────────────── */
.cex-canvas[data-template="timeline"] .cex-tl-intro {
  position: absolute; left: 0; top: 0; width: 1080px; height: 1350px; z-index: 2;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-photo {
  position: absolute; left: 0; top: 0; right: 0; height: 760px; overflow: hidden;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-photo img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.15) contrast(1.05);
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-grad {
  position: absolute; left: 0; right: 0; top: 0; height: 800px;
  background: linear-gradient(180deg, rgba(10,10,10,0.55) 0%, rgba(10,10,10,0.15) 30%, rgba(10,10,10,0.6) 75%, #0a0a0a 100%);
  z-index: 1;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-kicker {
  position: absolute; left: 80px; top: 80px; z-index: 3;
  font-family: var(--mono); font-size: 14px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.32em;
  color: rgba(255,255,255,0.85);
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-rule {
  position: absolute; left: 80px; top: 820px; width: 80px; height: 1px;
  background: var(--cex-accent); z-index: 3;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-h {
  position: absolute; left: 80px; top: 850px; z-index: 3;
  font-family: var(--cond); font-weight: 800; font-size: 132px; line-height: 0.92;
  color: #fff; letter-spacing: -0.025em; text-transform: none;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-h2 {
  position: absolute; left: 80px; top: 1110px; z-index: 3;
  font-family: var(--cond); font-weight: 300; font-size: 78px; line-height: 1;
  color: rgba(255,255,255,0.7); letter-spacing: -0.018em;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-h2 em {
  font-style: italic; color: var(--cex-accent); font-weight: 600;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-rule-bot {
  position: absolute; left: 80px; right: 80px; bottom: 130px; height: 1px;
  background: rgba(255,255,255,0.18); z-index: 3;
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-meta {
  position: absolute; left: 80px; right: 80px; bottom: 80px; z-index: 3;
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--mono); font-size: 13px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.28em;
  color: rgba(255,255,255,0.6);
}
.cex-canvas[data-template="timeline"] .cex-tl-intro-folio {
  position: absolute; right: 80px; top: 80px; z-index: 3;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.28em;
  color: rgba(255,255,255,0.55);
}

/* ── SLIDES 2/3/4: Meilensteine ──────────────────────────────────────── */
.cex-canvas[data-template="timeline"] .cex-tl-mile {
  position: absolute; top: 0; width: 1080px; height: 1350px; z-index: 2;
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-folio {
  position: absolute; right: 80px; top: 80px;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.28em;
  color: rgba(255,255,255,0.55);
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-act {
  position: absolute; left: 80px; top: 80px;
  font-family: var(--mono); font-size: 13px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.32em;
  color: var(--cex-accent);
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-rule {
  position: absolute; left: 80px; right: 80px; top: 150px; height: 1px;
  background: rgba(255,255,255,0.18);
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-rule.cex-tl-rule-2 {
  top: 590px;
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-year {
  position: absolute; left: 80px; top: 220px;
  font-family: var(--cond); font-weight: 800; font-size: 280px; line-height: 0.85;
  color: #fff; letter-spacing: -0.035em;
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-month {
  position: absolute; left: 80px; top: 510px;
  font-family: var(--mono); font-size: 26px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.32em;
  color: rgba(255,255,255,0.65);
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-title {
  position: absolute; left: 80px; right: 80px; top: 640px;
  font-family: var(--cond); font-weight: 700; font-size: 78px; line-height: 1.05;
  color: #fff; letter-spacing: -0.015em;
  /* Two-line clamp via fixed height */
  max-height: 168px; overflow: hidden;
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-notes {
  position: absolute; left: 80px; right: 80px; top: 830px;
  font-family: var(--body); font-size: 22px; line-height: 1.4; font-weight: 400;
  color: rgba(255,255,255,0.72);
  max-height: 124px; overflow: hidden;
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-photo {
  position: absolute; right: 80px; top: 220px; width: 340px; height: 340px;
  overflow: hidden; z-index: 3;
  box-shadow: 0 20px 50px rgba(0,0,0,0.5);
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-photo img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.1) contrast(1.05);
}
.cex-canvas[data-template="timeline"] .cex-tl-mile.has-photo .cex-tl-mile-year {
  /* Wenn Foto rechts oben sitzt, Jahr leicht nach unten — verhindert Kollision */
  font-size: 240px;
}
.cex-canvas[data-template="timeline"] .cex-tl-mile-stats {
  position: absolute; left: 80px; right: 80px; bottom: 130px;
  display: flex; gap: 60px;
}
.cex-canvas[data-template="timeline"] .cex-tl-stat .l {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.28em;
  color: rgba(255,255,255,0.5); margin-bottom: 6px;
}
.cex-canvas[data-template="timeline"] .cex-tl-stat .v {
  font-family: var(--cond); font-weight: 600; font-size: 48px; line-height: 1;
  color: #fff; letter-spacing: -0.01em;
}

/* ── Compact-Slide: bis zu 4 Meilensteine als Liste ──────────────────── */
.cex-canvas[data-template="timeline"] .cex-tl-compact .cex-tl-compact-list {
  position: absolute; left: 80px; right: 80px; top: 230px; bottom: 130px;
  display: flex; flex-direction: column;
}
.cex-canvas[data-template="timeline"] .cex-tl-row {
  display: flex; align-items: flex-start; gap: 40px;
  padding: 40px 0;
  border-bottom: 1px solid rgba(255,255,255,0.12);
  flex: 1; min-height: 0;
}
.cex-canvas[data-template="timeline"] .cex-tl-row:last-child {
  border-bottom: none;
}
.cex-canvas[data-template="timeline"] .cex-tl-row-year {
  font-family: var(--cond); font-weight: 800; font-size: 96px; line-height: 0.9;
  color: #fff; letter-spacing: -0.025em;
  flex-shrink: 0; min-width: 220px;
}
.cex-canvas[data-template="timeline"] .cex-tl-row-body {
  flex: 1; min-width: 0; padding-top: 8px;
}
.cex-canvas[data-template="timeline"] .cex-tl-row-kind {
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.28em;
  color: var(--cex-accent);
  margin-bottom: 8px;
}
.cex-canvas[data-template="timeline"] .cex-tl-row-title {
  font-family: var(--cond); font-weight: 700; font-size: 44px; line-height: 1.1;
  color: #fff; letter-spacing: -0.012em;
  /* Single-line clamp */
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 6px;
}
.cex-canvas[data-template="timeline"] .cex-tl-row-aux {
  font-family: var(--mono); font-size: 13px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.22em;
  color: rgba(255,255,255,0.55);
}

/* Empty-State Slot (kein Meilenstein vorhanden) */
.cex-canvas[data-template="timeline"] .cex-tl-empty {
  position: absolute; left: 80px; right: 80px; top: 380px;
}
.cex-canvas[data-template="timeline"] .cex-tl-empty-h {
  font-family: var(--cond); font-weight: 800; font-size: 84px; line-height: 0.95;
  color: rgba(255,255,255,0.4); letter-spacing: -0.02em;
  margin-bottom: 40px;
}
.cex-canvas[data-template="timeline"] .cex-tl-empty-sub {
  font-family: var(--mono); font-size: 16px; font-weight: 500; line-height: 1.6;
  text-transform: uppercase; letter-spacing: 0.22em;
  color: rgba(255,255,255,0.35);
}

/* ── SLIDE 5: Closing ────────────────────────────────────────────────── */
.cex-canvas[data-template="timeline"] .cex-tl-end {
  position: absolute; top: 0; width: 1080px; height: 1350px; z-index: 2;
}
.cex-canvas[data-template="timeline"] .cex-tl-end-kicker {
  position: absolute; left: 80px; top: 80px;
  font-family: var(--mono); font-size: 14px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.32em;
  color: rgba(255,255,255,0.55);
}
.cex-canvas[data-template="timeline"] .cex-tl-end-rule {
  position: absolute; left: 80px; top: 450px; width: 80px; height: 1px;
  background: var(--cex-accent);
}
.cex-canvas[data-template="timeline"] .cex-tl-end-brand {
  position: absolute; left: 80px; top: 490px;
  font-family: var(--cond); font-weight: 300; font-size: 54px; line-height: 1;
  color: rgba(255,255,255,0.7); letter-spacing: -0.005em; text-transform: uppercase;
}
.cex-canvas[data-template="timeline"] .cex-tl-end-model {
  position: absolute; left: 80px; top: 570px;
  font-family: var(--cond); font-weight: 800; font-size: 152px; line-height: 0.92;
  color: #fff; letter-spacing: -0.028em; text-transform: uppercase;
}
.cex-canvas[data-template="timeline"] .cex-tl-end-year {
  position: absolute; left: 80px; top: 760px;
  font-family: var(--cond); font-weight: 300; font-size: 96px; line-height: 1;
  color: var(--cex-accent); letter-spacing: -0.018em;
}
.cex-canvas[data-template="timeline"] .cex-tl-end-year em {
  font-style: italic; font-weight: 600;
}
.cex-canvas[data-template="timeline"] .cex-tl-end-folio {
  position: absolute; right: 80px; top: 80px;
  font-family: var(--mono); font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.28em;
  color: rgba(255,255,255,0.55);
}
.cex-canvas[data-template="timeline"] .cex-tl-end-wm {
  position: absolute; right: 80px; bottom: 80px;
  font-family: var(--mono); font-size: 13px; letter-spacing: 0.3em;
  text-transform: uppercase; color: rgba(255,255,255,0.55);
  text-align: right; line-height: 1.6;
}
.cex-canvas[data-template="timeline"] .cex-tl-end-wm b {
  display: block; font-family: var(--cond); font-weight: 700; font-size: 24px;
  letter-spacing: -0.005em; text-transform: lowercase;
  color: rgba(255,255,255,0.85); margin-bottom: 4px;
}
.cex-canvas[data-template="timeline"] .cex-tl-end-wm b i {
  color: var(--cex-accent); font-style: normal;
}

/* ========================================================================
   SERVICE Quick-Chips — replaces 18-item preset list
   ======================================================================== */
.svc-quick {
  display: flex; flex-direction: column; gap: 16px;
  padding: 4px 2px 8px;
}
.svc-quick-intro {
  font-family: var(--body); font-size: 13px; line-height: 1.5;
  color: var(--txt2); padding: 0 2px;
}

.svc-chips {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
}
.svc-chip {
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
  padding: 14px 16px; cursor: pointer; transition: all .15s;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  text-align: left; width: 100%;
  font-family: var(--body);
}
.svc-chip:hover, .svc-chip:active {
  background: rgba(255,255,255,0.06); border-color: var(--border2);
}
.svc-chip-label {
  font-family: var(--cond); font-weight: 700; font-size: 18px;
  color: var(--txt); letter-spacing: -0.005em;
}
.svc-chip-hint {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--txt2);
}
.svc-chip-used {
  background: rgba(61, 90, 241, 0.06); border-color: rgba(61, 90, 241, 0.25);
}
.svc-chip-used .svc-chip-label { color: var(--txt2); }
.svc-chip-check {
  display: inline-block; margin-left: 6px; color: var(--accent); font-weight: 700;
  font-size: 14px; vertical-align: 1px;
}

.svc-chip-custom {
  margin-top: 4px;
  background: transparent;
  border: 1px dashed rgba(255,255,255,0.18);
}
.svc-chip-custom .svc-chip-label { color: var(--accent); }
.svc-chip-custom .svc-chip-hint { color: var(--txt3); }
.svc-chip-custom:hover {
  background: rgba(61, 90, 241, 0.04);
  border-color: rgba(61, 90, 241, 0.4);
  border-style: solid;
}

/* ========================================================================
   Premium Sort/Filter Trigger — replaces native <select> in Tasks/Umbau
   ======================================================================== */
.sort-trigger {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; color: var(--txt2); border: 0;
  padding: 8px 4px; cursor: pointer; transition: color .15s;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
  max-width: 130px;
}
.sort-trigger:hover, .sort-trigger:active { color: var(--txt); }
.sort-trigger-label {
  font-family: var(--cond); font-weight: 600; font-size: 14px;
  letter-spacing: -0.005em; text-transform: none;
  color: var(--txt);
}
.sort-trigger-chev {
  width: 7px; height: 7px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-1.5px);
  margin-left: 2px;
  opacity: 0.7;
}
.sort-trigger:hover .sort-trigger-chev { opacity: 1; }

/* Sheet contents for sort/filter selection */
.filter-sheet {
  display: flex; flex-direction: column;
  padding: 4px 0 8px;
}
.filter-sheet-opt {
  background: transparent; color: var(--txt);
  border: 0; border-bottom: 1px solid var(--border);
  font-family: var(--cond); font-weight: 600; font-size: 18px;
  letter-spacing: -0.005em;
  text-align: left; padding: 16px 24px;
  cursor: pointer; transition: color .15s, background .15s;
  display: flex; align-items: center; justify-content: space-between;
}
.filter-sheet-opt:last-child { border-bottom: 0; }
.filter-sheet-opt:hover { color: var(--accent); }
.filter-sheet-opt.is-active { color: var(--accent); }
.filter-sheet-opt.is-active::after {
  content: ''; width: 14px; height: 8px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg) translate(2px, -3px);
}

/* ════════════════════════════════════════════════════════════════════════
   VERKAUFS-SEITE — Auktionshaus-Stil mit Scroll-getriebenen Animationen
   Editorial, vertrauensvoll, BAT-tier
   ════════════════════════════════════════════════════════════════════════ */
.sale-page {
  background: var(--bg);
  color: var(--txt);
  min-height: 100vh;
  font-family: var(--body);
}

/* Scroll-Progress-Bar (top of page, fills as user scrolls) */
.sale-progress {
  position: fixed; top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--accent);
  transform-origin: left;
  transform: scaleX(0);
  z-index: 100;
  transition: transform 0.05s linear;
  box-shadow: 0 0 12px rgba(61,90,241,0.5);
}

/* Hero-Vignette für mehr Tiefe */
.sale-hero-vignette {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.45) 110%);
  pointer-events: none;
}

/* Title-Char-Spans für Reveal-Animation */
.sale-hero-title {
  display: block;
  overflow: hidden;
  line-height: 1.05;
  padding-bottom: 0.05em;
}
.sale-hero-title .sale-ch {
  display: inline-block;
  white-space: pre;
}

/* Scroll-Hint — animated arrow */
.sale-hero-scroll-hint {
  position: absolute;
  bottom: -28px; left: 0; right: 0;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  pointer-events: none;
}
.sale-scroll-arrow {
  font-size: 16px;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 400;
}

/* Price-Bar Sticky-State (intensiviert bei is-stuck) */
.sale-price-bar {
  transition: box-shadow 0.3s ease, background 0.3s ease, padding 0.3s ease;
}
.sale-price-bar.is-stuck {
  box-shadow: 0 6px 24px rgba(0,0,0,0.45);
  background: rgba(13,13,13,0.92);
  padding: 16px 24px;
}
.sale-price-bar.is-stuck .sale-price-val {
  font-size: 28px;
  transition: font-size 0.3s ease;
}
.sale-price-val { transition: font-size 0.3s ease; }

/* Stat-Cell hover micro-motion */
.sale-stat {
  transition: background 0.25s ease;
}
.sale-stat:hover { background: var(--surface); }
.sale-stat-val[data-counter] { font-variant-numeric: tabular-nums; }

/* Spec-Row hover */
.sale-spec-row {
  transition: padding 0.18s, background 0.18s;
}
.sale-spec-row:hover { background: rgba(255,255,255,0.02); }

/* Service-Item hover lift */
.sale-svc-item {
  transition: padding 0.2s ease, background 0.2s ease;
}
.sale-svc-item:hover {
  background: rgba(255,255,255,0.025);
  padding-left: 8px; padding-right: 8px;
}

/* Mod-Item hover with subtle 3D lift */
.sale-mod-item {
  transition: transform 0.25s cubic-bezier(0.32,0.72,0,1), background 0.25s;
  border-radius: 4px;
}
.sale-mod-item:hover {
  background: rgba(255,255,255,0.025);
  transform: translateY(-2px);
}

/* Photo hover already set, plus mask-reveal init state */
.sale-photo {
  transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
}
.sale-photo:hover { transform: translateY(-3px); }

/* CTA hover with subtle scale */
.sale-cta {
  transition: all 0.18s cubic-bezier(0.32,0.72,0,1);
}
.sale-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(61,90,241,0.3); }
.sale-cta-secondary:hover { box-shadow: 0 8px 20px rgba(0,0,0,0.4); }

/* HERO */
.sale-hero {
  position: relative;
  height: 70vh; min-height: 460px; max-height: 720px;
  width: 100%;
  overflow: hidden;
}
.sale-hero-img {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  filter: brightness(0.78) contrast(1.05) saturate(0.95);
}
.sale-hero-img-empty {
  background: linear-gradient(135deg, var(--surface2) 0%, var(--surface) 100%);
}
.sale-hero-grad {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.30) 0%, transparent 30%, transparent 50%, rgba(0,0,0,0.85) 100%);
}
.sale-hero-chrome {
  position: absolute; top: 24px; left: 24px; right: 24px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.85);
}
.sale-chrome-l { display: flex; align-items: center; gap: 8px; }
.sale-chrome-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 10px var(--green);
}
.sale-hero-content {
  position: absolute; bottom: 38px; left: 24px; right: 24px;
}
.sale-hero-kicker {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.30em; text-transform: uppercase;
  color: rgba(255,255,255,0.75);
  margin-bottom: 12px;
}
.sale-hero-title {
  font-family: var(--cond); font-weight: 800;
  font-size: clamp(40px, 7vw, 64px); line-height: 0.95;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0;
}
.sale-hero-tagline {
  font-family: var(--body); font-size: 15px; line-height: 1.5;
  color: rgba(255,255,255,0.85);
  margin-top: 14px;
  max-width: 640px;
}

/* PRICE BAR */
.sale-price-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 24px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  gap: 16px; flex-wrap: wrap;
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.sale-price-label {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 4px;
}
.sale-price-val {
  font-family: var(--cond); font-weight: 800;
  font-size: 36px; line-height: 1; letter-spacing: -0.02em;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.sale-price-loc {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.06em; color: var(--txt3);
  margin-top: 6px;
}
.sale-cta-block {
  display: flex; gap: 10px;
}
.sale-cta {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 12px 22px;
  border-radius: 8px;
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.18s;
  white-space: nowrap;
}
.sale-cta-primary {
  background: var(--accent); color: #fff;
  border: 1px solid var(--accent);
}
.sale-cta-primary:hover {
  background: #2a45c0;
  transform: translateY(-1px);
}
.sale-cta-secondary {
  background: transparent; color: var(--txt);
  border: 1px solid var(--border2);
}
.sale-cta-secondary:hover { border-color: var(--txt3); }

/* KEY STATS */
.sale-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  margin: 0;
}
.sale-stat {
  background: var(--bg);
  padding: 24px 20px;
  text-align: center;
}
.sale-stat-label {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.20em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 8px;
}
.sale-stat-val {
  font-family: var(--cond); font-weight: 700;
  font-size: 22px; line-height: 1; letter-spacing: -0.005em;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
}
.sale-stat-val.sale-warn { color: var(--red); }
.sale-stat-val.sale-dim  { color: var(--txt3); font-weight: 500; }

@media (max-width: 600px) {
  .sale-stats { grid-template-columns: repeat(2, 1fr); }
  .sale-stat-val { font-size: 18px; }
}

/* SECTIONS */
.sale-section {
  max-width: 880px;
  margin: 0 auto;
  padding: 56px 24px;
  border-bottom: 1px solid var(--border);
}
.sale-section:last-of-type { border-bottom: none; }
.sale-section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 8px;
}
.sale-section-h {
  font-family: var(--cond); font-weight: 700;
  font-size: 28px; letter-spacing: -0.01em; line-height: 1;
  color: var(--txt);
  margin: 0 0 14px 0;
}
.sale-section-meta {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--txt3);
  font-variant-numeric: tabular-nums;
}
.sale-section-sub {
  font-family: var(--body); font-size: 14px; line-height: 1.5;
  color: var(--txt2);
  margin: 0 0 24px 0;
}
.sale-prose {
  font-family: var(--body); font-size: 15px; line-height: 1.6;
  color: var(--txt);
}

/* SPECS */
.sale-specs {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0;
  margin: 0;
}
.sale-spec-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.sale-spec-row dt {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt3);
}
.sale-spec-row dd {
  font-family: var(--body); font-size: 14px; font-weight: 500;
  color: var(--txt);
  text-align: right;
  font-variant-numeric: tabular-nums;
  margin-left: 12px;
}
@media (max-width: 600px) {
  .sale-specs { grid-template-columns: 1fr; }
}

/* SERVICE LIST */
.sale-svc-list, .sale-mod-list {
  list-style: none; padding: 0; margin: 0;
}
.sale-svc-item {
  display: grid;
  grid-template-columns: 110px 1fr auto;
  align-items: baseline;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
}
.sale-svc-item:last-child { border-bottom: none; }
.sale-svc-date {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.04em; color: var(--txt3);
  font-variant-numeric: tabular-nums;
}
.sale-svc-title {
  font-family: var(--cond); font-weight: 700; font-size: 17px;
  letter-spacing: -0.005em; color: var(--txt);
  line-height: 1.2;
}
.sale-svc-meta {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.10em; color: var(--txt3);
  margin-top: 4px;
}
.sale-svc-cost {
  font-family: var(--mono); font-size: 12px; font-weight: 600;
  color: var(--txt2);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}
.sale-svc-item .sale-svc-meta {
  grid-column: 2 / 3;
}
@media (max-width: 600px) {
  .sale-svc-item { grid-template-columns: 1fr auto; }
  .sale-svc-date { grid-column: 1 / -1; }
  .sale-svc-item .sale-svc-meta { grid-column: 1 / 2; }
}

/* MOD LIST */
.sale-mod-item {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
}
.sale-mod-item:last-child { border-bottom: none; }
.sale-mod-main { flex: 1; min-width: 0; }
.sale-mod-title {
  font-family: var(--cond); font-weight: 700; font-size: 19px;
  letter-spacing: -0.005em; color: var(--txt);
  line-height: 1.2;
}
.sale-mod-meta {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.10em; color: var(--txt3);
  margin-top: 4px;
}
.sale-mod-cost {
  font-family: var(--cond); font-weight: 700; font-size: 18px;
  color: var(--txt);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* PHOTO GALLERY */
.sale-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
@media (max-width: 600px) {
  .sale-gallery { grid-template-columns: repeat(2, 1fr); }
}
.sale-photo {
  aspect-ratio: 4 / 3;
  background: var(--surface);
  cursor: zoom-in;
  overflow: hidden;
  position: relative;
}
.sale-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1);
}
.sale-photo:hover img { transform: scale(1.04); }

/* CONTACT BOTTOM */
.sale-contact-bottom {
  background: var(--surface2);
  border-bottom: none;
  text-align: center;
}
.sale-contact-bottom .sale-section-h { margin-bottom: 12px; }
.sale-cta-bottom {
  justify-content: center;
  margin-top: 24px;
  flex-wrap: wrap;
}

/* FOOTER */
.sale-footer {
  display: flex; justify-content: space-between; align-items: center;
  max-width: 880px; margin: 0 auto;
  padding: 24px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--txt3);
}
.sale-footer-brand {
  font-family: var(--cond); font-weight: 700; font-size: 16px;
  font-style: italic; letter-spacing: 0;
  text-transform: none;
}
.sale-footer-brand .dim { color: var(--txt3); font-weight: 500; }
.sale-footer-brand .accent { color: var(--accent); }

/* ═══════════ FIRST-VEHICLE-WIZARD ═══════════ */
/* Editorial-Aesthetik wie Intro-Slides — Hairlines + Blueprint-Grid + soft Glow,
   keine Material-Design-Buntheit. */

.vw-overlay {
  position: fixed; inset: 0;
  z-index: 12000;
  background: var(--bg);
  opacity: 0;
  visibility: hidden;            /* CRITICAL: macht Element UND Children unklickbar */
  pointer-events: none;
  display: flex; flex-direction: column;
  isolation: isolate;
  transform: translateY(12px);   /* Slide-Up Entrance */
  /* visibility-Toggle erst NACH Fade-Out — sonst Snap statt Animation */
  transition: opacity 0.34s ease, transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), visibility 0s linear 0.34s;
}
.vw-overlay.vw-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity 0.34s ease, transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), visibility 0s linear 0s;
}

/* Atmosphärischer BG: Blueprint-Grid + EIN sehr soft blauer Glow (Intro-Style) */
.vw-bg {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: -1;
  overflow: hidden;
}
.vw-bg::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 0.18;
  mask-image: radial-gradient(ellipse 80% 90% at 30% 40%, black 20%, transparent 78%);
  -webkit-mask-image: radial-gradient(ellipse 80% 90% at 30% 40%, black 20%, transparent 78%);
}
.vw-bg::after {
  content: '';
  position: absolute; top: 6%; left: -18%; width: 70%; height: 90%;
  background: radial-gradient(ellipse, rgba(61,90,241,0.10) 0%, transparent 65%);
  pointer-events: none;
}

/* Top-Bar: Progress + Close — minimal, hairlines */
.vw-topbar {
  position: relative;
  z-index: 2;
  display: flex; align-items: center; gap: 14px;
  padding: max(env(safe-area-inset-top), 14px) 18px 14px;
}
.vw-progress {
  flex: 1;
  height: 1px;
  background: var(--border);
  position: relative;
  overflow: hidden;
}
.vw-progress-fill {
  position: absolute; top: 0; left: 0; height: 100%;
  background: var(--accent);
  transition: width 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.vw-close {
  background: transparent; border: 1px solid var(--border2);
  color: var(--txt2);
  font-family: var(--mono); font-size: 12px; line-height: 1;
  width: 32px; height: 32px; border-radius: var(--r);
  cursor: pointer; transition: color 0.18s, border-color 0.18s;
  display: inline-flex; align-items: center; justify-content: center;
}
.vw-close:hover { color: var(--txt); border-color: var(--txt2); }

/* Slide-Track horizontal scroll-locked */
.vw-track {
  flex: 1;
  position: relative;
  overflow: hidden;
}
.vw-slide {
  position: absolute; inset: 0;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 28px 24px 16px;
  overflow-y: auto;
  opacity: 0;
  pointer-events: none;
  transform: translateX(24px);
  transition: opacity 0.32s ease, transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
}
.vw-slide.vw-slide-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}
.vw-slide.vw-slide-leaving {
  transform: translateX(-24px);
}
.vw-slide-inner {
  width: 100%; max-width: 480px;
  display: flex; flex-direction: column; gap: 14px;
}

/* Typografie — wie Intro-Slides (bordered Tag-Pill, große Cond-Headline, body Sub) */
.vw-tag {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent); font-weight: 500;
  border: 1px solid rgba(61,90,241,0.3);
  padding: 5px 10px; border-radius: var(--r);
  display: inline-block; align-self: flex-start;
  margin-bottom: 22px;
}
.vw-h1 {
  font-family: var(--cond); font-weight: 800; line-height: 1;
  font-size: clamp(40px, 11vw, 64px);
  letter-spacing: -0.01em;
  color: var(--txt);
  margin: 0 0 22px;
  text-transform: none;
}
.vw-h1 .acc { color: var(--accent); }
.vw-sub {
  font-family: var(--body);
  font-size: 15px; color: var(--txt2); line-height: 1.7;
  max-width: 420px;
  margin: 0 0 28px;
}
.vw-sub strong { color: var(--txt); font-weight: 500; }

/* Path-Cards — Hairline statt Card, Editorial-Stil */
.vw-paths {
  display: flex; flex-direction: column; gap: 0;
  margin-top: 8px;
  border-top: 1px solid var(--border);
}
.vw-path-card {
  display: grid;
  grid-template-columns: 44px 1fr 14px;
  gap: 16px; align-items: center;
  padding: 18px 4px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  text-align: left;
  font: inherit; color: inherit;
  transition: padding 0.18s, opacity 0.18s;
  position: relative;
}
.vw-path-card::after {
  /* Chevron hint right side */
  content: '→';
  position: absolute; right: 4px; top: 50%; transform: translateY(-50%);
  color: var(--txt3); font-family: var(--mono); font-size: 14px;
  transition: transform 0.18s, color 0.18s;
}
.vw-path-card:hover {
  padding-left: 10px;
}
.vw-path-card:hover::after {
  color: var(--accent);
  transform: translate(4px, -50%);
}
.vw-path-card:active { opacity: 0.7; }
.vw-path-icon {
  display: flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  color: var(--txt2);
}
.vw-path-scan .vw-path-icon { color: var(--accent); }
.vw-path-text { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.vw-path-title {
  font-family: var(--cond); font-weight: 700; font-size: 18px;
  color: var(--txt); letter-spacing: -0.005em;
  line-height: 1.1;
}
.vw-path-sub {
  font-family: var(--body); font-size: 13px;
  color: var(--txt3); line-height: 1.45;
}
.vw-path-badge {
  display: inline-flex; align-items: center;
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
  margin-top: 4px;
  border: 1px solid rgba(61,90,241,0.3);
  padding: 3px 8px;
  border-radius: var(--r);
  align-self: flex-start;
}

/* Inputs — exakt wie patinaLog form-group Style überall sonst in der App */
.vw-input-group {
  display: flex; flex-direction: column; gap: 7px;
  margin-bottom: 18px;
}
.vw-label {
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--txt2);
}
.vw-input {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--border2);
  border-radius: 10px;
  color: var(--txt);
  font-family: var(--body); font-size: 14px;
  padding: 11px 14px;
  outline: none;
  transition: border-color 0.2s, background 0.2s;
}
.vw-input:focus {
  border-color: var(--accent);
  background: rgba(61,90,241,0.03);
}
.vw-input::placeholder { color: var(--txt3); }
.vw-input-large {
  /* Auf der Name-Slide: einziges Pflichtfeld → leicht prominenter, aber im
     gleichen System (bordered box, nicht headline-style). */
  font-size: 17px;
  padding: 14px 16px;
}

/* Photo-Area */
.vw-photo-area {
  display: flex; flex-direction: column; gap: 12px; align-items: stretch;
  margin: 8px 0 14px;
}
.vw-photo-preview {
  width: 100%;
  aspect-ratio: 16/10;
  border-radius: 10px;
  background: var(--bg);
  border: 1px solid var(--border2);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px;
  color: var(--txt3);
  overflow: hidden;
  position: relative;
}
.vw-photo-preview img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.vw-photo-empty .vw-photo-placeholder {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
}
.vw-secondary-btn {
  background: transparent;
  border: 1px solid var(--border2);
  color: var(--txt);
  padding: 10px 16px;
  border-radius: var(--r);
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  cursor: pointer;
  align-self: flex-start;
  transition: color 0.15s, border-color 0.15s;
}
.vw-secondary-btn:hover {
  color: var(--accent);
  border-color: rgba(61,90,241,0.55);
}

/* Scan-Review-Felder */
.vw-scan-fields {
  display: flex; flex-direction: column; gap: 10px;
  margin-top: 8px;
}
.vw-scan-field {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 12px; align-items: center;
}
.vw-scan-field-label {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--txt3);
}
.vw-scan-field-input {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 8px 10px;
  color: var(--txt);
  font-family: var(--body); font-size: 13px;
}

/* Success-Slide — editorial minimal, kein großer Ring */
.vw-slide-success { background: transparent; }
.vw-success-inner {
  align-items: flex-start;
}
.vw-success-mark {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent);
  border: 1px solid rgba(61,90,241,0.3);
  padding: 5px 10px;
  border-radius: var(--r);
  margin-bottom: 22px;
  animation: vw-success-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
}
.vw-success-mark svg { width: 12px; height: 12px; }
.vw-success-mark::after {
  content: 'Angelegt';
}
.vw-success-mark > svg + span { display: none; } /* fallback */
@keyframes vw-success-pop {
  from { transform: scale(0.6); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}
.vw-h1-success {
  animation: vw-success-text 0.5s 0.1s cubic-bezier(0.22, 1, 0.36, 1) backwards;
}
@keyframes vw-success-text {
  from { transform: translateY(8px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}

/* Footer Buttons — minimal, hairlines, kein Glow */
.vw-footer {
  position: relative;
  z-index: 2;
  display: flex; gap: 10px; align-items: center;
  padding: 14px 20px max(16px, env(safe-area-inset-bottom));
  border-top: 1px solid var(--border);
  background: var(--bg);
}
.vw-back-btn, .vw-skip-btn, .vw-next-btn {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, transform 0.1s, filter 0.15s;
}
.vw-back-btn {
  background: transparent; border: none;
  color: var(--txt3);
  padding: 11px 6px;
}
.vw-back-btn:hover { color: var(--txt) }
.vw-back-btn[hidden] { visibility: hidden; }
.vw-skip-btn {
  background: transparent;
  border: 1px solid var(--border2);
  color: var(--txt2);
  padding: 10px 14px; border-radius: var(--r);
  margin-left: auto;
}
.vw-skip-btn:hover {
  color: var(--txt);
  border-color: var(--txt2);
}
.vw-skip-btn[hidden] { display: none; }
.vw-next-btn {
  background: var(--accent); color: #fff;
  border: none; border-radius: var(--r);
  padding: 12px 22px;
  min-width: 130px;
}
.vw-next-btn:hover { filter: brightness(1.08); }
.vw-next-btn:active { transform: scale(0.97); }
.vw-next-btn:disabled {
  opacity: 0.4; cursor: not-allowed;
}
/* CTA-Pulse weg — Editorial-Stil bleibt sparsam */
.vw-next-btn.vw-success-cta { /* no animation */ }

/* Mobile Adjustments */
@media (max-width: 600px) {
  .vw-h1 { font-size: 32px; }
  .vw-slide-inner { gap: 12px; }
  .vw-input-large { font-size: 22px; padding: 16px 18px; }
  .vw-scan-field { grid-template-columns: 90px 1fr; gap: 8px; }
  .vw-success-mark { width: 80px; height: 80px; }
}

/* ═══════════ TEILEN-SHEET — Editorial Showcase + Utility ═══════════ */

.bs-share-section {
  display: flex; flex-direction: column;
  gap: 8px;
}
.bs-share-section.bs-share-utility { gap: 0; }

/* Featured-Card: Showroom & Insta — Preview + Text */
.bs-share-feature {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 14px; align-items: center;
  padding: 12px 14px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  text-align: left;
  font: inherit; color: inherit;
  width: 100%;
  transition: border-color 0.18s, transform 0.12s, background 0.18s;
}
.bs-share-feature:hover {
  border-color: rgba(61,90,241,0.5);
  background: rgba(61,90,241,0.04);
}
.bs-share-feature:active { transform: scale(0.99); }

.bs-share-feature-preview {
  width: 96px; height: 72px;
  border-radius: 8px;
  position: relative; overflow: hidden;
  background: linear-gradient(165deg, #1a1a1f 0%, #0f0f12 100%);
  border: 1px solid var(--border);
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}

/* Showroom-Preview: Watermark + Kicker — wie das echte Showroom */
.bs-share-preview-showroom {
  background: linear-gradient(165deg, rgba(61,90,241,0.18) 0%, rgba(15,15,18,0.95) 80%);
  align-items: flex-end; justify-content: flex-start;
  padding: 8px;
}
.bs-share-preview-watermark {
  position: absolute; right: -4px; bottom: -10px;
  font-family: var(--cond); font-weight: 900;
  font-size: 56px; line-height: 0.9;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.10);
  letter-spacing: -0.02em;
  pointer-events: none;
}
.bs-share-preview-content {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: 1px;
}
.bs-share-preview-kicker {
  font-family: var(--mono); font-size: 7px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent);
}
.bs-share-preview-title {
  font-family: var(--cond); font-weight: 800;
  font-size: 13px; color: var(--txt);
  letter-spacing: -0.005em;
}

/* Insta-Preview: 3 gestapelte Slide-Karten */
.bs-share-preview-insta {
  background: #08080a;
  position: relative;
}
.bs-share-preview-slide {
  position: absolute;
  width: 28px; height: 36px;
  border-radius: 4px;
  background: linear-gradient(165deg, #1f1f25 0%, #14141a 100%);
  border: 1px solid rgba(255,255,255,0.08);
}
.bs-share-preview-slide-1 {
  left: 50%; top: 50%;
  transform: translate(-58%, -50%) rotate(-6deg);
  background: linear-gradient(165deg, rgba(61,90,241,0.35) 0%, #1a1a1f 100%);
  z-index: 3;
}
.bs-share-preview-slide-2 {
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  background: linear-gradient(165deg, #25252b 0%, #14141a 100%);
  z-index: 2;
}
.bs-share-preview-slide-3 {
  left: 50%; top: 50%;
  transform: translate(-42%, -50%) rotate(6deg);
  background: linear-gradient(165deg, #2a2a30 0%, #18181d 100%);
  z-index: 1;
}
.bs-share-preview-fmt {
  position: absolute; bottom: 4px; right: 6px;
  font-family: var(--mono); font-size: 7px;
  letter-spacing: 0.1em;
  color: var(--txt3);
}

.bs-share-feature-text {
  display: flex; flex-direction: column; gap: 3px;
  min-width: 0;
}
.bs-share-feature-title {
  font-family: var(--cond); font-weight: 700; font-size: 16px;
  color: var(--txt); letter-spacing: -0.005em;
  display: flex; align-items: center; gap: 8px;
}
.bs-share-feature-sub {
  font-family: var(--body); font-size: 12px;
  color: var(--txt3); line-height: 1.45;
}

/* Trenner zwischen Showcase und Utility */
.bs-share-divider {
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--txt3);
  padding: 16px 14px 8px;
  display: flex; align-items: center; gap: 10px;
}
.bs-share-divider::after {
  content: ''; flex: 1;
  height: 1px; background: var(--border);
}

/* ── VIC Sub-Tab Carousel — horizontal slide zwischen Basis / Technik / Flüssigkeiten ── */
.vic-tab-viewport {
  position: relative;
  overflow: hidden;
  transition: height 0.42s cubic-bezier(0.32, 0.72, 0.16, 1);
}
.vic-tab-track {
  display: flex;
  width: 300%;
  /* CRITICAL: flex-start damit Slides ihre EIGENE Höhe behalten — sonst
     stretchen sie sich auf die Höhe des höchsten Slides (Default: stretch). */
  align-items: flex-start;
  transition: transform 0.42s cubic-bezier(0.32, 0.72, 0.16, 1);
  /* Vertical-Scroll bleibt frei, horizontaler Swipe via JS-Pointer-Events */
  touch-action: pan-y;
  cursor: grab;
}
.vic-tab-track:active { cursor: grabbing; }
.vic-tab-track[data-vic-active="basis"]   { transform: translateX(0%); }
.vic-tab-track[data-vic-active="technik"] { transform: translateX(-33.3333%); }
.vic-tab-track[data-vic-active="fluids"]  { transform: translateX(-66.6667%); }
.vic-tab-slide {
  flex: 0 0 33.3333%;
  min-width: 0;
  /* Kleinen Abstand zwischen Slides damit sie sich beim Sliden nicht berühren */
  padding: 0 2px;
}

/* ── VIC Tab Page-Indicator Dots ── */
.vic-tab-dots {
  display: flex; justify-content: center; gap: 6px;
  padding: 12px 0 4px;
}
.vic-tab-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: rgba(255,255,255,0.18);
  transition: background 0.32s, width 0.32s, transform 0.32s;
}
.vic-tab-dots[data-vic-active="basis"]   .vic-tab-dot[data-vdot="basis"],
.vic-tab-dots[data-vic-active="technik"] .vic-tab-dot[data-vdot="technik"],
.vic-tab-dots[data-vic-active="fluids"]  .vic-tab-dot[data-vdot="fluids"] {
  background: var(--accent);
  width: 18px;
  border-radius: 3px;
  box-shadow: 0 0 8px rgba(61,90,241,0.45);
}

/* ── Service-Tab Empty-State: Template-Picker mit handgepickten Routinen ── */
.svc-empty { padding: 8px 0 24px; }
.svc-empty-head { padding: 0 4px 18px; }
.svc-empty-title {
  font-family: var(--cond); font-weight: 700; font-size: 22px;
  letter-spacing: -0.01em; color: var(--txt); margin: 0 0 8px;
}
.svc-empty-text {
  font-family: var(--mono); font-size: 11px; line-height: 1.55;
  letter-spacing: 0.02em; color: var(--txt2); margin: 0;
}
.svc-empty-templates {
  display: flex; flex-direction: column; gap: 8px;
}
.svc-tpl-card {
  display: flex; align-items: center; gap: 14px;
  width: 100%; padding: 16px 18px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 12px; cursor: pointer;
  transition: border-color .15s, background .15s, transform .12s;
  text-align: left;
}
.svc-tpl-card:hover {
  background: rgba(255,255,255,0.04);
  border-color: var(--border2);
}
.svc-tpl-card:active { transform: scale(0.99); }
.svc-tpl-text { flex: 1; min-width: 0; }
.svc-tpl-group {
  font-family: var(--mono); font-size: 9.5px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--txt3); margin-bottom: 3px;
}
.svc-tpl-label {
  font-family: var(--cond); font-weight: 600; font-size: 17px;
  color: var(--txt); letter-spacing: -0.005em;
  line-height: 1.15;
}
.svc-tpl-chev {
  font-family: var(--cond); font-weight: 300; font-size: 22px;
  color: var(--txt3); flex-shrink: 0; line-height: 1;
}
.svc-empty-custom {
  display: block; width: 100%; margin: 18px 0 0;
  padding: 12px; background: none;
  border: 1px dashed var(--border2); border-radius: 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--txt2); cursor: pointer;
  transition: border-color .15s, color .15s;
}
.svc-empty-custom:hover { border-color: var(--accent); color: var(--accent); }

/* Hint-Banner für Modal-Header (Klärung von Konzepten direkt im Form) */
.form-hint-info {
  margin: 0 0 16px;
  padding: 10px 12px;
  background: rgba(61, 90, 241, 0.06);
  border: 1px solid rgba(61, 90, 241, 0.18);
  border-radius: 8px;
  font-family: var(--mono); font-size: 11px; line-height: 1.55;
  letter-spacing: 0.02em; color: var(--txt2);
}
.form-hint-info b { color: var(--accent); font-weight: 600; }
.form-hint-sub {
  margin: -4px 0 12px;
  padding: 0;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--txt3); line-height: 1.5;
}
