:root {
    --bg: #f6f7f9;
    --fg: #1a1d22;
    --muted: #687078;
    --accent: #1e63d6;
    --accent-hover: #1450ad;
    --border: #e3e6ea;
    --card: #ffffff;
    --shadow: 0 1px 2px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.05);
    --ok: #1f8a4c;
    --warn: #b97400;
    --err: #c4263c;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    font: 14px/1.5 -apple-system, "Segoe UI", "Inter", system-ui, sans-serif;
    background: var(--bg);
    color: var(--fg);
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-hover); text-decoration: underline; }

code, pre { font-family: ui-monospace, "SF Mono", Consolas, monospace; }

.topbar {
    display: flex; align-items: center; gap: 24px;
    padding: 12px 24px; background: var(--card); border-bottom: 1px solid var(--border);
}
.brand { font-weight: 700; color: var(--fg); }
.mainnav { flex: 1; display: flex; gap: 18px; align-items: center; }
.mainnav a { color: var(--muted); }
.mainnav a:hover { color: var(--fg); text-decoration: none; }

/* ─── Dropdown-Untermenü in der Mainnav ──────────────────── */
.nav-group { position: relative; display: inline-block; }
.nav-group-head { color: var(--muted); cursor: pointer; user-select: none; }
.nav-group-head:hover, .nav-group:focus-within .nav-group-head { color: var(--fg); }
.nav-group-menu {
    display: none;
    position: absolute; top: 100%; left: -10px; z-index: 100;
    min-width: 220px; padding: 6px 0;
    background: var(--card); border: 1px solid var(--border); border-radius: 6px;
    box-shadow: 0 4px 14px rgba(0,0,0,.08);
}
.nav-group-menu a {
    display: block; padding: 7px 14px; color: var(--fg); font-size: 13px;
}
.nav-group-menu a:hover { background: #f0f4f9; color: var(--accent); }
.nav-group:hover > .nav-group-menu,
.nav-group:focus-within > .nav-group-menu { display: block; }

.user-chip { display: flex; gap: 8px; align-items: center; font-size: 13px; }
.user-name { font-weight: 600; }
.user-role {
    font-size: 11px; padding: 2px 6px;
    background: #eef2f7; color: #345; border-radius: 6px; text-transform: uppercase;
}
.user-logout { color: var(--muted); }

.content { max-width: 1200px; margin: 32px auto; padding: 0 24px; }
.content.content-wide { max-width: min(1800px, calc(100vw - 32px)); }

.hero {
    background: var(--card); padding: 48px; border-radius: 12px;
    border: 1px solid var(--border); box-shadow: var(--shadow);
}
.hero h1 { margin: 0 0 12px; font-size: 28px; }

.login-hero {
    max-width: 960px;
    margin: 24px auto 0;
    background: var(--card);
    padding: 32px;
    border-radius: 12px;
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
    text-align: center;
}
.login-hero__panel { margin: 0 auto 24px; max-width: 640px; }
.login-hero__panel h1 { margin: 0 0 12px; font-size: 32px; }
.login-hero__cta { margin-top: 20px; padding: 12px 28px; font-size: 16px; }
.login-hero__note { margin-top: 16px; font-size: 13px; }
.login-hero__image { margin-top: 8px; }
.login-hero__image img {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: 10px;
    margin: 0 auto;
}

.muted { color: var(--muted); }

.button {
    display: inline-block; padding: 10px 18px; border-radius: 8px;
    background: var(--accent); color: #fff; font-weight: 600;
    border: 1px solid transparent; cursor: pointer;
}
.button:hover { background: var(--accent-hover); color: #fff; text-decoration: none; }
.button.primary { background: var(--accent); }

.tile-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; margin-top: 24px; }
.tile {
    display: block; background: var(--card); padding: 18px;
    border-radius: 10px; border: 1px solid var(--border); box-shadow: var(--shadow);
    color: var(--fg);
}
.tile:hover { transform: translateY(-1px); text-decoration: none; }
.tile h3 { margin: 0 0 4px; font-size: 16px; }
.tile p  { margin: 0; color: var(--muted); }

.flash-stack { margin-bottom: 16px; display: flex; flex-direction: column; gap: 8px; }
.flash       { padding: 10px 14px; border-radius: 8px; border: 1px solid var(--border); background: var(--card); }
.flash-success { border-color: #b6e3c4; background: #ecfaf0; color: var(--ok); }
.flash-error   { border-color: #f0c2c8; background: #fdecef; color: var(--err); }
.flash-warning { border-color: #f3d68a; background: #fff7e6; color: var(--warn); }
.warn { border: 1px solid #f3d68a; background: #fff7e6; color: var(--warn); padding: 8px 12px; border-radius: 6px; }
.warn code { background: rgba(185, 116, 0, 0.08); padding: 1px 4px; border-radius: 3px; }

.data-table { width: 100%; border-collapse: collapse; background: var(--card); border-radius: 8px; overflow: hidden; box-shadow: var(--shadow); }
.data-table th, .data-table td { padding: 8px 12px; border-bottom: 1px solid var(--border); text-align: left; vertical-align: top; }
.data-table th { background: #f3f5f8; font-weight: 600; }
.data-table tbody tr:hover { background: #fafbfc; }

.code-block { background: #0e141a; color: #d6dde6; padding: 14px; border-radius: 8px; overflow-x: auto; font-size: 12px; }
.placeholder { background: var(--card); padding: 24px; border: 1px dashed var(--border); border-radius: 8px; }

.setup-list { line-height: 2; }

/* ─── Imports-Seite ─────────────────────────────────────── */

.import-grid {
    display: grid; gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    margin: 16px 0 28px;
}
.import-grid .card {
    background: var(--card); border: 1px solid var(--border);
    border-radius: 10px; padding: 18px; box-shadow: var(--shadow);
}
.import-grid h2 { margin: 0 0 6px; font-size: 16px; }

.job-form { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.job-form label { font-size: 12px; color: var(--muted); margin-top: 6px; }
.job-form select, .job-form input[type=file] {
    padding: 8px 10px; border-radius: 6px; border: 1px solid var(--border);
    background: #fff; font-size: 13px;
}
.job-form button {
    align-self: flex-start; margin-top: 8px;
    padding: 8px 14px; border-radius: 6px; border: 1px solid transparent;
    background: var(--accent); color: #fff; font-weight: 600; cursor: pointer;
}
.job-form button[disabled] { background: #c0c5cb; cursor: not-allowed; }
.job-form button:hover:not([disabled]) { background: var(--accent-hover); }

.upload-details { margin-top: 12px; }
.upload-details summary { cursor: pointer; color: var(--muted); font-size: 13px; }
.upload-details form { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }

.jobs-heading { margin-top: 28px; }

/* Status-Pills */
.pill {
    display: inline-block; padding: 2px 8px; border-radius: 999px;
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
}
.pill-pending { background: #eef2f7; color: #345; }
.pill-running { background: #fff4d6; color: var(--warn); }
.pill-done    { background: #d8f4e1; color: var(--ok); }
.pill-failed  { background: #fadde1; color: var(--err); }

/* Fortschrittsbalken */
.bar {
    position: relative; height: 16px; background: #eef2f7;
    border-radius: 8px; overflow: hidden; min-width: 120px;
}
.bar-fill {
    position: absolute; left: 0; top: 0; bottom: 0;
    background: linear-gradient(90deg, #4d8df0, var(--accent));
    transition: width 0.4s ease;
}
.bar > span {
    position: relative; z-index: 1; display: block;
    text-align: center; line-height: 16px; font-size: 11px;
    color: #1a1d22; font-weight: 600;
}

tr.status-running { background: #fffaf0; }
tr.status-failed  { background: #fdf3f4; }

/* ─── Sortiment / Products ──────────────────────────────── */

.filter-bar { display: flex; gap: 8px; margin: 12px 0; }
.filter-bar input[type=search] {
    flex: 1; padding: 8px 12px; border-radius: 6px; border: 1px solid var(--border);
    background: #fff; font-size: 14px;
}
.filter-bar button {
    padding: 8px 16px; border-radius: 6px; border: 1px solid transparent;
    background: var(--accent); color: #fff; font-weight: 600; cursor: pointer;
}

.filter-pills { display: flex; gap: 6px; flex-wrap: wrap; margin: 0 0 16px; align-items: center; }
.filter-pill {
    padding: 5px 12px; border-radius: 999px; font-size: 12px;
    background: var(--card); border: 1px solid var(--border); color: var(--fg);
    transition: background 0.1s ease, border-color 0.1s ease, box-shadow 0.1s ease;
}
.filter-pill:hover { text-decoration: none; background: #eef2f7; border-color: #c6dafc; }
.filter-pill.active {
    background: var(--accent); color: #fff; border-color: var(--accent);
    font-weight: 600;
    box-shadow: 0 1px 3px rgba(30, 99, 214, 0.30);
}
.filter-pill.active small { color: #fff; opacity: 0.92; }
.filter-pill small { opacity: 0.85; margin-left: 4px; }

/* Multi-Pills (Aktiv/Inaktiv) — deutlich anderer ON-Look als Status-Pills:
   grüne Markierung wie eine "Toggle ist an"-Anzeige, mit Häkchen davor. */
.filter-pill.multi {
    display: inline-flex; align-items: center;
}
.filter-pill.multi.active {
    background: #ecfaf0;
    color: #166e3a;
    border-color: var(--ok);
    border-width: 1px;
    font-weight: 600;
    box-shadow: inset 3px 0 0 var(--ok);
}
.filter-pill.multi.active small { color: #166e3a; opacity: 0.85; }
.filter-pill.multi.active::before {
    content: '✓';
    margin-right: 4px;
    font-weight: 700;
    color: var(--ok);
}

/* Such-Eingabefeld als "aktiver Filter" anzeigen, wenn Query gesetzt */
.filter-bar input[type="search"]:not(:placeholder-shown) {
    background: #f7faff;
    border-color: #c6dafc;
}

/* "Alle Filter zurücksetzen"-Hinweis */
.filter-reset {
    margin-left: auto;
    color: var(--muted); font-size: 12px;
    padding: 4px 10px; border-radius: 6px;
}
.filter-reset:hover {
    background: #fef0e3; color: var(--err); text-decoration: none;
}

.products-table th { white-space: nowrap; }
.products-table td.num { text-align: right; white-space: nowrap; }
.products-table th.num { text-align: right; }
/* Row-Hintergrund nach Aktions-Bedarf, nicht nach Empfehlungs-Status:
 *   Standard      → weiß (90 %+ der Zeilen, ruhig)
 *   row-missing   → hellrot (kein EK gewählt ODER keine Markt-Daten)
 *   row-touched   → hellgrün (User hat in dieser Session VK oder EK
 *                   geändert; queued/ek_choices-Eintrag existiert)
 *   row-touched gewinnt über row-missing — wenn der User schon ange-
 *   fasst hat, ist das die wichtigere Info.
 */
.products-table tr.row-missing { background: #fdecef; }
.products-table tr.row-touched { background: #e9f7ef; }
.products-table tr.reco-NO_DATA { color: var(--muted); }

.diff-ok   { color: var(--ok); }
.diff-high { color: var(--err); }
.diff-low  { color: var(--warn); }

.match-badge {
    display: inline-block; padding: 0 6px; border-radius: 4px;
    font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
}
.match-mpn { background: #fff4d6; color: var(--warn); }
.match-sib { background: #eef4ff; color: #1450ad; }

.pill.reco-pill-OK          { background: #d8f4e1; color: var(--ok); }
.pill.reco-pill-ADJUST      { background: #fff4d6; color: var(--warn); }
.pill.reco-pill-TOO_HIGH    { background: #fadde1; color: var(--err); }
.pill.reco-pill-BELOW_FLOOR { background: #ffe1c2; color: #a04400; }
.pill.reco-pill-NO_DATA     { background: #eef2f7; color: #345; }

.pager {
    display: flex; align-items: center; justify-content: center; gap: 4px;
    margin: 18px 0; flex-wrap: wrap;
}
.pager-btn, .pager-num {
    display: inline-block; min-width: 32px; padding: 6px 10px;
    border: 1px solid var(--border); border-radius: 6px;
    background: var(--card); color: var(--fg); text-align: center;
    font-size: 13px; font-weight: 500;
}
.pager-btn:hover, .pager-num:hover {
    background: #eef2f7; text-decoration: none;
}
.pager-btn.disabled {
    color: #c0c5cb; background: #fafbfc; cursor: not-allowed;
}
.pager-num.current {
    background: var(--accent); border-color: var(--accent); color: #fff;
}
.pager-ellipsis {
    padding: 6px 4px; color: var(--muted); user-select: none;
}
.pager-info {
    margin-left: 12px; padding: 6px 8px; color: var(--muted); font-size: 12px;
}

.filter-pills-active { margin-top: -4px; }

/* AWIN-Browse: Kategorie-Multi-Toggle Section */
.cat-extras {
    margin: 6px 0 0;
}
.cat-extras > summary {
    cursor: pointer; padding: 4px 0;
    color: var(--muted); font-size: 13px; user-select: none;
    list-style: none;
}
.cat-extras > summary::-webkit-details-marker { display: none; }
.cat-extras > summary::before {
    content: '▸'; display: inline-block; width: 14px;
    color: var(--muted); transition: transform 0.15s;
}
.cat-extras[open] > summary::before { transform: rotate(90deg); }
.cat-extras > summary:hover { color: var(--accent); }
.mt-small { margin-top: 6px; }

.cat-actions { margin: 8px 0 14px; display: flex; gap: 10px; align-items: center; }
.cat-action {
    color: var(--muted); font-size: 12px;
    padding: 2px 8px; border-radius: 4px; text-decoration: none;
}
.cat-action:hover { background: #eef2f7; color: var(--accent); text-decoration: none; }

/* ─── Batch / Detail ────────────────────────────────────── */

.batch-bar {
    display: flex; gap: 12px; align-items: center;
    background: var(--card); border: 1px solid var(--border); padding: 10px 14px;
    border-radius: 8px; margin: 0 0 10px;
}
.batch-bar button {
    padding: 6px 12px; border-radius: 6px; border: 1px solid transparent;
    background: var(--accent); color: #fff; font-weight: 600; cursor: pointer;
}
.batch-bar .button { padding: 6px 12px; }
.check-col { width: 28px; text-align: center; }

.detail-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px; margin: 18px 0;
}
.detail-grid .card {
    background: var(--card); border: 1px solid var(--border); border-radius: 10px;
    padding: 14px; box-shadow: var(--shadow);
}
.detail-grid h3 { margin: 0 0 6px; font-size: 13px; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; }
.big-price { font-size: 22px; font-weight: 700; }
.big-pill  { font-size: 18px; font-weight: 700; }
.sparkline-box { margin-top: 10px; }
.sparkline { display: block; }

/* ─── Inline-Preis + Amazon ─────────────────────────────── */

.inline-price-cell { width: 130px; }
.vk-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}
.vk-stack .lookup-row { margin-top: 0; }
.vk-stack .change-pill { margin-top: 0; }
.inline-price {
    width: 100px; padding: 4px 6px; text-align: right;
    border: 1px solid var(--border); border-radius: 4px; font-size: 13px; background: #fff;
    transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}
.inline-price:focus      { outline: 2px solid var(--accent); outline-offset: -1px; }
.inline-price.saving     { background: #fffaf0; border-color: #f3a80f; }
.inline-price.saved      { background: #d8f4e1; border-color: #6cc488;
                           box-shadow: 0 0 0 2px rgba(108, 196, 136, .25); }
.inline-price.save-error { background: #fdecef; border-color: var(--err); }

.change-pill {
    display: inline-block; margin-top: 4px;
    padding: 2px 8px; border-radius: 999px;
    background: #eef4ff; color: #1450ad; border: 1px solid #d6e2f5;
    font-size: 11px;
}

.amz-btn {
    background: #fff; border: 1px solid var(--border); padding: 4px 10px;
    border-radius: 6px; font-size: 12px; cursor: pointer;
}
.amz-btn:hover { background: #fff7e6; border-color: #f3a80f; }

.amz-pill {
    position: relative;
    display: inline-block; min-width: 80px;
    padding: 4px 8px 4px 26px; background: #fff7e6; border: 1px solid #f3d68a;
    border-radius: 6px; font-size: 12px; line-height: 1.3;
    transition: background 0.4s ease, border-color 0.4s ease;
}
.amz-pill.flash-saved { background: #d8f4e1; border-color: #6cc488; }

.amz-refresh {
    position: absolute; top: 2px; left: 4px;
    background: transparent; border: none; padding: 0;
    width: 18px; height: 18px;
    font-size: 14px; line-height: 18px; cursor: pointer;
    color: var(--muted);
    border-radius: 4px;
}
.amz-refresh:hover { background: #f3d68a; color: #345; }

/* ─── Netto-EK-Dropdown + Netto-Marge ─────────────────────── */

.ek-select-cell { min-width: 220px; }
.ek-select {
    max-width: 240px; padding: 4px 6px; font-size: 12px;
    border: 1px solid var(--border); border-radius: 4px; background: #fff;
    transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}
.ek-select:focus      { outline: 2px solid var(--accent); outline-offset: -1px; }
.ek-select.saving     { background: #fffaf0; border-color: #f3a80f; }
.ek-select.saved      { background: #d8f4e1; border-color: #6cc488;
                        box-shadow: 0 0 0 2px rgba(108, 196, 136, .25); }
.ek-select.save-error { background: #fdecef; border-color: var(--err); }
.ek-select:disabled   { background: #f4f4f4; color: #999; }

.ek-marker {
    display: inline-block; width: 18px; height: 18px; line-height: 18px;
    text-align: center; font-size: 11px; font-weight: 700;
    border-radius: 4px; background: #1450ad; color: #fff;
    vertical-align: middle;
}
.ek-note { display: inline-block; margin-top: 2px; font-size: 11px; }

.margin-cell { min-width: 80px; }
.margin-pos { color: #1f7d3a; font-weight: 600; }
.margin-neg { color: var(--err); font-weight: 600; }

.ek-detail {
    margin-top: 4px; font-size: 11px; color: var(--muted);
    line-height: 1.3;
}

/* ─── Artikel-Spalte: Name max 3 Zeilen, kompakte Meta-Zeile ─── */

.products-table th:nth-child(2),
.article-cell { min-width: 280px; max-width: 360px; }
.article-name {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.3;
}
.article-meta {
    margin-top: 2px;
    font-size: 11px; color: var(--muted);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.article-meta .meta-brand { color: #345; font-weight: 500; }

/* ─── Markt-Offer-Grid (unter Median, 2-spaltig) ─── */

.median-cell { min-width: 200px; }
.median-head { font-weight: 600; }
.median-low {
    margin-top: 4px; font-size: 11px; color: #345;
    background: #eef4ff; border: 1px solid #d6e2f5;
    border-radius: 4px; padding: 2px 6px; display: inline-block;
}

/* ─── Tekno-Listen-Cards ─── */

.tekno-list {
    display: flex; flex-direction: column; gap: 8px;
    margin: 16px 0;
}
.tekno-card {
    background: var(--card); border: 1px solid var(--border);
    border-radius: 6px; padding: 10px 14px;
    transition: border-color .15s;
}
.tekno-card:hover { border-color: #1450ad; }
.tekno-head {
    display: flex; gap: 16px; align-items: flex-start;
    justify-content: space-between;
}
.tekno-title { flex: 1 1 auto; line-height: 1.3; }
.tekno-price {
    flex: 0 0 auto; text-align: right; white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.tekno-meta {
    margin-top: 4px; font-size: 12px; color: var(--muted);
}
.tekno-cat {
    display: inline-block; padding: 1px 8px;
    background: #eef4ff; color: #1450ad;
    border-radius: 999px; font-size: 11px;
    border: 1px solid #d6e2f5;
}

details.extra-cats {
    margin: 4px 0 12px;
}
details.extra-cats > summary {
    cursor: pointer;
    padding: 4px 0;
}

/* Prominenter Reset-Button (sichtbar wenn Filter ≠ Default) */
.filter-reset-prominent {
    display: inline-block; margin-left: 12px;
    padding: 6px 12px; border-radius: 6px;
    background: #fff7e6; color: #a14600;
    border: 1px solid #f3a868; text-decoration: none;
    font-size: 13px;
}
.filter-reset-prominent:hover { background: #ffe6cc; }

/* ─── Hersteller-Filter (Multi-Select Dropdown) ─── */

.brand-filter { position: relative; display: inline-block; }
.brand-filter > summary {
    list-style: none; cursor: pointer; user-select: none;
}
.brand-filter > summary::-webkit-details-marker { display: none; }
.brand-filter[open] > summary { background: #1450ad; color: #fff; border-color: #1450ad; }

.brand-filter-form {
    position: absolute; top: calc(100% + 4px); left: 0;
    background: #fff; border: 1px solid var(--border);
    border-radius: 8px; padding: 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    width: 320px; z-index: 50;
}
.brand-filter-list {
    max-height: 320px; overflow-y: auto;
    display: grid; gap: 4px;
    padding-right: 4px;
}
.brand-filter-list .brand-cb {
    display: flex; align-items: center; gap: 6px;
    padding: 4px 6px; cursor: pointer; font-size: 13px;
    border-radius: 4px;
}
.brand-filter-list .brand-cb:hover { background: #f4f6f8; }
.brand-filter-actions {
    display: flex; gap: 8px; justify-content: flex-end;
    margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border);
}

.brand-chip {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 2px 8px; margin-left: 4px;
    background: #eef4ff; color: #1450ad;
    border: 1px solid #d6e2f5; border-radius: 999px;
    font-size: 12px; text-decoration: none;
}
.brand-chip:hover { background: #d6e2f5; }
.brand-chip-x { color: #1450ad; font-weight: 700; }

/* Streuungs-/Pack-Hinweis-Pille neben dem Median */
.band-pill {
    display: inline-block; margin-left: 6px;
    padding: 1px 6px; border-radius: 999px;
    font-size: 10px; font-weight: 600;
    cursor: help; vertical-align: middle;
    border: 1px solid;
}
.band-pill.band-bimodal {
    background: #fff7d6; color: #8a6d00; border-color: #f3d68a;
}
.band-pill.band-pack_mismatch {
    background: #ffe6cc; color: #a14600; border-color: #f3a868;
}
.offer-grid {
    margin-top: 6px;
    display: grid;
    grid-template-columns: auto 1fr auto 1fr;
    column-gap: 12px;
    row-gap: 2px;
    font-size: 11px;
    text-align: left;
}
.offer-grid .offer-merchant {
    color: var(--muted);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.offer-grid .offer-price {
    color: #345; font-variant-numeric: tabular-nums;
    font-weight: 500;
}

/* ─── Markt-Lookup-Button unter Neuer Preis ─── */

.lookup-row { margin-top: 6px; }
.lookup-row .amz-pill { font-size: 11px; }

/* ─── Modal ─────────────────────────────────────────────── */

.modal {
    position: fixed; inset: 0; background: rgba(0,0,0,.45);
    display: flex; align-items: center; justify-content: center; z-index: 100;
}
.modal.hidden { display: none; }
.modal-card {
    background: var(--card); border-radius: 12px; padding: 24px;
    width: min(640px, calc(100vw - 32px));
    max-height: calc(100vh - 64px); overflow: auto;
    box-shadow: 0 20px 60px rgba(0,0,0,.25); position: relative;
}
.modal-close {
    position: absolute; top: 8px; right: 12px; background: none; border: none;
    font-size: 28px; line-height: 1; cursor: pointer; color: var(--muted);
}
.modal-close:hover { color: var(--err); }
.modal-body { margin-top: 12px; }
.modal-actions { margin-top: 16px; display: flex; gap: 8px; }

.amz-grid {
    display: grid; grid-template-columns: 140px 1fr; gap: 16px; align-items: start;
}
.amz-img { width: 100%; height: auto; border-radius: 6px; border: 1px solid var(--border); }
.loader { padding: 24px; text-align: center; color: var(--muted); }

.modal-card-wide { width: min(720px, calc(100vw - 32px)); }

.src-stack { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.src-card  {
    display: grid; grid-template-rows: auto 1fr; gap: 8px;
    border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px;
    background: var(--card);
}
.src-card-empty { background: #fafbfc; }
.src-check { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.src-check input[type=checkbox] { width: 18px; height: 18px; }
.src-name  { font-weight: 600; }
.src-body  { display: grid; grid-template-columns: 80px 1fr; gap: 12px; align-items: start; }
.src-img   { width: 80px; height: 80px; object-fit: contain; border: 1px solid var(--border); border-radius: 4px; background: #fff; }
.src-img-placeholder {
    width: 80px; height: 80px; border: 1px dashed var(--border); border-radius: 4px;
    display: flex; align-items: center; justify-content: center; color: var(--muted);
}
.src-info { min-width: 0; }
.src-title { font-weight: 500; line-height: 1.3; margin-bottom: 4px;
             overflow: hidden; text-overflow: ellipsis; display: -webkit-box;
             -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.src-price { font-size: 16px; }
.src-price strong { font-size: 18px; }

/* Kompakter Fallback (kein Auto-Preis): nur Name + Hinweis + großer Open-Link */
.src-card.src-card-empty {
    display: grid;
    grid-template-columns: 140px 1fr;
    align-items: center;
    background: #fafbfc;
    padding: 8px 12px;
    gap: 12px;
}
.src-card.src-card-empty .src-name { font-size: 13px; color: var(--muted); }
.src-card.src-card-empty .src-fallback {
    display: flex; flex-direction: column; gap: 6px; align-items: flex-start;
}
.button-secondary {
    display: inline-block; padding: 6px 12px; border-radius: 6px;
    background: #fff; border: 1px solid var(--border); color: var(--accent);
    font-weight: 500; font-size: 13px;
}
.button-secondary:hover {
    background: var(--accent); color: #fff; border-color: var(--accent);
    text-decoration: none;
}
.button-danger {
    display: inline-block; padding: 6px 12px; border-radius: 6px;
    background: #fff; border: 1px solid #f0c2c8; color: var(--err);
    font-weight: 500; font-size: 13px; cursor: pointer;
}
.button-danger:hover { background: var(--err); color: #fff; border-color: var(--err); }

.mt-large  { margin-top: 32px; }
.mt-medium { margin-top: 14px; }
form.inline { display: inline; }
td.actions { white-space: nowrap; }

/* AWIN-Feed-Form */
.awin-form {
    background: var(--card); border: 1px solid var(--border); border-radius: 10px;
    padding: 16px 20px; max-width: 880px;
    display: flex; flex-direction: column; gap: 8px;
}
.awin-form label { font-size: 12px; color: var(--muted); font-weight: 500; margin-top: 8px; }
.awin-form input[type=text], .awin-form textarea {
    padding: 8px 10px; border-radius: 6px; border: 1px solid var(--border);
    background: #fff; font-size: 13px; font-family: ui-monospace, Consolas, monospace;
}
.awin-form textarea { resize: vertical; min-height: 80px; }
.awin-form .checkbox-line { display: flex; align-items: center; gap: 8px; font-size: 14px; }
.awin-form .form-actions {
    display: flex; gap: 8px; margin-top: 14px;
}
.awin-form button {
    padding: 8px 18px; border-radius: 6px; border: 1px solid transparent;
    background: var(--accent); color: #fff; font-weight: 600; cursor: pointer;
}

/* AWIN-Browse */
.awin-stats {
    display: flex; gap: 24px; align-items: center; flex-wrap: wrap;
    background: var(--card); border: 1px solid var(--border); border-radius: 10px;
    padding: 12px 18px; margin-top: 8px;
}
.awin-stats strong { font-size: 18px; }

.awin-product {
    background: var(--card); border: 1px solid var(--border); border-radius: 10px;
    margin: 14px 0; padding: 14px 16px; box-shadow: var(--shadow);
}
.awin-product-head { display: grid; grid-template-columns: 80px 1fr; gap: 12px; align-items: center; margin-bottom: 12px; }
.awin-product-head h3 { margin: 0 0 4px; font-size: 16px; }
.awin-img { width: 80px; height: 80px; object-fit: contain; background: #fff; border-radius: 6px; border: 1px solid var(--border); }
.awin-img-placeholder {
    width: 80px; height: 80px; border: 1px dashed var(--border); border-radius: 6px;
    display: flex; align-items: center; justify-content: center; color: var(--muted);
}
.awin-offers { font-size: 13px; }
.awin-links { white-space: nowrap; }
.basket-link {
    display: inline-block; padding: 3px 10px; border-radius: 999px;
    background: var(--ok); color: #fff; font-weight: 600; font-size: 12px;
}
.basket-link:hover { background: #166e3a; color: #fff; text-decoration: none; }

/* Eigene Pack-den-Ranzen-Zeile in der Wettbewerber-Tabelle */
tr.awin-own { background: #e8f5e8; }
tr.awin-own td { border-top: 2px solid var(--ok); border-bottom: 2px solid var(--ok); }
tr.awin-own td:first-child { border-left: 4px solid var(--ok); }

/* Compact-Mode: <details>/<summary> als geklappte Karte */
details.awin-product { padding: 0; }
details.awin-product > summary {
    cursor: pointer; padding: 14px 16px; list-style: none;
}
details.awin-product > summary::-webkit-details-marker { display: none; }
details.awin-product > summary::before {
    content: '▸'; display: inline-block; width: 14px;
    color: var(--muted); transition: transform 0.15s;
}
details.awin-product[open] > summary::before { transform: rotate(90deg); }
details.awin-product > summary > .awin-product-head { display: inline-grid; vertical-align: top; width: calc(100% - 16px); margin-bottom: 0; }
details.awin-product > .awin-offers { margin: 0 16px 14px; }

/* ─── Variant-Gruppierung ───────────────────────────────── */

tr.variant-head    { border-top: 2px solid var(--border); }
tr.variant-followup td { border-top: 1px dashed #eef2f7; }
tr.variant-followup td:nth-child(2) { padding-left: 24px; color: var(--muted); }

/* Variant-Akzent: kontinuierlicher blauer Balken links durch alle
 * Zeilen der Variant-Gruppe — auch wenn dazwischen ein anderer Status
 * wechselt. Der Balken liegt als box-shadow inset, damit er die
 * row-touched/row-missing-Hintergründe nicht zerschneidet. */
.products-table tr.is-variant td:first-child {
    box-shadow: inset 4px 0 0 #1e63d6;
}
/* "Var"-Badge auf dem Kopf einer Variantengruppe (erste Zeile) */
.products-table tr.is-variant.variant-head td:nth-child(2)::before {
    content: "Var";
    display: inline-block;
    margin-right: 6px;
    padding: 1px 6px;
    background: #1e63d6;
    color: #fff;
    border-radius: 4px;
    font-size: 10px; font-weight: 700; line-height: 1.4;
    vertical-align: middle;
    letter-spacing: 0.5px;
}
.variant-tag {
    display: inline-block; margin: 2px 0;
    padding: 1px 8px; border-radius: 999px; font-size: 11px;
    background: #eef4ff; color: #1450ad; border: 1px solid #d6e2f5;
}

/* AWIN-Browse: Variant-Group-Container für Geschwister-Varianten
   (gleiche parent_product_id). Klarer farbiger Border-Rahmen + linke
   Akzent-Leiste signalisiert "diese Karten gehören zusammen". Innere
   variant-cards haben keine eigene Border, nur dünne Trennlinien. */
section.variant-group {
    background: var(--card);
    border: 1px solid #c6dafc;
    border-left: 4px solid #1e63d6;
    border-radius: 10px;
    margin: 14px 0;
    padding: 14px 16px 6px;
    box-shadow: var(--shadow);
}
.variant-group-head {
    display: grid; grid-template-columns: 80px 1fr; gap: 12px;
    align-items: center; margin-bottom: 8px;
    padding-bottom: 10px; border-bottom: 1px solid #c6dafc;
}
.variant-group-head h3 { margin: 0 0 4px; font-size: 16px; }
.variant-group-body { display: flex; flex-direction: column; gap: 0; }

details.variant-card {
    border: none;
    border-bottom: 1px solid #eef2f7;
    border-radius: 0;
    background: transparent;
    margin: 0;
}
details.variant-card:last-child { border-bottom: none; }
details.variant-card[open] { background: #f7faff; }
details.variant-card > summary {
    cursor: pointer; padding: 8px 4px; list-style: none; font-size: 13px;
}
details.variant-card > summary::-webkit-details-marker { display: none; }
details.variant-card > summary::before {
    content: '▸'; display: inline-block; width: 14px;
    color: var(--muted); transition: transform 0.15s;
}
details.variant-card[open] > summary::before { transform: rotate(90deg); }
details.variant-card > summary > .awin-product-head {
    display: inline-grid; vertical-align: top; width: calc(100% - 16px);
    margin-bottom: 0; grid-template-columns: 60px 1fr; gap: 10px;
}
details.variant-card > summary > .awin-product-head .awin-img,
details.variant-card > summary > .awin-product-head .awin-img-placeholder {
    width: 60px; height: 60px;
}
details.variant-card .variant-title {
    margin: 0 0 4px; font-size: 14px; font-weight: 600;
    display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
}
details.variant-card .variant-title .variant-tag {
    font-size: 12px; font-weight: 500;
}
details.variant-card > .awin-offers { margin: 0 12px 10px; }

/* ─── Lagerbestand ──────────────────────────────────────── */

.stock-ok   { color: var(--ok); }
.stock-low  { color: var(--warn); }
.stock-zero { color: var(--err); }

/* ─── OP-Spalte (Klasse + Verkäufe 2025) ─────────────────── */

.op-cell { min-width: 70px; }
.op-cell-link { display: inline-flex; gap: 5px; align-items: baseline; text-decoration: none; }
.op-cell-link:hover { text-decoration: none; }
.op-cell-link:hover .op-k { filter: brightness(1.10); }

.op-k {
    display: inline-block; min-width: 1.4em; text-align: center;
    font-weight: 700; border-radius: 3px; color: #fff;
    font-size: 11px; padding: 1px 5px; line-height: 1.4;
}
.op-k-A { background: #d97706; }
.op-k-B { background: #a05a00; }
.op-k-C { background: #1d4fd2; }
.op-k-D { background: #1a6320; }
.op-k-E { background: #7c0a91; }

.small { font-size: 11px; }

/* ─── Inactive-Produkt-Zeile ────────────────────────────── */

tr.is-inactive            { opacity: 0.5; }
tr.is-inactive:hover      { opacity: 1; }
.inactive-tag {
    display: inline-block; margin: 2px 0;
    padding: 1px 8px; border-radius: 999px; font-size: 11px;
    background: #fadde1; color: var(--err); border: 1px solid #f0c2c8;
    text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600;
}

/* ════════════════════════════════════════════════════════════════════
   PHASE 1 — Design-System-Vereinheitlichung
   Tokens · Typografie · Buttons · Forms · Topbar · Debug-Tray
   Bewusst am Dateiende: überschreibt frühere Ad-hoc-Regeln, ohne
   bestehendes Markup anpacken zu müssen.
   ══════════════════════════════════════════════════════════════════════ */

:root {
    /* Spacing-Skala (4er-Raster) */
    --sp-1: 4px;   --sp-2: 8px;   --sp-3: 12px;  --sp-4: 16px;
    --sp-5: 24px;  --sp-6: 32px;  --sp-7: 48px;  --sp-8: 64px;

    /* Radius-Skala */
    --r-sm: 6px;   --r-md: 10px;  --r-lg: 14px;  --r-xl: 20px;
    --r-pill: 999px;

    /* Font-Skala (modular) */
    --fs-xs: 11px; --fs-sm: 12px; --fs-base: 14px; --fs-md: 15px;
    --fs-lg: 17px; --fs-xl: 21px; --fs-2xl: 28px; --fs-3xl: 38px;

    /* Schatten-Stufen */
    --sh-sm: 0 1px 2px rgba(15, 23, 42, 0.04);
    --sh-md: 0 2px 4px rgba(15, 23, 42, 0.05), 0 4px 12px rgba(15, 23, 42, 0.05);
    --sh-lg: 0 8px 24px rgba(15, 23, 42, 0.10);
    --sh-xl: 0 20px 60px rgba(15, 23, 42, 0.18);
    --sh-focus: 0 0 0 3px rgba(30, 99, 214, 0.22);

    /* Erweiterte Palette — der bestehende --accent bleibt unangetastet,
       neue warme Sekundärfarbe für CTAs und Highlights. */
    --bg-soft: #f1f3f6;
    --bg-elevated: #ffffff;
    --fg-strong: #0f172a;
    --fg-mid: #475569;
    --fg-soft: #64748b;
    --border-soft: #eef0f3;
    --border-strong: #d8dde4;

    --warm: #c2410c;       /* Terracotta-Akzent (sparsam, für „handeln") */
    --warm-soft: #fef3ec;
    --warm-border: #f3c7a8;

    --ok-soft: #ecfdf5;
    --warn-soft: #fffbeb;
    --err-soft: #fef2f2;

    /* Typo-Stacks — modern, strukturiert, kein Spiel. Eine Familie für
       Body + Headlines, Hierarchie nur über Weight, Tracking und Größe. */
    --font-display: "Inter Tight", -apple-system, "Segoe UI", system-ui, sans-serif;
    --font-body: "Inter Tight", -apple-system, "Segoe UI", system-ui, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;
}

/* ── Typografie ───────────────────────────────────────────────────── */

body {
    font: 400 var(--fs-base)/1.55 var(--font-body);
    background: var(--bg);
    color: var(--fg-strong);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
    font-family: var(--font-display);
    color: var(--fg-strong);
    line-height: 1.2;
    letter-spacing: -0.02em;
}
h1 { font-size: var(--fs-2xl); font-weight: 700; margin: 0 0 var(--sp-4); letter-spacing: -0.025em; }
h2 { font-size: var(--fs-xl); font-weight: 600; margin: var(--sp-6) 0 var(--sp-3); }
h3 { font-size: var(--fs-lg); font-weight: 600; margin: 0 0 var(--sp-2); letter-spacing: -0.015em; }
h4 { font-size: var(--fs-md); font-weight: 600; margin: 0 0 var(--sp-2); letter-spacing: -0.01em; }

code, pre, kbd, samp { font-family: var(--font-mono); }

/* Tabellen und Zahlenfelder bekommen Tabular-Numerals — Beträge
   richten sich am Komma aus. */
.data-table, .products-table, .cart-table,
.inline-price, .ek-select, .num,
.diff-ok, .diff-high, .diff-low,
.margin-pos, .margin-neg, .big-price,
td.num, .median-cell, .offer-grid .offer-price {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1, "cv11" 1;
}

/* ── Topbar mit klarer Hierarchie ─────────────────────────────────── */

/* TOPBAR — strikt einheitlicher 52px-Strip, alle Items 100% Höhe */
.topbar {
    display: flex;
    align-items: stretch;
    height: 52px;
    padding: 0 24px;
    gap: 24px;
    background: var(--bg-elevated);
    border-bottom: 1px solid var(--border-strong);
    position: sticky; top: 0; z-index: 50;
}
.topbar > .brand,
.topbar > .user-chip { display: inline-flex; align-items: center; height: 100%; }
.topbar > .mainnav { flex: 1; min-width: 0; }
.brand {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 700;
    letter-spacing: -0.025em;
    color: var(--fg-strong);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.brand::before {
    content: '';
    display: inline-block;
    width: 22px; height: 22px;
    border-radius: 6px;
    background:
      linear-gradient(135deg, var(--accent) 0%, #6366f1 60%, var(--warm) 110%);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.15), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.brand:hover { text-decoration: none; color: var(--accent); }

.mainnav { gap: var(--sp-1); }
/* TOPBAR NAV — alle Items volle Topbar-Höhe, identische Optik */
.mainnav {
    display: flex;
    align-items: stretch;
    gap: 0;
    height: 100%;
}
.nav-group { display: inline-flex; align-items: stretch; height: 100%; position: relative; }

.mainnav > a, .nav-group-head {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 100%;
    padding: 0 14px;
    margin: 0;
    border: none;
    background: transparent;
    box-shadow: inset 0 -2px 0 transparent;
    font: 500 14px/1 var(--font-body);
    color: var(--fg-mid);
    letter-spacing: -0.005em;
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
    text-decoration: none;
    transition: color 0.12s, box-shadow 0.12s;
}
.mainnav > a:hover, .nav-group-head:hover {
    color: var(--fg-strong);
    background: transparent;
    text-decoration: none;
}
.mainnav .caret {
    flex: 0 0 auto;
    opacity: 0.45;
    color: currentColor;
    transition: transform 0.15s, opacity 0.15s;
}
.nav-group:hover .caret, .nav-group:focus-within .caret { opacity: 0.9; }
.nav-group:hover .caret, .nav-group[open] .caret { transform: rotate(180deg); }

/* Aktiver Eintrag: dunkler Text + 2px-Underline DIREKT am Item-Boden
   (durch box-shadow inset, fluchtet exakt mit der Topbar-Border) */
.mainnav > a.active,
.nav-group.active > .nav-group-head {
    color: var(--fg-strong);
    font-weight: 600;
    box-shadow: inset 0 -2px 0 var(--fg-strong);
}

/* Aktive Section: wir wissen welche Seite aktiv ist anhand der URL
   nicht direkt, aber dezentes Hover-Verhalten reicht aus. Wenn später
   pro Seite eine Klasse gesetzt wird, übernehmen wir hier den
   sichtbaren Marker. */
.mainnav > a:focus-visible, .nav-group-head:focus-visible {
    outline: none;
    box-shadow: var(--sh-focus);
}

.nav-group-menu {
    border-radius: var(--r-md);
    padding: var(--sp-2);
    box-shadow: var(--sh-lg);
    border-color: var(--border-strong);
    min-width: 240px;
}
.nav-group-menu a {
    padding: var(--sp-2) var(--sp-3);
    border-radius: var(--r-sm);
    font-size: var(--fs-base);
}
.nav-group-menu a:hover { background: var(--bg-soft); color: var(--accent); }

.user-chip { gap: var(--sp-2); font-size: var(--fs-sm); }
.user-name { font-weight: 600; color: var(--fg-strong); }
.user-role {
    font-size: 10px; padding: 2px 7px;
    background: var(--bg-soft); color: var(--fg-mid);
    border-radius: var(--r-pill);
    font-weight: 600;
}
.user-logout {
    padding: var(--sp-1) var(--sp-2);
    border-radius: var(--r-sm);
    color: var(--fg-soft);
}
.user-logout:hover { background: var(--bg-soft); color: var(--err); text-decoration: none; }

/* Debug-Toggle (eingeloggte User) */
.debug-toggle {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 10px;
    background: var(--bg-soft);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-pill);
    font: 500 var(--fs-xs)/1 var(--font-body);
    color: var(--fg-soft);
    cursor: pointer;
    transition: all 0.12s;
}
.debug-toggle:hover { color: var(--fg-strong); border-color: var(--border-strong); }
.debug-toggle__dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #cbd5e1;
    transition: background 0.12s, box-shadow 0.12s;
}
body[data-debug="on"] .debug-toggle {
    background: #fff7e6;
    border-color: #f3d68a;
    color: #92400e;
}
body[data-debug="on"] .debug-toggle__dot {
    background: #f59e0b;
    box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.18);
}

/* ── Content-Wrapper ──────────────────────────────────────────────── */

.content { padding: 0 var(--sp-5) var(--sp-7); margin: var(--sp-6) auto; }

/* ── Hero / Login ─────────────────────────────────────────────────── */

.hero, .login-hero {
    padding: var(--sp-7);
    border-radius: var(--r-lg);
    border: 1px solid var(--border-soft);
    box-shadow: var(--sh-md);
    background:
      radial-gradient(circle at 100% 0%, rgba(30, 99, 214, 0.06), transparent 50%),
      radial-gradient(circle at 0% 100%, rgba(194, 65, 12, 0.05), transparent 50%),
      var(--bg-elevated);
}
.hero h1, .login-hero h1 {
    font-family: var(--font-display);
    font-size: var(--fs-3xl);
    font-weight: 600;
}

/* ── Buttons: ein System, vier Rollen ─────────────────────────────── */

.button, .button.primary,
.batch-bar button, .filter-bar button,
.job-form button, .awin-form button,
.modal-actions button {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    height: 36px;
    padding: 0 var(--sp-4);
    border-radius: var(--r-sm);
    background: var(--accent);
    color: #fff;
    font: 600 var(--fs-base)/1 var(--font-body);
    border: 1px solid var(--accent);
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s, transform 0.06s, box-shadow 0.12s;
    box-shadow: var(--sh-sm);
}
.button:hover, .button.primary:hover,
.batch-bar button:hover, .filter-bar button:hover,
.job-form button:hover:not([disabled]), .awin-form button:hover {
    background: var(--accent-hover);
    border-color: var(--accent-hover);
    color: #fff;
    text-decoration: none;
}
.button:active { transform: translateY(1px); }
.button:focus-visible { outline: none; box-shadow: var(--sh-focus); }

.button-secondary, .amz-btn, .pager-btn, .pager-num,
.cat-action, .filter-pill {
    height: 32px;
    padding: 0 var(--sp-3);
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--bg-elevated);
    color: var(--fg-strong);
    border: 1px solid var(--border-strong);
    border-radius: var(--r-sm);
    font: 500 var(--fs-sm)/1 var(--font-body);
    cursor: pointer;
    transition: all 0.12s;
    box-shadow: var(--sh-sm);
}
.button-secondary:hover, .amz-btn:hover, .pager-btn:hover, .pager-num:hover {
    background: var(--bg-soft);
    border-color: var(--accent);
    color: var(--accent);
    text-decoration: none;
}
.button-secondary:focus-visible, .amz-btn:focus-visible {
    outline: none; box-shadow: var(--sh-focus);
}

.button-danger {
    height: 32px; padding: 0 var(--sp-3);
    background: var(--bg-elevated); color: var(--err);
    border: 1px solid #f0c2c8;
    border-radius: var(--r-sm);
    font: 500 var(--fs-sm)/1 var(--font-body);
    display: inline-flex; align-items: center; gap: 6px;
    transition: all 0.12s;
}
.button-danger:hover { background: var(--err); color: #fff; border-color: var(--err); }

/* Disabled für alle Button-Varianten */
.button[disabled], .job-form button[disabled],
.button-secondary[disabled], .amz-btn[disabled] {
    opacity: 0.55; cursor: not-allowed;
    background: var(--bg-soft); color: var(--fg-soft); border-color: var(--border-strong);
    box-shadow: none;
}

/* Ghost / Link-Buttons (z.B. „Notes / Log"-Summaries) bleiben unangetastet,
   bekommen aber konsistenten Focus-Ring. */
button:focus-visible, a:focus-visible {
    outline: none;
    box-shadow: var(--sh-focus);
    border-radius: var(--r-sm);
}

/* ── Form-Elemente: eine Höhe, eine Optik ─────────────────────────── */

input[type="text"], input[type="search"], input[type="email"],
input[type="password"], input[type="number"], input[type="date"],
input[type="url"], input[type="tel"], select, textarea {
    height: 36px;
    padding: 0 var(--sp-3);
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--r-sm);
    font: 400 var(--fs-base)/1.4 var(--font-body);
    color: var(--fg-strong);
    transition: border-color 0.12s, box-shadow 0.12s, background 0.12s;
    box-shadow: var(--sh-sm) inset;
}
textarea {
    height: auto;
    min-height: 80px;
    padding: var(--sp-2) var(--sp-3);
    line-height: 1.5;
    resize: vertical;
}
select {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--sp-3) center;
    background-size: 12px 8px;
    padding-right: var(--sp-6);
}

input:hover, select:hover, textarea:hover { border-color: #94a3b8; }
input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: var(--sh-focus);
    background: var(--bg-elevated);
}
input:disabled, select:disabled, textarea:disabled {
    background: var(--bg-soft); color: var(--fg-soft); cursor: not-allowed;
}

/* Number-Inputs in Tabellen kompakter — sonst sprengen sie die Zellen */
.cart-table input[type="number"], .products-table input[type="number"],
.qty-input, .inline-price {
    height: 28px; padding: 0 var(--sp-2);
    text-align: right;
    box-shadow: none;
}

/* Form-Sections (fieldset.form-section im Item-Editor) aufräumen */
fieldset.form-section {
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    padding: var(--sp-4) var(--sp-5);
    margin: 0 0 var(--sp-4);
    background: var(--bg-elevated);
    box-shadow: var(--sh-sm);
}
fieldset.form-section legend {
    padding: 0 var(--sp-2);
    font: 600 var(--fs-sm)/1 var(--font-body);
    color: var(--fg-mid);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--sp-3) var(--sp-4);
    margin: var(--sp-3) 0;
}
.form-grid label, .sourcing-item-form label {
    display: flex; flex-direction: column; gap: var(--sp-1);
    font: 500 var(--fs-sm)/1.3 var(--font-body);
    color: var(--fg-mid);
}

/* ── Cards · Tiles · Tabellen ─────────────────────────────────────── */

.tile, .import-grid .card, .detail-grid .card,
.awin-product, .awin-stats, section.variant-group, .awin-form {
    border-radius: var(--r-md);
    border: 1px solid var(--border-soft);
    box-shadow: var(--sh-sm);
}
.tile { transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease; }
.tile:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh-md);
    border-color: var(--accent);
}
.tile h3 {
    font-family: var(--font-display);
    font-size: var(--fs-md);
    font-weight: 600;
    letter-spacing: -0.015em;
}

.data-table, .products-table, .cart-table {
    border-radius: var(--r-md);
    overflow: hidden;
    box-shadow: var(--sh-sm);
    font-size: var(--fs-base);
}
.data-table th, .products-table th, .cart-table th {
    background: var(--bg-soft);
    font: 600 var(--fs-xs)/1.4 var(--font-body);
    color: var(--fg-mid);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: var(--sp-3);
}
.data-table td, .products-table td, .cart-table td { padding: var(--sp-3); }
.data-table tbody tr:hover, .products-table tbody tr:hover { background: var(--bg-soft); }

/* ── Flash / Toast ────────────────────────────────────────────────── */

.flash {
    border-radius: var(--r-md);
    padding: var(--sp-3) var(--sp-4);
    font-size: var(--fs-base);
    box-shadow: var(--sh-sm);
}
.flash-success { background: var(--ok-soft); border-color: #a7f3d0; color: #047857; }
.flash-error   { background: var(--err-soft); border-color: #fecaca; color: #b91c1c; }
.flash-warning { background: var(--warn-soft); border-color: #fde68a; color: #92400e; }

/* ── Pills allgemein dezenter ─────────────────────────────────────── */

.pill {
    padding: 3px 9px;
    font-size: 10px;
    letter-spacing: 0.06em;
}

/* ── SQL-Debug & Dev-Panes: globale Sichtbarkeit + Bottom-Tray ───── */

/* Bestehende inline-Styles aus db.php überschreiben.
   Selektorgewicht hoch genug, da .debug-tray > .sql-debug. */
.debug-tray {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 40;
    pointer-events: none;
    display: flex;
    justify-content: center;
    padding: 0 var(--sp-4) var(--sp-3);
}
.debug-tray > .sql-debug,
.debug-tray > .sql-debug-empty {
    pointer-events: auto;
    margin: 0;
    max-width: 1200px;
    width: 100%;
    background: rgba(15, 17, 25, 0.96);
    color: #cdd6f4;
    border-radius: var(--r-md);
    padding: var(--sp-2) var(--sp-3);
    font-size: var(--fs-sm);
    box-shadow: var(--sh-lg);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255, 255, 255, 0.06);
    transition: opacity 0.15s, transform 0.15s;
}
.debug-tray > .sql-debug summary {
    padding: var(--sp-1) var(--sp-1);
    font-size: var(--fs-sm);
    color: #cdd6f4;
}
.debug-tray > .sql-debug[open] {
    max-height: 60vh;
    overflow: auto;
    padding: var(--sp-3) var(--sp-4);
}

/* Wenn Debug AUS ist: sämtliche Dev-Panes verstecken */
body[data-debug="off"] [data-dev-pane],
body[data-debug="off"] .debug-tray,
body[data-debug="off"] .sql-debug,
body[data-debug="off"] .sql-debug-empty {
    display: none !important;
}
body[data-debug="off"] main { padding-bottom: 0; }

/* Wenn Debug AN: Tray sichtbar; Hauptinhalt bekommt unten Luft */
body[data-debug="on"] main { padding-bottom: var(--sp-7); }

/* ── Wareneinkauf: Dashboard-KPI-Band + kompakte Stage-Heads ────── */

.page-head--dashboard {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: var(--sp-4);
    margin: 0 0 var(--sp-3);
}
.page-head__main { flex: 1; min-width: 0; }
.page-head__main h1 {
    font-size: var(--fs-2xl);
    font-weight: 700;
    letter-spacing: -0.03em;
    margin: 0 0 4px;
}
.page-head__hint {
    margin: 0;
    color: var(--fg-soft);
    font-size: var(--fs-sm);
    line-height: 1.4;
}

/* KPI-Band — die zentrale „Was ist zu tun?"-Übersicht */
.kpi-band {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-3);
    margin: 0 0 var(--sp-6);
}
.kpi {
    display: grid;
    grid-template-rows: auto auto 1fr auto;
    gap: var(--sp-1);
    padding: var(--sp-4) var(--sp-5);
    min-height: 138px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    color: var(--fg-strong);
    text-decoration: none;
    transition: transform 0.14s, box-shadow 0.16s, border-color 0.16s;
    box-shadow: var(--sh-sm);
    position: relative;
    overflow: hidden;
}
.kpi:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh-md);
    text-decoration: none;
}
.kpi__top {
    display: flex; align-items: baseline; gap: var(--sp-3);
}
.kpi__num {
    font-size: 44px;
    font-weight: 700;
    letter-spacing: -0.04em;
    line-height: 1;
    font-variant-numeric: tabular-nums;
    color: var(--fg-strong);
}
.kpi__step {
    font: 600 var(--fs-xs)/1 var(--font-body);
    color: var(--fg-soft);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.kpi__label {
    font: 600 var(--fs-md)/1.2 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.012em;
    margin-top: 2px;
}
.kpi__sub {
    font-size: var(--fs-sm);
    color: var(--fg-mid);
    line-height: 1.4;
}
.kpi__sub strong {
    font-weight: 600;
    color: var(--fg-strong);
    font-variant-numeric: tabular-nums;
}
.kpi__hint {
    font-size: var(--fs-xs);
    color: var(--fg-soft);
}
.kpi__cta {
    font: 600 var(--fs-sm)/1 var(--font-body);
    color: var(--accent);
    margin-top: var(--sp-2);
    letter-spacing: -0.005em;
    min-height: 16px;
}

/* Akzent-Linie oben als 4. visuelle Kodierung */
.kpi::before {
    content: '';
    position: absolute;
    left: 0; right: 0; top: 0;
    height: 3px;
    background: transparent;
}
.kpi--pool.is-action {
    border-color: rgba(225, 29, 72, 0.20);
    background:
      radial-gradient(circle at 100% 0%, rgba(225, 29, 72, 0.06), transparent 55%),
      var(--bg-elevated);
}
.kpi--pool.is-action::before { background: linear-gradient(90deg, #e11d48, #f43f5e); }
.kpi--pool.is-action .kpi__num { color: #be123c; }
.kpi--pool.is-action .kpi__cta { color: #be123c; }

.kpi--listen.is-action {
    border-color: rgba(30, 99, 214, 0.22);
    background:
      radial-gradient(circle at 100% 0%, rgba(30, 99, 214, 0.06), transparent 55%),
      var(--bg-elevated);
}
.kpi--listen.is-action::before { background: linear-gradient(90deg, var(--accent), #4f7df5); }
.kpi--listen.is-action .kpi__num { color: var(--accent); }
.kpi--listen.is-action .kpi__cta { color: var(--accent); }

.kpi--bestellt.is-action {
    border-color: rgba(217, 119, 6, 0.25);
    background:
      radial-gradient(circle at 100% 0%, rgba(217, 119, 6, 0.07), transparent 55%),
      var(--bg-elevated);
}
.kpi--bestellt.is-action::before { background: linear-gradient(90deg, #d97706, #f59e0b); }
.kpi--bestellt.is-action .kpi__num { color: #b45309; }
.kpi--bestellt.is-action .kpi__cta { color: #b45309; }

/* Idle-State: matt, kein Druck */
.kpi.is-idle {
    background: var(--bg);
    border-style: dashed;
    border-color: var(--border-strong);
    color: var(--fg-soft);
}
.kpi.is-idle .kpi__num { color: #94a3b8; font-weight: 600; }
.kpi.is-idle .kpi__label { color: var(--fg-mid); }
.kpi.is-idle .kpi__cta { color: transparent; }
.kpi.is-idle:hover { border-style: solid; }

/* ── ToDo-Nav: Sidebar-Workflow-Auswahl ─────────────────────────── */

.todo-nav {
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    overflow: hidden;
    box-shadow: var(--sh-sm);
}
.todo-nav__head {
    padding: 10px var(--sp-3);
    font: 700 10px/1 var(--font-body);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fg-soft);
    background: var(--bg-soft);
    border-bottom: 1px solid var(--border-soft);
}
.todo-nav__row {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    padding: 12px var(--sp-3);
    border-bottom: 1px solid var(--border-soft);
    color: var(--fg-strong);
    text-decoration: none;
    cursor: pointer;
    position: relative;
    transition: background 0.12s, padding 0.12s;
}
.todo-nav__row:last-child { border-bottom: none; }
.todo-nav__row:hover { background: var(--bg-soft); text-decoration: none; }

/* Aktive Auswahl — linker farbiger Balken + heller Hintergrund */
.todo-nav__row.is-active {
    background: rgba(15, 23, 42, 0.035);
    padding-left: calc(var(--sp-3) + 3px);
}
.todo-nav__row.is-active::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--fg-strong);
}
.todo-nav__row.is-active .todo-nav__label { font-weight: 600; }

.todo-nav__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--border-strong);
    flex: 0 0 8px;
}
.todo-nav__dot--pool     { background: #e11d48; }
.todo-nav__dot--listen   { background: var(--accent); }
.todo-nav__dot--bestellt { background: #d97706; }
.todo-nav__dot--done     { background: #94a3b8; }

.todo-nav__main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.todo-nav__label {
    font: 500 var(--fs-sm)/1.2 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.005em;
}
.todo-nav__sub {
    font-size: 11px;
    color: var(--fg-soft);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.todo-nav__count {
    min-width: 24px;
    height: 22px;
    padding: 0 7px;
    border-radius: var(--r-pill);
    font: 700 var(--fs-sm)/22px var(--font-body);
    text-align: center;
    flex: 0 0 auto;
    font-variant-numeric: tabular-nums;
}
.todo-nav__count--pool     { background: #fef2f2; color: #b91c1c; }
.todo-nav__count--listen   { background: rgba(30, 99, 214, 0.12); color: var(--accent); }
.todo-nav__count--bestellt { background: var(--warn-soft); color: #b45309; }
.todo-nav__count--done     { background: var(--bg-soft); color: var(--fg-soft); font-weight: 600; }
.todo-nav__count.is-zero   { background: var(--bg-soft); color: #cbd5e1; }

.todo-nav__row--archive { background: var(--bg); }

/* ── Workspace single-column (vereinfacht — Tab-Nav übernimmt) ──── */

.workspace--single { display: block; }

/* Legacy workspace-Sidebar (falls noch genutzt) */
.workspace {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: var(--sp-4);
    align-items: start;
}
.workspace__sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    position: sticky;
    top: 60px;
    max-height: calc(100vh - 80px);
    overflow-y: auto;
}
.workspace__main { min-width: 0; }
@media (max-width: 1100px) {
    .workspace { grid-template-columns: 1fr; }
    .workspace__sidebar { position: static; max-height: none; }
}

/* ════════════════════════════════════════════════════════════════════
   BEDARFSPLANUNG (recommendation.php) — Page-Head + Context + Stats
   Räumt den bisherigen Inline-Style-Wirrwarr im Header auf.
   ══════════════════════════════════════════════════════════════════════ */

.page-head .page-head__row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-4);
    flex-wrap: wrap;
}
.page-head__title-wrap { flex: 1; min-width: 0; }
.page-head__actions {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    flex-wrap: wrap;
}

/* Banner für "Neu berechnet"-Meldung — als ruhige Pille */
.rec-banner {
    display: inline-flex;
    align-items: center;
    padding: 5px 10px;
    border-radius: var(--r-sm);
    font: 500 12px/1.2 var(--font-body);
    border: 1px solid;
}
.rec-banner--flash-success { background: var(--ok-soft); color: #047857; border-color: #a7f3d0; }
.rec-banner--flash-info    { background: var(--bg-soft); color: var(--fg-mid); border-color: var(--border-strong); }

/* btn-light: dezenter Ghost-Button für Header-Actions */
.btn-light {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 32px;
    padding: 0 12px;
    background: var(--bg-elevated);
    color: var(--fg-strong);
    border: 1px solid var(--border-strong);
    border-radius: var(--r-sm);
    font: 500 13px/1 var(--font-body);
    text-decoration: none;
    cursor: pointer;
    transition: all 0.12s;
    white-space: nowrap;
}
.btn-light:hover {
    background: var(--bg-soft);
    border-color: var(--fg-mid);
    color: var(--fg-strong);
    text-decoration: none;
}
.btn-light--accent { color: var(--accent); border-color: rgba(30, 99, 214, 0.25); }
.btn-light--accent:hover { background: rgba(30, 99, 214, 0.06); border-color: var(--accent); color: var(--accent); }

/* ── Context-Bar: Saison + Vergleichsfenster (kompakte Info-Reihe) ── */

.rec-context {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    margin: 0 0 var(--sp-4);
    overflow: hidden;
    box-shadow: var(--sh-sm);
}
.rec-context__item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-right: 1px solid var(--border-soft);
    font-size: 13px;
    white-space: nowrap;
}
.rec-context__item:last-of-type { border-right: none; }
.rec-context__label {
    font: 600 10px/1 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--fg-soft);
}
.rec-context__value {
    font-weight: 600;
    color: var(--fg-strong);
    font-variant-numeric: tabular-nums;
}
.rec-context__value small { font-weight: 400; color: var(--fg-soft); margin-left: 4px; }
.rec-context__value--warn { color: #b45309; }
.rec-context__chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 7px;
    margin-left: 6px;
    border-radius: var(--r-pill);
    font: 600 11px/1 var(--font-body);
    border: 1px solid;
}
.rec-context__chip--warn { background: var(--warn-soft); color: #92400e; border-color: #fde68a; }
.rec-context__chip--ok   { background: var(--ok-soft); color: #047857; border-color: #a7f3d0; }
.rec-context__edit {
    width: 24px; height: 24px;
    background: transparent;
    border: 1px solid var(--border-strong);
    border-radius: 4px;
    color: var(--fg-mid);
    cursor: pointer;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.12s;
}
.rec-context__edit:hover { border-color: var(--accent); color: var(--accent); }
.rec-context__details {
    flex: 1;
    border-left: 1px solid var(--border-soft);
    background: var(--bg-soft);
}
.rec-context__details > summary {
    padding: 10px 16px;
    cursor: pointer;
    list-style: none;
    font-size: 12px;
    color: var(--fg-soft);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    user-select: none;
}
.rec-context__details > summary::-webkit-details-marker { display: none; }
.rec-context__details > summary::before {
    content: '▸';
    transition: transform 0.15s;
    font-size: 10px;
}
.rec-context__details[open] > summary::before { transform: rotate(90deg); }
.rec-context__details-body {
    padding: 0 16px 12px;
    font-size: 12px;
    color: var(--fg-mid);
    display: flex;
    flex-direction: column;
    gap: 4px;
    line-height: 1.6;
}
.rec-context__details-body strong { color: var(--fg-strong); font-weight: 600; }
.rec-context__details-body small { color: var(--fg-soft); }
.rec-context__details-body .muted { opacity: 0.85; }

/* ── Stats: 3 große Zahlen + Status-Pills, klar getrennt ───────── */

.rec-stats {
    display: flex;
    align-items: center;
    gap: var(--sp-5);
    flex-wrap: wrap;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    padding: 14px 20px;
    margin: 0 0 var(--sp-4);
    box-shadow: var(--sh-sm);
}

/* Inline-Variante: Stats sitzen direkt im Page-Head zwischen Titel & Actions */
.rec-stats--inline {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
    flex: 1;
    justify-content: center;
    gap: var(--sp-4);
}
.rec-stats--inline .rec-stats__main {
    gap: var(--sp-4);
    padding-right: var(--sp-4);
}
.rec-stats--inline .rec-stat { min-width: auto; }
.rec-stats--inline .rec-stat__num { font-size: 19px; }
.rec-stats--inline .rec-stat__label { font-size: 10px; letter-spacing: 0.05em; }
.rec-stats--inline .rec-status-pill { padding: 4px 9px; font-size: 11px; }

/* Page-Head-Row mit Stats: alle 3 Bereiche zentriert ausgerichtet */
.page-head--with-stats .page-head__row {
    align-items: center;
    gap: var(--sp-4);
}
.page-head--with-stats .page-head__title-wrap { flex: 0 0 auto; min-width: 200px; }
.page-head--with-stats .page-head__actions { flex: 0 0 auto; }

@media (max-width: 1280px) {
    .page-head--with-stats .page-head__row { flex-wrap: wrap; }
    .rec-stats--inline { flex-basis: 100%; order: 3; justify-content: flex-start; }
}

.rec-stats__main {
    display: flex;
    gap: var(--sp-6);
    flex-wrap: wrap;
    padding-right: var(--sp-5);
    border-right: 1px solid var(--border-soft);
}
.rec-stat {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 90px;
}
.rec-stat__num {
    font: 700 22px/1 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.025em;
    font-variant-numeric: tabular-nums;
}
.rec-stat__label {
    font-size: 11px;
    color: var(--fg-soft);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}
.rec-stats__status {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.rec-status-pill {
    display: inline-flex;
    align-items: center;
    padding: 5px 11px;
    border-radius: var(--r-pill);
    font: 600 12px/1 var(--font-body);
    border: 1px solid;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.005em;
}
.rec-status-pill--blue   { background: rgba(30, 99, 214, 0.10); color: var(--accent); border-color: rgba(30, 99, 214, 0.25); }
.rec-status-pill--green  { background: var(--ok-soft); color: #047857; border-color: #a7f3d0; }
.rec-status-pill--orange { background: var(--warn-soft); color: #92400e; border-color: #fde68a; }
.rec-status-pill--grey   { background: var(--bg-soft); color: var(--fg-soft); border-color: var(--border-strong); }
.rec-status-pill.is-zero {
    background: transparent;
    color: var(--fg-soft);
    border-color: var(--border-soft);
    opacity: 0.6;
}

/* ── Filter-Form: kompakt, alle Felder eine Höhe ──────────────── */

.rec-filter {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin: 0 0 var(--sp-3);
    padding: 12px 16px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
}
.rec-filter select,
.rec-filter input[type="text"],
.rec-filter input[type="search"],
.rec-filter input[type="number"] {
    height: 32px;
    padding: 0 10px;
    border: 1px solid var(--border-strong);
    border-radius: var(--r-sm);
    background: var(--bg-elevated);
    font: 400 13px/1.2 var(--font-body);
    color: var(--fg-strong);
}
.rec-filter select:focus,
.rec-filter input:focus { outline: none; border-color: var(--accent); box-shadow: var(--sh-focus); }
.rec-filter button[type="submit"] {
    height: 32px;
    padding: 0 16px;
    background: var(--accent);
    color: #fff;
    border: 1px solid var(--accent);
    border-radius: var(--r-sm);
    font: 600 13px/1 var(--font-body);
    cursor: pointer;
    transition: background 0.12s;
}
.rec-filter button[type="submit"]:hover { background: var(--accent-hover); }

/* "Filter dropdown" details/summary (.fd / .fd-panel) — minimal aufräumen */
.rec-filter details.fd { position: relative; }
.rec-filter details.fd > summary {
    height: 32px;
    padding: 0 12px;
    border: 1px solid var(--border-strong);
    border-radius: var(--r-sm);
    background: var(--bg-elevated);
    cursor: pointer;
    list-style: none;
    font-size: 13px;
    color: var(--fg-strong);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.rec-filter details.fd > summary::-webkit-details-marker { display: none; }
.rec-filter details.fd[open] > summary { border-color: var(--accent); color: var(--accent); }
.fd-badge {
    background: var(--accent);
    color: #fff;
    font: 700 10px/1 var(--font-body);
    padding: 2px 6px;
    border-radius: var(--r-pill);
    margin-left: 4px;
}
.fd-panel {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    z-index: 60;
    min-width: 240px;
    padding: 12px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--r-md);
    box-shadow: var(--sh-lg);
}

/* "Zurücksetzen"-Link */
.rec-filter .filter-reset {
    color: var(--fg-soft);
    font-size: 12px;
    margin-left: 4px;
    text-decoration: none;
}
.rec-filter .filter-reset:hover { color: var(--err); text-decoration: none; }

/* Alte .kpi-Klasse muss noch existieren für Fallback */
.kpis { display: none; }

/* ── Minimal Page-Head + GitHub-Style Tab-Nav ─────────────────── */

.page-head--minimal {
    margin: 0 0 var(--sp-4);
    padding: 0;
}
.page-head--minimal h1 {
    font-size: 22px;
    font-weight: 600;
    letter-spacing: -0.025em;
    margin: 0;
    color: var(--fg-strong);
}

/* GitHub/Linear-Style Tabs: Label + Count, Underline bei aktiv. Mehr nicht. */
.tab-nav {
    display: flex;
    gap: 2px;
    border-bottom: 1px solid var(--border-strong);
    margin: 0 0 var(--sp-4);
    overflow-x: auto;
}
.tab-nav__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    cursor: pointer;
    font: 500 14px/1 var(--font-body);
    color: var(--fg-mid);
    letter-spacing: -0.005em;
    transition: color 0.12s, border-color 0.12s, background 0.12s;
    border-radius: 6px 6px 0 0;
    white-space: nowrap;
}
.tab-nav__btn:hover {
    color: var(--fg-strong);
    background: var(--bg-soft);
}
.tab-nav__btn:focus-visible {
    outline: none;
    background: var(--bg-soft);
    box-shadow: 0 0 0 2px var(--accent) inset;
}
.tab-nav__btn.is-active {
    color: var(--fg-strong);
    font-weight: 600;
    border-bottom-color: var(--fg-strong);
}

.tab-nav__count {
    min-width: 20px;
    height: 20px;
    padding: 0 7px;
    border-radius: 10px;
    background: var(--bg-soft);
    color: var(--fg-soft);
    font: 600 11px/20px var(--font-body);
    font-variant-numeric: tabular-nums;
    text-align: center;
    border: 1px solid var(--border-soft);
}
.tab-nav__btn.is-active .tab-nav__count {
    background: var(--fg-strong);
    color: #fff;
    border-color: var(--fg-strong);
}
.tab-nav__count.is-action:not(.is-zero) {
    /* Aktiv-bedürftige Counts dezent rot kennzeichnen */
    background: #fee2e2;
    color: #b91c1c;
    border-color: #fecaca;
}
.tab-nav__btn.is-active .tab-nav__count.is-action {
    background: #b91c1c;
    color: #fff;
    border-color: #b91c1c;
}

/* Topbar-Kbd-Trigger — dezenter Helper in der Topbar */
.topbar-kbd {
    width: 24px; height: 24px;
    border-radius: 50%;
    background: transparent;
    border: 1px solid var(--border-strong);
    color: var(--fg-soft);
    font: 600 12px/1 var(--font-mono);
    cursor: pointer;
    transition: all 0.12s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.topbar-kbd:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: var(--bg-soft);
}

/* ws-tabs (alte Variante) deaktivieren falls noch im DOM */
.ws-tabs { display: none; }

/* Stage-Toolbar war redundant — falls noch vorhanden, ausblenden */
.stage-toolbar { display: none; }

/* ── ws-tabs: Primäre Workflow-Navigation (Pool/Listen/WE/Archiv) ── */

.ws-tabs {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--border-soft);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    overflow: hidden;
    margin: 0 0 var(--sp-5);
    box-shadow: var(--sh-sm);
}
.ws-tab {
    background: var(--bg-elevated);
    border: none;
    padding: var(--sp-4) var(--sp-4);
    cursor: pointer;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: background 0.14s, box-shadow 0.14s;
    position: relative;
    font: inherit;
    color: inherit;
}
.ws-tab:hover { background: var(--bg-soft); }
.ws-tab:focus-visible { outline: none; box-shadow: inset 0 0 0 2px var(--accent); z-index: 2; }

.ws-tab__head {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
}
.ws-tab__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--border-strong);
    flex: 0 0 8px;
}
.ws-tab--pool .ws-tab__dot     { background: #e11d48; }
.ws-tab--listen .ws-tab__dot   { background: var(--accent); }
.ws-tab--bestellt .ws-tab__dot { background: #d97706; }
.ws-tab--archiv .ws-tab__dot   { background: #94a3b8; }

.ws-tab__label {
    flex: 1;
    font: 600 var(--fs-md)/1.2 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.015em;
}
.ws-tab__count {
    min-width: 28px;
    height: 26px;
    padding: 0 9px;
    border-radius: var(--r-pill);
    font: 700 var(--fs-sm)/26px var(--font-body);
    text-align: center;
    flex: 0 0 auto;
    font-variant-numeric: tabular-nums;
    background: var(--bg-soft);
    color: var(--fg-soft);
}
.ws-tab--pool .ws-tab__count:not(.is-zero)     { background: #fee2e2; color: #b91c1c; }
.ws-tab--listen .ws-tab__count:not(.is-zero)   { background: rgba(30, 99, 214, 0.12); color: var(--accent); }
.ws-tab--bestellt .ws-tab__count:not(.is-zero) { background: #fef3c7; color: #b45309; }
.ws-tab__count.is-zero { background: var(--bg-soft); color: #cbd5e1; }
.ws-tab__sub {
    font-size: var(--fs-xs);
    color: var(--fg-soft);
    line-height: 1.4;
    padding-left: 16px;
    font-variant-numeric: tabular-nums;
}

/* Aktiver Tab: klarer Indikator unten + dunklerer Hintergrund */
.ws-tab.is-active {
    background: var(--bg-elevated);
}
.ws-tab.is-active::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 3px;
}
.ws-tab--pool.is-active::after     { background: #e11d48; }
.ws-tab--listen.is-active::after   { background: var(--accent); }
.ws-tab--bestellt.is-active::after { background: #d97706; }
.ws-tab--archiv.is-active::after   { background: #94a3b8; }
.ws-tab.is-active .ws-tab__label { color: var(--fg-strong); }

/* Page-Head „lean" (ohne Dashboard-Gewicht) */
.page-head--lean {
    margin: 0 0 var(--sp-4);
}
.page-head--lean h1 {
    font-size: var(--fs-2xl);
    font-weight: 700;
    letter-spacing: -0.028em;
    margin: 0 0 4px;
}
.page-head--lean .page-head__hint {
    margin: 0;
    color: var(--fg-soft);
    font-size: var(--fs-sm);
}
.page-head--lean .page-head__hint strong {
    color: var(--fg-strong);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

/* Stage-Toolbars im Panel verschlanken — der Tab sagt schon, was los ist */
.stage-toolbar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--sp-4);
    margin: 0 0 var(--sp-3);
    padding: 0;
    border: none;
}
.stage-toolbar__title h2 {
    font-size: var(--fs-lg);
    font-weight: 600;
    letter-spacing: -0.018em;
    margin: 0;
}
.stage-toolbar__title p { display: none; } /* Subtitle redundant zum Tab-Sub */

@media (max-width: 820px) {
    .ws-tabs { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .ws-tabs { grid-template-columns: 1fr; }
    .ws-tab__sub { padding-left: 0; }
}

/* Panels — diskrete Daten-Container mit farbigem Header-Bar
   (analog Shopify / PrestaShop Admin Sidebar-Widgets). */
.panel {
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    overflow: hidden;
    box-shadow: var(--sh-sm);
}
.panel__head {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    padding: 10px var(--sp-3);
    background: linear-gradient(180deg, #334155 0%, #1e293b 100%);
    color: #f1f5f9;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
.panel__head h3 {
    margin: 0;
    font-size: var(--fs-sm);
    font-weight: 600;
    letter-spacing: -0.008em;
    color: inherit;
    flex: 1;
}
.panel__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px; height: 20px;
    opacity: 0.85;
}

.panel__head--pool {
    background: linear-gradient(180deg, #be123c 0%, #9f1239 100%);
}
.panel__head--accent {
    background: linear-gradient(180deg, var(--accent) 0%, #1750ad 100%);
}
.panel__head--neutral {
    background: linear-gradient(180deg, #475569 0%, #334155 100%);
}
.panel__head--warn {
    background: linear-gradient(180deg, #b45309 0%, #92400e 100%);
}
.panel__head--ok {
    background: linear-gradient(180deg, #047857 0%, #065f46 100%);
}

.panel__body { padding: 0; }
.panel__empty {
    padding: var(--sp-3) var(--sp-4);
    margin: 0;
    color: var(--fg-soft);
    font-size: var(--fs-sm);
    font-style: italic;
}

/* Panel-Rows — kompakte Listen-Items (Label links, Zahl rechts) */
.panel-row {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    padding: 10px var(--sp-3);
    border-bottom: 1px solid var(--border-soft);
    font-size: var(--fs-sm);
    transition: background 0.12s;
}
.panel-row:last-child { border-bottom: none; }
.panel-row__main { flex: 1; min-width: 0; }
.panel-row__label {
    font-weight: 500;
    color: var(--fg-strong);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    letter-spacing: -0.005em;
}
.panel-row__meta {
    margin-top: 2px;
    font-size: 11px;
    color: var(--fg-soft);
    display: flex; align-items: center; gap: 4px;
}
.panel-row__num {
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    font-size: var(--fs-sm);
    color: var(--fg-strong);
    white-space: nowrap;
    text-align: right;
    flex: 0 0 auto;
}
.panel-row--link {
    color: inherit;
    text-decoration: none;
    cursor: pointer;
}
.panel-row--link:hover {
    background: var(--bg-soft);
    text-decoration: none;
}
.panel-row--link:hover .panel-row__label { color: var(--accent); }

.dot {
    display: inline-block;
    width: 7px; height: 7px;
    border-radius: 50%;
    background: var(--border-strong);
}
.dot--warn { background: #f59e0b; box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.18); }
.dot--err  { background: #ef4444; box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.18); }
.dot--ok   { background: #10b981; box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.18); }

/* Stage-Tabs — der zentrale Fokus-Switch (Shop-Admin-Pattern) */
.stage-tabs {
    display: flex;
    gap: 2px;
    padding: 4px;
    margin: 0 0 var(--sp-4);
    background: var(--bg-soft);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
    position: sticky;
    top: 56px;
    z-index: 25;
    backdrop-filter: blur(10px);
}
.stage-tab {
    flex: 1;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    padding: 0 var(--sp-4);
    background: transparent;
    border: 1px solid transparent;
    border-radius: 7px;
    font: 500 var(--fs-base)/1 var(--font-body);
    color: var(--fg-mid);
    cursor: pointer;
    transition: all 0.15s;
    letter-spacing: -0.008em;
    position: relative;
}
.stage-tab:hover {
    background: rgba(255, 255, 255, 0.6);
    color: var(--fg-strong);
}
.stage-tab.is-active {
    background: var(--bg-elevated);
    color: var(--fg-strong);
    font-weight: 600;
    box-shadow: var(--sh-sm);
    border-color: var(--border-soft);
}
.stage-tab__step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--bg-soft);
    color: var(--fg-mid);
    font: 700 11px/1 var(--font-body);
    border: 1px solid var(--border-strong);
    flex: 0 0 22px;
    transition: all 0.15s;
}
.stage-tab.is-active .stage-tab__step {
    background: var(--fg-strong);
    color: #fff;
    border-color: var(--fg-strong);
}
.stage-tab__label {
    font-size: var(--fs-base);
}
.stage-tab__badge {
    min-width: 22px;
    height: 22px;
    padding: 0 8px;
    border-radius: var(--r-pill);
    font: 700 11px/22px var(--font-body);
    text-align: center;
    flex: 0 0 auto;
}
.stage-tab__badge--pool     { background: #fef2f2; color: #b91c1c; }
.stage-tab__badge--listen   { background: rgba(30, 99, 214, 0.12); color: var(--accent); }
.stage-tab__badge--bestellt { background: var(--warn-soft); color: #b45309; }
.stage-tab__badge--done     { background: var(--ok-soft); color: #047857; font-weight: 600; }

.stage-tab.is-active .stage-tab__badge--pool     { background: #fee2e2; color: #991b1b; }
.stage-tab.is-active .stage-tab__badge--listen   { background: rgba(30, 99, 214, 0.18); color: var(--accent); }
.stage-tab.is-active .stage-tab__badge--bestellt { background: #fef3c7; color: #92400e; }

/* Panels — nur das aktive Stadium zeigen */
.stage-panels > .stage { display: none; }
.stage-panels[data-active-tab="pool"] > #stage-pool,
.stage-panels[data-active-tab="listen"] > #stage-listen,
.stage-panels[data-active-tab="bestellt"] > #stage-bestellt { display: block; }

.stage { margin: 0; scroll-margin-top: 110px; }

/* Stage-Toolbar — Page-Header pro Stadium (analog Materials-Referenz) */
.stage-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-4);
    margin: 0 0 var(--sp-3);
    padding: 0 0 var(--sp-3);
    border-bottom: 1px solid var(--border-soft);
}
.stage-toolbar__title { flex: 1; min-width: 0; }
.stage-toolbar__title h2 {
    font-size: var(--fs-lg);
    font-weight: 600;
    letter-spacing: -0.018em;
    margin: 0 0 4px;
    color: var(--fg-strong);
}
.stage-toolbar__title p {
    margin: 0;
    color: var(--fg-soft);
    font-size: var(--fs-sm);
    line-height: 1.5;
    max-width: 720px;
}
.stage-toolbar__meta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    flex: 0 0 auto;
}
.count-pill {
    display: inline-flex;
    align-items: center;
    height: 26px;
    padding: 0 10px;
    background: var(--bg-soft);
    color: var(--fg-mid);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-pill);
    font: 600 var(--fs-xs)/1 var(--font-body);
    letter-spacing: 0.01em;
    font-variant-numeric: tabular-nums;
}
.count-pill--accent { background: rgba(30, 99, 214, 0.10); color: var(--accent); border-color: rgba(30, 99, 214, 0.20); }
.count-pill--warn   { background: var(--warn-soft); color: #b45309; border-color: #fde68a; }
.count-pill--ok     { background: var(--ok-soft); color: #047857; border-color: #a7f3d0; }

/* KPI, die zum aktiven Tab gehört, bekommt einen subtilen "selected"-Look */
.kpi--linked {
    border-color: var(--fg-strong) !important;
}
.kpi--linked::after {
    content: 'aktiv';
    position: absolute;
    top: var(--sp-3); right: var(--sp-4);
    font: 600 9px/1 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--fg-soft);
    padding: 3px 7px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--r-pill);
}

/* Mobile: Tabs scrollen horizontal */
@media (max-width: 720px) {
    .stage-tabs { overflow-x: auto; flex-wrap: nowrap; }
    .stage-tab { min-width: 140px; flex: 0 0 auto; }
}

/* Stepper als 3-Spalten-Grid mit Verbindungslinien dazwischen */
.workflow-stepper {
    list-style: none;
    margin: 0;
    padding: var(--sp-1);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-2);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
    counter-reset: wstep;
    position: relative;
}
.workflow-stepper::before {
    content: '';
    position: absolute;
    top: 50%; left: 16.66%; right: 16.66%;
    height: 2px;
    background: linear-gradient(90deg, #e2e8f0 0%, #e2e8f0 50%, #e2e8f0 100%);
    z-index: 0;
}
.wstep { position: relative; z-index: 1; }
.wstep a {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-3) var(--sp-3);
    border-radius: var(--r-sm);
    background: transparent;
    color: var(--fg-strong);
    text-decoration: none;
    transition: background 0.12s;
}
.wstep a:hover { background: var(--bg-soft); text-decoration: none; }
.wstep__num {
    flex: 0 0 28px;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--bg-soft);
    color: var(--fg-soft);
    border: 1.5px solid var(--border-strong);
    display: inline-flex; align-items: center; justify-content: center;
    font: 600 var(--fs-sm)/1 var(--font-body);
    transition: all 0.15s;
}
.wstep__body {
    display: flex; flex-direction: column; gap: 1px;
    flex: 1; min-width: 0;
}
.wstep__title {
    font: 600 var(--fs-base)/1.2 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.012em;
}
.wstep__sub {
    font-size: var(--fs-xs);
    color: var(--fg-soft);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.wstep__badge {
    flex: 0 0 auto;
    min-width: 24px; height: 24px;
    padding: 0 7px;
    border-radius: var(--r-pill);
    background: #e2e8f0;
    color: var(--fg-mid);
    font: 700 var(--fs-sm)/24px var(--font-body);
    text-align: center;
}

/* Aktive Stadien (haben Action-Items) bekommen ihre Farbe */
.wstep--has-action.wstep--pool .wstep__num {
    background: #fef2f2; border-color: #fecaca; color: #b91c1c;
}
.wstep--has-action.wstep--pool .wstep__badge {
    background: #fef2f2; color: #b91c1c;
}
.wstep--has-action.wstep--listen .wstep__num {
    background: rgba(30, 99, 214, 0.10); border-color: rgba(30, 99, 214, 0.30); color: var(--accent);
}
.wstep--has-action.wstep--listen .wstep__badge--accent {
    background: rgba(30, 99, 214, 0.10); color: var(--accent);
}
.wstep--has-action.wstep--bestellt .wstep__num {
    background: var(--warn-soft); border-color: #fde68a; color: #b45309;
}
.wstep--has-action.wstep--bestellt .wstep__badge--warn {
    background: var(--warn-soft); color: #b45309;
}
/* Leeres/abgeschlossenes Stadium dezenter */
.wstep:not(.wstep--has-action) a { opacity: 0.65; }
.wstep:not(.wstep--has-action):hover a { opacity: 1; }

/* Stage-Container — jeder Workflow-Schritt ein eigener Block */
.stage {
    margin: 0 0 var(--sp-6);
    scroll-margin-top: 72px; /* sticky topbar abziehen */
}
.stage-head {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-3) var(--sp-4);
    margin: 0 0 var(--sp-3);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
    position: sticky;
    top: 60px;
    z-index: 30;
    backdrop-filter: blur(6px);
    background: rgba(255, 255, 255, 0.94);
}
.stage-head__num {
    flex: 0 0 32px;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--bg-soft);
    color: var(--fg-mid);
    display: inline-flex; align-items: center; justify-content: center;
    font: 700 var(--fs-md)/1 var(--font-body);
    letter-spacing: -0.02em;
}
.stage[data-stage="pool"] .stage-head__num { background: #fef2f2; color: #b91c1c; }
.stage[data-stage="listen"] .stage-head__num { background: rgba(30, 99, 214, 0.10); color: var(--accent); }
.stage[data-stage="bestellt"] .stage-head__num { background: var(--warn-soft); color: #b45309; }

.stage-head__body { flex: 1; min-width: 0; }
.stage-head__body h2 {
    font-size: var(--fs-lg);
    font-weight: 600;
    margin: 0 0 2px;
    letter-spacing: -0.015em;
}
.stage-head__body p {
    margin: 0;
    font-size: var(--fs-sm);
    color: var(--fg-soft);
    line-height: 1.4;
}
.stage-head__count {
    flex: 0 0 auto;
    min-width: 32px; height: 32px;
    padding: 0 var(--sp-3);
    border-radius: var(--r-pill);
    background: var(--bg-soft);
    color: var(--fg-strong);
    font: 700 var(--fs-md)/32px var(--font-body);
    text-align: center;
    border: 1px solid var(--border-strong);
}
.stage[data-stage="pool"] .stage-head__count {
    background: #fef2f2; color: #b91c1c; border-color: #fecaca;
}
.stage[data-stage="listen"] .stage-head__count {
    background: rgba(30, 99, 214, 0.10); color: var(--accent); border-color: rgba(30, 99, 214, 0.30);
}
.stage-head__count--warn {
    background: var(--warn-soft) !important; color: #b45309 !important; border-color: #fde68a !important;
}

/* ── Cart-Blocks (Bestelllisten + Bestellt) ────────────────────── */

.cart-block {
    border-radius: var(--r-md);
    border: 1px solid var(--border-soft);
    background: var(--bg-elevated);
    padding: var(--sp-4) var(--sp-5);
    box-shadow: var(--sh-sm);
    margin-bottom: var(--sp-3);
    border-left-width: 4px;
}
.cart-block.soll     { border-left-color: var(--accent); }
.cart-block.bestellt { border-left-color: #10b981; }
.cart-block.teil     { border-left-color: #d97706; }
.cart-block.pool     { border-left-color: #e11d48; }
.cart-block.is-complete {
    opacity: 0.78;
    border-left-color: #94a3b8;
}
.cart-block.is-complete:hover { opacity: 1; }

.cart-head {
    display: flex;
    gap: var(--sp-3);
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: var(--sp-3);
}
.cart-head h3 {
    margin: 0;
    font-size: var(--fs-md);
    font-weight: 600;
    letter-spacing: -0.012em;
}
.cart-summary {
    font-size: var(--fs-sm);
    color: var(--fg-soft);
}
.cart-pill {
    display: inline-block;
    padding: 3px 9px;
    border-radius: var(--r-pill);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.cart-pill.soll     { background: rgba(30, 99, 214, 0.10); color: var(--accent); }
.cart-pill.bestellt { background: var(--ok-soft); color: #047857; }
.cart-pill.teil     { background: var(--warn-soft); color: #b45309; }
.cart-pill.online   { background: var(--err-soft); color: #b91c1c; }
.cart-pill.manual   { background: rgba(99, 102, 241, 0.10); color: #4338ca; }

/* Cart-Table als Shop-Backend-Line-Item-Liste:
   Ruhige Zeilen mit klarer Hierarchie, generöses Padding,
   stark unterschiedliche Schriftgewichte für Title vs. Meta. */
.cart-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--fs-sm);
    margin-top: var(--sp-2);
}
.cart-table th {
    background: var(--bg-soft);
    font: 600 10px/1.4 var(--font-body);
    color: var(--fg-soft);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 10px var(--sp-3);
    border-bottom: 1px solid var(--border-strong);
    text-align: left;
    white-space: nowrap;
    position: relative;
}
.cart-table th.num { text-align: right; }
.cart-table th.sortable {
    cursor: pointer;
    padding-right: 22px;
}
.cart-table th.sortable::after {
    content: '';
    position: absolute;
    right: 8px; top: 50%;
    width: 0; height: 0;
    margin-top: -3px;
    border-left: 3px solid transparent;
    border-right: 3px solid transparent;
    border-top: 4px solid var(--border-strong);
    opacity: 0.6;
}
.cart-table th.sortable:hover::after { border-top-color: var(--fg-mid); opacity: 1; }
.cart-table td {
    padding: var(--sp-3);
    border-bottom: 1px solid var(--border-soft);
    vertical-align: middle;
    font-size: var(--fs-sm);
}
.cart-table tr:last-child td { border-bottom: none; }
.cart-table tbody tr { transition: background 0.12s; }
.cart-table tbody tr:hover { background: rgba(15, 23, 42, 0.02); }
.cart-table td.num { text-align: right; }

/* Artikel-Cell — der primäre Anker pro Zeile */
.cart-table .name-cell { min-width: 280px; max-width: 520px; }
.row-title {
    display: block;
    font: 600 var(--fs-base)/1.35 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.012em;
    margin-bottom: 3px;
    overflow: hidden;
    text-overflow: ellipsis;
}
.row-meta {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    flex-wrap: wrap;
    font-size: var(--fs-xs);
    color: var(--fg-soft);
    line-height: 1.4;
}
.row-meta code {
    font-family: var(--font-mono);
    font-size: 11px;
    background: var(--bg-soft);
    color: var(--fg-mid);
    padding: 1px 6px;
    border-radius: 4px;
    border: 1px solid var(--border-soft);
}
.row-meta .meta-sep { color: var(--border-strong); }
.row-meta .meta-pid, .row-meta .meta-sku { color: var(--fg-soft); }
.row-meta .meta-sku code { padding: 0 4px; }

/* Numerische Zellen — Tabular, ruhig */
.cart-table .qty-big {
    font: 600 var(--fs-md)/1 var(--font-body);
    color: var(--fg-strong);
    font-variant-numeric: tabular-nums;
}
.cart-table .qty-soft {
    color: var(--fg-soft);
    font-variant-numeric: tabular-nums;
}

/* Per-Stage Spaltenbreiten — verhindert das Springen bei verschiedenen Listen */
.cart-table--pool .col-offen,
.cart-table--pool .col-bestand { width: 86px; }
.cart-table--pool .col-supplier { width: 280px; }
.cart-table--pool .col-supplier .pool-supplier-select { width: 100%; min-width: 0; }
.cart-table--pool .col-qty { width: 90px; }
.cart-table--pool .col-actions { width: 1%; white-space: nowrap; }

.cart-table--listen .col-soll { width: 110px; }
.cart-table--listen .col-price { width: 90px; }
.cart-table--listen .col-sum { width: 100px; }
.cart-table--listen .col-actions { width: 1%; white-space: nowrap; }

.cart-table--bestellt .col-bestellt { width: 90px; }
.cart-table--bestellt .col-eingang { width: 280px; }
.cart-table--bestellt .col-price { width: 90px; }
.cart-table--bestellt .col-sum { width: 100px; }

/* Bestellt-Eingang-Cell: Status + Eingang-Form sauber gestapelt */
.eingang-cell {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 240px;
}
.eingang-status {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
}
.eingang-num {
    font-variant-numeric: tabular-nums;
    font-size: var(--fs-sm);
    color: var(--fg-mid);
}
.eingang-num strong {
    font-size: var(--fs-md);
    font-weight: 600;
    color: var(--fg-strong);
}
.eingang-num.is-done strong { color: #047857; }
.eingang-num .of-total { color: var(--fg-soft); }
.progress-bar--sm { width: 90px; height: 4px; }

.eingang-form {
    display: flex;
    gap: 6px;
    align-items: center;
}
.eingang-form .qty-input {
    height: 30px;
    width: 70px !important;
}
.row-done-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    background: var(--ok-soft);
    color: #047857;
    border-radius: var(--r-pill);
    font-size: var(--fs-xs);
    font-weight: 600;
    align-self: flex-start;
}
.cart-table--bestellt tr.row-done {
    background: rgba(16, 185, 129, 0.02);
}
.cart-table--bestellt tr.row-done .row-title { color: var(--fg-mid); }

/* Action-Cluster — kompakte Icon-Button-Reihe rechts */
.action-cluster {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    justify-content: flex-end;
}
.action-cluster .inline-form { display: inline-flex; }

/* Button-System für Tabellen — kompakt, klar, wie Shop-Admin-Referenz */
.btn-action {
    height: 30px;
    padding: 0 var(--sp-3);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: var(--r-sm);
    font: 600 var(--fs-sm)/1 var(--font-body);
    cursor: pointer;
    transition: all 0.12s;
    border: 1px solid transparent;
    white-space: nowrap;
}
.btn-primary {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}
.btn-primary:hover { background: var(--accent-hover); border-color: var(--accent-hover); color: #fff; }
.btn-primary:focus-visible { outline: none; box-shadow: var(--sh-focus); }
.btn-primary svg { stroke: currentColor; }

/* Icon-Buttons im Stil der Materials-Referenz: zarte farbige Tönung,
   1px Rand, kompakt (28x28). Pro Aktions-Typ eigene Farbe. */
.btn-icon {
    width: 28px; height: 28px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--border-soft);
    background: var(--bg-elevated);
    color: var(--fg-mid);
    border-radius: var(--r-sm);
    cursor: pointer;
    transition: all 0.12s;
}
.btn-icon:hover {
    background: rgba(16, 185, 129, 0.08);
    border-color: rgba(16, 185, 129, 0.30);
    color: #047857;
}
.btn-icon--danger:hover {
    background: var(--err-soft);
    border-color: #fecaca;
    color: var(--err);
}
.btn-icon--accent:hover {
    background: rgba(30, 99, 214, 0.08);
    border-color: rgba(30, 99, 214, 0.30);
    color: var(--accent);
}
.btn-icon:focus-visible { outline: none; box-shadow: var(--sh-focus); }
.action-cluster { gap: 4px; }

.cart-actions {
    display: flex;
    gap: var(--sp-2);
    align-items: center;
    flex-wrap: wrap;
    margin-top: var(--sp-3);
    padding-top: var(--sp-3);
    border-top: 1px solid var(--border-soft);
}
.cart-actions label {
    font-size: var(--fs-sm);
    color: var(--fg-mid);
    font-weight: 500;
}

.inline-form { display: inline; margin: 0; }
.pool-supplier-select { min-width: 260px; }
.qty-input { width: 72px !important; padding: 0 var(--sp-2) !important; text-align: right; }

/* ── Bestellt-Card: Details/Summary mit Progress-Bar ───────────── */

.bestellt-card { margin: 0; }
.bestellt-card > summary {
    list-style: none;
    cursor: pointer;
    margin-bottom: 0;
    padding: var(--sp-2) 0;
    user-select: none;
}
.bestellt-card > summary::-webkit-details-marker { display: none; }
.bestellt-card > summary::before {
    content: '▸';
    display: inline-block;
    color: var(--fg-soft);
    margin-right: var(--sp-2);
    transition: transform 0.15s;
    font-size: 11px;
}
.bestellt-card[open] > summary::before { transform: rotate(90deg); }
.bestellt-summary__main {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    flex-wrap: wrap;
    flex: 1;
    min-width: 0;
}
.bestellt-summary__supplier {
    font: 600 var(--fs-md)/1.2 var(--font-body);
    letter-spacing: -0.012em;
}
.bestellt-summary__meta {
    font-size: var(--fs-sm);
    color: var(--fg-soft);
}
.bestellt-summary__progress {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    margin-left: auto;
}
.progress-num {
    font: 600 var(--fs-sm)/1 var(--font-body);
    color: var(--fg-mid);
    font-variant-numeric: tabular-nums;
}
.progress-num.is-complete { color: #047857; }
.progress-num.is-complete::after { content: ' ✓'; }
.progress-bar {
    display: inline-block;
    width: 100px;
    height: 6px;
    background: var(--bg-soft);
    border-radius: 3px;
    overflow: hidden;
}
.progress-bar__fill {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, #34d399, #10b981);
    border-radius: 3px;
    transition: width 0.3s;
}
.cart-block.is-complete .progress-bar__fill {
    background: linear-gradient(90deg, #94a3b8, #64748b);
}

.cart-notes {
    margin-top: var(--sp-3);
    padding-top: var(--sp-3);
    border-top: 1px solid var(--border-soft);
}
.cart-notes > details > summary {
    cursor: pointer;
    font-size: var(--fs-xs);
    color: var(--fg-soft);
}
.cart-notes__pre {
    font-size: var(--fs-xs);
    background: var(--bg-soft);
    padding: var(--sp-2) var(--sp-3);
    border-radius: var(--r-sm);
    white-space: pre-wrap;
    margin: var(--sp-2) 0 0;
}

.section-empty {
    color: var(--fg-soft);
    font-style: normal;
    padding: var(--sp-4) var(--sp-5);
    background: var(--bg-elevated);
    border: 1px dashed var(--border-strong);
    border-radius: var(--r-md);
    font-size: var(--fs-sm);
    text-align: center;
}

/* ── Order-Section: flacher Container für eine Bestellliste / Bestellung
   (statt der alten "verspielten" cart-block-Karten) ──────────── */

/* ORDER-SECTION — jede Bestellung visuell eine eigene Akte.
   Großzügiger Abstand, eindeutige Header-Identität, kräftiger Rand
   in Stadium-Farbe. Vollständig getrennt vom Nachbarn. */
.order-section {
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: 10px;
    margin: 0 0 28px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
    position: relative;
}
.order-section:last-child { margin-bottom: 0; }

/* Stadium-Akzent als 4px-Streifen ganz oben — sofort sichtbar als Anker */
.order-section::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--border-strong);
}
.order-section--listen::before   { background: var(--accent); }
.order-section--bestellt::before { background: #d97706; }
.order-section--teil::before     { background: #d97706; }
.order-section--pool::before     { background: #e11d48; }

.order-section__head {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
    padding: 18px 20px;
    background: var(--bg-elevated);
    border-bottom: 1px solid var(--border-soft);
}
.order-section__head .order-section__title {
    flex: 0 0 auto;
    margin-right: auto;
    display: flex;
    align-items: center;
    gap: 10px;
}
.order-section__title strong {
    font: 600 17px/1.2 var(--font-body);
    letter-spacing: -0.018em;
    color: var(--fg-strong);
}
.order-section__meta {
    font-size: 12px;
    color: var(--fg-soft);
    font-variant-numeric: tabular-nums;
    padding-left: 12px;
    border-left: 1px solid var(--border-soft);
}
.order-section__total {
    font: 700 20px/1 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.025em;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.order-section__total .muted {
    font-weight: 500;
    font-size: 12px;
    color: var(--fg-soft);
    margin-left: 4px;
    letter-spacing: 0;
}
.order-section--listen .order-section__head { border-left: 3px solid var(--accent); }
.order-section--bestellt .order-section__head { border-left: 3px solid #d97706; }
.order-section--bestellt.order-section--teil .order-section__head { border-left-color: #d97706; }

.order-section__title {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    flex-wrap: wrap;
}
.order-section__title strong {
    font: 600 var(--fs-base)/1.2 var(--font-body);
    letter-spacing: -0.012em;
    color: var(--fg-strong);
}
.order-section__meta {
    font-size: var(--fs-xs);
    color: var(--fg-soft);
    font-variant-numeric: tabular-nums;
}
.order-section__total {
    font: 600 var(--fs-md)/1 var(--font-body);
    color: var(--fg-strong);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.015em;
    white-space: nowrap;
}
.order-section__total .muted { font-weight: 400; }
.order-section__progress {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    font-size: var(--fs-sm);
    white-space: nowrap;
}
.order-section__sum {
    font: 600 var(--fs-md)/1 var(--font-body);
    color: var(--fg-strong);
    margin-left: var(--sp-2);
    font-variant-numeric: tabular-nums;
}

.order-section .cart-table {
    margin: 0;
}
.order-section .cart-table thead {
    background: transparent;
}
.order-section .cart-table th {
    padding: var(--sp-2) var(--sp-3) 6px;
    background: var(--bg-elevated);
}
.order-section .cart-table tbody tr:last-child td { border-bottom: 1px solid var(--border-soft); }
.order-section .cart-footer {
    margin: 0;
    border-radius: 0;
    border: none;
    border-top: 1px solid var(--border-soft);
    background: var(--bg-elevated);
}

/* Bestellt: Toggle für Positions-Detail */
.bestellt-card { margin: 0; }
.bestellt-card__toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px var(--sp-4);
    cursor: pointer;
    list-style: none;
    color: var(--fg-soft);
    font-size: var(--fs-xs);
    background: var(--bg);
    border-bottom: 1px solid var(--border-soft);
    user-select: none;
}
.bestellt-card__toggle::-webkit-details-marker { display: none; }
.bestellt-card__toggle::before {
    content: '▸';
    font-size: 10px;
    transition: transform 0.15s;
}
.bestellt-card[open] .bestellt-card__toggle::before { transform: rotate(90deg); }
.bestellt-card__toggle:hover { color: var(--fg-strong); }

.order-section .cart-notes {
    padding: var(--sp-3) var(--sp-4);
    border-top: 1px solid var(--border-soft);
}

.archive-hint {
    margin: var(--sp-4) 0 0;
    padding: var(--sp-3);
    background: var(--bg-soft);
    border: 1px dashed var(--border-strong);
    border-radius: var(--r-sm);
    text-align: center;
    font-size: var(--fs-sm);
}
.archive-hint a { color: var(--accent); font-weight: 500; }

/* ── Archiv-Tabelle: dichte Liste mit ausklappbarem Detail ───────── */

.archive-table {
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    overflow: hidden;
    box-shadow: var(--sh-sm);
}
.archive-table__head,
.archive-row__summary {
    display: grid;
    grid-template-columns:
      minmax(180px, 1.4fr)   /* supplier */
      minmax(140px, 1fr)     /* order */
      110px                  /* date */
      90px                   /* items */
      80px                   /* qty */
      110px;                 /* sum */
    gap: var(--sp-3);
    align-items: center;
    padding: 10px var(--sp-4);
}
.archive-table__head {
    background: var(--bg-soft);
    border-bottom: 1px solid var(--border-strong);
    font: 600 10px/1.4 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--fg-soft);
}
.archive-row {
    border-bottom: 1px solid var(--border-soft);
}
.archive-row:last-child { border-bottom: none; }
.archive-row__summary {
    cursor: pointer;
    list-style: none;
    font-size: var(--fs-sm);
    transition: background 0.12s;
    color: var(--fg-mid);
}
.archive-row__summary::-webkit-details-marker { display: none; }
.archive-row__summary:hover { background: var(--bg-soft); }
.archive-row__summary strong { color: var(--fg-strong); font-weight: 600; }
.archive-check {
    display: inline-block;
    width: 18px; height: 18px;
    border-radius: 50%;
    background: var(--ok-soft);
    color: #047857;
    font-size: 11px;
    line-height: 18px;
    text-align: center;
    margin-right: 6px;
    font-weight: 700;
}
.ac-col { font-variant-numeric: tabular-nums; }
.ac-col.num { text-align: right; }
.ac-col code {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--fg-mid);
}
.archive-row[open] > .archive-row__summary {
    background: var(--bg-soft);
    border-bottom: 1px solid var(--border-soft);
}
.archive-row__body {
    padding: var(--sp-3) var(--sp-4);
    background: var(--bg);
    border-top: 1px solid var(--border-soft);
}
.cart-table--archive { background: var(--bg-elevated); border-radius: var(--r-sm); }

@media (max-width: 980px) {
    .archive-table__head, .archive-row__summary {
        grid-template-columns: 1fr auto;
        grid-auto-flow: row;
    }
    .ac-col--date, .ac-col--items, .ac-col--qty { display: none; }
}

/* Stage-Panels braucht jetzt auch den 4. Tab "archiv" */
.stage-panels[data-active-tab="archiv"] > #stage-archiv { display: block; }

/* ── Bestelllisten-Footer als Action-Bar (Lieferart/Termin/Submit) ── */

.cart-footer {
    margin-top: var(--sp-4);
    padding: var(--sp-3) var(--sp-4);
    background: linear-gradient(180deg, var(--bg-soft) 0%, var(--bg-elevated) 100%);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    display: flex;
    gap: var(--sp-4);
    align-items: flex-end;
    flex-wrap: wrap;
}
.cart-footer__fields {
    display: flex;
    gap: var(--sp-3);
    flex-wrap: wrap;
    flex: 1;
}
.field-inline {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 160px;
}
.field-inline__label {
    font: 600 10px/1 var(--font-body);
    color: var(--fg-soft);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.field-inline input, .field-inline select { height: 34px; }

.cart-footer__submit {
    height: 40px;
    padding: 0 var(--sp-5);
    background: var(--accent);
    color: #fff;
    border: 1px solid var(--accent);
    border-radius: var(--r-sm);
    font: 600 var(--fs-base)/1 var(--font-body);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    transition: all 0.12s;
    letter-spacing: -0.005em;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04), var(--sh-sm);
}
.cart-footer__submit:hover {
    background: var(--accent-hover);
    border-color: var(--accent-hover);
    transform: translateY(-1px);
    box-shadow: var(--sh-md);
}
.cart-footer__submit:focus-visible { outline: none; box-shadow: var(--sh-focus); }
.cart-footer__submit--online {
    background: var(--warm);
    border-color: var(--warm);
}
.cart-footer__submit--online:hover {
    background: #9a3412;
    border-color: #9a3412;
}

/* ── Bestelllisten-Card: Hero-Header mit großem €-Betrag ────────── */

.cart-hero {
    display: flex;
    align-items: center;
    gap: var(--sp-4);
    margin: 0 0 var(--sp-3);
    padding: 0 0 var(--sp-3);
    border-bottom: 1px solid var(--border-soft);
}
.cart-hero__main { flex: 1; min-width: 0; }
.cart-hero__supplier {
    font: 600 var(--fs-lg)/1.2 var(--font-body);
    letter-spacing: -0.015em;
    margin: 0 0 4px;
    display: flex; align-items: center; gap: var(--sp-2); flex-wrap: wrap;
}
.cart-hero__supplier .cart-pill {
    font-weight: 600;
}
.cart-hero__meta {
    font-size: var(--fs-sm);
    color: var(--fg-soft);
    font-variant-numeric: tabular-nums;
}
.cart-hero__total {
    text-align: right;
    flex: 0 0 auto;
}
.cart-hero__amount {
    display: block;
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.025em;
    color: var(--fg-strong);
    font-variant-numeric: tabular-nums;
    line-height: 1;
}
.cart-hero__amount-sub {
    display: block;
    margin-top: 4px;
    font-size: var(--fs-xs);
    color: var(--fg-soft);
    letter-spacing: 0.02em;
}

/* ── "Abgeschlossen"-Chip-Liste in Bestellt ────────────────────── */

.bestellt-done {
    margin: var(--sp-4) 0 0;
    border-top: 1px dashed var(--border-strong);
    padding-top: var(--sp-3);
}
.bestellt-done > summary {
    list-style: none;
    cursor: pointer;
    color: var(--fg-soft);
    font-size: var(--fs-sm);
    padding: var(--sp-1) 0;
    user-select: none;
    display: inline-flex; align-items: center; gap: 6px;
}
.bestellt-done > summary::-webkit-details-marker { display: none; }
.bestellt-done > summary::before {
    content: '▸';
    transition: transform 0.15s;
    font-size: 11px;
}
.bestellt-done[open] > summary::before { transform: rotate(90deg); }
.bestellt-done > summary:hover { color: var(--fg-strong); }
.bestellt-done__label strong { color: var(--fg-strong); }

.bestellt-done__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--sp-2);
    margin-top: var(--sp-3);
}
.done-chip {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    padding: var(--sp-2) var(--sp-3);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-left: 3px solid #94a3b8;
    border-radius: var(--r-sm);
    font-size: var(--fs-sm);
    color: var(--fg-mid);
    box-shadow: var(--sh-sm);
    transition: opacity 0.12s;
    opacity: 0.85;
}
.done-chip:hover { opacity: 1; }
.done-chip__check {
    color: #10b981;
    font-weight: 700;
    flex: 0 0 auto;
}
.done-chip__supplier {
    font-weight: 600;
    color: var(--fg-strong);
    margin-right: auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.done-chip__meta {
    color: var(--fg-soft);
    font-size: var(--fs-xs);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

/* Mobile-Anpassung KPI-Band */
@media (max-width: 900px) {
    .kpi-band { grid-template-columns: 1fr; }
    .kpi { min-height: auto; padding: var(--sp-3) var(--sp-4); }
    .kpi__num { font-size: 36px; }
    .page-head--dashboard { flex-direction: column; align-items: flex-start; }
    .cart-hero { flex-direction: column; align-items: flex-start; gap: var(--sp-2); }
    .cart-hero__total { text-align: left; }
}

/* Action-Button für „Online bestellen (Tekno)" als Warm-CTA — sticht raus */
.cart-actions button[type="submit"][style*="dc2626"],
.cart-actions button[type="submit"][style*="background:#dc2626"] {
    background: var(--warm) !important;
    border-color: var(--warm) !important;
    color: #fff !important;
}
.cart-actions button[type="submit"][style*="dc2626"]:hover {
    background: #9a3412 !important;
    border-color: #9a3412 !important;
}

/* Bestelllisten: Pool-Move-Button mit Pfeil-Akzent */
.cart-block.pool button[type="submit"].button {
    background: var(--accent);
}
.cart-block.pool button[type="submit"].button:hover {
    background: var(--accent-hover);
}

/* ── Login-Hero, Dashboard-Tiles: warme Note ──────────────────────── */

.login-hero__panel h1 {
    font-family: var(--font-display);
    font-size: var(--fs-3xl);
    font-weight: 700;
    letter-spacing: -0.035em;
}
.login-hero__cta {
    height: 44px; padding: 0 var(--sp-5);
    font-size: var(--fs-md);
    background: var(--accent);
}

/* ── Dashboard ────────────────────────────────────────────────────── */

.dashboard-header {
    margin: var(--sp-3) 0 var(--sp-7);
    padding-bottom: var(--sp-5);
    border-bottom: 1px solid var(--border-soft);
}
.dashboard-header h1 {
    font-size: var(--fs-3xl);
    font-weight: 700;
    letter-spacing: -0.035em;
    margin: 0 0 var(--sp-2);
    background: linear-gradient(180deg, var(--fg-strong) 0%, #334155 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.dashboard-sub {
    color: var(--fg-soft);
    font-size: var(--fs-md);
    margin: 0;
    letter-spacing: -0.005em;
}
.dashboard-section { margin: 0 0 var(--sp-7); }
.dashboard-section__label {
    font-size: var(--fs-xs);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fg-soft);
    margin: 0 0 var(--sp-3);
    display: flex; align-items: center; gap: var(--sp-2);
}
.dashboard-section__label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border-soft);
}

.tile-grid--hero {
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--sp-4);
}
.tile-grid--compact {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--sp-3);
}

.tile {
    padding: var(--sp-5);
    border-radius: var(--r-md);
    border: 1px solid var(--border-soft);
    background: var(--bg-elevated);
    color: var(--fg-strong);
    transition: transform 0.14s cubic-bezier(.2,.7,.4,1),
                box-shadow 0.18s, border-color 0.18s;
    display: block;
    position: relative;
    overflow: hidden;
}
.tile p {
    color: var(--fg-soft);
    font-size: var(--fs-sm);
    margin: 0;
    line-height: 1.5;
}
.tile:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh-md);
    border-color: #cbd5e1;
    text-decoration: none;
}

.tile--hero {
    padding: var(--sp-6);
    min-height: 140px;
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}
.tile--hero h3 {
    font-size: var(--fs-lg);
    font-weight: 600;
    letter-spacing: -0.02em;
    margin: 0;
}
.tile--hero p { font-size: var(--fs-base); }

.tile__icon {
    width: 40px; height: 40px;
    border-radius: var(--r-sm);
    background: var(--bg-soft);
    color: var(--fg-mid);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: var(--sp-3);
    transition: background 0.15s, color 0.15s, transform 0.15s;
}
.tile__icon svg { width: 22px; height: 22px; }
.tile:hover .tile__icon { transform: scale(1.06); }

.tile--primary {
    background:
      radial-gradient(circle at 100% 0%, rgba(99, 102, 241, 0.10), transparent 55%),
      linear-gradient(135deg, var(--accent) 0%, #2756c5 100%);
    border-color: transparent;
    color: #fff;
}
.tile--primary h3, .tile--primary p { color: #fff; }
.tile--primary p { color: rgba(255, 255, 255, 0.82); }
.tile--primary .tile__icon {
    background: rgba(255, 255, 255, 0.16);
    color: #fff;
    backdrop-filter: blur(4px);
}
.tile--primary:hover {
    box-shadow: 0 8px 24px rgba(30, 99, 214, 0.28);
    border-color: transparent;
}
.tile--primary::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 0% 100%, rgba(255, 255, 255, 0.08), transparent 60%);
    pointer-events: none;
}

.tile--mini { padding: var(--sp-4); }
.tile--mini h3 { font-size: var(--fs-base); }

/* ── Filter-Pills / Filter-Bar Politur ────────────────────────────── */

.filter-pill {
    height: 30px;
    padding: 0 var(--sp-3);
    font-size: var(--fs-sm);
}
.filter-pill.active {
    box-shadow: 0 1px 3px rgba(30, 99, 214, 0.20), var(--sh-focus);
}

/* ── Tabs (Item-Editor & Co.) ─────────────────────────────────────── */

.tabs-nav {
    display: flex;
    gap: 2px;
    margin: var(--sp-3) 0 var(--sp-4);
    padding: 4px;
    background: var(--bg-soft);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    overflow-x: auto;
    flex-wrap: wrap;
}
.tabs-nav__btn {
    flex: 1 1 auto;
    min-width: 110px;
    height: 34px;
    padding: 0 var(--sp-3);
    background: transparent;
    border: 1px solid transparent;
    border-radius: 7px;
    font: 500 var(--fs-sm)/1 var(--font-body);
    color: var(--fg-mid);
    cursor: pointer;
    transition: all 0.12s;
    position: relative;
    white-space: nowrap;
    letter-spacing: -0.005em;
}
.tabs-nav__btn:hover { color: var(--fg-strong); background: rgba(255, 255, 255, 0.6); }
.tabs-nav__btn.is-active {
    background: var(--bg-elevated);
    color: var(--accent);
    font-weight: 600;
    box-shadow: var(--sh-sm);
    border-color: var(--border-soft);
}
.tabs-nav__btn.has-issue::after {
    content: '';
    position: absolute;
    top: 6px; right: 8px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--err);
    box-shadow: 0 0 0 2px var(--bg-elevated);
}

.tab-panel {
    /* Vorher fieldset.form-section — bekommt im Tab-Modus weniger
       optisches Gewicht, ist ja schon innerhalb der Tab-Card. */
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    padding: var(--sp-5);
    background: var(--bg-elevated);
    box-shadow: var(--sh-sm);
    margin: 0;
}
.tab-panel[hidden] { display: none; }
.tab-panel .legend-srhidden {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0 0 0 0); white-space: nowrap;
    border: 0;
}

/* Wenn JS aus ist: legends bleiben sichtbar, fieldsets wie zuvor */

/* Action-Bar im Item-Editor sticky am unteren Rand, damit „Speichern"
   immer in Reichweite ist — egal welcher Tab offen. */
.sourcing-item-form .form-actions {
    position: sticky;
    bottom: var(--sp-3);
    margin-top: var(--sp-5);
    padding: var(--sp-3) var(--sp-4);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-md);
    display: flex; gap: var(--sp-2); align-items: center; flex-wrap: wrap;
    z-index: 5;
}
.sourcing-item-form .form-actions a { margin-left: auto; color: var(--fg-soft); }

/* Item-Editor: Top-Toolbar (Refresh/KI/Zurück) sauberer */
.page-head { margin: 0 0 var(--sp-4); }
.page-head h1 {
    font-size: var(--fs-2xl);
    font-weight: 700;
    margin: 0 0 var(--sp-2);
    display: flex; align-items: center; gap: var(--sp-3);
}
.page-head h1 .pill { font-size: var(--fs-xs); }
.page-head > p { color: var(--fg-soft); font-size: var(--fs-sm); margin: 0; }
.page-head .btn,
.page-head .btn-sm,
.page-head form button {
    height: 30px; padding: 0 var(--sp-3);
    background: var(--bg-elevated); color: var(--fg-strong);
    border: 1px solid var(--border-strong); border-radius: var(--r-sm);
    font: 500 var(--fs-sm)/1 var(--font-body);
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 4px;
}
.page-head .btn:hover { border-color: var(--accent); color: var(--accent); }

/* ── Inline-Save-States vereinheitlichen ──────────────────────────── */

.inline-price.saved, .ek-select.saved {
    background: var(--ok-soft);
    border-color: #34d399;
    box-shadow: 0 0 0 2px rgba(52, 211, 153, 0.25);
}
.inline-price.saving, .ek-select.saving {
    background: var(--warn-soft);
    border-color: #f59e0b;
}
.inline-price.save-error, .ek-select.save-error {
    background: var(--err-soft);
    border-color: var(--err);
}

/* ── Modal Politur ────────────────────────────────────────────────── */

.modal-card {
    border-radius: var(--r-lg);
    box-shadow: var(--sh-xl);
    padding: var(--sp-5) var(--sp-5);
}
.modal-card h2, .modal-card h3 { font-family: var(--font-display); }

/* ── Pager ────────────────────────────────────────────────────────── */

.pager-num.current {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    box-shadow: var(--sh-sm);
}

/* ── Status-Pills mit Soft-Backgrounds ────────────────────────────── */

.pill-done    { background: var(--ok-soft); color: #047857; }
.pill-running { background: var(--warn-soft); color: #b45309; }
.pill-failed  { background: var(--err-soft); color: #b91c1c; }
.pill-pending { background: var(--bg-soft); color: var(--fg-mid); }

/* ════════════════════════════════════════════════════════════════════
   POLISH PASS — „Refined Operational"
   Spaß-Momente: Page-Load-Choreo, Tactile-Hover, Keyboard-First,
   Ambient-Background, Empty-State-Feier. Bleibt seriös, fühlt sich
   aber lebendig an.
   ══════════════════════════════════════════════════════════════════════ */

/* Ambient-Background: zwei sehr subtile radiale Gradienten erzeugen
   Tiefe ohne Ablenkung. Wirkt wie warmes Studio-Licht. */
body {
    background:
      radial-gradient(ellipse 60% 80% at 15% -5%, rgba(30, 99, 214, 0.035), transparent 50%),
      radial-gradient(ellipse 50% 70% at 95% 100%, rgba(194, 65, 12, 0.025), transparent 50%),
      var(--bg);
    min-height: 100vh;
}

/* Page-Load-Choreo — Reveal von oben nach unten, gestaffelt.
   Nur beim Initial-Load, nicht bei JS-getriggerten Updates. */
@keyframes pageload-rise {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}
body[data-pageload="initial"] .page-head--dashboard { animation: pageload-rise 0.45s cubic-bezier(.2,.7,.4,1) both; }
body[data-pageload="initial"] .kpi-band > .kpi { animation: pageload-rise 0.5s cubic-bezier(.2,.7,.4,1) both; }
body[data-pageload="initial"] .kpi-band > .kpi:nth-child(1) { animation-delay: 0.08s; }
body[data-pageload="initial"] .kpi-band > .kpi:nth-child(2) { animation-delay: 0.14s; }
body[data-pageload="initial"] .kpi-band > .kpi:nth-child(3) { animation-delay: 0.20s; }
body[data-pageload="initial"] .workspace { animation: pageload-rise 0.55s cubic-bezier(.2,.7,.4,1) 0.28s both; }

/* KPI-Karten: pressable hover + dynamische Akzentlinie oben */
.kpi {
    transition:
      transform 0.22s cubic-bezier(.2,.7,.4,1),
      box-shadow 0.22s cubic-bezier(.2,.7,.4,1),
      border-color 0.18s;
}
.kpi.is-action:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 36px -8px rgba(15, 23, 42, 0.18), 0 2px 4px rgba(15, 23, 42, 0.04);
}
.kpi.is-action:hover::before {
    height: 4px;
}
.kpi.is-action::before {
    transition: height 0.18s cubic-bezier(.2,.7,.4,1);
}
.kpi:active { transform: translateY(-1px); }

/* Pfeil im KPI-CTA und in Primary-Buttons gleitet auf Hover.
   Klassiker, aber satisfaction-as-a-service. */
.kpi__cta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    transition: gap 0.18s;
}
.kpi:hover .kpi__cta { gap: 8px; }

.btn-primary svg, .btn-action svg, .cart-footer__submit svg {
    transition: transform 0.2s cubic-bezier(.2,.7,.4,1);
}
.btn-primary:hover svg, .btn-action:hover svg, .cart-footer__submit:hover svg {
    transform: translateX(3px);
}
.btn-primary:active, .cart-footer__submit:active, .btn-action:active {
    transform: translateY(0) scale(0.985);
}

/* Tabellen-Zeilen: Hover mit Akzent statt nur grau, fühlt sich gezielt an */
.cart-table tbody tr {
    transition: background 0.14s, box-shadow 0.14s;
}
.cart-table tbody tr:hover {
    background: linear-gradient(90deg, rgba(30, 99, 214, 0.035), transparent 70%);
    box-shadow: inset 3px 0 0 var(--accent);
}

/* TODO-Nav: sanftes Slide-Right beim Hover deutet Klickbarkeit an */
.todo-nav__row {
    transition:
      background 0.14s,
      padding 0.16s cubic-bezier(.2,.7,.4,1);
}
.todo-nav__row:not(.is-active):hover {
    padding-left: 18px;
    background: var(--bg-soft);
}
.todo-nav__count {
    transition: transform 0.18s cubic-bezier(.2,.7,.4,1.5);
}
.todo-nav__row:hover .todo-nav__count:not(.is-zero) {
    transform: scale(1.06);
}

/* Tab-Wechsel: Inhalt blendet kurz auf */
@keyframes tab-fade-in {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}
.stage-panels > .stage:not([hidden]):not([style*="display: none"]) {
    /* aktive Stage bekommt einen leichten Reveal */
}
.stage-panels[data-active-tab="pool"]    > #stage-pool,
.stage-panels[data-active-tab="listen"]  > #stage-listen,
.stage-panels[data-active-tab="bestellt"]> #stage-bestellt,
.stage-panels[data-active-tab="archiv"]  > #stage-archiv {
    animation: tab-fade-in 0.28s cubic-bezier(.2,.7,.4,1);
}

/* ── Empty-State-Feier ─────────────────────────────────────────── */

.empty-celebration {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--sp-7) var(--sp-5);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
    position: relative;
    overflow: hidden;
}
.empty-celebration::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
      radial-gradient(circle at 50% 0%, rgba(16, 185, 129, 0.06), transparent 60%);
    pointer-events: none;
}
.empty-celebration__icon {
    width: 64px; height: 64px;
    margin: 0 auto var(--sp-4);
    border-radius: 50%;
    background: linear-gradient(180deg, #d1fae5, #a7f3d0);
    color: #047857;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 24px -8px rgba(16, 185, 129, 0.45);
    animation: bounce-in 0.6s cubic-bezier(.34,1.56,.64,1) both;
    position: relative;
    z-index: 1;
}
@keyframes bounce-in {
    0%   { transform: scale(0); opacity: 0; }
    60%  { transform: scale(1.08); opacity: 1; }
    100% { transform: scale(1); }
}
.empty-celebration h3 {
    font-family: var(--font-display);
    font-size: var(--fs-xl);
    font-weight: 600;
    letter-spacing: -0.02em;
    margin: 0 0 var(--sp-2);
    color: var(--fg-strong);
    position: relative;
    z-index: 1;
}
.empty-celebration p {
    color: var(--fg-soft);
    margin: 0;
    font-size: var(--fs-base);
    max-width: 420px;
    position: relative;
    z-index: 1;
}
.empty-celebration__cta {
    margin-top: var(--sp-4);
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: var(--r-pill);
    background: rgba(30, 99, 214, 0.08);
    transition: all 0.16s;
    position: relative;
    z-index: 1;
}
.empty-celebration__cta:hover {
    background: rgba(30, 99, 214, 0.14);
    text-decoration: none;
    gap: 10px;
}

/* ── Keyboard-Shortcut UI ─────────────────────────────────────── */

.kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-bottom-width: 2px;
    border-radius: 5px;
    font: 600 11px/1 var(--font-mono);
    color: var(--fg-mid);
    box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}

.kbd-hint {
    position: fixed;
    right: var(--sp-5);
    bottom: var(--sp-5);
    z-index: 20;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: rgba(15, 23, 42, 0.86);
    color: #cbd5e1;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--r-pill);
    font: 500 var(--fs-xs)/1 var(--font-body);
    backdrop-filter: blur(12px);
    cursor: pointer;
    box-shadow: 0 10px 40px -10px rgba(15, 23, 42, 0.45);
    transition: all 0.18s cubic-bezier(.2,.7,.4,1);
    opacity: 0.85;
}
.kbd-hint:hover {
    opacity: 1;
    transform: translateY(-2px);
    border-color: rgba(255, 255, 255, 0.18);
}
.kbd-hint .kbd {
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.18);
    color: #f1f5f9;
}

.kbd-overlay {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--sp-5);
    animation: tab-fade-in 0.2s cubic-bezier(.2,.7,.4,1);
}
.kbd-overlay[hidden] { display: none; }
.kbd-overlay__card {
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-lg);
    padding: var(--sp-6);
    width: min(440px, 100%);
    box-shadow: var(--sh-xl);
    animation: bounce-in 0.32s cubic-bezier(.2,.7,.4,1) both;
}
.kbd-overlay__card h3 {
    font-size: var(--fs-lg);
    font-weight: 600;
    letter-spacing: -0.018em;
    margin: 0 0 var(--sp-2);
}
.kbd-overlay__card > p {
    margin: 0 0 var(--sp-4);
    color: var(--fg-soft);
    font-size: var(--fs-sm);
}
.kbd-overlay__list {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--sp-2) var(--sp-4);
    align-items: center;
    margin: 0;
}
.kbd-overlay__list dt {
    display: inline-flex;
    gap: 4px;
    justify-content: flex-end;
}
.kbd-overlay__list dd {
    margin: 0;
    font-size: var(--fs-sm);
    color: var(--fg-strong);
}
.kbd-overlay__hint {
    margin-top: var(--sp-4);
    padding-top: var(--sp-3);
    border-top: 1px solid var(--border-soft);
    font-size: var(--fs-xs);
    color: var(--fg-soft);
    text-align: center;
}

/* ── KPI-Karten: subtle „heartbeat" wenn Action offen ──────────── */

@keyframes pulse-soft {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.55; }
}
.kpi.is-action::before {
    background-size: 200% 100%;
    animation: shimmer 4s ease-in-out infinite;
}
@keyframes shimmer {
    0%, 100% { background-position: 0% 50%; }
    50%      { background-position: 100% 50%; }
}

/* ── Reduced-motion respekt ───────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}

/* ════════════════════════════════════════════════════════════════════
   data-table-v2 — Freistehende, seriöse Datentabelle (Materials-Style)
   Kein Card-Wrapper, keine farbigen Seitenbalken, ruhige Trennlinien.
   Header sortierbar (visuell), Action-Buttons als farbige Icon-Pills,
   Meta-Footer unten rechts.
   ══════════════════════════════════════════════════════════════════════ */

.data-table-wrap {
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
    overflow: hidden;
}
.data-table-wrap > .data-table-v2 {
    margin: 0;
    border-radius: 0;
    box-shadow: none;
    border: none;
    width: 100%;
    border-collapse: collapse;
}

/* Tabellen-Header — heller Background, Sort-Indikator rechts, klar */
.data-table-v2 thead th {
    background: var(--bg-soft);
    border-bottom: 1px solid var(--border-strong);
    padding: 12px var(--sp-4);
    font: 600 11px/1 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--fg-mid);
    text-align: left;
    white-space: nowrap;
    position: relative;
}
.data-table-v2 thead th.num { text-align: right; }
.data-table-v2 thead th.sortable {
    cursor: pointer;
    padding-right: 28px;
    user-select: none;
    transition: color 0.12s;
}
.data-table-v2 thead th.sortable:hover { color: var(--fg-strong); }
.data-table-v2 thead th.sortable::after {
    content: '';
    position: absolute;
    right: var(--sp-3); top: 50%;
    width: 8px; height: 10px;
    margin-top: -5px;
    background:
      linear-gradient(180deg,
        var(--fg-soft) 0, var(--fg-soft) 3px,
        transparent 3px, transparent 5px,
        var(--fg-soft) 5px, var(--fg-soft) 7px,
        transparent 7px, transparent 10px) no-repeat;
    /* Doppelpfeil ↕ als CSS — leichter zu themen als Glyph */
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='10' viewBox='0 0 8 10'><path d='M4 0L7 3H1z M4 10L1 7H7z' fill='black'/></svg>") center / contain no-repeat;
            mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='10' viewBox='0 0 8 10'><path d='M4 0L7 3H1z M4 10L1 7H7z' fill='black'/></svg>") center / contain no-repeat;
    background: var(--fg-soft);
    opacity: 0.55;
    transition: opacity 0.12s;
}
.data-table-v2 thead th.sortable:hover::after { opacity: 1; }

/* Body-Zellen — angenehm luftig (14px vertikal) */
.data-table-v2 tbody td {
    padding: 14px var(--sp-4);
    border-bottom: 1px solid var(--border-soft);
    vertical-align: middle;
    font-size: var(--fs-sm);
    background: transparent;
}
.data-table-v2 tbody tr { transition: background 0.12s; }
.data-table-v2 tbody tr:hover { background: var(--bg-soft); }
.data-table-v2 tbody tr:hover td { background: transparent; }
.data-table-v2 tbody tr:hover { box-shadow: none; }
.data-table-v2 tbody tr:last-child td { border-bottom: none; }

/* Override: KEIN farbiger linker Akzent-Balken auf Hover */
.cart-table.data-table-v2 tbody tr:hover {
    background: var(--bg-soft);
    box-shadow: none;
}

/* Artikel-Cell — Titel groß, Meta in Code-Pills wie Referenz */
.data-table-v2 .row-title {
    font: 600 14px/1.35 var(--font-body);
    color: var(--fg-strong);
    letter-spacing: -0.01em;
    margin-bottom: 4px;
    display: block;
}
.data-table-v2 .row-meta {
    display: inline-flex;
    gap: 6px;
    align-items: center;
    flex-wrap: wrap;
    font-size: 12px;
    color: var(--fg-soft);
}
.data-table-v2 .row-meta code {
    font-family: var(--font-mono);
    font-size: 11px;
    background: var(--bg-soft);
    color: var(--fg-mid);
    padding: 2px 7px;
    border-radius: 4px;
    border: 1px solid var(--border-soft);
    letter-spacing: 0;
}
.data-table-v2 .row-meta .meta-sep { display: none; }

/* Numerische Werte — größer, fester, ruhiger */
.data-table-v2 .qty-big {
    font: 600 16px/1 var(--font-body);
    color: var(--fg-strong);
    font-variant-numeric: tabular-nums;
}
.data-table-v2 .qty-soft {
    color: var(--fg-soft);
    font-size: var(--fs-sm);
    font-variant-numeric: tabular-nums;
}

/* Footer mit Meta-Info — dezent, rechts ausgerichtet */
.data-table-foot {
    display: flex;
    justify-content: flex-end;
    padding: 10px var(--sp-4);
    background: var(--bg-soft);
    border-top: 1px solid var(--border-soft);
    font-size: 12px;
    color: var(--fg-soft);
    font-variant-numeric: tabular-nums;
}
.data-table-foot__meta {
    letter-spacing: 0.01em;
}

/* Inputs/Selects in der Tabelle dezenter rahmen */
.data-table-v2 .pool-supplier-select,
.data-table-v2 select {
    height: 32px;
    font-size: var(--fs-sm);
    background: var(--bg-elevated);
}
.data-table-v2 .qty-input {
    height: 30px;
    background: var(--bg-elevated);
}

/* Action-Cluster: Pillen-Style wie Materials-Referenz */
.data-table-v2 .action-cluster {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    justify-content: flex-end;
}
.data-table-v2 .btn-action {
    height: 30px;
    padding: 0 12px;
    background: var(--accent);
    color: #fff;
    border-radius: 6px;
    font: 600 12px/1 var(--font-body);
    letter-spacing: -0.005em;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}
.data-table-v2 .btn-action:hover {
    background: var(--accent-hover);
    color: #fff;
}
.data-table-v2 .btn-icon {
    width: 30px; height: 30px;
    border-radius: 6px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    color: var(--fg-soft);
}
.data-table-v2 .btn-icon:hover {
    background: var(--err-soft);
    border-color: #fecaca;
    color: var(--err);
}

/* ════════════════════════════════════════════════════════════════════
   PREISPLANUNG (/products) — Sync-Pill, Filter-Row, polished Table
   ══════════════════════════════════════════════════════════════════════ */

/* Header auf /products kompakter halten (lange Tabelle braucht den Platz) */
body[data-page="products"] .content,
.products-page .content { padding-top: 16px; }

.products-filter,
.products-filter-row { margin-bottom: 10px !important; }

.products-filter input[type="search"] {
    height: 34px;
    font-size: 14px;
}

/* Stats-Reihe auf /products etwas kompakter */
.page-head--with-stats .rec-stats--inline .rec-stat__num { font-size: 18px; }
.page-head--with-stats .rec-stats--inline .rec-stat__label { font-size: 10px; }

/* Page-Head selbst weniger Margin nach unten */
.page-head--with-stats { margin-bottom: 12px; }

/* Sync-Status als kompakte Pill (statt großem Banner) */
.sync-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    height: 32px;
    padding: 0 14px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: var(--r-pill);
    font: 500 12px/1 var(--font-body);
    color: var(--fg-mid);
    text-decoration: none;
    transition: all 0.12s;
}
.sync-pill:hover { border-color: var(--fg-mid); color: var(--fg-strong); text-decoration: none; }
.sync-pill__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--border-strong);
}
.sync-pill--ok   { color: #047857; border-color: #a7f3d0; background: var(--ok-soft); }
.sync-pill--ok .sync-pill__dot   { background: #10b981; box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.18); }
.sync-pill--warn { color: #b45309; border-color: #fde68a; background: var(--warn-soft); }
.sync-pill--warn .sync-pill__dot { background: #f59e0b; box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.18); }
.sync-pill--err  { color: #b91c1c; border-color: #fecaca; background: var(--err-soft); }
.sync-pill--err .sync-pill__dot  { background: #ef4444; box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.18); }
.sync-pill strong { color: inherit; font-weight: 600; }

/* Alte .sync-banner-Optik abschalten (sollte nicht mehr gerendert werden) */
.sync-banner { display: none; }

/* Filter-Form mit Such-Input und Filter-Pills-Reihe */
.products-filter {
    margin-bottom: 12px;
    align-items: center;
}
.products-filter-row {
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: 8px;
    padding: 8px 12px;
    margin-bottom: 10px;
    box-shadow: var(--sh-sm);
}
.products-filter-row .filter-pills {
    margin: 0;
}
.products-filter-row .filter-pills + .filter-pills {
    margin-top: 8px;
    padding-top: 10px;
    border-top: 1px dashed var(--border-soft);
}

/* Products-Tabelle: Sticky-Header + Zebra (gleiche Optik wie /recommendation).
   WICHTIG: kein overflow:hidden auf .products-table — das würde Sticky
   bei <th> kaputt machen. Stattdessen werden Ecken via clip-path
   beim ersten/letzten <th>/<td> simuliert (oder einfach nicht gerundet). */
.products-table {
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
    border-collapse: separate;
    border-spacing: 0;
    /* KEIN overflow:hidden — würde Sticky brechen */
}
.products-table thead th {
    position: sticky;
    top: 52px;
    z-index: 10;
    background: #eef0f4 !important;
    border-bottom: 1px solid #cbd5e1 !important;
    box-shadow: 0 1px 0 #cbd5e1;
    font-size: 10.5px !important;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #475569 !important;
    font-weight: 700 !important;
    padding: 10px 12px !important;
    white-space: nowrap;
}
/* Rounded corners auf Ecken-Cells statt overflow:hidden */
.products-table thead th:first-child { border-top-left-radius: 8px; }
.products-table thead th:last-child  { border-top-right-radius: 8px; }
.products-table tbody tr:last-child td:first-child { border-bottom-left-radius: 8px; }
.products-table tbody tr:last-child td:last-child  { border-bottom-right-radius: 8px; }
.products-table tbody tr td {
    background: #ffffff;
    border-bottom: 1px solid #e2e6ec !important;
    padding: 10px 12px !important;
}
.products-table tbody tr:nth-child(even) td { background: #f5f7fa; }
.products-table tbody tr:hover td { background: #e3eefe !important; border-bottom-color: #c5d8f5 !important; }
.products-table tbody tr:last-child td { border-bottom: none !important; }

/* Variant-Row-Indikator bleibt links — wird über cart-table.css behandelt */
.products-table tr.is-variant td:first-child {
    box-shadow: inset 4px 0 0 var(--accent);
}

/* Batch-Bar als Action-Toolbar oberhalb der Tabelle */
.batch-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin: 8px 0;
    padding: 10px 14px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: 8px;
    box-shadow: var(--sh-sm);
}
.batch-bar label {
    font-size: 13px;
    color: var(--fg-mid);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.batch-bar button[type="submit"] {
    height: 32px;
    padding: 0 14px;
    background: var(--accent);
    color: #fff;
    border: 1px solid var(--accent);
    border-radius: 6px;
    font: 600 13px/1 var(--font-body);
    cursor: pointer;
}
.batch-bar button[type="submit"]:hover { background: var(--accent-hover); }
.batch-bar > a.button {
    height: 32px;
    padding: 0 14px;
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    background: var(--bg-elevated);
    color: var(--fg-strong);
    border: 1px solid var(--border-strong);
    border-radius: 6px;
    font-size: 13px;
    text-decoration: none;
}
.batch-bar > a.button:hover { border-color: var(--accent); color: var(--accent); }

/* ════════════════════════════════════════════════════════════════════
   SOURCING-WORKSPACE — Master-Detail-Layout für Sortimentskorb
   Linke Sidebar: Item-Liste mit Status-Tabs.
   Rechte Spalte: Editor des aktuell ausgewählten Items (mit allen JTL-Feldern).
   ══════════════════════════════════════════════════════════════════════ */

.cart-workspace {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 20px;
    align-items: start;
}
@media (max-width: 1100px) {
    .cart-workspace { grid-template-columns: 1fr; }
}

/* ── Sidebar (Master) ── */
.cart-list {
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: 10px;
    overflow: hidden;
    position: sticky;
    top: 64px;
    max-height: calc(100vh - 80px);
    display: flex;
    flex-direction: column;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
}
.cart-list__tabs {
    display: flex;
    border-bottom: 1px solid var(--border-strong);
    background: var(--bg-soft);
    flex: 0 0 auto;
}
.cart-list__tab {
    flex: 1;
    padding: 10px 12px;
    text-align: center;
    text-decoration: none;
    color: var(--fg-mid);
    font: 500 13px/1 var(--font-body);
    letter-spacing: -0.005em;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: color 0.12s, border-color 0.12s, background 0.12s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.cart-list__tab:hover { color: var(--fg-strong); background: var(--bg-elevated); text-decoration: none; }
.cart-list__tab.is-active {
    color: var(--fg-strong);
    font-weight: 600;
    background: var(--bg-elevated);
    border-bottom-color: var(--fg-strong);
}
.cart-list__tab-count {
    min-width: 18px;
    height: 18px;
    padding: 0 6px;
    border-radius: 9px;
    background: var(--bg-elevated);
    color: var(--fg-soft);
    font: 700 11px/18px var(--font-body);
    font-variant-numeric: tabular-nums;
    text-align: center;
    border: 1px solid var(--border-strong);
}
.cart-list__tab.is-active .cart-list__tab-count {
    background: var(--fg-strong); color: #fff; border-color: var(--fg-strong);
}
.cart-list__tab-count--ok  { background: var(--ok-soft); color: #047857; border-color: #a7f3d0; }
.cart-list__tab-count--done{ background: var(--bg-soft); color: var(--fg-soft); }

.cart-list__items {
    flex: 1;
    overflow-y: auto;
    padding: 4px;
}
.cart-list__empty {
    padding: 24px 16px;
    color: var(--fg-soft);
    font-size: 13px;
    text-align: center;
    line-height: 1.5;
}

/* Item-Karte in der Sidebar */
.cart-item {
    display: flex;
    gap: 10px;
    padding: 10px;
    border-radius: 6px;
    text-decoration: none;
    color: inherit;
    transition: background 0.12s;
    margin-bottom: 2px;
    border: 1px solid transparent;
}
.cart-item:hover { background: var(--bg-soft); text-decoration: none; }
.cart-item.is-active {
    background: rgba(30, 99, 214, 0.08);
    border-color: rgba(30, 99, 214, 0.25);
}
.cart-item.is-active .cart-item__name { color: var(--accent); }

.cart-item__thumb {
    flex: 0 0 44px;
    width: 44px; height: 44px;
    border-radius: 6px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
    padding: 2px;
}
.cart-item__thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.cart-item__thumb-ph { color: var(--border-strong); font-size: 18px; }

.cart-item__body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.cart-item__name {
    font: 600 13px/1.3 var(--font-body);
    color: var(--fg-strong);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    letter-spacing: -0.005em;
}
.cart-item__brand {
    font-size: 11px;
    color: var(--fg-soft);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cart-item__brand code {
    font-family: var(--font-mono);
    font-size: 10px;
    background: var(--bg-soft);
    padding: 1px 4px;
    border-radius: 3px;
}
.cart-item__sub {
    font-size: 11px;
    font-weight: 500;
    margin-top: 2px;
}
.cart-item__sub--miss { color: var(--err); }
.cart-item__sub--ok   { color: #047857; }
.cart-item__sub--done { color: var(--fg-soft); }

/* Export-Auswahl-Form unter der Liste */
.cart-list__export {
    flex: 0 0 auto;
    padding: 10px 12px;
    border-top: 1px solid var(--border-strong);
    background: var(--bg-soft);
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.cart-list__export .btn.primary {
    width: 100%;
    padding: 10px;
    background: var(--accent);
    color: #fff;
    border: 1px solid var(--accent);
    border-radius: 6px;
    font: 600 13px/1 var(--font-body);
    cursor: pointer;
}
.export-pick-list summary {
    font: 500 12px/1 var(--font-body);
    color: var(--fg-mid);
    cursor: pointer;
    padding: 4px 0;
    list-style: none;
}
.export-pick-list summary::before {
    content: '▸';
    font-size: 10px;
    margin-right: 4px;
    transition: transform 0.15s;
}
.export-pick-list[open] summary::before { transform: rotate(90deg); }
.export-pick-list__body {
    margin-top: 8px;
    padding: 8px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: 6px;
    max-height: 200px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.export-pick {
    display: flex; align-items: center; gap: 6px;
    font-size: 12px;
    padding: 3px 4px;
    border-radius: 4px;
    cursor: pointer;
}
.export-pick:hover { background: var(--bg-soft); }

/* ── Detail (Editor-Pane) ── */
.cart-detail {
    min-width: 0;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: 10px;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.04);
    padding: 24px 28px;
}
.cart-detail__empty {
    padding: 60px 40px;
    text-align: center;
    color: var(--fg-soft);
}
.cart-detail__empty h2 {
    font-size: 18px;
    font-weight: 600;
    color: var(--fg-mid);
    margin: 0 0 8px;
}

/* Editor-Header im Pane */
.editor__head {
    display: flex; gap: 16px; align-items: flex-start;
    justify-content: space-between;
    padding-bottom: 14px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--border-soft);
    flex-wrap: wrap;
}
.editor__title-wrap { flex: 1; min-width: 0; }
.editor__title {
    margin: 0 0 6px;
    font: 600 19px/1.3 var(--font-body);
    letter-spacing: -0.018em;
    color: var(--fg-strong);
}
.editor__meta {
    display: flex; flex-wrap: wrap; gap: 6px 14px;
    margin: 0;
    font-size: 12px;
    color: var(--fg-soft);
}
.editor__meta strong { color: var(--fg-strong); font-weight: 600; }
.editor__meta code {
    font-family: var(--font-mono);
    background: var(--bg-soft);
    padding: 1px 6px;
    border-radius: 4px;
}

.editor__tools {
    display: inline-flex; gap: 6px; flex-wrap: wrap;
    flex: 0 0 auto;
}
.btn-light--sm {
    height: 28px; padding: 0 10px;
    font-size: 12px;
}

.editor-missing { margin: 0 0 16px; }

/* Action-Block am Ende der Form — gut sichtbarer Footer, NICHT sticky,
   damit das Layout vorhersagbar bleibt. */
.editor__actions {
    margin-top: 28px;
    padding: 16px 18px;
    background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
    border: 1px solid var(--border-strong);
    border-radius: 10px;
}
.editor__actions-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.editor__actions-row .btn-primary {
    height: 38px;
    padding: 0 18px;
    font-size: 14px;
}
.editor__status-hint {
    font-size: 13px;
    color: var(--fg-mid);
    flex: 1;
    min-width: 200px;
}
.editor__status-hint strong { color: var(--fg-strong); }
.editor__status-hint--ok   { color: #047857; }
.editor__status-hint--warn { color: #b45309; }

/* „Auf Bereit setzen"-Button — grüner Hero-CTA als nächster Schritt */
.btn-ready {
    height: 38px;
    padding: 0 18px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(180deg, #10b981 0%, #059669 100%);
    color: #fff;
    border: 1px solid #047857;
    border-radius: 7px;
    font: 600 14px/1 var(--font-body);
    cursor: pointer;
    transition: all 0.14s;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06), 0 2px 4px rgba(16, 185, 129, 0.18);
}
.btn-ready:hover {
    background: linear-gradient(180deg, #059669 0%, #047857 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.28);
}
.btn-ready:active { transform: translateY(0); }
.btn-ready:focus-visible { outline: none; box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.40); }
.btn-ready:disabled {
    background: var(--bg-soft);
    color: var(--fg-soft);
    border-color: var(--border-strong);
    cursor: not-allowed;
    box-shadow: none;
    transform: none;
}
.btn-ready svg { stroke: currentColor; }

/* ── KI-Debug-Tabelle (im AI-Status-Block) ───────────────────────── */

.ai-debug {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px dashed rgba(167, 139, 250, 0.5);
}
.ai-debug > summary {
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    color: #6d28d9;
    list-style: none;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    user-select: none;
}
.ai-debug > summary::-webkit-details-marker { display: none; }
.ai-debug > summary::before {
    content: '▸';
    font-size: 10px;
    transition: transform 0.15s;
}
.ai-debug[open] > summary::before { transform: rotate(90deg); }

.ai-debug__table {
    width: 100%;
    margin-top: 8px;
    border-collapse: collapse;
    background: #fff;
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid var(--border-soft);
    font-size: 12px;
}
.ai-debug__table th, .ai-debug__table td {
    padding: 6px 9px;
    border-bottom: 1px solid var(--border-soft);
    text-align: left;
    vertical-align: top;
}
.ai-debug__table thead th {
    background: var(--bg-soft);
    font: 600 10px/1.4 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--fg-soft);
}
.ai-debug__table tbody tr:last-child td { border-bottom: none; }
.ai-debug__table code {
    font-family: var(--font-mono);
    font-size: 11px;
    background: var(--bg-soft);
    padding: 1px 5px;
    border-radius: 3px;
    color: var(--fg-strong);
}
.ai-debug__val {
    max-width: 280px;
    color: var(--fg-mid);
    word-break: break-word;
}
.ai-debug__status {
    display: inline-block;
    padding: 1px 7px;
    border-radius: 3px;
    font: 600 10px/1.4 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ai-debug__status--filled   { background: var(--ok-soft); color: #047857; }
.ai-debug__status--skipped  { background: var(--bg-soft); color: var(--fg-soft); }
.ai-debug__status--note     { background: #ede9fe; color: #6d28d9; }
.ai-debug__status--unmapped { background: var(--warn-soft); color: #92400e; }

.ai-debug__raw {
    margin-top: 8px;
}
.ai-debug__raw > summary {
    cursor: pointer;
    font-size: 11px;
    color: var(--fg-soft);
    list-style: none;
}
.ai-debug__raw > summary::-webkit-details-marker { display: none; }
.ai-debug__raw > summary::before {
    content: '▸ ';
    font-size: 9px;
}
.ai-debug__raw[open] > summary::before { content: '▾ '; }
.ai-debug__raw pre {
    margin-top: 6px;
    background: var(--bg-soft);
    padding: 8px 10px;
    border-radius: 4px;
    font-size: 11px;
    line-height: 1.5;
    max-height: 280px;
    overflow: auto;
    white-space: pre-wrap;
    word-break: break-word;
    border: 1px solid var(--border-soft);
    color: var(--fg-strong);
}

/* Flash-Info-Variante (für Exported-Hinweis) */
.flash-info {
    background: rgba(30, 99, 214, 0.06);
    border-color: rgba(30, 99, 214, 0.20);
    color: var(--fg-mid);
}

/* ── KI-Anreicherung im Editor ──────────────────────────────────── */

.btn-light--ai {
    background: linear-gradient(180deg, #f5f3ff 0%, #ede9fe 100%);
    border-color: #c4b5fd;
    color: #6d28d9;
}
.btn-light--ai:hover {
    background: linear-gradient(180deg, #ede9fe 0%, #ddd6fe 100%);
    border-color: #8b5cf6;
    color: #5b21b6;
}
.btn-light--ai:disabled {
    opacity: 0.7;
    cursor: wait;
}

.ai-status {
    margin: 10px 0 14px;
    padding: 10px 14px;
    border-radius: 8px;
    border: 1px solid;
    font-size: 13px;
    line-height: 1.5;
}
.ai-status[hidden] { display: none; }
.ai-status--pending {
    background: #f5f3ff;
    border-color: #c4b5fd;
    color: #6d28d9;
}
.ai-status--ok {
    background: #ecfdf5;
    border-color: #a7f3d0;
    color: #047857;
}
.ai-status--error {
    background: #fef2f2;
    border-color: #fecaca;
    color: #b91c1c;
}
.ai-status strong { font-weight: 700; }
.ai-status small { color: var(--fg-soft); font-size: 11px; }
.ai-status pre {
    background: #fff;
    border: 1px solid var(--border-soft);
    border-radius: 4px;
    padding: 6px 8px;
    margin: 6px 0 0;
    overflow: auto;
    max-height: 200px;
}

/* Feld-Markierung: lila linker Balken + sanftes Tönung,
   beim ersten manuellen Edit (JS) wird die Klasse entfernt. */
.is-ai-suggested {
    background: linear-gradient(90deg, rgba(196, 181, 253, 0.18) 0%, rgba(196, 181, 253, 0.05) 100%) !important;
    border-left: 3px solid #8b5cf6 !important;
    padding-left: calc(var(--sp-3) - 2px) !important;
    transition: background 0.2s, border-color 0.2s;
}
.is-ai-suggested:focus {
    background: var(--bg-elevated) !important;
}
/* Textarea: ai-Marker als zusätzlicher Box-Shadow links */
textarea.is-ai-suggested {
    box-shadow: inset 3px 0 0 #8b5cf6, 0 0 0 1px #c4b5fd !important;
    background: linear-gradient(90deg, rgba(196, 181, 253, 0.10) 0%, transparent 100%) !important;
}

/* Identisch-Marker: grünes Häkchen + grüner Balken — KI hat denselben Wert */
.is-ai-identical {
    border-left: 3px solid #10b981 !important;
    padding-left: calc(var(--sp-3) - 2px) !important;
    background: linear-gradient(90deg, rgba(16, 185, 129, 0.08) 0%, transparent 60%) !important;
}
.is-ai-identical-pulse {
    animation: ai-pulse 1.2s cubic-bezier(.4, 0, .2, 1);
}
@keyframes ai-pulse {
    0%   { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.45); }
    100% { box-shadow: 0 0 0 8px rgba(16, 185, 129, 0); }
}
textarea.is-ai-identical {
    box-shadow: inset 3px 0 0 #10b981 !important;
}

/* Diff-Vorschlag-Panel unter einem Feld */
.ai-diff {
    margin: 6px 0 0;
    padding: 8px 10px;
    background: linear-gradient(180deg, #f5f3ff 0%, #ede9fe 100%);
    border: 1px solid #c4b5fd;
    border-left: 3px solid #8b5cf6;
    border-radius: 6px;
    font-size: 12px;
    color: var(--fg-strong);
    line-height: 1.4;
}
.ai-diff__head {
    display: flex;
    align-items: baseline;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.ai-diff__icon { font-size: 12px; }
.ai-diff__label {
    font-weight: 600;
    color: #6d28d9;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ai-diff__value {
    font-family: var(--font-mono);
    background: rgba(255, 255, 255, 0.7);
    padding: 2px 7px;
    border-radius: 4px;
    border: 1px solid rgba(196, 181, 253, 0.5);
    color: var(--fg-strong);
    word-break: break-word;
    flex: 1;
    min-width: 0;
}
.ai-diff__actions {
    display: flex;
    gap: 6px;
}
.ai-diff__btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 4px;
    font: 600 11px/1 var(--font-body);
    border: 1px solid;
    cursor: pointer;
    transition: all 0.12s;
}
.ai-diff__btn--accept {
    background: #10b981;
    color: #fff;
    border-color: #047857;
}
.ai-diff__btn--accept:hover {
    background: #047857;
    border-color: #065f46;
}
.ai-diff__btn--dismiss {
    background: #fff;
    color: var(--fg-mid);
    border-color: var(--border-strong);
}
.ai-diff__btn--dismiss:hover {
    background: var(--bg-soft);
    border-color: var(--fg-soft);
    color: var(--fg-strong);
}

/* Status-Pill für "identical" und "diff" in der Debug-Tabelle */
.ai-debug__status--identical { background: var(--ok-soft); color: #047857; }
.ai-debug__status--diff      { background: #ede9fe; color: #6d28d9; }

/* ════════════════════════════════════════════════════════════════════
   SOURCING — Sortable headers, supplier-badges, shop-status, modal
   ══════════════════════════════════════════════════════════════════════ */

/* Sortable Header */
.sourcing-table .th-sort { padding: 0; }
.sourcing-table .th-sort a {
    display: block;
    padding: 10px 12px;
    color: inherit;
    text-decoration: none;
    transition: background 0.12s, color 0.12s;
}
.sourcing-table .th-sort a:hover { background: var(--bg-soft); color: var(--fg-strong); text-decoration: none; }
.sourcing-table .th-sort.is-sorted a { color: var(--accent); }
.sort-arrow { font-size: 9px; opacity: .9; margin-left: 4px; }
.sort-arrow--idle { opacity: .25; }
.sort-note {
    margin-left: 12px;
    font-size: 11px;
    color: var(--fg-soft);
}
.sort-note strong { color: var(--fg-strong); }

/* Spalten-Breiten */
.sourcing-table .col-check { width: 32px; text-align: center; }
.sourcing-table .col-thumb { width: 56px; }
.sourcing-table .col-ean   { width: 130px; white-space: nowrap; }
.sourcing-table .col-supp  { width: 140px; }
.sourcing-table .col-status{ width: 80px; }
.sourcing-table .col-num   { width: 88px; }
.sourcing-table .col-margin{ width: 130px; }

/* Artikel-Cell: Title als Button (Klick öffnet Modal) */
.article-link {
    display: inline-block;
    padding: 0;
    background: transparent;
    border: none;
    color: var(--fg-strong);
    font: 600 13.5px/1.4 var(--font-body);
    cursor: pointer;
    text-align: left;
    letter-spacing: -0.005em;
    max-width: 100%;
}
.article-link:hover { color: var(--accent); text-decoration: underline; }
.article-meta { font-size: 11.5px; color: var(--fg-soft); margin-top: 2px; }
.article-meta strong { color: var(--fg-mid); font-weight: 600; }

/* Thumbnail */
.sourcing-table .col-thumb img {
    width: 40px; height: 40px;
    object-fit: contain;
    border-radius: 4px;
    background: #fff;
    border: 1px solid var(--border-soft);
    padding: 2px;
}

/* Lieferanten-Badges */
.supp-badge {
    display: inline-flex; align-items: center;
    padding: 2px 7px;
    margin-right: 4px;
    border-radius: 4px;
    font: 600 11px/1.4 var(--font-body);
    border: 1px solid;
    letter-spacing: -0.005em;
}
.supp-badge strong { font-weight: 700; margin-left: 3px; }
.supp-badge--awin {
    background: rgba(30, 99, 214, 0.10);
    color: var(--accent);
    border-color: rgba(30, 99, 214, 0.25);
}
.supp-badge--tekno {
    background: var(--ok-soft);
    color: #047857;
    border-color: #a7f3d0;
}
.supp-badge--none {
    background: transparent;
    color: var(--fg-soft);
    border-color: var(--border-soft);
}

/* Shop-Status-Badge */
.shop-badge {
    display: inline-flex; align-items: center;
    padding: 3px 9px;
    border-radius: 999px;
    font: 600 11px/1 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border: 1px solid;
}
.shop-badge--new      { background: var(--bg-elevated); color: var(--accent); border-color: rgba(30, 99, 214, 0.25); }
.shop-badge--active   { background: var(--ok-soft); color: #047857; border-color: #a7f3d0; }
.shop-badge--inactive { background: var(--bg-soft); color: var(--fg-soft); border-color: var(--border-strong); }

/* Klickbare Zeile signalisieren */
.sourcing-row { cursor: default; }
.sourcing-row:hover .article-link { color: var(--accent); }

/* Quick-Add-Button: einzelner Artikel direkt in den Korb */
.sourcing-table .col-action { width: 56px; text-align: center; }
.btn-quickadd {
    width: 32px; height: 32px;
    padding: 0;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--bg-elevated);
    border: 1px solid var(--border-strong);
    border-radius: 6px;
    color: var(--accent);
    cursor: pointer;
    transition: all 0.12s;
}
.btn-quickadd:hover {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(30, 99, 214, 0.25);
}
.btn-quickadd:active { transform: translateY(0); }
.btn-quickadd:focus-visible { outline: none; box-shadow: var(--sh-focus); }
.btn-quickadd svg { stroke: currentColor; }

/* ── Detail-Modal ────────────────────────────────────────────── */

.src-modal {
    position: fixed; inset: 0;
    z-index: 200;
    display: flex; align-items: center; justify-content: center;
    padding: 24px;
}
.src-modal[hidden] { display: none; }
.src-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(4px);
}
.src-modal__card {
    position: relative;
    background: var(--bg-elevated);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(15, 23, 42, 0.30);
    width: min(640px, 100%);
    max-height: calc(100vh - 48px);
    overflow: auto;
    padding: 28px 32px;
}
.src-modal__close {
    position: absolute; top: 10px; right: 14px;
    width: 32px; height: 32px;
    background: transparent; border: none;
    font-size: 24px; line-height: 1;
    color: var(--fg-soft);
    cursor: pointer;
    border-radius: 50%;
    transition: all 0.12s;
}
.src-modal__close:hover { background: var(--bg-soft); color: var(--err); }
.src-modal__head {
    display: flex; gap: 20px; align-items: flex-start;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border-soft);
    margin-bottom: 16px;
}
.src-modal__img,
.src-modal__img-placeholder {
    width: 120px; height: 120px;
    object-fit: contain;
    border: 1px solid var(--border-soft);
    border-radius: 8px;
    background: #fff;
    padding: 6px;
    flex: 0 0 auto;
}
.src-modal__img-placeholder {
    display: flex; align-items: center; justify-content: center;
    color: var(--fg-soft); font-size: 12px;
    background: var(--bg-soft);
}
.src-modal__title { flex: 1; min-width: 0; }
.src-modal__title h2 {
    margin: 0 0 6px;
    font: 600 18px/1.3 var(--font-body);
    letter-spacing: -0.018em;
    color: var(--fg-strong);
}
.src-modal__meta {
    margin: 0 0 6px;
    font-size: 13px;
    color: var(--fg-mid);
}
.src-modal__meta strong { color: var(--fg-strong); }
.src-modal__meta code {
    font-family: var(--font-mono);
    font-size: 12px;
    background: var(--bg-soft);
    padding: 1px 6px;
    border-radius: 4px;
}
.src-modal__cat {
    margin: 0 0 8px;
    font-size: 12px;
    color: var(--fg-soft);
}
.src-modal__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 14px;
    margin-bottom: 16px;
}
.src-modal__grid > div {
    padding: 12px 14px;
    background: var(--bg-soft);
    border-radius: 8px;
    border: 1px solid var(--border-soft);
    display: flex; flex-direction: column; gap: 2px;
}
.src-modal__lbl {
    font: 600 10px/1 var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--fg-soft);
}
.src-modal__val {
    font: 700 18px/1.2 var(--font-body);
    color: var(--fg-strong);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.025em;
}
.src-modal__grid small { font-size: 11px; color: var(--fg-soft); }
.src-modal__actions {
    padding-top: 14px;
    border-top: 1px solid var(--border-soft);
    font-size: 13px;
}
.src-modal__actions label {
    display: inline-flex; align-items: center; gap: 6px;
    cursor: pointer;
}

/* ── Sourcing-Suche: "kein EK"-Zeilen dezent ─────────────────────── */

.sourcing-table tr:has(.pill-gray) {
    color: var(--fg-soft);
    background: rgba(0, 0, 0, 0.012);
}
.sourcing-table tr:has(.pill-gray) strong { font-weight: 500; color: var(--fg-mid); }
.sourcing-table tr:has(.pill-gray) .num { color: var(--fg-soft); }
.sourcing-table tr:has(.pill-gray):hover {
    color: var(--fg-strong);
    background: var(--bg-soft);
}
.sourcing-table tr:has(.pill-gray):hover strong { color: var(--fg-strong); font-weight: 600; }

.thumb-placeholder {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border-radius: var(--r-sm);
    background: var(--bg-soft);
    border: 1px dashed var(--border-strong);
    color: #cbd5e1;
    font-size: var(--fs-xs);
}

.sourcing-table img {
    width: 40px; height: 40px;
    object-fit: contain;
    border-radius: var(--r-sm);
    background: #fff;
    border: 1px solid var(--border-soft);
    padding: 2px;
}

.src-tag {
    display: inline-block;
    padding: 1px 7px;
    background: var(--bg-soft);
    color: var(--fg-mid);
    border-radius: var(--r-pill);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.02em;
    margin-right: 3px;
}

.results-bar {
    display: flex; align-items: center; gap: var(--sp-3);
    margin: var(--sp-3) 0 var(--sp-4);
    padding: var(--sp-2) var(--sp-3);
    background: var(--bg-elevated);
    border: 1px solid var(--border-soft);
    border-radius: var(--r-md);
    box-shadow: var(--sh-sm);
}
.results-bar .btn,
.results-bar button[type="submit"] {
    margin-left: auto;
    height: 32px;
    padding: 0 var(--sp-4);
    background: var(--accent); color: #fff;
    border: 1px solid var(--accent);
    border-radius: var(--r-sm);
    font: 600 var(--fs-sm)/1 var(--font-body);
    cursor: pointer;
}

/* ── Sortimentskorb: Status-Spalte visuell harmonisieren ──────────── */
/* Die Status-Texte "ENTWURF · 1 FELDER", "BEREIT" etc. stehen als
   nackter Text in einer Zelle. Wir setzen via :has()-Logik keine
   Klasse — aber das Padding der Statuszelle wird ruhiger. */

/* ── Bild-URL-Inputs im Item-Editor kompakter ────────────────────── */

.sourcing-item-form input[type="text"][name^="jtl[Bild"] {
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    height: 32px;
    color: var(--fg-mid);
    background:
      linear-gradient(90deg, transparent 0, transparent calc(100% - 28px), var(--bg-soft) calc(100% - 28px), var(--bg-soft) 100%);
}
.sourcing-item-form input[type="text"][name^="jtl[Bild"]:focus {
    background: var(--bg-elevated);
    color: var(--fg-strong);
}

/* ── Kategorie-Picker im Item-Editor begrenzen ──────────────────── */

#catList, .cat-list, ul.cat-list {
    max-height: 360px;
    overflow-y: auto;
    margin: 0;
    padding: var(--sp-2);
    background: var(--bg-soft);
    border-radius: var(--r-sm);
    border: 1px solid var(--border-soft);
    list-style: none;
    font-size: var(--fs-sm);
}
.cat-opt {
    padding: 3px 6px;
    border-radius: 4px;
    cursor: pointer;
}
.cat-opt:hover { background: var(--bg-elevated); color: var(--accent); }
.cat-opt-path { color: var(--fg-soft); font-size: var(--fs-xs); }

/* ── "Vor Export zu pflegen"-Warnung intentional gestalten ────────── */

.flash.flash-warning strong { display: block; margin-bottom: 4px; }
.flash.flash-warning ul { margin: 0; padding-left: var(--sp-5); }

/* ── Login-Hero: ruhiger, weniger Hero-Padding ────────────────────── */

.login-hero { padding: var(--sp-6); }
.login-hero__panel h1 { font-size: var(--fs-2xl); }
.login-hero__cta {
    background: var(--accent);
    color: #fff;
    border: 1px solid var(--accent);
}

/* ── Mobile (für Wareneinkauf primär) ─────────────────────────────── */

@media (max-width: 820px) {
    .topbar { gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); flex-wrap: wrap; }
    .mainnav { order: 3; width: 100%; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
    .mainnav > a, .nav-group-head { white-space: nowrap; }
    .content { padding: 0 var(--sp-3) var(--sp-6); margin: var(--sp-4) auto; }
    .nav-group-menu { left: 0; right: auto; }
    fieldset.form-section { padding: var(--sp-3); }
    .form-grid { grid-template-columns: 1fr; }
    .debug-tray { padding: 0 var(--sp-2) var(--sp-2); }
    h1 { font-size: var(--fs-2xl); }
}
