:root{--navy:#0f1c3f;--ink:#1a2233;--mut:#6b7686;--line:#e6e9ef;--bg:#eef1f5;--card:#fff}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:#2456a6}
/* login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f1c3f,#1b2f5e)}
.login-card{background:#fff;padding:38px 34px;border-radius:14px;width:330px;box-shadow:0 18px 50px rgba(0,0,0,.35);display:flex;flex-direction:column}
.login-logo{font-size:26px;font-weight:800;color:var(--navy);letter-spacing:-.5px}
.login-logo span{color:#2456a6;font-weight:600}
.login-sub{color:var(--mut);font-size:13px;margin:6px 0 20px}
.login-card input{padding:12px 14px;border:1px solid var(--line);border-radius:9px;margin-bottom:11px;font-size:14px}
.login-card input:focus{outline:none;border-color:#2456a6}
.login-card button{padding:12px;border:0;border-radius:9px;background:var(--navy);color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin-top:4px}
.login-card button:hover{background:#16264f}
.login-err{background:#fdecec;color:#b4231f;padding:9px 12px;border-radius:8px;font-size:13px;margin-bottom:12px}
/* topbar */
.topbar{background:var(--navy);color:#fff;display:flex;justify-content:space-between;align-items:center;padding:14px 26px}
.brand{font-size:19px;font-weight:800;letter-spacing:-.4px}.brand span{color:#7fa8e6;font-weight:600}
.who{font-size:13px;color:#c7d2e6}.who a{color:#9fb6dd;margin-left:12px}
.rolepill{background:rgba(255,255,255,.14);padding:2px 9px;border-radius:10px;font-size:11px;margin-left:6px}
.wrap{max-width:1080px;margin:0 auto;padding:22px 20px 50px}
/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:22px}
.card{background:var(--card);border-radius:12px;padding:16px 18px;border:1px solid var(--line);border-left:4px solid var(--accent,#5a6677);position:relative}
.card-val{font-size:28px;font-weight:800;color:var(--ink);line-height:1}.card-val small{font-size:13px;color:var(--mut);font-weight:600;margin-left:3px}
.card-lbl{font-size:12.5px;color:var(--mut);margin-top:7px}
.card-tag{position:absolute;top:14px;right:14px;font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:#9aa4b2}
.card-trend{font-size:11px;color:#1f7a4d;margin-top:5px;font-weight:600}
.card.fin{background:linear-gradient(180deg,#fff,#f7f9fd)}.lock{font-weight:700;color:#0f1c3f}
/* grid */
.grid2{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}
@media(max-width:820px){.grid2{grid-template-columns:1fr}}
.panel{background:var(--card);border-radius:12px;padding:18px 20px;border:1px solid var(--line)}
.panel h2{font-size:15px;margin:0 0 14px;color:var(--ink)}
/* feed */
.act{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid #f0f2f6}
.act:last-child{border-bottom:0}
.act-dot{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:0 0 auto}
.act-body{flex:1;min-width:0}
.act-top{display:flex;justify-content:space-between;gap:8px}
.act-title{font-weight:600;font-size:13.5px}
.act-meta{font-size:11px;color:#9aa4b2;white-space:nowrap}
.act-detail{font-size:12.5px;color:#52606d;margin:3px 0 0;line-height:1.45}
.act-foot{margin-top:6px;display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.act-actor{font-size:11px;color:var(--mut);font-weight:600}
.act-proj{font-size:10px;color:#fff;padding:1px 7px;border-radius:9px;text-transform:lowercase}
.act-type{font-size:10px;padding:1px 7px;border-radius:9px;background:#eef0f4;color:#5a6677}
.t-done{background:#e6f4ec;color:#1f7a4d}.t-task{background:#fdf0e3;color:#b4541f}.t-note{background:#eef0f4;color:#5a6677}
.empty{color:#9aa4b2;font-size:13px}
/* days */
.days{display:flex;flex-direction:column;gap:7px}
.day{display:flex;justify-content:space-between;align-items:center;padding:10px 13px;border:1px solid var(--line);border-radius:9px;text-decoration:none;color:var(--ink);transition:.12s}
.day:hover{border-color:#2456a6;background:#f5f8fd}
.day-date{font-size:13px;font-weight:600;text-transform:capitalize}
.day-n{background:var(--navy);color:#fff;font-size:11px;font-weight:700;min-width:22px;text-align:center;padding:2px 7px;border-radius:10px}
/* day page / timeline */
.back{display:inline-block;margin:4px 0 10px;font-size:13px;text-decoration:none}
.dayhead{font-size:22px;margin:6px 0 2px;text-transform:capitalize}
.daycount{color:var(--mut);font-size:13px;margin:0 0 18px}
.timeline{position:relative}
.tl-item{display:grid;grid-template-columns:52px 18px 1fr;align-items:start;gap:0}
.tl-time{font-size:12px;color:var(--mut);padding-top:14px;text-align:right;padding-right:8px}
.tl-dot{width:11px;height:11px;border-radius:50%;margin:16px auto 0;position:relative;z-index:1}
.tl-item:not(:last-child) .tl-dot:after{content:"";position:absolute;top:11px;left:50%;transform:translateX(-50%);width:2px;height:calc(100% + 20px);background:var(--line)}
.tl-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 15px;margin:8px 0}
.tl-title{font-weight:600;font-size:14px}
.tl-detail{font-size:12.5px;color:#52606d;margin-top:4px;line-height:1.5}
.foot{text-align:center;color:#9aa4b2;font-size:11px;margin-top:30px}
/* ---- projectlaag + nieuwe onderdelen ---- */
.pagetitle{font-size:23px;margin:6px 0 2px;display:flex;align-items:center;gap:10px}
.pagesub{color:var(--mut);font-size:13px;margin:0 0 18px}
.muted{color:#9aa4b2;font-weight:400;font-size:13px}
.proj-chip{width:14px;height:14px;border-radius:4px;display:inline-block}
.projects{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;margin-bottom:24px}
.proj-tile{background:#fff;border:1px solid var(--line);border-top:4px solid var(--accent);border-radius:12px;padding:16px 18px;text-decoration:none;color:var(--ink);transition:.12s;display:block}
.proj-tile:hover{box-shadow:0 8px 22px rgba(15,28,63,.10);transform:translateY(-2px)}
.proj-name{font-size:17px;font-weight:700;margin-bottom:8px}
.proj-meta{display:flex;gap:12px;font-size:12px;color:var(--mut)}
.proj-last{font-size:11px;color:#9aa4b2;margin-top:8px}
a.act{text-decoration:none;color:inherit;display:flex;gap:11px;padding:11px 0;border-bottom:1px solid #f0f2f6}
a.act:hover .act-title{color:#2456a6}
.card-link{font-size:11px;color:#2456a6;margin-top:8px;font-weight:600}
a.card{text-decoration:none;color:inherit;display:block;transition:.12s}
a.card:hover{box-shadow:0 8px 22px rgba(15,28,63,.10);transform:translateY(-2px)}
/* items-tabel */
table.items{width:100%;border-collapse:collapse;font-size:13px}
table.items th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:#9aa4b2;padding:8px 10px;border-bottom:2px solid var(--line)}
table.items td{padding:9px 10px;border-bottom:1px solid #f0f2f6}
.it-name{font-weight:600}
.it-badge{background:#eef0f4;color:#5a6677;font-size:11px;padding:1px 8px;border-radius:9px;margin-right:6px}
.it-link{font-size:12px;font-weight:600;text-decoration:none}
.it-status{color:#52606d}
/* repeterende taken */
.recurs{display:flex;flex-direction:column;gap:8px}
.recur{display:block;border:1px solid var(--line);border-radius:10px;padding:11px 13px;text-decoration:none;color:var(--ink);transition:.12s}
.recur:hover{border-color:#2456a6;background:#f5f8fd}
.recur-top{display:flex;justify-content:space-between;align-items:center}
.recur-name{font-weight:600;font-size:13.5px}
.recur-n{background:var(--navy);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}
.recur-sched{font-size:12px;color:#2456a6;margin-top:3px}
.recur-last{font-size:11.5px;color:var(--mut);margin-top:3px}
.recur-head{display:flex;gap:16px;flex-wrap:wrap;align-items:center;background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 16px;margin:10px 0 18px;font-size:13px;color:#52606d}
.recur-badge{background:#e6f4ec;color:#1f7a4d;font-size:11px;font-weight:700;padding:2px 9px;border-radius:10px;text-transform:uppercase}
/* items-kleuren */
.legend{display:flex;gap:18px;margin:0 0 14px;font-size:12px;color:#52606d;flex-wrap:wrap}
.legend i{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:-1px;margin-right:5px}
.it-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:8px;vertical-align:1px}
.it-flags{color:#9aa4b2;font-size:12px}
.it-internal{font-weight:600;color:#2456a6;text-decoration:none}.it-internal:hover{text-decoration:underline}
/* statusfilter-chips */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.chip{font-size:12.5px;padding:5px 13px;border-radius:16px;border:1px solid var(--line);background:#fff;color:#52606d;text-decoration:none;transition:.12s}
.chip:hover{border-color:#2456a6;color:#2456a6}
.chip.on{background:var(--navy);color:#fff;border-color:var(--navy)}
