  :root{
    --bg:#e6ecf5; --surface:#ffffff; --surface-2:#eef3fa; --surface-3:#e3eaf4;
    --border:#cdd6e4; --text:#0e1a2c; --text-dim:#3e4a61; --text-faint:#6b7689;
    --accent:#1f86d6; --accent-dark:#125a96; --accent-soft:#e1eefb; --navy:#0c2c4f; --navy-soft:#d6e0ec; --sky:#3a9fe0;
    --green:#16a34a; --green-soft:#e6f6ec; --amber:#5d6b80; --amber-soft:#eceff4;
    --red:#dc4f4f; --red-soft:#fbe9e9; --purple:#15639e; --purple-soft:#e3edf7;
    --radius:12px; --shadow:0 6px 24px rgba(22,46,84,.08); --shadow-lg:0 16px 50px rgba(22,46,84,.18);
    font-synthesis:none;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{height:100%}
  body{background:var(--bg);color:var(--text);font-family:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
  ::-webkit-scrollbar{width:10px;height:10px}
  ::-webkit-scrollbar-thumb{background:#d4dbe8;border-radius:10px;border:2px solid var(--bg)}
  ::-webkit-scrollbar-track{background:transparent}

  .app{display:grid;grid-template-columns:236px 1fr;grid-template-rows:62px 1fr;height:100vh;grid-template-areas:"sidebar topbar" "sidebar main"}

  .sidebar{grid-area:sidebar;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
  .brand{display:flex;align-items:center;justify-content:center;padding:18px 16px 14px}
  .brand img,.brand svg{width:100%;max-width:190px;height:auto;display:block}
  .co-id{margin:0 12px 12px;display:flex;align-items:center;gap:10px;padding:9px 11px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px}
  .co-id .c-logo{width:26px;height:26px;border-radius:7px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;background:var(--accent)}
  .co-id b{display:block;font-size:13px;color:var(--text)} .co-id small{color:var(--text-faint);font-size:11px}

  nav.menu{flex:1;overflow-y:auto;padding:4px 12px}
  nav.menu .group-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-faint);padding:14px 10px 6px}
  nav.menu a{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:9px;color:var(--text-dim);text-decoration:none;cursor:pointer;font-weight:500;margin-bottom:2px}
  nav.menu a svg{width:18px;height:18px;flex:0 0 auto}
  nav.menu a:hover{background:var(--surface-2);color:var(--text)}
  nav.menu a.active{background:var(--accent);color:#fff;font-weight:600}
  nav.menu a .badge{margin-left:auto;background:var(--surface-3);color:var(--text-dim);font-size:11px;padding:1px 7px;border-radius:20px;font-weight:600}
  nav.menu a.active .badge{background:rgba(255,255,255,.28);color:#fff}
  nav.menu a .warn-dot{margin-left:auto;width:8px;height:8px;border-radius:50%;background:var(--accent)}

  .sidebar-foot{padding:12px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}
  .avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:#fff}
  .sidebar-foot .u b{display:block;font-size:12px;color:var(--text)} .sidebar-foot .u small{color:var(--text-faint);font-size:11px}

  .topbar{grid-area:topbar;display:flex;align-items:center;gap:16px;padding:0 24px;border-bottom:1px solid var(--border);background:var(--surface);position:relative;z-index:30}
  .notif-panel{position:absolute;top:52px;right:20px;width:350px;max-height:72vh;overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);z-index:60;display:none}
  .notif-panel.open{display:block}
  .notif-panel .nh{padding:13px 15px;border-bottom:1px solid var(--border);font-weight:800;font-size:14px;display:flex;justify-content:space-between;align-items:center}
  .notif-sec{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-faint);font-weight:700;padding:11px 15px 4px;background:var(--surface-2)}
  .notif-item{display:flex;gap:11px;align-items:flex-start;padding:10px 15px;cursor:pointer;border-top:1px solid var(--border)}
  .notif-item:hover{background:var(--surface-2)} .notif-item b{font-size:13px;font-weight:600;display:block} .notif-item small{color:var(--text-faint);font-size:11.5px}
  .notif-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex:0 0 auto}
  .notif-empty{padding:26px 15px;text-align:center;color:var(--text-faint);font-size:13px}
  .topbar h1{font-size:18px;font-weight:700} .topbar .crumb{color:var(--text-faint);font-size:13px}
  .search{margin-left:auto;display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:7px 12px;width:280px}
  .search input{background:none;border:none;color:var(--text);outline:none;width:100%;font-size:13px}
  .search svg{width:15px;height:15px;color:var(--text-faint)}
  .topbar .icon-btn{position:relative;width:36px;height:36px;border-radius:9px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);display:flex;align-items:center;justify-content:center;cursor:pointer}
  .topbar .icon-btn:hover{color:var(--accent);border-color:var(--accent)} .topbar .icon-btn svg{width:18px;height:18px}
  .notif-badge{position:absolute;top:-6px;right:-6px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;background:var(--red,#e23b3b);color:#fff;font-size:10px;font-weight:700;display:none;align-items:center;justify-content:center;line-height:1}
  .notif-badge.show{display:flex}
  .cow-btn{overflow:visible;padding:0} .cow-ico{width:26px;height:26px;object-fit:contain;display:block}

  main{grid-area:main;overflow-y:auto;padding:24px 28px 60px}
  .view{display:none;animation:fade .22s ease} .view.active{display:block}
  @keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
  .page-head{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:20px;gap:14px}
  /* in-content paginatitel verbergen: de titel + subheader staan nu op de bovenbalk (geen dubbele kop).
     detailpagina's (#view-detail) behouden hun .t want daar zit de "Terug"-knop in. */
  .view:not(#view-detail) .page-head > .t{display:none}
  .view:not(#view-detail) .page-head:not(:has(.page-actions)){display:none}
  .page-head .t h2{font-size:24px;font-weight:800;letter-spacing:-.4px;color:var(--text);display:flex;align-items:center;gap:10px;flex-wrap:wrap} .page-head .t p{color:var(--text-dim);font-size:13px;margin-top:2px}
  .page-actions{display:flex;gap:10px;flex-wrap:wrap}
  .back-btn{display:inline-flex;align-items:center;gap:7px;background:none;border:none;color:var(--text-dim);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;padding:0;margin-bottom:10px}
  .back-btn:hover{color:var(--accent)} .back-btn svg{width:15px;height:15px}
  .detail-wrap{max-width:none;display:flex;flex-direction:column;gap:18px}
  .detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 28px}
  .detail-card .section-title:first-of-type{margin-top:0}
  .detail-card>.section-title:first-child{margin-top:0}
  /* slanke workhours-indicator onder de titel, boven het witte veld */
  .wh-strip{display:flex;align-items:center;gap:10px;background:var(--accent-soft);border:1px solid #bfe0f7;color:#13507f;border-radius:10px;padding:10px 14px;margin-bottom:14px;font-size:13px}
  .wh-strip.warn{background:var(--amber-soft);border-color:#cfd6e0;color:var(--amber)}
  .wh-strip svg{width:17px;height:17px;flex:0 0 auto}
  .wh-strip .tag{margin-left:auto;font-size:11px;opacity:.8}

  .btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-weight:600;font-size:13px;cursor:pointer;transition:.15s;font-family:inherit}
  .btn:hover{border-color:var(--accent);color:var(--accent-dark)} .btn svg{width:16px;height:16px}
  .btn.primary{background:var(--accent);border-color:var(--accent);color:#fff} .btn.primary:hover{background:var(--accent-dark);color:#fff}
  .btn.ghost{background:transparent} .btn.sm{padding:6px 11px;font-size:12px}

  .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
  .stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
  .stat .label{color:var(--text-dim);font-size:12px;font-weight:600;display:flex;align-items:center;gap:10px}
  .stat .ico{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff} .stat .ico svg{width:19px;height:19px}
  .stat .val{font-size:28px;font-weight:800;margin-top:12px;color:var(--text);letter-spacing:-.5px}
  .stat .sub{font-size:12px;color:var(--text-faint);margin-top:3px;font-weight:500} .stat .sub.up{color:var(--green)} .stat .sub.down{color:var(--red)}

  .grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:18px}
  .panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
  .panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface-2)}
  .panel-head h3{font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.2px} .panel-head a{color:var(--accent-dark);font-size:12px;font-weight:600;text-decoration:none;cursor:pointer}
  .panel-body{padding:4px 0}

  .search-line{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 13px;margin-bottom:10px;max-width:420px}
  .search-line svg{width:15px;height:15px;color:var(--text-faint);flex:0 0 auto}
  .search-line input{border:none;background:none;outline:none;color:var(--text);font-size:13px;width:100%;font-family:inherit}
  .toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
  .toolbar input{flex:1 1 240px;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 12px;color:var(--text);font-size:13px;font-family:inherit;outline:none}
  .toolbar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
  .filters{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:3px;flex-wrap:wrap}
  .filters button{padding:6px 12px;border:none;background:none;color:var(--text-dim);border-radius:7px;cursor:pointer;font-size:12px;font-weight:600;font-family:inherit}
  .filters button.active{background:var(--accent-soft);color:var(--accent-dark)}
  th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
  th.sortable:hover{color:var(--text)}
  th.sortable .sort-arrow{font-size:10px;opacity:.35;margin-left:3px}
  th.sortable.active .sort-arrow{opacity:1;color:var(--accent)}

  table{width:100%;border-collapse:collapse}
  thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);font-weight:600;padding:11px 18px;border-bottom:1px solid var(--border);white-space:nowrap}
  tbody td{padding:14px 18px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
  tbody tr{cursor:pointer;transition:background .12s} tbody tr:hover{background:var(--surface-2)}
  tbody tr:last-child td{border-bottom:none}
  td .doc-id{font-weight:600;color:var(--text)} td .muted{color:var(--text-faint);font-size:12px}
  td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
  .client-cell{display:flex;align-items:center;gap:10px}
  .client-cell .ci{width:28px;height:28px;border-radius:7px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}

  .badge-status{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;white-space:nowrap}
  .badge-status::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
  .s-concept{background:var(--surface-3);color:var(--text-dim)}
  .s-verzonden{background:var(--accent-soft);color:var(--accent-dark)}
  .s-aanvaard,.s-betaald,.s-afgerond{background:var(--green-soft);color:var(--green)}
  .s-geweigerd,.s-teveroren{background:var(--red-soft);color:var(--red)}
  .s-verlopen,.s-open{background:var(--amber-soft);color:var(--amber)}
  .s-deels,.s-inproductie{background:var(--purple-soft);color:var(--purple)}

  .pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;padding:3px 9px;border-radius:7px;background:var(--surface-3);color:var(--text-dim);font-weight:600}
  .pill svg{width:12px;height:12px}
  .pill.peppol{background:var(--purple-soft);color:var(--purple)} .pill.email{background:var(--accent-soft);color:var(--accent-dark)}
  .pill.warn{background:var(--amber-soft);color:var(--amber)} .pill.hours{background:var(--accent-soft);color:var(--accent-dark)}

  .pbar{height:6px;background:var(--surface-3);border-radius:6px;overflow:hidden;min-width:84px}
  .pbar i{display:block;height:100%;background:var(--purple);border-radius:6px}

  .timeline{padding:8px 18px 14px} .tl-item{display:flex;gap:12px;padding:9px 0}
  .tl-item .dot{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:0 0 auto;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
  .tl-item .dot.green{background:var(--green);box-shadow:0 0 0 4px var(--green-soft)}
  .tl-item .dot.purple{background:var(--purple);box-shadow:0 0 0 4px var(--purple-soft)}
  .tl-item .dot.amber{background:var(--amber);box-shadow:0 0 0 4px var(--amber-soft)}
  .tl-item .c b{font-weight:600;font-size:13px} .tl-item .c small{display:block;color:var(--text-faint);font-size:11px;margin-top:1px}

  .funnel{display:flex;flex-direction:column;gap:10px;padding:16px 18px}
  .funnel .step{display:flex;align-items:center;gap:12px}
  .funnel .step .bar{flex:1;height:32px;border-radius:8px;display:flex;align-items:center;padding:0 12px;font-size:12px;font-weight:600;color:#fff}
  .funnel .step .cnt{width:42px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}

  .alert{display:flex;gap:13px;align-items:flex-start;background:var(--amber-soft);border:1px solid #cfd6e0;border-radius:12px;padding:14px 16px;margin-bottom:20px}
  .alert .ai{flex:0 0 auto;color:var(--amber)} .alert .ai svg{width:20px;height:20px}
  .alert b{font-size:13px} .alert .links{margin-top:6px;display:flex;flex-direction:column;gap:4px}
  .alert .links a{color:var(--accent-dark);font-size:12.5px;cursor:pointer;text-decoration:none;font-weight:600}
  .alert .links a:hover{text-decoration:underline}
  .alert.blue{background:var(--accent-soft);border-color:#bfe0f7} .alert.blue .ai{color:var(--accent)} .alert.blue b{color:#13507f}

  .overlay{position:fixed;inset:0;background:rgba(20,34,60,.42);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;z-index:100;padding:40px 20px;overflow-y:auto}
  .overlay.open{display:flex}
  .modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:780px;animation:pop .2s ease}
  .modal.wide{max-width:940px} .modal.narrow{max-width:520px}
  @keyframes pop{from{opacity:0;transform:scale(.97) translateY(8px)}to{opacity:1;transform:none}}
  .modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}
  .modal-head h3{font-size:17px;font-weight:700;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
  .modal-head .x{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
  .modal-head .x:hover{color:var(--text)}
  .modal-body{padding:22px} .modal-foot{padding:16px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}

  .doc{background:#fff;color:#1d2330;border:1px solid var(--border);border-radius:10px;padding:36px 40px;font-size:13px;box-shadow:var(--shadow)}
  .doc .d-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:26px;padding-bottom:18px;border-bottom:2px solid var(--accent)}
  .doc .d-head .logo{font-size:20px;font-weight:800;color:#1b2536}
  .doc .d-head .logo small{display:block;font-size:11px;font-weight:500;color:#7a8294;margin-top:3px;line-height:1.6}
  .doc .d-title{text-align:right} .doc .d-title h1{font-size:26px;letter-spacing:1px;color:var(--accent);text-transform:uppercase}
  .doc .d-title .num{color:#1b2536;font-weight:700;margin-top:2px}
  .doc .d-parties{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:24px}
  .doc .d-parties .lbl{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#9aa3b5;margin-bottom:5px}
  .doc .d-parties b{font-size:14px} .doc .d-parties p{color:#4a5568;font-size:12px;line-height:1.6}
  .doc .betreft{background:var(--accent-soft);padding:11px 15px;border-radius:8px;margin-bottom:18px;color:#1b2536}
  .doc .d-body{font-size:13px;color:#2b313f;line-height:1.7}
  .doc .d-body h1,.doc .d-body h2,.doc .d-body h3{color:#1b2536;margin:14px 0 8px} .doc .d-body h2{font-size:18px} .doc .d-body h3{font-size:15px}
  .doc .d-body p{margin:8px 0} .doc .d-body ul,.doc .d-body ol{margin:8px 0 8px 22px} .doc .d-body li{margin:3px 0}
  .doc table.lines{width:100%;border-collapse:collapse;margin:10px 0 4px}
  .doc table.lines th{background:var(--surface-3);color:#5a6276;font-size:10px;text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:9px 10px}
  .doc table.lines th.r,.doc table.lines td.r{text-align:right}
  .doc table.lines td{padding:10px;border-bottom:1px solid #e7ebf2;font-size:12.5px;color:#2b313f}
  .doc .totals{margin-left:auto;width:280px;margin-top:18px}
  .doc .totals .row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:#4a5568}
  .doc .totals .row.grand{border-top:2px solid var(--accent);margin-top:6px;padding-top:10px;font-size:17px;font-weight:800;color:#1b2536}
  .doc .d-foot{margin-top:28px;padding-top:16px;border-top:1px solid #e7ebf2;color:#7a8294;font-size:11px;line-height:1.7;display:flex;justify-content:space-between;gap:20px}
  /* professionele factuur (logokleuren, geen vakjes) */
  .doc.invoice{padding:40px 44px}
  .doc .iv-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;padding-bottom:14px;border-bottom:3px solid #3f7fd6}
  .doc .iv-contact{display:grid;grid-template-columns:max-content max-content;column-gap:10px;row-gap:6px;align-content:start;font-size:14.5px;color:#3f7fd6}
  .doc .iv-contact .l{font-weight:700}
  .doc .iv-contact .v{color:#1b2536;font-weight:600;white-space:nowrap}
  .doc .iv-title{display:flex;justify-content:space-between;align-items:flex-end;margin:20px 0 16px}
  .doc .iv-title h1{font-size:32px;letter-spacing:3px;color:#3f7fd6;text-transform:uppercase;font-weight:800;line-height:1}
  .doc .iv-title .num{color:#1b2536;font-weight:700;font-size:15px;margin-top:6px}
  .doc .iv-title .pd{text-align:right;color:#5a6478;font-size:12.5px;line-height:1.6}
  .doc .iv-meta{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:20px}
  .doc .iv-panel{background:#eef5fd;border-left:3px solid #3f7fd6;border-radius:0 8px 8px 0;padding:13px 16px}
  .doc .iv-panel .lbl{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#3f7fd6;font-weight:800;margin-bottom:6px}
  .doc .iv-panel b{font-size:14px;color:#1b2536}
  .doc .iv-panel p{color:#41506a;font-size:12.5px;line-height:1.65;margin-top:3px}
  .doc .iv-panel .kv{display:grid;grid-template-columns:96px 1fr;gap:3px 8px;font-size:12.5px;color:#41506a}
  .doc .iv-panel .kv b{font-size:12.5px}
  /* documenthoofd in Talsoft-template-stijl (offerte/factuur) — kleuren uit template_offerte.xlsx
     2-koloms raster: links (logo/adres/Aan) eindigt op dezelfde lijn; rechts (contact/titelkader) begint op dezelfde lijn */
  .doc .tdoc-row{display:grid;grid-template-columns:1fr 320px;column-gap:30px;align-items:start}
  .doc .tdoc-left{grid-column:1}
  /* logo: vult de kolom, witruimte boven/onder weggesneden (beeld is 1,93:1, grafiek zit als smalle band centraal) */
  .doc .tdoc-logo{width:100%;max-width:380px;aspect-ratio:4.77/1;object-fit:cover;object-position:center;display:block;margin:-2px 0 0 -10px}
  .doc .tdoc-contact{grid-column:2;display:grid;grid-template-columns:max-content 1fr;column-gap:10px;row-gap:5px;font-size:13px;color:#1F86D6;font-weight:600;align-content:start;padding-top:4px}
  .doc .tdoc-contact .l{font-weight:700}
  .doc .tdoc-addr{text-align:right;max-width:380px;color:#1F86D6;font-weight:700;font-size:13.5px;margin:1px 0 0}
  .doc .tdoc-rule{height:3px;background:#1565AD;border-radius:2px;margin:9px 0 16px}
  .doc .tdoc-meta{align-items:stretch}
  .doc .tdoc-aan{grid-column:1;max-width:380px;border:1px solid #cfd9e6;border-radius:4px;padding:13px 16px;font-size:14.5px;color:#1b2536}
  .doc .tdoc-aan-rows{display:grid;grid-template-columns:max-content 1fr;gap:5px 14px;align-items:baseline}
  .doc .tdoc-aan-rows .lbl{color:#1F86D6;font-weight:700;white-space:nowrap}
  .doc .tdoc-aan-rows .v{color:#1b2536}
  .doc .tdoc-aan-rows b{font-size:15.5px}
  .doc .tdoc-aan-rows .addr-row{margin-top:8px}
  .doc .tdoc-rightbox{grid-column:2;align-self:start;display:flex;flex-direction:column;gap:10px}
  .doc .tdoc-title{border:2.5px solid #1F86D6;border-radius:3px;color:#1565AD;font-size:26px;font-weight:800;letter-spacing:1.5px;text-align:center;padding:9px 0}
  .doc .tdoc-details{border:1px solid #cfd9e6;border-radius:4px;display:grid;grid-template-columns:max-content 1fr;gap:6px 14px;padding:12px 16px;font-size:13px}
  .doc .tdoc-details .lbl{color:#1F86D6;font-weight:700;white-space:nowrap}
  .doc .tdoc-details .val{color:#1b2536;font-weight:600}
  .doc table.lines.blue th{background:#1565AD;color:#fff}
  /* factuurlijnen lichtblauw (zoals de tandwielen in het logo) */
  .doc table.lines.blue tbody td{background:#e9f2fc;border-bottom:1px solid #d3e6f9}
  .doc table.lines.blue tbody tr:last-child td{border-bottom:1px solid #bcd9f3}
  .doc .iv-foot{margin-top:26px;padding-top:14px;border-top:2px solid #3f7fd6;display:flex;justify-content:space-between;gap:24px;font-size:11.5px;color:#5a6478;line-height:1.7}
  .doc .iv-foot b{color:#1b2536}

  .field{margin-bottom:16px}
  .field label{display:block;font-size:12px;color:var(--text-dim);margin-bottom:6px;font-weight:600}
  .field input,.field select,.field textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:10px 12px;color:var(--text);font-size:13px;font-family:inherit;outline:none}
  .field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
  .field input[readonly]{background:var(--surface-2);color:var(--text);cursor:default;border-style:dashed}
  .dfi{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:9px 11px;font-family:inherit;font-size:13px;color:var(--text)}
  .dfi[readonly],select.dfi:disabled{background:var(--surface-2);border-style:dashed;cursor:default;color:var(--text);opacity:1}
  .dfi:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}
  .quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:22px}
  .qbtn{display:flex;align-items:center;gap:16px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:22px 24px;cursor:pointer;text-align:left;transition:.15s;font-family:inherit;box-shadow:var(--shadow)}
  .qbtn:hover{border-color:var(--accent);box-shadow:0 8px 22px rgba(12,44,79,.18);transform:translateY(-2px)}
  .qbtn .qbtn-ic{width:56px;height:56px;border-radius:15px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
  .qbtn .qbtn-ic svg{width:29px;height:29px}
  .qbtn b{display:block;font-size:15.5px;color:var(--text)}
  .qbtn span{font-size:12.5px;color:var(--text-dim)}
  .field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px} .field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
  .hint{font-size:11px;color:var(--text-faint);margin-top:5px}

  .rt-toolbar{display:flex;gap:3px;flex-wrap:wrap;background:var(--surface-2);border:1px solid var(--border);border-bottom:none;border-radius:9px 9px 0 0;padding:6px 8px}
  .rt-toolbar button{min-width:30px;height:28px;padding:0 8px;border:1px solid transparent;background:none;border-radius:6px;cursor:pointer;color:var(--text-dim);font-size:13px;font-family:inherit}
  .rt-toolbar button:hover{background:var(--surface-3);color:var(--text)} .rt-toolbar .sep{width:1px;background:var(--border);margin:3px 4px}
  .rt-editor{min-height:220px;max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:0 0 9px 9px;padding:18px 20px;background:#fff;font-size:13.5px;line-height:1.7;color:#1d2330;outline:none}
  .rt-editor:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
  .rt-editor h2{font-size:18px;margin:12px 0 8px} .rt-editor h3{font-size:15px;margin:10px 0 6px}
  .rt-editor p{margin:8px 0} .rt-editor ul,.rt-editor ol{margin:8px 0 8px 22px}
  .rt-editor h1{font-size:21px;margin:14px 0 8px} .rt-editor blockquote{border-left:3px solid var(--accent);margin:8px 0;padding:4px 14px;color:var(--text-dim)} .rt-editor a{color:var(--accent);text-decoration:underline}
  .rt-toolbar select.rt-sel{height:28px;border:1px solid var(--border);background:var(--surface);border-radius:6px;font-size:12px;color:var(--text);padding:0 6px;cursor:pointer;font-family:inherit}
  .rt-toolbar .rt-color{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:28px;border:1px solid transparent;border-radius:6px;cursor:pointer;color:var(--text-dim);font-size:13px;font-weight:700}
  .rt-toolbar .rt-color:hover{background:var(--surface-3);color:var(--text)} .rt-toolbar .rt-color input{position:absolute;left:4px;right:4px;bottom:3px;height:3px;width:auto;padding:0;border:none;background:none;cursor:pointer}
  .rt-toolbar button svg{width:15px;height:15px;vertical-align:middle;pointer-events:none}

  .dropzone{border:2px dashed var(--border);border-radius:11px;padding:26px 20px;text-align:center;color:var(--text-faint);cursor:pointer;background:var(--surface-2);transition:.15s}
  .dropzone:hover{border-color:var(--accent);color:var(--accent-dark);background:var(--accent-soft)}
  .dropzone.has{border-style:solid;border-color:var(--green);background:var(--green-soft);color:var(--text)}
  .dropzone svg{width:26px;height:26px;margin-bottom:8px}
  .dropzone b{display:block;font-size:13px}

  .totals-box{margin-left:auto;width:280px;margin-top:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
  .totals-box .row{display:flex;justify-content:space-between;padding:5px 0;color:var(--text-dim);font-size:13px}
  .totals-box .row.grand{border-top:2px solid var(--accent);margin-top:6px;padding-top:9px;font-weight:800;font-size:17px;color:var(--text)}

  .info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 26px}
  .info-grid .k{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}
  .info-grid .v{font-size:14px;font-weight:600;margin-top:2px}
  .info-grid .v input,.info-grid .v select,.info-grid .v textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);font-size:13px;font-family:inherit;font-weight:500;outline:none}
  .info-grid .v input:focus,.info-grid .v select:focus,.info-grid .v textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
  .info-grid .v input[readonly]{background:var(--surface-2);border-style:dashed;cursor:default}
  .edit-input{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:7px 10px;color:var(--text);font-size:14px;font-family:inherit;outline:none}
  .edit-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
  .section-title{font-size:12px;text-transform:uppercase;letter-spacing:.7px;color:var(--text-faint);font-weight:700;margin:24px 0 12px}
  .callout{border-radius:10px;padding:12px 14px;font-size:13px;display:flex;gap:10px;align-items:flex-start}
  .callout.amber{background:var(--amber-soft);border:1px solid #cfd6e0;color:var(--amber)}
  .callout.blue{background:var(--accent-soft);border:1px solid #bfe0f7;color:#13507f}
  .callout svg{width:17px;height:17px;flex:0 0 auto;margin-top:1px}

  .toast-wrap{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:200}
  .toast{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:10px;padding:13px 16px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:11px;min-width:300px;animation:slidein .25s ease}
  .toast.info{border-left-color:var(--accent)} .toast.peppol{border-left-color:var(--purple)} .toast.warn{border-left-color:var(--amber)}
  .toast svg{width:18px;height:18px;flex:0 0 auto} .toast b{font-size:13px} .toast small{display:block;color:var(--text-faint);font-size:11px}
  @keyframes slidein{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}

  .empty{text-align:center;padding:50px 20px;color:var(--text-faint)}
  .empty svg{width:42px;height:42px;opacity:.4;margin-bottom:10px}
  .linkcard{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;cursor:pointer}
  .linkcard:hover{border-color:var(--accent)} .linkcard.static{cursor:default}
  .linkcard.static:hover{border-color:var(--border)}
  .linkcard .ic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex:0 0 auto} .linkcard .ic svg{width:17px;height:17px}
  .linkcard b{font-size:13px} .linkcard small{display:block;color:var(--text-faint);font-size:11px} .linkcard .arr{margin-left:auto;color:var(--text-faint)}
  .chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}

  /* uitklapbare gekoppelde documenten */
  .exgroup{margin-bottom:8px}
  .linkcard .chev{margin-left:auto;color:var(--text-faint);transition:transform .2s;font-size:13px}
  .linkcard.open .chev{transform:rotate(90deg);color:var(--accent)}
  .linkcard.open{border-color:var(--accent);border-bottom-left-radius:0;border-bottom-right-radius:0;background:var(--accent-soft)}
  .exbody{border:1px solid var(--accent);border-top:none;border-radius:0 0 10px 10px;padding:16px;background:var(--surface);animation:fade .2s ease}
  .exbody .info-grid{gap:10px 20px}
  .exbody .section-title:first-child{margin-top:0}
  .exbody .doc{padding:24px 26px}

  /* inklapbare sectie (bv. documentvoorbeeld) */
  .collapse-head{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:11px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px}
  .collapse-head:hover{border-color:var(--accent)}
  .collapse-head .section-title{margin:0!important}
  .collapse-head .chev{color:var(--text-faint);transition:transform .2s;font-size:13px}
  .collapse-head.open .chev{transform:rotate(90deg);color:var(--accent)}
  .collapse-head.open{border-color:var(--accent);border-bottom-left-radius:0;border-bottom-right-radius:0;background:var(--accent-soft)}

  /* PDF-viewer met interne scroll (geüploade bestelbon) */
  .pdf-bar{display:flex;align-items:center;justify-content:space-between;background:var(--surface-3);border:1px solid var(--border);border-bottom:none;border-radius:8px 8px 0 0;padding:7px 12px;font-size:12px;color:var(--text-dim);font-weight:600}
  .pdf-bar .r{display:flex;align-items:center;gap:10px}
  .pdf-bar .lnk{color:var(--accent);cursor:pointer}
  .pdf-viewer{max-height:440px;overflow-y:auto;background:#5b6273;border:1px solid var(--border);border-radius:0 0 8px 8px;padding:16px;display:flex;flex-direction:column;gap:14px}
  .pdf-viewer::-webkit-scrollbar-thumb{background:#3f4555}
  .pdf-page{background:#fff;color:#1d2330;border-radius:3px;box-shadow:0 4px 16px rgba(0,0,0,.35);padding:30px 34px;font-size:12px;line-height:1.6;flex:0 0 auto}
  .pdf-page .pp-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #1d2330;padding-bottom:12px;margin-bottom:14px}
  .pdf-page .pp-head .b{font-size:15px;font-weight:800} .pdf-page .pp-head small{color:#7a8294;font-size:10.5px}
  .pdf-page h4{font-size:20px;letter-spacing:1px;text-transform:uppercase;color:#1d2330;text-align:right}
  .pdf-page table{width:100%;border-collapse:collapse;margin:10px 0}
  .pdf-page table th{background:#eef1f7;text-align:left;font-size:10px;text-transform:uppercase;color:#5a6276;padding:7px 9px}
  .pdf-page table td{padding:8px 9px;border-bottom:1px solid #e7ebf2}
  .pdf-page table .r{text-align:right}
  .pdf-page .pp-num{text-align:center;color:#a6adba;font-size:10px;margin-top:18px;border-top:1px solid #eef1f7;padding-top:8px}
  .pdf-page .sign{display:flex;justify-content:space-between;margin-top:34px;gap:30px}
  .pdf-page .sign div{flex:1} .pdf-page .sign .line{border-top:1px solid #1d2330;margin-top:34px;padding-top:5px;font-size:10.5px;color:#7a8294}

  /* klant-filter */
  .sel-filter{background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:7px 12px;color:var(--text);font-size:12px;font-weight:600;font-family:inherit;outline:none;cursor:pointer}
  .sel-filter:focus{border-color:var(--accent)}

  /* offerte-/bestelling-picker rijen (multi-select) */
  .qp-row{display:flex;align-items:flex-start;gap:11px;padding:10px 12px;border:1px solid var(--border);border-radius:9px;margin-bottom:6px;background:var(--surface)}
  /* factuur-editor: bestellingenlijst toont ±3 stuks en scrollt voor de rest */
  .ie-orders-scroll{max-height:220px;overflow-y:auto;padding-right:5px;margin-bottom:4px}
  .qp-row.linked{background:var(--amber-soft);border-color:#cfd6e0}
  .qp-row.sel{border-color:var(--accent);background:var(--accent-soft)}
  .qp-linkhead{font-size:11px;font-weight:700;color:var(--amber);margin-bottom:4px;display:flex;align-items:center;gap:5px}
  .qp-row>input[type=checkbox],.qp-row>input[type=radio]{width:16px;height:16px;margin-top:2px;flex:0 0 auto;accent-color:var(--accent);cursor:pointer}
  .qp-main{flex:1;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;cursor:pointer}
  .qp-main .chev{color:var(--text-faint);font-size:11px;font-weight:600;white-space:nowrap;transition:transform .2s}
  .qp-main.open .chev{color:var(--accent)}
  /* klantrij met bewerk-knoppen */
  .kl-row{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:10px;background:var(--surface);margin-bottom:8px;padding-right:10px}
  .kl-row .kl-main{flex:1;display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;min-width:0}
  .kl-row .kl-main .chev{margin-left:auto;color:var(--text-faint);transition:transform .2s;font-size:13px}
  .kl-row .kl-main.open .chev{transform:rotate(90deg);color:var(--accent)}
  .kl-actions{display:flex;gap:6px;flex:0 0 auto}
  .btn.danger{color:var(--red);border-color:var(--red-soft)} .btn.danger:hover{border-color:var(--red);color:var(--red)}
  .btn.edit{background:#1e90ff;border-color:#1e90ff;color:#fff} .btn.edit:hover{background:#1577d2;border-color:#1577d2;color:#fff}
  .dl-btn{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--accent-dark);background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:5px 10px;cursor:pointer}
  .dl-btn:hover{border-color:var(--accent);background:var(--accent-soft)}
  .ico-act{width:30px;height:30px;border:1px solid var(--border);background:var(--surface);border-radius:7px;color:var(--text-dim);cursor:pointer;margin-left:6px;vertical-align:middle}
  .ico-act svg{width:15px;height:15px}
  .ico-act:hover{border-color:var(--accent);color:var(--accent)} .ico-act.del:hover{border-color:var(--red);color:var(--red)}

  /* virtual scrolling — enkel de zichtbare rijen, scrollt mee met de paginascroll (geen interne scrollbalk) */
  .vt-scroll{overflow:visible}
  .vt-scroll table{width:100%}
  .vt-scroll thead th{position:sticky;top:0;z-index:2;background:var(--surface-2)}
  .vt-scroll tr.vt-pad{cursor:default}
  .vt-scroll tr.vt-pad td{padding:0;border:none}
  /* filterrij in tabelkop (dashboard) */
  .filter-row th{padding:6px 10px;background:var(--surface);border-bottom:1px solid var(--border);font-weight:400}
  .filter-row select{cursor:pointer}

  /* combobox — type-en-filter keuzeveld (vervangt elke <select>) */
  .combo{position:relative;flex:1 1 auto;min-width:0;display:block}
  /* basis-stijl zodat élke dropdown (ook zonder eigen class) er als een net invoerveld uitziet */
  .combo-input{width:100%;cursor:text;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:10px 12px;color:var(--text);font-size:13px;font-family:inherit;outline:none}
  .combo-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
  .combo-input.dfi{border-radius:8px;padding:9px 11px}
  .combo-input:disabled{cursor:default;background:var(--surface-2);border-style:dashed;color:var(--text);opacity:1}
  /* inline (niet in een formulierveld): niet volle breedte rekken */
  .combo.combo-inline{display:inline-block;flex:0 0 auto;width:auto;vertical-align:middle}
  .combo-input.sel-filter{width:200px;max-width:50vw;padding:8px 12px;font-size:12px;font-weight:600}
  .combo-input.combo-compact{width:130px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:6px 9px;font-size:12px;color:var(--text);font-family:inherit}
  .combo-menu{position:absolute;left:0;right:0;top:calc(100% + 3px);z-index:90;background:var(--surface);border:1px solid var(--border);
    border-radius:9px;box-shadow:var(--shadow-lg);max-height:240px;overflow:auto;display:none;padding:4px}
  .combo-menu.open{display:block}
  .combo-opt{padding:8px 10px;font-size:13px;border-radius:6px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .combo-opt:hover{background:var(--accent-soft);color:var(--accent-dark)}
  .combo-opt.sel{background:var(--surface-2);font-weight:600}
  .combo-opt.muted{color:var(--text-faint);cursor:default}

  /* hamburger — enkel zichtbaar op smal scherm */
  .hamburger{display:none;width:38px;height:38px;border-radius:9px;background:var(--surface-2);border:1px solid var(--border);align-items:center;justify-content:center;cursor:pointer;color:var(--text-dim);margin-right:6px;flex:0 0 auto}
  .hamburger svg{width:20px;height:20px}
  .nav-scrim{display:none;position:fixed;inset:0;background:rgba(10,20,35,.45);z-index:150}
  .nav-scrim.open{display:block}

  @media(max-width:1100px){.stats{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}

  @media(max-width:820px){
    .app{grid-template-columns:1fr;grid-template-areas:"topbar" "main"}
    /* zijbalk wordt een uitschuifbaar paneel */
    .sidebar{position:fixed;top:0;left:0;bottom:0;width:250px;z-index:200;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}
    .sidebar.open{transform:none}
    .hamburger{display:inline-flex}
    main{padding:16px 14px 60px}
    .page-head{flex-direction:column;align-items:stretch;gap:10px}
    .page-head .t h2{font-size:20px}
    .page-actions{display:flex;flex-wrap:wrap;gap:8px}
    .quick-actions{grid-template-columns:1fr}
    .stats{grid-template-columns:1fr}
    .grid-2{grid-template-columns:1fr}
    .field-row,.field-row-3{grid-template-columns:1fr;display:grid;gap:0}
    .info-grid{grid-template-columns:1fr}
    /* brede tabellen mogen horizontaal scrollen i.p.v. persen */
    .panel{overflow-x:auto;overflow-y:visible}
    .panel table{min-width:600px}
    .detail-wrap{max-width:none}
    .detail-card{padding:16px}
    .modal{width:calc(100vw - 20px);max-width:none}
    .notif-panel{right:8px;left:8px;width:auto;top:60px}
    .toolbar{flex-direction:column;align-items:stretch;gap:10px}
    .topbar h1{font-size:17px}
    .doc.invoice,.doc{padding:22px 18px}
    .iv-top{flex-direction:column;gap:12px}
    .iv-meta{grid-template-columns:1fr}
    .doc .tdoc-row{grid-template-columns:1fr;row-gap:10px}
    .doc .tdoc-contact,.doc .tdoc-rightbox,.doc .tdoc-aan{grid-column:1}
    .doc .tdoc-logo{max-width:280px}
  }
  @media(max-width:480px){
    .quick-actions .qbtn{padding:16px 16px}
    .stat .val{font-size:24px}
  }

  /* toegewezen-gebruikers keuzelijst (projectformulier) */
  .chk-list{display:flex;flex-wrap:wrap;gap:8px 16px;padding:8px 2px}
  .chk{display:flex;align-items:center;gap:6px;font-size:13.5px;cursor:pointer;white-space:nowrap}
  .chk input{width:16px;height:16px;cursor:pointer}
