:root {
    --bg: #0f1216;
    --panel: #1a1f26;
    --panel-2: #222932;
    --border: #2c3540;
    --text: #e8edf2;
    --muted: #93a1b0;
    --brand: #c62828;
    --brand-dark: #8e1c1c;
    --green: #2e9e5b;
    --green-dark: #1f7a44;
    --amber: #d99a14;
    --blue: #2f7fd1;
    --radius: 14px;
    --shadow: 0 4px 18px rgba(0,0,0,.35);
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--bg);
    color: var(--text);
    font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}

a { color: inherit; text-decoration: none; }

/* ---------- Topbar ---------- */
.topbar {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 10px 22px;
    background: linear-gradient(180deg, #181d24, #12161b);
    border-bottom: 3px solid var(--brand);
    position: sticky;
    top: 0;
    z-index: 50;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand .logo { font-size: 30px; }
.brand-name { font-weight: 800; font-size: 20px; letter-spacing: .5px; }
.brand-sub { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; }

.mainnav { display: flex; gap: 6px; margin-left: 10px; }
.mainnav a {
    padding: 10px 18px;
    border-radius: 10px;
    color: var(--muted);
    font-weight: 600;
    transition: .15s;
}
.mainnav a:hover { background: var(--panel-2); color: var(--text); }
.mainnav a.active { background: var(--brand); color: #fff; }

.clock { margin-left: auto; color: var(--muted); font-variant-numeric: tabular-nums; font-size: 15px; }

/* ---------- Content ---------- */
.content { padding: 22px; max-width: 1500px; margin: 0 auto; }

.page-head { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.page-head h1 { font-size: 26px; margin: 0; font-weight: 800; }
.page-head .sub { color: var(--muted); }
.page-head .spacer { flex: 1; }

/* ---------- KPI cards ---------- */
.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; margin-bottom: 22px; }
.kpi {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px 18px;
    box-shadow: var(--shadow);
}
.kpi .label { color: var(--muted); font-size: 13px; text-transform: uppercase; letter-spacing: .5px; }
.kpi .value { font-size: 30px; font-weight: 800; margin-top: 6px; font-variant-numeric: tabular-nums; }
.kpi .value small { font-size: 15px; color: var(--muted); font-weight: 600; }
.kpi.green .value { color: #5fd18a; }
.kpi.amber .value { color: #f0c050; }

/* ---------- Panels & day groups ---------- */
.day-block {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 20px;
    overflow: hidden;
    box-shadow: var(--shadow);
}
.day-head {
    display: flex; align-items: center; gap: 16px;
    padding: 14px 18px;
    background: var(--panel-2);
    border-bottom: 1px solid var(--border);
}
.day-head .date { font-size: 19px; font-weight: 800; }
.day-head .meta { color: var(--muted); font-size: 14px; }
.day-head .spacer { flex: 1; }

/* ---------- Simulér ordrer ---------- */
.sim-form { display: flex; gap: 8px; align-items: center; }
.sim-form input[type=number] {
    width: 80px; background: #0c0f13; border: 1px solid var(--border); border-radius: 9px;
    color: var(--text); padding: 10px 12px; font-size: 15px; text-align: center;
}
.sim-form input[type=number]:focus { outline: none; border-color: var(--brand); }

/* ---------- Dagsproduktion / udbytte ---------- */
.yield-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px; font-size: 14px; }
.yield-grid > div { display: flex; justify-content: space-between; border-bottom: 1px solid var(--border); padding: 5px 0; }
.yield-grid span { color: var(--muted); }
.yield-grid b.neg { color: #e06666; }
.lot-layout { display: grid; grid-template-columns: 420px 1fr; gap: 16px; align-items: start; }
@@media (max-width: 900px) { .lot-layout { grid-template-columns: 1fr; } }

/* ---------- Dato-filter chips ---------- */
.dayfilter { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.dayfilter .chip {
    padding: 9px 16px; border-radius: 999px; border: 1px solid var(--border);
    background: var(--panel); color: var(--muted); font-weight: 600; font-size: 14px;
    transition: .12s; cursor: pointer;
}
.dayfilter .chip:hover { background: var(--panel-2); color: var(--text); }
.dayfilter .chip.active { background: var(--brand); border-color: var(--brand-dark); color: #fff; }

/* ---------- Tables ---------- */
table { width: 100%; border-collapse: collapse; }
th, td { padding: 12px 16px; text-align: left; }
th { color: var(--muted); font-size: 13px; text-transform: uppercase; letter-spacing: .4px; font-weight: 600; }
tbody tr { border-top: 1px solid var(--border); }
tbody tr:hover { background: rgba(255,255,255,.02); }
.num { text-align: right; font-variant-numeric: tabular-nums; }
.itemno { color: var(--muted); font-family: "Consolas", monospace; font-size: 14px; }
.big-kg { font-weight: 800; font-size: 17px; }

.bar { height: 7px; border-radius: 4px; background: var(--border); overflow: hidden; margin-top: 6px; max-width: 200px; }
.bar > span { display: block; height: 100%; background: var(--green); }

/* ---------- Badges ---------- */
.badge {
    display: inline-block; padding: 4px 11px; border-radius: 999px;
    font-size: 12.5px; font-weight: 700; letter-spacing: .3px;
}
.badge.modtaget { background: #3a2f12; color: #f0c050; }
.badge.frigivet { background: #143524; color: #5fd18a; }
.badge.klar     { background: #1d2b3a; color: #74b4ee; }
.badge.igang    { background: #143524; color: #5fd18a; }
.badge.paused   { background: #3a2f12; color: #f0c050; }
.badge.faerdig  { background: #2a2f36; color: #9fb0c0; }
.badge.nav      { background: #25303d; color: #8fb8e0; }
.badge.webshop  { background: #2e2536; color: #c79de0; }

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex; align-items: center; gap: 8px; justify-content: center;
    padding: 11px 18px; border-radius: 11px; border: 1px solid var(--border);
    background: var(--panel-2); color: var(--text); font-weight: 700; font-size: 15px;
    cursor: pointer; transition: .12s; user-select: none;
}
.btn:hover { filter: brightness(1.12); }
.btn:active { transform: translateY(1px); }
.btn.primary { background: var(--brand); border-color: var(--brand-dark); color: #fff; }
.btn.green { background: var(--green); border-color: var(--green-dark); color: #fff; }
.btn.amber { background: var(--amber); border-color: #b07e0c; color: #1a1206; }
.btn.ghost { background: transparent; }
.btn.lg { padding: 16px 26px; font-size: 18px; }
.btn:disabled { opacity: .4; cursor: not-allowed; }
.btn-row { display: flex; gap: 10px; flex-wrap: wrap; }

/* ---------- Production liste ---------- */
.prod-table td { vertical-align: middle; }
.prod-table .prod-row { border-left: 4px solid transparent; }
.prod-table .prod-row.klar    { border-left-color: var(--blue); }
.prod-table .prod-row.igang   { border-left-color: var(--green); }
.prod-table .prod-row.paused  { border-left-color: var(--amber); }
.prod-table .prod-row.faerdig { border-left-color: var(--border); opacity: .6; }
.prod-table .bar { margin: 0; }
.prod-table .btn { padding: 9px 12px; font-size: 14px; }

/* ---------- Production board ---------- */
.board { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 16px; }
.job-card {
    background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius);
    padding: 16px; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 12px;
}
.job-card.igang { border-color: var(--green); }
.job-card.paused { border-color: var(--amber); }
.job-card.faerdig { opacity: .65; }
.job-card h3 { margin: 0; font-size: 18px; }
.job-card .meta { color: var(--muted); font-size: 13.5px; display: flex; gap: 10px; flex-wrap: wrap; }
.progress-row { display: flex; justify-content: space-between; font-size: 14px; color: var(--muted); }
.progress-row b { color: var(--text); }

/* ---------- Weigh modal ---------- */
.modal-backdrop {
    position: fixed; inset: 0; background: rgba(0,0,0,.6);
    display: none; align-items: center; justify-content: center; z-index: 100; padding: 20px;
}
.modal-backdrop.open { display: flex; }
.modal {
    background: var(--panel); border: 1px solid var(--border); border-radius: 18px;
    width: min(920px, 100%); max-height: 92vh; overflow: auto; box-shadow: var(--shadow);
}
.modal-head { display: flex; align-items: center; padding: 16px 20px; border-bottom: 1px solid var(--border); }
.modal-head h2 { margin: 0; font-size: 20px; }
.modal-head .x { margin-left: auto; cursor: pointer; font-size: 26px; color: var(--muted); line-height: 1; }
.modal-body { padding: 20px; display: grid; grid-template-columns: 1fr 360px; gap: 22px; }
@@media (max-width: 760px) { .modal-body { grid-template-columns: 1fr; } }

.scale {
    background: #0c0f13; border: 1px solid var(--border); border-radius: 14px; padding: 22px; text-align: center;
}
.scale .read {
    font-size: 64px; font-weight: 800; font-variant-numeric: tabular-nums; color: #5fd18a;
    letter-spacing: 2px;
}
.scale .read small { font-size: 26px; color: var(--muted); }
.scale .hint { color: var(--muted); margin-top: 6px; font-size: 14px; }
.scale-stable { color: #5fd18a; } .scale-unstable { color: var(--amber); }

/* ---------- Label preview ---------- */
.label {
    background: #fff; color: #111; border-radius: 8px; padding: 14px; font-family: "Segoe UI", sans-serif;
    box-shadow: var(--shadow);
}
.label .l-top { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 2px solid #111; padding-bottom: 6px; }
.label .l-brand { font-weight: 800; font-size: 18px; }
.label .l-prod { font-size: 22px; font-weight: 800; margin: 8px 0 2px; }
.label .l-itemno { color: #555; font-family: monospace; }
.label .l-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 12px; margin: 10px 0; font-size: 14px; }
.label .l-grid b { font-size: 16px; }
.label .l-weight { font-size: 30px; font-weight: 800; }
.label .barcode { margin-top: 8px; }
.label .barcode .bars { height: 56px; background:
    repeating-linear-gradient(90deg,#111 0 2px,#fff 2px 4px,#111 4px 7px,#fff 7px 9px,#111 9px 11px,#fff 11px 16px); }
.label .barcode .digits { text-align: center; font-family: monospace; letter-spacing: 3px; margin-top: 3px; font-size: 14px; }

.pkg-list { margin-top: 14px; max-height: 230px; overflow: auto; }
.pkg-list table { font-size: 14px; }

.empty { color: var(--muted); text-align: center; padding: 40px; }

.toast {
    position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%) translateY(120px);
    background: var(--green); color: #fff; padding: 14px 22px; border-radius: 12px; font-weight: 700;
    box-shadow: var(--shadow); transition: transform .25s; z-index: 200;
}
.toast.show { transform: translateX(-50%) translateY(0); }

.flash { animation: flash .5s; }
@@keyframes flash { from { background: rgba(95,209,138,.25); } to { background: transparent; } }

/* ---------- Overblik: udfold + minimum ---------- */
.overview-table .ov-row.expanded { background: rgba(255,255,255,.03); }
.overview-table .expander { text-align: center; color: var(--muted); }
.overview-table .caret { display: inline-block; transition: transform .12s; font-size: 13px; }
.bar > span.partial { background: var(--amber); }
.freebar { margin-top: 5px; height: 6px; }
.freebar > span { transition: width .2s; }
.bar-cap { font-size: 12px; color: var(--muted); margin-top: 3px; font-variant-numeric: tabular-nums; }
.badge.min { background: #2e2536; color: #c79de0; margin-left: 6px; }

.ov-detail .detail-cell { background: #0c0f13; padding: 0 16px 14px 16px; }
.detail-loading { color: var(--muted); padding: 14px 0; }
.detail-table { margin: 6px 0; }
.detail-table th { font-size: 12px; padding: 8px 12px; }
.detail-table td { padding: 8px 12px; font-size: 14px; border-top: 1px solid var(--border); }

/* ---------- Vare-editor form ---------- */
.field { margin-bottom: 14px; display: flex; flex-direction: column; gap: 5px; flex: 1; }
.field label { font-size: 13px; color: var(--muted); font-weight: 600; }
.field input, .field select, .vm-row input {
    background: #0c0f13; border: 1px solid var(--border); border-radius: 9px;
    color: var(--text); padding: 10px 12px; font-size: 15px; width: 100%;
}
.field input:focus, .field select:focus, .vm-row input:focus { outline: none; border-color: var(--brand); }
.field input[readonly] { opacity: .6; }
.field .hint { color: var(--muted); font-size: 12px; }
.field-row { display: flex; gap: 12px; }
.prod-form h3.sec {
    font-size: 14px; text-transform: uppercase; letter-spacing: .5px; color: var(--muted);
    margin: 20px 0 12px; border-bottom: 1px solid var(--border); padding-bottom: 6px;
}
.vm-row { align-items: center; margin-bottom: 8px; }
.vm-row .btn { padding: 9px 12px; }

.modal-foot { display: flex; gap: 10px; padding: 16px 20px; border-top: 1px solid var(--border); align-items: center; }

/* Lovpligtig deklaration */
.decl { background: #0c0f13; border: 1px solid var(--border); border-radius: 12px; padding: 8px 14px; }
.decl-row { display: flex; align-items: center; justify-content: space-between; padding: 9px 0; border-bottom: 1px solid var(--border); }
.decl-row:last-child { border-bottom: none; }
.decl-row.head { font-weight: 700; }
.decl-row.sub { padding-left: 14px; color: var(--muted); }
.decl-row > span:first-child { font-size: 14.5px; }
.decl-one { display: flex; align-items: center; gap: 6px; }
.decl-one input { width: 90px; text-align: right; background: #14181e; border: 1px solid var(--border); border-radius: 8px; color: var(--text); padding: 8px 10px; font-size: 15px; }
.decl-dual { display: flex; align-items: center; gap: 6px; }
.decl-dual input { width: 72px; text-align: right; background: #14181e; border: 1px solid var(--border); border-radius: 8px; color: var(--text); padding: 8px 10px; font-size: 15px; }
.decl em { color: var(--muted); font-style: normal; font-size: 13px; min-width: 30px; }
