@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{--navy:#173763;--navy-dark:#102a4c;--orange:#c50;--bg:#eaedf2;--card:#fff;--border:#e4e8ee;--border-soft:#ececec;--text:#1b2a3d;--text-muted:#7d7d7d;--text-soft:#9a9a9a;--green:#2e7d52;--green-bg:#e7f3ec;--amber:#b5781f;--amber-bg:#faf3e3;--red:#b3402f;--red-bg:#f7e9e6;--blue:#345f86;--blue-bg:#e6eef6;--radius:10px;--radius-lg:16px;--shadow:0 1px 2px #102a4c0a, 0 8px 24px #102a4c0f}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:Manrope,Helvetica Neue,Helvetica,Arial,sans-serif}h1,h2,h3,h4{margin:0}a{color:inherit;text-decoration:none}.btn{cursor:pointer;border:1px solid #0000;border-radius:7px;align-items:center;gap:6px;padding:9px 15px;font-family:inherit;font-size:13px;font-weight:600;transition:filter .12s,background .12s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.15)}.btn-ghost{color:#444;background:#fff;border-color:#cbcbcb}.btn-ghost:hover{background:#f6f8fb}.btn-danger{color:var(--red);background:#fff;border-color:#e3c3bd}.btn-danger:hover{background:var(--red-bg)}.input,.select{width:100%;height:38px;color:var(--text);background:#fff;border:1px solid #cfcfcf;border-radius:7px;padding:0 11px;font-family:inherit;font-size:14px}.input:focus,.select:focus{border-color:var(--navy);outline:none}label.field{flex-direction:column;gap:5px;display:flex}label.field>span{color:#5a5a5a;font-size:12px;font-weight:600}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.badge{border-radius:6px;align-items:center;gap:5px;padding:3px 9px;font-size:12px;font-weight:600;display:inline-flex}.badge-green{background:var(--green-bg);color:var(--green)}.badge-amber{background:var(--amber-bg);color:var(--amber)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-blue{background:var(--blue-bg);color:var(--blue)}.badge-grey{color:#555;background:#ececec}.mono{font-family:ui-monospace,Menlo,monospace}.spinner{border:3px solid #d6dde7;border-top-color:var(--navy);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--navy);border-right:1px solid var(--navy-dark);flex-direction:column;flex:0 0 210px;gap:26px;width:210px;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0}.sidebar-logo{padding:2px 6px}.sidebar-logo img{width:46px;display:block}.sidebar-nav{flex-direction:column;gap:4px;display:flex}.nav-item{color:#9fb0c6;border-radius:7px;align-items:center;gap:10px;padding:9px 10px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item:hover{color:#cdd8e6;background:#ffffff12}.nav-item.actief{color:#fff;background:#ffffff24;font-weight:600}.nav-dot{background:#ffffff29;border-radius:3px;width:14px;height:14px}.nav-item.actief .nav-dot{background:var(--orange)}.sidebar-footer{flex-direction:column;gap:8px;margin-top:auto;display:flex}.sidebar-user{color:#ffffffb3;padding:0 4px;font-size:12px}.sidebar-logout{color:#cdd8e6;cursor:pointer;text-align:left;background:#ffffff14;border:none;border-radius:7px;padding:8px 10px;font-family:inherit;font-size:12px}.sidebar-logout:hover{color:#fff;background:#ffffff29}.app-content{flex:1;min-width:0;padding:40px 48px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title{color:var(--navy);font-size:24px;font-weight:800}.page-sub{color:var(--text-muted);max-width:620px;margin-top:4px;font-size:13px;line-height:1.5}.center-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.klant-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;max-width:940px;display:grid}.klant-card{cursor:pointer;flex-direction:column;gap:12px;padding:16px;transition:box-shadow .12s,transform .12s;display:flex}.klant-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #102a4c14,0 14px 32px #102a4c1a}.klant-card-top{justify-content:space-between;align-items:flex-start;display:flex}.klant-card-naam{color:#333;font-size:15px;font-weight:600}.klant-card-add{border-radius:var(--radius);color:#999;cursor:pointer;border:1px dashed #ccc;flex-direction:column;justify-content:center;align-items:center;gap:6px;min-height:148px;display:flex}.klant-card-add:hover{border-color:var(--navy);color:var(--navy)}.mini-week{flex-direction:column;gap:4px;display:flex}.mini-week-row{gap:3px;display:flex}.mini-week-label{text-align:center;color:#b5b5b5;flex:1;font-size:9px}.mini-week-cell{color:#666;background:#eee;border-radius:3px;flex:1;justify-content:center;align-items:center;height:22px;font-size:11px;display:flex}.mini-week-cell.leeg{color:#ccc;background:#f5f5f5}.formaat-chip{cursor:pointer;border:1px solid #d8d8d8;border-radius:7px;padding:5px 11px;font-family:inherit;font-size:12px}.behoefte-tabel{border-radius:var(--radius);border:1px solid #e9e9e9;overflow:hidden}.behoefte-row{border-bottom:1px solid #f2f2f2;grid-template-columns:160px repeat(7,1fr);align-items:center;gap:6px;padding:10px 14px;display:grid}.behoefte-head{background:#f4f7fb}.behoefte-col-label{text-align:center;color:#9a9a9a;text-transform:uppercase;font-size:11px}.behoefte-rij-naam{color:#333;font-size:13px;font-weight:500}.behoefte-input{text-align:center;color:#333;background:#fff;border:1px solid #cfcfcf;border-radius:6px;width:100%;height:36px;padding:0;font-family:inherit;font-size:14px}.behoefte-input:focus{border-color:var(--navy);outline:none}.behoefte-afgeleid{background:#faf9f5}.behoefte-derived{text-align:center;color:#8a8266;font-size:13px}.signaalbalk{background:var(--amber-bg);border-radius:var(--radius);color:#6a5524;border:1px solid #ecdcb4;align-items:center;gap:10px;margin-bottom:18px;padding:12px 16px;font-size:13px;display:flex}.filterbalk{gap:10px;margin-bottom:18px;display:flex}.tabel{border-collapse:collapse;width:100%;font-size:14px}.tabel thead th{text-align:left;border-bottom:1px solid var(--border-soft);color:#8a8a8a;text-transform:uppercase;letter-spacing:.03em;background:#f4f7fb;padding:12px 18px;font-size:12px;font-weight:600}.tabel tbody td{color:#333;border-bottom:1px solid #f2f2f2;padding:13px 18px}.tabel tbody tr{cursor:pointer;transition:background .1s}.tabel tbody tr:hover{background:#f8fafc}.tabel tbody tr:last-child td{border-bottom:none}.sectie-titel{color:#444;margin-bottom:14px;font-size:14px;font-weight:700}.sectie-kop{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.week-nav{align-items:center;gap:10px;display:flex}.besch-grid{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.besch-dag{background:#fff;border:1px solid #e6e6e6;border-radius:8px;flex-direction:column;gap:6px;min-height:110px;padding:9px;display:flex}.besch-dag.leeg{background:#fafafa;border-style:dashed}.besch-dag-kop{text-transform:uppercase;color:#666;justify-content:space-between;align-items:baseline;font-size:12px;display:flex}.besch-blok{align-items:center;gap:3px;display:flex}.besch-tijd{border:1px solid #cfcfcf;border-radius:5px;width:100%;min-width:0;padding:3px 4px;font-family:inherit;font-size:12px}.besch-tijd:focus{border-color:var(--navy);outline:none}.besch-x{color:var(--red);cursor:pointer;background:#f0e3e1;border:none;border-radius:5px;flex:none;width:20px;height:22px;font-size:13px}.besch-add{color:#888;cursor:pointer;background:#fff;border:1px dashed #cfcfcf;border-radius:5px;padding:4px;font-family:inherit;font-size:11px}.besch-add:hover{border-color:var(--navy);color:var(--navy)}.wp-grid{flex-direction:column;gap:8px;max-width:360px;display:flex}.wp-rij{text-transform:uppercase;color:#555;align-items:center;gap:8px;font-size:13px;display:flex}.verlof-form{border:1px solid var(--border-soft);background:#f8fafc;border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:12px;padding:14px;display:flex}.verlof-rij{border:1px solid #eee;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;display:flex}.modus-toggle{background:#fff;border:1px solid #d6dde7;border-radius:8px;display:inline-flex;overflow:hidden}.modus-toggle button{color:#6a7888;cursor:pointer;background:#fff;border:none;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600}.modus-toggle button.actief{background:var(--navy);color:#fff}.plan-balk{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.signalen{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.signaal-tegel{border-radius:var(--radius);border:1px solid var(--border);background:#fff;flex:none;min-width:130px;padding:12px 16px}.signaal-aantal{font-size:24px;font-weight:800}.signaal-label{color:var(--text-muted);margin-top:2px;font-size:12px}.signaal-tegel.amber .signaal-aantal{color:var(--amber)}.signaal-tegel.red .signaal-aantal{color:var(--red)}.signaal-tegel.blue .signaal-aantal{color:var(--blue)}.signaal-tegel.grijs .signaal-aantal{color:#888}.week-tabel{border-collapse:collapse;width:100%;font-size:13px}.week-tabel th{border-bottom:1px solid var(--border-soft);color:#8a8a8a;text-transform:uppercase;background:#f4f7fb;padding:10px 8px;font-size:12px}.week-tabel .dag-datum{color:#b5b5b5;font-size:10px;font-weight:400}.klant-kol{text-align:left;min-width:130px;padding-left:16px}.week-cel{text-align:center;cursor:pointer;vertical-align:middle;border-bottom:1px solid #f2f2f2;border-left:1px solid #f4f4f4;padding:10px 6px}.week-cel:hover{background:#f8fafc}.leeg-cel{color:#d5d5d5;cursor:default;text-align:center;background:#fcfcfc;border-bottom:1px solid #f2f2f2}.cel-telling{color:#444;font-size:14px}.cel-signalen{justify-content:center;gap:4px;margin-top:4px;display:flex}.dot{color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex}.dot.amber{background:#d99a3a}.dot.red{background:#c0584a}.dot.blue{background:#5681a8}.dag-layout{grid-template-columns:1fr 240px;align-items:start;gap:18px;display:grid}.dag-hoofd{flex-direction:column;gap:16px;display:flex}.klant-blok{padding:16px 18px}.klant-blok-kop{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.dienst-lijst{flex-direction:column;gap:7px;display:flex}.dienst-rij{border:1px solid #ececec;border-radius:8px;align-items:center;gap:8px;padding:7px 9px;display:flex}.dienst-rij.open{background:#fdfaf2;border-color:#ecdcb4}.dienst-nr{color:#888;flex:none;width:64px;font-family:ui-monospace,Menlo,monospace;font-size:12px}.dienst-select{flex:1;min-width:0;height:34px;font-size:13px}.dienst-select.bus-nodig{background:#fdf3f1;border-color:#e0b3ab}.reserve-pool{padding:16px;position:sticky;top:20px}.reserve-item{border:1px solid #eee;border-radius:7px;justify-content:space-between;align-items:center;margin-bottom:6px;padding:8px 10px;font-size:13px;display:flex}.kpi-rij{flex-wrap:wrap;gap:14px;margin-bottom:22px;display:flex}.kpi-tegel{border-radius:var(--radius);border:1px solid var(--border);background:#fff;flex:150px;min-width:150px;padding:16px 18px}.kpi-tegel.klikbaar{cursor:pointer;transition:box-shadow .12s,transform .12s}.kpi-tegel.klikbaar:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.kpi-waarde{color:var(--navy);font-size:30px;font-weight:800}.kpi-tegel.amber .kpi-waarde{color:var(--amber)}.kpi-tegel.red .kpi-waarde{color:var(--red)}.kpi-tegel.blue .kpi-waarde{color:var(--blue)}.kpi-label{color:var(--text-muted);margin-top:2px;font-size:12px}.stam-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;display:grid}.melding-rij{border:1px solid #eee;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;display:flex}.log-rij{border-bottom:1px solid #f2f2f2;flex-direction:column;gap:3px;padding:11px 0;display:flex}.log-rij:last-child{border-bottom:none}.modal-overlay{z-index:50;background:#102a4c73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);background:#fff;width:560px;max-width:100%;max-height:90vh;padding:24px 26px;overflow:auto;box-shadow:0 12px 48px #102a4c4d}.modal-kop{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.afmeld-keuze{cursor:pointer;border:1px solid #eee;border-radius:8px;align-items:center;gap:8px;margin-bottom:6px;padding:8px 10px;font-size:13px;display:flex}
