/* Installateur-portaal — donker thema (in lijn met het klant-CP). */
:root{
  --bg:#0a0a0a;--surface:#171717;--surface2:#1f1f1f;--line:#262626;--line2:#404040;
  --ink:#f5f5f5;--muted:#a3a3a3;--muted2:#737373;
  --green:#7D9F26;--green-h:#8cb22b;--green-ink:#04210F;--teal:#1AA6B7;--brand:#7D9F26;
  --danger:#ff8a7a;--radius:14px;--font:'Manrope',system-ui,sans-serif;
  --shadow:0 1px 2px rgba(0,0,0,.4),0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}[hidden]{display:none !important}
/* Donkere scrollbars in lijn met het thema (geen witte OS-balken). */
*{scrollbar-width:thin;scrollbar-color:var(--line2) transparent}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--muted2)}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
button{font:inherit;cursor:pointer}
input{font:inherit;background:#0f0f0f;color:var(--ink)}
.logo-mark{width:32px;height:32px;border-radius:9px;flex:none}
.brand-img{height:34px;width:auto;max-width:170px;border-radius:6px;flex:none;display:block;object-fit:contain}
.auth-brand .brand-img{height:40px;max-width:200px}

.btn-primary{background:var(--green);color:var(--green-ink);border:none;border-radius:10px;padding:.65rem 1.15rem;font-weight:700;font-size:.9rem}
.btn-primary:hover{background:var(--green-h)}
.btn-primary:disabled,.btn-primary[disabled]{opacity:.45;cursor:not-allowed;background:var(--green)}
.btn-primary:disabled:hover,.btn-primary[disabled]:hover{background:var(--green)}
.btn-block{width:100%}
.btn-ghost{background:var(--surface);border:1px solid var(--line2);color:var(--ink);border-radius:10px;padding:.5rem .9rem;font-weight:700;font-size:.86rem}
.btn-ghost:hover{border-color:var(--muted2)}

/* auth */
.auth{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(900px 480px at 75% -10%,rgba(125,159,38,.16),transparent 60%),var(--bg)}
.auth-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:2rem;width:min(400px,92vw);box-shadow:var(--shadow)}
.auth-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1.2rem}
.auth-brand b{display:block;font-size:1.1rem}.auth-brand span{font-size:.78rem;color:var(--muted)}
.auth-card h2{font-size:1.15rem;margin:0 0 .4rem}
.auth-card p.sub{color:var(--muted);font-size:.88rem;margin:0 0 1rem}
.auth-card form{display:flex;flex-direction:column;gap:.85rem}
.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.82rem;font-weight:700;color:var(--muted)}
.auth-card input{padding:.7rem .85rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink)}
.auth-card input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(125,159,38,.25)}
.auth-err{color:var(--danger);font-size:.85rem;min-height:1rem;margin:.2rem 0 0}
.auth-ok{background:rgba(125,159,38,.14);border:1px solid rgba(125,159,38,.4);color:#a8c94a;border-radius:10px;padding:.8rem 1rem;font-size:.9rem}
.auth-alt{font-size:.84rem;color:var(--muted);margin-top:.9rem;text-align:center}
.auth-alt a{color:var(--green);font-weight:700;cursor:pointer}

/* app — sidebar-layout, gelijk aan het klant-CP */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.side{background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:1.1rem .8rem;gap:.2rem;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:.55rem;padding:.4rem .5rem 1.3rem}
.side-brand b{font-size:1rem}.side-brand small{color:var(--brand);font-weight:800;margin-left:auto;font-size:.72rem;letter-spacing:.08em}
.side nav{display:flex;flex-direction:column;gap:.2rem}
.nav-item{display:flex;align-items:center;gap:.7rem;width:100%;background:none;border:none;color:var(--muted);padding:.68rem .75rem;border-radius:10px;font-weight:600;font-size:.92rem;text-align:left;transition:.12s}
.nav-item svg{width:19px;height:19px;flex:none}
.nav-item:hover{background:var(--bg);color:var(--ink)}
.nav-item.is-active{background:rgba(125,159,38,.16);color:var(--ink)}
.nav-item.is-active svg{color:var(--brand)}
.logout{margin-top:auto;background:none;border:1px solid var(--line2);color:var(--muted);border-radius:10px;padding:.6rem .75rem;font-weight:700;font-size:.88rem}
.logout:hover{color:var(--ink);border-color:var(--muted2)}
.main{padding:1.7rem clamp(1rem,3.5vw,2.6rem);max-width:none}
@media(max-width:840px){.app{grid-template-columns:1fr}.side{position:static;height:auto;flex-direction:row;align-items:center;overflow-x:auto}.side nav{flex-direction:row}.side-brand{padding:0 .6rem 0 0}.logout{margin-top:0;margin-left:auto}}
.pane-head{margin-bottom:1.3rem}
.pane-head .eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted2);font-weight:800}
.pane-head h1{font-size:1.55rem;margin:.25rem 0 0}
.pane-head p{color:var(--muted);margin:.4rem 0 0;font-size:.92rem;max-width:64ch}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.9rem;margin-bottom:1.2rem}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.2rem}
.card .k{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted2);font-weight:800}
.card .v{font-size:1.4rem;font-weight:800;margin-top:.3rem}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.tbl{width:100%;border-collapse:collapse;font-size:.9rem}
.tbl th{text-align:left;padding:.7rem 1rem;color:var(--muted2);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--line);background:var(--surface2)}
.tbl td{padding:.75rem 1rem;border-bottom:1px solid var(--line)}
.tbl tr:last-child td{border-bottom:none}
.tbl .empty{text-align:center;color:var(--muted2);padding:1.8rem}
.badge{border-radius:999px;padding:.15rem .6rem;font-size:.76rem;font-weight:700}
.badge-live{color:#a8c94a;background:rgba(125,159,38,.16)}
.badge-prep{color:var(--teal);background:rgba(26,166,183,.14)}
.tbl a.open{color:var(--green);font-weight:700;text-decoration:none;white-space:nowrap}

/* admin-banner + klant-aanbrengen-formulier */
.imp-banner{background:rgba(224,162,58,.12);border:1px solid rgba(224,162,58,.4);color:#e0a23a;border-radius:10px;padding:.6rem .9rem;font-size:.86rem;font-weight:600;margin-bottom:1.2rem}
.pane-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.pane-head-row .btn-primary{flex:none;white-space:nowrap}
.add-panel{padding:1.3rem;margin-bottom:1.2rem}
.add-panel h3,.modal-box h3{margin:0 0 .3rem;font-size:1rem}
.add-panel .hint,.modal-box .hint{color:var(--muted);font-size:.85rem;margin:0 0 1rem}
.add-panel form,.modal-box form{display:flex;flex-direction:column;gap:.8rem}
.add-panel label,.modal-box label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:700;color:var(--muted)}
.add-panel input,.add-panel textarea,.modal-box input,.modal-box textarea{padding:.6rem .8rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink);font-family:inherit;resize:vertical}
.add-panel input:focus,.add-panel textarea:focus,.modal-box input:focus,.modal-box textarea:focus{outline:none;border-color:var(--green)}
.row2{display:grid;gap:.8rem}@media(min-width:640px){.row2{grid-template-columns:1fr 1fr}}
/* Actieknoppen altijd rechts uitlijnen; status-melding links van de knop. */
.form-foot{display:flex;align-items:center;gap:.7rem;justify-content:flex-end;margin-top:.9rem}
.form-foot .saved{order:-1}
/* Popup-modals (create-formulieren) */
.modal-ov{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:6vh 1rem 2rem;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);overflow-y:auto}
.modal-ov[hidden]{display:none}
.modal-box{width:100%;max-width:540px;background:var(--card,#161616);border:1px solid var(--line2);border-radius:16px;padding:1.4rem 1.5rem 1.5rem;box-shadow:0 24px 64px rgba(0,0,0,.55);animation:modalIn .16s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.modal-head h3{font-size:1.15rem}
.modal-x{background:none;border:0;color:var(--muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .35rem;border-radius:8px}
.modal-x:hover{color:var(--ink);background:rgba(255,255,255,.06)}
.ld-send-row{flex-direction:row!important;align-items:center;gap:.5rem!important;font-weight:600!important;color:var(--ink)!important}
body.modal-open{overflow:hidden}
.saved{font-size:.85rem;color:var(--green);font-weight:700}

/* partner-badge */
.ref-url,.embed-code{width:100%;background:#0f0f0f;color:var(--ink);border:1px solid var(--line2);border-radius:10px;padding:.6rem .8rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem}
.embed-code{resize:vertical}
.badge-preview{display:inline-block}
.tbl .st{border-radius:999px;padding:.15rem .6rem;font-size:.76rem;font-weight:700}
.st-new{color:var(--teal);background:rgba(26,166,183,.14)}
.st-prog{color:#e0a23a;background:rgba(224,162,58,.14)}
.st-won{color:#a8c94a;background:rgba(125,159,38,.16)}
.st-lost{color:var(--muted2);background:rgba(115,115,115,.14)}
.btn-confirm{background:var(--green);color:var(--green-ink);border:none;border-radius:8px;padding:.35rem .7rem;font-weight:700;font-size:.78rem;white-space:nowrap}
.btn-confirm:hover{background:var(--green-h)}
.btn-confirm:disabled{opacity:.5;cursor:not-allowed}
#ld-table tbody tr[data-lead]{cursor:pointer}
.muted{color:var(--muted2)}
.eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted2);font-weight:800}

/* lead-detail (light) */
.ldx-grid{display:grid;grid-template-columns:1fr 320px;gap:1.2rem;align-items:start}
@media(max-width:1000px){.ldx-grid{grid-template-columns:1fr}}
.ldx-tabs{display:flex;gap:.2rem;border-bottom:1px solid var(--line);margin-bottom:1.3rem;flex-wrap:wrap}
.ldx-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);padding:.6rem 1rem;font-weight:700;font-size:.92rem;margin-bottom:-1px}
.ldx-tab:hover{color:var(--ink)}
.ldx-tab.is-active{color:var(--ink);border-bottom-color:var(--brand)}
.tab-ic{width:15px;height:15px;vertical-align:-3px;margin-right:5px}
.list-filter{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem}
.lf-search{flex:0 1 380px;min-width:180px;max-width:380px;background:#0f0f0f;border:1px solid var(--line2);border-radius:9px;color:var(--ink);font-family:inherit;font-size:.86rem;padding:.5rem .75rem}
.lf-search:focus{outline:none;border-color:var(--green)}
.lf-sel{background:#0f0f0f;border:1px solid var(--line2);border-radius:9px;color:var(--ink);font-family:inherit;font-size:.84rem;padding:.5rem .6rem;cursor:pointer}
.lf-sel:focus{outline:none;border-color:var(--green)}
.lf-count{font-size:.8rem;color:var(--muted);margin-left:auto;white-space:nowrap}
.ldx-head-line{font-size:1.05rem;font-weight:800;margin-bottom:.9rem;color:var(--ink)}
.ldx-cards{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
@media(max-width:680px){.ldx-cards{grid-template-columns:1fr}}
.ldx-card{background:var(--surface2);border:1px solid var(--line);border-radius:12px;padding:.85rem}
.ldx-card .k{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted2);font-weight:800;margin-bottom:.35rem}
.ldx-card .v{font-size:.92rem;line-height:1.4;color:var(--ink)}
.ldx-card ul{margin:.1rem 0 0;padding-left:1.05rem;color:var(--ink);font-size:.9rem;line-height:1.45}
.ldx-card .subs{margin-top:.45rem;padding-left:.6rem;border-left:1px solid var(--line2);color:var(--muted);font-size:.82rem;line-height:1.4}
.ldx-kv{display:flex;gap:.6rem;padding:.3rem 0;font-size:.9rem;border-bottom:1px solid var(--line)}
.ldx-kv:last-child{border-bottom:none}
.ldx-kv .k{color:var(--muted2);min-width:90px;flex:none}
.report-dl{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.ldx-tree ol{list-style:none;margin:.7rem 0 0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.ldx-tree li{display:flex;align-items:center;gap:.6rem;font-size:.88rem}
.ldx-tree .chk{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;flex:none;font-size:.7rem;font-weight:800;border:1.5px solid var(--line2);color:var(--muted2)}
.ldx-tree li.done .chk{background:var(--green);border-color:var(--green);color:var(--green-ink)}
.ldx-tree li.current .chk{border-color:var(--green);color:var(--green)}
.ldx-tree li span:last-child{color:var(--muted)}
.ldx-tree li.done span:last-child,.ldx-tree li.current span:last-child{color:var(--ink)}

/* lead-detail: top-acties (transparante knoppen rechtsboven, bv. Dashboard) */
.ldx-top-actions{display:flex;align-items:center;gap:.5rem;flex:1;flex-wrap:wrap;justify-content:flex-end}
.ldx-topbtn{display:inline-flex;align-items:center;gap:.45rem;background:transparent;border:1px solid var(--line2);color:var(--muted);border-radius:10px;padding:.5rem .8rem;font-weight:700;font-size:.84rem}
.ldx-topbtn svg{width:16px;height:16px}
.ldx-topbtn:hover{color:var(--ink);border-color:var(--muted2)}
.ldx-topbtn.is-active{background:rgba(125,159,38,.12);border-color:var(--green);color:var(--ink)}

/* lead-detail: scope-tab (read-only leveromvang) */
.sc-box .sc-h{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--green);font-weight:800;margin:1.1rem 0 .4rem}
.sc-box .sc-h:first-of-type{margin-top:.2rem}
.sc-box .sc-p{font-size:.92rem;line-height:1.5;color:var(--ink);margin:.2rem 0 .6rem}
.sc-box .sc-ul{margin:.2rem 0 .7rem;padding-left:1.2rem}
.sc-box .sc-ul li{font-size:.9rem;line-height:1.45;color:var(--ink);margin:.2rem 0}
.sc-box strong{color:var(--ink);font-weight:700}

/* lead-detail: dashboard-tab (ingebed dashboard) */
.ldx-db-bar{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;padding:.6rem .8rem;border-bottom:1px solid var(--line);background:var(--surface2)}
.ldx-db-url{font-size:.78rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--muted2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:42%}
.ldx-db-devs{display:flex;gap:.2rem;margin-left:auto;background:#0f0f0f;border:1px solid var(--line2);border-radius:9px;padding:.15rem}
.ldx-db-dev{background:none;border:none;border-radius:7px;padding:.3rem .45rem;color:var(--muted);display:grid;place-items:center}
.ldx-db-dev svg{width:18px;height:18px}
.ldx-db-dev.is-active{background:var(--green);color:var(--green-ink)}
.ldx-db-st{font-size:.82rem}
.ldx-db-stage{background:#000;min-height:560px;display:grid;place-items:center;padding:.8rem}
.ldx-db-frame{width:100%;height:560px;border:0;border-radius:8px;background:#0a0a0a;transition:width .2s ease}
.ldx-db-stage[data-device="ipad"] .ldx-db-frame{width:820px;max-width:100%}
.ldx-db-stage[data-device="mobile"] .ldx-db-frame{width:390px;max-width:100%}
.ldx-db-ph{text-align:center;color:var(--muted);max-width:30rem;padding:2.5rem 1rem}
.ldx-db-ph svg{width:42px;height:42px;color:var(--green);margin-bottom:.6rem}
.ldx-db-ph h3{margin:.2rem 0 .5rem;color:var(--ink);font-size:1.05rem}
.ldx-db-ph p{margin:0;font-size:.88rem;line-height:1.5}

/* Feedback-ronde (bouw-wizard): beoordeel-kaart boven de energie-app */
.ldx-fb{border-left:3px solid var(--green);padding:1rem 1.2rem;margin-bottom:12px}
.ldx-fb-ta{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:9px;color:var(--ink);padding:.55rem .7rem;font:inherit;font-size:.88rem;resize:vertical}
.ldx-fb-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:.8rem;flex-wrap:wrap}

/* ---- generieke helpers ---- */
.hint{color:var(--muted);font-size:.85rem}
.btn-link{background:none;border:none;color:var(--green);font-weight:700;font-size:.84rem;padding:0;cursor:pointer}
.btn-link:hover{color:var(--green-h);text-decoration:underline}
.tagpill{display:inline-block;background:var(--surface2);border:1px solid var(--line2);color:var(--muted);border-radius:999px;padding:.1rem .55rem;font-size:.74rem;font-weight:700;margin:.1rem .15rem 0 0}

/* ---- klantenlijst: rij-acties + klant-detail-tabs ---- */
.cl-actions{display:flex;align-items:center;gap:.9rem;justify-content:flex-end;white-space:nowrap}
.cdx-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);padding:.6rem 1rem;font-weight:700;font-size:.92rem;margin-bottom:-1px}
.cdx-tab:hover{color:var(--ink)}
.cdx-tab.is-active{color:var(--ink);border-bottom-color:var(--brand)}

/* ---- dossier: toestellen-editor ---- */
.ct-presence{display:flex;flex-wrap:wrap;gap:.5rem}
/* Toestellen als widgets: op desktop 3 naast elkaar, smallere (1-koloms) velden. */
.ct-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;align-items:start}
/* Binnen elke (smalle) widget blijven Merk/Model en Serienr/Datum op één lijn (2 kolommen). */
.ct-cards .row2{grid-template-columns:1fr 1fr;gap:.55rem}
@media(max-width:1100px){.ct-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.ct-cards{grid-template-columns:1fr}}
.ct-chip{display:inline-flex;align-items:center;gap:.4rem;background:#0f0f0f;border:1px solid var(--line2);border-radius:999px;padding:.4rem .8rem;font-size:.84rem;font-weight:600;color:var(--muted);cursor:pointer}
.ct-chip input{margin:0;accent-color:var(--green)}
.ct-chip.is-on{background:rgba(125,159,38,.16);border-color:var(--green);color:var(--ink)}
.ct-card-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.8rem}
.ct-card-head b{font-size:1rem}
.ct-card label{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;font-weight:700;color:var(--muted);margin-bottom:.6rem}
.ct-card input,.ct-card textarea{padding:.55rem .75rem;border:1px solid var(--line2);border-radius:9px;background:#0f0f0f;color:var(--ink);font-family:inherit;resize:vertical}
.ct-card input:focus,.ct-card textarea:focus{outline:none;border-color:var(--green)}
/* App-logins: wachtwoord-rij (input + tonen-knop naast elkaar). */
.app-pw-row{display:flex;align-items:center;gap:.5rem}
.app-pw-row input{flex:1;min-width:0}
.app-pw-row .app-reveal{flex:none;white-space:nowrap}
.app-card .app-del{color:var(--danger)}
/* App-logins slot-grid (overgenomen uit de klant-CP voor één uniforme layout) */
.cr-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;align-items:start;margin:.2rem 0 .4rem}
@media(max-width:1100px){.cr-slots{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.cr-slots{grid-template-columns:1fr}}
.cr-slot{border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;background:var(--surface2)}
.cr-slot-head{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.55rem}
.cr-slot-head b{font-size:.95rem}
.cr-slot-brand{color:var(--muted2);font-size:.82rem}
.cr-badge{margin-left:auto;font-size:.72rem;font-weight:700;border-radius:999px;padding:.18rem .55rem;white-space:nowrap}
.cr-badge.ok{background:rgba(125,159,38,.16);color:var(--green-h)}
.cr-badge.wait{background:rgba(214,158,46,.16);color:#d69e2e}
.cr-badge.todo{background:var(--surface);color:var(--muted2);border:1px solid var(--line2)}
.cr-f{display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;color:var(--muted);margin-bottom:.5rem}
.cr-f input{font-size:.9rem;padding:.5rem .6rem;border:1px solid var(--line2);border-radius:8px;background:var(--surface);color:var(--ink)}
.cr-pw-row{display:flex;align-items:center;gap:.5rem}
.cr-pw-row input{flex:1;min-width:0}
.cr-pw-row .cr-eye{flex:none}
.cr-slot-foot{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.6rem;justify-content:flex-end}
.cr-slot-foot .saved{order:-1}
.cr-slot-foot .cr-instr-link{order:-3;margin-right:auto;color:var(--green-h);font-weight:700;font-size:.82rem;text-decoration:none;cursor:pointer}
.cr-slot-foot .cr-instr-link:hover{text-decoration:underline}
.cr-slot-foot .btn{padding:.45rem .8rem;font-size:.85rem}
.cr-idem{display:flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--muted);font-weight:600;margin-bottom:.6rem;cursor:pointer}
.cr-idem input{accent-color:var(--green);margin:0}
.cr-slot-wait{font-size:.86rem;color:var(--muted);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}
.cr-slot-wait .crw-txt{flex:1 1 100%}
.cr-meth-q{font-size:.82rem;font-weight:700;color:var(--muted);margin-bottom:.4rem}
.cr-meth-btns{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}
.cr-meth{padding:.55rem .9rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--muted);font-weight:700;font-size:.85rem;cursor:pointer}
.cr-meth:hover{border-color:var(--green);color:var(--ink)}
.cr-meth.is-active{background:rgba(125,159,38,.16);border-color:var(--green);color:var(--ink)}
.cr-eye{display:inline-grid;place-items:center;width:24px;height:22px;border:1px solid var(--line2);background:var(--surface2);color:var(--muted);border-radius:7px;cursor:pointer;padding:0;flex:none}
.cr-eye:hover{color:var(--ink)}
.cr-eye:disabled{opacity:.5;cursor:default}
.cr-btn{background:var(--surface);border:1px solid var(--line2);color:var(--ink);border-radius:9px;padding:.45rem .8rem;font-weight:700;font-size:.85rem;cursor:pointer}
.cr-btn:hover{border-color:var(--muted2)}
.cr-btn.cr-save{background:var(--green);border-color:var(--green);color:var(--green-ink)}
.cr-btn.cr-save:hover{background:var(--green-h)}
.cr-instr-body{font-size:.88rem;color:var(--muted);line-height:1.55}
.cr-instr-body b{color:var(--ink)}
/* Documenten-tab: moderne uploadzone + bestandskaarten. */
.doc-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem;text-align:center;padding:1.6rem 1rem;border:1.5px dashed var(--line2);border-radius:14px;cursor:pointer;transition:.15s;color:var(--muted)}
.doc-drop:hover,.doc-drop.is-over{border-color:var(--green);background:rgba(125,159,38,.07);color:var(--ink)}
.doc-drop-ic{width:34px;height:34px;color:var(--green)}
.doc-drop-t{font-weight:600;color:var(--ink);font-size:.92rem}
.doc-drop-link{color:var(--green);text-decoration:underline}
.doc-drop-sub{font-size:.78rem;color:var(--muted)}
.doc-stage{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.8rem 1rem;border:1px solid var(--line2);border-radius:12px;background:rgba(255,255,255,.02)}
.doc-stage-file{display:flex;align-items:center;gap:.6rem;min-width:0;flex:1}
.doc-stage-ic svg{width:22px;height:22px;color:var(--green)}
.doc-stage-name{font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-stage-act{display:flex;align-items:center;gap:.7rem;flex:none}
.doc-switch{display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;font-size:.86rem;color:var(--muted);flex:none}
.doc-switch input{position:absolute;opacity:0;width:0;height:0}
.doc-switch-tr{width:38px;height:21px;border-radius:21px;background:var(--line2);position:relative;transition:.15s;flex:none}
.doc-switch-tr::after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2.5px;left:2.5px;transition:.15s}
.doc-switch input:checked + .doc-switch-tr{background:var(--green)}
.doc-switch input:checked + .doc-switch-tr::after{transform:translateX(17px)}
.doc-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}
.doc-card{display:flex;align-items:center;gap:.8rem;padding:.6rem .75rem;border:1px solid var(--line2);border-radius:12px;transition:.15s}
.doc-card:hover{border-color:var(--muted2)}
.doc-card-ic{flex:none;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:9px;background:rgba(125,159,38,.1);color:var(--green)}
.doc-card-ic svg{width:20px;height:20px}
.doc-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.12rem}
.doc-card-top{display:flex;align-items:center;gap:.5rem;min-width:0}
.doc-card-name{font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-card-meta{font-size:.78rem;color:var(--muted)}
.doc-pill{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:.1rem .42rem;border-radius:6px;background:var(--line2);color:var(--muted);flex:none}
.doc-pill--shared{background:rgba(125,159,38,.18);color:var(--green)}
.doc-card-act{display:flex;align-items:center;gap:.25rem;flex:none}
.doc-iconbtn{background:transparent;border:none;color:var(--muted);cursor:pointer;padding:.42rem;border-radius:8px;line-height:0;transition:.12s}
.doc-iconbtn svg{width:17px;height:17px}
.doc-iconbtn:hover{background:rgba(255,255,255,.06);color:var(--ink)}
.doc-iconbtn.doc-del:hover{color:var(--danger)}
.doc-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.6rem;color:var(--muted);text-align:center}
.doc-empty svg{width:30px;height:30px;opacity:.5}

/* ---- dossier: app-logins (wachtwoord-reveal) ---- */
.app-secret{display:inline-flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.app-pw{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.86rem;color:var(--ink);background:#0f0f0f;border:1px solid var(--line2);border-radius:7px;padding:.15rem .5rem}
.app-row .ldx-kv a{color:var(--green);text-decoration:none;word-break:break-all}

/* ---- pijplijn (read-only kanban) ---- */
.kanban{display:flex;gap:.8rem;overflow-x:auto;padding-bottom:.8rem;align-items:stretch;width:100%}
.kb-col{flex:1 1 0;min-width:165px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.55rem;display:flex;flex-direction:column}
.kb-col-add{flex:0 0 44px;display:flex;justify-content:center;align-items:flex-start;padding-top:.4rem}
.kbc-add-btn{width:36px;height:36px;border-radius:10px;border:1px dashed var(--line2);background:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center}
.kbc-add-btn svg{width:18px;height:18px}
.kbc-add-btn:hover{border-color:var(--green);color:var(--green)}
.kb-col-head{display:flex;align-items:center;justify-content:space-between;padding:.2rem .35rem .55rem;margin-bottom:.4rem;border-bottom:1px solid var(--line)}
.kb-col-head span:first-child{font-size:.78rem;font-weight:700;color:var(--muted)}
.kb-count{font-size:.72rem;color:var(--muted2)}
.kb-col-body{display:flex;flex-direction:column;gap:.5rem;min-height:30px}
.kb-card{background:var(--surface2);border:1px solid var(--line2);border-radius:9px;padding:.6rem .65rem;cursor:pointer;transition:.12s}
.kb-card:hover{border-color:var(--muted2)}
.kb-card-name{font-size:.86rem;font-weight:700;color:var(--ink)}
.kb-card-sub{font-size:.74rem;color:var(--muted2);margin-top:.15rem}
.kb-empty{color:var(--line2);font-size:.8rem;text-align:center;padding:.4rem}

/* ---- Chats-menu (gesprekkenlijst + chat) ---- */
.ch-layout{display:grid;grid-template-columns:320px 1fr;gap:.9rem;align-items:stretch;height:calc(100vh - 220px);min-height:420px}
@media(max-width:840px){.ch-layout{grid-template-columns:1fr;height:auto}}
.ch-list-wrap{display:flex;flex-direction:column}
.ch-list{overflow-y:auto;flex:1}
.ch-thread{display:flex;flex-direction:column;gap:.2rem;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--line);padding:.7rem .8rem;cursor:pointer;color:var(--ink)}
.ch-thread:hover{background:var(--bg)}
.ch-thread.is-active{background:rgba(125,159,38,.1)}
.ch-th-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.ch-th-name{font-weight:700;font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ch-th-unread{flex:none;min-width:18px;height:18px;padding:0 .35rem;border-radius:999px;background:#ff5a4d;color:#fff;font-size:.68rem;font-weight:800;display:grid;place-items:center}
.ch-th-last{font-size:.78rem;color:var(--muted2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ch-empty{color:var(--muted2);font-size:.86rem;padding:1rem}
.ch-main{display:flex;flex-direction:column}
.ch-empty-pane{margin:auto;color:var(--muted2);font-size:.9rem;padding:2rem;text-align:center}
.ch-pane{display:flex;flex-direction:column;height:100%;min-height:0}
.ch-pane-head{padding:.8rem .9rem;border-bottom:1px solid var(--line);font-size:.95rem}
.ch-pane .ic-log{flex:1;max-height:none;padding:.8rem .9rem;margin:0}
.ch-pane .ic-form{border-top:1px solid var(--line);margin:0}

/* ---- Communicatie (installateur↔klant chat) ---- */
.ic-log{max-height:48vh;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding:.4rem 0 .8rem}
.ic-empty{color:var(--muted2);font-size:.86rem;text-align:center;padding:1.4rem}
.ic-msg{max-width:78%;display:flex;flex-direction:column;gap:.15rem}
.ic-msg.me{align-self:flex-end;align-items:flex-end}
.ic-msg.them{align-self:flex-start;align-items:flex-start}
.ic-bubble{padding:.5rem .8rem;border-radius:14px;font-size:.9rem;line-height:1.4;white-space:pre-wrap;word-break:break-word}
.ic-msg.me .ic-bubble{background:var(--green);color:var(--green-ink);border-bottom-right-radius:5px}
.ic-msg.them .ic-bubble{background:var(--surface2);border:1px solid var(--line2);color:var(--ink);border-bottom-left-radius:5px}
/* Energiebeheer-berichten in de gedeelde chat: eigen accent t.o.v. de klant. */
.ic-msg.them.from-eb .ic-bubble{background:rgba(56,132,196,.10);border-color:rgba(56,132,196,.35)}
/* Kanaalschakelaar (Klant / Carl / Groep) */
.ic-chan{display:flex;gap:.4rem;flex-wrap:wrap}
.ic-chan-btn{position:relative;display:inline-flex;align-items:center;gap:.3rem;background:#0f0f0f;border:1px solid var(--line2);color:var(--muted);border-radius:999px;padding:.3rem .7rem;font-size:.78rem;font-weight:700;cursor:pointer}
.ic-chan-btn:hover{color:var(--ink)}
.ic-chan-btn.is-active{background:rgba(125,159,38,.16);border-color:var(--green);color:var(--green-h)}
.ic-chan-btn .ch-dot{min-width:16px;height:16px;padding:0 .25rem;border-radius:999px;background:var(--green);color:var(--green-ink);font-size:.6rem;font-weight:800;display:inline-grid;place-items:center;line-height:1}
.ic-att{margin-top:.35rem;font-size:.78rem;opacity:.85}
.ic-meta{font-size:.68rem;color:var(--muted2)}
.ic-form{display:flex;gap:.5rem;align-items:flex-end;border-top:1px solid var(--line);padding-top:.7rem}
.ic-form textarea{flex:1;padding:.55rem .75rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink);font-family:inherit;resize:vertical}
.ic-form textarea:focus{outline:none;border-color:var(--green)}
.io-note{width:100%;padding:.6rem .8rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink);font-family:inherit;resize:vertical;line-height:1.5}
.io-note:focus{outline:none;border-color:var(--green)}
.ldx-del{color:var(--danger);border-color:rgba(255,138,122,.4)}
.ldx-del svg{width:17px;height:17px;color:var(--danger)}
.ldx-del:hover{background:rgba(255,138,122,.1);border-color:var(--danger)}
.cdx-info-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-bottom:.6rem}
.cdx-info-contact{background:transparent;border:1px solid var(--line2);color:var(--muted);border-radius:9px;padding:.3rem;line-height:0;cursor:pointer;flex:none}
.cdx-info-contact svg{width:18px;height:18px}
.cdx-info-contact:hover{color:var(--ink);border-color:var(--green)}
.cdx-info-name{font-weight:700;color:var(--ink);font-size:1rem;margin-bottom:.35rem}
.cdx-info-line{color:var(--muted);font-size:.88rem;line-height:1.5;word-break:break-word}

/* ---- Intake-samenvatting (kaarten met categorie-iconen, gespiegeld van MCP) ---- */
.sx-head{display:flex;align-items:center;gap:.6rem;margin:0 0 .85rem;justify-content:space-between}
.sx-head-l{display:flex;align-items:center;gap:.6rem;min-width:0}
.sx-head-edit{flex:none}
.sx-head-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:rgba(125,159,38,.15);color:var(--green);flex:none}
.sx-head-ic svg{width:20px;height:20px}
.sx-head-t{font-size:1.05rem;font-weight:700;color:var(--ink)}
.sx-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
@media(max-width:680px){.sx-grid{grid-template-columns:1fr}}
.sx-card{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.8rem .9rem}
.sx-card-h{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}
.sx-ic{display:inline-grid;place-items:center;flex:none}
.sx-ic svg{width:17px;height:17px}
.sx-lab{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted2);font-weight:700}
.sx-val{font-size:.92rem;color:var(--ink);line-height:1.4}
.sx-ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}
.sx-ul li{display:flex;gap:.5rem;align-items:flex-start;font-size:.9rem;color:var(--ink);line-height:1.4}
.sx-dot{margin-top:.45rem;width:5px;height:5px;border-radius:50%;flex:none}
.sx-subs{list-style:none;margin:.5rem 0 0;padding:0 0 0 .6rem;border-left:1px solid var(--line2);display:flex;flex-direction:column;gap:.15rem}
.sx-subs li{font-size:.82rem;color:var(--muted);line-height:1.4}

/* ---- Onboarding-traject (samenvatting-tab) ---- */
.ob-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}
.ob-prog{font-size:.74rem;color:var(--muted2);font-weight:700}
.ob-bar{height:6px;background:var(--surface2);border:1px solid var(--line);border-radius:99px;overflow:hidden;margin-bottom:.9rem}
.ob-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--teal));border-radius:99px}
.ob-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.ob-step{display:flex;align-items:center;gap:.6rem;font-size:.88rem}
.ob-dot{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;flex:none;font-size:.7rem;font-weight:800;border:1.5px solid var(--line2);color:var(--muted2)}
.ob-step.done .ob-dot{background:var(--green);border-color:var(--green);color:var(--green-ink)}
.ob-step.current .ob-dot{border-color:var(--green);color:var(--green)}
.ob-lab{color:var(--muted)}
.ob-step.done .ob-lab,.ob-step.current .ob-lab{color:var(--ink)}

/* ---- Algemeen-tab: bewerkbare contact + woning/contract ---- */
.ag-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem .8rem}
@media(max-width:640px){.ag-grid{grid-template-columns:1fr}}
/* Algemeen-tab: de twee widgets (Woninggegevens / Energiecontract) naast elkaar,
   met smallere velden (1 kolom binnen elk panel). */
.ag-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}
.ag-cols .ag-grid{grid-template-columns:1fr}
@media(max-width:860px){.ag-cols{grid-template-columns:1fr}}
.ag-f{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;font-weight:700;color:var(--muted)}
.ag-f input,.ag-f select{padding:.55rem .75rem;border:1px solid var(--line2);border-radius:9px;background:#0f0f0f;color:var(--ink);font-family:inherit;font-size:.9rem;font-weight:500}
.ag-f input:focus,.ag-f select:focus{outline:none;border-color:var(--green)}

/* ---- Onboarding-gegevens bewerken ---- */
.sx-edit-row{display:flex;justify-content:flex-end;margin-bottom:.7rem}
.ae-panel label{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;font-weight:700;color:var(--muted);margin-bottom:.6rem}
.ae-panel input,.ae-panel textarea{padding:.55rem .75rem;border:1px solid var(--line2);border-radius:9px;background:#0f0f0f;color:var(--ink);font-family:inherit;resize:vertical}
.ae-panel input:focus,.ae-panel textarea:focus{outline:none;border-color:var(--green)}
.ae-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.9rem;flex-wrap:wrap}
.ae-head-actions{display:flex;align-items:center;gap:.6rem}
.ae-seg{display:flex;align-items:center;gap:.9rem;margin-bottom:.6rem;flex-wrap:wrap}
.ae-seg .ae-radio{flex-direction:row;align-items:center;gap:.35rem;font-size:.86rem;font-weight:600;color:var(--ink);margin-bottom:0}
.ae-seg .ae-radio input{accent-color:var(--green)}
.ae-fields-h{display:flex;align-items:center;justify-content:space-between;margin:.4rem 0 .5rem}
.ae-field{background:var(--surface2);border:1px solid var(--line2);border-radius:10px;padding:.7rem;margin-bottom:.6rem}
.ae-field textarea{width:100%;margin-top:.4rem;margin-bottom:.3rem}

/* ---- Analyse aanvragen ---- */
.ar-warn{display:flex;gap:.6rem;align-items:flex-start;background:rgba(224,162,58,.1);border:1px solid rgba(224,162,58,.4);color:#e6c074;border-radius:10px;padding:.7rem .9rem;font-size:.84rem;line-height:1.5;margin:.2rem 0 .8rem}
.ar-warn b{color:#f0d28a}
.ar-note-l{display:block;margin-top:.7rem;font-size:.78rem;font-weight:700;color:var(--muted)}
.ar-note-l textarea{display:block;width:100%;margin-top:.3rem;padding:.55rem .75rem;border:1px solid var(--line2);border-radius:9px;background:#0f0f0f;color:var(--ink);font-family:inherit;resize:vertical}
.ar-note-l textarea:focus{outline:none;border-color:var(--green)}
.ar-checklist{list-style:none;margin:.6rem 0 .2rem;padding:0;display:flex;flex-direction:column;gap:.5rem}
.ar-ck{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;line-height:1.45}
.ar-ck-dot{flex:0 0 1.3rem;width:1.3rem;height:1.3rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700}
.ar-ck.ok .ar-ck-dot{background:rgba(125,159,38,.18);color:var(--green)}
.ar-ck.todo .ar-ck-dot{background:#1a1a1a;border:1px solid var(--line2);color:var(--muted)}
.ar-ck.ok .ar-ck-lab{color:var(--ink)}
.ar-ck.todo .ar-ck-lab{color:var(--muted)}
.ar-ck-hint{color:#8a8a8a;font-weight:400}
.ar-up{margin-top:.9rem;padding-top:.8rem;border-top:1px solid var(--line2)}
.ar-file{display:block;margin-top:.2rem;font-size:.82rem;color:var(--muted)}
.ld-send-row{display:flex;align-items:center;gap:.5rem;margin-top:.7rem;font-size:.84rem;color:var(--muted);cursor:pointer}
.ld-send-row input{accent-color:var(--green);margin:0}
.ld-act .ld-intake{padding:.32rem .7rem;font-size:.8rem}

/* Dashboard: Huidige stand-widget (1/3) + grafieken (2/3) */
.dash-stand-grid{display:grid;grid-template-columns:minmax(210px,.9fr) 1fr 1fr;gap:1.2rem;align-items:start}
@media(max-width:1100px){.dash-stand-grid{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.dash-stand-grid{grid-template-columns:1fr}}
.dash-stand-grid .chartbox{margin-bottom:0}
.mini-charts{display:flex;flex-direction:column;gap:.9rem}
.mini-c .mini-lab{font-size:.74rem;font-weight:700;margin-bottom:.15rem}
.linechart{width:100%;height:auto;display:block;overflow:visible}
.lc-line{fill:none;stroke-width:2;stroke-linejoin:round;stroke-linecap:round}
.lc-dot{stroke:#111;stroke-width:1.5}
.lc-axis{font-size:8px;fill:#9aa0a6}
.lc-grid{stroke:#1c1c1c;stroke-width:1}
.lc-legend{display:flex;gap:1rem;justify-content:center;margin-top:.6rem;font-size:.76rem;color:#9aa0a6}
.lc-legend span{display:inline-flex;align-items:center;gap:.35rem}
.lc-legend i{display:inline-block;width:1rem;height:0;border-top:2px solid;border-radius:2px}
.stand-widget{background:#111;border:1px solid var(--line2);border-radius:12px;padding:1.1rem 1.2rem}
.sw-h{font-size:.86rem;font-weight:600;color:#dce0e5;margin-bottom:.8rem}
.sw-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;padding:.38rem 0;color:#c7ccd3}
.sw-row b{font-weight:700;font-size:1.05rem}
.sw-pos{color:var(--green)}
.sw-neg{color:#e0a23a}
.sw-net{border-top:1px solid var(--line2);margin-top:.35rem;padding-top:.65rem;color:var(--ink)}
.sw-net b{font-size:1.2rem}
.chartbox{background:#111;border:1px solid var(--line2);border-radius:12px;padding:1rem 1.1rem;margin-bottom:1.2rem}
.chart-h{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;font-size:.86rem;font-weight:600;color:#dce0e5;margin-bottom:.85rem}
.chart-h-txt{min-width:0}
.chart-h-sub{font-weight:400;font-size:.76rem;color:#9aa0a6;margin-left:.4rem}
.chart-per{display:inline-flex;gap:2px;background:#0c0c0c;border:1px solid var(--line2);border-radius:7px;padding:2px;flex:none;align-self:center}
.chart-per button{background:none;border:0;color:#9aa0a6;font-family:inherit;font-size:.66rem;font-weight:700;line-height:1;padding:.22rem .42rem;border-radius:5px;cursor:pointer}
.chart-per button:hover{color:#dce0e5}
.chart-per button.is-on{background:var(--green,#7D9F26);color:#04210F}
.chart-empty{color:#9aa0a6;font-size:.84rem;text-align:center;padding:1.4rem 0;margin:0}
/* In-app dialog */
.ui-dialog-box{max-width:420px}
.ui-dialog-msg{margin:.2rem 0 0;color:var(--ink);font-size:.92rem;line-height:1.5}
.ui-dialog-box .modal-head{margin-bottom:.2rem}
.ui-dialog-input{width:100%;margin-top:.9rem}
.ui-dialog-foot{justify-content:flex-end;margin-top:1.1rem}
/* Klant-analyseaanvragen (lijst-modal vanuit het dashboard) */
.crq-list{display:flex;flex-direction:column;gap:.7rem;max-height:60vh;overflow-y:auto;margin-top:.6rem}
.crq-item{border:1px solid var(--line2);border-radius:12px;padding:.8rem .9rem}
.crq-head{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem}
.crq-date{font-size:.78rem;color:#9aa0a6;flex:none}
.crq-msg{margin:.4rem 0 .7rem;font-size:.9rem;color:var(--ink);white-space:pre-wrap;line-height:1.45}
.crq-act{display:flex;gap:.5rem;justify-content:flex-end}
.crq-act .btn-ghost,.crq-act .btn-primary{font-size:.82rem;padding:.42rem .85rem}
.barh{display:flex;flex-direction:column;gap:.5rem}
.barh-row{display:grid;grid-template-columns:8.5rem 1fr 2rem;align-items:center;gap:.6rem;font-size:.8rem}
.barh-lab{color:#c7ccd3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.barh-track{background:#1a1a1a;border-radius:999px;height:.7rem;overflow:hidden}
.barh-fill{display:block;height:100%;background:linear-gradient(90deg,var(--green),#a8c94a);border-radius:999px}
.barh-val{text-align:right;font-weight:600;color:var(--ink)}
/* Contact-form header (met Bewaren) + audittrail */
.ag-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.7rem}
.ag-head .eyebrow{margin:0}
.audit-list{list-style:none;margin:0;padding:0}
.audit-list>li{display:flex;gap:.9rem;padding:.6rem .9rem;border-bottom:1px solid var(--line2);font-size:.84rem}
.audit-list>li:last-child{border-bottom:none}
.audit-when{flex:0 0 9rem;color:#9aa0a6;font-size:.78rem;white-space:nowrap}
.audit-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}
.audit-body b{font-weight:600;color:var(--ink)}
.audit-detail{color:#9aa0a6;font-size:.8rem;white-space:pre-wrap;word-break:break-word}
.doc-list{display:flex;flex-direction:column}
.doc-item{display:flex;align-items:center;gap:.8rem;padding:.8rem .95rem;border-bottom:1px solid var(--line2)}
.doc-item:last-child{border-bottom:none}
.doc-ic{font-size:1.2rem;flex:none}
.doc-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}
.doc-meta b{font-weight:600;color:var(--ink)}
.doc-date{font-size:.76rem;color:#9aa0a6}
.doc-item .btn-primary,.doc-item .btn-ghost{padding:.4rem .8rem;font-size:.82rem;white-space:nowrap}
.ds-subtabs{display:flex;gap:.2rem;margin-bottom:1rem;border-bottom:1px solid var(--line2);flex-wrap:wrap}
.ds-sub{background:none;border:none;cursor:pointer;padding:.5rem .9rem;font:inherit;font-size:.86rem;color:var(--muted);border-bottom:2px solid transparent}
.ds-sub.is-active{color:var(--ink);border-bottom-color:var(--green);font-weight:600}
.hist-sub{background:none;border:none;cursor:pointer;padding:.5rem .9rem;font:inherit;font-size:.86rem;color:var(--muted);border-bottom:2px solid transparent}
.hist-sub.is-active{color:var(--ink);border-bottom-color:var(--green);font-weight:600}
.note-side-ta{width:100%;background:#0f0f0f;border:1px solid var(--line2);border-radius:9px;color:var(--ink);font-family:inherit;font-size:.84rem;line-height:1.5;padding:.55rem .7rem;resize:vertical}
.note-side-ta:focus{outline:none;border-color:var(--green)}

/* ===== Email Manager ===== */
.em-layout{display:grid;grid-template-columns:260px 1fr;gap:.9rem;align-items:start}
.em-cats{padding:.5rem;display:flex;flex-direction:column;gap:.25rem}
.em-cat{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;text-align:left;background:none;border:1px solid transparent;border-radius:10px;padding:.6rem .7rem;cursor:pointer;color:var(--ink);font-size:.9rem;font-weight:600}
.em-cat:hover{background:var(--surface2)}
.em-cat.is-active{background:rgba(125,159,38,.12);border-color:rgba(125,159,38,.4)}
.em-cat small{color:var(--muted2);font-weight:600;font-size:.72rem}
.em-editor{padding:1.1rem}
.em-ed-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}
.em-ed-head b{font-size:1.05rem}
.em-toggle{font-size:.85rem;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:.4rem}
.em-plan-badge{background:rgba(125,159,38,.15);border:1px solid rgba(125,159,38,.4);color:#a8c94a;border-radius:999px;padding:.1rem .6rem;font-size:.74rem;font-weight:800}
.em-auto{display:flex;flex-direction:column;gap:.35rem;margin:.3rem 0 .4rem;font-size:.86rem;color:var(--ink)}
.em-auto label{display:flex;align-items:center;gap:.4rem}
.em-days{width:64px;padding:.25rem .4rem;border:1px solid var(--line2);border-radius:7px;background:#0f0f0f;color:var(--ink)}
.em-vars{font-size:.74rem;color:var(--muted2);margin-top:.4rem;word-break:break-word}
.em-preview{border:1px solid var(--line);border-radius:10px;padding:.8rem 1rem;background:#fff;color:#0C1A22;font-size:.9rem;line-height:1.5;max-height:280px;overflow:auto}
.em-preview p{margin:0 0 .7rem}.em-preview ul{margin:0 0 .7rem;padding-left:1.2rem}.em-preview a{color:#5a7d10}
.em-foot{display:flex;align-items:center;gap:.8rem;margin-top:.9rem}
.em-hr{border:none;border-top:1px solid var(--line);margin:1.1rem 0}
.em-upsell{background:rgba(26,166,183,.1);border:1px solid rgba(26,166,183,.4);color:#7fcdd8;border-radius:10px;padding:.8rem .9rem;font-size:.86rem;line-height:1.5}
.em-dom-row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.em-dom-row .mp-input{flex:1;min-width:160px}
.em-dom-status{margin:.6rem 0}.em-dom-status .ok{color:var(--green);font-weight:700}.em-dom-status .pending{color:#e6c074;font-weight:700}
.em-recs{display:flex;flex-direction:column;gap:.4rem;margin:.4rem 0}
.em-rec{display:flex;gap:.5rem;align-items:center;background:var(--surface2);border:1px solid var(--line);border-radius:8px;padding:.5rem .6rem;font-size:.74rem;flex-wrap:wrap}
.em-rec-t{font-weight:800;color:var(--muted)}
.em-rec code{font-family:ui-monospace,monospace;color:var(--ink);word-break:break-all}
.em-rec-v{color:var(--muted2)}

/* WYSIWYG markdown-toolbar (gedeeld door editor + popup) */
.md-toolbar{display:flex;gap:.25rem;margin:.3rem 0}
.md-btn{width:30px;height:30px;border:1px solid var(--line2);background:var(--surface);border-radius:7px;color:var(--ink);font-weight:800;cursor:pointer;font-size:.86rem}
.md-btn:hover{border-color:var(--green);color:var(--green)}
.mp-input{width:100%;padding:.55rem .7rem;border:1px solid var(--line2);border-radius:9px;background:#0f0f0f;color:var(--ink);font-family:inherit;font-size:.9rem}
.mp-input:focus{outline:none;border-color:var(--green)}
.mp-area{resize:vertical;line-height:1.5}

/* Mail-popup (modal) */
.mailpop{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}
.mailpop-box{background:var(--surface);border:1px solid var(--line2);border-radius:16px;width:560px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.mailpop-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;border-bottom:1px solid var(--line)}
.mailpop-x{background:none;border:none;color:var(--muted2);font-size:1.4rem;cursor:pointer;line-height:1}
.mailpop-body{padding:1.1rem 1.2rem;overflow:auto}
.mailpop-body .eyebrow{display:block;margin-bottom:.25rem}
.mp-hint{font-size:.76rem;color:var(--muted2);margin:.5rem 0 0;line-height:1.4}
.mailpop-foot{display:flex;align-items:center;gap:.7rem;padding:.9rem 1.2rem;border-top:1px solid var(--line)}
.mailpop-foot .saved{margin-right:auto}
.cl-mail{background:none;border:none;color:var(--muted2);cursor:pointer;padding:.2rem;vertical-align:middle}
.cl-mail:hover{color:var(--green)}
@media(max-width:760px){.em-layout{grid-template-columns:1fr}}
