﻿:root{
  --navy:#0f2744;--navy-mid:#1a3c6e;--navy-light:#2952a3;
  --gold:#f0c800;--gold-light:#fffbeb;--gold-border:#f5d840;
  --green:#16a34a;--green-light:#f0fdf4;
  --red:#dc2626;--red-light:#fef2f2;
  --orange:#e07b30;--orange-light:#fff3e8;
  --blue:#1e3a7a;--blue-mid:#2952a3;--blue-light:#dbeafe;--blue-pale:#f0f6ff;
  --gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;
  --gray-400:#9ca3af;--gray-600:#4b5563;--gray-800:#1f2937;
  --bg:#f0f3f9;--surface:#fff;--surface2:#f8f9fc;
  --border:#dde3ef;--border-strong:#c5cde0;
  --text:#0f2744;--text-mid:#3d5177;--text-soft:#7a8ba8;
  --shadow:0 2px 12px rgba(15,39,68,.08);--shadow-lg:0 8px 32px rgba(15,39,68,.16);
  --radius:12px;--radius-sm:8px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
button,input,select,textarea{font-family:inherit;font-size:inherit}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.6}
.screen{display:none;min-height:100vh;flex-direction:column}
.screen.active{display:flex}
#s-login.active{display:flex}

/* ── LOGIN ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);padding:20px}
.login-box{background:white;border-radius:16px;padding:32px 28px;width:100%;max-width:360px;box-shadow:var(--shadow-lg)}
.login-logo-wrap{text-align:center;margin-bottom:12px}
.login-logo-box{width:110px;height:110px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center}
.login-logo{width:100%;height:100%;object-fit:contain;display:block;transform:scale(1.42);transform-origin:center}
.login-company{font-size:12px;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.1em;margin-top:10px}
.login-title{font-size:20px;font-weight:700;color:var(--navy);margin-top:4px}
.login-field{margin-bottom:14px}
.login-field label{display:block;font-size:12px;font-weight:600;color:var(--text-mid);margin-bottom:5px}
.login-field input{width:100%;padding:11px 14px;font-size:15px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Inter',sans-serif;outline:none;transition:border-color .15s}
.login-field input:focus{border-color:var(--navy-mid);box-shadow:0 0 0 3px rgba(26,60,110,.1)}
.login-err{background:var(--red-light);color:var(--red);font-size:12px;font-weight:600;padding:8px 12px;border-radius:6px;margin-bottom:12px;display:none}
.login-btn{width:100%;padding:13px;border:none;border-radius:var(--radius-sm);background:var(--navy);color:white;font-family:'Inter',sans-serif;font-size:15px;font-weight:700;cursor:pointer;margin-top:4px}
.login-btn:hover{background:var(--navy-light)}

/* ── TOPBAR ── */
.topbar{background:var(--navy);color:white;padding:44px 16px 12px;position:sticky;top:0;z-index:100;box-shadow:0 2px 16px rgba(15,39,68,.3)}
.topbar-inner{display:flex;align-items:center;gap:10px}
.topbar h1{font-size:17px;font-weight:700;flex:1;letter-spacing:-.01em}
.topbar .sub{font-size:11px;opacity:.55;margin-top:1px}
.back-btn{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);border:none;color:white;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.logo-sm{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.logo-dwv{background:var(--gold);color:var(--navy)}
.logo-bbl{background:var(--gold);color:var(--navy)}
.prog-bar{height:3px;background:rgba(255,255,255,.15);margin-top:10px;border-radius:2px;overflow:hidden}
.prog-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .4s}
.topbar-right{display:flex;align-items:center;gap:8px}
.user-pill{background:rgba(255,255,255,.12);border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;cursor:pointer}

/* ── HOME ── */
.home-hdr{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);padding:52px 20px 28px;color:white;position:relative;overflow:hidden}
.home-hdr::before{content:'';position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:rgba(232,160,32,.12)}
.home-logo-row{display:flex;align-items:center;gap:16px;margin-bottom:14px;position:relative;z-index:1}
.home-logo{width:56px;height:56px;border-radius:14px;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--navy);flex-shrink:0;box-shadow:0 4px 14px rgba(232,160,32,.4)}
.home-company{font-size:11px;font-weight:600;letter-spacing:.1em;opacity:.6;text-transform:uppercase;margin-bottom:3px}
.home-title{font-size:22px;font-weight:700}
.home-user-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border-radius:20px;padding:5px 12px;font-size:12px;margin-top:10px;position:relative;z-index:1}
.home-content{padding:16px;flex:1;display:flex;flex-direction:column;gap:12px}
.module-card{background:white;border-radius:var(--radius);box-shadow:0 2px 12px rgba(15,39,68,.08);padding:14px 14px 12px;overflow:hidden}
.home-section-label{font-size:14px;font-weight:700;color:var(--navy);letter-spacing:.01em;margin:0 0 12px;padding-bottom:10px;border-bottom:1.5px solid var(--gray-100)}
.module-card .big-btn{margin-bottom:8px}
.sec-row{display:flex;flex-direction:column;gap:8px}
.mini-btn{padding:13px 14px;border:none;border-radius:var(--radius-sm);color:white;font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;text-align:left;display:flex;align-items:center;gap:10px;box-shadow:0 2px 8px rgba(15,39,68,.12);transition:transform .12s;width:100%}
.mini-btn:active{transform:scale(.98)}
.mini-btn .m-ico{font-size:18px;flex-shrink:0}
.mini-btn .m-txt{flex:1;min-width:0}
.mini-btn .m-lbl{display:block;font-size:13px;font-weight:600;line-height:1.2}
.mini-btn .m-sub{display:block;font-size:11px;opacity:.7;font-weight:400;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.big-btn{width:100%;padding:16px 18px;border:none;border-radius:var(--radius);color:white;font-size:15px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;text-align:left;display:flex;align-items:center;gap:14px;margin-bottom:10px;box-shadow:0 3px 14px rgba(15,39,68,.18);transition:transform .12s;position:relative;overflow:hidden}
.big-btn:active{transform:scale(.97)}
.big-btn .btn-ico{font-size:26px;flex-shrink:0}
.big-btn .btn-body{flex:1}
.big-btn .btn-title{font-size:15px;font-weight:600}
.big-btn .btn-sub{font-size:12px;opacity:.75;margin-top:2px;font-weight:400}
.big-btn .btn-arr{font-size:20px;opacity:.5}
.btn-blue{background:linear-gradient(135deg,var(--gold),#facc15);color:#000}
.btn-navy2{background:linear-gradient(135deg,var(--navy),var(--navy-mid))}
.btn-gold{background:linear-gradient(135deg,var(--navy),var(--navy-mid))}
.btn-green{background:linear-gradient(135deg,var(--navy),var(--navy-mid))}
.btn-orange{background:linear-gradient(135deg,var(--navy),var(--navy-mid))}
.btn-teal{background:linear-gradient(135deg,var(--gold),#facc15);color:#000}
.btn-purple{background:linear-gradient(135deg,var(--gold),#facc15);color:#000}
.install-hint{margin-top:16px;padding:14px 16px;background:white;border-radius:var(--radius);box-shadow:var(--shadow)}
.install-hint-title{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px}
.install-hint p{font-size:12px;color:var(--gray-600);line-height:1.6}

/* ── SCROLL CONTENT ── */
.scroll-content{flex:1;overflow-y:auto;padding:14px;padding-bottom:100px}

/* ── CARDS & FIELDS (Dagverslag) ── */
.card{background:white;border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow)}
.card-title{font-size:11px;font-weight:700;color:var(--blue-mid);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;display:flex;align-items:center;gap:6px}
.card-title::before{content:"";display:block;width:3px;height:14px;background:var(--blue-mid);border-radius:2px}
.card-hint{font-size:11px;color:var(--gray-400);margin-bottom:12px;line-height:1.5;padding:8px 10px;background:var(--gray-50);border-radius:6px;border-left:3px solid var(--blue-light)}
.field{margin-bottom:12px}.field:last-child{margin-bottom:0}
.field label{display:block;font-size:12px;font-weight:600;color:var(--gray-600);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;font-size:15px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--gray-50);color:var(--gray-800);font-family:'Inter',sans-serif;-webkit-appearance:none;transition:border-color .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy-mid);background:white;box-shadow:0 0 0 3px rgba(26,60,110,.08)}
.field textarea{resize:vertical;min-height:72px;line-height:1.55}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}
.grid2{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:10px}
.grid3{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:10px}
.grid2>div:empty,.grid3>div:empty{display:none}
.toggle-group{display:flex;gap:6px}
.tbtn{flex:1;padding:10px 4px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--gray-50);font-size:13px;font-weight:600;color:var(--gray-600);cursor:pointer;text-align:center;font-family:'Inter',sans-serif;transition:all .12s}
.tbtn.on{background:var(--blue);border-color:var(--blue);color:white}
.counters{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.counter-box{background:var(--blue-pale);border-radius:var(--radius-sm);padding:12px;text-align:center}
.counter-label{font-size:10px;color:var(--blue-mid);font-weight:700;margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}
.counter-ctrl{display:flex;align-items:center;justify-content:center;gap:12px}
.cbtn{width:32px;height:32px;border-radius:50%;border:none;background:var(--blue-mid);color:white;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:'Inter',sans-serif}
.cbtn:active{transform:scale(.9)}
.cval{font-size:20px;font-weight:700;color:var(--blue);min-width:28px}
.act-item{background:#fff;border:1.5px solid var(--gray-200);border-left:4px solid var(--navy-light);border-radius:var(--radius-sm);padding:14px;margin-bottom:12px;box-shadow:0 1px 6px rgba(15,39,68,.06)}
.act-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.act-lbl{font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.05em}
.lijn-lbl{font-size:10px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;padding:3px 8px;background:var(--gray-100);border-radius:4px;display:inline-block}
.lijn-block{margin-bottom:10px;padding-bottom:10px;border-bottom:1.5px dashed var(--gray-200)}
.lijn-block:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.l1g{display:grid;grid-template-columns:1fr 130px;gap:7px;margin-bottom:7px}
.code-combo-wrap{position:relative}
.code-combo-inp{width:100%;padding:7px 10px;border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:13px;background:white;color:var(--text);outline:none}
.code-combo-inp:focus{border-color:var(--navy-mid)}
.code-drop{position:absolute;top:calc(100% + 2px);left:0;right:0;background:white;border:1.5px solid var(--navy-mid);border-radius:8px;max-height:220px;overflow-y:auto;z-index:200;box-shadow:0 4px 16px rgba(0,0,0,.15)}
.code-drop-item{padding:9px 12px;font-size:12px;cursor:pointer;border-bottom:1px solid var(--border);line-height:1.4}
.code-drop-item:last-child{border-bottom:none}
.code-drop-item:hover{background:var(--blue-pale)}
.code-drop-empty{padding:9px 12px;font-size:12px;color:var(--text-soft)}
/* Code bibliotheek */
.clib-inactief{opacity:.55}
.clib-role-inactief{background:var(--gray-100)!important;color:var(--gray-400)!important}
.l1g2{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:7px}
.l1g2 > div:nth-child(4){grid-column:1 / -1}
@media (min-width:560px){
  .l1g2{grid-template-columns:70px 90px 1fr 1fr}
  .l1g2 > div:nth-child(4){grid-column:auto}
}
.l2g{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:7px}
.l2g2{display:grid;grid-template-columns:80px 1fr;gap:7px;margin-bottom:7px}
.l2g3{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:7px}
/* Bureau filters */
.bureau-filter-card{background:white;border-radius:var(--radius);padding:14px;margin-bottom:12px;box-shadow:var(--shadow)}
.bureau-filter-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.bureau-filter-hdr-ttl{font-size:11px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.06em}
.bureau-filter-toggle{background:none;border:1.5px solid var(--border);border-radius:6px;cursor:pointer;font-size:11px;color:var(--text-soft);padding:2px 8px;line-height:1.6;transition:all .15s;font-family:inherit;font-weight:600}
.bureau-filter-toggle:hover{background:var(--gray-50);color:var(--navy);border-color:var(--navy-mid)}
.bureau-filter-body.collapsed{display:none}
.bureau-filter-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.bureau-filter-field{display:flex;flex-direction:column;gap:3px}
.bureau-filter-label{font-size:10px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em}
.bureau-filter-inp{width:100%;padding:8px 11px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Inter',sans-serif;font-size:13px;background:var(--gray-50);color:var(--text);outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none}
select.bureau-filter-inp{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.bureau-filter-inp:focus{border-color:var(--navy-mid);background:white;box-shadow:0 0 0 3px rgba(26,60,110,.07)}
.bureau-filter-reset{width:100%;padding:8px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:none;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;color:var(--text-soft);cursor:pointer;transition:all .12s}
.bureau-filter-reset:hover{background:var(--gray-50);color:var(--navy)}
.af{display:flex;flex-direction:column;gap:3px}
.af label{font-size:10px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em}
.af input,.af select{width:100%;padding:8px 9px;font-size:13px;border:1px solid var(--gray-200);border-radius:6px;background:white;color:var(--gray-800);font-family:'Inter',sans-serif;-webkit-appearance:none}
.af select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;padding-right:22px}
.af input:focus,.af select:focus{outline:none;border-color:var(--blue-mid)}
/* Dagverslag formulier mat-item — APARTE klasse om conflict te vermijden met materiaal-overzicht */
.dv-mat-item{background:#fff;border:1.5px solid var(--gray-200);border-left:4px solid var(--navy);border-radius:var(--radius-sm);padding:14px;margin-bottom:12px;box-shadow:0 1px 6px rgba(15,39,68,.06)}
.dv-mat-hdr{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:10px}
.dv-mat-lbl{font-size:12px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.05em}
.dv-mat-grid{display:grid;grid-template-columns:175px 1fr 72px 100px 110px;gap:8px;width:100%}
@media(max-width:640px){.dv-mat-grid{grid-template-columns:1fr 1fr}.dv-mat-grid>div:nth-child(2){grid-column:1/-1}.dv-mat-grid>div:nth-child(5){grid-column:1/-1}}
.mf{display:flex;flex-direction:column;gap:3px}
.mf label{font-size:10px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em}
.mf input,.mf select{width:100%;padding:8px 9px;font-size:13px;border:1px solid var(--gray-200);border-radius:6px;background:white;color:var(--gray-800);font-family:'Inter',sans-serif;-webkit-appearance:none}
.mf select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;padding-right:22px}
.del-btn{width:28px;height:28px;border-radius:50%;border:none;color:var(--red);background:var(--red-light);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.add-btn-dv{display:block;margin:12px 0 0;padding:8px 22px;min-width:200px;border:none;border-radius:20px;background:var(--navy);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:opacity .12s;text-align:center}
.add-btn-dv:active{opacity:.8}
.add-btn-gold{border-color:var(--gold);color:#92610a}
.add-btn-gold:active{background:var(--gold-light)}
.sbadge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}
.sbadge.concept{background:var(--orange-light);color:var(--orange)}
.sbadge.ingediend{background:var(--green-light);color:var(--green)}
.bdot{width:7px;height:7px;border-radius:50%;background:currentColor}
.bdot.pulse{animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:white;border-top:1px solid var(--gray-200);display:flex;gap:10px;box-shadow:0 -4px 20px rgba(0,0,0,.08);z-index:600}
.btn-sec{flex:1;padding:13px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--gray-50);color:var(--gray-600);font-size:13px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif}
.btn-grn{flex:2;padding:13px;border:none;border-radius:var(--radius-sm);background:var(--green);color:white;font-size:14px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif}
.btn-grn:active{opacity:.88;transform:scale(.98)}
.vitem{background:white;border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;gap:12px;cursor:pointer;box-shadow:var(--shadow);transition:transform .1s}
.vitem:active{transform:scale(.98)}
.vmeta{flex:1}
.vtitle{font-size:14px;font-weight:600;color:var(--gray-800)}
.vsub{font-size:12px;color:var(--gray-400);margin-top:3px}
.empty{padding:40px 20px;text-align:center;color:var(--gray-400)}
.empty .ico{margin-bottom:12px;display:flex;justify-content:center;color:var(--gray-300)}
.empty .ico svg{width:52px;height:52px;display:block}
.empty p{font-size:14px}
.drow{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--gray-100);font-size:13px}
.drow:last-child{border-bottom:none}
.dl{color:var(--gray-400);font-weight:500}
.dv{color:var(--gray-800);font-weight:600;text-align:right;max-width:60%}
.filter-row{display:flex;gap:6px;margin:12px 0}
.fil-btn{flex:1;padding:9px 6px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);background:white;font-size:12px;font-weight:600;color:var(--gray-600);cursor:pointer;text-align:center;font-family:'Inter',sans-serif}
.fil-btn.on{background:var(--navy);border-color:var(--navy);color:white}

/* ── AANVRAAG (Boeboels) ── */
.req-card{background:white;border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:10px;box-shadow:var(--shadow)}
.req-card-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.req-card-icon{width:34px;height:34px;border-radius:8px;background:var(--navy);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;color:#fff}
.req-card-title{font-size:13px;font-weight:700;color:var(--navy)}
.req-card-sub{font-size:11px;color:var(--text-soft);margin-top:1px}
.row-g{display:grid;gap:10px;margin-bottom:10px}
.row-g.c1{grid-template-columns:1fr}
.row-g.c2{grid-template-columns:1fr}
.row-g.c3{grid-template-columns:1fr}
.fld{display:flex;flex-direction:column;gap:4px}
.fld label{font-size:12px;font-weight:600;color:var(--text-mid)}
.req-star{color:var(--red);margin-left:2px}
.fld input,.fld select,.fld textarea{width:100%;font-family:'Inter',sans-serif;font-size:14px;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);outline:none;transition:border-color .15s;-webkit-appearance:none}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--navy-mid);box-shadow:0 0 0 3px rgba(26,60,110,.1)}
.fld textarea{resize:vertical;min-height:72px}
.fld select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}
.fld .hint{font-size:11px;color:var(--text-soft);margin-top:2px}
.fld input[readonly]{background:var(--gray-50);color:var(--text-soft)}

/* Aanvraag item (categorie-blok) */
.aanvr-item-wrap{border:1.5px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden}
.aanvr-item-hdr{background:linear-gradient(135deg,var(--navy),var(--navy-light));padding:12px 14px;display:flex;align-items:center;justify-content:space-between}
.aanvr-item-hdr-l{display:flex;align-items:center;gap:10px}
.aanvr-num{width:24px;height:24px;background:rgba(255,255,255,.2);color:white;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.aanvr-cat-badge{font-size:12px;font-weight:600;color:rgba(255,255,255,.9)}
.aanvr-remove{background:rgba(255,255,255,.15);border:none;color:white;width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}
.aanvr-item-body{padding:14px}

/* Dept tiles */
.dept-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.dept-tile{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 7px;text-align:center;cursor:pointer;transition:all .12s;background:var(--surface2);user-select:none}
.dept-tile:hover{border-color:var(--navy-mid);background:#f0f4ff}
.dept-tile.selected{border-color:var(--navy);background:var(--navy);color:white}
.dept-icon{font-size:20px;margin-bottom:3px}
.dept-label{font-size:10px;font-weight:700;line-height:1.3}

/* Categorie body */
.cat-section{background:var(--surface2);border-radius:6px;padding:12px;margin-bottom:8px}
.cat-section-title{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* Kotje grid */
.kotje-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-top:6px}
.kotje-btn{padding:6px 4px;border:1.5px solid var(--border);border-radius:6px;background:var(--surface2);font-family:'Inter',sans-serif;font-size:9px;font-weight:500;color:var(--text-mid);cursor:pointer;transition:all .1s;text-align:center;line-height:1.3}
.kotje-btn.selected{border-color:var(--navy);background:var(--navy);color:white}

/* Bool (radio-style) */
.bool-group{display:flex;gap:8px;margin-top:4px}
.bool-opt{flex:1;padding:9px 8px;border:1.5px solid var(--border);border-radius:6px;background:var(--surface2);font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:var(--text-mid);cursor:pointer;text-align:center;transition:all .12s;user-select:none}
.bool-opt.selected{border-color:var(--navy);background:var(--navy);color:white}
.bool-opt.selected-ja{border-color:var(--green);background:var(--green-light);color:var(--green)}
.bool-opt.selected-nee{border-color:var(--red);background:var(--red-light);color:var(--red)}

/* Multiselect */
.multisel-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.multisel-opt{padding:6px 12px;border:1.5px solid var(--border);border-radius:20px;font-family:'Inter',sans-serif;font-size:12px;font-weight:500;color:var(--text-mid);cursor:pointer;transition:all .12s;user-select:none}
.multisel-opt.selected{border-color:var(--navy);background:var(--navy);color:white}

.add-aanvr-btn{width:100%;padding:11px;border:2px dashed var(--border-strong);border-radius:var(--radius-sm);background:transparent;color:var(--text-soft);font-family:'Inter',sans-serif;font-size:13px;font-weight:500;cursor:pointer;margin-top:6px;transition:all .12s}
.add-aanvr-btn:hover{border-color:var(--navy-mid);color:var(--navy-mid);background:#f0f4ff}

/* Concepten boeboels */
.concept-aanvr{background:white;border-radius:var(--radius-sm);padding:14px;margin-bottom:10px;box-shadow:var(--shadow);cursor:pointer;border-left:4px solid var(--orange);display:flex;align-items:center;gap:12px;transition:transform .1s}
.concept-aanvr:active{transform:scale(.98)}

/* Validation */
.val-box{border-radius:var(--radius-sm);padding:14px;margin-top:12px;font-size:13px;line-height:1.7;display:none}
.val-box.ok{background:var(--green-light);border:1.5px solid #86efac;color:#166534}
.val-box.err{background:var(--red-light);border:1.5px solid #fca5a5;color:#991b1b}
.loader-row{display:none;align-items:center;gap:10px;padding:10px 0;color:var(--text-soft);font-size:13px}
.spin{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--navy-mid);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.autosave-pill{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.12);padding:5px 10px;border-radius:20px;font-size:11px;color:rgba(255,255,255,.75);flex-shrink:0;white-space:nowrap}
.as-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite}

/* Dashboard */
.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px}
.stat-c{background:white;border-radius:var(--radius-sm);padding:12px;box-shadow:var(--shadow);cursor:pointer;transition:transform .1s,box-shadow .1s;user-select:none}
.stat-c:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.stat-c:active{transform:scale(.97)}
.stat-c.active-filter{outline:2.5px solid var(--gold);outline-offset:2px;background:var(--gold-light)}
.stat-c.s-open{border-left:4px solid var(--orange)}
.stat-c.s-prog{border-left:4px solid var(--gold)}
.stat-c.s-done{border-left:4px solid var(--green)}
.stat-c.s-urg{border-left:4px solid var(--red)}
.stat-lbl{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.stat-val{font-size:24px;font-weight:700;color:var(--navy);font-family:'DM Mono',monospace}
.search-inp{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Inter',sans-serif;font-size:14px;background:white;color:var(--text);outline:none;margin-bottom:8px}
.search-inp:focus{border-color:var(--navy-mid)}
.filter-row2{display:flex;gap:6px;margin-bottom:12px}
.f-sel{flex:1;padding:8px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Inter',sans-serif;font-size:12px;background:white;color:var(--text);-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:26px}
.dash-aanvr-item{background:white;border-radius:var(--radius-sm);padding:14px;margin-bottom:8px;box-shadow:var(--shadow);cursor:pointer;border-left:4px solid transparent;transition:transform .1s}
.dash-aanvr-item:active{transform:scale(.98)}
.dash-aanvr-item.s-Nieuw{border-left-color:var(--blue-mid)}
.dash-aanvr-item.s-In-behandeling{border-left-color:var(--gold)}
.dash-aanvr-item.s-Klaar{border-left-color:var(--green)}
.dash-aanvr-item.s-Afgerond{border-left-color:var(--gray-400)}
.dash-aanvr-item.s-Geannuleerd{border-left-color:var(--red)}
.pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;white-space:nowrap}
.pill-nieuw{background:#dbeafe;color:#1e40af}
.pill-inbehandeling{background:#fef9c3;color:#854d0e}
.pill-klaar{background:#dcfce7;color:#14532d}
.pill-afgerond{background:#f3f4f6;color:#374151}
.pill-geannuleerd{background:#fee2e2;color:#991b1b}
.pill-urg{background:#fee2e2;color:#991b1b}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,39,68,.55);z-index:200;align-items:flex-end;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:white;border-radius:var(--radius) var(--radius) 0 0;width:100%;max-height:88vh;overflow-y:auto;box-shadow:0 -8px 32px rgba(15,39,68,.2);scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.modal::-webkit-scrollbar{width:4px}
.modal::-webkit-scrollbar-track{background:transparent}
.modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.modal::-webkit-scrollbar-thumb:hover{background:var(--text-soft)}
.modal-box{background:#fff;border-radius:18px;width:100%;box-shadow:0 8px 40px rgba(15,39,68,.22)}
.modal-hdr{background:var(--navy);color:white;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0}
.modal-hdr h3{font-size:15px;font-weight:700}
.modal-close{background:none;border:none;color:white;font-size:22px;cursor:pointer;opacity:.7;line-height:1}
.modal-body{padding:16px}
.modal-sec-title{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:10px;margin-top:16px}
.modal-sec-title:first-child{margin-top:0}
.drow-m{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--gray-100);font-size:13px}
.drow-m:last-child{border-bottom:none}
.dm-l{color:var(--gray-400);font-weight:500}
.dm-v{color:var(--gray-800);font-weight:600;text-align:right;max-width:65%;word-break:break-word}
.status-sel-m{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Inter',sans-serif;font-size:14px;margin-bottom:10px;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}
.notes-ta{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Inter',sans-serif;font-size:13px;min-height:80px;resize:vertical;margin-bottom:12px}
.modal-actions{display:flex;gap:8px}
.btn-save-m{flex:2;padding:12px;border:none;border-radius:var(--radius-sm);background:var(--navy);color:white;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;cursor:pointer}
.btn-del-m{flex:1;padding:12px;border:1.5px solid var(--red);border-radius:var(--radius-sm);background:none;color:var(--red);font-family:'Inter',sans-serif;font-size:13px;font-weight:600;cursor:pointer}
.btn-edit-m{flex:1;padding:12px;border:1.5px solid var(--gold);border-radius:var(--radius-sm);background:var(--gold-light);color:#92610a;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;cursor:pointer}

/* Admin */
.admin-topbar{display:flex;gap:10px;align-items:center;margin-bottom:14px}
.admin-search-inp{flex:1;padding:11px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;outline:none;color:var(--text-dark)}
.admin-search-inp:focus{border-color:var(--blue)}
.admin-new-btn{padding:11px 18px;border:none;border-radius:var(--radius-sm);background:var(--navy);color:#fff;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap}
.admin-new-btn:active{background:var(--blue)}
.admin-user-card{background:white;border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;cursor:pointer;transition:box-shadow .15s}
.admin-user-card:hover{box-shadow:0 4px 16px rgba(15,39,68,.13)}
.admin-user-avatar{width:42px;height:42px;border-radius:50%;background:var(--navy);color:white;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.admin-user-info{flex:1;min-width:0}
.admin-user-name{font-size:14px;font-weight:700;color:var(--navy)}
.admin-user-sub{font-size:12px;color:var(--text-soft);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-user-perms{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.admin-perm-chip{font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;background:var(--blue-pale);color:var(--blue-mid)}
.admin-perm-chip.chip-admin{background:#fef3c7;color:#92400e}
.admin-perm-chip.chip-wij{background:#f0fdf4;color:#166534}
.admin-user-role{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;background:var(--blue-light);color:var(--navy-mid);flex-shrink:0}
.admin-user-role.admin{background:#fef3c7;color:#92400e}
.admin-btn-sm{padding:6px 12px;border:1px solid var(--border);border-radius:6px;background:none;font-family:'Inter',sans-serif;font-size:11px;font-weight:600;cursor:pointer;color:var(--text-mid)}
.admin-btn-sm:hover{background:var(--navy);color:white;border-color:var(--navy)}
.admin-btn-del{color:var(--red);border-color:var(--red)}
.admin-btn-del:hover{background:var(--red);color:white}
/* Toggle switch */
.toggle-switch{position:relative;width:46px;height:26px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--border);border-radius:26px;transition:.2s}
.toggle-slider:before{content:'';position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:white;border-radius:50%;transition:.2s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.toggle-switch input:checked+.toggle-slider{background:var(--blue)}
.toggle-switch input:checked+.toggle-slider:before{transform:translateX(20px)}
/* Perm rows */
.perm-section-ttl{font-size:11px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;padding:14px 0 6px;border-top:1px solid var(--border);margin-top:8px}
.perm-section-ttl:first-child{border-top:none;padding-top:0}
.perm-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--gray-50)}
.perm-row:last-child{border-bottom:none}
.perm-row-lbl{font-size:14px;font-weight:600;color:var(--text-dark)}
.perm-row-sub{font-size:12px;color:var(--text-soft);margin-top:1px}
/* Legacy - keep for other uses */
.user-form-wrap{background:white;border-radius:var(--radius);padding:16px;margin-bottom:14px;box-shadow:var(--shadow)}
.user-form-title{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:14px}
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:4px}
.perm-opt{padding:8px;border:1.5px solid var(--border);border-radius:6px;font-size:12px;font-weight:600;color:var(--text-mid);cursor:pointer;text-align:center;user-select:none;transition:all .12s}
.perm-opt.on{background:var(--green);border-color:var(--green);color:white}
.btn-export{padding:9px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:white;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-mid)}

/* Confirm dialog */
.confirm-overlay{display:none;position:fixed;inset:0;background:rgba(15,39,68,.6);z-index:300;align-items:center;justify-content:center;padding:20px}
.confirm-overlay.open{display:flex}
.confirm-box{background:white;border-radius:var(--radius);max-width:380px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden}
.confirm-hdr{background:var(--navy);color:white;padding:18px 20px;font-size:15px;font-weight:700}
.confirm-body{padding:20px;font-size:14px;color:var(--text-mid);line-height:1.6}
.confirm-actions{display:flex;gap:10px;padding:16px 20px;border-top:1px solid var(--border)}
.confirm-ja{flex:2;padding:12px;border:none;border-radius:var(--radius-sm);background:var(--green);color:white;font-family:'Inter',sans-serif;font-size:14px;font-weight:700;cursor:pointer}
.confirm-nee{flex:1;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:none;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-mid)}
/* Toast */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--gray-800);color:white;padding:10px 20px;border-radius:30px;font-size:13px;font-weight:600;opacity:0;transition:all .25s;z-index:999;white-space:nowrap;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{background:var(--green)}
.toast.warn{background:var(--orange)}
.toast.err{background:var(--red)}

@media(min-width:600px){
  .dept-grid{grid-template-columns:repeat(5,1fr)}
  .kotje-grid{grid-template-columns:repeat(4,1fr)}
  .stats-row{grid-template-columns:repeat(4,1fr)}
  .modal{max-width:560px;border-radius:var(--radius);align-self:center}
  .modal-overlay{align-items:center}
  .grid2,.row-g.c2{grid-template-columns:1fr 1fr}
  .grid3,.row-g.c3{grid-template-columns:1fr 1fr 1fr}
}

/* ════════════════════════════════════════
   HUB HOME
════════════════════════════════════════ */
.hub-hero{background:linear-gradient(145deg,var(--navy) 0%,var(--navy-mid) 100%);padding:18px 20px 24px}
.hub-top-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.hub-logo-center{display:flex;align-items:center;gap:12px;flex-shrink:0}
.hub-logo{width:58px;height:58px;border-radius:14px;object-fit:cover;flex-shrink:0;box-shadow:0 4px 14px rgba(232,160,32,.4)}
.hub-logo-text{}
.hub-company{font-size:10px;font-weight:600;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.12em}
.hub-appname{font-size:16px;font-weight:700;color:white;margin-top:2px}
.hub-user-info{text-align:right;flex-shrink:0}
.hub-greeting{font-size:11px;color:rgba(255,255,255,.55);font-weight:500}
.hub-username{font-size:13px;font-weight:700;color:white;margin-top:1px}
.hub-logout{display:block;margin-top:5px;font-size:11px;color:rgba(255,255,255,.35);cursor:pointer}

.hub-tiles-wrap{padding:20px 16px 90px;flex:1}
.hub-tiles{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.hub-tile{border-radius:20px;padding:28px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;min-height:120px;transition:transform .15s ease,box-shadow .15s ease;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.hub-tile:active{transform:scale(.96)}
.hub-tile-label{font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;line-height:1.2}
.hub-tile-sub{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-top:7px;opacity:.75}

.tile-dv{background:#e8a020}
.tile-dv .hub-tile-label,.tile-dv .hub-tile-sub{color:#fff}
.tile-bbl{background:#1a3c6e}
.tile-bbl .hub-tile-label,.tile-bbl .hub-tile-sub{color:#fff}
.tile-admin{background:#eeeff2;grid-column:1 / -1}
.tile-admin .hub-tile-label{color:#1a1a2e}

/* ════════════════════════════════════════
   SUB-HUB SCREENS
════════════════════════════════════════ */
.hub-module-content{padding:16px;display:flex;flex-direction:column;gap:10px;padding-bottom:90px;flex:1}
.module-action{background:white;border-radius:14px;border:none;width:100%;display:flex;align-items:center;gap:14px;padding:18px 16px;cursor:pointer;transition:background .1s;text-align:left;box-shadow:var(--shadow);min-height:68px}
.module-action:active{background:var(--gray-50)}
.module-action-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.module-action-icon svg{width:24px;height:24px;display:block}
.module-action-body{flex:1}
.module-action-title{font-size:15px;font-weight:700;color:var(--navy)}
.module-action-sub{font-size:12px;color:var(--text-soft);margin-top:2px}
.module-action-arr{font-size:22px;color:var(--border-strong);flex-shrink:0;font-weight:300}
.icon-blue{background:#dbeafe;color:#1d4ed8}
.icon-navy{background:#e8edf8;color:#1a3c6e}
.icon-orange{background:var(--orange-light);color:#c2410c}
.icon-teal{background:#d0f8f5;color:#0d9488}
.icon-gold{background:var(--gold-light);color:#b45309}
.icon-green{background:var(--green-light);color:#059669}
.icon-purple{background:#f3e8ff;color:#7c3aed}

/* ════════════════════════════════════════
   BOTTOM NAV
════════════════════════════════════════ */
#bottom-nav{position:fixed;bottom:0;left:0;right:0;background:white;border-top:1px solid var(--border);display:flex;align-items:stretch;padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -2px 16px rgba(15,39,68,.08);z-index:500}
#bottom-nav.hidden{display:none!important}
.bnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 4px 10px;border:none;background:none;cursor:pointer;color:var(--text-soft);transition:color .15s;-webkit-tap-highlight-color:transparent;min-height:56px}
.bnav-btn.active{color:var(--navy-mid)}
.bnav-ico{font-size:20px;line-height:1}
.bnav-svg{width:22px;height:22px;display:block;color:currentColor}
.bnav-lbl{font-size:10px;font-weight:600;letter-spacing:.02em;margin-top:1px}
/* ════════════════════════════════════════
   REGISTRATIES
════════════════════════════════════════ */
.tile-reg{background:#1a3c6e;grid-column:1 / -1}
.tile-reg .hub-tile-label,.tile-reg .hub-tile-sub{color:#fff}

/* Kiosk hero */
.reg-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 60%,#1e4a8a 100%);padding:28px 20px 32px;position:relative}
.reg-back-btn{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.15);border:none;color:white;font-size:14px;font-weight:600;padding:6px 14px;border-radius:20px;cursor:pointer}
.reg-hero-title{font-size:24px;font-weight:800;color:white;text-align:center;margin-top:8px}
.reg-hero-sub{font-size:12px;color:rgba(255,255,255,.55);text-align:center;margin-top:4px;text-transform:uppercase;letter-spacing:.1em}

/* Form inputs */
.reg-input{width:100%;padding:14px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:15px;color:var(--text);background:white;outline:none;transition:border-color .15s}
.reg-input:focus{border-color:var(--navy-mid);box-shadow:0 0 0 3px rgba(26,60,110,.1)}

/* Registreer button */
.reg-submit-btn{width:100%;margin-top:16px;padding:18px;background:var(--gold);border:none;border-radius:var(--radius);font-family:inherit;font-size:16px;font-weight:800;letter-spacing:.06em;color:var(--navy);cursor:pointer;transition:background .15s;text-transform:uppercase}
.reg-submit-btn:active{background:#e6c200}

/* Success state */
.reg-success-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:12px}
.reg-success-check{width:72px;height:72px;border-radius:50%;background:var(--green-light);color:var(--green);font-size:36px;display:flex;align-items:center;justify-content:center;font-weight:700}
.reg-success-title{font-size:22px;font-weight:800;color:var(--navy)}
.reg-success-sub{font-size:14px;color:var(--text-soft);line-height:1.6}
.reg-nieuw-btn{margin-top:8px;padding:14px 32px;background:var(--navy);border:none;border-radius:var(--radius);color:white;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}

/* Overzicht list */
.reg-card{background:white;border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow);margin-bottom:10px}
.reg-card-naam{font-size:15px;font-weight:700;color:var(--navy)}
.reg-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.reg-tag{font-size:11px;font-weight:600;color:var(--text-mid);background:var(--gray-100);border-radius:6px;padding:3px 8px}
.reg-card-datum{font-size:11px;color:var(--text-soft);margin-top:6px}

.reg-hero-logo-box{width:110px;height:110px;border-radius:22px;background:#fff;box-shadow:0 4px 18px rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;overflow:hidden}
.reg-hero-logo{width:100%;height:100%;object-fit:contain;display:block;transform:scale(1.45);transform-origin:center}

/* ── Kiosk welkomscherm & check-out ── */
#s-reg-kiosk.active{display:flex;flex-direction:column;min-height:100vh}
.kiosk-btn-wrap{display:flex;flex-direction:column;gap:20px;padding:32px 24px;width:100%;max-width:440px;margin:0 auto;flex:1;justify-content:center;align-items:stretch}
.kiosk-action-btn{display:flex;align-items:center;justify-content:center;gap:16px;border:none;border-radius:18px;padding:30px 24px;font-size:20px;font-weight:800;letter-spacing:.04em;cursor:pointer;width:100%;box-shadow:0 6px 24px rgba(0,0,0,.13);transition:transform .1s,box-shadow .1s;font-family:inherit}
.kiosk-action-btn:active{transform:scale(.97);box-shadow:0 2px 8px rgba(0,0,0,.1)}
.kiosk-btn-ico{font-size:34px;line-height:1;display:block}
.kiosk-btn-primary{background:var(--blue);color:#fff}
.kiosk-btn-checkout{background:var(--orange);color:#fff}
.checkout-card{display:flex;align-items:center;gap:16px;background:#fff;border:2px solid var(--border);border-radius:14px;padding:18px 20px;margin:0 16px 12px;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.06);transition:border-color .15s,box-shadow .15s}
.checkout-card:active{border-color:var(--blue);box-shadow:0 4px 16px rgba(0,80,180,.15)}
.checkout-avatar{width:52px;height:52px;border-radius:50%;background:var(--blue-pale);color:var(--blue);font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.checkout-info{flex:1;min-width:0}
.checkout-name{font-size:17px;font-weight:700;color:var(--text-dark)}
.checkout-meta{font-size:13px;color:var(--text-soft);margin-top:2px}
.checkout-arr{font-size:22px;color:var(--gray-400);flex-shrink:0}
.checkout-success-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:20;padding:40px 24px;text-align:center;gap:14px}
.kiosk-exit-btn{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.15);border:none;color:rgba(255,255,255,.75);font-size:16px;width:34px;height:34px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.kiosk-exit-btn:active{background:rgba(255,255,255,.28)}
.reg-card-row{font-size:13px;color:var(--gray-700);margin-top:4px}
.reg-card-lbl{font-size:11px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em}
.checkout-success-ico{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,var(--blue),#1e4a8a);color:#fff;font-size:42px;display:flex;align-items:center;justify-content:center}
.checkout-success-title{font-size:26px;font-weight:800;color:var(--navy);margin-top:4px}
.checkout-success-name{font-size:16px;color:var(--text-soft);font-weight:600}
.checkout-success-cd{font-size:12px;color:var(--text-soft);margin-top:4px}

/* ── HOME v2 ─────────────────────────────── */
.home-hero{background:linear-gradient(135deg,#f5d840 0%,#f0c800 100%);padding-bottom:28px;clip-path:polygon(0 0,100% 0,100% calc(100% - 28px),0 100%);position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:240px}
.home-hero-topbar{position:absolute;top:6px;right:16px;text-align:right}
.home-hero-userinfo{text-align:right}
.home-hero-logout{font-size:12px;color:rgba(255,255,255,.75);text-decoration:underline;cursor:pointer;display:block;line-height:1.4}
.home-hero-greet-row{font-size:13px;color:rgba(255,255,255,.90);font-weight:400;margin-top:1px}
.home-hero-greet-row strong{font-weight:800;color:#fff}
.home-hero-logo-wrap{display:flex;flex-direction:column;align-items:center;padding:0 0 4px;gap:6px}
.home-hero-logo-box{width:180px;height:180px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.home-hero-logo{width:100%;height:100%;object-fit:contain;display:block;transform:scale(1.42);transform-origin:center}
.home-hero-company{font-size:10px;font-weight:700;letter-spacing:.2em;color:rgba(255,255,255,.85);text-transform:uppercase}
.home-sections{padding:20px 20px 120px}
.home-group{margin-bottom:20px}
.home-group-lbl{font-size:12px;font-weight:500;letter-spacing:.05em;color:#1a1a1a;padding:0 4px 10px;text-transform:uppercase}
.home-group-inner{display:flex;flex-direction:column;gap:8px}
.home-acc{border-radius:10px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.1)}
.home-group-inner>.home-item{border-radius:10px;border-top:none;box-shadow:0 1px 4px rgba(0,0,0,.1)}
.home-sec-hdr{display:flex;align-items:center;width:100%;background:#1a3c6e;border:none;padding:16px 18px;cursor:pointer;text-align:left;transition:filter .15s}
.home-sec-hdr:active{filter:brightness(1.1)}
.home-sec-hdr-label{flex:1;font-size:15px;font-weight:600;color:#fff;letter-spacing:.01em}
.home-item-ico,.home-sec-hdr-ico,.home-item-sub,.home-sec-hdr-sub{display:none}
.home-sec-hdr-chev{font-size:22px;color:rgba(255,255,255,.4);font-weight:300;transition:transform .28s ease;display:block;line-height:1}
.home-sec-hdr.open .home-sec-hdr-chev{transform:rotate(90deg)}
.home-sec-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.home-sec-body.open{max-height:600px;background:#f4f5f8;border-left:3px solid var(--gold);border-radius:0 0 10px 10px}
.home-item{display:flex;align-items:center;width:100%;background:#1a3c6e;border:none;border-top:1px solid rgba(255,255,255,.06);padding:15px 18px;cursor:pointer;text-align:left;transition:filter .12s;min-height:52px}
.home-item:first-child{border-top:none}
.home-item:active{filter:brightness(1.12)}
.home-item-gold{background:#fff;border-top-color:rgba(0,0,0,.06);padding-left:24px}
.home-item-gold:first-child{border-top:1px solid rgba(0,0,0,.05)}
.home-item-gold:active{filter:brightness(.97)}
.home-item-gold .home-item-label{color:var(--navy);font-size:14px;font-weight:600}
.home-item-gold .home-item-arr{color:rgba(26,60,110,.35)}
.home-item-label{flex:1;font-size:15px;font-weight:600;color:#fff;letter-spacing:.01em}
.home-item-arr{font-size:20px;color:rgba(255,255,255,.35);font-weight:300;line-height:1}
@media(min-width:600px){
  .home-hero-logo-box{width:200px;height:200px}
  .home-hero-company{font-size:12px;letter-spacing:.22em}
  .home-sec-hdr{padding:18px 22px}
  .home-item{padding:16px 22px}
  .home-item-gold{padding-left:28px}
  .home-sec-hdr-label{font-size:15px}
  .home-item-label{font-size:15px}
  .home-sections{padding:24px 20px 120px}
}

/* ── SCAN VERSLAG ─────────────────────────────── */
.scan-upload-area{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:36px 20px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}
.scan-upload-area:active{background:var(--gray-100);border-color:var(--navy-mid)}
.scan-upload-icon{font-size:40px;margin-bottom:10px}
.scan-upload-title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:4px}
.scan-upload-sub{font-size:13px;color:var(--text-soft)}
.scan-result-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px}
.scan-result-row:last-child{border-bottom:none}
.scan-result-label{color:var(--text-soft);flex-shrink:0;margin-right:12px}
.scan-result-val{font-weight:600;color:var(--navy);text-align:right}
.scan-badge{display:inline-block;background:var(--navy);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px}
.scan-loader-wrap{text-align:center;padding:32px 20px}
.scan-loader-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 14px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── MATERIAALBOEK ───────────────────────────── */
.mat-filter-panel{background:#fff;border-radius:14px;box-shadow:0 2px 12px rgba(15,39,68,.08);padding:14px 16px;margin-bottom:14px}
.mat-filter-search-wrap{display:flex;align-items:center;gap:10px;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:0 14px;margin-bottom:12px;transition:border-color .15s}
.mat-filter-search-wrap:focus-within{border-color:var(--navy-mid)}
.mat-filter-icon{font-size:15px;color:var(--text-soft);flex-shrink:0}
.mat-filter-search{flex:1;padding:11px 0;border:none;background:transparent;font-size:14px;font-family:inherit;color:var(--text-dark);outline:none}
.mat-filter-search::placeholder{color:var(--text-soft)}
.mat-filter-bottom{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.mat-status-pills{display:flex;gap:5px;flex-shrink:0}
.mat-pill{padding:6px 14px;border:1.5px solid var(--border);border-radius:20px;background:transparent;font-size:12px;font-weight:600;color:var(--text-mid);cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}
.mat-pill.active{background:var(--navy);border-color:var(--navy);color:#fff}
.mat-cat-pill-select{flex:1;min-width:120px;padding:6px 12px;border:1.5px solid var(--border);border-radius:20px;font-family:inherit;font-size:12px;font-weight:600;color:var(--text-mid);background:#fff;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:28px}
/* legacy kept for compatibility */
.mat-search-bar{display:flex;gap:8px;margin-bottom:12px}
.mat-search-input{flex:1;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:#fff;color:var(--text)}
.mat-search-input:focus{outline:none;border-color:var(--navy-mid)}
.mat-filter-row{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.mat-filter-btn{padding:6px 14px;border:1.5px solid var(--border);border-radius:20px;background:#fff;font-size:12px;font-weight:600;color:var(--text-mid);cursor:pointer;transition:all .15s;white-space:nowrap}
.mat-filter-btn.active{background:var(--navy);border-color:var(--navy);color:#fff}
.mat-cat-select{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:13px;color:var(--text);background:#fff;width:100%}
.mat-item{display:flex;align-items:center;gap:12px;background:#fff;border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow);cursor:pointer;transition:filter .12s}
.mat-item:active{filter:brightness(.97)}
.mat-item-foto{width:48px;height:48px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;overflow:hidden;background:var(--gray-100)}
.mat-item-foto img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.mat-item-body{flex:1;min-width:0}
.mat-item-title{font-size:14px;font-weight:700;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mat-item-sub{font-size:12px;color:var(--text-soft);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mat-item-badges{display:flex;gap:5px;align-items:center;margin-top:5px;flex-wrap:wrap}
.mat-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;white-space:nowrap}
.mat-badge-cat{background:var(--blue-light);color:var(--navy)}
.mat-badge-actief{background:#dcfce7;color:#166534}
.mat-badge-inactief{background:var(--gray-100);color:var(--gray-600)}
.mat-actief-wrap{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--gray-50);border-radius:var(--radius-sm);margin-bottom:4px}
.mat-actief-label{flex:1;font-size:14px;font-weight:600;color:var(--navy)}
.mat-toggle{position:relative;display:inline-block;width:46px;height:26px;flex-shrink:0}
.mat-toggle input{opacity:0;width:0;height:0;position:absolute}
.mat-toggle-track{position:absolute;inset:0;background:var(--gray-200);border-radius:13px;cursor:pointer;transition:background .2s}
.mat-toggle-track:before{content:'';position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.mat-toggle input:checked+.mat-toggle-track{background:var(--green)}
.mat-toggle input:checked+.mat-toggle-track:before{transform:translateX(20px)}
.mat-foto-area{border:2px dashed var(--border-strong);border-radius:var(--radius-sm);padding:24px;text-align:center;cursor:pointer;transition:border-color .15s;background:var(--gray-50)}
.mat-foto-area:active{border-color:var(--navy);background:var(--gray-100)}
.mat-foto-preview{width:100%;max-height:240px;object-fit:contain;border-radius:var(--radius-sm);border:1px solid var(--border);display:block}
.mat-fotos-strip{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}
.mat-foto-tile{position:relative;width:76px;height:76px;border-radius:8px;overflow:hidden;background:var(--gray-50);border:1.5px solid var(--border);flex-shrink:0}
.mat-foto-tile img{width:100%;height:100%;object-fit:cover;display:block;cursor:pointer}
.mat-foto-tile-del{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}
.mat-foto-add-tile{width:76px;height:76px;border:2px dashed var(--border-strong);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;background:var(--gray-50);gap:3px;flex-shrink:0;transition:border-color .15s}
.mat-foto-add-tile:active{border-color:var(--navy);background:var(--gray-100)}
.mat-foto-add-icon{font-size:20px}
.mat-foto-add-lbl{font-size:10px;font-weight:600;color:var(--navy)}
.mat-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;z-index:600;padding:16px}
.mat-lightbox.open{display:flex}
.mat-lightbox img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:10px}
.mat-lightbox-close{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.18);border:none;color:#fff;font-size:22px;cursor:pointer;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.mat-save-status{font-size:12px;color:var(--text-soft);white-space:nowrap;padding:0 6px}
.mat-actief-row{display:flex;align-items:center;gap:12px;padding-bottom:14px;margin-bottom:8px;border-bottom:1px solid var(--border)}
.mat-actief-row-lbl{font-size:14px;font-weight:600;color:var(--text)}
.lijsten-type-tabs{display:flex;gap:6px;margin-bottom:2px}
.lijsten-tab{flex:1;padding:8px 4px;border:1.5px solid var(--border-strong);border-radius:8px;background:#fff;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-soft);transition:all .15s}
.lijsten-tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.lijsten-item{display:flex;align-items:center;gap:8px;padding:9px 4px;border-bottom:1px solid var(--border)}
.lijsten-item:last-child{border-bottom:none}
.lijsten-item-val{flex:1;font-size:13px;font-weight:500;color:var(--text)}
.lijsten-item-parent{font-size:11px;color:var(--text-soft);background:var(--gray-100);border-radius:4px;padding:1px 6px}
.lijsten-del-btn{background:none;border:none;color:var(--gray-300);font-size:14px;cursor:pointer;padding:3px 6px;border-radius:6px;line-height:1;transition:color .1s}
.lijsten-del-btn:active{color:var(--red)}
.lijsten-add-row{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border)}
.lijsten-add-btn{background:var(--navy);color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:20px;cursor:pointer;font-weight:700;line-height:1;flex-shrink:0}
.mat-count{font-size:12px;color:var(--text-soft);margin-bottom:8px}
.mat-nieuw-btn{position:fixed;bottom:80px;right:16px;width:52px;height:52px;border-radius:50%;background:var(--navy);color:#fff;border:none;font-size:26px;cursor:pointer;box-shadow:0 4px 16px rgba(15,39,68,.35);display:flex;align-items:center;justify-content:center;z-index:10;transition:background .15s}
.mat-nieuw-btn:active{background:var(--navy-light)}

/* ════════════════════════════════════════
   CALCULATOR
   ════════════════════════════════════════ */
.home-item-calc{background:linear-gradient(135deg,var(--navy),var(--navy-light));border-radius:10px;border-top:none;box-shadow:0 2px 8px rgba(15,39,68,.35);margin-top:6px}
.home-item-calc:active{filter:brightness(1.1)}
.home-item-calc .home-item-label{color:#fff;font-weight:800;letter-spacing:.08em}
.home-item-calc .home-item-arr{color:rgba(255,255,255,.7);font-weight:600}

/* Overzicht items */
.calc-item{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:all .12s}
.calc-item:active{background:var(--gold-light);border-color:var(--gold-border)}
.calc-item-main{flex:1;min-width:0}
.calc-item-naam{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calc-item-sub{font-size:11px;color:var(--text-soft)}
.calc-status{font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em;background:var(--gray-100);color:var(--gray-600)}
.calc-status-concept{background:#fff7e0;color:#92610a}
.calc-status-ingediend{background:#dbeafe;color:#1d4ed8}
.calc-status-gegund{background:#dcfce7;color:#166534}
.calc-status-verloren{background:#fee2e2;color:#991b1b}
.calc-status-archief{background:#e5e7eb;color:#4b5563}

/* Posten lijst (in project) */
.calc-post-row{display:flex;align-items:center;gap:10px;padding:10px 8px;border:1.5px solid #dbe1ea;background:#f3f5f8;border-radius:8px;margin-bottom:6px;cursor:pointer;transition:all .12s}
.calc-post-row:active{filter:brightness(.97)}
.calc-post-row-nr{font-size:13px;font-weight:800;color:var(--navy);min-width:38px}
.calc-post-row-main{flex:1;min-width:0}
.calc-post-row-beschr{font-size:13px;font-weight:600;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calc-post-row-sub{font-size:11px;color:var(--text-soft);margin-top:2px}
.calc-post-row-prijs{font-size:13px;font-weight:700;color:var(--navy);white-space:nowrap}

/* Totalen card rows */
.calc-tot-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;color:var(--gray-700)}
.calc-tot-row strong{font-weight:700;color:var(--navy)}

/* Taak block */
.calc-taak-block{border:1.5px solid var(--border);background:#fff;border-radius:10px;padding:12px;margin-bottom:10px}
.calc-taak-hdr{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.calc-taak-naam-inp{flex:1;font-size:13px;font-weight:700;color:var(--navy);border:1.5px solid var(--gray-200);border-radius:6px;padding:7px 9px;background:var(--gray-50);font-family:'Inter',sans-serif}
.calc-taak-naam-inp:focus{outline:none;border-color:var(--navy-mid);background:#fff}
.calc-taak-actions{display:flex;gap:4px}
.calc-taak-btn{background:#fff;border:1.5px solid var(--gold);color:#92610a;border-radius:6px;height:30px;padding:0 10px;font-size:11px;font-family:'Inter',sans-serif;cursor:pointer;line-height:1;flex-shrink:0;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.calc-taak-btn-save:hover{background:var(--gold-light)}
.calc-taak-btn-del{border-color:var(--red);color:var(--red);width:30px;padding:0;font-size:14px}
.calc-taak-btn-del:hover{background:#fee2e2}
.calc-taak-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.calc-rend-input{display:flex;flex-direction:column;gap:3px;position:relative}
.calc-rend-input label{font-size:10px;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em}
.calc-rend-input input{width:100%;padding:7px 9px;font-size:13px;border:1.5px solid var(--gray-200);border-radius:6px;background:var(--gray-50);font-family:'Inter',sans-serif}
.calc-rend-input input:focus{outline:none;border-color:var(--navy-mid);background:#fff}
.calc-rend-unit{position:absolute;right:8px;top:24px;font-size:10px;color:var(--text-soft);font-weight:500;pointer-events:none}
.calc-rend-method{margin:8px 0}
.calc-rend-method label{display:block;font-size:10px;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}
.calc-rend-method select{width:100%;padding:8px 9px;font-size:13px;border:1.5px solid var(--gray-200);border-radius:6px;background:#fff;font-family:'Inter',sans-serif;font-weight:600;color:var(--gray-800)}
.calc-taak-result{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:8px;padding-top:8px;border-top:1.5px dashed var(--gold)}
.calc-taak-result>div{display:flex;flex-direction:column;align-items:flex-start}
.calc-taak-result span{font-size:10px;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.calc-taak-result strong{font-size:12px;color:var(--navy);font-weight:700;margin-top:2px}

/* Templates */
.calc-tpl-item{display:flex;align-items:center;gap:8px;padding:10px 6px;border-bottom:1px solid var(--border)}
.calc-tpl-item:last-child{border-bottom:none}
.calc-tpl-item-main{flex:1;min-width:0}
.calc-tpl-item-naam{font-size:13px;font-weight:600;color:var(--navy)}
.calc-tpl-item-sub{font-size:11px;color:var(--text-soft);margin-top:2px}
.calc-tpl-item-actions{display:flex;gap:4px;flex-shrink:0}
.calc-tpl-action-btn{background:#fff;border:1.5px solid var(--gray-200);border-radius:6px;width:30px;height:30px;font-size:13px;cursor:pointer;line-height:1;color:var(--gray-700);transition:all .12s;display:flex;align-items:center;justify-content:center}
.calc-tpl-action-btn:hover{background:var(--gold-light);border-color:var(--gold)}
.calc-tpl-action-btn-del{color:var(--red);border-color:#fecaca}
.calc-tpl-action-btn-del:hover{background:#fee2e2;border-color:var(--red)}

/* Section header (Posten / Taken kaart titel) */
.calc-section-hdr{display:flex;align-items:center;justify-content:space-between;padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid var(--border)}
.calc-section-ttl{font-size:12px;font-weight:700;color:var(--blue-mid);text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;gap:8px}
.calc-section-ttl::before{content:"";display:block;width:3px;height:14px;background:var(--blue-mid);border-radius:2px}
.calc-section-actions{display:flex;gap:6px;flex-shrink:0}
.calc-icon-btn{background:#1a1d2e;border:none;border-radius:8px;width:34px;height:34px;cursor:pointer;color:#fff;margin-right:6px;display:inline-flex;align-items:center;justify-content:center;transition:all .12s;flex-shrink:0}
.calc-icon-btn:hover{background:#0f1117}
.calc-section-btn-tpl{background:#fff;border:1.5px solid var(--gold);color:#92610a;border-radius:8px;width:34px;height:34px;font-size:15px;cursor:pointer;line-height:1;font-weight:700;transition:all .12s;display:flex;align-items:center;justify-content:center}
.calc-section-btn-tpl:hover{background:var(--gold-light)}
.calc-section-btn-add{background:var(--navy);color:#fff;border:none;border-radius:8px;width:34px;height:34px;font-size:20px;cursor:pointer;line-height:1;font-weight:700;transition:filter .12s}
.calc-section-btn-add:hover{filter:brightness(1.15)}

/* Status pill bar (in project sectie) */
.calc-status-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px dashed var(--border)}
.calc-status-pill{flex:1;min-width:80px;padding:8px 12px;border-radius:18px;border:1.5px solid transparent;background:#fff;font-family:'Inter',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;color:var(--gray-500);transition:all .15s;opacity:.45}
.calc-status-pill:hover{opacity:.75}
.calc-status-pill.active{opacity:1;color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.calc-status-pill.calc-status-concept{border-color:#fed7aa}
.calc-status-pill.calc-status-concept.active{background:#f97316;border-color:#f97316;color:#fff}
.calc-status-pill.calc-status-ingediend{border-color:#fde68a}
.calc-status-pill.calc-status-ingediend.active{background:#facc15;border-color:#facc15;color:#000}
.calc-status-pill.calc-status-gegund{border-color:#bbf7d0}
.calc-status-pill.calc-status-gegund.active{background:#16a34a;border-color:#16a34a;color:#fff}
.calc-status-pill.calc-status-verloren{border-color:#fecaca}
.calc-status-pill.calc-status-verloren.active{background:#dc2626;border-color:#dc2626;color:#fff}
.calc-status-pill.calc-status-archief{border-color:#d1d5db}
.calc-status-pill.calc-status-archief.active{background:#6b7280;border-color:#6b7280;color:#fff}

/* Status badge in overzicht (calc list) — herdefiniëren met juiste kleuren */
.calc-status-concept{background:#fff7ed;color:#9a3412}
.calc-status-ingediend{background:#fef9c3;color:#854d0e}
.calc-status-gegund{background:#dcfce7;color:#166534}
.calc-status-verloren{background:#fee2e2;color:#991b1b}
.calc-status-archief{background:#f3f4f6;color:#4b5563}

/* Calculator modal/popup (taak picker, post picker, templates beheer, edit) */
.calc-modal{position:fixed;inset:0;background:rgba(15,39,68,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;align-items:center;justify-content:center;padding:20px;animation:calcModalFadeIn .18s ease-out}
@keyframes calcModalFadeIn{from{opacity:0}to{opacity:1}}
.calc-modal-box{background:#fff;border-radius:16px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.35);overflow:hidden;animation:calcModalSlideIn .22s ease-out}
@keyframes calcModalSlideIn{from{transform:translateY(20px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.calc-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,var(--navy),var(--navy-mid));color:#fff;flex-shrink:0}
.calc-modal-ttl{font-size:15px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.calc-modal-x{background:rgba(255,255,255,.15);border:none;color:#fff;font-size:14px;cursor:pointer;width:30px;height:30px;border-radius:8px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .12s}
.calc-modal-x:hover{background:rgba(255,255,255,.28)}
.calc-modal-body{padding:16px 20px 20px;display:flex;flex-direction:column;flex:1;min-height:0;gap:0}
.calc-modal-tabs{display:flex;gap:8px;margin-bottom:12px;background:var(--gray-100);padding:4px;border-radius:10px}
.calc-modal-tab{flex:1;padding:9px 12px;border:none;background:transparent;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--text-soft);cursor:pointer;border-radius:8px;transition:all .15s}
.calc-modal-tab.active{background:#fff;color:var(--navy);box-shadow:0 1px 3px rgba(0,0,0,.08);font-weight:700}
.calc-modal-search-wrap{position:relative;margin-bottom:12px;flex-shrink:0}
.calc-modal-search-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.55;pointer-events:none}
.calc-modal-search{width:100%;padding:11px 14px 11px 38px;font-size:14px;border:1.5px solid var(--gray-200);border-radius:10px;background:var(--gray-50);color:var(--gray-800);font-family:'Inter',sans-serif;transition:all .15s}
.calc-modal-search:focus{outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(240,200,0,.18)}
.calc-modal-list{flex:1;overflow-y:auto;min-height:140px;margin:0 -4px;padding:0 4px}
.calc-modal-list::-webkit-scrollbar{width:6px}
.calc-modal-list::-webkit-scrollbar-track{background:transparent}
.calc-modal-list::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:3px}
.calc-modal-list::-webkit-scrollbar-thumb:hover{background:var(--gray-300)}
.calc-modal-foot{font-size:11px;color:var(--text-soft);text-align:center;padding-top:10px;margin-top:8px;border-top:1px solid var(--border);flex-shrink:0}
.calc-modal-save-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--gold),#facc15);border:none;border-radius:10px;font-family:'Inter',sans-serif;font-weight:700;font-size:14px;color:var(--navy);cursor:pointer;margin-top:6px;letter-spacing:.02em;box-shadow:0 4px 12px rgba(240,200,0,.3);transition:transform .12s,box-shadow .12s}
.calc-modal-save-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(240,200,0,.4)}
.calc-modal-save-btn:active{transform:translateY(0)}

/* Override calc-tpl-item styling binnen .calc-modal voor consistente look */
.calc-modal-list .calc-tpl-item{padding:12px 14px;border-radius:10px;margin-bottom:6px;border:1.5px solid var(--border);transition:all .12s;background:#fff}
.calc-modal-list .calc-tpl-item:last-child{margin-bottom:2px}
.calc-modal-list .calc-tpl-item[onclick]{cursor:pointer}
.calc-modal-list .calc-tpl-item[onclick]:hover{border-color:var(--gold);background:var(--gold-light);transform:translateX(2px)}
.calc-modal-list .calc-tpl-item-naam{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:3px}
.calc-modal-list .calc-tpl-item-sub{font-size:12px;color:var(--text-soft)}
.calc-modal-list .calc-tpl-item-actions{margin-left:8px}
.calc-modal-list .calc-tpl-item-ico{flex-shrink:0;font-size:22px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--gold-light);border-radius:8px;margin-right:4px}

/* Empty state in modals */
.calc-modal-empty{padding:32px 16px;text-align:center}
.calc-modal-empty-ico{font-size:42px;margin-bottom:10px;opacity:.6}
.calc-modal-empty-ttl{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px}
.calc-modal-empty-sub{font-size:12px;color:var(--text-soft);line-height:1.5}
.calc-modal-empty-sub strong{color:var(--navy)}

/* ════════════════════════════════════════
   TAAK ACCORDION SECTIES (Rendement / Shift / 5 NETTO / Samenvatting)
   ════════════════════════════════════════ */
.calc-accordion{border:1.5px solid var(--border);border-radius:10px;margin-bottom:8px;background:#fff;overflow:hidden;transition:border-color .15s}
.calc-accordion.open{border-color:#c8d0dd}
.calc-accordion-hdr{display:flex;align-items:center;width:100%;padding:10px 12px;background:var(--gray-50);border:none;cursor:pointer;font-family:'Inter',sans-serif;text-align:left;transition:background .12s;gap:8px}
.calc-accordion.open .calc-accordion-hdr{background:linear-gradient(90deg,#eef1f6,#fff)}
.calc-accordion-hdr:hover{background:#eef1f6}
.calc-accordion-chev{display:inline-block;font-size:11px;color:var(--gray-500);transition:transform .15s;width:14px;text-align:center}
.calc-accordion.open .calc-accordion-chev{transform:rotate(90deg);color:var(--navy)}
.calc-accordion-ttl{flex:1;font-size:12px;font-weight:700;color:var(--navy);letter-spacing:.02em}
.calc-accordion-badge{font-size:11px;font-weight:600;color:var(--navy);background:#eef1f6;padding:3px 8px;border-radius:10px;border:1px solid #d8dde7}
.calc-accordion-body{display:none;padding:12px}
.calc-accordion.open .calc-accordion-body{display:block}

/* Resultaat-row in rendement sectie */
.calc-rend-result-row{margin-top:10px;padding:8px 10px;background:#eef1f6;border-radius:6px;font-size:12px;color:var(--gray-700)}
.calc-rend-result-row strong{font-weight:700;color:var(--navy);font-size:13px}

/* Shift sectie */
.calc-shift-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:10px}
.calc-shift-row>div{background:var(--gray-50);padding:8px;border-radius:6px;display:flex;flex-direction:column}
.calc-shift-row span{font-size:10px;color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.calc-shift-row strong{font-size:13px;color:var(--navy);font-weight:700;margin-top:2px}
.calc-shift-result{padding:10px 12px;background:linear-gradient(90deg,var(--gold-light),#fff);border:1.5px solid var(--gold-border);border-radius:8px;font-size:13px;display:flex;justify-content:space-between;align-items:center}
.calc-shift-result span{font-weight:600;color:var(--gray-700)}
.calc-shift-result strong{font-size:16px;color:var(--navy);font-weight:800}

/* Cost tables (Uurkost, Verplaatsing, Machine, Transport, Levering) */
.calc-cost-controls{display:flex;gap:8px;margin-bottom:10px}
.calc-cost-controls select{flex:1;padding:7px 9px;font-size:12px;border:1.5px solid var(--gray-200);border-radius:6px;background:var(--gray-50);font-family:'Inter',sans-serif}
.calc-cost-subhdr{font-size:11px;font-weight:700;color:var(--blue-mid);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.calc-cost-subhdr::before{content:"";display:block;width:3px;height:11px;background:var(--blue-mid);border-radius:2px}
.calc-cost-table-hdr{display:grid;grid-template-columns:2fr .8fr .8fr 1fr 1fr 1fr 28px;gap:6px;font-size:9px;font-weight:700;color:var(--gray-600);text-transform:uppercase;padding:6px 4px;border-bottom:1px solid var(--border);letter-spacing:.04em}
.calc-cost-table-hdr-wide{grid-template-columns:2fr .6fr .8fr 1fr 1fr 1fr 28px}
.calc-cost-table{display:flex;flex-direction:column;gap:4px;padding:6px 0}
.calc-cost-row{display:grid;grid-template-columns:2fr .8fr .8fr 1fr 1fr 1fr 28px;gap:6px;align-items:center;padding:4px 0;font-size:12px}
.calc-cost-row-wide{grid-template-columns:2fr .6fr .8fr 1fr 1fr 1fr 28px}
.calc-cost-row select,.calc-cost-row input{padding:6px 8px;font-size:11.5px;border:1.5px solid var(--gray-200);border-radius:5px;background:var(--gray-50);font-family:'Inter',sans-serif;min-width:0}
.calc-cost-row select:focus,.calc-cost-row input:focus{outline:none;border-color:var(--navy-mid);background:#fff}
.calc-cost-cell{font-size:11.5px;color:var(--gray-700);padding:6px 4px;text-align:right}
.calc-cost-tot{font-weight:700;color:var(--navy)}
.calc-cost-del{background:#fff;border:1.5px solid #fecaca;color:var(--red);border-radius:5px;width:24px;height:24px;font-size:12px;cursor:pointer;line-height:1;font-weight:700;padding:0}
.calc-cost-del:hover{background:#fee2e2}
.calc-cost-add{margin-top:8px;padding:6px 12px;background:#fff;border:1.5px dashed var(--gold);color:#92610a;font-size:11px;font-weight:600;border-radius:6px;cursor:pointer;font-family:'Inter',sans-serif}
.calc-cost-add:hover{background:var(--gold-light)}
.calc-cost-tot-row{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding:8px 10px;background:#eef1f6;border:1.5px solid #dbe1ea;border-radius:6px;font-size:12px}
.calc-cost-tot-row span{font-weight:600;color:var(--gray-700)}
.calc-cost-tot-row strong{font-size:14px;color:var(--navy);font-weight:800}

/* Final samenvatting */
.calc-taak-final{display:flex;flex-direction:column;gap:6px}
.calc-taak-final-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#fff;border-radius:6px;font-size:12px}
.calc-taak-final-row span{font-weight:600;color:var(--gray-700)}
.calc-taak-final-row strong{font-size:14px;color:var(--navy);font-weight:700}
.calc-taak-final-hi{background:linear-gradient(135deg,var(--gold),#facc15);border-radius:8px;padding:10px 14px;margin-top:4px}
.calc-taak-final-hi span{color:#1a1a1a;font-weight:700}
.calc-taak-final-hi strong{color:#000;font-size:18px;font-weight:800}

/* Update calc-taak-block om accordion-stijl te ondersteunen */
.calc-taak-block{border:1.5px solid #dbe1ea;background:#f3f5f8;border-radius:12px;padding:12px;margin-bottom:14px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.calc-taak-block .calc-taak-grid{margin-bottom:10px}

/* ════════════════════════════════════════
   COMPACT POST GEGEVENS
   ════════════════════════════════════════ */
.calc-post-card{padding:12px}
.calc-post-grid{display:grid;grid-template-columns:.7fr 1fr 1fr .6fr;gap:6px}
.calc-post-grid-3{grid-template-columns:.7fr 1fr 1fr}
.calc-post-grid-eh{grid-template-columns:1fr 1fr;margin-top:6px}
.calc-proj-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}
.calc-proj-grid-marges{grid-template-columns:1fr 1fr 1fr;margin-top:6px}
.calc-mini-field textarea{width:100%;padding:7px 9px;font-size:13px;border:1.5px solid var(--gray-200);border-radius:6px;background:var(--gray-50);color:var(--gray-800);font-family:'Inter',sans-serif;line-height:1.45;min-width:0}
.calc-mini-field textarea:focus{outline:none;border-color:var(--navy-mid);background:#fff;box-shadow:0 0 0 2px rgba(26,60,110,.08)}
.calc-mini-field{display:flex;flex-direction:column;gap:2px;min-width:0}
.calc-mini-field label{font-size:9.5px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em}
.calc-mini-field input,.calc-mini-field select{width:100%;padding:7px 9px;font-size:13px;border:1.5px solid var(--gray-200);border-radius:6px;background:var(--gray-50);color:var(--gray-800);font-family:'Inter',sans-serif;-webkit-appearance:none;min-width:0}
.calc-mini-field input:focus,.calc-mini-field select:focus{outline:none;border-color:var(--navy-mid);background:#fff;box-shadow:0 0 0 2px rgba(26,60,110,.08)}
.calc-mini-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;padding-right:26px}

/* ════════════════════════════════════════
   PARAMETERS SCHERM
   ════════════════════════════════════════ */
.calc-param-tabs{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;padding:4px;background:var(--gray-100);border-radius:10px;flex-wrap:nowrap}
.calc-param-tab{flex:1;min-width:90px;padding:8px 10px;border:none;background:transparent;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;color:var(--text-soft);cursor:pointer;border-radius:7px;transition:all .15s;white-space:nowrap}
.calc-param-tab.active{background:#fff;color:var(--navy);box-shadow:0 1px 3px rgba(0,0,0,.08);font-weight:700}
.calc-param-tbl-hdr{display:grid;grid-template-columns:1.5fr 1.5fr 1fr 1fr 36px;gap:6px;font-size:9px;font-weight:700;color:var(--gray-600);text-transform:uppercase;padding:8px 4px;border-bottom:1.5px solid var(--border);letter-spacing:.04em;margin-bottom:4px}
.calc-param-arb-hdr{grid-template-columns:1.8fr 1fr 1fr 1fr 36px}
.calc-param-vrt-hdr{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 36px}
.calc-param-mch-hdr{grid-template-columns:2fr 1fr 1fr 1fr .6fr 36px}
.calc-param-row{display:grid;grid-template-columns:1.5fr 1.5fr 1fr 1fr 36px;gap:6px;align-items:center;padding:4px 0;border-bottom:1px solid var(--gray-100)}
.calc-param-row:last-child{border-bottom:none}
.calc-param-arb-row{grid-template-columns:1.8fr 1fr 1fr 1fr 36px}
.calc-param-vrt-row{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr 36px}
.calc-param-mch-row{grid-template-columns:2fr 1fr 1fr 1fr .6fr 36px}
.calc-param-row input,.calc-param-row select{width:100%;padding:7px 9px;font-size:12px;border:1.5px solid var(--gray-200);border-radius:6px;background:var(--gray-50);font-family:'Inter',sans-serif;min-width:0}
.calc-param-row input:focus,.calc-param-row select:focus{outline:none;border-color:var(--navy-mid);background:#fff}
.calc-param-del{background:#fff;border:1.5px solid #fecaca;color:var(--red);border-radius:6px;width:30px;height:30px;font-size:14px;cursor:pointer;line-height:1;font-weight:700;padding:0}
.calc-param-del:hover{background:#fee2e2}
.calc-param-add-btn{margin-top:12px;width:100%;padding:11px;background:linear-gradient(135deg,var(--gold),#facc15);border:none;border-radius:8px;font-family:'Inter',sans-serif;font-weight:700;font-size:13px;color:var(--navy);cursor:pointer;letter-spacing:.02em;box-shadow:0 2px 8px rgba(240,200,0,.25)}
.calc-param-add-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(240,200,0,.35)}

/* ════════════════════════════════════════
   IMPORT TAKENLIJST (klant → calculatie)
   ════════════════════════════════════════ */
.calc-imp-legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:10px;padding:8px 10px;background:var(--gray-50);border-radius:7px}
.calc-imp-legend-it{font-size:11px;color:var(--gray-600);font-weight:600;display:flex;align-items:center;gap:6px}
.calc-imp-dot{display:inline-block;width:10px;height:10px;border-radius:50%}
.calc-imp-dot-strong{background:#16a34a}
.calc-imp-dot-weak{background:#facc15}
.calc-imp-dot-none{background:#9ca3af}

.calc-imp-hdr{display:grid;grid-template-columns:32px 1fr 1.3fr .9fr 56px;gap:10px;align-items:center;padding:6px 12px;font-size:9.5px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;border-bottom:1.5px solid var(--gray-200);margin-bottom:6px}
.calc-imp-hdr-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calc-imp-row{display:grid;grid-template-columns:32px 1fr 1.3fr .9fr 56px;gap:10px;align-items:center;padding:9px 12px;border:1.5px solid var(--gray-200);border-radius:8px;margin-bottom:6px;background:#fff;transition:all .12s}
.calc-imp-row.imp-row-strong{border-left:4px solid #16a34a}
.calc-imp-row.imp-row-weak{border-left:4px solid #facc15}
.calc-imp-row.imp-row-none{border-left:4px solid #9ca3af}
.calc-imp-row-num{font-size:11px;font-weight:800;color:var(--gray-400);text-align:center}
.calc-imp-row-orig{font-size:13px;color:var(--gray-800);font-weight:500;line-height:1.4;word-break:break-word}
.calc-imp-row-sel{padding:7px 9px;font-size:12px;border:1.5px solid var(--gray-200);border-radius:6px;background:var(--gray-50);font-family:'Inter',sans-serif;width:100%;color:var(--gray-800);min-width:0;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234b5563' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;padding-right:26px}
.calc-imp-row-sel:focus{outline:none;border-color:var(--gold);background-color:#fff;box-shadow:0 0 0 3px rgba(240,200,0,.15)}
.calc-imp-row-klant{font-size:12px;color:var(--gray-700);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.calc-imp-row-klant-empty{color:var(--gray-300);font-style:italic}
.calc-imp-row-pct{font-size:11px;font-weight:700;color:#166534;background:#dcfce7;padding:3px 6px;border-radius:5px;text-align:center;min-width:42px}
.calc-imp-row.imp-row-weak .calc-imp-row-pct{color:#854d0e;background:#fef9c3}
.calc-imp-row-pct-empty{color:var(--gray-500) !important;background:var(--gray-100) !important}

@media (max-width:640px){
  .calc-imp-hdr{display:none}
  .calc-imp-row{grid-template-columns:28px 1fr 56px;grid-template-rows:auto auto auto;gap:4px 6px}
  .calc-imp-row-num{grid-row:1;grid-column:1}
  .calc-imp-row-orig{grid-row:1;grid-column:2 / 4}
  .calc-imp-row-sel{grid-row:2;grid-column:1 / 3}
  .calc-imp-row-pct{grid-row:2;grid-column:3}
  .calc-imp-row-klant{grid-row:3;grid-column:1 / 4;font-size:11px;color:var(--text-soft);padding:2px 0 0 28px}
  .calc-imp-row-klant:not(:empty)::before{content:"Klant origineel: ";font-weight:600}
}

/* ════════════════════════════════════════
   CALCULATOR FILTER PANEL (overzicht)
   ════════════════════════════════════════ */
.calc-filter-panel{background:#fff;border:1.5px solid var(--border);border-radius:12px;margin-bottom:14px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.calc-filter-hdr{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--gray-50);user-select:none;border-bottom:1px solid var(--border)}
.calc-filter-ico{font-size:14px}
.calc-filter-ttl{flex:1;font-size:13px;font-weight:700;color:var(--navy);letter-spacing:.02em}
.calc-filter-count{font-size:10px;font-weight:700;color:var(--text-soft);background:var(--gray-100);padding:3px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.04em}
.calc-filter-count.on{background:var(--gold);color:var(--navy)}
.calc-filter-body{display:block;padding:14px}
.calc-filter-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.calc-filter-field{display:flex;flex-direction:column;gap:4px}
.calc-filter-field label{font-size:10px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em}
.calc-filter-field input,.calc-filter-field select{width:100%;padding:8px 10px;font-size:13px;border:1.5px solid var(--gray-200);border-radius:7px;background:var(--gray-50);font-family:'Inter',sans-serif;color:var(--gray-800)}
.calc-filter-field input:focus,.calc-filter-field select:focus{outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(240,200,0,.15)}
.calc-filter-status-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;padding-top:10px;border-top:1px dashed var(--border)}
.calc-filter-status-pill{padding:7px 12px;font-size:11px;font-weight:700;border:1.5px solid var(--gray-200);background:#fff;border-radius:14px;cursor:pointer;font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);transition:all .15s}
.calc-filter-status-pill:hover{border-color:var(--gold);color:var(--navy)}
.calc-filter-status-pill.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.calc-filter-status-pill.calc-status-concept.active{background:#f97316;border-color:#f97316;color:#fff}
.calc-filter-status-pill.calc-status-ingediend.active{background:#facc15;border-color:#facc15;color:#000}
.calc-filter-status-pill.calc-status-gegund.active{background:#16a34a;border-color:#16a34a;color:#fff}
.calc-filter-status-pill.calc-status-verloren.active{background:#dc2626;border-color:#dc2626;color:#fff}
.calc-filter-status-pill.calc-status-archief.active{background:#6b7280;border-color:#6b7280;color:#fff}
.calc-filter-clear{padding:8px 14px;font-size:11px;font-weight:600;background:transparent;border:1.5px solid var(--border-strong);color:var(--text-soft);border-radius:7px;cursor:pointer;font-family:'Inter',sans-serif}
.calc-filter-clear:hover{border-color:var(--red);color:var(--red);background:#fee2e2}

/* ════════════════════════════════════════
   CONFIRM MODAL (rode waarschuwing)
   ════════════════════════════════════════ */
.calc-confirm-box{padding:0;overflow:hidden}
.calc-confirm-hdr{display:flex;align-items:center;gap:14px;padding:20px 22px;background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}
.calc-confirm-ico{font-size:34px;line-height:1;animation:calcConfirmPulse 1.4s ease-in-out infinite}
@keyframes calcConfirmPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
.calc-confirm-ttl{font-size:18px;font-weight:800;letter-spacing:-.01em}
.calc-confirm-body{padding:20px 22px}
.calc-confirm-msg{font-size:13.5px;line-height:1.6;color:var(--gray-800);margin-bottom:18px}
.calc-confirm-msg strong{color:var(--navy);font-weight:700}
.calc-confirm-msg em{color:var(--text-soft);font-style:italic}
.calc-confirm-actions{display:flex;gap:10px;justify-content:flex-end}
.calc-confirm-btn-cancel{padding:10px 18px;background:#fff;border:1.5px solid var(--border-strong);color:var(--gray-700);font-family:'Inter',sans-serif;font-size:13px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .12s}
.calc-confirm-btn-cancel:hover{background:var(--gray-100);border-color:var(--gray-400)}
.calc-confirm-btn-ok{padding:10px 22px;background:var(--navy);border:none;color:#fff;font-family:'Inter',sans-serif;font-size:13px;font-weight:700;border-radius:8px;cursor:pointer;transition:all .12s;letter-spacing:.02em}
.calc-confirm-btn-ok:hover{filter:brightness(1.15)}
.calc-confirm-btn-ok.calc-confirm-btn-danger{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 12px rgba(220,38,38,.35)}
.calc-confirm-btn-ok.calc-confirm-btn-danger:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(220,38,38,.5)}

/* Progress overlay */
.calc-progress-box{padding:30px 26px;text-align:center}
.calc-progress-spinner{width:48px;height:48px;border:4px solid var(--gold-light);border-top-color:var(--gold);border-radius:50%;margin:0 auto 18px;animation:calcSpin 0.9s linear infinite}
@keyframes calcSpin{to{transform:rotate(360deg)}}
.calc-progress-ttl{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:6px}
.calc-progress-sub{font-size:12px;color:var(--text-soft);margin-bottom:16px;min-height:18px}
.calc-progress-bar{width:100%;height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}

/* ── SUPPORT (tickets) ── */
.tk-prio-wrap{display:flex;gap:8px;margin-bottom:14px}
.tk-prio-btn{flex:1;padding:12px 8px;border:1.5px solid var(--border);background:#fff;border-radius:var(--radius-sm);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-mid);transition:all .15s}
.tk-prio-btn.on.prio-low{background:#dcfce7;border-color:var(--green);color:#14532d}
.tk-prio-btn.on.prio-mid{background:#fef9c3;border-color:var(--gold);color:#854d0e}
.tk-prio-btn.on.prio-high{background:#fee2e2;border-color:var(--red);color:#991b1b}
.tk-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-top:10px}
.tk-photo-thumb{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:1.5px solid var(--border);cursor:pointer;background:var(--gray-100)}
.tk-photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.tk-photo-rm{position:absolute;top:3px;right:3px;width:22px;height:22px;border:none;background:rgba(220,38,38,.92);color:#fff;border-radius:50%;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.tk-photo-add{aspect-ratio:1;border:2px dashed var(--border-strong);border-radius:8px;background:var(--gray-50);color:var(--text-soft);font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.tk-photo-add:hover{border-color:var(--navy);color:var(--navy)}
.tk-list{display:flex;flex-direction:column;gap:8px}
.tk-card{background:white;border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow);cursor:pointer;border-left:4px solid transparent;transition:transform .1s}
.tk-card:active{transform:scale(.98)}
.tk-card.s-Open{border-left-color:var(--blue-mid)}
.tk-card.s-In-behandeling{border-left-color:var(--gold)}
.tk-card.s-Wacht-op-klant{border-left-color:var(--orange)}
.tk-card.s-Opgelost{border-left-color:var(--green)}
.tk-card.s-Gesloten{border-left-color:var(--gray-400)}
.tk-card-row1{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px;gap:8px}
.tk-card-id{font-size:10px;font-weight:700;color:var(--text-soft);font-family:'DM Mono',monospace}
.tk-card-title{font-size:13px;font-weight:600;color:var(--navy);margin-bottom:3px;line-height:1.3}
.tk-card-meta{font-size:11px;color:var(--text-soft);display:flex;flex-wrap:wrap;gap:8px}
.tk-prio-pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700}
.tk-prio-pill.low{background:#dcfce7;color:#14532d}
.tk-prio-pill.mid{background:#fef9c3;color:#854d0e}
.tk-prio-pill.high{background:#fee2e2;color:#991b1b}
.tk-status-pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;white-space:nowrap}
.tk-status-pill.s-Open{background:#dbeafe;color:#1e40af}
.tk-status-pill.s-In-behandeling{background:#fef9c3;color:#854d0e}
.tk-status-pill.s-Wacht-op-klant{background:#ffedd5;color:#9a3412}
.tk-status-pill.s-Opgelost{background:#dcfce7;color:#14532d}
.tk-status-pill.s-Gesloten{background:#f3f4f6;color:#374151}
.tk-filters{background:#fff;border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:10px;box-shadow:var(--shadow);display:grid;grid-template-columns:1fr 1fr;gap:8px}
.tk-filters input,.tk-filters select{padding:8px 10px;border:1.5px solid var(--border);border-radius:6px;font-size:12px;background:var(--gray-50);width:100%}
.tk-filters .tk-filt-search{grid-column:1/-1}
/* ── Ticket slide-in panel (tkp-) ── */
.tkp-overlay{position:fixed;inset:0;z-index:280;background:rgba(15,39,68,0);pointer-events:none;transition:background .25s}
.tkp-overlay.open{background:rgba(15,39,68,.48);pointer-events:auto}
.tkp-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:480px;background:#f0f3f9;box-shadow:-6px 0 40px rgba(15,39,68,.22);transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden;z-index:281}
.tkp-overlay.open .tkp-panel{transform:translateX(0)}
/* Panel header */
.tkp-hdr{background:var(--navy);padding:44px 16px 16px;flex-shrink:0}
.tkp-hdr-row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.tkp-id{font-size:11px;font-weight:700;color:rgba(255,255,255,.45);letter-spacing:.08em}
.tkp-close{background:rgba(255,255,255,.12);border:none;color:rgba(255,255,255,.8);font-size:18px;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;flex-shrink:0;transition:background .15s}
.tkp-close:hover{background:rgba(255,255,255,.22)}
.tkp-type{font-size:17px;font-weight:800;color:#fff;margin-bottom:12px;line-height:1.2}
.tkp-status-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:20px;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s}
.tkp-status-btn:hover{opacity:.88}
.tkp-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.tkp-status-caret{font-size:10px;opacity:.6;margin-left:2px}
/* Panel body */
.tkp-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:8px 0 8px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.tkp-body::-webkit-scrollbar{width:4px}
.tkp-body::-webkit-scrollbar-track{background:transparent}
.tkp-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.tkp-sec{background:#fff;padding:16px 16px}
.tkp-sec-ttl{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
/* Form fields */
.tkp-field{margin-bottom:12px}
.tkp-field:last-child{margin-bottom:0}
.tkp-lbl{display:block;font-size:11px;font-weight:700;color:var(--text-soft);margin-bottom:5px;letter-spacing:.04em;text-transform:uppercase}
.tkp-sel-wrap{position:relative}
.tkp-sel-wrap::after{content:'▾';position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-soft);font-size:12px}
.tkp-inp{width:100%;padding:10px 12px;font-size:14px;font-family:inherit;border:1.5px solid var(--border);border-radius:8px;background:#fff;color:var(--text);-webkit-appearance:none;appearance:none;cursor:pointer;transition:border-color .15s}
.tkp-inp:focus{outline:none;border-color:var(--navy-mid);box-shadow:0 0 0 3px rgba(26,60,110,.08)}
select.tkp-inp{padding-right:28px}
.tkp-inp[disabled]{background:var(--gray-50);color:var(--text-soft);cursor:default;border-color:var(--gray-200)}
.tkp-static{font-size:14px;color:var(--text);padding:6px 0;font-weight:500}
.tkp-static-sub{font-size:12px;color:var(--text-soft);margin-top:1px}
.tkp-pill-btn{padding:4px 12px;border:1.5px solid var(--border);border-radius:20px;background:none;font-size:12px;cursor:pointer;color:var(--text-mid);font-family:inherit;margin-left:8px}
.tkp-pill-btn:hover{border-color:var(--navy);color:var(--navy)}
.tkp-textarea{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:13px;line-height:1.6;resize:vertical;min-height:100px;background:#fff;box-sizing:border-box;color:var(--text);transition:border-color .15s}
.tkp-textarea:focus{outline:none;border-color:var(--navy-mid);box-shadow:0 0 0 3px rgba(26,60,110,.08)}
.tkp-textarea[readonly]{background:var(--gray-50);border-color:transparent;cursor:default;padding:0;resize:none}
.tkp-info-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;color:var(--text-soft)}
.tkp-info-row span:last-child{color:var(--text-mid);font-weight:500}
.tkp-empty{font-size:12px;color:var(--text-soft);font-style:italic;margin-bottom:8px}
.tkp-add-btn{margin-top:8px;padding:7px 16px;border:1.5px solid var(--border);border-radius:20px;background:#fff;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-mid)}
.tkp-add-btn:hover{border-color:var(--navy);color:var(--navy)}
/* Panel footer */
.tkp-footer{display:flex;gap:8px;padding:12px 16px;background:#fff;border-top:1px solid var(--gray-100);flex-shrink:0}

/* ── BEHEER NIEUW TICKET PANEL ─────────────────────────────── */
.bhn-panel{border-radius:20px 0 0 20px;overflow:hidden}
.bhn-hdr{background:linear-gradient(135deg,#f5d840 0%,#f0c800 100%);padding:32px 16px 22px;flex-shrink:0;position:relative;text-align:center}
.bhn-logo{width:140px;height:90px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;background:transparent;padding:0;overflow:visible}
.bhn-logo img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.bhn-close{position:absolute;top:14px;right:14px;background:rgba(26,29,46,.18);border:none;color:var(--navy);font-size:20px;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;transition:background .15s;flex-shrink:0;z-index:2}
.bhn-close:hover{background:rgba(26,29,46,.32);color:#fff}
.bhn-title{font-size:24px;font-weight:800;color:var(--navy);letter-spacing:-.02em;line-height:1.15;text-align:center}
.bhn-sub{display:none}
.bhn-sec{background:#fff;padding:16px;border-radius:12px;margin:0 8px}
.bhn-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bhn-photo-area{display:flex;flex-direction:column;gap:8px}
.tkp-btn-del{padding:11px 14px;border:1.5px solid #fecaca;border-radius:8px;background:none;color:var(--red);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}
.tkp-btn-main{flex:1;padding:11px;border:none;border-radius:8px;background:var(--navy);color:#fff;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer}
.tkp-btn-sec{flex:1;padding:11px;border:1.5px solid var(--border);border-radius:8px;background:#fff;color:var(--text);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer}
/* Comments (reused in panel) */
.tkm-comment{display:flex;gap:10px;margin-bottom:12px}
.tkm-comment-avatar{width:30px;height:30px;border-radius:50%;background:var(--navy);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.tkm-comment-bubble{flex:1;background:var(--gray-50);border-radius:0 10px 10px 10px;padding:8px 12px}
.tkm-comment-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.tkm-comment-author{font-size:11px;font-weight:700;color:var(--navy)}
.tkm-comment-time{font-size:10px;color:var(--text-soft)}
.tkm-comment-text{font-size:13px;color:var(--text);line-height:1.45}
.tkm-no-comments{font-size:12px;color:var(--text-soft);font-style:italic;padding:4px 0 8px}
.tkm-older-btn{display:block;width:100%;padding:7px 12px;margin-bottom:10px;border:1px dashed var(--border);background:var(--gray-50);color:var(--text-soft);font-family:inherit;font-size:12px;font-weight:600;border-radius:8px;cursor:pointer;text-align:center;transition:background .12s}
.tkm-older-btn:hover{background:var(--gray-100);color:var(--text-mid)}
.tkm-comment-input{display:flex;flex-direction:column;gap:8px;background:var(--gray-50);border:1.5px solid var(--border);border-radius:12px;padding:10px}
.tkm-comment-ta{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:13px;min-height:56px;resize:none;box-sizing:border-box;background:#fff;transition:border-color .12s}
.tkm-comment-ta:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(26,29,46,.08)}
.tkm-send-btn{align-self:flex-end;padding:8px 20px;border:none;background:var(--navy);color:#fff;border-radius:8px;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .12s}
.tkm-send-btn:active{opacity:.8}
.tkm-history-hdr{display:flex;justify-content:space-between;align-items:center;margin:14px 0 8px;padding-top:12px;border-top:1px solid var(--border)}
.tkm-history-hdr span:first-child{font-size:11px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em}
.tkm-history-count{font-size:11px;color:var(--text-soft);font-weight:500}
/* Legacy comment styles (keep for other uses) */
.tk-comments-wrap{margin-top:14px}
.tk-comment{background:var(--gray-50);border-left:3px solid var(--navy-light);border-radius:6px;padding:8px 12px;margin-bottom:6px;font-size:12px}
.tk-comment-hdr{font-size:10px;color:var(--text-soft);font-weight:600;margin-bottom:3px;display:flex;justify-content:space-between}
.tk-comment-body{color:var(--text);white-space:pre-wrap;line-height:1.4}
.tk-comment-input{display:flex;gap:6px;margin-top:8px}
.tk-comment-input textarea{flex:1;padding:8px 10px;border:1.5px solid var(--border);border-radius:6px;font-family:inherit;font-size:12px;min-height:38px;resize:vertical}
.tk-comment-send{padding:0 14px;border:none;background:var(--navy);color:#fff;border-radius:6px;font-weight:600;cursor:pointer;font-size:12px}
.tk-modal-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px;margin-bottom:10px}
.tk-modal-photos img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;cursor:pointer;border:1px solid var(--border)}
.tk-modal-photo-wrap{position:relative}
.tk-modal-photo-wrap .tk-photo-rm{position:absolute;top:4px;right:4px;opacity:0;transition:opacity .15s}
.tk-modal-photo-wrap:hover .tk-photo-rm{opacity:1}

/* Beheer-scherm (sidebar layout) */
.tk-beheer-wrap{display:flex;min-height:calc(100vh - 86px)}
.tk-sidebar{width:62px;background:var(--navy);display:flex;flex-direction:column;align-items:center;padding:14px 0;gap:6px;flex-shrink:0}
.tk-sb-btn{width:44px;height:44px;border-radius:10px;border:none;background:transparent;color:rgba(255,255,255,.55);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.tk-sb-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.tk-sb-btn.on{background:var(--gold);color:var(--navy)}
.tk-main{flex:1;padding:14px;overflow-x:hidden;background:var(--bg)}
.tk-toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.tk-toolbar-l{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.tk-toolbar-r{display:flex;gap:8px;align-items:center}
.tk-btn{padding:9px 14px;border:1.5px solid var(--border);background:#fff;border-radius:var(--radius-sm);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;color:var(--navy);display:inline-flex;align-items:center;gap:6px}
.tk-btn:hover{background:var(--gray-50)}
.tk-btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.tk-btn-primary:hover{background:var(--navy-light)}
/* Refresh knop */
.tk-btn-icon{width:34px;height:34px;padding:0;justify-content:center;font-size:17px;border-radius:50%;flex-shrink:0;transition:background .15s,transform .15s}
.tk-btn-icon:hover{background:var(--gray-100)}
.tk-btn-icon.spinning{animation:tkRefreshSpin .7s linear infinite}
@keyframes tkRefreshSpin{to{transform:rotate(360deg)}}
.tk-refresh-info{font-size:11px;color:var(--text-soft);white-space:nowrap;font-weight:500}
.tk-group-hdr{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft);background:var(--gray-100);padding:8px 12px;border-radius:6px;margin-bottom:6px;margin-top:10px;display:flex;justify-content:space-between}
.tk-group-hdr:first-child{margin-top:0}
.tk-group-hdr-count{background:#fff;color:var(--navy);padding:1px 8px;border-radius:10px;font-size:10px}

/* Kanban */
.tk-kanban{display:flex;gap:10px;overflow-x:auto;padding-bottom:14px}
.tk-kan-col{flex:0 0 240px;background:var(--gray-100);border-radius:8px;padding:10px;min-height:200px}
.tk-kan-col-hdr{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-soft);margin-bottom:8px;display:flex;justify-content:space-between;letter-spacing:.05em}
.tk-kan-col.drag-over{background:var(--gold-light);outline:2px dashed var(--gold)}
.tk-kan-card{background:#fff;border-radius:6px;padding:10px;margin-bottom:6px;box-shadow:0 1px 3px rgba(0,0,0,.08);cursor:grab;border-left:3px solid var(--blue-mid)}
.tk-kan-card.dragging{opacity:.4}
.tk-kan-card-id{font-size:10px;color:var(--text-soft);font-weight:700;margin-bottom:2px;font-family:'DM Mono',monospace}
.tk-kan-card-title{font-size:12px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tk-kan-card-meta{font-size:10px;color:var(--text-soft);display:flex;justify-content:space-between;align-items:center;gap:4px}

/* Beheer-modal */
.tk-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tk-edit-grid .full{grid-column:1/-1}
.tk-edit-fld{margin-bottom:10px}
.tk-edit-fld label{display:block;font-size:10px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.tk-edit-fld input,.tk-edit-fld select,.tk-edit-fld textarea{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:6px;font-family:inherit;font-size:13px;background:var(--gray-50)}

/* Project picker tabs */
.tk-tabs{display:flex;border-bottom:1.5px solid var(--border);margin-bottom:12px}
.tk-tab{flex:1;padding:10px;border:none;background:none;font-family:inherit;font-size:13px;font-weight:600;color:var(--text-soft);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px}
.tk-tab.on{color:var(--navy);border-bottom-color:var(--navy)}
.tk-proj-row{padding:10px 12px;border:1.5px solid var(--border);border-radius:6px;margin-bottom:6px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .12s;background:#fff}
.tk-proj-row:hover{border-color:var(--navy);background:var(--blue-pale)}
.tk-proj-row.selected{border-color:var(--green);background:var(--green-light)}
.tk-proj-row .nm{font-size:13px;font-weight:600;color:var(--navy)}
.tk-proj-row .sub{font-size:11px;color:var(--text-soft)}
.tk-proj-pill-act{font-size:9px;font-weight:700;background:var(--green-light);color:var(--green);padding:2px 7px;border-radius:10px}
.tk-proj-pill-inact{font-size:9px;font-weight:700;background:var(--gray-100);color:var(--text-soft);padding:2px 7px;border-radius:10px}

/* Dashboard tiles */
.tk-dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:14px}
.tk-dash-tile{background:#fff;border-radius:var(--radius-sm);padding:14px;box-shadow:var(--shadow);border-left:4px solid var(--navy);cursor:pointer;transition:transform .1s}
.tk-dash-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.tk-dash-tile.t-open{border-left-color:var(--blue-mid)}
.tk-dash-tile.t-prog{border-left-color:var(--gold)}
.tk-dash-tile.t-wait{border-left-color:var(--orange)}
.tk-dash-tile.t-resolved{border-left-color:var(--green)}
.tk-dash-tile.t-closed{border-left-color:var(--gray-400)}
.tk-dash-tile.t-urgent{border-left-color:var(--red)}
.tk-dash-tile-lbl{font-size:11px;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em}
.tk-dash-tile-val{font-size:28px;font-weight:700;color:var(--navy);margin-top:4px}
.tk-empty{padding:36px 20px;text-align:center;color:var(--text-soft);background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow)}
.tk-empty .ico{margin-bottom:10px;display:flex;justify-content:center;color:var(--gray-300)}
.tk-empty .ico svg{width:36px;height:36px;display:block}

/* Lightbox voor foto's */
.tk-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;display:none;align-items:center;justify-content:center;padding:20px}
.tk-lightbox.open{display:flex}
.tk-lightbox img{max-width:100%;max-height:90vh;border-radius:8px}
.tk-lightbox .close{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;font-size:32px;cursor:pointer}
@media (max-width:600px){.tk-edit-grid{grid-template-columns:1fr}.tk-sidebar{width:48px}.tk-sb-btn{width:36px;height:36px;font-size:17px}}

/* ── CLICKUP-STYLE TABLE (dense grid) ── */
.cu-tbl{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow)}
.cu-thead{display:grid;background:#fafbfd;border-bottom:1.5px solid var(--border);position:sticky;top:0;z-index:5;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft)}
.cu-thead .cu-cell{padding:6px 10px;border-right:1px solid var(--gray-100);user-select:none;cursor:default}
.cu-thead .cu-cell:last-child{border-right:none}
.cu-row{display:grid;border-bottom:1px solid var(--gray-100);font-size:12px;align-items:center;cursor:pointer;transition:background .08s}
.cu-row:last-child{border-bottom:none}
.cu-row:hover{background:#f5f8ff}
.cu-cell{padding:4px 10px;border-right:1px solid var(--gray-100);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.cu-cell:last-child{border-right:none}
.cu-cell.subj{white-space:normal;line-height:1.35;font-weight:500;color:var(--text)}
.cu-cell.id{font-family:'DM Mono',monospace;font-size:10.5px;color:var(--text-soft);font-weight:700}
.cu-cell.proj{font-weight:600;color:var(--navy)}
/* Grid templates per view */
.cu-tbl.tbl-7{}
.cu-tbl.tbl-7 .cu-thead,.cu-tbl.tbl-7 .cu-row{grid-template-columns:84px minmax(180px,2.4fr) 116px 78px 140px 140px 100px}
.cu-tbl.tbl-8 .cu-thead,.cu-tbl.tbl-8 .cu-row{grid-template-columns:84px minmax(180px,2.4fr) 116px 78px 140px 140px 130px 100px}
@media (max-width:760px){.cu-tbl{display:none}.cu-cards{display:flex !important}}
@media (min-width:761px){.cu-cards{display:none !important}}

/* Status chips ClickUp-stijl */
.cu-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:12px;font-size:10.5px;font-weight:700;line-height:1.3;letter-spacing:.01em;white-space:nowrap}
.cu-chip::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cu-chip.s-Open{background:#e0ecff;color:#1e40af}.cu-chip.s-Open::before{background:#3b82f6}
.cu-chip.s-In-behandeling{background:#fff3c2;color:#854d0e}.cu-chip.s-In-behandeling::before{background:#eab308}
.cu-chip.s-Wacht-op-klant{background:#ffe2c2;color:#9a3412}.cu-chip.s-Wacht-op-klant::before{background:#f97316}
.cu-chip.s-Opgelost{background:#d1fadf;color:#14532d}.cu-chip.s-Opgelost::before{background:#16a34a}
.cu-chip.s-Gesloten{background:#e5e7eb;color:#374151}.cu-chip.s-Gesloten::before{background:#6b7280}
/* ── IT SUPPORT FORM (gele hero + gecentreerde card) ── */
.tk-form-screen{background:#f7f8fb;min-height:100vh}
.tk-form-hero{background:linear-gradient(135deg,#f5d840 0%,#f0c800 100%);clip-path:polygon(0 0,100% 0,100% calc(100% - 28px),0 100%);padding:24px 16px 52px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;min-height:200px}
.tk-form-back{position:absolute;top:14px;left:14px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.85);border:none;color:var(--navy);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 2px 6px rgba(0,0,0,.06);transition:background .15s}
.tk-form-back:hover{background:#fff}
.tk-form-logo{width:120px;height:120px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.tk-form-logo img{width:100%;height:100%;object-fit:contain;transform:scale(1.42);transform-origin:center}
.tk-form-eyebrow{font-size:10px;font-weight:700;letter-spacing:.22em;color:rgba(15,39,68,.78);text-transform:uppercase;margin-top:2px}
.tk-form-body{padding:0 16px 110px;margin-top:-22px;position:relative;z-index:2}
.tk-form-card{max-width:640px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px 24px 20px;box-shadow:0 4px 20px rgba(15,39,68,.06)}
.tk-form-card-hdr{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--gray-100)}
.tk-form-card h2{font-size:18px;font-weight:700;color:var(--navy);letter-spacing:-.01em;line-height:1.2}
.tk-form-card .ttl-sub{font-size:12px;color:var(--text-soft);margin-top:4px;line-height:1.4}
.tk-form-actions{display:flex;gap:10px;margin-top:18px;padding-top:14px;border-top:1px solid var(--gray-100)}
.tk-form-actions .tk-btn{flex:1;padding:11px 16px}
.tk-form-actions .tk-btn-primary{flex:2}
@media (max-width:600px){.tk-form-card{padding:18px 18px 16px;border-radius:12px}.tk-form-logo{width:100px;height:100px}.tk-form-hero{min-height:170px;padding:20px 12px 46px}}

.cu-chip.cu-chip-dyn::before{display:none}
.cu-chip.cu-chip-empty{background:transparent;color:var(--text-soft);font-style:italic;font-weight:500;border:1px dashed var(--border-strong);padding:2px 8px}
.cu-chip.cu-chip-empty::before{display:none}
.cu-chip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;display:inline-block}
.cu-dash-tile.cu-dash-tile-dyn::before{background:var(--bar,#0f2744)}

.cu-prio{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600}
.cu-prio .ico{font-size:13px;line-height:1}
.cu-prio.high{color:#dc2626}
.cu-prio.mid{color:#ca8a04}
.cu-prio.low{color:#16a34a}

/* Avatars */
.cu-avatar{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:0}
.cu-user{display:inline-flex;align-items:center;gap:6px;min-width:0;line-height:1}
.cu-user .nm{font-size:12px;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.cu-user.unassigned .nm{color:var(--text-soft);font-style:italic;font-weight:400}

/* Group rows (collapsible) */
.cu-group{margin-bottom:10px}
.cu-group-hdr{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:11px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;user-select:none;box-shadow:var(--shadow)}
.cu-group-hdr:hover{background:#fafbfd}
.cu-group-chev{font-size:10px;color:var(--text-soft);transition:transform .15s;display:inline-block;width:10px}
.cu-group.collapsed .cu-group-chev{transform:rotate(-90deg)}
.cu-group.collapsed .cu-tbl,.cu-group.collapsed .cu-cards{display:none}
.cu-group-bar{width:3px;height:14px;border-radius:2px;background:var(--navy)}
.cu-group-cnt{margin-left:auto;background:var(--gray-100);color:var(--text-mid);padding:1px 8px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:0;text-transform:none}

/* Mobile fallback cards (≤760px) */
.cu-cards{display:none;flex-direction:column;gap:6px}
.cu-mc{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;box-shadow:0 1px 3px rgba(0,0,0,.05);cursor:pointer}
.cu-mc:hover{background:#fafbfd}
.cu-mc-row{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-bottom:4px}
.cu-mc-id{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-soft);font-weight:700}
.cu-mc-subj{font-size:13px;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cu-mc-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:11px;color:var(--text-soft)}

/* ClickUp-stijl Kanban */
.cu-kan{display:flex;gap:10px;overflow-x:auto;padding-bottom:14px;align-items:flex-start}
.cu-kan-col{flex:0 0 256px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - 200px)}
.cu-kan-col-bar{height:3px}
.cu-kan-col-bar.s-Open{background:#3b82f6}
.cu-kan-col-bar.s-In-behandeling{background:#eab308}
.cu-kan-col-bar.s-Wacht-op-klant{background:#f97316}
.cu-kan-col-bar.s-Opgelost{background:#16a34a}
.cu-kan-col-bar.s-Gesloten{background:#6b7280}
.cu-kan-col-hdr{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;font-size:11px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--gray-100)}
.cu-kan-col-cnt{background:var(--gray-100);color:var(--text-mid);padding:1px 7px;border-radius:9px;font-size:10px;font-weight:700;letter-spacing:0;text-transform:none}
.cu-kan-col-body{padding:8px;flex:1;overflow-y:auto;min-height:120px}
.cu-kan-col.drag-over{background:#f5f8ff;outline:2px dashed var(--blue-mid);outline-offset:-2px}
.cu-kan-card{background:#fff;border:1px solid var(--border);border-radius:6px;padding:9px 10px;margin-bottom:6px;cursor:grab;box-shadow:0 1px 2px rgba(0,0,0,.04);transition:box-shadow .12s,transform .08s}
.cu-kan-card:hover{box-shadow:0 2px 8px rgba(15,39,68,.1)}
.cu-kan-card:active{cursor:grabbing}
.cu-kan-card.dragging{opacity:.4;transform:rotate(1.5deg)}
.cu-kan-card-id{font-family:'DM Mono',monospace;font-size:9.5px;color:var(--text-soft);font-weight:700;margin-bottom:3px;display:flex;justify-content:space-between;align-items:center}
.cu-kan-card-title{font-size:12px;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:7px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cu-kan-card-foot{display:flex;justify-content:space-between;align-items:center;gap:6px}
.cu-kan-col-empty{font-size:11px;color:var(--text-soft);text-align:center;padding:18px 8px;font-style:italic}

/* ClickUp-stijl Dashboard */
.cu-dash{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:14px}
.cu-dash-tile{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;cursor:pointer;transition:all .1s;position:relative;overflow:hidden}
.cu-dash-tile:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:0 2px 8px rgba(15,39,68,.08)}
.cu-dash-tile::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--navy)}
.cu-dash-tile.t-open::before{background:#3b82f6}
.cu-dash-tile.t-prog::before{background:#eab308}
.cu-dash-tile.t-wait::before{background:#f97316}
.cu-dash-tile.t-resolved::before{background:#16a34a}
.cu-dash-tile.t-closed::before{background:#6b7280}
.cu-dash-tile.t-urgent::before{background:#dc2626}
.cu-dash-tile-lbl{font-size:9.5px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.cu-dash-tile-val{font-size:22px;font-weight:700;color:var(--navy);line-height:1;letter-spacing:-.02em}
.cu-dash-tile-sub{font-size:10px;color:var(--text-soft);margin-top:2px}
.cu-dash-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cu-dash-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px}
.cu-dash-card-ttl{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--gray-100)}
.cu-dash-line{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:12px}
.cu-dash-line .l{color:var(--text-mid)}
.cu-dash-line .r{color:var(--navy);font-weight:700}
@media (max-width:600px){.cu-dash-row{grid-template-columns:1fr}}

/* ── BEHEER SCREEN: ClickUp-style frame ── */
.tk-beheer-screen{background:#f7f8fb}
.tk-beheer-screen .tk-beheer-wrap{display:flex;min-height:calc(100vh - 60px);background:#f7f8fb}
.tk-bh-topbar{background:#fff;border-bottom:1px solid var(--border);padding:10px 16px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:50;box-shadow:0 1px 0 rgba(15,39,68,.04)}
.tk-bh-back{width:32px;height:32px;border-radius:8px;background:transparent;border:none;color:var(--text-mid);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.tk-bh-back:hover{background:var(--gray-100)}
.tk-bh-logo{width:38px;height:38px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tk-bh-logo img{width:100%;height:100%;object-fit:contain}
.tk-bh-title{flex:1;font-size:15px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.tk-bh-sub{font-weight:500;color:var(--text-soft);font-size:13px;margin-left:4px}
.tk-bh-user{font-size:12px;color:var(--text-soft)}

/* New sidebar (200px wide on desktop) */
.tk-sidebar2{width:220px;background:#fff;border-right:1px solid var(--border);padding:14px 8px;display:flex;flex-direction:column;gap:14px;flex-shrink:0;overflow-y:auto;max-height:calc(100vh - 60px);position:sticky;top:60px;align-self:flex-start}
.tk-sb-section{display:flex;flex-direction:column;gap:2px}
.tk-sb-section-ttl{font-size:10px;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;padding:4px 10px 4px}
.tk-sb-section-hdr{display:flex;align-items:center;gap:6px;padding:4px 10px;cursor:pointer;border-radius:6px;user-select:none}
.tk-sb-section-hdr:hover{background:var(--gray-50)}
.tk-sb-chev{font-size:9px;color:var(--text-soft);transition:transform .15s;width:10px;display:inline-block}
.tk-sb-section.collapsed .tk-sb-chev{transform:rotate(-90deg)}
.tk-sb-section.collapsed .tk-sb-list{display:none}
.tk-sb-add{margin-left:auto;background:none;border:none;color:var(--text-soft);cursor:pointer;font-size:13px;width:22px;height:22px;border-radius:5px;display:flex;align-items:center;justify-content:center;line-height:1}
.tk-sb-add:hover{background:var(--gray-100);color:var(--navy)}
.tk-sb-link{display:flex;align-items:center;gap:8px;padding:7px 10px;border:none;background:transparent;color:var(--text-mid);font-family:inherit;font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;text-align:left;width:100%}
.tk-sb-link:hover{background:var(--gray-50);color:var(--navy)}
.tk-sb-link.on{background:#eef3ff;color:var(--navy);font-weight:600}
.tk-sb-link .ic{font-size:14px;width:18px;text-align:center;flex-shrink:0;color:var(--text-soft)}
.tk-sb-link.on .ic{color:var(--navy)}
.tk-sb-list{display:flex;flex-direction:column;gap:1px}
.tk-sb-proj{display:flex;align-items:center;gap:8px;padding:6px 10px 6px 22px;font-size:12.5px;color:var(--text-mid);border-radius:6px;cursor:pointer;border:none;background:transparent;font-family:inherit;text-align:left;width:100%;font-weight:500}
.tk-sb-proj:hover{background:var(--gray-50)}
.tk-sb-proj.on{background:#eef3ff;color:var(--navy);font-weight:600}
.tk-sb-proj-dot{width:8px;height:8px;border-radius:50%;background:var(--navy-light);flex-shrink:0}
.tk-sb-proj-cnt{margin-left:auto;font-size:10px;color:var(--text-soft);background:var(--gray-100);padding:1px 6px;border-radius:8px;font-weight:600}
.tk-sb-proj.on .tk-sb-proj-cnt{background:#dbeafe;color:#1e40af}

.tk-main2{flex:1;padding:14px 18px;overflow-x:hidden;background:#f7f8fb;min-width:0}
.tk-toolbar2{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.tk-sel{padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;font-family:inherit;font-size:13px;color:var(--text-mid);cursor:pointer}
.tk-sel:hover{border-color:var(--border-strong)}

/* Mobile: collapse sidebar */
@media (max-width:760px){
  .tk-sidebar2{position:fixed;left:0;top:60px;bottom:0;height:auto;max-height:none;z-index:90;transform:translateX(-100%);transition:transform .2s;box-shadow:2px 0 12px rgba(0,0,0,.1);width:240px}
  .tk-sidebar2.open{transform:translateX(0)}
  .tk-bh-back{margin-right:auto}
  .tk-main2{padding:12px}
}

/* Hide bottom-nav when on beheer screen */
.tk-beheer-screen + #bottom-nav,#s-support-beheer.active~#bottom-nav{display:none !important}

/* Inline edit popover */
.cu-popover{position:fixed;display:none;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px rgba(15,39,68,.18);z-index:400;min-width:200px;max-width:280px;max-height:340px;overflow-y:auto;padding:6px;font-size:13px}
.cu-popover.open{display:block}
.cu-pop-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;cursor:pointer;color:var(--text);font-weight:500}
.cu-pop-item:hover{background:var(--gray-50)}
.cu-pop-item.on{background:#eef3ff;color:var(--navy);font-weight:600}
/* Status-chips in dropdown: altijd witte achtergrond + zwarte tekst, enkel de stip behoudt de kleur */
.cu-pop-item .cu-chip-dyn{background:transparent!important;color:var(--text)!important;}
.cu-pop-search{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:12px;margin-bottom:4px;background:var(--gray-50)}
.cu-pop-search:focus{outline:none;border-color:var(--navy-light);background:#fff}
.cu-pop-empty{padding:10px;text-align:center;color:var(--text-soft);font-size:12px;font-style:italic}
.cu-pop-divider{height:1px;background:var(--border);margin:4px 0}
.cu-pop-clear{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:6px;cursor:pointer;color:var(--text-soft);font-size:12px;font-style:italic}
.cu-pop-clear:hover{background:var(--gray-50);color:var(--red)}

/* Editable cell hover state */
.cu-cell.editable{cursor:pointer}
.cu-cell.editable:hover{background:#eef3ff;outline:1.5px solid var(--blue-light);outline-offset:-1px;border-radius:4px}

/* Interne prio chip */
.cu-iprio{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:700;line-height:1.3;white-space:nowrap;background:var(--gray-100);color:var(--text-mid)}
.cu-iprio::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0;background:currentColor;opacity:.85}
.cu-iprio.empty{color:var(--text-soft);font-weight:500;background:transparent;padding:0}
.cu-iprio.empty::before{display:none}

/* Lightere grid for beheer */
.tk-main2 .cu-tbl{box-shadow:0 1px 0 rgba(15,39,68,.04)}
.tk-main2 .cu-thead{background:#fafbfd}
.tk-main2 .cu-row:hover{background:#f5f8ff}

/* Update grid templates with interne prio column */
.cu-tbl.tbl-9 .cu-thead,.cu-tbl.tbl-9 .cu-row{grid-template-columns:80px minmax(180px,2.4fr) 110px 76px 110px 130px 130px 120px 100px}
@media (max-width:760px){.tk-bh-topbar{padding:10px 12px;gap:10px}.tk-bh-title{font-size:14px}.tk-bh-sub{display:none}}

/* Overzicht-scherm — beheer-stijl zonder sidebar, gecentreerd */
.tk-overview-main{max-width:1200px;margin:0 auto;width:100%;padding:18px 22px}
.tk-overview-main .tk-toolbar2{margin-bottom:10px}
.tk-ovz-search{padding:9px 14px 9px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;font-family:inherit;font-size:13px;width:100%;min-width:240px;color:var(--text);transition:all .12s}
.tk-ovz-search:focus{outline:none;border-color:var(--navy-light);box-shadow:0 0 0 3px rgba(41,82,163,.1)}
.tk-overview-main .tk-toolbar-l{flex:1;max-width:380px}
.tk-filters-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:14px;box-shadow:0 1px 3px rgba(15,39,68,.04);display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.tk-filters-card select{padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:var(--gray-50);font-family:inherit;font-size:13px;color:var(--text-mid);cursor:pointer;transition:all .12s}
.tk-filters-card select:hover{border-color:var(--border-strong);background:#fff}
.tk-filters-card select:focus{outline:none;border-color:var(--navy-light);background:#fff;box-shadow:0 0 0 3px rgba(41,82,163,.08)}
@media (max-width:760px){.tk-overview-main{padding:12px}.tk-overview-main .tk-toolbar-l{max-width:none}.tk-filters-card{grid-template-columns:1fr 1fr}}
.calc-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold),#facc15);transition:width .3s ease;width:0%}