/* ============================================================
   HandelWerk — APP designsysteem (intern, donkere shell)
   Merkrood #e30613 · Space Grotesk + Hanken Grotesk
   ============================================================ */
:root{
  --brand:#e30613;
  --bg:#0B0C0F;--bg2:#0F1116;--surface:#15171D;--surface2:#1B1E26;--surface3:#222633;
  --line:rgba(255,255,255,.07);--line2:rgba(255,255,255,.13);--line3:rgba(255,255,255,.2);
  --tx:#EDEEF2;--mut:#9CA0AC;--mut2:#6A6F7C;
  --red:#e30613;
  --red2:color-mix(in oklab,var(--red),white 22%);
  --redsoft:color-mix(in srgb,var(--red),transparent 86%);
  --redline:color-mix(in srgb,var(--red),transparent 66%);
  --green:#37D481;--greensoft:rgba(55,212,129,.13);
  --amber:#F5B544;--bluetag:#5B9BFF;
  --disp:"Space Grotesk",system-ui,sans-serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --r-sm:8px;--r:11px;--r-lg:15px;--r-xl:20px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --glass:rgba(15,17,22,.8);--pv-bg:#0a0a0c;
}
/* ---------- lichte modus ---------- */
body.light{
  --bg:#EEF0F4;--bg2:#FFFFFF;--surface:#FFFFFF;--surface2:#F6F7F9;--surface3:#E9ECF1;
  --line:rgba(18,22,31,.09);--line2:rgba(18,22,31,.14);--line3:rgba(18,22,31,.26);
  --tx:#171A21;--mut:#5C6373;--mut2:#8B92A0;
  --green:#1f9d57;--greensoft:rgba(31,157,87,.12);
  --glass:rgba(255,255,255,.82);--pv-bg:#E7E9EF;
}
body{transition:background .25s var(--ease),color .25s var(--ease)}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--tx);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.5;overflow:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--red);color:#fff}
button{font-family:inherit;cursor:pointer}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:6px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#2c3140}

/* ---------- shell ---------- */
.app-shell{display:grid;grid-template-columns:248px 1fr;height:100vh;height:100dvh}
.sidebar{background:var(--bg2);border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0}
.sb-brand{display:flex;align-items:center;gap:10px;padding:20px 20px 18px}
.sb-brand img{height:19px;max-width:100%}
.sb-brand .logo-light{display:none}
body.light .sb-brand .logo-dark{display:none}
body.light .sb-brand .logo-light{display:block}
.logo-swap .logo-light{display:none}
body.light .logo-swap .logo-dark{display:none}
body.light .logo-swap .logo-light{display:block}
.sb-section{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut2);padding:16px 22px 8px}
.sb-nav{flex:1;overflow-y:auto;padding:6px 12px}
.sb-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r);color:var(--mut);font-size:14.5px;font-weight:500;transition:background .15s,color .15s;margin-bottom:2px;position:relative}
.sb-link svg{width:18px;height:18px;flex:0 0 auto;opacity:.85}
.sb-link:hover{background:var(--surface2);color:var(--tx)}
.sb-link.active{background:var(--surface3);color:var(--tx)}
.sb-link.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;background:var(--red);border-radius:0 3px 3px 0}
.sb-link.active svg{color:var(--red2);opacity:1}
.sb-badge{margin-left:auto;font-size:11px;background:var(--surface3);color:var(--mut);border-radius:20px;padding:1px 8px;font-weight:600}
.sb-foot{border-top:1px solid var(--line);padding:14px 16px;display:flex;align-items:center;gap:11px}
.sb-foot .av{width:34px;height:34px;border-radius:9px;background:linear-gradient(150deg,var(--red),var(--red2));display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:13px;color:#fff}
.sb-foot .nm{font-size:13px;font-weight:600;line-height:1.2}
.sb-foot .nm small{display:block;color:var(--mut2);font-weight:400;font-size:11.5px}

.main{display:flex;flex-direction:column;min-width:0;min-height:0}
.topbar{height:64px;flex:0 0 auto;border-bottom:1px solid var(--line);background:var(--glass);backdrop-filter:blur(14px);display:flex;align-items:center;gap:16px;padding:0 24px}
.tb-title{display:flex;flex-direction:column;gap:1px}
.tb-title .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--mut2)}
.tb-title h1{font-family:var(--disp);font-size:19px;font-weight:600;letter-spacing:-.01em}
.tb-actions{margin-left:auto;display:flex;align-items:center;gap:10px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:14px;border:1px solid transparent;border-radius:var(--r-sm);padding:9px 15px;transition:transform .14s var(--ease),background .15s,border-color .15s,box-shadow .15s;white-space:nowrap;color:var(--tx)}
.btn svg{width:16px;height:16px}
.btn-line{border-color:var(--line2);background:transparent}
.btn-line:hover{background:var(--surface2);border-color:var(--line3)}
.btn-ghost{color:var(--mut)}.btn-ghost:hover{color:var(--tx);background:var(--surface)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 6px 18px var(--redsoft)}
.btn-red:hover{background:var(--red2);transform:translateY(-1px);box-shadow:0 10px 26px var(--redsoft)}
.btn-sm{padding:7px 11px;font-size:13px;border-radius:8px}
.btn-icon{padding:9px;border-radius:9px}

/* ---------- content split ---------- */
.content{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,560px);gap:0}
.form-pane{overflow-y:auto;padding:24px 28px 80px}
.preview-pane{overflow-y:auto;border-left:1px solid var(--line);background:var(--pv-bg);padding:28px 28px 80px;display:flex;flex-direction:column;align-items:center}
.theme-toggle{width:38px;height:38px;border-radius:9px;border:1px solid var(--line2);background:transparent;color:var(--mut);display:grid;place-items:center;transition:all .15s}
.theme-toggle:hover{color:var(--tx);background:var(--surface2);border-color:var(--line3)}
.theme-toggle svg{width:18px;height:18px}
.theme-toggle .moon{display:none}
body.light .theme-toggle .sun{display:none}
body.light .theme-toggle .moon{display:block}
.form-stack{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:18px}

/* ---------- cards / sections ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.card-h{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}
.card-h .ico{width:30px;height:30px;border-radius:8px;background:var(--redsoft);border:1px solid var(--redline);display:grid;place-items:center;color:var(--red2);flex:0 0 auto}
.card-h .ico svg{width:16px;height:16px}
.card-h h2{font-family:var(--disp);font-size:15.5px;font-weight:600;letter-spacing:-.01em}
.card-h .sub{font-size:12.5px;color:var(--mut2)}
.card-h .right{margin-left:auto}
.card-b{padding:20px}

/* ---------- form controls ---------- */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:7px;min-width:0}
.field label{font-size:12px;font-weight:600;color:var(--mut);letter-spacing:.01em;display:flex;align-items:center;gap:6px}
.field .hint{width:15px;height:15px;border-radius:50%;background:var(--surface3);color:var(--mut);font-size:10px;display:grid;place-items:center;font-weight:700;cursor:help}
.inp,.sel{width:100%;background:var(--bg2);border:1px solid var(--line2);border-radius:9px;padding:10px 12px;color:var(--tx);font-family:var(--sans);font-size:14px;transition:border-color .15s,box-shadow .15s;min-width:0}
.inp::placeholder{color:var(--mut2)}
.inp:focus,.sel:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px var(--redsoft)}
.sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%239CA0AC' stroke-width='1.6'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.inp.money{font-variant-numeric:tabular-nums}
.in-prefix{position:relative}
.in-prefix .pf{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--mut2);font-size:14px;pointer-events:none;line-height:1}
.in-prefix .inp{padding-left:26px}

/* segmented control */
.seg{display:flex;width:100%;background:var(--bg2);border:1px solid var(--line2);border-radius:9px;padding:3px;gap:2px}
.seg button{flex:1;min-width:0;border:none;background:transparent;color:var(--mut);font-size:12.5px;font-weight:600;padding:7px 6px;border-radius:7px;transition:background .15s,color .15s;white-space:nowrap;text-align:center;overflow:hidden;text-overflow:ellipsis}
.seg button.on{background:var(--surface3);color:var(--tx)}
.seg button.on.red{background:var(--red);color:#fff}

/* autocomplete */
.ac-wrap{position:relative}
.ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface2);border:1px solid var(--line2);border-radius:10px;box-shadow:0 16px 40px rgba(0,0,0,.5);z-index:20;overflow:hidden;display:none}
.ac-list.open{display:block}
.ac-item{padding:10px 13px;font-size:13.5px;cursor:pointer;display:flex;justify-content:space-between;gap:10px}
.ac-item:hover,.ac-item.sel{background:var(--surface3)}
.ac-item small{color:var(--mut2)}

/* ---------- vehicle cards ---------- */
.veh-list{display:flex;flex-direction:column;gap:14px}
.veh{background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r-lg);overflow:hidden;transition:border-color .18s}
.veh:hover{border-color:var(--line3)}
.veh-top{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--line)}
.veh-top .idx{width:24px;height:24px;border-radius:7px;background:var(--surface3);display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:12px;color:var(--mut)}
.veh-top .vt-title{font-family:var(--disp);font-weight:600;font-size:14px}
.veh-top .vt-title small{color:var(--mut2);font-weight:400;font-family:var(--sans)}
.veh-top .right{margin-left:auto;display:flex;align-items:center;gap:8px}
.chip{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;border:1px solid var(--line2);color:var(--mut)}
.chip.verkoop{color:var(--green);border-color:var(--greensoft);background:var(--greensoft)}
.chip.inkoop{color:#FF8A8A;border-color:rgba(255,90,90,.25);background:rgba(255,90,90,.1)}
.chip.marge{color:var(--amber)}.chip.btw{color:var(--bluetag)}.chip.verlegd{color:var(--mut)}
.veh-rm{width:28px;height:28px;border-radius:8px;border:1px solid var(--line2);background:transparent;color:var(--mut2);display:grid;place-items:center;transition:all .15s}
.veh-rm:hover{color:#FF6B6B;border-color:rgba(255,107,107,.4);background:rgba(255,107,107,.08)}
.veh-b{padding:16px}
.veh-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:13px}
.veh-row:last-child{margin-bottom:0}
.veh-row.three{grid-template-columns:1fr 1fr 1fr}
.veh-row.seg-row{grid-template-columns:.82fr 1.18fr}
.veh-row.mm{grid-template-columns:1.3fr 1.3fr .9fr}
.add-veh{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;padding:14px;border:1.5px dashed var(--line2);border-radius:var(--r-lg);background:transparent;color:var(--mut);font-weight:600;font-size:14px;transition:all .16s}
.add-veh:hover{border-color:var(--redline);color:var(--red2);background:var(--redsoft)}

/* deel popover */
.pop-wrap{position:relative}
.pop{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface2);border:1px solid var(--line2);border-radius:12px;box-shadow:0 18px 48px rgba(0,0,0,.55);padding:6px;min-width:180px;z-index:30;display:none}
.pop.open{display:block}
.pop button{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;color:var(--tx);font-size:14px;font-weight:500;border-radius:8px;text-align:left}
.pop button:hover{background:var(--surface3)}
.pop button svg{width:17px;height:17px;color:var(--mut)}

/* ---------- A4 invoice preview ---------- */
.a4-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut2);align-self:flex-start;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.a4-label .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px var(--greensoft)}
.a4{background:#fff;color:#1a1a1a;width:100%;max-width:480px;border-radius:6px;box-shadow:0 30px 70px rgba(0,0,0,.5);padding:34px 32px;font-size:12px;line-height:1.5;font-family:var(--sans)}
.a4-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1.5px solid #111;padding-bottom:16px;margin-bottom:16px}
.a4-head img{height:42px}
.a4-head .co{text-align:right;font-size:10px;color:#444;line-height:1.5}
.a4-head .co b{color:#111;font-size:11px}
.a4-meta{display:flex;justify-content:space-between;gap:20px;margin-bottom:18px}
.a4-meta h3{font-family:var(--disp);font-size:18px;font-weight:700;color:#111;margin-bottom:8px;letter-spacing:-.01em}
.a4-meta .row{display:flex;gap:8px;font-size:11px;margin-bottom:2px}
.a4-meta .row span:first-child{color:#777;min-width:78px}
.a4-meta .klant{background:#f6f6f7;border:1px solid #e5e5e7;border-radius:4px;padding:11px 13px;min-width:170px;font-size:11px;line-height:1.6}
.a4-meta .klant b{display:block;color:#111;margin-bottom:2px;font-size:12px}
.a4-tbl{width:100%;border-collapse:collapse;font-size:10.5px;margin-bottom:16px}
.a4-tbl th{background:#f0f0f2;border:1px solid #d8d8dc;padding:6px 8px;text-align:left;text-transform:uppercase;font-size:9px;letter-spacing:.04em;color:#555;font-weight:700}
.a4-tbl td{border:1px solid #e0e0e4;padding:6px 8px;vertical-align:top}
.a4-tbl td.r{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
.a4-tbl .tv{color:#1f9d57;font-weight:700}
.a4-tbl .ti{color:#d6334a;font-weight:700}
.a4-tbl .empty td{color:#aaa;text-align:center;padding:18px;font-style:italic}
.a4-tot{width:62%;margin-left:auto;font-size:11px;margin-bottom:14px}
.a4-tot .tr{display:flex;justify-content:space-between;padding:5px 2px;border-bottom:1px solid #eee}
.a4-tot .tr>span:last-child{white-space:nowrap;padding-left:10px}
.a4-tot .tr.saldo{border-top:1.5px solid #111;border-bottom:1.5px solid #111;font-weight:700;color:#111;margin-top:3px}
.a4-tot .tr.pay{font-family:var(--disp);font-weight:700;font-size:13px;color:#111;border:none}
.a4-tot .tr .g{color:#1f9d57}
.a4-foot{border-top:1px solid #ddd;padding-top:12px;font-size:9px;color:#888;line-height:1.6}
.status-pill{display:inline-block;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;border-radius:20px}
.status-pill.betaald{background:#e4f7ed;color:#1f9d57}
.status-pill.open{background:#fdeaea;color:#d6334a}
.status-pill.aanbetaald{background:#fff4e0;color:#c8881a}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface2);border:1px solid var(--line2);border-radius:12px;padding:13px 20px;font-size:14px;font-weight:500;box-shadow:0 16px 44px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:100;display:flex;align-items:center;gap:10px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .ok{width:20px;height:20px;border-radius:50%;background:var(--green);display:grid;place-items:center;color:#04210f}

/* ---------- volledige-breedte pagina (lijstschermen) ---------- */
.page{flex:1;min-height:0;overflow-y:auto;padding:22px 26px 80px}
.page-inner{max-width:1320px;margin:0 auto}

/* filter-tabs */
.toolbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.ftabs{display:inline-flex;background:var(--bg2);border:1px solid var(--line2);border-radius:11px;padding:3px;gap:2px}
.ftab{border:none;background:transparent;color:var(--mut);font-family:var(--sans);font-size:14px;font-weight:600;padding:8px 15px;border-radius:8px;display:inline-flex;align-items:center;gap:8px;transition:background .15s,color .15s}
.ftab:hover{color:var(--tx)}
.ftab.active{background:var(--surface3);color:var(--tx)}
.ftab .cnt{font-size:11.5px;background:var(--surface);border:1px solid var(--line2);color:var(--mut);border-radius:20px;padding:0 7px;min-width:20px;text-align:center;font-weight:600}
.ftab.active .cnt{background:var(--red);border-color:var(--red);color:#fff}
.search{margin-left:auto;position:relative;min-width:240px}
.search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--mut2)}
.search input{width:100%;background:var(--bg2);border:1px solid var(--line2);border-radius:10px;padding:10px 12px 10px 36px;color:var(--tx);font-family:var(--sans);font-size:14px}
.search input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px var(--redsoft)}

/* periode-balk */
.periodbar{display:flex;align-items:center;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.ptab{border:none;background:transparent;color:var(--mut);font-family:var(--sans);font-size:13px;font-weight:600;padding:6px 12px;border-radius:8px;transition:background .15s,color .15s}
.ptab:hover{color:var(--tx);background:var(--surface)}
.ptab.active{background:var(--surface2);color:var(--tx);border:1px solid var(--line2)}
.period-nav{margin-left:8px;display:inline-flex;align-items:center;gap:8px;color:var(--mut)}
.period-nav button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line2);background:transparent;color:var(--mut);display:grid;place-items:center}
.period-nav button:hover{color:var(--tx);background:var(--surface)}
.period-nav .plabel{font-size:13px;font-weight:600;color:var(--tx);min-width:90px;text-align:center}

/* stat-kaarten */
.statrow{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px}
.statcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px}
.statcard .lbl{font-size:12px;color:var(--mut2);font-weight:600;display:flex;align-items:center;gap:7px}
.statcard .lbl .di{width:8px;height:8px;border-radius:3px;background:var(--mut2)}
.statcard .val{font-family:var(--disp);font-size:24px;font-weight:700;letter-spacing:-.02em;margin-top:8px;white-space:nowrap}
.statcard.accent{border-color:var(--redline);background:linear-gradient(180deg,var(--redsoft),var(--surface))}
.statcard.accent .val{color:var(--red2)}.statcard.accent .lbl .di{background:var(--red)}
.statcard.good .val{color:var(--green)}.statcard.good .lbl .di{background:var(--green)}

/* datatabel */
.tablecard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.tbl-scroll{overflow-x:auto}
.dtable{width:100%;border-collapse:collapse;font-size:13.5px;min-width:760px;table-layout:auto}
.dtable thead th{background:var(--bg2);text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--mut2);font-weight:500;padding:12px 9px;border-bottom:1px solid var(--line);white-space:nowrap;position:sticky;top:0;z-index:1}
.dtable thead th.r{text-align:right}
.dtable tbody td{padding:12px 8px;border-bottom:1px solid var(--line);vertical-align:middle;white-space:nowrap}
.dtable tbody tr:last-child td{border-bottom:none}
.dtable tbody tr.row:hover{background:var(--surface2);cursor:pointer}
.dtable td.r{text-align:right;font-variant-numeric:tabular-nums;font-size:13px}
.dtable .car{display:flex;align-items:center;gap:9px;min-width:0}
.dtable .car .thumb{width:34px;height:26px;border-radius:6px;background:var(--surface3);display:grid;place-items:center;font-size:13px;flex:0 0 auto}
.dtable .car .nm{font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.dtable .car .nm small{display:block;color:var(--mut2);font-weight:400;font-size:11.5px}
.kent{font-family:var(--disp);font-weight:700;font-size:11.5px;background:#F5C518;color:#1a1a1a;border-radius:4px;padding:2px 7px;letter-spacing:.02em}
.tbadge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;border:1px solid var(--line2);color:var(--mut)}
.tbadge.marge{color:var(--amber);border-color:color-mix(in srgb,var(--amber),transparent 70%);background:color-mix(in srgb,var(--amber),transparent 90%)}
.tbadge.btw{color:var(--bluetag);border-color:color-mix(in srgb,var(--bluetag),transparent 70%);background:color-mix(in srgb,var(--bluetag),transparent 90%)}
.tbadge.factuur{color:var(--mut)}
.tbadge.extern{color:var(--mut);border-style:dashed}
.dagen{display:inline-flex;align-items:center;gap:6px;color:var(--mut)}
.dagen .bolt{width:7px;height:7px;border-radius:50%;background:var(--green)}
.dagen.lang .bolt{background:var(--amber)}.dagen.zeerlang .bolt{background:var(--red)}
.pos{color:var(--green);font-weight:700}.neg{color:#FF6B6B;font-weight:700}
.muted-cell{color:var(--mut2)}
.row-act{display:inline-flex;gap:4px}
.row-act button{width:28px;height:28px;border-radius:7px;border:1px solid var(--line2);background:transparent;color:var(--mut);display:grid;place-items:center}
.row-act button:hover{color:var(--tx);background:var(--surface3)}
/* uitklap-detail */
.detail-row td{background:var(--bg2);padding:0;border-bottom:1px solid var(--line)}
.detail-in{padding:16px 18px 18px 63px;display:grid;grid-template-columns:1.4fr 1fr;gap:24px}
.detail-in h4{font-family:var(--disp);font-size:13px;font-weight:600;color:var(--mut);margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}
.kostlijst{display:flex;flex-direction:column;gap:8px}
.kostlijst .kr{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px solid var(--line)}
.kostlijst .kr:last-child{border:none}
.kostlijst .kr.tot{font-weight:700;color:var(--tx)}
.winstbox{background:var(--surface);border:1px solid var(--line2);border-radius:12px;padding:16px}
.winstbox .wr{display:flex;justify-content:space-between;font-size:13px;padding:5px 0}
.winstbox .wr.big{font-family:var(--disp);font-size:18px;font-weight:700;border-top:1px solid var(--line2);margin-top:6px;padding-top:12px}
.empty-state{text-align:center;color:var(--mut2);padding:48px 20px;font-size:14px}
.list-hint{font-size:12.5px;color:var(--mut2);margin:0 2px 12px;display:flex;align-items:center;gap:8px}
.list-hint svg{width:15px;height:15px;color:var(--red2)}
.kr-amt{display:inline-flex;align-items:center;gap:8px}
.rmk{width:19px;height:19px;border-radius:5px;border:1px solid var(--line2);background:transparent;color:var(--mut2);font-size:14px;line-height:1;display:grid;place-items:center;cursor:pointer}
.rmk:hover{color:#FF6B6B;border-color:rgba(255,107,107,.4);background:rgba(255,107,107,.08)}
.kost-add{display:flex;gap:8px;margin-top:14px;align-items:center}
.kost-add .inp{flex:1}
.row-act button svg{transition:transform .2s var(--ease)}
tr.row.open td{background:var(--surface2)}

/* === Voorraad detail: kosten + kostenfactuur koppelen + foto's === */
.act-tabs{display:inline-flex;gap:5px;justify-content:flex-end}
.act-tab{border:1px solid var(--line2);background:transparent;color:var(--mut);font-family:var(--sans);font-size:11.5px;font-weight:600;padding:5px 8px;border-radius:8px;display:inline-flex;align-items:center;gap:5px;transition:all .15s;white-space:nowrap}
.act-tab:hover{color:var(--tx);border-color:rgba(255,255,255,.28)}
.act-tab.on{background:var(--red);border-color:var(--red);color:#fff}
.act-tab svg{width:13px;height:13px}

.kdetail{padding:18px 22px 20px}
.kdetail h4{font-family:var(--disp);font-size:15px;font-weight:700;letter-spacing:-.01em;margin-bottom:4px}
.ksum{display:flex;flex-wrap:wrap;gap:18px;font-size:13px;color:var(--mut);margin:10px 0 18px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.ksum b{color:var(--tx);font-weight:600;margin-left:5px}
.ksum .g{color:var(--green)}.ksum .n{color:#FF6B6B}

.kost-list{display:flex;flex-direction:column}
.kost-row{display:grid;grid-template-columns:96px 110px 1fr auto 28px;gap:14px;align-items:center;padding:11px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.kost-row .kdate{color:var(--mut2);font-variant-numeric:tabular-nums}
.kost-row .kdesc{color:var(--tx)}
.kost-row .kdesc .lk{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--mut2);margin-left:8px}
.kost-row .kdesc .lk svg{width:11px;height:11px;color:var(--green)}
.kost-row .kamt{text-align:right;font-weight:600;font-variant-numeric:tabular-nums}
.catbadge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;justify-self:start;color:var(--amber);border:1px solid color-mix(in srgb,var(--amber),transparent 70%);background:color-mix(in srgb,var(--amber),transparent 90%);text-transform:capitalize}
.kost-tot{display:flex;justify-content:space-between;align-items:center;padding:14px 0 0;font-family:var(--disp);font-weight:700;font-size:15px}
.kost-tot .v{font-variant-numeric:tabular-nums}

.add-bar{display:flex;gap:8px;margin-top:16px;align-items:center;flex-wrap:wrap}
.add-bar .inp,.add-bar .sel{height:38px;padding-top:0;padding-bottom:0}
.add-bar .c-date{width:130px}.add-bar .c-cat{width:140px}.add-bar .c-desc{flex:1;min-width:160px}.add-bar .c-amt{width:120px}

.koppel{margin-top:20px;border-top:1px solid var(--line);padding-top:18px}
.koppel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.koppel-head .t{font-size:12px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.05em}
.fac-row{display:flex;align-items:center;gap:16px;padding:13px 14px;border:1px solid var(--line2);border-radius:11px;margin-top:10px;background:var(--bg2)}
.fac-row .fac-main{flex:1;min-width:0}
.fac-row .fac-main .nm{font-weight:600;font-size:13.5px}
.fac-row .fac-main .nm .nr{color:var(--mut2);font-weight:500;margin-left:7px}
.fac-row .fac-main .meta{font-size:12px;color:var(--mut2);margin-top:3px}
.fac-row .fac-rest{text-align:right;font-size:12px;color:var(--mut)}
.fac-row .fac-rest b{display:block;color:var(--tx);font-size:14px;font-variant-numeric:tabular-nums}
.fac-row .fac-act{display:flex;gap:7px}
.btn-green{background:var(--green);color:#06281a;border:1px solid var(--green)}
.btn-green:hover{filter:brightness(1.08);transform:translateY(-1px)}
.koppel-empty{font-size:12.5px;color:var(--mut2);margin-top:10px}

/* foto's */
.foto-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.foto-bar .cnt{font-size:12.5px;color:var(--mut2)}
.foto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}
.foto-thumb{aspect-ratio:4/3;border-radius:9px;background:var(--surface3);border:1px solid var(--line2);display:grid;place-items:center;font-size:24px;position:relative;cursor:pointer;overflow:hidden}
.foto-thumb .del{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:6px;background:rgba(0,0,0,.55);color:#fff;border:none;display:grid;place-items:center;font-size:13px;opacity:0;transition:opacity .15s}
.foto-thumb:hover .del{opacity:1}
.foto-empty{color:var(--mut2);font-size:13px;padding:20px 0 4px}
.foto-add{border:1px dashed var(--line2);background:transparent;color:var(--mut);aspect-ratio:4/3;border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.foto-add:hover{border-color:var(--red);color:var(--red2);background:var(--redsoft)}
.foto-add svg{width:20px;height:20px}

/* === Archief: status badges, status row-bar, compacte actieknoppen === */
.sbadge{font-size:11px;font-weight:600;padding:3px 11px;border-radius:20px;border:1px solid transparent;display:inline-block;white-space:nowrap}
.sbadge.betaald{color:var(--green);background:color-mix(in srgb,var(--green),transparent 88%);border-color:color-mix(in srgb,var(--green),transparent 68%)}
.sbadge.open{color:#FF7A7A;background:rgba(255,107,107,.1);border-color:rgba(255,107,107,.32)}
.sbadge.aanbetaald{color:var(--amber);background:color-mix(in srgb,var(--amber),transparent 88%);border-color:color-mix(in srgb,var(--amber),transparent 65%)}
.dtable tbody tr.row td:first-child{box-shadow:inset 3px 0 0 transparent}
.dtable tbody tr.row.st-betaald td:first-child{box-shadow:inset 3px 0 0 var(--green)}
.dtable tbody tr.row.st-open td:first-child{box-shadow:inset 3px 0 0 #FF5A5A}
.dtable tbody tr.row.st-aanbetaald td:first-child{box-shadow:inset 3px 0 0 var(--amber)}
.saldo-pos{color:var(--green);font-weight:600}
.row-actions{display:inline-flex;gap:6px;justify-content:flex-end}
.btn-xs{padding:5px 10px;font-size:12px;border-radius:7px;gap:5px;font-weight:600}
.btn-danger{background:#E5484D;color:#fff;border:1px solid #E5484D}
.btn-danger:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn.is-disabled{opacity:.38;pointer-events:none}

/* === Inkoop: payment + koppel badges, bedragregels === */
.paybadge{font-size:11px;font-weight:600;padding:3px 11px;border-radius:20px;border:1px solid transparent;white-space:nowrap}
.paybadge.bank{color:var(--green);background:color-mix(in srgb,var(--green),transparent 88%);border-color:color-mix(in srgb,var(--green),transparent 68%)}
.paybadge.contant{color:var(--amber);background:color-mix(in srgb,var(--amber),transparent 88%);border-color:color-mix(in srgb,var(--amber),transparent 65%)}
.paybadge.pin{color:var(--bluetag);background:color-mix(in srgb,var(--bluetag),transparent 88%);border-color:color-mix(in srgb,var(--bluetag),transparent 68%)}
.gbadge{font-size:11px;font-weight:600;padding:3px 11px;border-radius:20px;border:1px solid transparent;white-space:nowrap;display:inline-block}
.gbadge.vol{color:var(--green);background:color-mix(in srgb,var(--green),transparent 88%);border-color:color-mix(in srgb,var(--green),transparent 68%)}
.gbadge.deels{color:var(--amber);background:color-mix(in srgb,var(--amber),transparent 86%);border-color:color-mix(in srgb,var(--amber),transparent 62%);text-align:center;line-height:1.2}
.gbadge.deels small{display:block;font-size:9.5px;font-weight:500;opacity:.9}
.gbadge.geen{color:var(--mut2);border-color:var(--line2);border-style:dashed}
.km-cell{color:var(--mut);font-variant-numeric:tabular-nums}
.km-cell small{color:var(--mut2)}
.lev-cell b{font-weight:600;color:var(--tx)}
.lev-cell small{color:var(--mut2);font-weight:400}
.bedrag-head{display:grid;grid-template-columns:1fr 116px 92px 60px;gap:12px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--mut2);font-weight:600;padding:0 2px 4px}
.bedrag-row{display:grid;grid-template-columns:1fr 116px 92px 60px;gap:12px;align-items:center;margin-bottom:8px}
.bedrag-row .btwv{text-align:right;font-variant-numeric:tabular-nums;color:var(--mut);font-size:13px}
.bedrag-row .aftrek{display:flex;align-items:center;justify-content:center}
.bedrag-row .aftrek input{width:17px;height:17px;accent-color:var(--red)}
.bedrag-tot{display:flex;gap:22px;flex-wrap:wrap;font-size:13.5px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.bedrag-tot b{font-family:var(--disp);font-weight:700;color:var(--tx)}
.sub-note{font-size:13px;color:var(--mut2);margin:2px 0 18px}
.col-actions{display:inline-flex;gap:6px;justify-content:flex-end}

/* === Rapportages === */
.subnote{font-size:13.5px;color:var(--mut);margin:-2px 0 18px}
.subtabs-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:6px;margin-bottom:20px}
.subtabs-card .ftabs{background:transparent;border:none;padding:0;width:100%}
.subtabs-card .ftab{flex:1;justify-content:center}
.exportbar{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.exportbar .field{min-width:160px}
.btn-green{background:var(--green);color:#06281a;border:1px solid var(--green);font-weight:700}
.btn-green:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn-blue{background:#2F9BE8;color:#fff;border:1px solid #2F9BE8;font-weight:600}
.btn-blue:hover{filter:brightness(1.07);transform:translateY(-1px)}
.result-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px}
.result-card .rl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut2)}
.result-card .rv{font-family:var(--disp);font-size:26px;font-weight:700;margin-top:6px}

/* BTW-aangifte panelen */
.btw-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}
.btwbox{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px;display:flex;flex-direction:column}
.btwbox.hl{border-color:var(--line2);box-shadow:0 0 0 1px var(--line2),0 18px 50px rgba(0,0,0,.4)}
.btwbox h3{font-family:var(--disp);font-size:16px;font-weight:600;color:var(--tx);margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.btwbox .kv{display:flex;justify-content:space-between;gap:14px;font-size:14px;padding:7px 0;color:var(--mut)}
.btwbox .kv b{color:var(--tx);font-weight:600;font-variant-numeric:tabular-nums}
.btwbox .kv .pos{color:var(--green)}
.btwbox .foot{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line2)}
.btwbox .foot .l{font-family:var(--disp);font-size:17px;font-weight:600;color:var(--tx)}
.btwbox .foot .v{font-family:var(--disp);font-size:20px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--tx)}
.btwbox .foot .v.red{color:#FF5A5A}
.btwbox .note{color:var(--mut2);font-size:12px;margin-top:10px}
.rap-h{font-family:var(--disp);font-size:16px;font-weight:600;margin:6px 0 14px}
.dtable tfoot td{background:var(--bg2);font-weight:700;border-top:2px solid var(--line2);padding:14px;font-variant-numeric:tabular-nums}
.dtable tfoot td.pos{color:var(--green)}
.dtable td.dash{color:var(--mut2)}
@media(max-width:880px){.btw-grid{grid-template-columns:1fr}}

/* === Relaties === */
.tbadge.particulier{color:var(--bluetag);border-color:color-mix(in srgb,var(--bluetag),transparent 66%);background:color-mix(in srgb,var(--bluetag),transparent 88%)}
.tbadge.zakelijk{color:#B98AFF;border-color:color-mix(in srgb,#B98AFF,transparent 66%);background:color-mix(in srgb,#B98AFF,transparent 88%)}
.link-cell{color:var(--red2)}
.dtable tbody tr.row:hover .link-cell{text-decoration:underline}
.plaats-cell .pc{color:var(--mut2);font-variant-numeric:tabular-nums}
.row-act-stack{display:inline-flex;flex-direction:column;gap:6px;align-items:flex-end}

/* === Import / Profiel: segmented tabs (lichte pill-stijl) === */
.segtabs{display:inline-flex;background:var(--surface);border:1px solid var(--line2);border-radius:11px;padding:5px;gap:4px;margin-bottom:18px}
.segtab{border:none;background:transparent;color:var(--mut);font-family:var(--sans);font-size:14px;font-weight:600;padding:9px 18px;border-radius:8px;transition:background .15s,color .15s}
.segtab:hover{color:var(--tx)}
.segtab.active{background:var(--surface3);color:var(--tx);box-shadow:0 1px 2px rgba(0,0,0,.3)}
.infobanner{background:color-mix(in srgb,var(--bluetag),transparent 90%);border:1px solid color-mix(in srgb,var(--bluetag),transparent 74%);border-radius:var(--r-lg);padding:16px 18px;color:var(--mut);font-size:13.5px;line-height:1.55;margin-bottom:22px}
.formcard.narrow{max-width:760px}
.formcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 26px;margin-bottom:20px}
.formcard h3{font-family:var(--disp);font-size:17px;font-weight:600;color:var(--tx);margin-bottom:18px;letter-spacing:-.01em}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px 22px;margin-bottom:16px}
.frow.one{grid-template-columns:1fr}
.frow:last-of-type{margin-bottom:0}
.frm-actions{display:flex;gap:10px;margin-top:22px}
textarea.inp{resize:vertical;min-height:78px;line-height:1.5}
.profile-stack{max-width:620px;display:flex;flex-direction:column;gap:18px}

/* === Beheer === */
.beheer-stack{max-width:920px;display:flex;flex-direction:column;gap:20px}
.switch{position:relative;width:46px;height:26px;flex:0 0 auto;cursor:pointer}
.switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:1}
.switch .track{position:absolute;inset:0;background:var(--surface3);border:1px solid var(--line2);border-radius:20px;transition:background .18s,border-color .18s}
.switch .knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .18s var(--ease)}
.switch input:checked~.track{background:var(--red);border-color:var(--red)}
.switch input:checked~.knob{transform:translateX(20px)}
.switchrow{display:flex;align-items:center;gap:12px;margin-bottom:14px;font-size:14px;font-weight:500}
.weblink{color:var(--red2);font-size:14px;font-weight:600;display:inline-block;margin-bottom:20px}
.weblink:hover{text-decoration:underline}
.logorow{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center}
.logo-preview{width:240px;height:96px;border:1px solid var(--line2);border-radius:var(--r);background:#fff;display:grid;place-items:center;padding:14px}
.logo-preview img{max-height:100%;max-width:100%;object-fit:contain}
.filepick{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.filebox{display:flex;align-items:center;gap:12px;border:1px solid var(--line2);border-radius:9px;padding:8px 8px 8px 8px;background:var(--bg2);width:100%;max-width:420px}
.filebox .fakebtn{background:var(--surface3);border:1px solid var(--line2);border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600;color:var(--tx);white-space:nowrap}
.filebox .fname{color:var(--mut2);font-size:13px}
.colorrow{display:flex;align-items:center;gap:12px}
.swatch{width:54px;height:34px;border-radius:8px;border:1px solid var(--line2);cursor:pointer;padding:0;overflow:hidden}
.colorrow .hex{font-family:var(--mono);font-size:13px;color:var(--mut)}
.rolepill{font-size:11px;font-weight:600;padding:3px 11px;border-radius:20px;color:var(--red2);background:var(--redsoft);border:1px solid var(--redline)}

/* === Platform admin dashboard === */
.admin-body{display:block;overflow-y:auto;overflow-x:hidden;height:auto;min-height:100vh;background:var(--bg)}
body.light.admin-body{background:#EEF0F4}
body.light .kpi.feature{background:linear-gradient(150deg,#FCE7E9,#FFFFFF)}
.admin-top{position:sticky;top:0;z-index:30;background:var(--glass);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.admin-top-in{max-width:1320px;margin:0 auto;display:flex;align-items:center;gap:18px;height:64px;padding:0 26px}
.admin-top .brand{display:flex;align-items:center;gap:11px}
.admin-top .brand img{height:22px;max-width:100%}
.admin-top .brand .ptag{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--mut2);border:1px solid var(--line2);border-radius:6px;padding:3px 8px}
.admin-top .sp{margin-left:auto}
.admin-actions{display:flex;align-items:center;gap:9px}
.admin-page{max-width:1320px;margin:0 auto;padding:24px 26px 80px}
.admin-h{display:flex;align-items:baseline;gap:12px;margin-bottom:20px}
.admin-h h1{font-family:var(--disp);font-size:26px;font-weight:700;letter-spacing:-.02em;color:var(--tx)}
.admin-h .sub{color:var(--mut2);font-size:13.5px}

/* hero KPI band */
.kpi-hero{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:14px;margin-bottom:14px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;position:relative;overflow:hidden}
.kpi .kl{font-size:12.5px;color:var(--mut2);font-weight:600;display:flex;align-items:center;gap:8px}
.kpi .kv{font-family:var(--disp);font-size:28px;font-weight:700;letter-spacing:-.02em;margin-top:8px;white-space:nowrap;color:var(--tx)}
.kpi .kd{font-size:12px;color:var(--mut2);margin-top:4px}
.kpi .kd .up{color:var(--green)}
.kpi.feature{background:linear-gradient(150deg,var(--redsoft),var(--surface));border-color:var(--redline)}
.kpi.feature .kv{color:var(--red2);font-size:32px}
.kpi .ic{position:absolute;top:16px;right:16px;width:30px;height:30px;border-radius:8px;background:var(--bg2);border:1px solid var(--line);display:grid;place-items:center;color:var(--mut2)}
.kpi .ic svg{width:16px;height:16px}

/* traffic mini-row */
.mini-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.mkpi{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r);padding:14px 16px}
.mkpi .l{font-size:12px;color:var(--mut2);font-weight:600}
.mkpi .v{font-family:var(--disp);font-size:20px;font-weight:700;margin-top:5px;color:var(--tx)}

/* dashboard grid */
.dash-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:18px;margin-bottom:18px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px}
.card h3{font-family:var(--disp);font-size:16px;font-weight:600;margin-bottom:4px;color:var(--tx)}
.card .csub{font-size:12.5px;color:var(--mut2);margin-bottom:18px}
.card .cside{display:flex;flex-direction:column;gap:22px}

/* bar chart */
.barchart{display:flex;align-items:flex-end;gap:8px;height:150px;padding-top:10px}
.barchart .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}
.barchart .bar{width:60%;max-width:26px;background:linear-gradient(180deg,var(--red2),var(--red));border-radius:5px 5px 0 0;min-height:3px;transition:height .7s var(--ease)}
.barchart .bx{font-family:var(--mono);font-size:9.5px;color:var(--mut2);writing-mode:vertical-rl;transform:rotate(180deg)}

/* top pages list */
.toplist{display:flex;flex-direction:column}
.toplist .tr{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.toplist .tr:last-child{border-bottom:none}
.toplist .tr .pg{font-family:var(--mono);font-size:12.5px;color:var(--mut);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.toplist .tr .vw{font-weight:700;font-variant-numeric:tabular-nums;color:var(--tx)}
.toplist .tr .bar-inline{flex:1;height:5px;background:var(--surface3);border-radius:3px;margin:0 4px;overflow:hidden}
.toplist .tr .bar-inline span{display:block;height:100%;background:var(--red);border-radius:3px}

/* device bars */
.devrow{display:flex;align-items:center;gap:12px;margin-bottom:14px;font-size:13px}
.devrow .dn{width:64px;color:var(--mut);text-transform:capitalize}
.devrow .dbar{flex:1;height:8px;background:var(--surface3);border-radius:5px;overflow:hidden}
.devrow .dbar span{display:block;height:100%;background:linear-gradient(90deg,var(--red),var(--red2));border-radius:5px}
.devrow .dp{width:42px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}

.empty-mini{color:var(--mut2);font-size:13px;padding:18px 0}
.tbadge.actief{color:var(--green);background:color-mix(in srgb,var(--green),transparent 86%);border-color:color-mix(in srgb,var(--green),transparent 64%)}
.tbadge.demo{color:var(--bluetag);background:color-mix(in srgb,var(--bluetag),transparent 86%);border-color:color-mix(in srgb,var(--bluetag),transparent 64%)}
@media(max-width:980px){.kpi-hero{grid-template-columns:1fr 1fr}.mini-kpis{grid-template-columns:1fr 1fr}.dash-grid{grid-template-columns:1fr}}
@media(max-width:560px){.kpi-hero,.mini-kpis{grid-template-columns:1fr}.admin-actions .lbl-hide{display:none}}

/* === Klant-formulier (publieke pagina) === */
body.klant-body{overflow:auto;height:auto;min-height:100%}
.klant-page{min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:40px 20px;background:radial-gradient(700px 380px at 50% -8%,var(--redsoft),transparent 62%)}
.klant-card{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--line2);border-radius:var(--r-xl);padding:36px 36px 32px;box-shadow:0 40px 100px rgba(0,0,0,.5)}
.klant-card .brand{text-align:center;margin-bottom:8px}
.klant-card .brand img{height:42px;margin:0 auto 8px}
.klant-card .brand .sub{color:var(--mut2);font-size:12.5px}
.klant-card h2{font-family:var(--disp);font-size:23px;font-weight:700;text-align:center;margin-top:18px}
.klant-card .intro{color:var(--mut);font-size:14px;text-align:center;margin:8px auto 24px;max-width:90%;line-height:1.5}
.chkrow{display:flex;align-items:center;gap:10px;margin:4px 0 18px;cursor:pointer;font-size:14px;font-weight:500}
.req{color:var(--red2)}

/* ============================================================
   RESPONSIVE / MOBIEL
   ============================================================ */

/* hamburger (alleen zichtbaar onder 880px) + uitschuifbare zijbalk */
.nav-burger{display:none;flex:0 0 auto;width:40px;height:40px;border:1px solid var(--line2);border-radius:10px;background:transparent;position:relative;cursor:pointer}
.nav-burger span{position:absolute;left:11px;right:11px;height:2px;background:var(--tx);border-radius:2px;transition:transform .25s var(--ease),opacity .2s}
.nav-burger span:nth-child(1){top:13px}.nav-burger span:nth-child(2){top:19px}.nav-burger span:nth-child(3){top:25px}
.nav-burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:59;opacity:0;pointer-events:none;transition:opacity .25s}
.nav-backdrop.show{opacity:1;pointer-events:auto}

/* factuur: voorbeeld-overlay */
@media(max-width:1180px){
  .content{grid-template-columns:1fr}
  .preview-pane{display:none}
  .preview-pane.show{display:flex;position:fixed;inset:0;z-index:70;background:rgba(8,8,10,.96);overflow-y:auto;padding:24px 16px 70px}
}
.preview-toggle-btn{display:none}
@media(max-width:1180px){.preview-toggle-btn{display:inline-flex}}

/* tablet & telefoon */
@media(max-width:880px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;bottom:0;left:0;width:272px;max-width:84vw;z-index:60;transform:translateX(-103%);transition:transform .28s var(--ease);box-shadow:24px 0 60px rgba(0,0,0,.45)}
  .sidebar.open{transform:none}
  .nav-burger{display:block}
  .topbar{height:auto;min-height:60px;padding:10px 14px;gap:10px;flex-wrap:wrap}
  .tb-title h1{font-size:17px}
  .tb-actions{flex-wrap:wrap;justify-content:flex-end;row-gap:8px}
  .page{padding:16px 14px 70px}
  .form-pane{padding:16px 14px 70px}
  .grid2,.grid3,.veh-row,.veh-row.three,.veh-row.mm,.veh-row.seg-row,.frow{grid-template-columns:1fr}
  .search{margin-left:0;width:100%;min-width:0}
  .detail-in{grid-template-columns:1fr;padding-left:18px}
  .ftabs{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .ftab{white-space:nowrap}
  .inp,.sel,.search input{font-size:16px} /* voorkomt automatisch inzoomen op iPhone */
  .formcard{padding:18px 16px}
  .logorow{grid-template-columns:1fr}
  .logo-preview{max-width:240px}
  .kdetail{padding:14px 14px 16px}
  .list-hint{display:block;line-height:1.55}
  .list-hint svg{display:inline-block;vertical-align:-2px;margin-right:4px}
  .admin-top-in{height:auto;min-height:56px;flex-wrap:wrap;padding:8px 14px;gap:8px;row-gap:6px}
  .admin-actions{flex-wrap:wrap;row-gap:6px;margin-left:auto;justify-content:flex-end}
  .admin-page{padding:18px 14px 70px}
}

@media(max-width:640px){
  .bedrag-head{display:none}
  .bedrag-row{grid-template-columns:1fr 80px 44px;gap:8px}
  .bedrag-row>.inp:first-child{grid-column:1/-1}
  .add-bar .c-date,.add-bar .c-cat,.add-bar .c-amt{width:auto;flex:1 1 45%}
  .add-bar .c-desc{flex:1 1 100%}
  .subtabs-card .ftabs{flex-wrap:wrap;overflow:visible}
  .subtabs-card .ftab{flex:1 1 45%}
  .exportbar .field{min-width:0;flex:1 1 45%}
  .exportbar{align-items:stretch}
  .frm-actions{flex-wrap:wrap}
  .barchart .bx{display:none}
  .barchart{gap:3px}
  .card-b{padding:16px}
}

@media(max-width:560px){
  .statcard .val{font-size:20px}
  .kpi .kv{font-size:24px}.kpi.feature .kv{font-size:26px}
  .klant-card{padding:26px 20px 24px}
  .tb-actions .btn{padding:8px 11px;font-size:13px}
  .a4{padding:22px 16px;overflow-x:auto}
  .a4-tbl{font-size:9.5px}
  .a4-tbl th,.a4-tbl td{padding:4px 5px}
  .a4-meta{flex-direction:column;gap:12px}
  .a4-meta .klant{min-width:0}
  .a4-tot{width:100%}
  .periodbar{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .ptab{white-space:nowrap}
  .toast{left:14px;right:14px;transform:translateY(20px);max-width:none}
  .toast.show{transform:translateY(0)}
}
/* einde responsive */

/* ============================================================
   Compat-laag voor bestaande HandelWerk-JS (shared.js)
   - toonMelding() richt zich op #melding (.opslag-melding)
   - info-tip tooltips (shared.js bouwt .hw-tooltip)
   Gethemed via app.css-tokens zodat licht/donker meeflipt.
   ============================================================ */
.opslag-melding{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface2);border:1px solid var(--line2);border-radius:12px;padding:13px 20px;font-size:14px;font-weight:500;color:var(--tx);box-shadow:0 16px 44px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:120;max-width:calc(100vw - 28px)}
.opslag-melding.show{opacity:1;transform:translateX(-50%) translateY(0)}
.opslag-melding.error{border-color:var(--redline);color:var(--red2)}
.info-tip{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:50%;border:1px solid var(--line2);color:var(--mut);font-size:10px;font-weight:700;cursor:help;vertical-align:middle;margin-left:4px;font-family:var(--sans)}
.hw-tooltip{position:fixed;z-index:200;background:var(--surface3);color:var(--tx);border:1px solid var(--line2);border-radius:8px;padding:8px 11px;font-size:12.5px;line-height:1.4;max-width:280px;box-shadow:0 10px 30px rgba(0,0,0,.45);pointer-events:none}
.saldo-neg{color:#FF7A7A;font-weight:600}
.statcard.bad .val{color:#FF7A7A}.statcard.bad .lbl .di{background:#FF7A7A}
@media (max-width:880px){.opslag-melding{left:14px;right:14px;transform:translateY(20px);max-width:none}.opslag-melding.show{transform:translateY(0)}}
