:root{--bg-warm: #f9f5f0;--bg-surface: #ffffff;--bg-wash: #f3f2ec;--bg-sunken: #efeae1;--ink: #1e1e2e;--ink-soft: #2c3340;--text-1: #1e1e2e;--text-2: #585b70;--text-muted: #8b8e98;--text-on-dark: #eef1f8;--accent: #677c92;--accent-deep: #55687c;--accent-tint: rgba(103,124,146,.16);--action: #2563eb;--action-deep: #1d4ed8;--hairline: #e4e0d9;--line-2: #efeae2;--border-input: #d8d3ca;--danger: #d9534f;--danger-deep: #c0392b;--danger-tint: rgba(217,83,79,.1);--success: #2f9e6f;--warn-bg: #fdf3d8;--warn-line: #f0dca0;--warn-text: #8a6d1a;--kleur-af: #dd9b3c;--kleur-4p: #4071a8;--kleur-2p: #41937a;--kleur-los: #8a8d99;--kleur-leeg: #ffffff;--kleur-rand: var(--hairline);--module-breedte: 33px;--rij-hoogte: 66px;--font-ui: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Spline Sans Mono", ui-monospace, "SF Mono", Menlo, monospace;--r-xs: 4px;--r-sm: 7px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--logo-h: 28px;--header-h: 54px;--sh-soft: 0 1px 2px rgba(30,30,46,.05), 0 8px 24px -14px rgba(30,30,46,.14);--sh-card: 0 1px 2px rgba(30,30,46,.05), 0 18px 40px -22px rgba(30,30,46,.22);--sh-cta: 0 1px 2px rgba(30,30,46,.1), 0 12px 24px -12px rgba(103,124,146,.65);--sh-modal: 0 2px 8px rgba(30,30,46,.1), 0 40px 80px -28px rgba(30,30,46,.45);--sh-tile: 0 1px 0 rgba(255,255,255,.25) inset, 0 1px 2px rgba(30,30,46,.18);--ease: cubic-bezier(.22,.7,.3,1);--dur: .18s}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-ui);font-size:13px;line-height:1.45;color:var(--text-1);background-color:var(--bg-warm);background-image:radial-gradient(1100px 520px at 84% -14%,rgba(103,124,146,.07),transparent 60%),radial-gradient(900px 620px at -8% 112%,rgba(103,124,146,.045),transparent 56%);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;color-scheme:light}h1,h2,h3{margin:0;letter-spacing:-.02em;font-weight:800}button{font-family:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}.app{min-height:100%;display:flex;flex-direction:column}.kt-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:16px;height:var(--header-h);padding:0 26px;background:#f9f5f0d1;-webkit-backdrop-filter:saturate(1.1) blur(10px);backdrop-filter:saturate(1.1) blur(10px);border-bottom:1px solid var(--hairline)}.kt-header__spacer{flex:1}.kt-header__home{display:inline-flex;align-items:center;padding:0;background:none;border:0;cursor:pointer;transition:opacity var(--dur) var(--ease)}.kt-header__home svg,.kt-header__home img{height:var(--logo-h);width:auto;display:block}.kt-header__home:hover{opacity:.65}.app-brand{display:flex;align-items:center;gap:12px}.app-brand__divider{width:1px;height:22px;background:var(--hairline)}.app-title{font-size:14px;font-weight:800;letter-spacing:-.01em;color:var(--ink)}.app-title small{display:block;font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.app-header__ctx{display:flex;align-items:center;gap:12px;min-width:0}.app-header__crumb{font-size:13px;font-weight:700;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}.app-main{flex:1;padding:30px 38px 56px;max-width:1280px;width:100%;margin:0 auto}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px;animation:rise .55s var(--ease) both}.page-title{font-size:26px;font-weight:800;color:var(--ink)}.page-sub{margin-top:5px;font-size:13px;color:var(--text-2)}.btn{--bg: var(--bg-surface);--fg: var(--text-1);--bd: var(--border-input);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-ui);font-size:13px;font-weight:600;padding:8px 15px;border-radius:var(--r-sm);border:1px solid var(--bd);background:var(--bg);color:var(--fg);cursor:pointer;white-space:nowrap;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),transform .08s var(--ease),color var(--dur) var(--ease)}.btn:hover{--bg: var(--bg-wash)}.btn:active{transform:translateY(.5px)}.btn svg{width:16px;height:16px}.btn--primary{--bg: var(--accent);--fg: #fff;--bd: transparent;font-weight:700;padding:9px 17px;border-radius:var(--r-lg);box-shadow:var(--sh-cta)}.btn--primary:hover{--bg: var(--accent-deep);transform:translateY(-1px)}.btn--primary:active{transform:translateY(0)}.btn--action{--bg: var(--action);--fg: #fff;--bd: transparent;font-weight:700}.btn--action:hover{--bg: var(--action-deep)}.btn--ghost{--bg: var(--bg-wash);--fg: var(--text-2);--bd: transparent}.btn--ghost:hover{--bg: #ebe7df;--fg: var(--ink)}.btn--danger{--bg: #fff;--fg: var(--danger);--bd: var(--border-input)}.btn--danger:hover{--bg: var(--danger-tint);--bd: var(--danger);--fg: var(--danger-deep)}.btn--sm{padding:6px 11px;font-size:12px;gap:6px}.btn--block{width:100%}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-md);border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.icon-btn:hover:not(:disabled){background:var(--accent-tint);color:var(--accent-deep)}.icon-btn svg{width:17px;height:17px}.icon-btn--danger:hover:not(:disabled){background:var(--danger-tint);color:var(--danger)}.icon-btn:disabled{opacity:.32;cursor:default}.field{display:flex;flex-direction:column;gap:6px}.field>span,.lbl{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.input{width:100%;font-family:var(--font-ui);font-size:14px;color:var(--ink);padding:9px 11px;background:var(--bg-surface);border:1px solid var(--border-input);border-radius:var(--r-sm);transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.input::placeholder{color:var(--text-muted)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-tint)}.input--ghost{border-color:transparent;background:transparent;padding:4px 0;font-size:15px;font-weight:700}.input--ghost:focus{box-shadow:none;border-bottom:1px solid var(--accent);border-radius:0}.panel{background:var(--bg-surface);border:1px solid var(--hairline);border-radius:var(--r-xl);box-shadow:var(--sh-card);overflow:hidden}.proj-sectie{margin-bottom:18px}.proj-sectie:last-child{margin-bottom:0}.proj-sectie__titel{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin:0 0 8px 2px}.proj-list{display:flex;flex-direction:column}.proj-row{display:flex;align-items:center;gap:14px;width:100%;padding:16px 20px;background:transparent;border:none;text-align:left;border-bottom:1px solid var(--line-2);cursor:pointer;transition:background var(--dur) var(--ease)}.proj-row:last-child{border-bottom:none}.proj-row:hover{background:#fdfaf5}.proj-row--sjabloon{background:#6e8c6429;box-shadow:inset 3px 0 #6e8c64}.proj-row--sjabloon:hover{background:#6e8c643d}.proj-row--sjabloon .proj-row__mark{background:linear-gradient(150deg,#7c9c72,#56714d)}.proj-row--sjabloon .proj-row__ster{color:#56714d}.proj-row__mark{flex:none;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:#fff;background:linear-gradient(150deg,var(--accent),var(--accent-deep));font-weight:800;font-size:15px;box-shadow:var(--sh-soft)}.proj-row__body{min-width:0;flex:1;display:flex;flex-direction:column}.proj-row__name{font-size:15px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-row__meta{font-size:12px;color:var(--text-muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-row__cue{color:var(--text-muted);transition:transform var(--dur) var(--ease),color var(--dur) var(--ease)}.proj-row:hover .proj-row__cue{transform:translate(3px);color:var(--accent)}.proj-row__ster,.proj-row__edit,.proj-row__pdf,.proj-row__del{opacity:0;transition:opacity var(--dur) var(--ease)}.proj-row:hover .proj-row__ster,.proj-row:focus-within .proj-row__ster,.proj-row:hover .proj-row__edit,.proj-row:focus-within .proj-row__edit,.proj-row:hover .proj-row__pdf,.proj-row:focus-within .proj-row__pdf,.proj-row:hover .proj-row__del,.proj-row:focus-within .proj-row__del{opacity:1}.proj-row__ster--actief{opacity:1}.empty{text-align:center;padding:52px 24px;color:var(--text-2)}.empty__icon{color:var(--text-muted);opacity:.6;margin-bottom:12px}.empty__title{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:4px}.toolbar{display:flex;align-items:center;gap:10px}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#1e1e2e57;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .2s ease both}.modal{position:relative;z-index:101;width:100%;max-width:460px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;background:var(--bg-surface);border-radius:var(--r-xl);box-shadow:var(--sh-modal);overflow:hidden;animation:rise .3s var(--ease) both}.modal--wide{max-width:560px}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--ink-soft);color:var(--text-on-dark)}.modal__title{font-size:14.5px;font-weight:700;letter-spacing:-.01em}.modal__sub{font-size:11px;color:#fff9;font-weight:600}.modal__close{border:none;background:#ffffff1f;color:#fff;width:28px;height:28px;border-radius:8px;cursor:pointer;display:grid;place-items:center;transition:background var(--dur) var(--ease)}.modal__close:hover{background:#ffffff3d}.modal__close svg{width:15px;height:15px}.modal__body{padding:20px;overflow:auto;display:flex;flex-direction:column;gap:16px}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid var(--hairline);background:var(--bg-wash)}.modal__footer .spacer{flex:1}.modal__back{margin-right:auto}.optlist{display:flex;flex-direction:column;gap:6px}.opt{display:flex;align-items:center;gap:12px;width:100%;padding:11px 13px;text-align:left;cursor:pointer;background:var(--bg-surface);border:1px solid var(--hairline);border-radius:var(--r-md);color:var(--ink);font-size:13.5px;font-weight:600;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform .08s var(--ease)}.opt:hover{background:var(--bg-wash);border-color:#d8d3c8}.opt:active{transform:translateY(.5px)}.opt__swatch{flex:none;width:26px;height:26px;border-radius:7px;box-shadow:var(--sh-tile)}.opt__txt{flex:1;min-width:0}.opt__sub{display:block;margin-top:2px;font-size:11px;font-weight:600;color:var(--text-muted)}.opt__chev{color:var(--text-muted)}.opt__cue{flex:none;color:var(--accent);opacity:.8}.opt--grey{opacity:.5}.opt--grey:hover{opacity:.72}.opt__warn{font-size:10.5px;font-weight:700;color:var(--warn-text);background:var(--warn-bg);border:1px solid var(--warn-line);padding:2px 7px;border-radius:999px}.ruimtes{display:flex;flex-direction:column;gap:11px}.ruimtegroep{display:flex;flex-direction:column;gap:6px}.ruimtegroep__hd{display:flex;align-items:center;gap:6px}.ruimtegroep__kop{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent)}.ruimtegroep__add{display:inline-grid;place-items:center;width:18px;height:18px;padding:0;border:none;border-radius:5px;background:var(--accent-tint);color:var(--accent);cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.ruimtegroep__add:hover{background:var(--accent);color:#fff}.ruimtegroep__add svg{width:12px;height:12px}.ruimte-nieuw{display:flex;gap:8px;align-items:center;margin-top:2px}.ruimte-nieuw .input{flex:1}.ruimte-nieuw .btn{flex:0 0 auto;white-space:nowrap}.chips{display:flex;flex-wrap:wrap;gap:7px}.chip{display:inline-flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:6px 11px;border-radius:999px;font-size:12.5px;font-weight:600;background:var(--bg-wash);border:1px solid var(--hairline);color:var(--text-2);transition:all var(--dur) var(--ease)}.chip input{position:absolute;opacity:0;width:0;height:0}.chip--on{background:var(--accent);border-color:var(--accent);color:#fff}.tabbar{display:inline-flex;align-items:center;gap:4px;padding:4px;background:var(--bg-wash);border-radius:var(--r-md);border:1px solid var(--hairline)}.tab{border:none;background:transparent;color:var(--text-2);font-size:13px;font-weight:700;padding:6px 14px;border-radius:7px;cursor:pointer;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.tab:hover{color:var(--ink)}.tab--active{background:var(--bg-surface);color:var(--accent-deep);box-shadow:0 1px 2px #1e1e2e29}.tab--add{color:var(--text-muted);font-weight:800}.editor{display:flex;flex-direction:column;gap:18px}.editor__bar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.editor__bar-right{display:inline-flex;align-items:center;gap:12px}.histknoppen{display:inline-flex;align-items:center;gap:2px}.editor__hint{font-size:11.5px;color:var(--text-muted)}.rail-wrap{background:var(--bg-surface);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:var(--sh-soft);overflow:hidden;animation:rise .4s var(--ease) both}.rail-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:5px 12px 5px 14px;border-bottom:1px solid var(--line-2)}.rail-head__no{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-muted);background:var(--bg-wash);padding:1px 8px;border-radius:999px}.rail-head__fill{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.rail-head__right{display:inline-flex;align-items:center;gap:10px}.label-preview{background:#fff;border:1px solid var(--border-input);border-radius:var(--r-md);padding:12px;text-align:center;overflow-x:auto}.label-preview canvas{max-width:100%;height:auto;vertical-align:middle;box-shadow:0 0 0 1px #1e1e2e0f}.label-range{display:flex;gap:12px;margin-top:12px}.label-range .field{flex:1;min-width:0}.rail{position:relative;padding:14px 16px 16px;background:linear-gradient(var(--bg-sunken),var(--bg-sunken));overflow-x:auto}.rail__grid{position:relative;display:grid;width:100%;min-width:calc(24 * var(--module-min, 25px));grid-template-columns:repeat(24,minmax(var(--module-min, 25px),1fr));border-radius:9px;overflow:hidden;box-shadow:inset 0 0 0 1px #1e1e2e12}.module{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;height:var(--rij-hoogte);padding:6px 5px;border:none;cursor:grab;color:#fff;overflow:hidden;background:var(--bg, #ccc);box-shadow:var(--sh-tile),0 0 0 1px #1e1e2e1f;transition:filter var(--dur) var(--ease),transform .1s var(--ease)}.module:hover{filter:brightness(1.07);z-index:3}.module:active{cursor:grabbing}.module[data-cat=af]{--bg: var(--kleur-af)}.module[data-cat="4p"]{--bg: var(--kleur-4p)}.module[data-cat="2p"]{--bg: var(--kleur-2p)}.module[data-cat=los]{--bg: var(--kleur-los)}.module[data-cat=leeg]{--bg: #ffffff;color:var(--text-muted);box-shadow:inset 0 0 0 1px var(--hairline)}.module__letter{position:absolute;top:4px;left:4px;min-width:16px;height:16px;padding:0 4px;display:grid;place-items:center;border-radius:5px;background:#1e1e2e61;color:#fff;font-size:10.5px;font-weight:800;line-height:1}.module__naam{font-size:10.5px;font-weight:700;line-height:1.12;text-align:center;max-width:100%;max-height:36px;overflow:hidden;padding:0 2px;overflow-wrap:break-word;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.module__meta{font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:.02em;color:#ffffffd9}.module__ruimte{position:absolute;bottom:3px;right:5px;max-width:72%;font-size:10px;font-weight:800;letter-spacing:.02em;color:#fffffff2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.module[data-cat=leeg] .module__meta{color:var(--text-muted)}.module--narrow .module__naam{font-size:9px;-webkit-line-clamp:3}.cel--ok,.cel--bad{z-index:3}.cel--ok:after,.cel--bad:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0}.cel--ok:after{background:#677c924d;box-shadow:inset 0 0 0 1px var(--accent)}.cel--bad:after{background:#d9534f52;box-shadow:inset 0 0 0 1px var(--danger)}.cel{position:relative;height:var(--rij-hoogte)}.cel--open:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fcfbf8;box-shadow:inset 0 0 0 1px var(--line-2)}.cel__add{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;border:none;background:transparent;cursor:pointer;padding:0;transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.cel__add:hover{background:#fff;box-shadow:inset 0 0 0 1.5px var(--accent)}.slot__plus{color:var(--accent);opacity:0;transition:opacity var(--dur) var(--ease);display:grid}.cel__add:hover .slot__plus{opacity:1}.slot__plus svg{width:18px;height:18px;display:block}.ctx-back{display:inline-flex;align-items:center;gap:7px}@keyframes rise{0%{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}@keyframes fade{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}.seg{display:inline-flex;gap:3px;padding:3px;background:var(--bg-wash);border:1px solid var(--hairline);border-radius:9px}.seg button{border:none;background:transparent;cursor:pointer;font-family:var(--font-ui);font-size:13px;font-weight:700;color:var(--text-2);padding:6px 13px;border-radius:6px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.seg button:hover{color:var(--ink)}.seg button[aria-pressed=true]{background:var(--bg-surface);color:var(--accent-deep);box-shadow:0 1px 2px #1e1e2e29}.seg button:disabled{opacity:.4;cursor:not-allowed}.paneel-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.paneel-row__lbl{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.paneel-hint{font-size:11.5px;color:var(--text-muted)}@media (max-width: 1024px){.app-main{padding:26px 22px 48px}:root{--module-min: 23px}}@media (max-width: 720px){.kt-header{padding:0 14px;gap:10px}.app-title,.app-brand__divider{display:none}:root{--logo-h: 22px;--header-h: 50px}.app-header__crumb{display:none}.app-main{padding:18px 12px 40px}.page-head{flex-direction:column;align-items:stretch;gap:14px}.page-title{font-size:22px}.toolbar{flex-wrap:wrap}.toolbar .btn{flex:1 1 auto}.editor__bar{gap:10px}:root{--rij-hoogte: 58px;--module-min: 20px}.module__naam{font-size:9px}.rail{padding:12px 12px 14px}.modal__body{padding:16px}.rail-head{flex-wrap:wrap}}.ruimte-groep{margin-bottom:16px}.ruimte-groep__kop{display:flex;align-items:center;justify-content:space-between}.ruimte-chips{display:flex;flex-wrap:wrap;gap:6px}.ruimte-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid var(--lijn, #e5e5e5);border-radius:999px}.ruimte-chip__x{border:none;background:none;cursor:pointer;font-size:1.1em;line-height:1}.input--mini{width:90px;padding:2px 6px}.ruimte-groep__nieuw{display:flex;gap:8px;margin-top:12px}.beheer{padding:var(--sp-4, 16px)}.beheer__bar{display:flex;align-items:center;gap:12px;margin-bottom:16px}.beheer__titel{margin:0 0 12px}.type-groep{margin-bottom:20px}.type-groep__kop{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.type-rij{display:flex;align-items:center;gap:10px;padding:6px 8px;border-bottom:1px solid var(--lijn, #e5e5e5)}.type-rij--verborgen{opacity:.5}.type-rij__naam{font-weight:600}.type-rij__meta{color:var(--ink-zacht, #777);font-size:.85em}.check{display:flex;align-items:center;gap:8px;margin:6px 0}.portaal-midden{min-height:100%;display:flex;align-items:center;justify-content:center;padding:28px}.portaal-kaart{width:100%;background:var(--bg-surface);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:var(--sh-card);padding:30px 30px 26px;display:flex;flex-direction:column;gap:16px}.portaal-kaart--smal{max-width:380px}.portaal-kaart--gecentreerd{text-align:center;align-items:center}.portaal-kop{display:flex;flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:2px}.portaal-kaart--gecentreerd .portaal-kop{align-items:center}.portaal-logo{height:var(--logo-h);width:auto;display:block}.portaal-titel{font-size:20px}.portaal-sub{margin:0;color:var(--text-2);font-size:13px;line-height:1.5}.portaal-fout{margin:0;font-size:12.5px;color:var(--danger-deep);background:var(--danger-tint);border:1px solid var(--warn-line);border-color:#d9534f4d;border-radius:var(--r-sm);padding:8px 11px}.portaal-wissel{margin:2px 0 0;text-align:center;font-size:12.5px;color:var(--text-2)}.portaal-link{border:none;background:none;padding:0;cursor:pointer;font:inherit;font-weight:700;color:var(--accent)}.portaal-link:hover{color:var(--accent-deep);text-decoration:underline}.portaal-of{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:11.5px;text-transform:lowercase}.portaal-of:before,.portaal-of:after{content:"";flex:1;height:1px;background:var(--hairline)}.portaal-google{gap:9px}.portaal-spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--hairline);border-top-color:var(--accent);animation:portaal-draai .7s linear infinite}@keyframes portaal-draai{to{transform:rotate(360deg)}}.launcher{min-height:100%;display:flex;flex-direction:column}.launcher-kop-acties{display:flex;align-items:center;gap:8px}.launcher-koptitel{font-weight:800;font-size:14px;color:var(--ink)}.launcher-main{width:100%;max-width:920px;margin:0 auto;padding:32px 26px 64px}.launcher-grid{display:grid;grid-template-columns:repeat(auto-fill,184px);gap:16px}.tool-tegel{aspect-ratio:1 / 1;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;text-align:left;padding:20px;background:var(--bg-surface);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:var(--sh-soft);cursor:pointer;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease)}.tool-tegel:hover{transform:translateY(-2px);box-shadow:var(--sh-card);border-color:var(--accent)}.tool-tegel:active{transform:translateY(0)}.tool-tegel__icoon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;color:var(--accent);background:var(--accent-tint);border-radius:var(--r-md)}.tool-tegel__icoon svg{width:26px;height:26px}.tool-tegel__naam{font-weight:800;font-size:15px;line-height:1.25;color:var(--ink)}.launcher-leeg{color:var(--text-2);font-size:14px;padding:8px 2px}.tool-toggles{display:flex;align-items:center;gap:6px}.tool-pil{font:inherit;font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:999px;cursor:pointer;white-space:nowrap;border:1px solid var(--border-input);background:var(--bg-surface);color:var(--text-muted);transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),color var(--dur) var(--ease)}.tool-pil--aan{background:var(--accent);border-color:var(--accent);color:#fff}.gebruiker-groep{margin-bottom:26px}.gebruiker-groep:last-child{margin-bottom:0}.gebruiker-groep-titel{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin:0 2px 10px}.gebruiker-groep-aantal{font-size:11px;font-weight:700;letter-spacing:0;min-width:18px;height:18px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-tint);color:var(--accent-deep);border-radius:999px}.gebruiker-lijst{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.gebruiker-rij{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--hairline);border-radius:var(--r-md);box-shadow:var(--sh-soft)}.gebruiker-rij--pending{border-color:var(--warn-line);background:var(--warn-bg)}.gebruiker-mail{flex:1;min-width:0;font-weight:600;color:var(--ink);font-size:13.5px;overflow-wrap:anywhere}.gebruiker-jij{color:var(--text-muted);font-weight:600}.gebruiker-acties{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:6px;flex-shrink:0}@media (max-width: 640px){.launcher-main{padding:24px 16px 56px}.gebruiker-rij{flex-wrap:wrap}.gebruiker-acties{width:100%}}
