@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;450;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');
/* Mega-Welle §W (22.05.2026): Components-Bridge (Multi-Selektoren auf alte
   Page-Hub-Klassen). ADDITIV — alte Klassennamen bleiben, Bridge harmonisiert
   nur Farben/Radien/Größen. Wird via @import in JEDE Page übernommen, die
   prova-design.css lädt. */
@import url('lib/prova-components.css');

/* ═══════════════════════════════════════════════════════════════════
   PROVA DESIGN SYSTEM v2.0 — MEGA⁹³ Konsolidierung (2026-05-21)
   ═══════════════════════════════════════════════════════════════════
   ÄNDERUNGEN ggü. v1.0:
   - EINE Schrift: Inter (450/500/600/700/800), JetBrains Mono für §§/Zahlen.
     DM Sans entfernt.
   - Light-Tokens als :root-Basis (heller Hintergrund, dunkler Text — beste
     Lesbarkeit für Zielgruppe 50–60).
   - Dark-Tokens als [data-theme="dark"]-Override.
   - Theme-System via lib/prova-theme.js (data-theme="hell|dunkel|empfohlen").
   - Lesbarkeits-Tuning: Fließtext 16px / line-height 1.6 / weight 450,
     Labels 500–600.
   - Bestehende v1.0-Dark-Werte erhalten (keine Regression in Dark-Mode).
   ═══════════════════════════════════════════════════════════════════ */

/* ── TOKENS — LIGHT-DEFAULT ── */
:root {
  --font-ui: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;

  /* Hintergrund-Ebenen (Light: heller = unten, leicht abgesetzt = oben) */
  --bg:        #f8fafc;                /* Body */
  --bg2:       #ffffff;                /* Topbar/Sidebar */
  --bg3:       #f1f5f9;                /* 2. Ebene (Panel-Innenseite) */
  --bg-elev:   #ffffff;                /* Alias */

  /* Oberflächen (Karten + Inputs heller als bg) */
  --surface:   #ffffff;                /* Karten-Standard */
  --surface2:  #f8fafc;                /* Inputs, Sub-Cards */
  --surface3:  #eef2f7;                /* Hover/Focus-Surface */

  /* Borders — WCAG-konformer Kontrast auf hellem Hintergrund */
  --border:    #e2e8f0;
  --border2:   #cbd5e1;
  --border-focus: #1a3a6b;             /* PROVA-Primary fürs Focus-Ring */

  /* ── MEGA⁹⁵ Struktur-Tokens (theme-aware) ──
     Hairlines / Hover / Active / Scrollbar — Werte greifen auf bg/surface,
     müssen daher pro Theme invertieren. Vorher waren das hartcodierte
     rgba(255,255,255,...) → im Light-Modus unsichtbar. */
  --hairline:        rgba(15,23,42,.08);   /* Trennlinien, Divider, Scrollbar-Track */
  --hairline-strong: rgba(15,23,42,.14);   /* Stärkere Ränder */
  --hover-bg:        rgba(15,23,42,.04);   /* Hover-Flächen auf bg/surface */
  --active-bg:       rgba(26,58,107,.08);  /* Aktiver Nav-/Tab-Eintrag (Primary-Tönung) */
  --scrollbar-thumb: rgba(15,23,42,.18);   /* Scrollbar-Thumb */

  /* Text — Kontrast Pass (Light): AAA-nah für Fließtext, AA+ für Sekundär */
  --text:           #0f172a;           /* Fließtext, 19.3:1 auf #f8fafc — AAA */
  --text2:          #1e293b;           /* Labels primär, 15.7:1 — AAA */
  --text3:          #475569;           /* Sekundärtext, 7.4:1 — AAA Large/AA */
  --muted:          #64748b;           /* Meta/Pill-Text, 5.1:1 — AA */
  --text-disabled:  #94a3b8;           /* Disabled-States */
  --text-on-accent: #ffffff;           /* Button-Text auf Akzent */

  /* Akzent-Farben (konsistent zu IHK-Goldstandard-Templates F-09 / F-15) */
  --primary:   #1a3a6b;                /* PROVA-Primärblau */
  --accent:    #3b82f6;
  --accent2:   #1a3a6b;
  --success:   #059669;
  --warning:   #d97706;
  --danger:    #dc2626;
  --purple:    #7c3aed;

  /* Radii */
  --r-xs: 4px;  --r-sm: 6px;  --r-md: 10px;
  --r-lg: 14px; --r-xl: 18px; --r-2xl: 24px;

  /* Schatten — für hellen Hintergrund kalibriert (Stripe/Vercel-Style) */
  --shadow-xs: 0 1px 2px rgba(15,23,42,.06);
  --shadow-sm: 0 2px 6px rgba(15,23,42,.08);
  --shadow-md: 0 4px 14px rgba(15,23,42,.10);
  --shadow-lg: 0 12px 32px rgba(15,23,42,.14);
  --shadow-xl: 0 20px 48px rgba(15,23,42,.18);
  --shadow-glow: 0 0 0 3px rgba(59,130,246,.18);

  /* Übergänge */
  --ease: cubic-bezier(.25,.46,.45,.94);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --t-fast: .1s var(--ease);
  --t-base: .18s var(--ease);
  --t-slow: .3s var(--ease);

  /* RGB-Varianten für rgba()-Nutzung (für Tokens, die Alpha brauchen) */
  --accent-rgb: 59,130,246;
  --primary-rgb: 26,58,107;
  --danger-rgb: 220,38,38;
  --success-rgb: 5,150,105;
  --warning-rgb: 217,119,6;
  --purple-rgb: 124,58,237;

  /* Content-Padding */
  --content-pad-x: 24px;
  --content-pad-y: 20px;

  /* Lesbarkeits-Tuning (Zielgruppe 50–60) */
  --fs-body: 16px;
  --lh-body: 1.6;
  --fw-body: 450;
  --fw-label: 600;
}

/* ── DARK-OVERRIDE ── aktiviert via <html data-theme="dark"> (prova-theme.js) */
[data-theme="dark"] {
  /* Hintergrund-Ebenen (Dark: war v1.0 :root) */
  --bg:        #0b0d11;
  --bg2:       #111318;
  --bg3:       #161a22;
  --bg-elev:   #111318;

  --surface:   #1c2130;
  --surface2:  #232a3a;
  --surface3:  #2a3142;

  --border:    rgba(255,255,255,0.10);
  --border2:   rgba(255,255,255,0.16);
  --border-focus: #4f8ef7;

  /* MEGA⁹⁵ Struktur-Tokens — Dark-Werte (entspricht der bisherigen Praxis) */
  --hairline:        rgba(255,255,255,.08);
  --hairline-strong: rgba(255,255,255,.16);
  --hover-bg:        rgba(255,255,255,.06);
  --active-bg:       rgba(79,142,247,.12);
  --scrollbar-thumb: rgba(255,255,255,.18);

  /* Text — Dark (war v1.0 mit MEGA⁷⁰ Phase 1.1 Kontrast-Fix) */
  --text:           #eaecf4;           /* 16.49:1 */
  --text2:          #c1c9dd;           /* MEGA⁹³ heller (war #a3abc2) — 11.4:1 AAA */
  --text3:          #a3abc2;           /* MEGA⁹³ heller (war #8b93ab) — 8.7:1 AAA */
  --muted:          #8b93ab;           /* 6.4:1 AAA Large / AA */
  --text-disabled:  #5a6278;
  --text-on-accent: #ffffff;

  /* Akzent — Dark-spezifisch (heller, lebendiger) */
  --primary:   #4f8ef7;
  --accent:    #4f8ef7;
  --accent2:   #3a7be0;
  --success:   #10b981;
  --warning:   #f59e0b;
  --danger:    #ef4444;
  --purple:    #8b5cf6;

  /* Schatten — für dunklen Hintergrund kalibriert */
  --shadow-xs: 0 1px 2px rgba(0,0,0,.3);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.4);
  --shadow-md: 0 4px 16px rgba(0,0,0,.5);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.6);
  --shadow-xl: 0 20px 60px rgba(0,0,0,.7);
  --shadow-glow: 0 0 20px rgba(79,142,247,.18);

  --accent-rgb: 79,142,247;
  --primary-rgb: 79,142,247;
}

/* ── MANUS MARINE ── DEFAULT für App-Shell-Seiten ─────────────────────
   Spec §0.3 (Manus-Pixel-Spec, 2026-05-22): Marine ist sichtbarer
   Standard der App-Seiten (akte, archiv, fachurteil, dashboard,
   Phasen-Screens), NICHT optional. „Hell" + „Dunkel" bleiben wählbar.
   prova-theme.js mappt mode='empfohlen' → data-theme="empfohlen" und
   ist Default beim ersten Login.
   Werte sind 1:1 aus §0.3 übernommen — keine Interpretation. */
[data-theme="empfohlen"] {
  /* Hintergrund-Ebenen */
  --bg:        #0d141e;
  --bg-deep:   #0a0e19;
  --bg2:       #161e2b;
  --bg3:       #1b2531;
  --bg-elev:   #1d2733;

  /* Oberflächen — gestaffelt für Karte → Karte-in-Karte */
  --surface:        #161e2b;
  --surface-raised: #1d2733;   /* Karte-in-Karte, Aufgaben-Items, Toolbar */
  --surface-raised-2:#1b2531;  /* alt erhöht (Hover, Chips) */
  --surface2:       #1b2531;   /* Alias für Bestandscode */
  --surface3:       #1d2733;   /* Alias für Bestandscode */

  /* Borders + Hairlines */
  --border:           rgba(255,255,255,.06);
  --border2:          rgba(255,255,255,.10);
  --border-focus:     #5aa0ff;
  --hairline:         rgba(255,255,255,.06);
  --hairline-strong:  rgba(255,255,255,.10);
  --hairline-stronger:rgba(255,255,255,.14);

  /* Text-Stufen */
  --text:           #eef2f7;
  --text2:          #c4d0de;
  --text2-muted:    #9fb0c4;
  --text3:          #7e8ea4;
  --text3-faint:    #5b6b80;
  --muted:          #7e8ea4;   /* Alias für Bestandscode */
  --text-disabled:  #5b6b80;
  --text-on-accent: #ffffff;

  /* Akzent */
  --primary:        #3b82f6;
  --accent:         #3b82f6;
  --accent-soft:    #5aa0ff;
  --accent-softer:  #7db0ff;
  --accent2:        #2c6bd1;

  /* Status-Farben — Konvention §0.4: codiert STATUS, nicht Kategorie */
  --success:        #10b981;
  --success-bright: #3dd2a0;
  --warning:        #e8a838;
  --danger:         #e05d50;
  --purple:         #8b5cf6;

  /* Schatten — Schwebende Fenster Spec §0.6: 0 16px 48px rgba(0,0,0,.55) */
  --shadow-xs: 0 1px 2px rgba(0,0,0,.22);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.28);
  --shadow-md: 0 4px 16px rgba(0,0,0,.36);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.45);
  --shadow-xl: 0 16px 48px rgba(0,0,0,.55);
  --shadow-glow: 0 0 18px rgba(91,160,255,.18);

  --accent-rgb: 59,130,246;
  --primary-rgb: 59,130,246;
  --success-rgb: 16,185,129;
  --warning-rgb: 232,168,56;
  --danger-rgb: 224,93,80;

  /* Interaktion */
  --hover-bg:        rgba(255,255,255,.04);
  --active-bg:       rgba(91,160,255,.10);
  --scrollbar-thumb: rgba(255,255,255,.14);
}

/* ── BASIS-LESBARKEIT (greift global, beide Modi) ── */
body {
  font-family: var(--font-ui);
  font-size: var(--fs-body);
  font-weight: var(--fw-body);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--bg);
}
label, .label, th, dt, .ak-section-label {
  font-weight: var(--fw-label);
}

/* ═══════════════════════════════════════════════════════════════════
   BASIS-LAYER — nur für Seiten, die keine eigenen Werte setzen
   (body/sidebar/main/.card als Defaults, niedrige Spezifizität,
    damit page-spezifische Styles problemlos überschreiben können)
   ═══════════════════════════════════════════════════════════════════ */
body {
  font-family: var(--font-ui);
  background: var(--bg);
  color: var(--text);
}

/* Globale Karten-Regel — überschreibt alte weiße .card-Styles, außer
   wenn eine Page-spezifische Regel mit höherer Spezifizität greift.
   KEIN !important — Pages mit bewusstem Override bleiben intakt. */
.card {
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  transition: border-color var(--t-base), box-shadow var(--t-base);
}
.card:hover { border-color: var(--border2); }

/* Card-Header (z.B. in baubegleitung): dunkel statt dunkelblau-Sonderton */
.card-header {
  background: var(--bg3);
  color: var(--text);
  padding: 16px 22px;
}
.card-body {
  background: var(--surface);
  color: var(--text);
  padding: 20px 22px;
}

/* ═══════════════════════════════════════════════════════════════════
   LAYOUT — gleichmäßige Abstände zur Sidebar (Fix #9)
   Standard-Padding für alle Haupt-Content-Container. Seiten können
   mit höherer Spezifizität überschreiben, der Default ist konsistent.
   Tokens: --content-pad-x (24px), --content-pad-y (20px)
   ═══════════════════════════════════════════════════════════════════ */
.main,
.main-wrap,
.main-content,
.doku-wrap,
.page-content {
  padding: var(--content-pad-y) var(--content-pad-x) calc(var(--content-pad-y) * 3);
  min-width: 0;  /* Flex-Kind darf schrumpfen — Overflow-Bug verhindern */
}

/* Mobile: knappere Abstände, extra Bottom für Safe-Area */
@media (max-width: 768px) {
  .main,
  .main-wrap,
  .main-content,
  .doku-wrap,
  .page-content {
    padding: 12px 14px calc(72px + env(safe-area-inset-bottom, 0px));
  }
}

/* ═══════════════════════════════════════════════════════════
   TYPOGRAFIE
   ═══════════════════════════════════════════════════════════ */
body { font-family: var(--font-ui); }

.p-page-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--text, #eaecf4);
  letter-spacing: -.02em;
  line-height: 1.2;
}
.p-page-sub {
  font-size: 12px;
  color: var(--text3, rgba(255,255,255,.6));
  margin-top: 3px;
  line-height: 1.4;
}
.p-section-label {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text2, rgba(255,255,255,.72));
}
.p-mono {
  font-family: var(--font-mono);
  font-size: .9em;
}

/* ═══════════════════════════════════════════════════════════
   KARTEN — Das zentrale Layout-Element
   ═══════════════════════════════════════════════════════════ */
.p-card {
  background: var(--surface, #161b2e);
  border: 1px solid var(--border, rgba(255,255,255,.07));
  border-radius: var(--r-xl);
  padding: 16px;
  transition: border-color var(--t-base), transform var(--t-base), box-shadow var(--t-base);
  position: relative;
  overflow: hidden;
}
/* Shimmer-Linie oben — MEGA⁹⁵: theme-aware (im Light-Modus war white-rgba unsichtbar) */
.p-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--hairline, rgba(15,23,42,.08)), transparent);
  pointer-events: none;
}
.p-card:hover {
  border-color: rgba(var(--accent-rgb), .25);
  box-shadow: var(--shadow-md);
}
.p-card-clickable {
  cursor: pointer;
}
.p-card-clickable:hover {
  transform: translateY(-2px);
  border-color: rgba(var(--accent-rgb), .3);
  box-shadow: 0 8px 28px rgba(0,0,0,.4), 0 0 0 1px rgba(var(--accent-rgb), .08);
}
.p-card-clickable:active {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.p-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border, rgba(255,255,255,.07));
}
.p-card-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text, #eaecf4);
}
.p-card-sub {
  font-size: 11px;
  color: var(--text3, rgba(255,255,255,.4));
  margin-top: 2px;
}
.p-card-body { }

/* ═══════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════ */

/* Basis */
.p-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 18px;
  border-radius: var(--r-lg);
  border: none;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  font-family: var(--font-ui);
  transition: all var(--t-fast);
  text-decoration: none;
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}
.p-btn:active { transform: scale(.97); }
.p-btn:disabled { opacity: .45; cursor: not-allowed; transform: none !important; box-shadow: none !important; }

/* Primär — Blau */
.p-btn-primary {
  background: var(--accent, #4f8ef7);
  color: #fff;
}
.p-btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.12), transparent);
  pointer-events: none;
}
.p-btn-primary:hover { background: #3a7ef0; box-shadow: 0 4px 16px rgba(var(--accent-rgb),.4); transform: translateY(-1px); }

/* KI — Lila */
.p-btn-ki {
  background: linear-gradient(135deg, #5b48f0, #8b5cf6);
  color: #fff;
}
.p-btn-ki::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.15), transparent);
  pointer-events: none;
}
.p-btn-ki:hover { filter: brightness(1.1); box-shadow: 0 4px 18px rgba(var(--purple-rgb),.45); transform: translateY(-1px); }

/* Erfolg — Grün */
.p-btn-success {
  background: linear-gradient(135deg, #10b981, #059669);
  color: #fff;
}
.p-btn-success:hover { box-shadow: 0 4px 16px rgba(var(--success-rgb),.4); transform: translateY(-1px); }

/* Gefahr — Rot */
.p-btn-danger {
  background: transparent;
  color: #ef4444;
  border: 1px solid rgba(var(--danger-rgb),.3);
}
.p-btn-danger:hover { background: rgba(var(--danger-rgb),.08); border-color: rgba(var(--danger-rgb),.5); }

/* Sekundär — Neutral */
.p-btn-secondary {
  background: var(--surface2, rgba(255,255,255,.06));
  color: var(--text2, rgba(255,255,255,.7));
  border: 1px solid var(--border2, rgba(255,255,255,.1));
}
.p-btn-secondary:hover { background: var(--surface3, rgba(255,255,255,.09)); color: var(--text); }

/* Ghost */
.p-btn-ghost {
  background: transparent;
  color: var(--text3);
  border: 1px solid transparent;
}
.p-btn-ghost:hover { background: var(--surface2); color: var(--text); }

/* Sizes */
.p-btn-sm { padding: 5px 12px; font-size: 12px; border-radius: var(--r-md); }
.p-btn-lg { padding: 12px 24px; font-size: 14px; border-radius: var(--r-xl); }
.p-btn-full { width: 100%; }

/* Loading State */
.p-btn.loading {
  pointer-events: none;
  opacity: .75;
}
.p-btn.loading::after {
  content: '';
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: p-spin .65s linear infinite;
  margin-left: 4px;
}
@keyframes p-spin { to { transform: rotate(360deg); } }

/* ═══════════════════════════════════════════════════════════
   INPUTS
   ═══════════════════════════════════════════════════════════ */
.p-input, .p-select, .p-textarea {
  width: 100%;
  padding: 9px 12px;
  background: var(--surface2, rgba(255,255,255,.05));
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: var(--r-lg);
  color: var(--text, #eaecf4);
  font-size: 13px;
  font-family: var(--font-ui);
  outline: none;
  transition: border-color var(--t-base), box-shadow var(--t-base);
  box-sizing: border-box;
}
.p-input:focus, .p-select:focus, .p-textarea:focus {
  border-color: var(--accent, #4f8ef7);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), .12);
}
.p-input::placeholder, .p-textarea::placeholder { color: var(--text3); }
.p-textarea { min-height: 100px; resize: vertical; line-height: 1.6; }
.p-select { cursor: pointer; }

.p-form-group { margin-bottom: 14px; }
.p-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text2, rgba(255,255,255,.72));
  margin-bottom: 5px;
}
.p-input-hint {
  font-size: 11px;
  color: var(--text3);
  margin-top: 4px;
}
.p-input-hint.success { color: #10b981; }
.p-input-hint.error   { color: #ef4444; }

/* Input mit Icon */
.p-input-wrap { position: relative; }
.p-input-wrap .p-input { padding-left: 36px; }
.p-input-icon {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text3);
  font-size: 14px;
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════
   BADGES & STATUS CHIPS
   ═══════════════════════════════════════════════════════════ */
.p-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
.p-badge-blue    { background: rgba(var(--accent-rgb),.12);  color: #4f8ef7; border: 1px solid rgba(var(--accent-rgb),.2); }
.p-badge-green   { background: rgba(var(--success-rgb),.12); color: #10b981; border: 1px solid rgba(var(--success-rgb),.2); }
.p-badge-red     { background: rgba(var(--danger-rgb),.12);  color: #ef4444; border: 1px solid rgba(var(--danger-rgb),.2); }
.p-badge-orange  { background: rgba(var(--warning-rgb),.12); color: #f59e0b; border: 1px solid rgba(var(--warning-rgb),.2); }
.p-badge-purple  { background: rgba(var(--purple-rgb),.12);  color: #8b5cf6; border: 1px solid rgba(var(--purple-rgb),.2); }
.p-badge-neutral { background: var(--hover-bg, rgba(15,23,42,.04)); color: var(--text3); border: 1px solid var(--border2); }

/* Dot davor */
.p-badge-dot::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   FILTER CHIPS
   ═══════════════════════════════════════════════════════════ */
.p-chips {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.p-chip {
  padding: 5px 13px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  background: var(--surface2);
  border: 1px solid var(--border);
  color: var(--text3);
  cursor: pointer;
  transition: all var(--t-base);
  font-family: var(--font-ui);
  white-space: nowrap;
}
.p-chip:hover { border-color: var(--accent); color: var(--accent); }
.p-chip.active, .p-chip.act {
  background: rgba(var(--accent-rgb), .12);
  border-color: rgba(var(--accent-rgb), .35);
  color: var(--accent, #4f8ef7);
}

/* ═══════════════════════════════════════════════════════════
   LISTEN-ITEMS
   ═══════════════════════════════════════════════════════════ */
.p-list-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  background: var(--surface);
  transition: all var(--t-base);
  cursor: pointer;
}
.p-list-item:hover {
  border-color: rgba(var(--accent-rgb), .3);
  background: rgba(var(--accent-rgb), .04);
}
.p-list-item + .p-list-item { margin-top: 6px; }

/* ═══════════════════════════════════════════════════════════
   EMPTY STATES
   ═══════════════════════════════════════════════════════════ */
.p-empty {
  text-align: center;
  padding: 48px 24px;
}
.p-empty-icon {
  font-size: 38px;
  margin-bottom: 14px;
  opacity: .35;
  display: block;
}
.p-empty-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 7px;
}
.p-empty-sub {
  font-size: 12px;
  color: var(--text3);
  line-height: 1.6;
  margin-bottom: 20px;
}

/* ═══════════════════════════════════════════════════════════
   TOAST NOTIFICATIONS
   ═══════════════════════════════════════════════════════════ */
.p-toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  background: var(--bg2, #1c2130);
  border: 1px solid var(--border2);
  border-radius: var(--r-lg);
  padding: 10px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  box-shadow: var(--shadow-lg);
  z-index: 9999;
  opacity: 0;
  transition: all .25s var(--ease);
  pointer-events: none;
  white-space: nowrap;
  font-family: var(--font-ui);
}
.p-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.p-toast.success { border-color: rgba(var(--success-rgb),.4); color: #10b981; }
.p-toast.error   { border-color: rgba(var(--danger-rgb),.4);  color: #ef4444; }
.p-toast.warning { border-color: rgba(var(--warning-rgb),.4); color: #f59e0b; }

/* ═══════════════════════════════════════════════════════════
   MODALS — Bottom Sheet auf Mobile, zentriert auf Desktop
   ═══════════════════════════════════════════════════════════ */
.p-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-slow);
}
.p-modal-overlay.show { opacity: 1; pointer-events: all; }
.p-modal {
  background: var(--bg2, #111827);
  border: 1px solid var(--border2);
  border-radius: var(--r-xl);
  width: 100%;
  max-width: 480px;
  max-height: 85vh;
  overflow-y: auto;
  box-shadow: var(--shadow-xl);
  transform: scale(.96) translateY(8px);
  transition: transform var(--t-slow);
}
.p-modal-overlay.show .p-modal { transform: scale(1) translateY(0); }
.p-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--border);
}
.p-modal-title { font-size: 15px; font-weight: 800; color: var(--text); }
.p-modal-close {
  width: 30px; height: 30px;
  border-radius: var(--r-md);
  border: none;
  background: var(--surface2);
  color: var(--text3);
  font-size: 16px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all var(--t-fast);
  flex-shrink: 0;
}
.p-modal-close:hover { background: var(--surface3, rgba(255,255,255,.1)); color: var(--text); }
.p-modal-body { padding: 16px 20px; }
.p-modal-footer {
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 8px;
}

/* ═══════════════════════════════════════════════════════════
   DATENTABELLEN
   ═══════════════════════════════════════════════════════════ */
.p-table { width: 100%; border-collapse: collapse; }
.p-table th {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text3);
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
  text-align: left;
}
.p-table td {
  padding: 10px 12px;
  font-size: 13px;
  color: var(--text2);
  border-bottom: 1px solid var(--hairline, rgba(15,23,42,.08));
}
.p-table tr:hover td { background: var(--hover-bg, rgba(15,23,42,.04)); }
.p-table tr:last-child td { border-bottom: none; }

/* ═══════════════════════════════════════════════════════════
   SECTION HEADERS
   ═══════════════════════════════════════════════════════════ */
.p-section {
  margin-bottom: 24px;
}
.p-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.p-section-bar {
  width: 3px;
  height: 16px;
  border-radius: 2px;
  background: var(--accent, #4f8ef7);
  flex-shrink: 0;
}
.p-section-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}
.p-section-actions { margin-left: auto; display: flex; gap: 6px; }

/* ═══════════════════════════════════════════════════════════
   KPI KARTEN
   ═══════════════════════════════════════════════════════════ */
.p-kpi {
  background: var(--surface, #161b2e);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 16px;
  cursor: pointer;
  transition: all var(--t-base);
}
.p-kpi:hover { border-color: rgba(var(--accent-rgb),.2); box-shadow: var(--shadow-sm); }
.p-kpi-label {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text3);
  margin-bottom: 8px;
}
.p-kpi-value {
  font-size: 28px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.03em;
  line-height: 1;
  margin-bottom: 4px;
}
.p-kpi-sub { font-size: 11px; color: var(--text3); }

/* ═══════════════════════════════════════════════════════════
   STEP PROGRESS
   ═══════════════════════════════════════════════════════════ */
.p-steps {
  display: flex;
  align-items: center;
  gap: 4px;
  overflow-x: auto;
}
.p-step {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text3);
  white-space: nowrap;
}
.p-step-num {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--surface2);
  border: 1px solid var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  flex-shrink: 0;
  transition: all var(--t-base);
}
.p-step.active .p-step-num { background: var(--accent); border-color: var(--accent); color: #fff; }
.p-step.done .p-step-num   { background: #10b981; border-color: #10b981; color: #fff; }
.p-step.active { color: var(--text); }
.p-step.done   { color: #10b981; }
.p-step-sep { flex: 1; height: 1px; background: var(--border); min-width: 12px; }

/* ═══════════════════════════════════════════════════════════
   SUCHFELD — Standard
   ═══════════════════════════════════════════════════════════ */
.p-search-wrap { position: relative; }
.p-search {
  width: 100%;
  padding: 10px 14px 10px 38px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  font-size: 13px;
  color: var(--text);
  font-family: var(--font-ui);
  outline: none;
  transition: border-color var(--t-base), box-shadow var(--t-base);
  box-sizing: border-box;
}
.p-search:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(var(--accent-rgb),.12); }
.p-search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text3);
  font-size: 14px;
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════
   SEITENHEADER — Einheitlich für alle Seiten
   ═══════════════════════════════════════════════════════════ */
.p-header {
  padding: 20px 24px 14px;
  flex-shrink: 0;
}
.p-header-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}
.p-header-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   INLINE-FEEDBACK (Autosave, Status)
   ═══════════════════════════════════════════════════════════ */
.p-autosave {
  font-size: 11px;
  color: #10b981;
  opacity: 0;
  transition: opacity .4s;
  font-weight: 600;
}
.p-autosave.show { opacity: 1; }

.p-char-count { font-size: 11px; color: var(--text3); margin-top: 4px; }
.p-char-count.ok   { color: #10b981; }
.p-char-count.warn { color: #f59e0b; }
.p-char-count.bad  { color: #ef4444; }

/* ═══════════════════════════════════════════════════════════
   DIVIDER
   ═══════════════════════════════════════════════════════════ */
.p-divider {
  height: 1px;
  background: var(--border, rgba(255,255,255,.07));
  margin: 16px 0;
}

/* ═══════════════════════════════════════════════════════════
   AKKORDEON / COLLAPSED SECTIONS
   ═══════════════════════════════════════════════════════════ */
.p-accordion {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.p-accordion + .p-accordion { margin-top: 6px; }
.p-accordion-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  cursor: pointer;
  background: var(--surface);
  transition: background var(--t-fast);
}
.p-accordion-head:hover { background: var(--surface2); }
.p-accordion-title { font-size: 13px; font-weight: 700; color: var(--text); }
.p-accordion-toggle {
  font-size: 12px;
  color: var(--text3);
  transition: transform var(--t-base);
  flex-shrink: 0;
}
.p-accordion.open .p-accordion-toggle { transform: rotate(180deg); }
.p-accordion-body {
  padding: 14px 16px;
  border-top: 1px solid var(--border);
  display: none;
}
.p-accordion.open .p-accordion-body { display: block; }

/* ═══════════════════════════════════════════════════════════
   PROGRESS BAR
   ═══════════════════════════════════════════════════════════ */
.p-progress-wrap {
  height: 6px;
  background: var(--surface2);
  border-radius: 3px;
  overflow: hidden;
}
.p-progress-bar {
  height: 100%;
  border-radius: 3px;
  background: var(--accent, #4f8ef7);
  transition: width .6s var(--ease);
}
.p-progress-bar.success { background: #10b981; }
.p-progress-bar.danger  { background: #ef4444; }
.p-progress-bar.warning { background: #f59e0b; }

/* ═══════════════════════════════════════════════════════════
   TOOLTIPS (data-tip Attribut → nav.js injiziert)
   ═══════════════════════════════════════════════════════════ */
.p-help {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: var(--hover-bg, rgba(15,23,42,.04));
  border: 1px solid var(--hairline-strong, rgba(15,23,42,.14));
  color: var(--text3);
  font-size: 9px;
  font-weight: 800;
  cursor: help;
  margin-left: 5px;
  vertical-align: middle;
  flex-shrink: 0;
  transition: all var(--t-fast);
}
.p-help:hover {
  background: rgba(var(--accent-rgb),.15);
  border-color: rgba(var(--accent-rgb),.4);
  color: var(--accent, #4f8ef7);
}

/* ═══════════════════════════════════════════════════════════
   LOADING SKELETON
   ═══════════════════════════════════════════════════════════ */
.p-skeleton {
  background: linear-gradient(90deg,
    var(--surface2) 25%,
    var(--surface3, rgba(255,255,255,.08)) 50%,
    var(--surface2) 75%
  );
  background-size: 200% 100%;
  animation: p-shimmer 1.5s infinite;
  border-radius: var(--r-md);
}
@keyframes p-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ═══════════════════════════════════════════════════════════
   WICHTIGE OVERRIDE — bestehende Klassen upgraden
   ═══════════════════════════════════════════════════════════ */

/* card → p-card Design */
.card {
  border-radius: var(--r-xl) !important;
  transition: border-color var(--t-base), box-shadow var(--t-base) !important;
}
.card:hover { border-color: rgba(var(--accent-rgb), .15) !important; }

/* btn-primary upgrade */
.btn-primary, button[class*="btn-primary"] {
  border-radius: var(--r-lg) !important;
  font-weight: 700 !important;
  transition: all var(--t-fast) !important;
}
.btn-primary:hover { transform: translateY(-1px) !important; box-shadow: 0 4px 14px rgba(var(--accent-rgb),.35) !important; }
.btn-primary:active { transform: scale(.98) !important; }

/* form-group inputs */
.form-group input, .form-group select, .form-group textarea {
  border-radius: var(--r-lg) !important;
  transition: border-color var(--t-base), box-shadow var(--t-base) !important;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--accent, #4f8ef7) !important;
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), .1) !important;
  outline: none !important;
}

/* Modals */
.modal-box, .modal-inner {
  border-radius: var(--r-xl) !important;
  border: 1px solid var(--border2) !important;
}

/* Buttons allgemein */
button { font-family: var(--font-ui) !important; }

/* ═══════════════════════════════════════════════════════════
   ANIMATIONEN
   ═══════════════════════════════════════════════════════════ */
@keyframes p-fadein {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes p-scalein {
  from { opacity: 0; transform: scale(.95); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes p-slidein-right {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}
.p-anim-fadein    { animation: p-fadein .25s var(--ease) both; }
.p-anim-scalein   { animation: p-scalein .2s var(--ease) both; }
.p-anim-slidein   { animation: p-slidein-right .2s var(--ease) both; }

/* Staggered für Listen */
.p-stagger > * { animation: p-fadein .2s var(--ease) both; }
.p-stagger > *:nth-child(1) { animation-delay: .03s; }
.p-stagger > *:nth-child(2) { animation-delay: .06s; }
.p-stagger > *:nth-child(3) { animation-delay: .09s; }
.p-stagger > *:nth-child(4) { animation-delay: .12s; }
.p-stagger > *:nth-child(5) { animation-delay: .15s; }
.p-stagger > *:nth-child(n+6) { animation-delay: .18s; }

/* ═══════════════════════════════════════════════════════════
   MOBILE OVERRIDES
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  .p-header { padding: 12px 12px 10px; }
  .p-card { border-radius: 12px !important; }
  .p-btn { min-height: 44px; }
  .p-modal { border-radius: 20px 20px 0 0 !important; }
  .p-chips { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .p-chips::-webkit-scrollbar { display: none; }
  .p-header-row { flex-direction: column; gap: 10px; }
  .p-header-actions { width: 100%; }
  .p-header-actions .p-btn { flex: 1; }
  input, select, textarea { font-size: 16px !important; } /* iOS Zoom Fix */
}

/* ── Topbar Overlap Fix ── */
.topbar { gap: 8px; }
.topbar-left { min-width: 0; flex: 1; overflow: hidden; }
.topbar-right { flex-shrink: 0; white-space: nowrap; display: flex; align-items: center; gap: 6px; }
.topbar-paket { max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.breadcrumb { min-width: 0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
@media (max-width: 640px) {
  .topbar { padding: 0 12px; }
  .topbar-paket { display: none; }
  .breadcrumb strong { max-width: 120px; display: inline-block; overflow: hidden; text-overflow: ellipsis; }
}
