:root{
  /* Lightr-huisstijl: koel grijs + teal accent (var-namen behouden) */
  --paper:#F4F5F7; --panel:#FFFFFF; --ink:#18212F; --muted:#5A6472; --faint:#97A0AD;
  --line:#E7EAEE; --line2:#D7DCE3;
  --indigo:#10C9A9; --indigo-soft:#E2F8F3; --indigo-line:#9FE7D9;   /* teal */
  --yellow:#B8F2E6;
  --green:#0E9F76; --green-soft:#E1F5EE;
  --amber:#9A6A05; --amber-soft:#F6ECD6;
  --grey:#5A6472; --grey-soft:#EDEFF2;
  --radius:10px;
  --mono:ui-monospace,"SF Mono","JetBrains Mono",Menlo,monospace;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--indigo);text-decoration:none}
button,input,select,textarea{font-family:inherit}
::selection{background:var(--yellow)}

.bar{display:flex;align-items:center;justify-content:space-between;padding:14px 26px;border-bottom:1px solid var(--line);background:var(--paper);position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:11px}
.brand .mk{font-weight:800;letter-spacing:-.02em;font-size:17px;color:var(--ink)}
.brand .mk .x{color:var(--indigo);font-weight:800;margin-left:3px}
.brand .tag{font-family:var(--mono);font-size:11px;color:var(--faint);border:1px solid var(--line2);border-radius:5px;padding:2px 7px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{color:var(--muted);font-weight:600;font-size:13px;padding:7px 13px;border-radius:7px}
.nav a.on,.nav a:hover{background:var(--ink);color:#fff}
.nav .who{color:var(--faint);font-family:var(--mono);font-size:11.5px;margin-right:6px}

.wrap{max-width:1240px;margin:0 auto;padding:26px}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
h2.view-h{font-size:24px;letter-spacing:-.02em;margin:6px 0 2px;font-weight:800}
.view-sub{color:var(--muted);margin-bottom:22px}

.flash{margin:0 0 16px;padding:11px 14px;border-radius:9px;font-weight:600;font-size:13px}
.flash.ok{background:var(--green-soft);color:var(--green)}
.flash.error{background:#FBE9E7;color:#9B2C1F}
.flash.warn{background:#FDF4E3;color:#8A5A00}

.split{display:grid;grid-template-columns:430px 1fr;gap:24px;align-items:start}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius)}
.panel + .panel{margin-top:16px}
.panel h3{font-size:12px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:0;padding:14px 16px;border-bottom:1px solid var(--line)}
.pbody{padding:14px 16px}

.field{margin-bottom:14px}
.field:last-child{margin-bottom:0}
.field>label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px}
.inp,select.inp,textarea.inp{width:100%;border:1px solid var(--line2);border-radius:8px;padding:9px 11px;font-size:13px;background:#fff;color:var(--ink)}
.inp:focus{outline:2px solid var(--indigo);outline-offset:1px;border-color:transparent}
.curfiles{margin-top:12px;padding:10px 12px;background:var(--grey-soft);border-radius:8px;font-size:12.5px;line-height:1.7}
input[type=file]{font-size:12.5px;color:var(--muted);max-width:100%}
input[type=file]::file-selector-button{border:1px solid var(--line2);border-radius:8px;padding:8px 14px;background:#fff;color:var(--ink);font-weight:600;font-size:12.5px;cursor:pointer;margin-right:10px;transition:border-color .1s}
input[type=file]::file-selector-button:hover{border-color:var(--indigo)}
.chk{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}
.chk input{width:16px;height:16px}
.priced td.amt{font-family:var(--mono);text-align:right;font-weight:600}
tr.total td{border-top:2px solid var(--line2);font-weight:700}
/* variabelen herkend */
.varmap{display:flex;flex-direction:column}
.varrow{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line)}
.varrow:last-child{border-bottom:0}
.varrow .arr{color:var(--faint)}
.varrow .col{flex:1;font-weight:600}
.varrow .col.mono{font-family:var(--mono);font-size:12.5px}
.varrow .col.miss{color:var(--faint);font-style:italic;font-weight:500}
.varrow .tick{font-weight:700}
.varrow .tick.ok{color:var(--green)}
.varrow .tick.no{color:var(--faint)}
/* kaart-pager */
.pager{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line)}
.pgbtn{width:34px;height:34px;border:1px solid var(--line2);border-radius:8px;background:#fff;color:var(--ink);font-size:16px;cursor:pointer}
.pgbtn:hover{background:var(--grey-soft)}
.pglabel{font-size:13px;white-space:nowrap}
.pager input[type=range]{flex:1;accent-color:var(--indigo)}
/* waarden van de kaart */
.cardvals{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;overflow-x:auto}
.cardvals .vcell{padding:14px 16px;border-right:1px solid var(--line);min-width:120px}
.cardvals .vcell:last-child{border-right:0}
.cardvals .vh{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--faint);margin-bottom:6px}
.cardvals .vv{font-weight:700;font-size:14px}
.cardvals .vv.empty{color:#8A5A00;font-weight:600}
/* envelop-adres onder de kaart */
.cardaddr{border-top:1px solid var(--line);padding:14px 16px;background:#FbFaF7}
.cardaddr .addr-h{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--faint);margin-bottom:8px}
.cardaddr .addr-body div{font-weight:600;font-size:13.5px;line-height:1.5}
/* herkende adreskolommen in de check */
.addr-map{border-top:1px solid var(--line);margin-top:6px}
.addr-map .varrow .col.miss{color:#9B2C1F}
/* order-actiebalk + vergrendel-indicator */
.orderbar{display:flex;align-items:center;gap:12px;margin:0 0 16px;flex-wrap:wrap}
.statusnote{font-size:12.5px;font-weight:600;padding:6px 11px;border-radius:8px}
.statusnote.open{background:var(--green-soft);color:var(--green)}
.statusnote.locked{background:var(--grey-soft);color:var(--grey)}
/* brede preview bovenaan */
.preview-top{margin-bottom:18px}
.preview-top .cardshell{max-width:880px}
/* overzichtsblokjes naast elkaar */
.blocks{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:start}
.blocks .panel{margin:0}
@media(max-width:1100px){.blocks{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.blocks{grid-template-columns:1fr}}
/* laad-overlay tijdens genereren */
.overlay{position:fixed;inset:0;z-index:50;display:none;align-items:center;justify-content:center;
  background:rgba(28,26,23,.55);backdrop-filter:blur(2px)}
.overlay.on{display:flex}
.overlay .card{background:#fff;border-radius:14px;padding:28px 30px;width:min(420px,92vw);
  box-shadow:0 18px 60px rgba(0,0,0,.3);text-align:center}
.overlay .spinner{width:44px;height:44px;margin:0 auto 16px;border-radius:50%;
  border:4px solid var(--line2);border-top-color:var(--indigo);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.overlay .ol-step{font-weight:700;font-size:15px;color:var(--ink);min-height:20px}
.overlay .ol-sub{margin-top:8px;color:var(--faint);font-size:12.5px}
.overlay .ol-steps{margin-top:16px;text-align:left;display:inline-block}
.overlay .ol-li{font-size:12.5px;color:var(--faint);padding:3px 0;display:flex;align-items:center;gap:8px}
.overlay .ol-li.done{color:var(--green)}
.overlay .ol-li.active{color:var(--ink);font-weight:600}
.overlay .ol-dot{width:14px;text-align:center}
/* variabelen-check op het orderformulier */
.check-banner{font-weight:700;font-size:13px;padding:9px 11px;border-radius:8px;margin-bottom:8px}
.check-banner.ok{background:var(--green-soft);color:var(--green)}
.check-banner.err{background:#FBE9E6;color:#9B2C1F}
.check-banner.warn{background:#FDF4E3;color:#8A5A00}
.check-problems{margin:0 0 8px;padding-left:18px;color:#9B2C1F;font-size:12.5px}
.check-problems.warn{color:#8A5A00}
.check-problems li{margin:3px 0}
.btn:disabled{opacity:.5;cursor:not-allowed}
.tworow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.seg{display:flex;border:1px solid var(--line2);border-radius:8px;overflow:hidden}
.seg label{flex:1}
.seg input{position:absolute;opacity:0;pointer-events:none}
.seg span{display:block;text-align:center;background:#fff;color:var(--muted);font-weight:600;font-size:12.5px;padding:9px 6px;border-right:1px solid var(--line2);cursor:pointer}
.seg label:last-child span{border-right:0}
.seg input:checked + span{background:var(--ink);color:#fff}

.drop{border:1.5px dashed var(--line2);border-radius:9px;padding:16px;text-align:center;background:#fff}
.drop input{display:block;margin:8px auto 0;font-size:12px}
.drop .t{font-weight:600}
.drop .h{color:var(--faint);font-size:12px;margin-top:2px}

.lead{display:flex;align-items:center;gap:12px;background:var(--indigo-soft);border:1px solid var(--indigo-line);border-radius:9px;padding:12px 14px;margin-top:14px}
.lead .big{font-size:20px;font-weight:800;color:var(--indigo);font-family:var(--mono)}
.lead .lbl{font-size:12.5px;color:var(--muted);line-height:1.3}
.lead .lbl b{color:var(--ink)}

.btn{border:0;border-radius:9px;padding:11px 16px;font-weight:700;font-size:13.5px;cursor:pointer}
.btn.primary{background:var(--indigo);color:var(--ink)}
.btn.primary:hover{background:#0DB497}
.btn.ghost{background:#fff;border:1px solid var(--line2);color:var(--ink)}
.btn.ghost:hover{border-color:var(--ink)}
.btn.sm{padding:7px 12px;font-size:12.5px}
.actions{display:flex;gap:10px;margin-top:16px}

.stage{padding:22px;background:repeating-linear-gradient(45deg,#F3F1EC 0 10px,#F6F4EF 10px 20px);display:flex;justify-content:center}
.cardshell{width:100%;max-width:620px;box-shadow:0 8px 30px rgba(0,0,0,.13);background:#fff;border-radius:3px;overflow:hidden}
.cardshell img{width:100%;display:block}
.pvtog{display:flex;gap:3px;background:var(--grey-soft);border-radius:7px;padding:3px;width:max-content}
.pvtog a{color:var(--muted);font-weight:600;font-size:12.5px;padding:6px 13px;border-radius:5px}
.pvtog a.on{background:#fff;color:var(--ink)}

.kv{display:grid;grid-template-columns:160px 1fr;gap:0}
.kv div{padding:10px 14px;border-bottom:1px solid var(--line)}
.kv .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--faint)}
.kv .v{font-weight:600}
.kv >div:nth-last-child(-n+2){border-bottom:0}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.stat .num{font-size:30px;font-weight:800;letter-spacing:-.03em;font-family:var(--mono)}
.stat.accent .num{color:var(--indigo)}
.stat .cap{font-size:12.5px;color:var(--muted);margin-top:2px}
.stat a{color:inherit}

.tablewrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:600;padding:12px 16px;border-bottom:1px solid var(--line);background:#fff}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:top}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:#FCFBF8}
.oid{font-family:var(--mono);font-weight:600}
.sub{color:var(--faint);font-size:11.5px}
.num-c{font-family:var(--mono)}
.flink{font-family:var(--mono);font-size:12px;color:var(--indigo);font-weight:600}
.flink.off{color:var(--faint)}

.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 9px;border-radius:20px}
.pill .pd{width:6px;height:6px;border-radius:50%}
.pill.new{background:var(--indigo-soft);color:var(--indigo)}.pill.new .pd{background:var(--indigo)}
.pill.in_production{background:var(--amber-soft);color:var(--amber)}.pill.in_production .pd{background:var(--amber)}
.pill.shipped{background:var(--green-soft);color:var(--green)}.pill.shipped .pd{background:var(--green)}
.pill.concept{background:var(--grey-soft);color:var(--grey)}.pill.concept .pd{background:var(--grey)}
.pill.ingekocht{background:var(--indigo-soft);color:var(--indigo)}.pill.ingekocht .pd{background:var(--indigo)}
.pill.goedgekeurd{background:var(--indigo-soft);color:var(--indigo)}.pill.goedgekeurd .pd{background:var(--indigo)}

.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--paper)}
.login-logo-img{display:block;height:48px;margin:0 auto 22px}
.brand-logo{height:26px;display:block}
.login-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:32px;box-shadow:0 12px 40px rgba(24,33,47,.07)}
.login-card h1{font-size:22px;letter-spacing:-.02em;margin:0 0 4px;text-align:center}
.login-card p.s{color:var(--muted);margin:0 0 22px;font-size:13px;text-align:center}
.login-card .field{margin-bottom:13px}
.login-card .btn{width:100%;margin-top:6px}
.demo{margin-top:18px;font-family:var(--mono);font-size:11px;color:var(--faint);line-height:1.6;border-top:1px solid var(--line);padding-top:14px}

.foot{margin-top:20px;font-size:12px;color:var(--faint);font-family:var(--mono)}
.inline-form{display:inline}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
select.mini{border:1px solid var(--line2);border-radius:7px;padding:6px 8px;font-size:12px;background:#fff}
@media(max-width:920px){.split{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}.kv{grid-template-columns:120px 1fr}}
