/* ============================================================
   SDEYE CRM — stijl
   ============================================================ */
:root{
  --navy:#0d1b2a;
  --navy-2:#152a40;
  --accent:#19c3b1;
  --accent-d:#11a596;
  --tekst:#1d2733;
  --grijs:#64748b;
  --rand:#e2e8f0;
  --bg:#f4f6f9;
  --wit:#ffffff;
  --rood:#e23d52;
  --groen:#1faf6a;
  --oranje:#e29b1f;
  --blauw:#2f72e2;
  --schaduw:0 1px 3px rgba(13,27,42,.08),0 1px 2px rgba(13,27,42,.06);
  --radius:10px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--tekst);background:var(--bg);font-size:14.5px;line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--accent-d);text-decoration:none}
button{font-family:inherit;font-size:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ---- Laad/centreren ---- */
.midden{min-height:100vh;display:grid;place-items:center;padding:24px}

/* ---- Login / setup kaart ---- */
.kaart{
  background:var(--wit);border:1px solid var(--rand);border-radius:14px;
  box-shadow:var(--schaduw);padding:30px;width:100%;max-width:380px;
}
.kaart h1{margin:0 0 4px;font-size:22px}
.kaart .sub{color:var(--grijs);margin:0 0 22px;font-size:13.5px}
.merk{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.merk .logo{width:40px;height:40px;border-radius:9px;background:var(--navy);
  color:var(--accent);display:grid;place-items:center;font-weight:800;letter-spacing:.5px}
.veld{margin-bottom:14px}
.veld label{display:block;font-weight:600;margin-bottom:5px;font-size:13px;color:#33414f}
.veld input,.veld select,.veld textarea{
  width:100%;padding:9px 11px;border:1px solid var(--rand);border-radius:8px;background:#fbfcfe;
}
.veld input:focus,.veld select:focus,.veld textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(25,195,177,.18);background:#fff;
}
.veld textarea{min-height:80px;resize:vertical}
.foutmelding{background:#fdecee;color:#b21f33;border:1px solid #f6c5cc;
  padding:9px 12px;border-radius:8px;font-size:13px;margin-bottom:14px}

/* ---- Knoppen ---- */
.knop{
  display:inline-flex;align-items:center;gap:7px;justify-content:center;
  background:var(--accent);color:#04312c;border:none;padding:9px 16px;border-radius:8px;
  font-weight:700;transition:.15s;
}
.knop:hover{background:var(--accent-d);color:#fff}
.knop.vol{width:100%}
.knop.grijs{background:#eef2f7;color:#33414f}
.knop.grijs:hover{background:#e2e8f0;color:#1d2733}
.knop.rood{background:#fce8eb;color:var(--rood)}
.knop.rood:hover{background:var(--rood);color:#fff}
.knop.klein{padding:5px 10px;font-size:12.5px;font-weight:600}
.knop[disabled]{opacity:.55;cursor:not-allowed}

/* ---- App layout ---- */
.app{display:grid;grid-template-columns:228px 1fr;min-height:100vh}
.zijbalk{background:var(--navy);color:#cdd7e3;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.zijbalk .top{padding:18px 18px 12px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.07)}
.zijbalk .logo{width:34px;height:34px;border-radius:8px;background:var(--accent);color:var(--navy);
  display:grid;place-items:center;font-weight:800}
.zijbalk .naam{font-weight:800;color:#fff;letter-spacing:.5px}
.zijbalk .naam small{display:block;font-weight:500;color:#7e93a8;letter-spacing:0;font-size:11px}
.nav{padding:12px 10px;flex:1;overflow:auto}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:#cdd7e3;
  font-weight:600;margin-bottom:2px}
.nav a .ic{width:18px;text-align:center;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav a.actief{background:var(--accent);color:var(--navy)}
.nav .kop{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:#64788f;padding:14px 12px 6px;font-weight:700}
.zijbalk .voet{padding:12px;border-top:1px solid rgba(255,255,255,.07);font-size:12.5px}
.zijbalk .voet .wie{color:#fff;font-weight:600}
.zijbalk .voet .rol{color:#7e93a8}
.zijbalk .voet a{color:#9fb0c2;display:inline-block;margin-top:6px}

.inhoud{display:flex;flex-direction:column;min-width:0}
.balk{background:var(--wit);border-bottom:1px solid var(--rand);padding:14px 24px;
  display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:5}
.balk h2{margin:0;font-size:18px}
.balk .spacer{flex:1}
.zoek{position:relative}
.zoek input{padding:8px 12px 8px 32px;border:1px solid var(--rand);border-radius:8px;background:#fbfcfe;width:220px}
.zoek::before{content:"⌕";position:absolute;left:10px;top:7px;color:var(--grijs);font-size:16px}
main{padding:22px 24px;flex:1}

/* ---- Tabel ---- */
.tabel-wrap{background:var(--wit);border:1px solid var(--rand);border-radius:var(--radius);overflow:hidden;box-shadow:var(--schaduw)}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--rand);vertical-align:middle}
th{background:#f8fafc;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:#5b6b7b}
tbody tr{cursor:pointer}
tbody tr:hover{background:#f6fbfa}
tbody tr:last-child td{border-bottom:none}
td.rechts,th.rechts{text-align:right}
.leeg{padding:48px 20px;text-align:center;color:var(--grijs)}
.leeg .groot{font-size:34px;margin-bottom:8px}

/* ---- Badges ---- */
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11.5px;font-weight:700;
  background:#eef2f7;color:#3a4a5a;white-space:nowrap}
.badge.offerte{background:#eef2f7;color:#475569}
.badge.gepland{background:#e7f0fd;color:var(--blauw)}
.badge.in-uitvoering{background:#e6f6ef;color:var(--groen)}
.badge.oplevering{background:#fdf2e3;color:var(--oranje)}
.badge.afgerond{background:#e9ecef;color:#566}
.badge.on-hold{background:#fdeaea;color:#b4543a}
.badge.geannuleerd{background:#f1f3f5;color:#909}
.badge.open{background:#eef2f7;color:#475569}
.badge.bezig{background:#fdf2e3;color:var(--oranje)}
.badge.klaar{background:#e6f6ef;color:var(--groen)}
.badge.hoog{background:#fdeaea;color:var(--rood)}
.badge.normaal{background:#eef2f7;color:#475569}
.badge.laag{background:#eef4ff;color:#5b6b7b}

/* ---- Dashboard ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:var(--wit);border:1px solid var(--rand);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--schaduw)}
.kpi .n{font-size:28px;font-weight:800;line-height:1}
.kpi .l{color:var(--grijs);font-size:13px;margin-top:4px}
.rooster{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:900px){.rooster{grid-template-columns:1fr}}
.paneel{background:var(--wit);border:1px solid var(--rand);border-radius:var(--radius);box-shadow:var(--schaduw)}
.paneel h3{margin:0;padding:14px 16px;border-bottom:1px solid var(--rand);font-size:14.5px}
.paneel .lijst{padding:6px 0}
.paneel .regel{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid #f1f5f9}
.paneel .regel:last-child{border-bottom:none}
.paneel .regel .t{flex:1;min-width:0}
.paneel .regel .t b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.paneel .regel .t span{color:var(--grijs);font-size:12.5px}

/* ---- Detail ---- */
.detail-kop{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px}
.detail-kop .titel{flex:1}
.detail-kop h2{margin:0 0 4px}
.meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;
  background:var(--wit);border:1px solid var(--rand);border-radius:var(--radius);padding:16px;box-shadow:var(--schaduw);margin-bottom:18px}
.meta .m label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--grijs);margin-bottom:2px}
.meta .m div{font-weight:600}
.sectie{margin-bottom:22px}
.sectie .sk{display:flex;align-items:center;margin-bottom:10px}
.sectie .sk h3{margin:0;font-size:15px}
.sectie .sk .spacer{flex:1}

/* ---- Modal ---- */
.overlay{position:fixed;inset:0;background:rgba(13,27,42,.45);display:grid;place-items:center;z-index:50;padding:20px}
.modal{background:var(--wit);border-radius:14px;width:100%;max-width:520px;max-height:90vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal .mk{padding:16px 20px;border-bottom:1px solid var(--rand);display:flex;align-items:center}
.modal .mk h3{margin:0;font-size:16px}
.modal .mk .x{margin-left:auto;background:none;border:none;font-size:22px;color:var(--grijs);line-height:1}
.modal .mb{padding:18px 20px}
.modal .mv{padding:14px 20px;border-top:1px solid var(--rand);display:flex;gap:10px;justify-content:flex-end;position:sticky;bottom:0;background:#fff}
.rij2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
@media(max-width:520px){.rij2{grid-template-columns:1fr}}

/* ---- Toast ---- */
#toasts{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:8px;z-index:90}
.toast{background:var(--navy);color:#fff;padding:11px 16px;border-radius:9px;box-shadow:0 6px 20px rgba(0,0,0,.25);
  font-size:13.5px;animation:omhoog .2s ease}
.toast.fout{background:var(--rood)}
.toast.ok{background:var(--groen)}
@keyframes omhoog{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---- Mobiel ---- */
@media(max-width:760px){
  .app{grid-template-columns:1fr}
  .zijbalk{position:fixed;left:-240px;width:228px;z-index:60;transition:.2s}
  .zijbalk.open{left:0}
  .menu-knop{display:inline-flex}
  .schaduwlaag{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55}
}
.menu-knop{display:none;background:none;border:1px solid var(--rand);border-radius:8px;padding:6px 10px}

/* ============================================================
   Planning-module
   ============================================================ */
.plan-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.plan-tabs{display:inline-flex;background:#eef2f7;border-radius:9px;padding:3px}
.plan-tab{border:none;background:none;padding:7px 14px;border-radius:7px;font-weight:600;color:#51616f}
.plan-tab.actief{background:#fff;color:var(--navy);box-shadow:var(--schaduw)}
.plan-toolbar .spacer{flex:1}

/* extra status-badges */
.badge.backlog{background:#eef2f7;color:#475569}
.badge.gepland{background:#e7f0fd;color:var(--blauw)}
.badge.bezig{background:#fdf2e3;color:var(--oranje)}
.badge.blokkade{background:#fdeaea;color:var(--rood)}
.badge.klaar{background:#e6f6ef;color:var(--groen)}

/* ---- Gantt ---- */
.gantt{position:relative;overflow:auto;border:1px solid var(--rand);border-radius:var(--radius);background:#fff;box-shadow:var(--schaduw);max-height:70vh}
.gantt-inner{position:relative;font-size:12.5px}
.gantt-row{display:flex;align-items:stretch;min-height:36px}
.gantt-row.maand{min-height:24px}
.gantt-row.dag{min-height:26px}
.gantt-name{flex:0 0 220px;width:220px;position:sticky;left:0;z-index:3;background:#fff;
  border-right:1px solid var(--rand);border-bottom:1px solid #eef1f5;padding:0 12px;display:flex;align-items:center;gap:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-row.fase .gantt-name{background:#f4f7fb;font-weight:700}
.gantt-row.kop .gantt-name{background:#f8fafc;font-weight:700;z-index:4;border-bottom:1px solid var(--rand)}
.gantt-track{position:relative;border-bottom:1px solid #eef1f5;flex:0 0 auto}
.gantt-axis{display:flex;flex:0 0 auto}
.gantt-cel{flex:0 0 auto;border-right:1px solid #f1f4f8;text-align:center;color:#7a8a99;font-size:11px;display:flex;align-items:center;justify-content:center}
.gantt-cel.we{background:#fafbfc}
.gantt-cel.maand{font-weight:700;color:#41525f;justify-content:flex-start;padding-left:6px;border-right:1px solid #e4e9ef}
.gantt-weekend{position:absolute;top:0;bottom:0;background:#fafbfc;z-index:0}
.gantt-today{position:absolute;top:0;bottom:0;width:2px;background:var(--rood);opacity:.5;z-index:2}
.gantt-bar{position:absolute;height:18px;top:9px;border-radius:5px;background:var(--accent);
  box-shadow:0 1px 2px rgba(0,0,0,.15);cursor:pointer;z-index:1;overflow:hidden;display:flex;align-items:center}
.gantt-bar .vul{position:absolute;left:0;top:0;bottom:0;background:rgba(0,0,0,.22)}
.gantt-bar .lab{position:relative;padding:0 7px;color:#053b35;font-weight:600;font-size:11px;white-space:nowrap}
.gantt-mijl{position:absolute;width:16px;height:16px;top:10px;background:var(--navy);transform:rotate(45deg);
  border-radius:3px;cursor:pointer;z-index:2;box-shadow:0 1px 2px rgba(0,0,0,.2)}
.gantt-svg{position:absolute;left:220px;top:0;pointer-events:none;z-index:2;overflow:visible}
.gantt-leeg{padding:30px;text-align:center;color:var(--grijs)}

/* ---- Kanban ---- */
.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;align-items:flex-start}
.kanban-kolom{flex:0 0 250px;background:#f4f6f9;border:1px solid var(--rand);border-radius:var(--radius);min-height:80px}
.kanban-kop{padding:10px 12px;font-weight:700;font-size:13px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--rand)}
.kanban-kop .n{margin-left:auto;background:#fff;border:1px solid var(--rand);border-radius:20px;padding:0 8px;font-size:11.5px;color:#64748b}
.kanban-lijst{padding:8px;display:flex;flex-direction:column;gap:8px;min-height:40px}
.kanban-lijst.over{background:#e9f7f4;outline:2px dashed var(--accent);outline-offset:-4px;border-radius:8px}
.kanban-kaart{background:#fff;border:1px solid var(--rand);border-radius:8px;padding:9px 11px;box-shadow:var(--schaduw);cursor:grab}
.kanban-kaart:active{cursor:grabbing}
.kanban-kaart .t{font-weight:600;margin-bottom:5px}
.kanban-kaart .m{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:11.5px;color:#64748b}
.kanban-kaart .pb{height:5px;background:#eef2f7;border-radius:3px;margin-top:7px;overflow:hidden}
.kanban-kaart .pb i{display:block;height:100%;background:var(--accent)}

/* ---- Sprints ---- */
.sprint{background:#fff;border:1px solid var(--rand);border-radius:var(--radius);box-shadow:var(--schaduw);margin-bottom:14px}
.sprint-kop{padding:12px 16px;border-bottom:1px solid var(--rand);display:flex;align-items:center;gap:10px}
.sprint-kop .titel{font-weight:700}
.sprint-kop .periode{color:var(--grijs);font-size:12.5px}
.sprint-kop .spacer{flex:1}
.sprint-taken{padding:6px 0}
.sprint-regel{display:flex;align-items:center;gap:10px;padding:8px 16px;border-bottom:1px solid #f1f5f9}
.sprint-regel:last-child{border-bottom:none}
.sprint-regel .t{flex:1}

/* progress in modal */
.plan-voortgang{display:flex;align-items:center;gap:10px}
.plan-voortgang input[type=range]{flex:1}
.plan-afh{max-height:150px;overflow:auto;border:1px solid var(--rand);border-radius:8px;padding:6px}
.plan-afh label{display:flex;align-items:center;gap:8px;padding:3px 4px;font-weight:500;cursor:pointer}
.plan-afh label:hover{background:#f6fbfa}

/* ============================================================
   Crew / werkplanning
   ============================================================ */
.rp-grid{display:grid;background:var(--wit);border:1px solid var(--rand);border-radius:var(--radius);
  box-shadow:var(--schaduw);overflow:auto;max-height:72vh}
.rp-cel{border-right:1px solid #eef1f5;border-bottom:1px solid #eef1f5;min-height:46px;padding:4px;
  display:flex;flex-direction:column;gap:3px;font-size:12.5px}
.rp-cel.kop{position:sticky;top:0;z-index:2;background:#f8fafc;font-weight:600;text-align:center;
  align-items:center;justify-content:center;min-height:40px}
.rp-cel.naam{position:sticky;left:0;z-index:1;background:#fff;flex-direction:row;align-items:center;gap:7px;
  font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-right:1px solid var(--rand)}
.rp-cel.kop.hoek{position:sticky;left:0;top:0;z-index:3;justify-content:flex-start;padding-left:12px}
.rp-cel.we{background:#fafbfc}
.rp-cel.onb{background:repeating-linear-gradient(45deg,#fdecee,#fdecee 6px,#fbe2e5 6px,#fbe2e5 12px)}
.rp-cel.conflict{box-shadow:inset 0 0 0 2px var(--rood)}
.rp-cel:hover{background:#f3fbfa;cursor:pointer}
.rp-cel.naam:hover{cursor:default;background:#fff}
.shift-chip{background:#eef2f7;border-radius:5px;padding:3px 7px;font-size:11.5px;cursor:pointer;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.shift-chip.bevestigd{background:#e6f6ef}
.shift-chip:hover{filter:brightness(.96)}
