/* =========================================================================
   ServiceHub - Redesign: Belegeditor "Dokumente / Verknuepfungen / Verlauf"
   (ed-docs)
   --------------------------------------------------------------------------
   REIN OPTISCH. Additive Schicht. Re-Skin von drei Tab-Inhalten im gemeinsamen
   Belegeditor (Angebot - Auftrag - Rechnung - Lieferschein - Gutschrift) plus
   der eingebetteten PDF-Vorschau-Spalte. Styled die ECHTEN Selektoren aus
   doc-editor-layout.js und doc-editor-layout.css:

     Dokumente-Tab (_renderDocumentsTab):
       .del-documents
       .del-doc-uploadbox (+ __icon / __title / __hint / __progress / is-dragover)
       .del-doc-list (+ __loading / __empty / __error)
       .del-doc-item (+ __icon / __body / __name / __meta / __attach / __actions)
       .del-doc-btn (+ --danger)

     Verknuepfungen-Tab (_renderLinksTab):
       .del-overview-grid / .del-card (Karten)
       .del-link-list / li / a (Verknuepfungsliste)

     Verlauf-Tab (_renderHistoryTab):
       .del-history / .del-history-list / .del-history-item
       .del-history-date / .del-history-change / .del-history-actor
       (als weiche Zeitleiste neu gerahmt)

     PDF-Vorschau (rechte Spalte, BLEIBT sichtbar - nur schoener):
       .del-preview / .del-preview-header / .del-preview-toolbar
       .del-preview-content / .del-preview-placeholder

   WICHTIG: doc-editor-layout.js injiziert beim Rendern der History inline
   style-Attribute (Hellfarben, kein Dark-Mode). Diese Schicht gewinnt durch
   hoehere Spezifitaet (.del-wrap-Scope) und bringt die warme Palette plus
   Dark-Mode zurueck - ohne Wust von Wichtig-Markern.

   KEINE Funktions-, Markup- oder Logik-Aenderung. Nichts wird versteckt (kein
   display none auf Buttons, Tabs, Feldern, Zeilen, Vorschau). Reines CSS.

   Tokens lokal als --sxd- auf die Editor-Container gescoped (ladereihenfolge-
   unabhaengig). Light plus Dark via data-theme. Globale Basis nicht angefasst.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Figtree:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

/* ---------- Tokens (Light) - auf die Editor-Container gescoped ---------- */
.del-wrap .del-tab-content,
.del-wrap .del-preview {
  --sxd-accent: #E73D25;
  --sxd-accent-700: #C5331E;
  --sxd-accent-soft: #FCEDE7;
  --sxd-accent-line: rgba(231, 61, 37, .22);
  --sxd-honey: #D99A2B;
  --sxd-honey-soft: #FBF0DA;
  --sxd-ok: #16A34A;
  --sxd-ok-soft: #E9F8EF;
  --sxd-warn: #C7791A;
  --sxd-warn-soft: #FBF1E0;
  --sxd-info: #2F6BD6;
  --sxd-info-soft: #EAF1FC;

  --sxd-bg: #FAF6F2;
  --sxd-surface: #FFFFFF;
  --sxd-surf-2: #F6F1EB;
  --sxd-surf-3: #EFE8E0;
  --sxd-field: #F8F4EF;

  --sxd-ink: #231C17;
  --sxd-text: #463D35;
  --sxd-text-2: #6B6157;
  --sxd-muted: #9A8F84;
  --sxd-border: #EEE5DC;
  --sxd-border-2: #E3D9CE;

  --sxd-font-head: 'Space Grotesk', 'Figtree', system-ui, sans-serif;
  --sxd-font-body: 'Figtree', system-ui, sans-serif;
  --sxd-font-mono: 'Space Mono', ui-monospace, monospace;

  --sxd-r-xs: 7px;
  --sxd-r-sm: 9px;
  --sxd-r-md: 12px;
  --sxd-r-lg: 16px;
  --sxd-r-pill: 999px;

  --sxd-shadow-sm: 0 1px 2px rgba(120, 80, 50, .06);
  --sxd-shadow-soft: 0 6px 20px rgba(120, 80, 50, .07), 0 1px 2px rgba(120, 80, 50, .05);
  --sxd-shadow-lg: 0 18px 44px rgba(120, 80, 50, .14);
  --sxd-ring: 0 0 0 3px var(--sxd-accent-soft);
  --sxd-tr: .16s cubic-bezier(.2, .7, .3, 1);
}

/* ---------- Tokens (Dark) ---------- */
[data-theme="dark"] .del-wrap .del-tab-content,
[data-theme="dark"] .del-wrap .del-preview {
  --sxd-accent: #F2543B;
  --sxd-accent-700: #E0432B;
  --sxd-accent-soft: rgba(242, 84, 59, .16);
  --sxd-accent-line: rgba(242, 84, 59, .30);
  --sxd-honey: #E6AE4A;
  --sxd-honey-soft: rgba(230, 174, 74, .16);
  --sxd-ok: #3BC07A;
  --sxd-ok-soft: rgba(59, 192, 122, .15);
  --sxd-warn: #E5A33C;
  --sxd-warn-soft: rgba(229, 163, 60, .15);
  --sxd-info: #5C8FE8;
  --sxd-info-soft: rgba(92, 143, 232, .16);

  --sxd-bg: #15120F;
  --sxd-surface: #1E1A16;
  --sxd-surf-2: #241F1A;
  --sxd-surf-3: #2C2620;
  --sxd-field: #211C18;

  --sxd-ink: #F6F1EC;
  --sxd-text: #E2D8CE;
  --sxd-text-2: #B3A99E;
  --sxd-muted: #8C8175;
  --sxd-border: #2E2822;
  --sxd-border-2: #3A332B;

  --sxd-shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);
  --sxd-shadow-soft: 0 6px 20px rgba(0, 0, 0, .35), 0 1px 2px rgba(0, 0, 0, .4);
  --sxd-shadow-lg: 0 18px 44px rgba(0, 0, 0, .5);
  --sxd-ring: 0 0 0 3px var(--sxd-accent-soft);
}

/* =========================================================================
   1) DOKUMENTE-TAB - Container
   ========================================================================= */

.del-wrap .del-tab-content .del-documents {
  gap: 18px;
  font-family: var(--sxd-font-body);
  color: var(--sxd-text);
}

/* Hinweis-Zeile "Beleg muss zuerst gespeichert werden ..." */
.del-wrap .del-tab-content .del-documents > .del-muted {
  margin: 0;
  padding: 18px 20px;
  background: var(--sxd-surf-2);
  border: 1px dashed var(--sxd-border-2);
  border-radius: var(--sxd-r-md);
  color: var(--sxd-text-2);
  font-size: 13.5px;
  line-height: 1.55;
}

/* =========================================================================
   2) DOKUMENTE-TAB - Upload-Ablage (Drag and Drop)
   ========================================================================= */

.del-wrap .del-tab-content .del-doc-uploadbox {
  border: 2px dashed var(--sxd-border-2);
  border-radius: var(--sxd-r-lg);
  padding: 30px 22px;
  background:
    radial-gradient(120% 90% at 50% -10%, var(--sxd-surf-2), var(--sxd-surface) 72%);
  cursor: pointer;
  transition: border-color var(--sxd-tr), background var(--sxd-tr), box-shadow var(--sxd-tr), transform var(--sxd-tr);
}
.del-wrap .del-tab-content .del-doc-uploadbox:hover,
.del-wrap .del-tab-content .del-doc-uploadbox:focus,
.del-wrap .del-tab-content .del-doc-uploadbox.is-dragover {
  border-color: var(--sxd-accent);
  background: var(--sxd-accent-soft);
  box-shadow: var(--sxd-shadow-soft);
  outline: none;
}
.del-wrap .del-tab-content .del-doc-uploadbox.is-dragover {
  transform: translateY(-1px);
}

.del-wrap .del-tab-content .del-doc-uploadbox__icon {
  font-size: 30px;
  line-height: 1;
  margin-bottom: 10px;
  filter: saturate(.9);
}
.del-wrap .del-tab-content .del-doc-uploadbox__title {
  font-family: var(--sxd-font-head);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--sxd-ink);
  margin-bottom: 5px;
}
.del-wrap .del-tab-content .del-doc-uploadbox__hint {
  font-size: 12.5px;
  color: var(--sxd-muted);
  line-height: 1.5;
}
.del-wrap .del-tab-content .del-doc-uploadbox__progress {
  margin-top: 14px;
  padding: 9px 14px;
  border-radius: var(--sxd-r-sm);
  background: var(--sxd-info-soft);
  color: var(--sxd-info);
  border: 1px solid var(--sxd-accent-line);
  border-color: color-mix(in srgb, var(--sxd-info) 30%, transparent);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--sxd-font-body);
}

/* =========================================================================
   3) DOKUMENTE-TAB - Liste plus Zustaende
   ========================================================================= */

.del-wrap .del-tab-content .del-doc-list {
  gap: 10px;
}

.del-wrap .del-tab-content .del-doc-list__loading,
.del-wrap .del-tab-content .del-doc-list__empty,
.del-wrap .del-tab-content .del-doc-list__error {
  padding: 22px 18px;
  text-align: center;
  font-size: 13px;
  border-radius: var(--sxd-r-md);
  background: var(--sxd-surf-2);
  border: 1px solid var(--sxd-border);
  color: var(--sxd-muted);
}
.del-wrap .del-tab-content .del-doc-list__error {
  color: var(--sxd-accent);
  background: var(--sxd-accent-soft);
  border-color: var(--sxd-accent-line);
}

/* Beleg-Datei-Zeile als weiche Karte */
.del-wrap .del-tab-content .del-doc-item {
  gap: 14px;
  padding: 13px 16px;
  background: var(--sxd-surface);
  border: 1px solid var(--sxd-border);
  border-radius: var(--sxd-r-md);
  box-shadow: var(--sxd-shadow-sm);
  transition: border-color var(--sxd-tr), box-shadow var(--sxd-tr), transform var(--sxd-tr);
}
.del-wrap .del-tab-content .del-doc-item:hover {
  border-color: var(--sxd-accent-line);
  box-shadow: var(--sxd-shadow-soft);
  transform: translateY(-1px);
}

.del-wrap .del-tab-content .del-doc-item__icon {
  font-size: 22px;
  line-height: 1;
  width: 42px;
  height: 42px;
  flex: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--sxd-r-sm);
  background: var(--sxd-surf-2);
  border: 1px solid var(--sxd-border);
}

.del-wrap .del-tab-content .del-doc-item__name {
  font-family: var(--sxd-font-head);
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--sxd-ink);
  margin-bottom: 3px;
}
.del-wrap .del-tab-content .del-doc-item__meta {
  font-size: 11.5px;
  color: var(--sxd-muted);
  font-family: var(--sxd-font-mono);
}

/* "Mit Beleg per E-Mail senden"-Haekchen */
.del-wrap .del-tab-content .del-doc-item__attach {
  color: var(--sxd-text-2) !important;
  font-size: 12px !important;
}
.del-wrap .del-tab-content .del-doc-item__attach input[type="checkbox"] {
  accent-color: var(--sxd-accent);
  width: 14px;
  height: 14px;
}

/* Aktions-Knoepfe (Download / Loeschen) */
.del-wrap .del-tab-content .del-doc-btn {
  padding: 7px 13px;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--sxd-font-body);
  color: var(--sxd-text);
  background: var(--sxd-surface);
  border: 1px solid var(--sxd-border-2);
  border-radius: var(--sxd-r-pill);
  transition: background var(--sxd-tr), border-color var(--sxd-tr), color var(--sxd-tr), transform var(--sxd-tr);
}
.del-wrap .del-tab-content .del-doc-btn:hover {
  background: var(--sxd-accent-soft);
  border-color: var(--sxd-accent-line);
  color: var(--sxd-accent);
  transform: translateY(-1px);
}
.del-wrap .del-tab-content .del-doc-btn:active {
  transform: scale(.98);
}
.del-wrap .del-tab-content .del-doc-btn--danger {
  color: var(--sxd-accent-700);
}
.del-wrap .del-tab-content .del-doc-btn--danger:hover {
  background: var(--sxd-accent-soft);
  border-color: var(--sxd-accent-line);
  color: var(--sxd-accent-700);
}

/* =========================================================================
   4) VERKNUEPFUNGEN-TAB - Karten plus Verknuepfungsliste
   ========================================================================= */

.del-wrap .del-tab-content .del-overview-grid {
  gap: 16px;
}

/* Karte (auch fuer den Verknuepfungen-Tab genutzt) - warm gerahmt */
.del-wrap .del-tab-content .del-card {
  background: var(--sxd-surface);
  border: 1px solid var(--sxd-border);
  border-radius: var(--sxd-r-lg);
  box-shadow: var(--sxd-shadow-soft);
  padding: 18px 20px;
  font-family: var(--sxd-font-body);
  color: var(--sxd-text);
  transition: border-color var(--sxd-tr), box-shadow var(--sxd-tr);
}
.del-wrap .del-tab-content .del-card:hover {
  border-color: var(--sxd-border-2);
}
.del-wrap .del-tab-content .del-card h4 {
  margin: 0 0 14px;
  padding: 0 0 12px;
  font-family: var(--sxd-font-head);
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--sxd-ink);
  border-bottom: 1px solid var(--sxd-border);
}

.del-wrap .del-tab-content .del-link-list {
  margin: 0;
  padding: 0;
  list-style: none;
}
.del-wrap .del-tab-content .del-link-list li {
  padding: 11px 0;
  border-bottom: 1px solid var(--sxd-border);
}
.del-wrap .del-tab-content .del-link-list li:last-child {
  border-bottom: none;
}
.del-wrap .del-tab-content .del-link-list a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--sxd-accent);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 600;
  transition: color var(--sxd-tr);
}
.del-wrap .del-tab-content .del-link-list a:hover {
  color: var(--sxd-accent-700);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* =========================================================================
   5) VERLAUF-TAB - Zeitleiste
   --------------------------------------------------------------------------
   _renderHistoryTab() setzt inline style-Attribute (Hellfarben). Hoehere
   Spezifitaet ueberschreibt sie warm plus dark; gefaerbte Status-Badges
   bleiben unberuehrt (semantisch).
   ========================================================================= */

.del-wrap .del-tab-content .del-history {
  font-family: var(--sxd-font-body);
  color: var(--sxd-text);
}

.del-wrap .del-tab-content .del-history-list {
  list-style: none;
  margin: 0;
  padding: 4px 0 0 4px;
  position: relative;
}

/* Eintrag als Zeitleisten-Knoten mit linker Fuehrungslinie und Punkt */
.del-wrap .del-tab-content .del-history-item {
  position: relative;
  align-items: baseline;
  gap: 6px 12px;
  margin: 0;
  padding: 10px 4px 16px 24px !important;
  border-bottom: none !important;
  border-left: 2px solid var(--sxd-border);
}
.del-wrap .del-tab-content .del-history-item:last-child {
  border-left-color: transparent;
  padding-bottom: 2px !important;
}
.del-wrap .del-tab-content .del-history-item::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 13px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--sxd-surface);
  border: 2px solid var(--sxd-border-2);
}
/* Juengster Eintrag (erster in der Liste) hervorgehoben */
.del-wrap .del-tab-content .del-history-item:first-child::before {
  background: var(--sxd-accent);
  border-color: var(--sxd-accent);
  box-shadow: 0 0 0 4px var(--sxd-accent-soft);
}

.del-wrap .del-tab-content .del-history-date {
  color: var(--sxd-muted) !important;
  font-family: var(--sxd-font-mono);
  font-size: 11.5px !important;
}
.del-wrap .del-tab-content .del-history-actor {
  color: var(--sxd-text-2) !important;
  font-size: 12px !important;
}

/* =========================================================================
   6) EINGEBETTETE PDF-VORSCHAU (rechte Spalte) - BLEIBT sichtbar, nur schoener
   --------------------------------------------------------------------------
   Reine Optik: weiche Karte, ruhige Toolbar, gepolsterter Inhalt. KEIN
   display none, KEIN erzwungenes Ein- oder Ausblenden - die vorhandene
   Aufklapp- bzw. Kollaps-Logik (.del-preview--collapsed) bleibt unberuehrt.
   ========================================================================= */

.del-wrap .del-preview {
  background: var(--sxd-surf-2);
  border-left: 1px solid var(--sxd-border);
  font-family: var(--sxd-font-body);
  color: var(--sxd-text);
}

.del-wrap .del-preview .del-preview-header {
  padding: 14px 16px;
  border-bottom: 1px solid var(--sxd-border);
  background: var(--sxd-surface);
}
.del-wrap .del-preview .del-preview-header h3 {
  margin: 0;
  font-family: var(--sxd-font-head);
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--sxd-ink);
}

.del-wrap .del-preview .del-preview-toolbar {
  gap: 6px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--sxd-border);
  background: var(--sxd-surface);
}

/* Umschalt-Knoepfe Kundensicht / Intern in der Vorschau-Toolbar */
.del-wrap .del-preview .del-preview-toolbar .del-btn {
  padding: 6px 13px;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--sxd-font-body);
  color: var(--sxd-text-2);
  background: var(--sxd-surf-2);
  border: 1px solid var(--sxd-border-2);
  border-radius: var(--sxd-r-pill);
  transition: background var(--sxd-tr), border-color var(--sxd-tr), color var(--sxd-tr);
}
.del-wrap .del-preview .del-preview-toolbar .del-btn:hover {
  border-color: var(--sxd-accent-line);
  color: var(--sxd-accent);
  background: var(--sxd-accent-soft);
}
.del-wrap .del-preview .del-preview-toolbar .del-btn.del-btn--active {
  background: var(--sxd-accent);
  border-color: var(--sxd-accent);
  color: #fff;
}

/* Eckiger Ein-/Ausklapp-Knopf im Vorschau-Kopf */
.del-wrap .del-preview .del-preview-header .del-btn--icon {
  border: 1px solid var(--sxd-border-2);
  background: var(--sxd-surf-2);
  color: var(--sxd-text-2);
  border-radius: var(--sxd-r-sm);
  transition: background var(--sxd-tr), border-color var(--sxd-tr), color var(--sxd-tr);
}
.del-wrap .del-preview .del-preview-header .del-btn--icon:hover {
  border-color: var(--sxd-accent-line);
  color: var(--sxd-accent);
  background: var(--sxd-accent-soft);
}

/* Vorschau-Inhalt: weiche Buehne fuer das gerahmte Belegblatt */
.del-wrap .del-preview .del-preview-content {
  padding: 14px;
  background:
    radial-gradient(130% 80% at 50% 0%, var(--sxd-surf-2), var(--sxd-surf-3) 100%);
}

.del-wrap .del-preview .del-preview-placeholder {
  color: var(--sxd-muted);
  font-size: 13px;
}

/* Das eingebettete Belegblatt als weiche, erhabene Karte */
.del-wrap .del-preview .del-preview-content .del-preview-doc {
  border: 1px solid var(--sxd-border);
  border-radius: var(--sxd-r-md);
  box-shadow: var(--sxd-shadow-lg);
  overflow: hidden;
}
