/* Klant-CP — donker thema (in lijn met de MCP: neutral + groen/teal-accent) */
: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;
  --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}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
/* Donkere scrollbars in lijn met het thema (geen witte OS-balken) — gelijk aan het CPI. */
*{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)}
button{font:inherit;cursor:pointer}
input,select,textarea{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:160px;border-radius:6px;flex:none;display:block;object-fit:contain}
.auth-brand .brand-img{height:40px;max-width:200px}

.btn{border:1px solid transparent;border-radius:10px;padding:.65rem 1.15rem;font-weight:700;font-size:.9rem;transition:.15s}
.btn-primary{background:color-mix(in srgb,var(--green) 76%,#000);color:#fff}
.btn-primary:hover{background:color-mix(in srgb,var(--green) 88%,#000)}
.btn-ghost{background:var(--surface);border-color:var(--line2);color:var(--ink)}
.btn-block{width:100%}
/* In-app dialog (vervangt browser-native alert/confirm/prompt) */
.ui-modal-ov{position:fixed;inset:0;z-index:2000;display:flex;align-items:flex-start;justify-content:center;padding:8vh 1rem 2rem;background:rgba(0,0,0,.62);backdrop-filter:blur(3px);overflow-y:auto}
.ui-modal-box{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--line2);border-radius:16px;padding:1.3rem 1.4rem 1.4rem;box-shadow:0 24px 64px rgba(0,0,0,.55);animation:uiModalIn .16s ease}
@keyframes uiModalIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.ui-dialog-title{margin:0 0 .4rem;font-size:1.1rem;color:var(--ink)}
.ui-dialog-msg{margin:0;color:var(--ink);font-size:.92rem;line-height:1.5}
.ui-dialog-input{width:100%;margin-top:.9rem;padding:.55rem .75rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink)}
.ui-dialog-foot{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1.2rem}
body.ui-modal-open{overflow:hidden}

/* 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-alt{font-size:.84rem;color:var(--muted);margin-top:.9rem;text-align:center}
.auth-alt a{color:var(--green);font-weight:700;cursor:pointer;text-decoration:none}
.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}

/* layout */
.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(--green);font-weight:800;margin-left:auto;font-size:.72rem;letter-spacing:.08em}
.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(--green)}
.nav-badge{margin-left:auto;min-width:18px;height:18px;padding:0 .35rem;border-radius:999px;background:var(--green);color:var(--green-ink);font-size:.68rem;font-weight:800;display:inline-grid;place-items:center;line-height:1}
.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{display:flex;gap:.2rem}.side-brand{padding:0 .6rem 0 0}.logout{margin-top:0;margin-left:auto}}

.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{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;letter-spacing:-.01em}
.pane-head p{color:var(--muted);margin:.4rem 0 0;font-size:.92rem;max-width:62ch}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.9rem;margin-bottom:1.2rem}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.2rem;box-shadow:var(--shadow)}
.card .k{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted2);font-weight:800}
.card .v{font-size:1.05rem;font-weight:800;margin-top:.3rem;word-break:break-word}
.card .v.badge-live{color:var(--green)}

.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow);margin-bottom:1.2rem}
.panel h2{font-size:1.05rem;margin:0 0 .9rem}
.panel h3{font-size:.95rem;margin:1.1rem 0 .6rem}

/* ===== Klantdashboard (home) ===== */
/* Basis-utilities die elders in de CP al gebruikt worden maar nog niet bestonden. */
.muted{color:var(--muted)}
.btn-link{background:none;border:0;color:var(--green-h);font-weight:700;font-size:.86rem;padding:0;cursor:pointer;text-decoration:none}
.btn-link:hover{text-decoration:underline}
/* KPI-kaarten: hergebruik .cards/.card, met sub-regel + CTA-variant. */
.kpi .v{font-size:1.9rem;line-height:1.05;letter-spacing:-.02em}
.kpi .sub{font-size:.82rem;color:var(--muted);margin-top:.35rem;font-weight:600}
.kpi-cta{display:flex;flex-direction:column;justify-content:space-between;gap:.7rem;background:linear-gradient(150deg,rgba(125,159,38,.16),rgba(26,166,183,.12));border-color:rgba(125,159,38,.4)}
.kpi-cta .k{color:var(--green-h)}
.kpi-cta .cta-t{font-size:1rem;font-weight:800;margin-top:.2rem}
.kpi-cta .btn{margin-top:.2rem;align-self:flex-start}
/* KPI's met een actie rechtsboven (Open → / Beheren / Chat) */
.kpi,.kpi-inst{display:flex;flex-direction:column}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}
.kpi-corner{flex:none;padding:.28rem .62rem;font-size:.76rem;border-radius:9px}
.kpi .sub:empty{display:none}
.kpi-inst{background:linear-gradient(150deg,rgba(125,159,38,.16),rgba(26,166,183,.12));border-color:rgba(125,159,38,.4)}
.kpi-inst .k{color:var(--green-h)}
.kpi-inst .cta-t{font-size:1.15rem;font-weight:800;margin:.35rem 0 .2rem;word-break:break-word}
.kpi-inst-action{margin-top:auto;align-self:flex-start}
/* marktgrafiek iets compacter op het dashboard */
#home-market .linechart,#home-today .linechart{max-height:200px;margin:0 auto}
.home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;align-items:start}
@media(max-width:1100px){.home-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.home-grid{grid-template-columns:1fr}}
/* onderste rij: energie-app-teaser links + analyse-banner rechts */
.home-bottom{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;align-items:stretch;margin-top:1.2rem}
@media(max-width:760px){.home-bottom{grid-template-columns:1fr}}
.home-bottom .panel{margin-bottom:0}
.analyse-banner{display:flex;flex-direction:column;gap:.5rem;justify-content:center;background:var(--surface);border:1px solid var(--line2)}
.ab-ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:rgba(125,159,38,.16);flex:none}
.ab-ic svg{width:28px;height:28px;color:var(--green-h)}
.analyse-banner .eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--green-h);font-weight:800}
.analyse-banner h2{margin:.35rem 0 .25rem;font-size:1.2rem}
.analyse-banner p{margin:0;color:var(--muted);font-size:.92rem;max-width:46ch}
.analyse-banner .btn{align-self:flex-start;margin-top:.8rem}
.panel-h{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem;margin:0 0 .9rem}
.panel-h h2{margin:0}
.panel-h .btn-link{font-size:.82rem}
/* feiten-lijst (mijn installatie) */
.fact{display:flex;align-items:flex-start;gap:.7rem;padding:.6rem 0;border-top:1px solid var(--line)}
.fact:first-of-type{border-top:0}
.fact-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:rgba(125,159,38,.14);flex:none;font-size:1rem}
.fact-main{min-width:0;flex:1;display:flex;flex-direction:column}
.fact-t{display:block;font-weight:700;font-size:.92rem}
.fact-s{display:block;font-size:.8rem;color:var(--muted);margin-top:.15rem}
.fact>.btn{flex:none;align-self:center}
.fact-badge{flex:none;font-size:.72rem;font-weight:800;padding:.2rem .5rem;border-radius:999px;align-self:center}
.fact-badge.ok{background:rgba(125,159,38,.16);color:var(--green-h)}
.fact-badge.wait{background:rgba(224,162,58,.16);color:#e0a23a}
.fact-badge.none{background:var(--surface2);color:var(--muted2)}
/* acties-lijst */
.act{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.7rem 0;border-top:1px solid var(--line)}
.act:first-of-type{border-top:0}
.act-t{font-weight:600;font-size:.9rem;min-width:0}
.act .btn{flex:none}
.home-empty{display:flex;align-items:center;gap:.6rem;color:var(--muted);font-size:.9rem;padding:.4rem 0}
.home-empty svg{width:20px;height:20px;color:var(--green);flex:none}
/* documenten-rij (home) */
.hdoc-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 0;border-top:1px solid var(--line)}
.hdoc-row:first-of-type{border-top:0}
.hdoc-meta{min-width:0}
.hdoc-meta b{display:block;font-size:.9rem;word-break:break-word}
.hdoc-meta span{font-size:.78rem;color:var(--muted2)}
/* energie-app teaser (vervaagde voorbeeldwaarden, klik → tarieven) */
.teaser{display:grid;grid-template-columns:300px 1fr;gap:1.6rem;align-items:center;text-decoration:none;color:inherit;cursor:pointer;background:linear-gradient(135deg,rgba(125,159,38,.13),rgba(26,166,183,.10));border:1px solid rgba(125,159,38,.4);transition:.15s}
.teaser:hover{border-color:rgba(125,159,38,.75);box-shadow:0 8px 30px rgba(0,0,0,.35)}
@media(max-width:760px){.teaser{grid-template-columns:1fr}}
.teaser-preview{position:relative;background:#111;border:1px solid var(--line2);border-radius:12px;padding:.3rem .9rem}
.teaser-badge{position:absolute;top:.5rem;right:.6rem;font-size:.62rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,.55);padding:.15rem .45rem;border-radius:6px}
.t-row{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;border-top:1px solid var(--line)}
.t-row:first-child{border-top:0}
.t-ic{width:22px;text-align:center;flex:none;font-size:.95rem}
.t-lab{flex:1;font-size:.82rem;color:var(--muted);font-weight:600;min-width:0}
.t-val{font-weight:800;font-size:.85rem;color:var(--ink);white-space:nowrap}
.teaser-pitch .eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--green-h);font-weight:800}
.teaser-pitch h2{margin:.2rem 0 .3rem;font-size:1.2rem}
.teaser-pitch p{margin:0 0 1rem;color:var(--muted);font-size:.92rem;max-width:54ch}
.teaser-pitch .btn{flex:none;display:inline-block}
/* marktgrafiek (geport van CPI) */
.chartbox{background:#111;border:1px solid var(--line2);border-radius:12px;padding:1rem 1.1rem;position:relative}
.lc-hit{cursor:pointer}
.mk-tt{position:absolute;transform:translate(-50%,-100%);background:#0c0c0c;border:1px solid var(--line2);border-radius:9px;padding:.5rem .65rem;min-width:184px;box-shadow:0 10px 28px rgba(0,0,0,.55);pointer-events:none;z-index:5}
.mk-tt-h{font-size:.74rem;font-weight:800;color:var(--ink);margin-bottom:.35rem;text-transform:capitalize}
.mk-tt-r{display:flex;justify-content:space-between;gap:1rem;font-size:.76rem;color:var(--muted);padding:.1rem 0}
.mk-tt-r span:last-child{color:#dce0e5;font-weight:600;font-variant-numeric:tabular-nums}
.mk-tt-tot{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;margin-top:.35rem;padding-top:.35rem;border-top:1px solid var(--line2);font-size:.78rem;color:var(--muted)}
.mk-tt-tot b{color:var(--green-h);font-size:.84rem;font-variant-numeric:tabular-nums}
.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:var(--muted2);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:var(--muted2);font-family:inherit;font-size:.66rem;font-weight:700;line-height:1;padding:.22rem .42rem;border-radius:5px}
.chart-per button:hover{color:#dce0e5}
.chart-per button.is-on{background:var(--green);color:var(--green-ink)}
.chart-empty{color:var(--muted2);font-size:.84rem;text-align:center;padding:1.4rem 0;margin:0}
.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:var(--muted2)}
.lc-grid{stroke:#1c1c1c;stroke-width:1}
.chart-note{font-size:.74rem;color:var(--muted2);margin:.6rem 0 0;text-align:center}

/* ===== Mijn dossier: 2-koloms layout + sidebar + intake-samenvatting (CPI-stijl) ===== */
.dossier-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:1.4rem;align-items:start}
@media(max-width:980px){.dossier-layout{grid-template-columns:1fr}}
.dossier-main{min-width:0}
.dossier-side{display:flex;flex-direction:column;gap:1rem;position:sticky;top:1rem}
@media(max-width:980px){.dossier-side{position:static}}
.ds-card{margin-bottom:0;padding:1.1rem}
.ds-actions{display:flex;gap:.5rem;flex-wrap:wrap;padding:.8rem}
.ds-actions .btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;white-space:nowrap}
.ds-actions .btn svg{width:15px;height:15px;flex:none}
.cdx-info-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}
.cdx-info-contact{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--surface2);color:var(--muted);flex:none;border:1px solid var(--line2)}
.cdx-info-contact svg{width:17px;height:17px}
button.cdx-info-contact{cursor:pointer;padding:0;transition:.13s}
button.cdx-info-contact:hover{color:var(--green-h);border-color:var(--green)}
.cdx-info-name{font-size:1.05rem;font-weight:800;margin-bottom:.3rem;word-break:break-word}
.cdx-info-line{font-size:.86rem;color:var(--muted);line-height:1.5;word-break:break-word}
.ds-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.ds-steps li{display:flex;align-items:center;gap:.55rem;font-size:.88rem;color:var(--muted2)}
.ds-steps li .chk{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:.7rem;border:1.5px solid var(--line2);color:var(--muted2);flex:none}
.ds-steps li.done{color:var(--ink)}
.ds-steps li.done .chk{background:var(--green);border-color:var(--green);color:var(--green-ink)}
.ds-steps li.current{color:var(--ink);font-weight:700}
.ds-steps li.current .chk{border-color:var(--green);color:var(--green)}
.ds-note{width:100%;padding:.6rem .7rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink);resize:vertical;font-family:inherit;font-size:.88rem}
.ds-note:focus{outline:none;border-color:var(--green)}
.ds-instnote{padding:.9rem 1.1rem;background:rgba(224,162,58,.08);border-color:rgba(224,162,58,.35)}
.ds-instnote p{margin:0;font-size:.88rem;color:var(--muted)}
.ds-instnote b{color:var(--ink)}
/* intake-samenvatting widgets (geport uit CPI) */
.sx-head{display:flex;align-items:center;gap:.6rem;margin:0 0 .85rem;justify-content:space-between;flex-wrap:wrap}
.sx-head-l{display:flex;align-items:center;gap:.6rem;min-width:0}
.sx-head-edit{flex:none;text-decoration: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}
/* toestel-widgets: 3 kolommen + ct-card (geport uit CPI) */
.row2{display:grid;gap:.8rem}@media(min-width:640px){.row2{grid-template-columns:1fr 1fr}}
.ct-presence{display:flex;flex-wrap:wrap;gap:.5rem}
.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-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;align-items:start}
.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-card{margin-bottom:0}
.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{width:100%;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)}
/* Documenten: drag&drop-zone + bestandskaarten (geport uit CPI) */
.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);margin-top:1rem}
.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;justify-content:flex-end}
.doc-list{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-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}

.steps{list-style:none;margin:0;padding:0 0 0 .4rem;border-left:2px solid var(--line2)}
.steps li{position:relative;padding:0 0 1.1rem 1.2rem;font-size:.92rem}
.steps li::before{content:"";position:absolute;left:-7px;top:.3rem;width:10px;height:10px;border-radius:50%;background:var(--green);border:2px solid var(--surface);box-shadow:0 0 0 1px var(--green)}
.steps li b{display:block}
.steps li .when{font-size:.76rem;color:var(--muted2)}
.steps li p{margin:.2rem 0 0;color:var(--muted);font-size:.88rem}
.steps .empty{color:var(--muted2);font-style:italic}
.steps .empty::before{display:none}

/* Vaste projectfases (checklist) */
.phases{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.1rem}
.phase{display:flex;align-items:center;gap:.7rem;padding:.5rem 0}
.phase+.phase{border-top:1px solid var(--line)}
.phase-check{flex:none;display:grid;place-items:center;color:var(--muted2)}
.phase-check svg{width:22px;height:22px}
.phase.is-done .phase-check{color:var(--green)}
.phase-label{font-size:.94rem;color:var(--muted)}
.phase.is-done .phase-label{color:var(--ink);font-weight:600}
.phase-dl{margin-left:.5rem;background:transparent;border:1px solid var(--green);color:var(--green);border-radius:8px;padding:.15rem .55rem;font-size:.78rem;font-weight:700;cursor:pointer;vertical-align:middle}
.phase-dl:hover{background:rgba(125,159,38,.14)}

.analysis-box{background:rgba(125,159,38,.09);border:1px solid rgba(125,159,38,.3);border-radius:10px;padding:.9rem 1.1rem;font-size:.9rem;white-space:pre-wrap;line-height:1.55}
.scope-body .sc-h{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--green);font-weight:800;margin:1.1rem 0 .4rem}
.scope-body .sc-h:first-child{margin-top:.2rem}
.scope-body .sc-p{font-size:.92rem;line-height:1.5;margin:.2rem 0 .6rem}
.scope-body .sc-ul{margin:.2rem 0 .7rem;padding-left:1.2rem}
.scope-body .sc-ul li{font-size:.9rem;line-height:1.45;margin:.2rem 0}
.scope-body strong{font-weight:700}

/* scope-vragenlijst (klant vult in) */
.csf-panel{border-color:rgba(125,159,38,.4);box-shadow:0 0 0 1px rgba(125,159,38,.12)}
.csf-head h2{margin:0 0 .3rem}
.csf-head p{margin:0 0 1rem;color:var(--muted)}
.csf-cat{margin:1.1rem 0}
.csf-cat h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--green);margin:0 0 .6rem;font-weight:800}
/* Wizard-opties in dezelfde stijl als de aanvraag-funnel (volle kaarten), maar dark. */
.csf-item{background:none;border:none;padding:0;margin:0}
.csf-q{font-weight:800;font-size:1.18rem;line-height:1.3;margin:0 0 .25rem}
.csf-help{font-size:.88rem;color:var(--muted);margin-bottom:1rem;line-height:1.5}
.csf-opts{display:grid;gap:.55rem;margin:1rem 0 1.1rem}
.csf-opt{position:relative;display:flex;align-items:center;gap:.8rem;width:100%;text-align:left;
  padding:.95rem 1.05rem;border:1.5px solid var(--line2);border-radius:12px;background:#0f0f0f;color:var(--ink);
  font:inherit;font-size:1rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,transform .05s}
.csf-opt:hover{border-color:var(--green);background:#12150b}
.csf-opt:active{transform:scale(.995)}
.csf-opt:has(input:checked){border-color:var(--green);background:rgba(125,159,38,.12);box-shadow:inset 0 0 0 1px var(--green)}
.csf-opt input{position:absolute;opacity:0;pointer-events:none}
.csf-opt::before{content:"";width:22px;height:22px;flex:none;border:1.5px solid var(--line2);background:#0a0a0a;
  background-position:center;background-repeat:no-repeat;background-size:14px;transition:.15s}
.csf-opt:has(input[type=radio])::before{border-radius:50%}
.csf-opt:has(input[type=checkbox])::before{border-radius:6px}
.csf-opt:has(input:checked)::before{border-color:var(--green);background-color:var(--green);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2304210F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}
.csf-text,.csf-comment{width:100%;background:#0f0f0f;border:1px solid var(--line2);border-radius:10px;color:var(--ink);padding:.7rem .85rem;font:inherit;font-size:.95rem}
.csf-text{min-height:96px;resize:vertical}
.csf-comment{margin-top:.7rem;font-size:.88rem}
.csf-foot{display:flex;align-items:center;gap:.8rem;margin-top:1rem;justify-content:flex-end}
.csf-foot .saved{order:-1;margin-right:auto}
.csf-done{display:flex;align-items:flex-start;gap:.9rem}
.csf-done-ic{width:34px;height:34px;border-radius:50%;background:var(--green);color:var(--green-ink);display:grid;place-items:center;font-weight:800;flex:none}
.csf-done h2{margin:0 0 .25rem}
.csf-done p{margin:0;color:var(--muted)}

/* credentials */
.cr-item{display:flex;align-items:center;gap:.7rem;border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;margin-bottom:.6rem;font-size:.9rem;flex-wrap:wrap;background:var(--surface2)}
.cr-item b{min-width:160px}
.cr-item .muted{color:var(--muted2);font-size:.82rem}
.cr-item .acts{margin-left:auto;display:flex;gap:.4rem}
.btn-mini{border:1px solid var(--line2);background:var(--surface2);color:var(--muted);border-radius:8px;padding:.25rem .6rem;font-size:.76rem;font-weight:700}
.btn-mini:hover{color:var(--ink)}
.btn-mini.danger:hover{color:var(--danger);border-color:var(--danger)}
.cn-dl{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.45rem;margin-top:.9rem}
.cn-dl-label{font-size:.9rem;color:var(--muted)}
.cn-dl-btn{display:inline-flex;align-items:center;gap:.5rem}
.cn-dl-btn svg{width:18px;height:18px}
.cn-actions{display:flex;align-items:center;gap:.7rem;justify-content:flex-end;margin-top:.6rem}
.cn-actions .saved{margin-right:auto}
.cr-systems{margin:.2rem 0 1rem}
.cr-systems:empty{display:none}
.cr-sys-head{font-size:.85rem;color:var(--muted);margin-bottom:.5rem}
.cr-sys-chips{display:flex;flex-wrap:wrap;gap:.45rem}
.cr-sys-chip{display:inline-flex;align-items:center;gap:.2rem;background:var(--surface2);border:1px solid var(--line2);border-radius:999px;padding:.35rem .7rem;font-size:.85rem;color:var(--ink)}
.cr-sys-brand{color:var(--muted2)}
/* Per-systeem login-slots (energiedossier) */
.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)}
.pane-intro{color:var(--muted);font-size:.95rem;line-height:1.6;margin:0 0 1.2rem;max-width:760px}
/* "Bestel Nu"-checkout (basispakket) */
.co-cols{align-items:start}
.co-card,.co-info{padding:1.3rem}
.co-title{margin:.2rem 0 .9rem;font-size:1.15rem}
.co-comps{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1rem}
.co-f{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:700;color:var(--muted)}
.co-f>span{font-weight:700}
.co-fixed{background:rgba(125,159,38,.12);border:1px solid rgba(125,159,38,.35);border-radius:9px;padding:.55rem .75rem;color:var(--ink);font-weight:700;font-size:.92rem}
.co-f select{padding:.55rem .75rem;border:1px solid var(--line2);border-radius:9px;background:#0f0f0f;color:var(--ink);font-family:inherit;font-size:.92rem}
.co-incl{list-style:none;margin:.2rem 0 1rem;padding:0;display:flex;flex-direction:column;gap:.45rem}
.co-incl li{position:relative;padding-left:1.5rem;font-size:.9rem;color:var(--ink);line-height:1.4}
.co-incl li::before{content:"✓";position:absolute;left:0;color:var(--green-h);font-weight:800}
.co-total{display:flex;align-items:baseline;justify-content:space-between;border-top:1px solid var(--line);padding-top:.8rem;margin-bottom:1rem}
.co-total span{color:var(--muted);font-weight:700}
.co-total b{font-size:1.5rem}.co-total small{font-size:.75rem;color:var(--muted2);font-weight:600}
.co-note{font-size:.78rem;color:var(--muted2);margin:.6rem 0 0;text-align:center}
.co-info p{font-size:.92rem;line-height:1.6;color:var(--muted);margin:.5rem 0}
.co-later{list-style:none;margin:.4rem 0;padding:0;display:flex;flex-direction:column;gap:.4rem}
.co-later li{display:flex;justify-content:space-between;gap:1rem;font-size:.88rem;color:var(--ink);border-bottom:1px dashed var(--line);padding-bottom:.4rem}
.co-deal{margin-top:1rem!important;background:rgba(26,166,183,.08);border:1px solid rgba(26,166,183,.3);border-radius:10px;padding:.8rem 1rem;color:var(--ink)!important;font-size:.9rem!important}
.co-banner{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.1rem;padding:.95rem 1.15rem;background:linear-gradient(90deg,rgba(125,159,38,.16),rgba(26,166,183,.12));border:1px solid rgba(125,159,38,.4);border-radius:12px}
.co-banner-tx{flex:1;min-width:220px;font-size:.92rem;line-height:1.5}
.co-banner-tx b{display:block;font-size:1.02rem;color:var(--ink);margin-bottom:.15rem}
.co-banner-tx span{color:var(--muted)}
.co-banner-btn{flex:none;white-space:nowrap}
.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-meta{margin-left:auto;display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}
.cr-slot-brand{color:var(--muted2);font-size:.82rem}
.cr-badge{font-size:.72rem;font-weight:700;border-radius:999px;padding:.18rem .55rem;white-space:nowrap}
/* Toggle "Geen gegevens beschikbaar" (toestel zonder login/cloud) */
.cr-nodata{background:var(--surface);border:1px solid var(--line2);color:var(--muted2);border-radius:999px;padding:.18rem .6rem;font-size:.72rem;font-weight:700;white-space:nowrap;cursor:pointer}
.cr-nodata:hover{color:var(--ink);border-color:var(--muted2)}
.cr-nodata.is-on{background:rgba(214,158,46,.16);color:#9a6f12;border-color:rgba(214,158,46,.5)}
/* "Geen gegevens beschikbaar" geselecteerd → widget volledig inklappen + notitie tonen. */
.cr-nodata-note{display:none;font-size:.84rem;color:var(--muted2);line-height:1.5}
.cr-slot.is-nodata .cr-nodata-note{display:block}
.cr-slot.is-nodata .cr-slot-fields,.cr-slot.is-nodata .cr-instr-top{display:none!important}
.cr-badge.ok{background:rgba(125,159,38,.16);color:#5f7d16}
.cr-badge.wait{background:rgba(214,158,46,.16);color:#9a6f12}
.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-2col{display:grid;gap:1rem;grid-template-columns:1fr}
.cr-slot.has-instr .cr-slot-2col{grid-template-columns:1fr 1.05fr;align-items:start}
@media(max-width:780px){.cr-slot.has-instr .cr-slot-2col{grid-template-columns:1fr}}
.cr-slot-2col .cr-instr{margin:0}
.cr-slot-2col .cr-instr-card{margin:0}
.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}
/* Instructie-link onder de toesteltitel: informeer de klant vóór het invullen (login vs API). */
.cr-instr-top{display:inline-block;margin:-.15rem 0 .7rem;color:var(--green-h);font-weight:700;font-size:.82rem;text-decoration:none;cursor:pointer}
.cr-instr-top:hover{text-decoration:underline}
/* "Idem als zonnepanelen" aangevinkt → widget inklappen (velden/methodekeuze/instructie verbergen). */
.cr-slot.is-collapsed .cr-f,.cr-slot.is-collapsed .cr-meth-wrap,.cr-slot.is-collapsed .cr-instr-top{display:none!important}
.cr-idem-note{display:none;font-size:.82rem;color:var(--muted2);margin:.15rem 0 .2rem}
.cr-slot.is-collapsed .cr-idem-note{display:block}
.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-pw-saved{color:var(--green-h);font-size:.74rem;font-weight:700;margin-left:.35rem}
.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-layout{display:flex;flex-direction:column;gap:1rem}
.cr-layout .panel{max-width:640px;margin-bottom:0}
.cr-instr--side .cr-instr-card{margin:0}
@media(min-width:1080px){
  .cr-layout{flex-direction:row;align-items:flex-start}
  .cr-layout .panel{flex:0 1 600px}
  .cr-instr--side{flex:1 1 460px;max-width:580px;position:sticky;top:1rem}
}
.cr-form{border-top:1px solid var(--line);padding-top:1rem;margin-top:1rem;display:flex;flex-direction:column;gap:.8rem}
.cr-form .fld-cap{display:inline-flex;align-items:baseline;gap:.15rem}
.cr-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:700;color:var(--muted)}
.cr-form input,.cr-form select{padding:.6rem .8rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink)}
.cr-instr-card{border:1px solid color-mix(in srgb,var(--brand,#1AA6B7) 45%,transparent);background:color-mix(in srgb,var(--brand,#1AA6B7) 8%,var(--surface2));border-radius:12px;padding:.9rem 1rem}
.cr-instr-title{font-weight:800;font-size:.92rem;margin-bottom:.4rem;color:var(--ink)}
.cr-instr-h{font-size:.84rem;color:var(--ink);background:#0f0f0f;border:1px solid var(--line2);border-radius:8px;padding:.5rem .65rem;margin:.2rem 0 .5rem}
.cr-instr-body{font-size:.86rem;color:var(--muted);line-height:1.55}
.cr-instr-body p{margin:.2rem 0 .5rem}
.cr-instr-body ul{margin:.2rem 0 .5rem;padding-left:1.2rem;list-style:disc}
.cr-instr-body li{margin:.15rem 0}
.cr-instr-body b{color:var(--ink)}
.cr-instr a,.cr-instr-foot a{color:var(--brand,#1AA6B7);font-weight:700;text-decoration:none}
.cr-instr-foot{margin-top:.4rem;font-size:.84rem}
.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}
.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(--brand,#7D9F26);color:var(--ink)}
.cr-meth.is-active{background:color-mix(in srgb,var(--brand,#7D9F26) 16%,#0f0f0f);border-color:var(--brand,#7D9F26);color:var(--ink)}
/* FAQ-accordion (zelfde patroon als de website) */
.faq-head{text-align:center;margin:2.2rem 0 1rem}
.faq-head .eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted2);font-weight:800}
.faq-head h2{margin:.2rem 0 0}
.faq{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:.5rem}
.faq-item{border:1px solid var(--line);border-radius:12px;background:var(--surface);overflow:hidden}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;text-align:left;background:none;border:0;color:var(--ink);font-weight:700;font-size:.95rem;padding:.9rem 1.1rem;cursor:pointer}
.faq-q .chev{flex:none;color:var(--muted2);transition:transform .2s}
.faq-q .chev svg{width:20px;height:20px;display:block}
.faq-item.open .faq-q .chev{transform:rotate(180deg)}
.faq-a{display:none;padding:0 1.1rem 1rem;color:var(--muted);font-size:.9rem;line-height:1.6}
.faq-item.open .faq-a{display:block}
.faq-a p{margin:.2rem 0 .5rem}
/* Energiebeheer Connect */
.cn-grid{display:grid;gap:1.2rem}
@media(min-width:860px){.cn-grid{grid-template-columns:1fr 1fr}}
.cn-steps{margin:.4rem 0 1rem;padding-left:1.2rem;display:flex;flex-direction:column;gap:.5rem;color:var(--muted)}
.cn-steps b{color:var(--ink)}
.cn-note{font-size:.82rem;margin-top:.7rem}
.cn-code-row{display:flex;align-items:stretch;gap:.5rem;margin:.3rem 0 .8rem}
.cn-code-box{flex:1;font-family:ui-monospace,Consolas,monospace;font-size:1.6rem;font-weight:800;letter-spacing:.12em;color:var(--ink);background:#0f0f0f;border:1px dashed var(--line2);border-radius:10px;padding:.8rem 1rem;text-align:center;user-select:all}
.cn-copy{flex:none;width:52px;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--muted);display:grid;place-items:center;cursor:pointer}
.cn-copy svg{width:20px;height:20px}
.cn-copy:hover{border-color:var(--brand,#7D9F26);color:var(--ink)}
.cn-copy.ok{border-color:var(--brand,#7D9F26);color:var(--brand,#7D9F26);background:color-mix(in srgb,var(--brand,#7D9F26) 14%,#0f0f0f)}
.cn-scan{border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;margin-bottom:.7rem;background:var(--surface2)}
.cn-scan-h{font-size:.78rem;color:var(--muted2);margin-bottom:.4rem}
.cn-scan-list{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:.25rem;font-size:.9rem}
.cn-audit{border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;margin-bottom:.7rem;background:rgba(125,159,38,.05)}
.cn-audit .cn-scan-list{list-style:none;padding-left:0}
.cn-add{color:#7fae3a}
.cn-del{color:#d98a8a}
.cn-chg{color:#d8b24a}
.row2{display:grid;gap:.8rem}
@media(min-width:640px){.row2{grid-template-columns:1fr 1fr}.row2--wide-right{grid-template-columns:1fr 1.3fr}}
.form-foot{display:flex;align-items:center;gap:.7rem;justify-content:flex-end}
.form-foot .saved{order:-1;margin-right:auto}
.saved{font-size:.85rem;color:var(--green);font-weight:700}

/* payments */
.tbl{width:100%;border-collapse:collapse;font-size:.9rem}
.tbl th{text-align:left;padding:.65rem .8rem;color:var(--muted2);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.tbl td{padding:.7rem .8rem;border-bottom:1px solid var(--line)}
.tbl tr:last-child td{border-bottom:none}
.tbl .empty{text-align:center;color:var(--muted2);padding:1.6rem}
.pay-open{color:#e0a23a;background:rgba(224,162,58,.14);border-radius:999px;padding:.15rem .6rem;font-size:.78rem;font-weight:700}
.pay-paid{color:#a8c94a;background:rgba(125,159,38,.16);border-radius:999px;padding:.15rem .6rem;font-size:.78rem;font-weight:700}

.ac-form{display:flex;flex-direction:column;gap:.85rem;max-width:420px}
.ac-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;font-weight:700;color:var(--muted)}
.ac-form input{padding:.65rem .85rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink)}

/* analyse-download */
.dl-row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-top:1rem}
.dl-row .muted{color:var(--muted2);font-size:.84rem}

/* mijn dashboard (ingebed) + projectcommunicatie */
.db-layout{display:grid;grid-template-columns:1fr;gap:1.2rem;align-items:start}
/* Dashboard 3/4 + Instellingen 1/4 zodra het instellingen-paneel zichtbaar is. */
.db-layout:has(.db-settings:not([hidden])){grid-template-columns:3fr 1fr}
@media(max-width:900px){.db-layout:has(.db-settings:not([hidden])){grid-template-columns:1fr}}
.db-settings{align-self:start;margin-bottom:0}
.db-main{padding:0;overflow:hidden;margin-bottom:0;display:flex;flex-direction:column}
.db-bar{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;padding:.7rem 1rem;border-bottom:1px solid var(--line);background:var(--surface2)}
.db-bar .muted{color:var(--muted2);font-size:.82rem;word-break:break-all}
.db-bar .btn{margin-left:auto;padding:.45rem .9rem;font-size:.84rem}
/* device-voorbeeldknoppen (desktop/ipad/mobiel) bovenaan rechts */
.db-devices{margin-left:auto;display:inline-flex;gap:.15rem;background:var(--surface);border:1px solid var(--line2);border-radius:9px;padding:.15rem}
.db-dev{display:grid;place-items:center;width:30px;height:28px;border:0;background:transparent;color:var(--muted2);border-radius:7px;cursor:pointer}
.db-dev svg{width:17px;height:17px}
.db-dev:hover{color:var(--ink);background:rgba(255,255,255,.05)}
.db-dev.is-active{color:var(--green);background:rgba(125,159,38,.16)}
.db-stage{min-height:480px}
#db-frame{width:100%;height:640px;border:0;display:block;background:var(--bg);margin:0 auto;transition:max-width .2s ease}
/* device-simulatie: smaller iframe, gecentreerd op een donkere "frame" */
.db-stage[data-device="ipad"],.db-stage[data-device="mobile"]{background:#0a0a0a;padding:1rem 0;display:flex;align-items:stretch;justify-content:center}
.db-stage[data-device="ipad"] #db-frame{max-width:834px;border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.45)}
.db-stage[data-device="mobile"] #db-frame{max-width:390px;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.45)}
.db-placeholder{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;background:#0a0a0a}
.db-placeholder svg{width:52px;height:52px;color:var(--muted2);margin-bottom:1rem}
.db-placeholder h3{margin:0 0 .5rem;font-size:1.1rem;color:var(--ink)}
.db-placeholder p{margin:0;max-width:44ch;color:var(--muted);font-size:.9rem;line-height:1.55}

/* Bouw-voortgang (ontwikkelfase): vier klantvriendelijke fases */
.db-buildprog{margin-bottom:14px}
.dbp-list{list-style:none;display:flex;gap:.6rem 1.4rem;flex-wrap:wrap;margin:.6rem 0 0;padding:0}
.dbp-list li{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.88rem}
.dbp-dot{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--line);color:var(--muted);font-size:.74rem;font-weight:700;flex:none}
.dbp-list li.done .dbp-dot{background:var(--green);color:var(--green-ink,#04210F)}
.dbp-list li.done{color:var(--ink)}
.dbp-list li.current .dbp-dot{background:var(--teal);color:#fff}
.dbp-list li.current{color:var(--ink);font-weight:600}

/* Feedback-ronde (bouw-wizard): beoordeel-kaart boven de energie-app */
.db-feedback{border-left:3px solid var(--green);margin-bottom:14px}
.db-feedback h2{font-size:1.05rem;margin:0 0 .4rem}
.db-feedback textarea{width:100%;margin-top:.6rem;background:var(--bg);border:1px solid var(--line);border-radius:9px;color:var(--ink);padding:.6rem .75rem;font:inherit;font-size:.9rem;resize:vertical}
.db-fb-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:.9rem;flex-wrap:wrap}

/* Dashboard-instellingen (klant-voorkeuren) */
.db-settings h2{font-size:1rem;margin:0 0 .9rem}
.db-set-row{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.4rem 0}
.db-set-row span small{color:var(--muted)}
.db-switch{appearance:none;-webkit-appearance:none;position:relative;width:44px;height:25px;border-radius:13px;background:var(--line);cursor:pointer;flex:none;transition:background .15s ease;border:none}
.db-switch::after{content:"";position:absolute;top:3px;left:3px;width:19px;height:19px;border-radius:50%;background:#fff;transition:transform .15s ease}
.db-switch:checked{background:var(--green)}
.db-switch:checked::after{transform:translateX(19px)}
.db-switch:disabled{opacity:.5;cursor:not-allowed}
.db-chat{padding:0;margin-bottom:0;display:flex;flex-direction:column;height:72vh;min-height:520px}
/* Globale chat-slide-over (drawer rechts, op elke pagina) */
.chat-drawer-ov{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:64;animation:cdFade .15s ease}
@keyframes cdFade{from{opacity:0}to{opacity:1}}
.chat-drawer{position:fixed;top:0;right:0;height:100vh;width:min(440px,100vw);background:var(--surface);border-left:1px solid var(--line2);box-shadow:-18px 0 50px rgba(0,0,0,.5);z-index:65;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .22s ease;will-change:transform}
.chat-drawer.is-open{transform:translateX(0)}
/* Zwevende wit-transparante "Chat"-knop rechtsboven (vervangt het sidebar "Chat"-item) */
.chat-fab{position:fixed;top:16px;right:18px;z-index:60;display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .95rem;border-radius:999px;background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.28);cursor:pointer;font-weight:700;font-size:.85rem;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:0 4px 14px rgba(0,0,0,.25);transition:.15s}
.chat-fab:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.5);transform:translateY(-1px)}
.chat-fab svg{width:18px;height:18px}
.chat-fab-lbl{line-height:1}
.chat-fab-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 .3rem;border-radius:999px;background:#e5484d;color:#fff;font-size:.66rem;font-weight:800;display:inline-grid;place-items:center;line-height:1;border:2px solid var(--surface)}
.chat-drawer-head{display:flex;align-items:flex-start;gap:.6rem;padding:.9rem 1.1rem;border-bottom:1px solid var(--line);background:var(--surface2);flex:none}
.chat-drawer-ttl h2{margin:0;font-size:1rem}
.chat-parties{margin:.25rem 0 0;font-size:.76rem;color:var(--muted2);line-height:1.45}
.chat-parties b{color:var(--muted);font-weight:700}
.chat-x{margin-left:auto;background:none;border:none;color:var(--muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .2rem;flex:none}
.chat-x:hover{color:var(--ink)}
/* Kanaalschakelaar (Installateur / Carl / Groep) */
.chat-chan{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-bottom:.15rem}
.chat-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:.76rem;font-weight:700;cursor:pointer}
.chat-chan-btn:hover{color:var(--ink)}
.chat-chan-btn.is-active{background:rgba(125,159,38,.16);border-color:var(--green);color:var(--green-h)}
.chat-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}
.chat-head{padding:.95rem 1.1rem;border-bottom:1px solid var(--line);flex:none}
.chat-head h2{margin:0;font-size:1rem}
.chat-head p{margin:.25rem 0 0;font-size:.78rem;color:var(--muted2)}
.chat-log{flex:1;overflow-y:auto;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.7rem}
.chat-empty{margin:auto;color:var(--muted2);font-size:.85rem;text-align:center;max-width:32ch;line-height:1.5}
.chat-msg{max-width:88%;padding:.5rem .7rem;border-radius:12px;font-size:.86rem;line-height:1.4;word-wrap:break-word}
.chat-msg .who{display:block;font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted2);font-weight:800;margin-bottom:.2rem}
.chat-msg .when{display:block;font-size:.66rem;color:var(--muted2);margin-top:.3rem}
.chat-msg.them{align-self:flex-start;background:var(--surface2);border:1px solid var(--line);border-bottom-left-radius:4px}
.chat-msg.me{align-self:flex-end;background:rgba(125,159,38,.16);border:1px solid rgba(125,159,38,.4);border-bottom-right-radius:4px}
/* Installateur-berichten in de gedeelde chat: eigen accent zodat ze opvallen t.o.v. Energiebeheer. */
.chat-msg.them.from-installer{background:rgba(56,132,196,.10);border-color:rgba(56,132,196,.35)}
.chat-msg.them.from-installer .who{color:#2f78b5}
.chat-day{align-self:center;margin:.3rem 0;font-size:.72rem;color:var(--muted2);background:var(--surface2);border:1px solid var(--line);border-radius:999px;padding:.15rem .7rem}
.chat-img{display:block;max-width:100%;max-height:220px;border-radius:8px;margin:.35rem 0 .1rem;cursor:zoom-in;border:1px solid var(--line)}
.chat-file{display:inline-flex;align-items:center;gap:.25rem;margin:.35rem 0 .1rem;background:rgba(0,0,0,.25);border:1px solid var(--line2);color:inherit;border-radius:8px;padding:.3rem .55rem;font-size:.82rem;cursor:pointer;max-width:100%}
.chat-file:hover{border-color:var(--green)}
/* composer */
.chat-form{display:flex;flex-direction:column;gap:.45rem;padding:.7rem 1rem;border-top:1px solid var(--line);flex:none;position:relative}
.chat-row{display:flex;gap:.4rem;align-items:flex-end}
.chat-form textarea{width:100%;background:#0f0f0f;color:var(--ink);border:1px solid var(--line2);border-radius:10px;padding:.6rem .8rem;font-size:.9rem;line-height:1.45;min-height:56px;max-height:160px;resize:vertical;font-family:inherit;box-sizing:border-box}
.chat-row #chat-send{margin-left:auto}
.chat-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(125,159,38,.2)}
.chat-form textarea:disabled{opacity:.55;cursor:not-allowed}
.chat-form .btn{padding:.55rem .9rem;font-size:.84rem;flex:none}
.chat-iconbtn{flex:none;width:36px;height:36px;border:1px solid var(--line2);background:var(--surface2);border-radius:9px;font-size:1.05rem;line-height:1;cursor:pointer}
.chat-iconbtn:hover{border-color:var(--green)}
.chat-iconbtn:disabled{opacity:.5;cursor:not-allowed}
.emoji-pop{position:absolute;left:1rem;bottom:calc(100% - .2rem);background:var(--surface);border:1px solid var(--line2);border-radius:12px;padding:.5rem;display:flex;flex-wrap:wrap;gap:.1rem;width:264px;box-shadow:0 12px 30px rgba(0,0,0,.5);z-index:5}
.emoji-pop .emoji{width:34px;height:34px;border:none;background:none;font-size:1.2rem;border-radius:8px;cursor:pointer}
.emoji-pop .emoji:hover{background:var(--surface2)}
.chat-attach-chip{display:inline-flex;align-items:center;gap:.4rem;background:var(--surface2);border:1px solid var(--line2);border-radius:999px;padding:.25rem .35rem .25rem .65rem;font-size:.8rem;color:var(--muted)}
.chat-attach-chip button{background:none;border:none;color:var(--muted);font-size:1.15rem;line-height:1;cursor:pointer;padding:0 .15rem}
.chat-attach-chip button:hover{color:var(--danger)}

/* Lena-service (zwevende AI-assistent in het CP) */
.lena-fab{position:fixed;right:22px;bottom:22px;width:60px;height:60px;border-radius:50%;background:var(--green);color:var(--green-ink);border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.45);z-index:60;cursor:pointer;transition:.15s}
.lena-fab:hover{background:var(--green-h);transform:translateY(-2px)}
.lena-fab.is-open{transform:scale(.9);opacity:.85}
.lena-fab svg{width:28px;height:28px}
.lena-widget{position:fixed;right:22px;bottom:94px;width:min(380px,calc(100vw - 32px));height:min(560px,calc(100vh - 130px));background:var(--surface);border:1px solid var(--line2);border-radius:16px;box-shadow:0 18px 50px rgba(0,0,0,.5);display:flex;flex-direction:column;overflow:hidden;z-index:60}
.lena-head{display:flex;align-items:center;gap:.5rem;padding:.8rem 1rem;border-bottom:1px solid var(--line);background:var(--surface2)}
.lena-title{font-weight:800;font-size:.95rem;line-height:1.1}
.lena-title small{display:block;font-weight:600;color:var(--muted2);font-size:.72rem;margin-top:.1rem}
.lena-x{margin-left:auto;background:none;border:none;color:var(--muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .2rem}
.lena-x:hover{color:var(--ink)}
.lena-log{flex:1;overflow-y:auto;padding:1.1rem;display:flex;flex-direction:column;gap:.7rem}
.lena-empty{margin:auto;color:var(--muted2);font-size:.88rem}
.lena-msg{max-width:80%;padding:.6rem .85rem;border-radius:14px;font-size:.9rem;line-height:1.5;word-wrap:break-word}
.lena-msg.bot{align-self:flex-start;background:var(--surface2);border:1px solid var(--line);border-bottom-left-radius:4px}
.lena-msg.me{align-self:flex-end;background:rgba(125,159,38,.16);border:1px solid rgba(125,159,38,.4);border-bottom-right-radius:4px}
.lena-msg a{color:var(--green)}
.lena-msg.typing{display:flex;gap:5px;align-self:flex-start}
.lena-msg.typing i{width:7px;height:7px;border-radius:50%;background:var(--muted2);animation:lena-b 1.2s infinite}
.lena-msg.typing i:nth-child(2){animation-delay:.2s}
.lena-msg.typing i:nth-child(3){animation-delay:.4s}
@keyframes lena-b{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.lena-quick{display:flex;flex-wrap:wrap;gap:.5rem;padding:0 1.1rem .5rem}
.lena-chip{background:var(--surface2);border:1px solid var(--line2);color:var(--ink);border-radius:999px;padding:.4rem .8rem;font-size:.82rem}
.lena-chip:hover{border-color:var(--green)}
.lena-form{display:flex;gap:.5rem;align-items:flex-end;padding:.8rem 1.1rem;border-top:1px solid var(--line)}
.lena-form textarea{flex:1;background:#0f0f0f;color:var(--ink);border:1px solid var(--line2);border-radius:10px;padding:.6rem .75rem;font-size:.9rem;resize:none;font-family:inherit}
.lena-form textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(125,159,38,.2)}
.lena-form .btn{padding:.6rem .95rem;font-size:.86rem;flex:none}

/* ---- Onboarding-stepper ---- */
/* Layout: links de actieve stap + content, rechts de verticale stappen-sidebar. */
.onb-layout{display:grid;grid-template-columns:1fr 300px;gap:1.3rem;align-items:start;margin-bottom:1.2rem}
@media(max-width:920px){.onb-layout{grid-template-columns:1fr}}
.onb-main{min-width:0}
.onb-side{min-width:0}
@media(min-width:921px){.onb-side{position:sticky;top:1rem}}

/* Sidebar-kaart met verticale stappen */
.onb{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);
  background-image:radial-gradient(600px 120px at 0% -40%,rgba(125,159,38,.12),transparent 60%)}
.onb-side-h{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.8rem}
.onb-side-t{font-weight:800;font-size:.9rem}
.onb-badge{font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--teal);background:rgba(26,166,183,.14);border-radius:999px;padding:.16rem .5rem;white-space:nowrap}
.onb-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}
.onb-step{display:flex;align-items:center;gap:.6rem;background:#0f0f0f;border:1px solid var(--line2);border-radius:11px;padding:.6rem .7rem;min-width:0}
.onb-step.is-clickable{cursor:pointer}
.onb-step.is-clickable:hover{border-color:var(--muted2)}
.onb-step.is-locked{opacity:.5}
.onb-step.is-active{border-color:rgba(26,166,183,.45)}
.onb-step.is-done{border-color:rgba(125,159,38,.5)}
/* De stap die je BEKIJKT krijgt de prominente markering (groene huisstijl, volgt de navigatie). */
.onb-step.is-viewing{border-color:var(--green);background:rgba(125,159,38,.08);box-shadow:0 0 0 2px rgba(125,159,38,.4)}
.onb-ic{flex:none;width:24px;height:24px;border-radius:999px;display:grid;place-items:center;font-size:.78rem;font-weight:800;background:var(--surface2);color:var(--muted2);border:1px solid var(--line2)}
.onb-step.is-viewing .onb-ic{background:var(--green);color:var(--green-ink);border-color:var(--green)}
.onb-step.is-done .onb-ic{background:transparent;border-color:transparent}
.onb-ic svg{width:20px;height:20px;color:var(--green)}
.onb-lab{font-weight:700;font-size:.85rem;line-height:1.2;min-width:0}
.onb-lab small{display:block;font-weight:600;font-size:.7rem;color:var(--muted2);margin-top:.1rem}

/* Linkse stap-kop: "Stap X van Y" + voortgang + hint */
.onb-step-head{margin-bottom:1rem}
.onb-stepno{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--green);font-weight:800;margin-bottom:.2rem}
.onb-sh-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap}
.onb-sh-t{font-size:1.3rem;margin:0;font-weight:800}
.onb-prog{display:flex;align-items:center;gap:.55rem;min-width:160px}
.onb-bar{flex:1;height:7px;border-radius:999px;background:var(--line2);overflow:hidden}
.onb-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--teal));transition:width .4s ease}
.onb-prog b{font-size:.82rem;color:var(--muted);font-weight:700;white-space:nowrap}
.onb-sh-hint{color:var(--muted);font-size:.9rem;line-height:1.5;margin:.5rem 0 0;max-width:none}

/* Stap-paneel (content) onder de kop */
.onb-panel{margin-bottom:1.2rem}
.onb-pl{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.4rem;box-shadow:var(--shadow)}
/* "kale" stap: geen paneelkader → enkel de grijze widgets op de zwarte achtergrond */
.onb-pl--bare{background:none;border:0;padding:0;box-shadow:none}
.onb-koppel-actions{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;justify-content:flex-end;margin-top:1.1rem}
.onb-pl h3{margin:0 0 .5rem;font-size:1.05rem}
.onb-pl p{margin:0 0 .9rem;color:var(--muted);font-size:.92rem;line-height:1.55}
/* Netwerk koppelen (ingebed in onboarding) — vereenvoudigde 3-stappen-uitleg + tools */
.onb-opt{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted2);background:var(--surface2);border:1px solid var(--line2);border-radius:999px;padding:.15rem .5rem;margin-left:.5rem;vertical-align:middle}
.cnx-steps{display:flex;flex-direction:column;gap:.55rem;margin:.2rem 0 1.1rem}
.cnx-step{display:flex;gap:.65rem;align-items:flex-start;font-size:.9rem;color:var(--muted);line-height:1.5}
.cnx-step b{color:var(--ink)}
.cnx-n{flex:none;width:22px;height:22px;border-radius:999px;display:grid;place-items:center;font-size:.74rem;font-weight:800;background:rgba(125,159,38,.16);color:var(--green-h)}
.cnx-tools{display:flex;flex-wrap:wrap;align-items:center;gap:.9rem}
.cnx-code{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.88rem;color:var(--muted)}
.cnx-code code{font-family:ui-monospace,Consolas,monospace;background:#0f0f0f;border:1px solid var(--line2);border-radius:7px;padding:.18rem .6rem;letter-spacing:.1em;color:var(--ink);font-weight:700}
.cnx-copy{display:inline-grid;place-items:center;width:30px;height:28px;flex:none;border:1px solid var(--line2);background:var(--surface2);color:var(--muted);border-radius:8px;cursor:pointer;padding:0;transition:.13s}
.cnx-copy svg{width:15px;height:15px}
.cnx-copy:hover{color:var(--ink);border-color:var(--muted2)}
.cnx-copy.ok{color:var(--green-h);border-color:var(--green)}
.cnx-scans{margin-top:.4rem}
.cnx-ok{color:var(--green-h);font-weight:700;font-size:.88rem}
.onb-faq-head{margin-top:1.5rem}
/* Pakketkeuze-kaarten (sales) */
.pkg-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:.4rem}
.pkg-grid--single{grid-template-columns:1fr;max-width:480px;margin-inline:auto}
@media(max-width:680px){.pkg-grid{grid-template-columns:1fr}}
.pkg-card{display:flex;flex-direction:column;gap:.7rem;background:#0f0f0f;border:1px solid var(--line2);border-radius:var(--radius);padding:1.2rem}
.pkg-card--featured{border-color:rgba(125,159,38,.55);box-shadow:0 0 0 1px rgba(125,159,38,.25)}
.pkg-head{display:flex;align-items:flex-start;gap:.7rem}
.pkg-ic{flex:none;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--surface2);border:1px solid var(--line2)}
.pkg-ic svg{width:23px;height:23px;color:var(--teal)}
.pkg-card--featured .pkg-ic{background:rgba(125,159,38,.14);border-color:rgba(125,159,38,.4)}
.pkg-card--featured .pkg-ic svg{color:var(--green)}
.pkg-htx{flex:1;min-width:0}
.pkg-htx h3{margin:0;font-size:1.08rem;font-weight:800}
.pkg-badge{display:inline-block;margin-top:.25rem;font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted2);background:var(--surface2);border:1px solid var(--line2);border-radius:999px;padding:.12rem .55rem}
.pkg-card--featured .pkg-badge{color:var(--green);background:rgba(125,159,38,.13);border-color:rgba(125,159,38,.35)}
.pkg-price{font-size:1.18rem;font-weight:800}
.pkg-price s{color:var(--muted2);font-weight:600;font-size:.85rem;margin-right:.4rem}
.pkg-price small{font-size:.72rem;font-weight:700;color:var(--muted2);margin-left:.25rem}
.pkg-sub{margin:0;color:var(--muted);font-size:.88rem;line-height:1.5}
.pkg-pos{margin:0;font-weight:800;font-size:.84rem;color:var(--green)}
.pkg-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}
.pkg-list li{display:flex;align-items:flex-start;gap:.5rem;font-size:.87rem;color:var(--ink);line-height:1.4}
.pkg-list svg{flex:none;width:16px;height:16px;color:var(--green);margin-top:.12rem}
.pkg-pay{margin-top:auto;font-size:.88rem;color:var(--muted);background:var(--surface2);border:1px solid var(--line);border-radius:10px;padding:.6rem .75rem}
.pkg-pay b{color:var(--ink)}
.pkg-extras{border-top:1px solid var(--line);padding-top:.7rem;display:flex;flex-direction:column;gap:.45rem}
.pkg-extras-h{font-weight:800;font-size:.8rem;color:var(--ink)}
.pkg-extra{display:flex;align-items:center;gap:.55rem;font-size:.86rem;color:var(--ink);cursor:pointer}
.pkg-extra input{width:17px;height:17px;accent-color:var(--green);flex:none}
.pkg-extra span{flex:1}
.pkg-extra b{color:var(--muted);font-weight:700;font-size:.82rem}
.pkg-extras-base{margin:.15rem 0 0;font-size:.76rem;color:var(--muted2)}
.pkg-card .btn{margin-top:.1rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}
.pkg-card .btn svg{width:18px;height:18px}
.onb-offer{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.4rem}
.onb-offer li{font-size:.92rem;color:var(--ink)}
.onb-offer a,.onb-check a{color:var(--green);font-weight:700}
.onb-check{display:flex;gap:.6rem;align-items:flex-start;font-size:.9rem;color:var(--ink);line-height:1.5;background:#0f0f0f;border:1px solid var(--line2);border-radius:10px;padding:.8rem .9rem;cursor:pointer}
.onb-check input{margin-top:.2rem;flex:none;width:18px;height:18px;accent-color:var(--green)}
.onb-akkoord-foot{display:flex;align-items:center;gap:.8rem;margin-top:1rem}

/* Vragenlijst-wizard (één vraag per pagina) */
.csf-prog{display:flex;align-items:center;gap:.6rem;margin-top:.8rem}
.csf-prog-bar{flex:1;height:6px;border-radius:999px;background:var(--line2);overflow:hidden}
.csf-prog-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--teal));transition:width .3s ease}
.csf-count{font-size:.8rem;color:var(--muted);white-space:nowrap}
.csf-page{padding:.4rem 0}
.csf-cat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted2);font-weight:800;margin-bottom:.5rem}
.csf-wiz-foot{display:flex;align-items:center;gap:.7rem;margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--line)}
.csf-wiz-foot .btn-ghost{margin-right:auto}

/* Betaal-paneel (Mollie QR + checkout) */
.onb-pay-row{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap;margin:.4rem 0 .2rem}
.onb-qr{display:flex;flex-direction:column;align-items:center;gap:.4rem;background:#fff;border-radius:12px;padding:.7rem;border:1px solid var(--line2)}
.onb-qr img{width:180px;height:180px;display:block}
.onb-qr span{font-size:.74rem;color:#333;font-weight:700}
.onb-pay-actions{display:flex;flex-direction:column;gap:.6rem;align-items:flex-start}
.onb-pay-btn{display:inline-block;text-decoration:none;font-size:.95rem;padding:.7rem 1.1rem}
.onb-pay-note{font-size:.78rem!important;color:var(--muted2)!important;margin-top:.8rem!important}

/* "Extra vragen"-kaart bovenaan het Overzicht */
.onb-extra{margin-bottom:1.1rem}
.onb-extra-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  background:linear-gradient(100deg,rgba(26,166,183,.16),rgba(125,159,38,.10));border:1px solid var(--teal);border-radius:var(--radius);padding:1rem 1.2rem}
.onb-extra-txt b{display:block;font-size:.98rem}
.onb-extra-txt span{font-size:.85rem;color:var(--muted)}
.onb-extra-card .btn-primary{flex:none;text-decoration:none}

/* =====================================================================
   Mijn Energiebeheer — energieprofiel, scores, acties (Fase 1)
   ===================================================================== */
.nav-sec{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted2);font-weight:800;padding:.9rem .75rem .3rem}
@media(max-width:840px){.nav-sec{display:none}}
.btn-sm{padding:.4rem .8rem;font-size:.82rem;border-radius:9px}

/* generieke app-form inputs (energieprofiel) */
.ep-f input,.ep-f select,.ep-f textarea,.comp-card input,.comp-card select,.comp-card textarea,#ep-apps{
  padding:.6rem .8rem;border:1px solid var(--line2);border-radius:10px;background:#0f0f0f;color:var(--ink);width:100%;font-family:inherit}
.ep-f input:focus,.ep-f select:focus,.ep-f textarea:focus,.comp-card input:focus,.comp-card textarea:focus,#ep-apps:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(125,159,38,.2)}
.ep-f textarea,.comp-card textarea{resize:vertical;line-height:1.45}

/* scorekaarten */
.score-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem;margin-bottom:1.2rem}
.score-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow)}
.score-top{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}
.score-title{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted2);font-weight:800}
.score-num{font-family:var(--font);font-weight:800;font-size:1.7rem;line-height:1}
.score-num small{font-size:.9rem;color:var(--muted2);font-weight:700}
.score-bar{height:8px;border-radius:6px;background:var(--surface2);overflow:hidden;margin:.7rem 0 .55rem}
.score-bar span{display:block;height:100%;border-radius:6px;background:var(--green);transition:width .4s}
.score-lvl{font-size:.92rem;font-weight:700}
.score-sub{font-size:.78rem;color:var(--muted2);margin-top:.15rem}
/* niveau-kleuren (rustig, geen alarm) */
.score-card.lvl-eenvoudig .score-bar span,.score-card.lvl-laag .score-bar span{background:var(--green)}
.score-card.lvl-gemiddeld .score-bar span,.score-card.lvl-matig .score-bar span{background:var(--teal)}
.score-card.lvl-verhoogd .score-bar span{background:#e0a23a}
.score-card.lvl-hoog .score-bar span{background:#e0843a}
.score-card.lvl-verhoogd .score-num,.score-card.lvl-hoog .score-num{color:#e8a94a}
.score-card.dossier .score-bar span{background:var(--teal)}

/* energie-overzicht op het startscherm */
.energy-overview{margin-top:1.4rem}
.energy-sum-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:.4rem 0 .9rem}
.energy-sum-head h2{font-size:1.1rem;margin:0}
.energy-link{color:var(--green);font-weight:700;font-size:.86rem;cursor:pointer;text-decoration:none}
.energy-intro{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  background:linear-gradient(100deg,rgba(26,166,183,.14),rgba(125,159,38,.10));border:1px solid var(--teal);border-radius:var(--radius);padding:1.1rem 1.3rem;margin-top:1rem}
.energy-intro-tx b{display:block;font-size:1rem;margin-bottom:.2rem}
.energy-intro-tx span{font-size:.88rem;color:var(--muted);max-width:62ch;display:block}
.energy-intro .btn{flex:none}

/* trigger-CTA (subtiel, niet-agressief) */
.energy-trigger{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
  background:rgba(224,162,58,.09);border:1px solid rgba(224,162,58,.35);border-radius:var(--radius);padding:1rem 1.2rem;margin-bottom:1.2rem}
.energy-trigger-ic{font-size:1.5rem;flex:none}
.energy-trigger-tx{flex:1;min-width:240px}
.energy-trigger-tx b{display:block;font-size:.96rem;margin-bottom:.15rem}
.energy-trigger-tx span{font-size:.86rem;color:var(--muted);line-height:1.5}
.energy-trigger .btn{flex:none}

/* energieprofiel */
.ep-why{background:rgba(26,166,183,.08);border:1px solid rgba(26,166,183,.3);border-radius:10px;padding:.7rem 1rem;font-size:.84rem;color:var(--muted);margin-bottom:1.2rem;line-height:1.5}
.ep-panel h2{font-size:1.02rem}
.ep-help{font-size:.85rem;color:var(--muted);margin:-.3rem 0 1rem}
.cr-inst-note{display:flex;gap:.6rem;align-items:flex-start;background:rgba(224,162,58,.08);border:1px solid rgba(224,162,58,.3);border-radius:10px;padding:.7rem 1rem;font-size:.84rem;color:var(--muted);margin:-.3rem 0 1rem;line-height:1.5}
.cr-inst-note .cr-inst-ic{flex:none;font-size:1rem}
.cr-inst-note b{color:var(--ink)}
.ep-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem}
/* "Algemeen"-tab: twee kaarten naast elkaar (zoals CPI), velden gestapeld per kaart. */
.ep-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;align-items:start}
.ep-cols .ep-grid{grid-template-columns:1fr}
@media (max-width:900px){.ep-cols{grid-template-columns:1fr}}
.ep-f{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;font-weight:700;color:var(--muted)}
.ep-f>span{font-weight:700}
.ep-foot{display:flex;align-items:center;gap:.9rem;margin:.4rem 0 2rem;justify-content:flex-end}
.ep-foot .saved{order:-1}
.ct-del-btn{background:none;border:0;color:var(--danger);cursor:pointer;padding:.2rem;display:inline-grid;place-items:center;flex:none}
.ct-del-btn svg{width:18px;height:18px}

/* componenten aanvinken */
.comp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.7rem}
.comp-chip{display:flex;align-items:center;gap:.7rem;min-height:62px;padding:.75rem .95rem;border:1.5px solid var(--line2);border-radius:13px;background:#0f0f0f;cursor:pointer;transition:border-color .13s,background .13s,transform .06s;font-size:.92rem;font-weight:600;line-height:1.25}
.comp-chip:active{transform:scale(.985)}
.comp-chip:hover{border-color:var(--green)}
.comp-chip.on{border-color:var(--green);background:rgba(125,159,38,.12);box-shadow:inset 0 0 0 1px var(--green)}
.comp-chip input{position:absolute;opacity:0;pointer-events:none}
.comp-ic{font-size:1.2rem;flex:none}
/* Toevoeg-knoppen (instance-gebaseerd: zelfde type mag meerdere keren) */
.comp-adds{display:flex;flex-wrap:wrap;gap:.55rem}
.comp-add{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem .85rem;border:1.5px solid var(--line2);border-radius:11px;background:#0f0f0f;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--ink);transition:border-color .13s,background .13s,transform .06s}
.comp-add::before{content:"+";font-weight:800;color:var(--green);margin-right:-.1rem}
.comp-add:hover{border-color:var(--green);background:rgba(125,159,38,.1)}
.comp-add:active{transform:scale(.985)}
.comp-add:disabled{opacity:.5;cursor:default}
.comp-details{margin-top:1.3rem}
.comp-det-h{font-size:.9rem;margin:0 0 .8rem}
.comp-det-h small{color:var(--muted2);font-weight:500}
.comp-card{border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem;margin-bottom:.9rem;background:var(--bg)}
.comp-card-h{font-weight:800;font-size:.95rem;margin-bottom:.8rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.comp-card-foot{display:flex;align-items:center;gap:.7rem;margin-top:.8rem}

/* energiecomplexiteit-scherm */
.ec-explain{font-size:.95rem;line-height:1.6;color:var(--ink)}
.ec-scale{list-style:none;margin:1rem 0 0;padding:0;display:grid;gap:.4rem}
.ec-scale li{display:flex;align-items:center;gap:.7rem;padding:.5rem .8rem;border:1px solid var(--line);border-radius:9px;font-size:.88rem;color:var(--muted)}
.ec-scale li b{flex:none;min-width:46px;color:var(--muted2)}
.ec-scale li.on{border-color:var(--green);background:rgba(125,159,38,.1);color:var(--ink);font-weight:700}
.ec-scale li.on b{color:var(--green)}

/* energie-acties */
.ea-prog .ea-prog-top{display:flex;align-items:baseline;justify-content:space-between;gap:.8rem;flex-wrap:wrap}
.ea-prog-top b{font-size:1.02rem}
.ea-bar{height:10px;border-radius:6px;background:var(--surface2);overflow:hidden;margin-top:.7rem}
.ea-bar span{display:block;height:100%;border-radius:6px;background:var(--green);transition:width .4s}
.ea-group h2{font-size:.95rem}
.act-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.act-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:.8rem 0}
.act-item+.act-item{border-top:1px solid var(--line)}
.act-tx{flex:1;min-width:220px}
.act-tx b{display:block;font-size:.92rem}
.act-tx span{font-size:.82rem;color:var(--muted2)}
.act-item.is-done .act-tx b{color:var(--muted)}
.act-item.is-dismissed{opacity:.6}
.act-btns{display:flex;align-items:center;gap:.5rem;flex:none}
.act-done{color:var(--green);font-weight:700;font-size:.86rem}
.act-nvt{color:var(--muted2);font-size:.82rem}

/* =====================================================================
   Mijn Energiebeheer — Fase 2 (Energiekluis + Energiehistoriek)
   ===================================================================== */
/* kluis-tabs */
.kluis-tabs{display:flex;gap:.4rem;margin-bottom:1.2rem;border-bottom:1px solid var(--line);flex-wrap:wrap}
.kluis-tab{display:inline-flex;align-items:center;gap:.45rem;background:none;border:none;color:var(--muted);padding:.6rem .9rem;font-weight:700;font-size:.9rem;border-bottom:2px solid transparent;margin-bottom:-1px}
.kluis-tab svg{width:16px;height:16px;flex:none}
.kluis-tab:hover{color:var(--ink)}
.kluis-tab.is-active{color:var(--ink);border-bottom-color:var(--green)}
.kluis-tab.is-active svg{color:var(--green)}
/* Count-badge op een tab (bv. Stappenplan X/Y) — groene huisstijl-pill */
.kt-badge{display:inline-grid;place-items:center;min-width:20px;height:18px;padding:0 .4rem;border-radius:999px;font-size:.7rem;font-weight:800;line-height:1;background:rgba(125,159,38,.16);color:var(--green-h);font-variant-numeric:tabular-nums}
.kt-badge.is-done{background:var(--green);color:var(--green-ink)}
/* "Alle stappen afgerond"-blok in de Stappenplan-tab */
.onb-done{display:flex;align-items:flex-start;gap:.8rem;background:rgba(125,159,38,.08);border:1px solid rgba(125,159,38,.35);border-radius:14px;padding:1rem 1.15rem}
.onb-done-ic{flex:none;width:30px;height:30px;border-radius:999px;display:grid;place-items:center;background:var(--green);color:var(--green-ink)}
.onb-done-ic svg{width:18px;height:18px}
.onb-done b{display:block;font-size:1rem;margin-bottom:.15rem}
.onb-done span{font-size:.88rem;color:var(--muted);line-height:1.5}
.onb-done span b{display:inline;font-size:inherit;margin:0;color:var(--ink)}
/* Voltooid stappenplan: enkel de sidebar (volledige breedte), geen lege linkerkolom. */
.onb-layout--done{grid-template-columns:1fr}
.onb-layout--done .onb-main{display:none}
.onb-layout--done .onb-side{position:static}
/* Analyse-poort: "nog te doen"-lijst in de modal */
.ar-todo{margin:.6rem 0 .2rem;padding-left:1.1rem;display:flex;flex-direction:column;gap:.35rem}
.ar-todo li{font-size:.9rem;color:var(--ink);line-height:1.45}

/* documenten + installateurslijst */
.doc-form h3{margin:0 0 .9rem;font-size:1rem}
.doc-up-row{display:flex;align-items:center;gap:.7rem;margin-top:.8rem;flex-wrap:wrap}
.doc-list,.inst-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.2rem}
.doc-item,.inst-item{display:flex;align-items:flex-start;gap:.8rem;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.85rem 1rem}
.doc-ic{font-size:1.4rem;flex:none}
.doc-tx,.inst-tx{flex:1;min-width:0}
.doc-tx b,.inst-tx b{display:block;font-size:.94rem}
.doc-meta,.inst-meta{display:block;font-size:.8rem;color:var(--muted2);margin-top:.15rem}
.doc-meta a,.inst-meta a{color:var(--teal);text-decoration:none}
.doc-cat{color:var(--green);font-weight:700}
.doc-note{display:block;font-size:.82rem;color:var(--muted);margin-top:.3rem;font-style:italic}
.doc-acts,.inst-acts{display:flex;gap:.4rem;flex:none}
.inst-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.4rem}
.inst-tag{font-size:.72rem;background:rgba(125,159,38,.14);color:#a8c94a;border-radius:6px;padding:.12rem .5rem;font-weight:700}
.resp-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.2rem}
.resp-chip,.hist-check{display:flex;align-items:center;gap:.45rem;font-size:.86rem;font-weight:600;color:var(--ink);cursor:pointer}
.resp-chip input,.hist-check input{width:17px;height:17px;accent-color:var(--green)}

/* historiek */
.hist-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.hist-chart{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:.9rem}
.hc-title{font-size:.78rem;color:var(--muted2);font-weight:700;margin-bottom:.6rem}
.hc-bars{display:flex;align-items:flex-end;gap:.3rem;height:84px}
.hc-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:.25rem;min-width:0}
.hc-bar{width:100%;max-width:26px;border-radius:4px 4px 0 0;display:block}
.hc-col small{font-size:.62rem;color:var(--muted2);white-space:nowrap}
.hist-list{display:flex;flex-direction:column}
.hist-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.75rem 0}
.hist-row+.hist-row{border-top:1px solid var(--line)}
.hist-row-tx{flex:1;min-width:0}
.hist-row-tx b{display:block;font-size:.92rem}
.hist-vals{display:block;font-size:.82rem;color:var(--muted);margin-top:.15rem}
.hist-flags{display:inline-block;font-size:.78rem;margin-top:.25rem}
.hist-acts{display:flex;gap:.4rem;flex:none}
.hist-checks{display:flex;flex-wrap:wrap;gap:1.1rem;margin-top:.8rem}

/* =====================================================================
   CP-vragenlijst — gecentreerde, minimalistische kaart (zoals analyse-funnel)
   ===================================================================== */
.csf-wrap{max-width:640px;margin:0 auto}
.csf-wrap .csf-head{text-align:center;margin-bottom:1.4rem}
.csf-intro{color:var(--muted);font-size:.95rem;line-height:1.5;margin:0 0 1.1rem}
.csf-wrap .csf-prog{max-width:440px;margin:0 auto}
.csf-wrap .csf-cat-label{text-align:center}
.csf-wrap .csf-q{text-align:center;font-size:1.32rem}
.csf-wrap .csf-help{text-align:center}
.csf-wrap .csf-comment{margin-top:1rem}
/* footer gecentreerd; bij enkelvoudige keuze is er enkel 'Vorige' (auto-door) */
.csf-wrap .csf-wiz-foot{justify-content:center;border-top:none;padding-top:.4rem}
.csf-wrap .csf-wiz-foot .btn-ghost{margin-right:0}

.db-ph-cta{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-top:1.1rem}

/* APP-logins: wachtwoord tonen (oog-icoon) */
.cr-pw{display:inline-flex;align-items:center;gap:.35rem;flex-wrap:wrap}
.cr-pw-val{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;color:var(--ink);background:var(--surface);border:1px solid var(--line2);border-radius:6px;padding:.05rem .4rem;letter-spacing:.04em;white-space:nowrap}
/* "opgeslagen: •••••• 👁" valt op een eigen regel onder het label, zodat de bolletjes
   niet verticaal breken wanneer de kolom smal is. */
.cr-form .fld-cap{display:flex;flex-wrap:wrap;align-items:baseline;gap:.1rem .35rem}
.cr-saved-pw{display:inline-flex;align-items:center;gap:.4rem;flex-basis:100%;margin-left:0;margin-top:.15rem;font-size:.74rem;color:var(--muted2);font-weight:600}
/* Installateurs: "+"-knop rechtsboven wanneer er al een installateur is */
.inst-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.inst-add-ic{width:38px;height:38px;border-radius:11px;border:1px solid var(--line2);background:var(--surface);color:var(--green-h);cursor:pointer;display:grid;place-items:center;flex:none;transition:border-color .13s,background .13s}
.inst-add-ic:hover{border-color:var(--green);background:rgba(125,159,38,.1)}
.inst-add-ic svg{width:20px;height:20px}
/* installateur uitnodigen op het platform */
/* Installateurskaart: block-indeling met één rechts-uitgelijnde footer-actiebalk. */
.inst-item{display:block}
.inst-foot{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:.45rem;margin-top:.75rem;padding-top:.7rem;border-top:1px solid var(--line)}
.inst-foot>.inv-badge:first-child,.inst-foot>.inst-invite:first-child{margin-right:auto}
.inst-foot .inst-invite{color:var(--green-h)}
.inst-foot .inst-invite:hover{border-color:var(--green);background:rgba(125,159,38,.1)}
.inv-badge{display:inline-block;font-size:.78rem;font-weight:700;padding:.25rem .6rem;border-radius:999px}
.inv-badge.ok{background:rgba(125,159,38,.16);color:var(--green-h)}
.inv-badge.wait{background:rgba(224,162,58,.16);color:#e0a23a}
.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}

/* =====================================================================
   Mijn plan — twee kolommen (componenten/prijs/hosting + tarieven)
   ===================================================================== */
.plan-grid{display:grid;gap:1.2rem}
@media(min-width:880px){.plan-grid{grid-template-columns:1fr 1fr;align-items:start}}
.plan-col{margin-bottom:0}
.plan-col h2{margin:0 0 .1rem;font-size:1.1rem}
.plan-col .muted{color:var(--muted)}
.plan-lead{margin:.1rem 0 1rem;font-size:.92rem;color:var(--muted)}
.plan-comps,.plan-tars{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.plan-comp,.plan-tar{display:flex;align-items:center;gap:.7rem;padding:.6rem .1rem;border-bottom:1px solid var(--line)}
.plan-comp:last-child,.plan-tar:last-child{border-bottom:0}
.plan-comp-ic{flex:none;font-size:1.05rem;width:1.5rem;text-align:center}
.plan-comp-tx{flex:1;min-width:0}
.plan-comp-pr{flex:none;font-weight:700;font-size:.86rem;color:var(--ink);white-space:nowrap}
.plan-incl{color:var(--green-h);font-weight:700}
.plan-lb{display:inline-block;font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#e0a23a;background:rgba(224,162,58,.16);border:1px solid rgba(224,162,58,.35);border-radius:999px;padding:.08rem .45rem;vertical-align:middle;white-space:nowrap}
.plan-tot{display:flex;justify-content:space-between;align-items:baseline;margin-top:.9rem;padding-top:.8rem;border-top:1px solid var(--line2);font-size:.95rem}
.plan-tot b{font-size:1.3rem}
.plan-tot small{font-size:.68rem;color:var(--muted2);font-weight:600}
.plan-fine{font-size:.82rem;color:var(--muted);margin:.45rem 0 0;line-height:1.55}
.plan-host{display:flex;gap:.7rem;align-items:flex-start;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line);font-size:.85rem;line-height:1.5}
.plan-host-ic{flex:none;font-size:1.2rem}
.plan-host-note{font-size:.82rem}
.plan-tar-tx{flex:1;min-width:0;font-size:.9rem;line-height:1.4}
.plan-tar-tx b{font-weight:700}
.plan-tar-tx .muted{font-weight:400;font-size:.86rem;color:var(--muted)}
.plan-tar-pr{flex:none;font-weight:800;font-size:.88rem;color:var(--ink);white-space:nowrap}
.plan-note{display:flex;gap:.6rem;align-items:flex-start;margin-top:1rem;padding:.8rem .9rem;background:var(--surface2);border:1px solid var(--line2);border-radius:10px;font-size:.84rem;line-height:1.5;color:var(--muted)}
.plan-note-ic{flex:none}
.plan-ask{display:block;margin-top:2.8rem;text-align:center;text-decoration:none}
.plan-local{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line)}
.plan-local-h{font-size:.78rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--muted2);margin-bottom:.3rem}
.plan-order{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.6rem}
.plan-step{display:flex;align-items:center;gap:.8rem;padding:.7rem .1rem;border-bottom:1px solid var(--line)}
.plan-step-tx{flex:1;min-width:0;font-size:.92rem;line-height:1.4}
.plan-step-tx .muted{font-size:.82rem}
.plan-step-qty{flex:none;display:flex;align-items:center;gap:.55rem}
.plan-step-qty button{width:2rem;height:2rem;border-radius:8px;border:1px solid var(--line2);background:#0f0f0f;color:var(--ink);font-size:1.1rem;font-weight:700;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center}
.plan-step-qty button:hover{border-color:var(--green-h)}
.plan-step-qty .po-n{min-width:1.4rem;text-align:center;font-weight:800;font-size:1rem}
.plan-order-tot{display:flex;justify-content:space-between;align-items:baseline;margin:.8rem 0 .7rem;padding-top:.7rem;border-top:1px solid var(--line2);font-size:.95rem}
.plan-order-tot b{font-size:1.3rem}.plan-order-tot small{font-size:.68rem;color:var(--muted2);font-weight:600}
.plan-tar-more{margin-top:1.2rem}
.plan-tar-more>summary{cursor:pointer;font-size:.85rem;font-weight:700;color:var(--muted);padding:.3rem 0}
.plan-tar-more[open]>summary{margin-bottom:.4rem}

/* ============================================================
   MOBIEL (app-gevoel) — bottom-nav, sheet, kaarten-tabellen,
   tabs-scroll, touch-targets. Deze blokken raken desktop niet.
   ============================================================ */

/* Bottom tab bar + "Meer"-sheet: enkel op mobiel zichtbaar. */
.mnav,.msheet,.msheet-ov{display:none}

@media(max-width:840px){
  /* App-shell: sidebar weg, vaste onderbalk, ruimte onder de content. */
  .side{display:none}
  .main{padding:1rem .9rem calc(84px + env(safe-area-inset-bottom,0px));min-width:0}
  .mnav{position:fixed;left:0;right:0;bottom:0;z-index:70;display:flex;background:var(--surface);border-top:1px solid var(--line);padding:.3rem .15rem calc(.3rem + env(safe-area-inset-bottom,0px));box-shadow:0 -6px 18px rgba(0,0,0,.25)}
  .mnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.18rem;background:none;border:none;color:var(--muted);font-size:.6rem;font-weight:700;letter-spacing:.01em;padding:.32rem 0 .22rem;min-height:52px;cursor:pointer;border-radius:10px}
  .mnav-item svg{width:22px;height:22px}
  .mnav-item.is-active{color:var(--green)}
  .mnav-item.is-active svg{color:var(--green)}
  .msheet-ov[data-open]{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:71}
  .msheet[data-open]{display:block;position:fixed;left:0;right:0;bottom:0;z-index:72;background:var(--surface);border-top:1px solid var(--line2);border-radius:16px 16px 0 0;padding:.6rem .8rem calc(1rem + env(safe-area-inset-bottom,0px));box-shadow:0 -14px 40px rgba(0,0,0,.45)}
  .msheet-grip{width:44px;height:4px;border-radius:99px;background:var(--line2);margin:.15rem auto .7rem}
  .msheet .nav-item{min-height:48px}
  .msheet .logout{margin:0;width:100%;min-height:46px}
  .msheet-sep{height:1px;background:var(--line);margin:.5rem 0}

  /* FAB's: Lena boven de onderbalk; chat-pill blijft bovenaan maar compacter. */
  .lena-fab{bottom:calc(78px + env(safe-area-inset-bottom,0px));right:14px;width:54px;height:54px}
  .chat-fab .chat-fab-lbl{display:none}
  .chat-fab{padding:.5rem .6rem}

  /* Chat-drawer = volledig scherm. */
  .chat-drawer{width:100vw}

  /* Typografie & witruimte compacter. */
  .pane-head h1{font-size:clamp(1.15rem,4.5vw,1.35rem)}
  .pane-head p{font-size:.86rem}
  .panel{padding:.95rem}

  /* Formulieren: geen iOS-zoom, duim-vriendelijk. */
  input:not([type=checkbox]):not([type=radio]),select,textarea{font-size:16px}
  input:not([type=checkbox]):not([type=radio]),select{min-height:44px}
  .btn,.btn-primary,.btn-ghost{min-height:44px}
  .form-foot{flex-wrap:wrap}

  /* Tab-rijen (dossier/energie-app): scrollen i.p.v. wrappen, 44px targets. */
  .kluis-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;scrollbar-width:none}
  .kluis-tabs::-webkit-scrollbar{display:none}
  .kluis-tab{flex:0 0 auto;white-space:nowrap;min-height:44px;scroll-snap-align:start}
}

/* Tabellen → kaarten (enkel .tbl-cards; data-label komt uit de JS-render). */
@media(max-width:620px){
  .tbl-cards thead{display:none}
  .tbl-cards,.tbl-cards tbody{display:block;width:100%}
  .tbl-cards tr{display:block;background:var(--surface);border:1px solid var(--line);border-radius:12px;margin:.65rem 0;padding:.3rem .85rem}
  .tbl-cards td{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.45rem 0;border-bottom:1px dashed var(--line);text-align:right}
  .tbl-cards tr td:last-child{border-bottom:none}
  .tbl-cards td::before{content:attr(data-label);color:var(--muted);font-size:.78rem;font-weight:600;flex:none;text-align:left}
  .tbl-cards td:not([data-label])::before,.tbl-cards td[data-label=""]::before{content:none}
  .tbl-cards td.empty{display:block;text-align:center}
  /* Andere (niet-omgebouwde) tabellen: horizontaal scrollen i.p.v. knijpen. */
  .tbl:not(.tbl-cards){display:block;overflow-x:auto}
}
@media(max-width:840px){iframe{max-width:100%;width:100%}}

/* ============================================================
   Afmaak-wizard (progressive profiling, v118): wow-scherm,
   stepper, voortgangsbalk en lock-overlays.
   ============================================================ */
#obw-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:rgba(125,159,38,.14);border:1px solid rgba(125,159,38,.4);border-radius:12px;padding:.65rem 1rem;margin-bottom:1.2rem;font-size:.9rem;flex-wrap:wrap}
#obw-bar b{color:var(--green)}
.obw-top{display:flex;align-items:center;gap:1rem;max-width:640px;margin:0 auto .9rem}
.obw-prog{flex:1;height:6px;border-radius:99px;background:var(--line);overflow:hidden}
.obw-prog span{display:block;height:100%;background:var(--green);border-radius:99px;transition:width .3s ease}
.obw-card{max-width:640px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:clamp(1.2rem,4vw,2.2rem)}
.obw-card h2{margin:.1rem 0 .4rem;font-size:1.25rem}
.obw-q{color:var(--muted);margin:.1rem 0 .9rem;font-size:.92rem}
.obw-opts{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.55rem;margin-bottom:.9rem}
.obw-opt{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:.8rem .6rem;color:var(--ink);font-weight:600;font-size:.9rem;cursor:pointer;min-height:48px;transition:.12s}
.obw-opt:hover{border-color:var(--green)}
.obw-opt.is-on{background:rgba(125,159,38,.16);border-color:var(--green);color:var(--ink)}
.obw-inline{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:.55rem 0;font-size:.92rem;flex-wrap:wrap}
.obw-inline input{max-width:12rem}
.obw-unit{display:inline-flex;align-items:center;gap:.4rem}
.obw-brand{display:flex;align-items:center;gap:.8rem;margin:.5rem 0;flex-wrap:wrap}
.obw-brand b{min-width:9rem}
.obw-brand-in{flex:1;min-width:200px}
.obw-foot{display:flex;justify-content:flex-end;align-items:center;gap:.7rem;margin-top:1.2rem;flex-wrap:wrap}
.obw-wow{text-align:center;padding:.6rem 0}
.obw-wow-ic{font-size:2.6rem;margin-bottom:.4rem}
.obw-wow h1{font-size:clamp(1.35rem,4.5vw,1.7rem);margin:.2rem 0 .5rem}
.obw-sub{color:var(--muted);max-width:34rem;margin:.6rem auto 0}
.obw-chips{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:.9rem 0}
.obw-chip{background:rgba(125,159,38,.14);border:1px solid rgba(125,159,38,.45);color:var(--ink);border-radius:999px;padding:.4rem .85rem;font-size:.86rem;font-weight:600}
.btn-lg{padding:.85rem 1.6rem;font-size:1rem}
/* Lock-overlay op vergrendelde views (energie-app / verbinden). */
.obw-locked{position:relative}
.obw-locked > *:not(.obw-lock-ov):not(.pane-head){filter:blur(4px);pointer-events:none;user-select:none}
.obw-lock-ov{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:center;padding-top:14vh;z-index:5}
.obw-lock-card{background:var(--surface);border:1px solid var(--line2);border-radius:16px;padding:1.6rem 1.8rem;max-width:26rem;text-align:center;box-shadow:0 18px 50px rgba(0,0,0,.45)}
.obw-lock-ic{font-size:2rem;margin-bottom:.3rem}
.obw-lock-card h3{margin:.2rem 0 .4rem}
.obw-lock-card p{color:var(--muted);font-size:.92rem;margin:0 0 1rem}
/* Besparingsindicatie op het wow-scherm (enkel bij zelf opgegeven verbruik). */
.obw-save{background:rgba(125,159,38,.12);border:1px solid rgba(125,159,38,.4);border-radius:12px;padding:.85rem 1rem;margin:.9rem auto .2rem;max-width:34rem;font-size:.95rem}
.obw-save b{color:var(--green)}
.obw-save small{display:block;color:var(--muted);margin-top:.35rem;font-size:.78rem;line-height:1.4}
/* E1 (finale E2E): op desktop ligt de "Contacteer …"-pill (fixed, rechtsboven) over de
   "Verder afmaken"-knop van de vergrendel-banner → banner houdt ruimte vrij. */
@media(min-width:841px){#obw-bar{margin-right:12.5rem}}

/* Modulair dossier (fase 1): module-grid op de samenvatting-tab. */
.dsm-panel{padding:1.2rem 1.3rem;margin-bottom:1rem}
.dsm-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.9rem}
.dsm-total{display:flex;align-items:center;gap:.6rem;font-size:.88rem;font-weight:600;color:var(--muted)}
.dsm-total-bar{width:9rem;height:6px;border-radius:999px;background:var(--line2);overflow:hidden;display:inline-block}
.dsm-total-bar>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--teal))}
.dsm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.7rem}
.dsm-card{display:flex;align-items:center;gap:.75rem;text-align:left;background:var(--surface);border:1px solid var(--line2);border-radius:12px;padding:.75rem .9rem;cursor:pointer;font:inherit;color:var(--ink);transition:border-color .15s,transform .15s;min-width:0}
.dsm-card:hover{border-color:var(--green);transform:translateY(-1px)}
.dsm-card.is-done{border-color:rgba(125,159,38,.55)}
.dsm-card.is-empty{opacity:.85}
.dsm-ring{flex:0 0 auto;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:conic-gradient(var(--green) calc(var(--p)*1%),var(--line2) 0);position:relative}
.dsm-ring>span{width:34px;height:34px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:1.05rem}
.dsm-body{min-width:0;flex:1}
.dsm-body b{display:block;font-size:.92rem;line-height:1.25}
.dsm-body small{display:block;color:var(--muted);font-size:.76rem;line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.dsm-pct{flex:0 0 auto;font-size:.8rem;font-weight:700;color:var(--muted)}
.dsm-card.is-done .dsm-pct{color:var(--green)}
@media(max-width:640px){.dsm-grid{grid-template-columns:1fr}}

/* Fase 2 modulair dossier: deelrechten-schakelaars (CP → Installateurs-tab). */
.msh-panel{padding:1.1rem 1.2rem;margin-top:1rem}
.msh-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.35rem .9rem}
.msh-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.45rem .6rem;border:1px solid var(--line2);border-radius:9px;font-size:.9rem;cursor:pointer}
.msh-row:hover{border-color:var(--green)}
.msh-row input{width:1.1rem;height:1.1rem;accent-color:var(--green);flex:0 0 auto}
@media(max-width:640px){.msh-grid{grid-template-columns:1fr}}
