/* Planner — Recht in je Oor */
:root{
  --bg:#F7F6F3; --vlak:#FFFFFF; --inkt:#1C1B18; --inkt2:#6B6A64; --inkt3:#9C9B94;
  --lijn:#E6E4DE; --navy:#1C2B4A;
  --rood:#E24B4A; --rood-bg:#FCEBEB; --rood-inkt:#791F1F;
  --amber:#EF9F27; --amber-bg:#FAEEDA; --amber-inkt:#633806;
  --groen:#1D9E75; --groen-bg:#E1F5EE; --groen-inkt:#0F6E56;
  --paars-bg:#EEEDFE; --paars-inkt:#3C3489;
  --r:10px;
}
*{box-sizing:border-box;margin:0}
html,body{height:100%}
body{font-family:-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--inkt);font-size:14px}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font:inherit;width:100%;padding:8px 10px;border:1px solid var(--lijn);border-radius:8px;background:var(--vlak)}
input:focus,select:focus,textarea:focus,button:focus-visible{outline:2px solid var(--navy);outline-offset:1px}
.verborgen{display:none!important}

/* ---------- login ---------- */
.login-scherm{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--navy);padding:20px}
.login-kaart{background:var(--vlak);border-radius:16px;padding:32px 28px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px}
.login-logo{width:44px;height:44px;border-radius:50%;background:var(--groen);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px}
.login-kaart h1{font-size:22px}
.login-sub{color:var(--inkt2);margin-top:-10px}
.login-kaart label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--inkt2)}
.fout{color:var(--rood-inkt);background:var(--rood-bg);padding:8px 12px;border-radius:8px;font-size:13px}

/* ---------- knoppen ---------- */
.knop{padding:7px 14px;border-radius:8px;border:1px solid var(--lijn);background:var(--vlak);font-size:13px}
.knop.primair{background:var(--navy);color:#fff;border-color:var(--navy)}
.knop.breed{width:100%;padding:10px}
.knop.gevaar{color:var(--rood-inkt)}

/* ---------- topbar ---------- */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:var(--vlak);border-bottom:1px solid var(--lijn);position:sticky;top:0;z-index:20}
.merk{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px}
.merk-dot{width:10px;height:10px;border-radius:50%;background:var(--groen)}
.views{display:flex;gap:4px;background:var(--bg);border-radius:8px;padding:3px}
.views button{padding:5px 14px;font-size:13px;border-radius:6px;color:var(--inkt2)}
.views button.actief{background:var(--vlak);color:var(--inkt);font-weight:600;box-shadow:0 1px 2px rgba(0,0,0,.08)}
.topbar-rechts{display:flex;align-items:center;gap:8px}
.avatar-knop{width:32px;height:32px;border-radius:50%;background:var(--paars-bg);color:var(--paars-inkt);font-weight:600;font-size:13px;background-size:cover;background-position:center}

/* ---------- filterbalk ---------- */
.filterbalk{display:flex;align-items:center;gap:8px;padding:10px 16px;overflow-x:auto;scrollbar-width:none}
.filterbalk::-webkit-scrollbar{display:none}
.filterchip{border:1px solid var(--lijn);background:var(--vlak);padding:4px 12px;font-size:12.5px;border-radius:14px;color:var(--inkt2);white-space:nowrap}
.filterchip.actief{background:var(--inkt);color:#fff;border-color:var(--inkt)}
.filter-ruimte{flex:1}
.filter-editors{display:flex}

/* ---------- avatars ---------- */
.avatar{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;background-size:cover;background-position:center;border:2px solid var(--vlak);flex-shrink:0}
.avatar.klein{width:16px;height:16px;font-size:8px;border:0}
.avatar.kiesbaar{cursor:pointer;opacity:.45}
.avatar.kiesbaar.actief{opacity:1}
.filter-editors .avatar+.avatar{margin-left:-7px}
.avatar.leeg{background:var(--vlak);border:1.5px dashed var(--inkt3);color:var(--inkt3)}

/* ---------- lijst ---------- */
main{padding:0 16px 90px;max-width:1100px;margin:0 auto}
.dag-kop{font-size:12.5px;font-weight:600;margin:18px 2px 8px;color:var(--inkt2)}
.dag-kop.rood{color:var(--rood-inkt)}.dag-kop.groen{color:var(--groen-inkt)}
.rij{display:flex;align-items:center;gap:12px;background:var(--vlak);border:1px solid var(--lijn);border-left-width:3px;border-radius:var(--r);padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:box-shadow .12s}
.rij:hover{box-shadow:0 3px 10px rgba(28,27,24,.10)}
.rij.urgent{border-left-color:var(--rood)}.rij.let-op{border-left-color:var(--amber)}
.rij.klaar{border-left-color:var(--groen)}.rij.neutraal{border-left-color:var(--inkt3)}
.rij-info{flex:1.6;min-width:0}
.rij-titel{font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:6px}
.rij-klant{font-size:11.5px;color:var(--inkt2);margin-top:1px}
.rij-chips{flex:2.4;display:flex;flex-wrap:wrap;gap:5px}
.rij-datums{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:12px;min-width:86px}
.datum-rood{color:var(--rood-inkt);font-weight:600}.datum-amber{color:var(--amber-inkt);font-weight:600}
.datum-groen{color:var(--groen-inkt);font-weight:600}.datum-grijs{color:var(--inkt3)}
.ster{color:var(--amber);font-size:14px}

/* ---------- deliverable-chips ---------- */
.chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 4px 2px 8px;border-radius:11px;background:#F1EFE8;color:#5F5E5A;white-space:nowrap}
.chip.klaar{background:var(--groen-bg);color:var(--groen-inkt)}
.chip.bezig{background:var(--amber-bg);color:var(--amber-inkt)}
.chip .avatar.klein{margin-left:1px}

/* ---------- board ---------- */
.board{display:grid;grid-template-columns:repeat(4,minmax(230px,1fr));gap:12px;align-items:start;padding-top:8px}
.kolom-kop{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--inkt2);text-transform:uppercase;letter-spacing:.04em;padding:0 2px 8px}
.kolom-kop .balk{width:8px;height:8px;border-radius:2px}
.kolom-kop .teller{background:var(--lijn);border-radius:9px;padding:1px 8px;font-size:11px}
.kolom{min-height:120px;border-radius:var(--r)}
.kolom.sleep-over{background:rgba(28,43,74,.06);outline:2px dashed var(--navy)}
.kaart{background:var(--vlak);border:1px solid var(--lijn);border-left-width:3px;border-left-color:transparent;border-radius:var(--r);padding:11px 12px;margin-bottom:8px;cursor:grab}
.kaart:active{cursor:grabbing}
.kaart.urgent{border-left-color:var(--rood)}.kaart.let-op{border-left-color:var(--amber)}.kaart.klaar{border-left-color:var(--groen)}
.kaart-titel{font-size:12.5px;font-weight:600}
.kaart-klant{font-size:11px;color:var(--inkt2)}
.kaart .rij-chips{margin-top:8px;flex:initial}
.voortgang{height:3px;background:var(--lijn);border-radius:2px;margin-top:9px;overflow:hidden}
.voortgang span{display:block;height:100%;background:var(--groen)}
.kaart-voet{display:flex;justify-content:space-between;align-items:center;margin-top:9px}
.badge{font-size:10.5px;padding:2px 8px;border-radius:9px;font-weight:600}
.badge.rood{background:var(--rood-bg);color:var(--rood-inkt)}
.badge.amber{background:var(--amber-bg);color:var(--amber-inkt)}
.badge.groen{background:var(--groen-bg);color:var(--groen-inkt)}
.badge.paars{background:var(--paars-bg);color:var(--paars-inkt)}
.badge.grijs{background:#F1EFE8;color:#5F5E5A;font-weight:400}

/* ---------- kalender ---------- */
.week-nav{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 0 4px}
.week-nav button{border:1px solid var(--lijn);background:var(--vlak);border-radius:8px;padding:4px 12px}
.week-naam{font-size:13.5px;font-weight:600;min-width:170px;text-align:center}
.kalender-dag{margin-top:14px}
.kalender-dag-kop{font-size:13px;font-weight:600;padding:2px;display:flex;gap:8px;align-items:center}
.kalender-dag-kop.vandaag{color:var(--navy)}
.kalender-dag-kop .dagteller{font-size:11px;color:var(--inkt3);font-weight:400}
.agenda-item{display:flex;align-items:center;gap:10px;background:var(--vlak);border:1px solid var(--lijn);border-radius:var(--r);padding:9px 12px;margin-top:6px;cursor:pointer}
.agenda-icoon{font-size:14px;width:20px;text-align:center}
.agenda-info{flex:1;min-width:0}
.agenda-titel{font-size:13px;font-weight:600}
.agenda-sub{font-size:11px;color:var(--inkt2)}
.leeg-melding{color:var(--inkt3);font-size:13px;text-align:center;padding:40px 0}

/* ---------- modal ---------- */
.modal-achtergrond{position:fixed;inset:0;background:rgba(28,27,24,.45);z-index:40}
.modal{position:fixed;z-index:50;background:var(--vlak);border-radius:16px;width:min(560px,calc(100vw - 24px));max-height:88dvh;overflow-y:auto;left:50%;top:50%;transform:translate(-50%,-50%);padding:20px}
@media(max-width:600px){.modal{top:auto;bottom:0;left:0;transform:none;width:100vw;border-radius:16px 16px 0 0;max-height:92dvh}}
.modal-kop{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:4px}
.modal-kop h2{font-size:17px;line-height:1.3}
.modal-sluit{font-size:20px;color:var(--inkt3);padding:2px 8px}
.modal-sub{font-size:12.5px;color:var(--inkt2);margin-bottom:14px}
.modal label{display:flex;flex-direction:column;gap:4px;font-size:12.5px;color:var(--inkt2);margin-bottom:10px}
.veld-rij{display:flex;gap:10px}.veld-rij>label{flex:1}
.sectie-kop{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--inkt2);margin:16px 0 8px}
.taak{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--lijn)}
.taak:last-child{border-bottom:0}
.taak-status{width:30px;height:30px;border-radius:8px;border:1px solid var(--lijn);font-size:14px;flex-shrink:0}
.taak-status.klaar{background:var(--groen-bg);color:var(--groen-inkt);border-color:transparent}
.taak-status.bezig{background:var(--amber-bg);color:var(--amber-inkt);border-color:transparent}
.taak-naam{flex:1;font-size:13.5px}
.taak select{width:auto;padding:5px 8px;font-size:12.5px}
.modal-acties{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}
.modal-acties .knop{flex:1;min-width:120px}
.deliv-kiezer{display:flex;flex-wrap:wrap;gap:6px}
.deliv-kiezer .filterchip.actief{background:var(--navy);border-color:var(--navy)}

/* ---------- instellingen ---------- */
.instellingen-kaart{background:var(--vlak);border:1px solid var(--lijn);border-radius:var(--r);padding:16px;margin-top:14px}
.instellingen-kaart h3{font-size:14px;margin-bottom:10px}
.matrix{width:100%;border-collapse:collapse;font-size:12.5px}
.matrix th,.matrix td{padding:7px 6px;text-align:center;border-bottom:1px solid var(--lijn)}
.matrix th:first-child,.matrix td:first-child{text-align:left}
.matrix input[type=checkbox]{width:16px;height:16px}

/* ---------- toast & tabbar ---------- */
.toast{position:fixed;bottom:86px;left:50%;transform:translateX(-50%);background:var(--inkt);color:#fff;padding:9px 18px;border-radius:20px;font-size:13px;z-index:60;max-width:90vw}
.tabbar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--vlak);border-top:1px solid var(--lijn);padding:6px 0 max(6px,env(safe-area-inset-bottom));z-index:30}
.tabbar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;font-size:10px;color:var(--inkt3)}
.tabbar button span{font-size:17px}
.tabbar button.actief{color:var(--navy);font-weight:600}

@media(max-width:760px){
  .views{display:none}
  .tabbar{display:flex}
  .rij{flex-wrap:wrap}
  .rij-info{flex:1 1 60%}
  .rij-datums{align-items:flex-end}
  .rij-chips{flex:1 1 100%;order:3}
  .board{grid-template-columns:repeat(4,82vw);overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px}
  .board>div{scroll-snap-align:start}
  main{padding-bottom:120px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}
