:root {
    /* Brand: warm greige + ink-zwart + lime-accent (bento/soft-UI stijl). */
    --bg: #e7e6e0;            /* achtergrond achter de app-shell */
    --shell: #f4f3ef;        /* grote afgeronde app-container */
    --bg-soft: #efeee8;       /* subtiele vlakken (tabelkop, hover) */
    --card: #ffffff;
    --border: #e8e6de;
    --border-strong: #dad7cd;
    --text: #1a1c1e;
    --muted: #6f6e67;
    --primary: #1c1e20;       /* primair = ink (knoppen/actief) */
    --primary-600: #111315;
    --primary-50: #ecebe4;
    --accent: #d6f23f;        /* lime highlight */
    --accent-ink: #1b1d1f;
    --btn-fg: #ffffff;        /* tekst op primaire (ink) knop */
    --accent-soft: #eef7c4;
    --accent-grad: linear-gradient(135deg, #e2f55c 0%, #c7ec3a 100%);
    --link: #2f6ae0;
    --danger: #d8483f;
    --danger-soft: #fbe9e7;
    --green: #2f9e54;
    --green-soft: #e7f5ec;
    --warn: #b9740a;
    --warn-soft: #fbf1df;

    --radius: 20px;
    --radius-sm: 14px;
    --radius-xs: 11px;
    --shadow-sm: 0 1px 2px rgba(24,24,20,.05), 0 2px 8px rgba(24,24,20,.04);
    --shadow: 0 8px 24px rgba(24,24,20,.08);
    --shadow-lg: 0 24px 60px rgba(24,24,20,.13);
    --ring: 0 0 0 3px rgba(28,30,32,.15);
    --tr: 160ms cubic-bezier(.4, 0, .2, 1);
}

/* App-shell: de hele app in één grote afgeronde container (referentie-stijl). */
.app-shell {
    max-width: 1340px;
    margin: 1.1rem auto;
    background: var(--shell);
    border: 1px solid var(--border);
    border-radius: 30px;
    box-shadow: var(--shadow-lg);
    overflow: clip;
}

/* Slanke top-progress-bar voor htmx/SPA-navigatie. */
#top-progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; z-index: 300;
    background: var(--accent); border-radius: 0 3px 3px 0; opacity: 0; pointer-events: none; }
#top-progress.active { width: 85%; opacity: 1; transition: width 9s cubic-bezier(.08,.7,.3,1); }
#top-progress.done { width: 100%; opacity: 0; transition: width .2s ease, opacity .35s ease .15s; }

* { box-sizing: border-box; }

html {
    /* iOS/Safari blaast tekst in brede kolommen automatisch op → uitzetten */
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

body {
    margin: 0;
    font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background: var(--bg);
    color: var(--text);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: -0.011em;
}

.topbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.3rem 1.4rem;
    background: transparent;
    border-bottom: 1px solid var(--border);
}
.brand {
    font-weight: 800; font-size: 0.98rem; letter-spacing: -0.02em;
    padding: 0.4rem 0.8rem; border: 1px solid var(--border-strong);
    border-radius: 999px; background: var(--card); color: var(--text);
    text-decoration: none; white-space: nowrap; transition: background var(--tr);
}
.brand:hover { background: var(--bg-soft); }
.nav { display: flex; align-items: center; gap: 0.15rem; }
.nav > a {
    text-decoration: none;
    color: var(--muted);
    font-weight: 600;
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
    white-space: nowrap;
    transition: background var(--tr), color var(--tr);
}
.nav > a:hover { color: var(--text); background: var(--bg-soft); }
.nav > a.active { color: var(--btn-fg); background: var(--primary); }

/* Dropdown-groepen (CSS-only, hover + focus voor toetsenbord) */
.nav-group { position: relative; }
.nav-trigger {
    background: none; border: none; cursor: pointer;
    color: var(--muted); font-weight: 600; font-size: 0.95rem;
    padding: 0.4rem 0.7rem; border-radius: 999px; font-family: inherit;
    white-space: nowrap;
    transition: background var(--tr), color var(--tr);
}
.nav-trigger:hover { color: var(--text); background: var(--bg-soft); }
.nav-trigger.active { color: var(--btn-fg); background: var(--primary); }
.nav-menu {
    position: absolute; top: 100%; left: 0; min-width: 200px;
    background: var(--card); border: 1px solid var(--border); border-radius: 9px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.10); padding: 0.4rem;
    display: none; z-index: 50;
}
.nav-group:hover .nav-menu,
.nav-group:focus-within .nav-menu { display: block; }
.nav-menu a {
    display: block; padding: 0.5rem 0.7rem; border-radius: 6px;
    text-decoration: none; color: var(--text); font-size: 0.92rem; font-weight: 500;
}
.nav-menu a:hover { background: var(--bg); }
.nav-menu a.active { color: var(--primary); background: var(--bg); }
.help-list { margin: 0.5rem 0 0; padding-left: 1.1rem; }
.help-list li { margin-bottom: 0.6rem; line-height: 1.5; }
.help-list em { color: var(--muted); font-style: normal; }

.container { max-width: none; margin: 0; padding: 1.3rem 1.6rem 2.2rem; }

.page-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.btn {
    background: var(--primary-600);
    color: var(--btn-fg);
    border: none;
    border-radius: var(--radius-xs);
    padding: 0.56rem 1.05rem;
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    cursor: pointer;
    box-shadow: 0 1px 2px rgba(24,24,20,.18), 0 6px 16px rgba(24,24,20,.16);
    transition: transform var(--tr), box-shadow var(--tr), filter var(--tr);
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 2px 4px rgba(24,24,20,.2), 0 10px 24px rgba(24,24,20,.22); }
.btn:active { transform: translateY(0); }
.btn:disabled { opacity: 0.6; cursor: progress; box-shadow: none; transform: none; }

/* Globale invoervelden: modern, met accent focus-ring. :where() = 0 specificiteit,
   zodat compacte component-velden (filters/threshold/row-actions) blijven winnen. */
:where(input:not([type="checkbox"]):not([type="radio"]):not([type="range"]), select, textarea) {
    background: var(--card); color: var(--text);
    border: 1px solid var(--border-strong); border-radius: var(--radius-xs);
    padding: 0.5rem 0.7rem; font-size: 0.9rem; font-family: inherit;
    transition: border-color var(--tr), box-shadow var(--tr), background var(--tr);
}
:where(input, select, textarea):focus {
    outline: none; border-color: var(--primary); box-shadow: var(--ring);
}
input::placeholder { color: var(--muted); opacity: 0.7; }

.price-form { display: flex; flex-wrap: wrap; gap: 1rem; align-items: flex-end; }
.price-form label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.85rem; color: var(--muted); }
.price-form input { padding: 0.5rem 0.7rem; border: 1px solid var(--border); border-radius: 7px; font-size: 0.95rem; }
.ship-item { font-size: 0.85rem; }
.ship-qty { display: inline-block; min-width: 64px; font-variant-numeric: tabular-nums; color: var(--muted); }

.attr-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 0.8rem; }
.attr-grid > div { font-size: 0.95rem; }
.attr-label { display: block; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--muted); }
.edit-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.8rem; align-items: end; }
.edit-form label { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.8rem; color: var(--muted); min-width: 0; }
.edit-form input, .edit-form select { padding: 0.45rem 0.6rem; border: 1px solid var(--border); border-radius: 7px; font-size: 0.95rem; width: 100%; min-width: 0; box-sizing: border-box; }
.edit-form .btn { grid-column: 1 / -1; justify-self: start; }
/* Product-thumbnail (bol-hoofdafbeelding) naast titels op productmaster + voorraad */
.prod-thumb { width: 44px; height: 44px; object-fit: cover; border-radius: 6px; border: 1px solid var(--border); background: #fff; flex: 0 0 auto; vertical-align: middle; }
.prod-cell { display: flex; align-items: center; gap: 0.6rem; }
.pm-name .prod-thumb { width: 38px; height: 38px; margin-right: 0.15rem; }
.prod-thumb-ph { object-fit: contain; opacity: 0.9; }
.import-ok { color: var(--green); font-weight: 600; }
.import-err { color: var(--danger); font-weight: 600; }
.muted-row td { color: var(--muted); background: #fafbfc; }
.row-actions { display: flex; gap: 0.5rem; }
.row-actions form { display: inline; }
.link-btn { background: none; border: none; color: var(--link); cursor: pointer; font-size: 0.85rem; padding: 0; }
.link-btn.danger { color: var(--danger); font-weight: 700; }
/* Status-kleuren met .badge.-prefix zodat ze de .badge-basis (later in dit bestand)
   overschrijven; anders zijn alle pills blauw. */
.badge.status-uitverkocht { background: #fef2f2; color: var(--danger); }
.badge.status-bestellen { background: #fef2f2; color: var(--danger); }      /* inkopen = rood */
.badge.status-bijnaop { background: #fffbeb; color: #b45309; }              /* amber */
.badge.status-ok { background: #ecfdf5; color: var(--green); }              /* op koers = groen */
.badge.status-nuversturen { background: #fff7ed; color: #c2410c; }          /* oranje */
.badge.status-achterlandleeg { background: #fef2f2; color: var(--danger); } /* rood */
.badge.status-binnenkort { background: #fffbeb; color: #b45309; }           /* amber */
.badge.status-opkoers { background: #ecfdf5; color: var(--green); }         /* groen */
.badge.status-uitlopend, .badge.status-geenverkoop { background: #f3f4f6; color: #6b7280; }  /* grijs */
.badge.status-open { background: #ecfdf5; color: var(--green); }            /* open = wijzigbaar */
.badge.status-locked { background: #f3f4f6; color: #6b7280; }               /* geboekt/locked */
.badge.status-cancelled { background: #fef2f2; color: var(--danger); }      /* geannuleerd */
.badge.status-concept { background: #f3f4f6; color: #6b7280; }
.badge.status-besteld { background: #eef2ff; color: #4338ca; }
.badge.status-inproductie { background: #fffbeb; color: #b45309; }
.badge.status-aangemeldi4y { background: #eff6ff; color: #1d4ed8; }
.badge.status-verzonden { background: #ecfeff; color: #0e7490; }
.badge.status-ontvangen { background: #ecfdf5; color: var(--green); }
.badge.status-geannuleerd { background: #fef2f2; color: var(--danger); }
.badge.status-pending { background: #fffbeb; color: #b45309; }
.badge.status-approved { background: #ecfdf5; color: var(--green); }
.badge.status-rejected { background: #fef2f2; color: var(--danger); }
.row-actions-stack { display: flex; flex-direction: column; gap: 0.4rem; }
.row-actions-stack form { display: flex; gap: 0.3rem; align-items: center; flex-wrap: wrap; }
.row-actions-stack input { padding: 0.3rem 0.5rem; border: 1px solid var(--border); border-radius: 6px; font-size: 0.8rem; }
.exec-form input { max-width: 110px; }

h1 { font-size: 1.5rem; margin-bottom: 1rem; }
h2 { font-size: 1.05rem; margin: 0 0 0.75rem; }
.muted { color: var(--muted); font-weight: 400; }

.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}
.kpi-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.05rem 1.25rem;
    box-shadow: var(--shadow-sm);
    transition: transform var(--tr), box-shadow var(--tr);
}
a.kpi-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.kpi-label { color: var(--muted); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
.kpi-value { font-size: 1.7rem; font-weight: 700; margin-top: 0.35rem; letter-spacing: -0.02em; }
.kpi-value.small { font-size: 1rem; font-weight: 600; }
.kpi-sub { display: block; color: var(--muted); font-size: 0.72rem; margin-top: 0.2rem; }

/* Zoektermen-chips (tag-input met hover-✕) */
.chip-box { display: flex; flex-wrap: wrap; gap: 0.35rem; align-items: center;
    border: 1px solid var(--border-strong, #dad7cd); border-radius: var(--radius-xs, 11px);
    padding: 0.35rem 0.45rem; background: var(--card, #fff); min-height: 38px; }
.chip-box:focus-within { border-color: var(--primary); box-shadow: var(--ring); }
.chip { display: inline-flex; align-items: center; gap: 0.25rem; background: var(--bg-soft, #efeee8);
    border: 1px solid var(--border, #e8e6de); border-radius: 999px; padding: 0.15rem 0.55rem;
    font-size: 0.82rem; white-space: nowrap; }
.chip-x { border: 0; background: none; cursor: pointer; color: var(--muted, #6f6e67); font-size: 1rem;
    line-height: 1; padding: 0; opacity: 0; width: 0; overflow: hidden;
    transition: opacity 0.12s, width 0.12s; }
.chip:hover .chip-x, .chip:focus-within .chip-x { opacity: 1; width: 1rem; }
.chip-x:hover { color: var(--danger, #d8483f); }
.chip-input { border: 0 !important; outline: 0; flex: 1; min-width: 130px; padding: 0.2rem !important;
    background: transparent !important; box-shadow: none !important; }
.kpi-toggle { border: 1px solid var(--border); background: #fff; border-radius: 6px; cursor: pointer; font-size: 0.8rem; line-height: 1; padding: 0.1rem 0.35rem; margin-left: 0.3rem; color: var(--primary); }
.kpi-toggle:hover { background: var(--bg); }

.card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.35rem;
    margin-bottom: 1.5rem;
    box-shadow: var(--shadow-sm);
}

.filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-bottom: 1rem;
}
.filters input, .filters select {
    padding: 0.5rem 0.7rem;
    border: 1px solid var(--border);
    border-radius: 7px;
    font-size: 0.9rem;
}
.filters input[type="search"] { min-width: 240px; }
.checkbox { display: flex; align-items: center; gap: 0.4rem; color: var(--muted); }

/* Filter-/actie-balk: zoekveld links, actie-popovers rechts — gedeeld patroon over
   pagina's (Productmaster, Inbound, …) zodat de layout overal in lijn ligt. */
.filter-bar { display: flex; align-items: flex-start; justify-content: space-between;
    gap: 0.75rem; flex-wrap: wrap; margin-bottom: 1rem; }
.filter-bar .filters { margin-bottom: 0; flex: 1 1 320px; }
.filter-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: flex-start; }
.action-pop { position: relative; margin: 0; }
.action-pop > summary { list-style: none; cursor: pointer; display: inline-flex; align-items: center;
    gap: 0.35rem; padding: 0.5rem 0.85rem; border: 1px solid var(--border-strong);
    border-radius: var(--radius-xs); background: var(--card); color: var(--text);
    font-size: 0.85rem; font-weight: 600; white-space: nowrap; transition: border-color var(--tr); }
.action-pop > summary::-webkit-details-marker { display: none; }
.action-pop > summary::before { content: "+"; font-weight: 700; color: var(--link); font-size: 1.05em; line-height: 1; }
.action-pop > summary:hover { border-color: var(--text); }
.action-pop[open] > summary { border-color: var(--text); box-shadow: var(--ring); }
.action-pop-body { position: absolute; right: 0; top: calc(100% + 0.4rem); z-index: 40;
    min-width: 340px; max-width: min(94vw, 480px); background: var(--card);
    border: 1px solid var(--border); border-radius: var(--radius-sm);
    box-shadow: var(--shadow-lg); padding: 1rem 1.1rem; }
.action-pop-wide > .action-pop-body { min-width: min(94vw, 720px); max-width: min(94vw, 720px); }
.action-pop-body h3 { margin: 0 0 0.5rem; font-size: 0.95rem; }
.action-pop-body > form { margin: 0; }
.action-pop-body .meta:first-child { margin-top: 0; }
@media (max-width: 760px) {
    .filter-bar { flex-direction: column; align-items: stretch; }
    .filter-actions { width: 100%; }
    .action-pop, .action-pop > summary { width: 100%; justify-content: center; }
    .action-pop-body { left: 0; right: auto; width: 100%; min-width: 0; }
}

/* Gegroepeerde lijst-kadertjes — actief / lancering / uitlopend, elk inklapbaar in een
   eigen kader. Gedeeld door Productmaster en Sales & velocity zodat ze identiek ogen. */
.pm-group { margin: 0 0 0.9rem; border: 1px solid var(--border); background: var(--bg-soft);
    border-radius: var(--radius-sm); box-shadow: var(--shadow-sm); padding: 0.15rem 0.7rem 0.55rem; }
.pm-group > summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: 0.5rem;
    padding: 0.55rem 0.15rem; border-bottom: 1px solid var(--border); margin: 0 0 0.35rem; }
.pm-group > summary::-webkit-details-marker { display: none; }
.pm-group > summary h2 { margin: 0; font-size: 1.05rem; font-weight: 700; }
.pm-group-n { font-size: 0.8rem; color: var(--muted); font-weight: 600; }

/* Uitleg-tekst onderaan een pagina (verplaatst van bovenaan): subtiel afgescheiden. */
.page-foot-note { margin-top: 1.5rem; padding-top: 0.9rem; border-top: 1px solid var(--border); }

.data-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    overflow: hidden;
    font-size: 0.85rem;
}
/* Alle cel-inhoud (incl. titels, links) exact dezelfde grootte als de rest */
.data-table th, .data-table td,
.data-table td a, .data-table td span:not(.badge) { font-size: inherit; font-weight: 400; }
.data-table td a { font-weight: 500; }
.data-table th, .data-table td {
    padding: 0.6rem 0.8rem;
    text-align: left;
    border-bottom: 1px solid var(--border);
}
.data-table th { background: var(--bg-soft); color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; font-size: 0.7rem; }
.data-table td.num, .data-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.data-table tbody tr { transition: background var(--tr); }
.data-table tbody tr:not(.row-buy):not(.row-ship):not(.low-stock):not(.muted-row):hover td { background: var(--bg-soft); }
.data-table tr.low-stock td { background: var(--danger-soft); }
.data-table a { color: var(--link); text-decoration: none; font-weight: 500; }
.data-table a:hover { text-decoration: underline; }
/* knoppen in tabellen mogen NIET de blauwe tabel-linkkleur erven (= leesbare knoptekst) */
.data-table a.btn { color: var(--btn-fg); }
.data-table a.btn:hover { text-decoration: none; }
/* product-chip in de inkooporders-Producten-cel (thumbnail + naam) */
.po-prod { display: inline-flex; align-items: center; gap: 0.3rem; vertical-align: middle; margin: 0 0.15rem 0.15rem 0; }
.prod-thumb-xs { width: 20px; height: 20px; border-radius: 4px; }
.empty { text-align: center; color: var(--muted); padding: 1.5rem; }
.meta { color: var(--muted); font-size: 0.8rem; margin-top: 0.5rem; }

.badge {
    display: inline-block;
    padding: 0.17rem 0.55rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.4;
    background: var(--primary-50);
    color: var(--primary-600);
}
.badge-inbound, .badge-return { background: #ecfdf5; color: var(--green); }
.badge-outbound, .badge-sale { background: #fef2f2; color: var(--danger); }
.badge-adjustment { background: #fffbeb; color: #b45309; }
.badge-transfer { background: #eef2ff; color: var(--primary); }

/* ----------------------------------------------------------------------
   Responsive / mobile-friendly. Standaard voor alle (nieuwe) pagina's:
   wikkel brede tabellen in .table-wrap of vertrouw op de mobile-regels.
---------------------------------------------------------------------- */

/* Horizontaal scrollbare tabel-wrapper (gebruik <div class="table-wrap">) */
.table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* Hamburger alleen tonen op mobiel */
.hamburger { display: none; font-size: 1.5rem; cursor: pointer; padding: 0.2rem 0.5rem; line-height: 1; user-select: none; }

@media (max-width: 900px) {
    .topbar { flex-wrap: wrap; gap: 0.4rem; padding: 0.35rem 0.9rem; }
    .brand { flex: 1; font-size: 0.9rem; padding: 0.3rem 0.6rem; }
    .hamburger { display: block; padding: 0.1rem 0.45rem; }

    /* Menu standaard verborgen; klap verticaal open onder de balk bij checkbox-aan */
    .nav {
        display: none;
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        gap: 0.15rem;
        margin-top: 0.5rem;
    }
    .nav-toggle-cb:checked ~ .nav { display: flex; }

    .nav > a { width: 100%; padding: 0.5rem 0.6rem; border-radius: 8px; }

    /* Groepen: trigger vol-breed, submenu inline uitgeklapt (geen hover nodig) */
    .nav-group { width: 100%; }
    .nav-trigger { width: 100%; text-align: left; padding: 0.5rem 0.6rem; }
    .nav-menu {
        display: block;
        position: static;
        box-shadow: none;
        border: none;
        padding: 0 0 0.3rem 0.8rem;
        min-width: 0;
    }
    .nav-menu a { padding: 0.4rem 0.6rem; }

    .container { padding: 1rem; }
    h1 { font-size: 1.25rem; }

    /* Tabellen in .table-wrap: horizontaal scrollbaar (fallback) */
    .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

    /* Tabellen met class="responsive": stapel elke rij als kaart op mobiel.
       Gebruik data-label op <td> voor het kolomlabel. */
    table.responsive, table.responsive thead, table.responsive tbody,
    table.responsive tr, table.responsive td { display: block; width: 100%; }
    table.responsive thead { display: none; }
    table.responsive tr {
        border: 1px solid var(--border); border-radius: 10px;
        margin-bottom: 0.7rem; padding: 0.4rem 0.7rem; background: var(--card);
    }
    table.responsive td {
        display: flex; justify-content: space-between; align-items: baseline;
        gap: 1rem; text-align: right; border: none;
        border-bottom: 1px solid var(--border); padding: 0.45rem 0;
        white-space: normal; word-break: break-word;
    }
    table.responsive td:last-child { border-bottom: none; }
    table.responsive td::before {
        content: attr(data-label); font-weight: 600; color: var(--muted);
        text-align: left; font-size: 0.78rem; text-transform: uppercase;
        letter-spacing: 0.02em; flex: 0 0 auto;
    }
    table.responsive td:empty { display: none; }
    /* Inputs/selects in responsive tabellen vol-breed */
    table.responsive td input, table.responsive td select { width: 100%; max-width: 60%; }

    /* Compacte (niet-gestapelde) tabellen: kleiner font, sticky 1e kolom, scrollbaar */
    .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; border-radius: 10px; }
    .data-table.compact { font-size: 0.8rem; }
    .data-table.compact th, .data-table.compact td { padding: 0.45rem 0.55rem; white-space: nowrap; }
    /* Titelkolom (2e kolom) afkappen i.p.v. uitrekken */
    .data-table.compact td:nth-child(2), .data-table.compact th:nth-child(2) {
        max-width: 180px; overflow: hidden; text-overflow: ellipsis;
    }
    .data-table.compact th:first-child, .data-table.compact td:first-child {
        position: sticky; left: 0; background: var(--card); z-index: 1;
    }
    .data-table.compact thead th:first-child { background: #fafbfc; }

    /* KPI's en grids naar 1-2 koloms */
    .kpi-grid { grid-template-columns: repeat(2, 1fr); gap: 0.6rem; }
    .kpi-value { font-size: 1.25rem; }

    /* Formulieren stapelen */
    .edit-form, .price-form { grid-template-columns: 1fr; }
    .filters { flex-direction: column; align-items: stretch; }
    .filters input[type="search"] { min-width: 0; width: 100%; }

    .page-head { flex-direction: column; align-items: flex-start; gap: 0.6rem; }
    .btn-row { display: flex; flex-wrap: wrap; gap: 0.5rem; }
}

@media (max-width: 480px) {
    .kpi-grid { grid-template-columns: 1fr; }
    .brand { font-size: 0.95rem; }
    /* Grafieken: breedte vullen, harde hoogtelimiet (voorkomt oneindige groei) */
    .card canvas { max-width: 100% !important; max-height: 320px !important; }
}

/* LVB-zendingen: nette kaart per zending met uitgelijnde artikelregels */
.ship-card { background: var(--card); border: 1px solid var(--border); border-radius: 10px; margin-bottom: 0.5rem; }
.ship-head { display: flex; align-items: center; flex-wrap: wrap; gap: 0.4rem 0.55rem; padding: 0.6rem 0.85rem; cursor: pointer; list-style: none; }
.ship-head::-webkit-details-marker { display: none; }
.ship-chev { transition: transform 0.15s; opacity: 0.5; font-size: 0.75rem; }
details.ship-card[open] .ship-chev { transform: rotate(90deg); }
.ship-meta { margin-left: auto; font-size: 0.85rem; }
.ship-origin { background: rgba(127,127,127,0.12); }
.ship-items { margin-bottom: 0.4rem; }
.ship-items th:first-child, .ship-items td:first-child { padding-left: 0.85rem; }
.ship-items th:last-child, .ship-items td:last-child { padding-right: 0.85rem; }
.ship-items { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.ship-items th, .ship-items td { padding: 0.4rem 0.6rem; border-bottom: 1px solid var(--border); text-align: left; }
.ship-items th.num, .ship-items td.num { text-align: right; font-variant-numeric: tabular-nums; }
.ship-items th { color: var(--muted); font-weight: 600; font-size: 0.78rem; text-transform: uppercase; }
.ship-items .neg { color: var(--danger); font-weight: 600; }
.ship-items .pos { color: var(--green); }

/* Overzicht: sectietitels, KPI-delta, 2-koloms grafieken */
.section-title { font-size: 0.95rem; color: var(--muted); margin: 1.5rem 0 0.6rem; text-transform: uppercase; letter-spacing: 0.03em; }
.kpi-delta { font-size: 0.8rem; font-weight: 600; margin-top: 0.2rem; color: var(--muted); }
.kpi-delta.up { color: var(--green); }
.kpi-delta.down { color: var(--danger); }
.chart-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
@media (max-width: 900px) { .chart-2col { grid-template-columns: 1fr; gap: 1rem; } }

.sim-summary { display: flex; flex-wrap: wrap; gap: 1.2rem; margin-top: 0.8rem; font-size: 0.9rem; color: var(--muted); }
.sim-summary strong { color: var(--text); }

/* Inklapbare kaarten (<details class="card collapsible">) */
details.collapsible > summary {
    list-style: none; cursor: pointer; display: flex; align-items: center;
    justify-content: space-between; gap: 0.5rem;
}
details.collapsible > summary::-webkit-details-marker { display: none; }
details.collapsible > summary h2 { margin: 0; }
details.collapsible > summary::after {
    content: "▾"; color: var(--muted); font-size: 1rem; transition: transform 0.2s;
}
details.collapsible[open] > summary::after { transform: rotate(180deg); }
details.collapsible > summary + * { margin-top: 1rem; }

/* Grafiek-box: vaste, leesbare hoogte; groter op mobiel */
.chart-box { position: relative; width: 100%; height: 300px; }
.chart-box canvas { position: absolute; inset: 0; width: 100% !important; height: 100% !important; }
/* Veiligheidsnet: geen losse grafiek mag ongelimiteerd groeien */
canvas { max-height: 420px; }
@media (max-width: 900px) {
    .chart-box { height: 360px; }  /* groter op mobiel zodat labels leesbaar zijn */
}

/* Voorraad-tabel: highlight rijen die actie vereisen */
.data-table tr.row-buy td { background: #fff7ed; }   /* inkopen — oranje */
.data-table tr.row-ship td { background: #eff6ff; }  /* naar LVB — blauw */
.data-table tr.row-buy td:first-child { box-shadow: inset 3px 0 0 #f59e0b; }
.data-table tr.row-ship td:first-child { box-shadow: inset 3px 0 0 #2563eb; }
.legend-dot { display: inline-block; width: 0.7rem; height: 0.7rem; border-radius: 50%; vertical-align: middle; margin: 0 0.2rem 0 0.6rem; }
.legend-dot.buy { background: #f59e0b; }
.legend-dot.ship { background: #2563eb; }

/* Kleine knop + algemene knoprij (basis, ook buiten media query) */
.btn-row { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.btn-sm { padding: 0.3rem 0.6rem; font-size: 0.8rem; }

/* Invoice-review: formulier links, bronbestand-voorvertoning rechts */
.review-split { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr); gap: 1rem; align-items: start; }
.review-preview { position: sticky; top: 1rem; }
.doc-frame { width: 100%; height: 70vh; border: 1px solid var(--border); border-radius: 8px; background: #fff; }
@media (max-width: 1000px) { .review-split { grid-template-columns: 1fr; } .review-preview { position: static; } .doc-frame { height: 50vh; } }

/* Commandocentrum: actie-tegels bovenaan het Overzicht */
.action-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.8rem;
    margin-bottom: 1.5rem;
}
.action-tile {
    display: block;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 0.95rem 1.1rem;
    text-decoration: none;
    color: var(--text);
    background: var(--card);
    border-left: 4px solid var(--border);
    box-shadow: var(--shadow-sm);
    transition: transform var(--tr), box-shadow var(--tr);
}
.action-tile:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.action-count { font-size: 1.8rem; font-weight: 700; line-height: 1; }
.action-label { font-size: 0.85rem; font-weight: 600; margin-top: 0.35rem; }
.action-unit { font-size: 0.75rem; color: var(--muted); margin-top: 0.15rem; }
/* >0 = urgentie (rood/links gekleurd); 0 = rustige 'alles in orde'-staat */
.action-tile.is-urgent { border-left-color: var(--danger); background: #fef2f2; }
.action-tile.is-urgent .action-count { color: var(--danger); }
.action-tile.is-calm { border-left-color: var(--green); }
.action-tile.is-calm .action-count { color: var(--muted); }

/* Compact aanvul-/inkoopadvies-paneel op /inventory */
.advies-paneel { padding: 0.5rem 0.9rem; }
.advies-paneel > summary { display: flex; align-items: baseline; gap: 0.8rem; flex-wrap: wrap; cursor: pointer; list-style: none; }
.advies-paneel > summary h2 { display: inline; font-size: 1rem; margin: 0; }
.advies-paneel .advies-kpi { color: var(--muted); font-size: 0.8rem; }
.advies-paneel h3 { font-size: 0.85rem; margin: 0.8rem 0 0.3rem; color: var(--muted); font-weight: 600; }
.advies-paneel .data-table { font-size: 0.8rem; }

/* Instellingen-pagina: compacte grid van label + invoerveld */
.settings-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 0.6rem 1rem; }
.settings-grid label { display: flex; flex-direction: column; font-size: 0.8rem; gap: 0.2rem; }
.settings-grid input { padding: 0.3rem 0.4rem; }

/* Actie-iconen (winkelwagen = bestellen/inkoop, vrachtwagen = naar LVB versturen) */
.act-ico { width: 14px; height: 14px; vertical-align: -0.15em; flex: none; }
/* Subtiele chips, NAAST elkaar (niet gestapeld) zodat rijen laag blijven */
.act-chips { display: inline-flex; flex-wrap: nowrap; gap: 0.5rem; align-items: center; }
.act-chip { display: inline-flex; align-items: center; gap: 0.15rem; font-size: 0.75rem; font-weight: 600; white-space: nowrap; }
.act-chip svg { width: 14px; height: 14px; flex: none; }
.act-buy { color: #1d4ed8; }
.act-ship { color: #0e7490; }

/* Front-dekking vs lead-time: relatieve kleur-indicator (geen absolute drempel) */
.cover-pill { display: inline-block; padding: 0.05rem 0.4rem; border-radius: 999px; font-weight: 700; font-size: 0.8rem; }
.cover-pill.cover-danger { background: #fef2f2; color: var(--danger); }
.cover-pill.cover-warn { background: #fff7ed; color: #b45309; }
.cover-pill.cover-ok { background: #ecfdf5; color: var(--green); }
.cover-lead { font-size: 0.68rem; display: block; }

/* Compacte voorraadtabel: sub-regels onder de hoofdwaarde + per-locatie mini-lijst */
.cell-sub { display: block; font-size: 0.7rem; opacity: 0.6; line-height: 1.3; }
.cell-sub-inline { font-size: 0.7rem; opacity: 0.6; }
.twoline { line-height: 1.3; }
.col-product a { font-weight: 600; }
.col-product .cell-sub { font-size: 0.72rem; }
.loc-cell .loc-row { display: flex; justify-content: space-between; gap: 0.75rem; font-size: 0.78rem; line-height: 1.45; }
.loc-cell .loc-name { opacity: 0.6; }
.loc-cell .loc-qty { font-variant-numeric: tabular-nums; }

/* Instelbaar drempel-formulier in de risico-KPI-kaart */
.threshold-form { display: flex; flex-wrap: wrap; gap: 0.4rem; align-items: center; margin-top: 0.4rem; }
.threshold-form label { font-size: 0.75rem; color: var(--muted); display: flex; align-items: center; gap: 0.2rem; }
.threshold-form input { width: 3.2rem; padding: 0.2rem 0.3rem; border: 1px solid var(--border); border-radius: 6px; font-size: 0.8rem; }

/* ---- Tooltip-affordance: toon dat er info is bij hover ------------------- */
[title] { cursor: help; }
a[title], button[title], .btn[title], .badge[title], input[title], label[title],
summary[title], .link-btn[title] { cursor: pointer; }
/* Kolomkoppen met uitleg krijgen automatisch een ⓘ. */
.data-table th[title]::after { content: "\00A0\24D8"; font-size: 0.78em; opacity: 0.55; font-weight: 400; }
/* Inline info-icoontje voor cijfers/teksten met een tooltip. */
.tip-ico { font-size: 0.74em; opacity: 0.5; margin-left: 0.12em; cursor: help; vertical-align: 0.05em; }

/* "→ LVB onderweg"-regel in de per-locatie-cel: leesbaar blauw geaccentueerd. */
.loc-cell .loc-row.intransit .loc-name,
.loc-cell .loc-row.intransit .loc-qty { color: #0e7490; font-weight: 600; }
.loc-cell .loc-row.intransit .cell-sub-inline { opacity: 1; color: #0e7490; font-weight: 500; }

/* Compacte panelen naast elkaar (Overzicht: productie/onderweg/zendingen). */
/* Masonry-achtig via CSS-kolommen: panelen pakken strak onder elkaar zonder dat
   een korte kaart wordt 'opgerekt' tot de hoogte van een hoge buurkaart (=gat). */
.cards-grid { column-width: 430px; column-gap: 1rem; margin-bottom: 1.5rem; }
.cards-grid > .card { break-inside: avoid; -webkit-column-break-inside: avoid; display: inline-block; width: 100%; margin: 0 0 1rem; vertical-align: top; }
.mini-card { padding: 1rem 1.1rem; overflow-x: auto; }
.mini-card > .data-table { min-width: 100%; }
@media (max-width: 520px) { .cards-grid { column-width: auto; column-count: 1; } }
.mini-card h3 { font-size: 0.9rem; margin: 0 0 0.7rem; }
.mini-card .data-table { font-size: 0.78rem; }
.mini-card .data-table th, .mini-card .data-table td { padding: 0.42rem 0.55rem; }

/* Advies + 'Onderweg naar LVB' naast elkaar (2 koloms) i.p.v. één brede kolom. */
.advies-2col { display: grid; grid-template-columns: 1.5fr 1fr; gap: 1rem; align-items: start; }
.advies-2col > * { margin-bottom: 0; }
@media (max-width: 900px) { .advies-2col { grid-template-columns: 1fr; } }

/* ======================================================================
   DARK MODE — toggle rechtsboven, voorkeur opgeslagen (localStorage).
   Het meeste gaat automatisch via de CSS-variabelen; hieronder de
   hardcoded oppervlakken/tinten die nog een donkere variant nodig hebben.
   ====================================================================== */
.theme-toggle {
    background: none; border: 1px solid var(--border); border-radius: 8px;
    cursor: pointer; font-size: 1rem; line-height: 1; padding: 0.35rem 0.5rem;
    color: var(--muted);
}
.theme-toggle:hover { background: var(--bg); }

[data-theme="dark"] {
    /* Brand-dark: warm near-black + lime-accent; 'ink' wordt licht zodat knoppen/
       pills oplichten (lichte vlakken met donkere tekst — referentie-stijl). */
    --bg: #0c0d0a;
    --shell: #141511;
    --bg-soft: #1d1f18;
    --card: #1a1c16;
    --border: #2a2c23;
    --border-strong: #3a3d31;
    --text: #f0efe6;
    --muted: #9b9c8d;
    --primary: #ecebe2;
    --primary-600: #f1f0e7;
    --primary-50: rgba(255,255,255,0.08);
    --btn-fg: #18190f;
    --accent: #d6f23f;
    --accent-ink: #1b1d12;
    --accent-soft: rgba(214,242,63,0.16);
    --accent-grad: linear-gradient(135deg, #d6f23f 0%, #b7e231 100%);
    --link: #84b4ff;
    --danger: #f4787a; --danger-soft: rgba(244,113,116,0.14);
    --green: #6cd081;  --green-soft: rgba(108,208,129,0.14);
    --warn: #e3a851;   --warn-soft: rgba(227,168,81,0.14);
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.5);
    --shadow: 0 8px 26px rgba(0,0,0,0.55);
    --shadow-lg: 0 24px 56px rgba(0,0,0,0.66);
    --ring: 0 0 0 3px rgba(214,242,63,0.26);
    color-scheme: dark;
}
[data-theme="dark"] body {
    background: var(--bg); color: var(--text);
    background-image: radial-gradient(1100px 550px at 82% -12%, rgba(214,242,63,0.05), transparent 60%);
    background-attachment: fixed;
}
[data-theme="dark"] .btn { box-shadow: 0 2px 10px rgba(0,0,0,0.5); }
[data-theme="dark"] .brand { background: var(--card); border-color: var(--border-strong); }
[data-theme="dark"] .data-table th { background: var(--bg-soft); color: var(--muted); }
/* Status-pills: donker getinte achtergrond + lichte tekst (anders onleesbaar). */
[data-theme="dark"] .badge { background: rgba(255,255,255,0.06); }
[data-theme="dark"] .badge.status-besteld,
[data-theme="dark"] .badge-transfer, [data-theme="dark"] .badge-adjustment { color: #a9b0ff; background: rgba(127,129,245,0.16); }
[data-theme="dark"] .badge.status-aangemeldi4y { color: #82b6ff; background: rgba(59,130,246,0.16); }
[data-theme="dark"] .badge.status-verzonden { color: #5fd0e8; background: rgba(14,116,144,0.22); }
[data-theme="dark"] .badge.status-inproductie, [data-theme="dark"] .badge.status-bijnaop,
[data-theme="dark"] .badge.status-binnenkort, [data-theme="dark"] .badge.status-pending,
[data-theme="dark"] .badge.status-nuversturen { color: #f0b968; background: rgba(180,83,9,0.22); }
[data-theme="dark"] .badge.status-concept, [data-theme="dark"] .badge.status-locked,
[data-theme="dark"] .badge.status-uitlopend, [data-theme="dark"] .badge.status-geenverkoop { color: #aab2c2; background: rgba(255,255,255,0.07); }
[data-theme="dark"] .badge-inbound, [data-theme="dark"] .badge-return,
[data-theme="dark"] .badge.status-ontvangen, [data-theme="dark"] .badge.status-ok,
[data-theme="dark"] .badge.status-approved, [data-theme="dark"] .badge.status-open,
[data-theme="dark"] .badge.status-opkoers { color: #74dd88; background: rgba(95,206,116,0.15); }
[data-theme="dark"] .badge-outbound, [data-theme="dark"] .badge-sale,
[data-theme="dark"] .badge.status-cancelled, [data-theme="dark"] .badge.status-geannuleerd,
[data-theme="dark"] .badge.status-rejected, [data-theme="dark"] .badge.status-uitverkocht,
[data-theme="dark"] .badge.status-bestellen, [data-theme="dark"] .badge.status-achterlandleeg { color: #ff9ea0; background: rgba(244,113,116,0.15); }
[data-theme="dark"] .data-table tr.low-stock td { background: rgba(244,113,116,0.10); }
[data-theme="dark"] .data-table tr.row-buy td { background: rgba(245,158,11,0.12); }
[data-theme="dark"] .data-table tr.row-ship td { background: rgba(83,155,245,0.12); }
[data-theme="dark"] .muted-row td { background: #11161d; color: var(--muted); }
[data-theme="dark"] input, [data-theme="dark"] select, [data-theme="dark"] textarea {
    background: #0d1117; color: var(--text); border-color: var(--border);
}
[data-theme="dark"] .nav-menu { box-shadow: 0 8px 24px rgba(0,0,0,0.5); }
[data-theme="dark"] .nav > a.active, [data-theme="dark"] .nav > a:hover,
[data-theme="dark"] .nav-trigger.active, [data-theme="dark"] .nav-trigger:hover,
[data-theme="dark"] .nav-menu a:hover, [data-theme="dark"] .nav-menu a.active,
[data-theme="dark"] .kpi-toggle:hover, [data-theme="dark"] .theme-toggle:hover { background: #222b35; }
[data-theme="dark"] .action-tile.is-urgent { background: rgba(244,113,116,0.10); }
[data-theme="dark"] .action-tile.is-urgent .action-count,
[data-theme="dark"] .cover-pill.cover-danger { color: #ff9ea0; }
[data-theme="dark"] .loc-cell .loc-row.intransit .loc-name,
[data-theme="dark"] .loc-cell .loc-row.intransit .loc-qty,
[data-theme="dark"] .loc-cell .loc-row.intransit .cell-sub-inline { color: #5ec5e8; }
/* Actie-chips/iconen lichter zodat ze leesbaar zijn op donker. */
[data-theme="dark"] .act-buy { color: #6ea8ff; }
[data-theme="dark"] .act-ship { color: #4fc3e8; }
[data-theme="dark"] .link-btn, [data-theme="dark"] .data-table a,
[data-theme="dark"] .nav-menu a { color: #6ea8ff; }
[data-theme="dark"] .data-table a.btn { color: var(--btn-fg); }
[data-theme="dark"] .cover-pill.cover-danger { background: rgba(244,113,116,0.16); }
[data-theme="dark"] .cover-pill.cover-warn { background: rgba(180,83,9,0.22); color: #f3b95f; }
[data-theme="dark"] .cover-pill.cover-ok { background: rgba(87,196,106,0.16); color: #7fd98c; }

/* ======================================================================
   MOBILE POLISH (globaal) — raakt elke pagina, tabel en grafiek.
   ====================================================================== */

/* Nooit horizontaal scrollen van de hele pagina; media blijft binnen kader.
   'clip' i.p.v. 'hidden' zodat position:sticky blijft werken. */
html, body { overflow-x: clip; }
img, svg, video, canvas, table, pre { max-width: 100%; }

/* Topbar zit in de app-shell; niet sticky (clip-container). */
.topbar { position: static; }

/* Brede tabellen krijgen een subtiele rand zodat 'scrollbaar' duidelijk is. */
.table-wrap { border: 1px solid var(--border); border-radius: 10px; }
.table-wrap > .data-table { border: none; border-radius: 0; }

/* Utility: verberg laag-prioriteit kolcommen/elementen op smalle schermen. */
@media (max-width: 640px) {
    .hide-sm { display: none !important; }
}

@media (max-width: 900px) {
    /* iOS zoomt in bij focus op invoer < 16px → forceer 16px op mobiel. */
    input:not([type="checkbox"]):not([type="radio"]):not([type="range"]),
    select, textarea { font-size: 16px !important; }

    /* Compacte maar nog goed-tikbare targets in de navigatie. */
    .nav > a, .nav-trigger { min-height: 34px; display: flex; align-items: center; }
    .nav-menu a { min-height: 30px; display: flex; align-items: center; }
    .btn, .link-btn, .kpi-toggle { min-height: 36px; }

    /* Lang menu blijft scrollbaar binnen het scherm. */
    .nav { max-height: 78vh; overflow-y: auto; }

    /* Kaarten en grids iets compacter zodat er meer past zonder rommel. */
    .card { padding: 1rem; }
    .container { padding: 0.85rem; }

    /* Sub-regels in compacte tabellen niet afkappen maar tonen (overzicht). */
    .data-table.compact .cell-sub { white-space: nowrap; }
}

@media (max-width: 480px) {
    h1 { font-size: 1.15rem; }
    h2 { font-size: 1rem; }
    .kpi-value { font-size: 1.2rem; }
    .action-count { font-size: 1.5rem; }
    /* Actie-tegels en attributen 1-koloms voor maximale leesbaarheid. */
    .action-grid { grid-template-columns: 1fr 1fr; }
}
