/* ============================================================
   ScaleHub productmockups — strakke teal-wireframe UI
   Gedeeld door beide richtingen. Markup wordt door mockups.js
   in elk [data-mockup] element gezet.
   ============================================================ */

.mk{
  --mk-line:#e1ebec; --mk-ink:#0c1c1f; --mk-muted:#71807f; --mk-soft:#f4f8f8;
  background:#fff; border:1px solid var(--mk-line); border-radius:16px;
  box-shadow:0 1px 2px rgba(6,38,45,.05); overflow:hidden;
  font-family:'Hanken Grotesk',sans-serif; color:var(--mk-ink); line-height:1.4;
  width:100%;
}
.mk *{ box-sizing:border-box; }
.mk-bar{ display:flex; align-items:center; gap:8px; padding:12px 16px; border-bottom:1px solid var(--mk-line); background:#fcfefe; }
.mk-dot{ width:9px;height:9px;border-radius:50%; background:#dde7e7; }
.mk-bar .mk-title{ font-size:13px; font-weight:700; letter-spacing:-.01em; margin-left:4px; }
.mk-bar .mk-tag{ margin-left:auto; font-size:11px; font-weight:700; color:var(--brand-deep); background:var(--teal-050); padding:3px 9px; border-radius:999px; border:1px solid var(--teal-100); }
.mk-body{ padding:16px; }
.mono{ font-family:'Hanken Grotesk',sans-serif; font-variant-numeric:tabular-nums; }

/* generieke rij */
.mk-row{ display:flex; align-items:center; justify-content:space-between; padding:9px 0; border-bottom:1px solid var(--mk-soft); font-size:14px; }
.mk-row:last-child{ border-bottom:0; }
.mk-row .k{ color:var(--mk-muted); }
.mk-row .v{ font-weight:600; font-variant-numeric:tabular-nums; }
.mk-chip{ font-size:11px; font-weight:700; padding:3px 9px; border-radius:6px; }
.chip-a{ background:#e7f6ee; color:#0a7d4f; }
.chip-tl{ background:var(--teal-050); color:var(--brand-deep); }
.chip-w{ background:#fdf3e3; color:#a76a13; }
.mk-check{ width:18px;height:18px;border-radius:50%; background:#e7f6ee; color:#0a7d4f; display:grid;place-items:center; font-size:11px; flex:none; }

/* partijkaart */
.mk-partij .head{ display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:6px; }
.mk-partij .pid{ font-size:18px; font-weight:800; letter-spacing:-.02em; }
.mk-partij .sub{ font-size:12px; color:var(--mk-muted); }

/* etiket */
.mk-etiket .label{ border:1.5px solid var(--mk-ink); border-radius:10px; padding:14px; }
.mk-etiket .pn{ font-size:16px; font-weight:800; letter-spacing:-.02em; }
.mk-etiket .barcode{ height:38px; margin-top:12px; background:repeating-linear-gradient(90deg,var(--mk-ink) 0 2px, #fff 2px 5px, var(--mk-ink) 5px 6px, #fff 6px 9px); border-radius:3px; }
.mk-etiket .lr{ display:flex; justify-content:space-between; font-size:12px; margin-top:10px; }
.mk-etiket .lr b{ font-size:13px; }
.fao{ display:inline-flex; align-items:center; gap:6px; background:var(--teal-050); color:var(--brand-deep); font-weight:700; font-size:12px; padding:4px 10px; border-radius:999px; border:1px solid var(--teal-100); }

/* marge per kilo */
.mk-marge .bigm{ display:flex; align-items:baseline; gap:8px; margin-top:4px; padding-top:12px; border-top:1px dashed var(--mk-line); }
.mk-marge .bigm .lab{ font-size:13px; color:var(--mk-muted); }
.mk-marge .bigm .val{ font-size:30px; font-weight:800; color:#0a7d4f; letter-spacing:-.03em; font-variant-numeric:tabular-nums; margin-left:auto; }
.mk-marge .live{ display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:700; color:var(--brand-deep); }
.mk-marge .live .pulse{ width:7px;height:7px;border-radius:50%;background:var(--brand); animation:mkpulse 1.8s infinite; }
@keyframes mkpulse{ 0%,100%{box-shadow:0 0 0 0 rgba(0,142,180,.4)} 50%{box-shadow:0 0 0 5px rgba(0,142,180,0)} }

/* tabel (inname) */
.mk-table table{ width:100%; border-collapse:collapse; font-size:13px; }
.mk-table th{ text-align:left; font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--mk-muted); font-weight:700; padding:0 0 8px; border-bottom:1px solid var(--mk-line); }
.mk-table td{ padding:9px 0; border-bottom:1px solid var(--mk-soft); font-weight:600; font-variant-numeric:tabular-nums; }
.mk-table tr:last-child td{ border-bottom:0; }
.mk-table .hot td{ background:linear-gradient(90deg,var(--teal-050),transparent); }
.mk-table .weigh{ display:inline-flex; align-items:center; gap:6px; font-size:11px; color:var(--brand-deep); font-weight:700; }

/* kanban */
.mk-kanban .cols{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; }
.mk-col h5{ font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--mk-muted); margin:0 0 8px; font-weight:700; display:flex; justify-content:space-between; }
.kcard{ background:var(--mk-soft); border:1px solid var(--mk-line); border-radius:9px; padding:9px; margin-bottom:8px; }
.kcard .t{ font-size:12.5px; font-weight:700; }
.kcard .m{ font-size:11px; color:var(--mk-muted); margin-top:3px; display:flex; justify-content:space-between; }
.kcard .ren{ color:#0a7d4f; font-weight:700; }
.kcard.act{ border-color:var(--brand); box-shadow:0 0 0 2px rgba(0,142,180,.14); background:#fff; }

/* dashboard */
.mk-dash .tiles{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-bottom:14px; }
.dtile{ background:var(--mk-soft); border-radius:10px; padding:11px 12px; }
.dtile .l{ font-size:10.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--mk-muted); font-weight:700; }
.dtile .n{ font-size:21px; font-weight:800; letter-spacing:-.02em; margin-top:3px; font-variant-numeric:tabular-nums; }
.dtile .n small{ font-size:12px; color:#0a7d4f; font-weight:700; }
.mk-dash .bars{ display:flex; align-items:flex-end; gap:8px; height:78px; padding:0 2px; }
.mk-dash .bars .b{ flex:1; background:linear-gradient(var(--brand-bright),var(--brand)); border-radius:5px 5px 0 0; position:relative; }
.mk-dash .bars .b.lo{ background:var(--teal-200); }
.mk-dash .bars .b::after{ content:attr(data-l); position:absolute; bottom:-18px; left:0; right:0; text-align:center; font-size:9.5px; color:var(--mk-muted); }
.mk-dash .legend{ margin-top:26px; font-size:11.5px; color:var(--mk-muted); display:flex; gap:14px; }
.mk-dash .alert{ margin-top:12px; display:flex; align-items:center; gap:9px; padding:9px 11px; background:#fdf3e3; border-radius:8px; font-size:12px; color:#8a5a10; font-weight:600; }

/* companion (mobiel) */
.mk-phone{ width:230px; margin:0 auto; background:#0c1c1f; border-radius:30px; padding:9px; box-shadow:var(--shadow-lg); }
.mk-phone .scr{ background:#fff; border-radius:23px; overflow:hidden; }
.mk-phone .pbar{ background:var(--ink-teal); color:#fff; padding:14px 16px 12px; }
.mk-phone .pbar .pt{ font-size:11px; opacity:.7; }
.mk-phone .pbar .ph{ font-size:16px; font-weight:800; margin-top:2px; }
.mk-phone .pbody{ padding:13px; }
.mk-act{ display:flex; align-items:center; gap:10px; padding:11px; border:1px solid var(--mk-line); border-radius:11px; margin-bottom:8px; font-size:13px; font-weight:700; }
.mk-act .ai{ width:32px;height:32px;border-radius:8px; background:var(--teal-050); display:grid;place-items:center; flex:none; }
.mk-act.prim{ background:var(--brand); color:#fff; border-color:var(--brand); }
.mk-act.prim .ai{ background:rgba(255,255,255,.18); }
.mk-toast{ margin-top:4px; padding:10px 11px; background:#e7f6ee; border-radius:10px; font-size:11.5px; color:#0a7d4f; font-weight:700; display:flex; gap:7px; align-items:center; }

.mk svg{ display:block; }
.ic{ width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:1.8; }
