/* ─── ECHTE HUISSTIJL (opgehaald van vastgoedenadvies.be) ───
   Font: Quicksand · Groen CTA: #9cbe57 · Paars logo: #785068
   Header: wit · Tekst: zwart
   ──────────────────────────────────────────────────────── */
:root {
  --groen:        #9cbe57;   /* exact sitegroen – CTA knoppen */
  --groen-dark:   #87a843;   /* hover */
  --groen-light:  #f0f5e6;   /* lichte tint */
  --paars:        #785068;   /* aubergine uit logo */
  --paars-dark:   #5e3d51;   /* donkerder accent */
  --paars-light:  #f4eef2;   /* lichte tint */
  --wit:          #ffffff;
  --bg:           #fafafa;
  --g100:         #f2f2f2;
  --g200:         #e4e4e4;
  --g400:         #a8a8a8;
  --g600:         #707070;
  --g800:         #333;
  --text:         #1c1c1c;
  --rood:         #dc3545;   /* sitewaarschuwingsrood */
  --r:            8px;
  --sh-sm:        0 1px 5px rgba(0,0,0,.06);
  --sh-md:        0 3px 14px rgba(0,0,0,.09);
  --sh-lg:        0 8px 30px rgba(0,0,0,.12);
  --font:         'Quicksand', 'Helvetica Neue', Arial, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;font-weight:500}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:var(--font)}
input,select,textarea{
  font-family:var(--font);font-size:.94rem;font-weight:500;
  border:1.5px solid var(--g200);border-radius:var(--r);
  padding:0 14px;height:46px;width:100%;outline:none;
  transition:border-color .2s,box-shadow .2s;background:var(--wit);color:var(--text)
}
textarea{padding:11px 14px;height:auto}
input:focus,select:focus,textarea:focus{border-color:var(--groen);box-shadow:0 0 0 3px rgba(156,190,87,.15)}
label{display:block;font-size:.83rem;font-weight:700;color:var(--g600);margin-bottom:6px}
.field{margin-bottom:16px}

/* ─── HEADER (wit, zoals echte site) ─────────────────── */
header{
  background:var(--wit);padding:0 36px;display:flex;align-items:center;
  justify-content:space-between;height:74px;
  box-shadow:0 2px 10px rgba(0,0,0,.06);border-bottom:1px solid var(--g100);
  position:sticky;top:0;z-index:100
}
.logo-blok{display:flex;align-items:center}
.logo-img{height:48px;width:auto;display:block}
.hdr-r{display:flex;align-items:center;gap:8px}
.hdr-link{color:var(--g600);font-size:.86rem;font-weight:600;padding:8px 14px;border-radius:6px;border:none;background:transparent;cursor:pointer;font-family:var(--font);transition:all .2s}
.hdr-link:hover{color:var(--paars);background:var(--paars-light)}
.hdr-admin{background:var(--groen);color:#fff;font-size:.86rem;font-weight:700;padding:9px 20px;border-radius:6px;border:none;font-family:var(--font);cursor:pointer;transition:background .2s}
.hdr-admin:hover{background:var(--groen-dark)}

/* ─── PAGINA'S ──────────────────────────────────────── */
.page{display:none}.page.active{display:block}
.wrap{max-width:860px;margin:0 auto;padding:40px 24px}
.wrap-w{max-width:1080px;margin:0 auto;padding:40px 24px}
.ptitel{font-weight:700;font-size:1.7rem;color:var(--paars);margin-bottom:4px}
.psub{color:var(--g600);font-size:.93rem;margin-bottom:30px;font-weight:500}

/* ─── CARD ───────────────────────────────────────────── */
.card{background:var(--wit);border-radius:12px;box-shadow:var(--sh-sm);padding:28px;border:1px solid var(--g100)}
.card+.card{margin-top:16px}
.card-t{font-weight:700;font-size:1.1rem;color:var(--paars);margin-bottom:18px}

/* ─── KNOPPEN ───────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:11px 22px;border-radius:var(--r);font-size:.88rem;font-weight:700;transition:all .2s;border:none;cursor:pointer;font-family:var(--font)}
.btn-g{background:var(--groen);color:#fff}
.btn-g:hover{background:var(--groen-dark);transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-p{background:var(--paars);color:#fff}
.btn-p:hover{background:var(--paars-dark)}
.btn-ol{background:transparent;border:1.5px solid var(--paars);color:var(--paars)}
.btn-ol:hover{background:var(--paars-light)}
.btn-l{background:var(--paars-light);color:var(--paars-dark)}
.btn-l:hover{background:#ecdfe8}
.btn-icon{background:var(--wit);color:var(--paars);border:1.5px solid var(--g200);padding:8px 11px}
.btn-icon:hover{background:var(--paars-light);border-color:var(--paars)}
.btn-del{background:#fef2f2;color:var(--rood);border:1.5px solid #f5c6c6}
.btn-del:hover{background:#fde0e0}
.btn-sm{padding:7px 14px;font-size:.8rem}
.btn-fw{width:100%;justify-content:center}

/* ─── BADGES ────────────────────────────────────────── */
.badge{display:inline-block;padding:4px 11px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.02em}
.bg{background:var(--groen-light);color:var(--groen-dark)}
.bp{background:var(--paars-light);color:var(--paars)}
.bw{background:var(--g100);color:var(--g600)}
.bo{background:#fff3e0;color:#c27020}

.lijn{height:1px;background:var(--g100);margin:22px 0}

/* ══════════ PUBLIEKE PAGINA ══════════ */
.pand-kaart{background:var(--wit);border-radius:12px;overflow:hidden;box-shadow:var(--sh-md);margin-bottom:28px;border:1px solid var(--g100)}
.pand-foto-wrap{width:100%;height:250px;overflow:hidden;position:relative;background:linear-gradient(135deg,var(--paars) 0%,var(--paars-dark) 100%);display:flex;align-items:center;justify-content:center}
.pand-foto-ph{display:flex;flex-direction:column;align-items:center;gap:12px;color:rgba(255,255,255,.55)}
.pand-foto-ph span{font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;font-weight:600}
.pand-foto{width:100%;height:100%;object-fit:cover;display:block}
.pand-body{padding:22px 26px}
.pand-adres{font-weight:700;font-size:1.35rem;color:var(--paars);margin-bottom:10px;line-height:1.3}
.pand-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.kenm{display:flex;flex-wrap:wrap;gap:16px;font-size:.86rem;color:var(--g600);margin-top:10px;font-weight:600}
.k{display:flex;align-items:center;gap:6px}
.k svg{color:var(--groen);flex-shrink:0}
.pand-omschr{font-size:.9rem;line-height:1.7;color:var(--g600);margin-top:12px;padding-top:12px;border-top:1px solid var(--g100);font-weight:500}

.slots-t{font-weight:700;font-size:1.15rem;color:var(--paars);margin-bottom:14px}
.dag-gr{margin-bottom:20px}
.dag-lbl{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--g400);margin-bottom:9px;padding-bottom:7px;border-bottom:1px solid var(--g100)}
.slots-gr{display:grid;grid-template-columns:repeat(auto-fill,minmax(115px,1fr));gap:8px}
.slot-k{padding:13px 8px;border-radius:var(--r);border:1.5px solid var(--g200);background:var(--wit);text-align:center;transition:all .18s;cursor:pointer}
.slot-k:not(.vol):hover{border-color:var(--groen);background:var(--groen-light);transform:translateY(-2px);box-shadow:var(--sh-sm)}
.slot-k.gek{border-color:var(--groen);background:var(--groen-light);box-shadow:0 0 0 3px rgba(156,190,87,.2)}
.slot-k.vol{opacity:.4;cursor:not-allowed;background:var(--g100)}
.slot-uur{font-weight:700;font-size:1rem;color:var(--text);display:block}
.slot-dtk{font-size:.71rem;color:var(--g600);display:block;margin-top:2px;font-weight:600}
.slot-stxt{font-size:.69rem;display:block;margin-top:3px;font-weight:600}
.slot-k.gek .slot-stxt{color:var(--groen-dark)}
.slot-k.vol .slot-stxt{color:var(--g400)}
.slot-k:not(.vol):not(.gek) .slot-stxt{color:var(--g400)}

.form-wrap{margin-top:28px}.form-wrap.hid{display:none}
.gek-banner{background:var(--groen-light);border:1.5px solid #c5d99a;border-radius:var(--r);padding:12px 16px;margin-bottom:18px;font-size:.9rem;color:var(--groen-dark);font-weight:700;display:flex;align-items:center;gap:9px}
.succ-box{background:var(--groen-light);border:1.5px solid #c5d99a;border-radius:12px;padding:36px;text-align:center}
.succ-ic{display:flex;justify-content:center;margin-bottom:14px}
.succ-t{font-weight:700;font-size:1.3rem;color:var(--paars);margin-bottom:10px}
.succ-tx{color:var(--g600);font-size:.91rem;line-height:1.7;font-weight:500}

/* ══════════ LOGIN ══════════ */
.lgn-wrap{min-height:calc(100vh - 74px);display:flex;align-items:center;justify-content:center;padding:40px 24px;background:linear-gradient(150deg,var(--paars) 0%,var(--paars-dark) 55%,var(--groen) 130%)}
.lgn-card{background:var(--wit);border-radius:14px;box-shadow:var(--sh-lg);padding:44px 40px;width:100%;max-width:390px;text-align:center}
.lgn-logo-c{width:64px;height:64px;border-radius:50%;margin:0 auto 16px;background:radial-gradient(circle at 35% 30%, #8a6078, var(--paars) 70%);border:3px solid #b0b0b0;display:flex;align-items:center;justify-content:center}
.lgn-titel{font-weight:700;font-size:1.1rem;color:var(--paars);margin-bottom:4px}
.lgn-sub{color:var(--g400);font-size:.82rem;margin-bottom:26px;font-weight:600}
.lgn-card .field{text-align:left}

/* ══════════ DASHBOARD ══════════ */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:28px}
.stat{background:var(--wit);border-radius:10px;padding:20px 22px;border:1px solid var(--g100);box-shadow:var(--sh-sm)}
.stat-l{font-size:.76rem;font-weight:700;color:var(--g600);margin-bottom:10px}
.stat-v{font-weight:700;font-size:2.1rem;color:var(--paars);line-height:1}
.tbl{width:100%;border-collapse:collapse;font-size:.87rem}
.tbl th{text-align:left;font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--g400);padding:11px 16px;border-bottom:2px solid var(--g100);white-space:nowrap}
.tbl td{padding:14px 16px;border-bottom:1px solid var(--g100);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:var(--bg)}
.pnm{font-weight:700;color:var(--text)}
.ploc{font-size:.78rem;color:var(--g400);margin-top:2px;font-weight:600}
.bez-wrap{display:flex;align-items:center;gap:10px}
.bez-bar{flex:1;height:7px;background:var(--g100);border-radius:4px;overflow:hidden;min-width:60px}
.bez-fill{height:100%;border-radius:4px;transition:width .4s}
.laag{background:var(--groen)}.midden{background:#e6952a}.hoog{background:var(--rood)}
.bez-txt{font-size:.82rem;color:var(--g600);white-space:nowrap;font-weight:700}
.acties{display:flex;gap:8px;justify-content:flex-end}

/* ══════════ DETAIL ══════════ */
.terug{display:inline-flex;align-items:center;gap:6px;color:var(--paars);font-size:.85rem;font-weight:700;margin-bottom:22px;cursor:pointer;transition:gap .15s}
.terug:hover{gap:10px}
.dag-blok{margin-bottom:26px}
.dag-blok-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:10px}
.dag-blok-titel{font-weight:700;font-size:1rem;color:var(--paars)}
.si{margin-bottom:9px;border-radius:var(--r);overflow:hidden;border:1px solid var(--g200)}
.sh{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;background:var(--wit);cursor:pointer;transition:background .15s;user-select:none}
.sh:hover{background:var(--bg)}
.sh.open{background:var(--paars-light);border-bottom:1px solid var(--g200)}
.sh-l{display:flex;align-items:center;gap:13px}
/* nieuwe slot status indicator: gekleurde stip i.p.v. emoji */
.sdot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.sdot.bezet{background:var(--groen)}
.sdot.vrij{background:var(--g200);border:2px solid var(--g400);box-sizing:border-box}
.snm{font-weight:700;font-size:.93rem;color:var(--text)}
.ssub{font-size:.79rem;color:var(--g600);margin-top:2px;display:flex;align-items:center;gap:6px;font-weight:600}
.opm-ic{color:var(--paars);flex-shrink:0;display:inline-flex}
.sh-r{display:flex;align-items:center;gap:10px}
.sb{display:none;background:var(--wit)}.sb.open{display:block}
.kr{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:start;padding:15px 18px;border-bottom:1px solid var(--g100);font-size:.86rem}
.kr:last-child{border-bottom:none}
.knm{font-weight:700;color:var(--text)}
.kdet{color:var(--g600);font-size:.81rem;margin-top:3px;font-weight:500}
.kopm{font-style:italic;color:var(--g600);font-size:.81rem;margin-top:7px;padding-top:7px;border-top:1px dashed var(--g200);font-weight:500}
.kact{display:flex;gap:6px;justify-content:flex-end;align-items:flex-start}
.leeg{padding:18px;color:var(--g400);font-size:.85rem;text-align:center;font-weight:600}

/* ══════════ NIEUW PAND / SLOT BOUWER ══════════ */
.sbr{display:grid;grid-template-columns:1.2fr 1fr 1fr 1.1fr auto;gap:10px;align-items:end}
.del-btn{height:46px;padding:0 13px;background:#fef2f2;border:1.5px solid #f5c6c6;border-radius:var(--r);color:var(--rood);font-size:.9rem;font-weight:700;cursor:pointer;transition:background .15s;font-family:var(--font);display:flex;align-items:center;justify-content:center;white-space:nowrap}
.del-btn:hover{background:#fde0e0}
.add-mom{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:var(--paars-light);border:1.5px dashed var(--paars);border-radius:var(--r);color:var(--paars);font-size:.88rem;font-weight:700;cursor:pointer;transition:background .15s;font-family:var(--font);margin-top:6px}
.add-mom:hover{background:#ecdfe8}
.prev-item{display:inline-flex;align-items:center;gap:5px;background:var(--groen-light);border:1px solid #c5d99a;border-radius:6px;padding:5px 11px;font-size:.79rem;color:var(--groen-dark);margin:3px;font-weight:600}

/* ══════════ MODAL ══════════ */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(2px)}
.ov.open{display:flex}
.modal{background:var(--wit);border-radius:12px;box-shadow:var(--sh-lg);padding:32px;width:100%;max-width:460px;animation:min .2s ease}
@keyframes min{from{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-t{font-weight:700;font-size:1.15rem;color:var(--paars);margin-bottom:14px}
.modal-v{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}

/* ══════════ TOAST ══════════ */
.toast{position:fixed;bottom:24px;right:24px;background:var(--g800);color:#fff;padding:13px 20px;border-radius:var(--r);font-size:.87rem;font-weight:600;box-shadow:var(--sh-lg);z-index:300;opacity:0;transform:translateY(8px);transition:all .25s;pointer-events:none}
.toast.on{opacity:1;transform:translateY(0)}
.toast.ok{border-left:4px solid var(--groen)}
.toast.err{border-left:4px solid var(--rood)}

/* Datum-veld met kalenderknop */
.datum-veld{position:relative}
.datum-veld input[type="text"]{padding-right:42px}
.datum-knop{position:absolute;right:1px;top:1px;bottom:1px;width:40px;border:none;background:transparent;border-radius:0 var(--r) var(--r) 0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--g600);transition:color .15s}
.datum-knop:hover{color:var(--paars)}
.datum-knop input[type="date"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;padding:0}

@media(max-width:640px){
  header{padding:0 14px;height:64px}
  .logo-img{height:38px}
  .wrap,.wrap-w{padding:22px 14px}
  .sbr{grid-template-columns:1fr 1fr}
  .tbl th:nth-child(2),.tbl td:nth-child(2){display:none}
  .kr{grid-template-columns:1fr auto}
}
/* ── Inklapbare dagen in pand-detail ── */
.dag-body{display:none}
.dag-body.open{display:block}
.dag-chv{transition:transform .18s;flex-shrink:0;color:var(--g600)}
.dag-blok-hdr.open .dag-chv{transform:rotate(90deg)}
.dag-blok-hdr{user-select:none}
.dag-voorbij .dag-blok-titel{color:var(--g600)}
.dag-voorbij{opacity:.85}


/* ── Geblokkeerd slot (stip) ── */
.sdot.geblok{background:#f0c000;border:2px solid #c89a00;box-sizing:border-box}
