:root{
  --red:#DA291C; --red-dark:#AD2015;
  --yellow:#FFC72C;
  --ink:#2B2420; --gray-600:#6B6459; --gray-400:#9C9488; --gray-200:#E4DFD6; --gray-100:#F1EDE5;
  --bg:#F5F2EC; --white:#FFFFFF;
  --ok:#1E8A4C; --ok-bg:#E4F5EA;
  --warn:#C97A0A; --warn-bg:#FCF1DC;
  --crit:#D93025; --crit-bg:#FBE7E5;
  --info:#2E6DB4; --info-bg:#E9F1FB;
  --shadow-sm:0 2px 8px rgba(43,36,32,.06);
  --shadow-md:0 10px 28px rgba(43,36,32,.14);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:'Poppins',-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--ink); min-height:100vh;
}
h1,h2,h3{margin:0;font-weight:600;}
p{margin:0;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;font-size:14px;}
[hidden]{display:none !important;}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:999px;border:none;font-size:14px;font-weight:600;transition:background .15s;}
.btn-primary{background:var(--red);color:var(--white);}
.btn-primary:hover{background:var(--red-dark);}
.btn-ghost{background:transparent;color:var(--red);border:1.5px solid var(--gray-200);}
.btn-ghost:hover{border-color:var(--red);background:var(--crit-bg);}
.btn-danger{background:transparent;color:var(--crit);border:1.5px solid var(--gray-200);margin-right:auto;}
.btn-danger:hover{border-color:var(--crit);background:var(--crit-bg);}
.btn-block{width:100%;}
.icon-btn{background:transparent;border:none;color:var(--white);opacity:.85;padding:6px;border-radius:8px;display:flex;}
.icon-btn:hover{opacity:1;background:rgba(255,255,255,.15);}

.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:999px;font-size:12.5px;font-weight:600;}
.badge-ok{background:var(--ok-bg);color:var(--ok);}
.badge-aandacht{background:var(--warn-bg);color:var(--warn);}
.badge-actie{background:var(--crit-bg);color:var(--crit);}
.badge-nieuw{background:var(--info-bg);color:var(--info);}
.badge-region{background:var(--gray-100);color:var(--gray-600);}

/* ---- Login ---- */
.login-wrap{display:flex;min-height:100vh;}
.login-brand{
  flex:0 0 42%;background:var(--red);color:var(--white);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:48px;text-align:center;gap:14px;position:relative;overflow:hidden;
}
.login-brand::after{
  content:'';position:absolute;bottom:-60px;right:-60px;width:220px;height:220px;
  border-radius:50%;background:rgba(255,199,44,.12);
}
.login-brand h1{font-size:26px;}
.login-brand .sub{color:var(--yellow);font-size:14.5px;font-weight:500;margin-bottom:18px;}
.value-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;text-align:left;}
.value-list li{display:flex;align-items:center;gap:12px;font-size:14px;}
.value-list .dot{
  flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--yellow);color:var(--red-dark);
  display:flex;align-items:center;justify-content:center;
}
/* Uitsnede van mcd-logo.png: het logo zit linksboven op een breed, verder wit canvas.
   Het venster toont alleen het rode vlak (met marge naar binnen zodat er nooit wit
   doorheen komt); het rood loopt naadloos over in het paneel dankzij de kleurmeting. */
.logo-crop{width:200px;aspect-ratio:1.45/1;position:relative;overflow:hidden;margin:0 auto;}
.logo-crop img{position:absolute;width:543%;left:-9.2%;top:-12.9%;display:block;}
.login-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--white);}
.login-card{width:100%;max-width:360px;}
.kicker{font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray-400);margin-bottom:8px;}
.login-card h2{font-size:26px;margin-bottom:8px;}
.login-card .desc{color:var(--gray-600);font-size:14.5px;margin-bottom:24px;line-height:1.5;}
.login-hint{margin-top:14px;font-size:12.5px;color:var(--gray-400);text-align:center;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:500;color:var(--gray-600);margin-bottom:6px;}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border-radius:10px;border:1.5px solid var(--gray-200);background:var(--gray-100);}
.field textarea{resize:vertical;min-height:90px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);background:var(--white);}
.form-error{color:var(--crit);font-size:13px;margin:0 0 14px;}

/* ---- App shell ---- */
.topbar{background:var(--red);color:var(--white);padding:0 28px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20;}
.brand-mark{display:flex;align-items:center;gap:11px;}
.brand-mark span{font-weight:600;font-size:16px;}
.user-block{display:flex;align-items:center;gap:12px;}
.user-meta{text-align:right;line-height:1.3;}
.user-meta .name{font-size:13.5px;font-weight:600;}
.user-meta .role{font-size:11.5px;color:var(--yellow);}
main{max-width:1200px;margin:0 auto;width:100%;padding:28px;}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:22px;flex-wrap:wrap;}
.page-head h1{font-size:23px;}
.page-head .desc{color:var(--gray-600);font-size:14px;margin-top:4px;}
.page-footer{text-align:center;padding:18px;font-size:12px;color:var(--gray-400);}

.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px;}
.kpi-card{
  background:var(--white);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow-sm);
  border:none;border-left:4px solid var(--gray-200);text-align:left;font-family:inherit;color:inherit;
  cursor:pointer;transition:transform .12s,box-shadow .12s;width:100%;
}
.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.kpi-card.active{box-shadow:0 0 0 2px var(--ink), var(--shadow-sm);}
.kpi-card.total{border-left-color:var(--ink);}
.kpi-card.ok{border-left-color:var(--ok);}
.kpi-card.aandacht{border-left-color:var(--warn);}
.kpi-card.actie{border-left-color:var(--crit);}
.kpi-card.nieuw{border-left-color:var(--info);}
.kpi-card .num{font-size:26px;font-weight:700;line-height:1;}
.kpi-card .label{font-size:12.5px;color:var(--gray-600);margin-top:6px;}

.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px;margin-bottom:28px;}
.card-grid .empty-note{grid-column:1/-1;}
.loc-card{background:var(--white);border-radius:16px;box-shadow:var(--shadow-sm);padding:18px;display:flex;flex-direction:column;gap:9px;cursor:pointer;transition:transform .15s,box-shadow .15s;}
.loc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.loc-card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;}
.loc-card h3{font-size:15px;}
.loc-city{font-size:12.5px;color:var(--gray-400);}
.loc-meta{display:flex;flex-direction:column;gap:5px;font-size:12.5px;color:var(--gray-600);}
.history-dots{display:flex;gap:5px;margin-top:2px;}
.history-dots .dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.empty-note{color:var(--gray-400);font-size:13.5px;padding:8px 2px;}

.panel{background:var(--white);border-radius:14px;padding:20px;box-shadow:var(--shadow-sm);margin-bottom:28px;}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px;}
.panel-head h2{font-size:16px;}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.table-scroll table{min-width:640px;}
table.tbl{width:100%;border-collapse:collapse;font-size:13px;}
table.tbl th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--gray-400);font-weight:600;padding:8px 10px;border-bottom:1.5px solid var(--gray-200);}
table.tbl td{padding:9px 10px;border-bottom:1px solid var(--gray-100);vertical-align:top;}
table.tbl tr:hover td{background:var(--gray-100);}
.status-select{padding:5px 8px;border-radius:8px;border:1.5px solid var(--gray-200);background:var(--white);font-size:12.5px;}
.btn-link{background:none;border:none;color:var(--info);font-size:12.5px;padding:0;text-decoration:underline;cursor:pointer;}
.btn-link.danger{color:var(--crit);}
.nowrap{white-space:nowrap;}
.chk-list{max-height:220px;overflow-y:auto;border:1.5px solid var(--gray-200);border-radius:10px;background:var(--white);}
.chk{
  display:flex;align-items:center;gap:12px;font-size:13.5px;
  padding:9px 12px;margin:0;border-bottom:1px solid var(--gray-100);cursor:pointer;
}
.chk:last-child{border-bottom:none;}
.chk:hover{background:var(--gray-100);}
.chk input[type="checkbox"]{
  width:16px;height:16px;flex:0 0 auto;margin:0;padding:0;accent-color:var(--red);cursor:pointer;
}

.head-btns{display:flex;gap:10px;flex-wrap:wrap;}

/* ---- Foto's ---- */
.foto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-bottom:8px;}
.foto-item{position:relative;border-radius:10px;overflow:hidden;background:var(--gray-100);aspect-ratio:4/3;}
.foto-item img{width:100%;height:100%;object-fit:cover;display:block;}
.foto-del{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.55);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.foto-del:hover{background:rgba(0,0,0,.75);}
.foto-upload{display:flex;align-items:center;gap:10px;margin:6px 0 4px;flex-wrap:wrap;}

/* ---- Patchkast (42U) ---- */
.rack-model{font-size:12px;color:var(--gray-400);margin:2px 0 10px;}
.rack-wrap{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start;margin-bottom:6px;}
.rack{display:grid;grid-template-rows:repeat(42,20px);grid-template-columns:1fr;width:250px;flex:0 0 auto;background:#3A332C;border-radius:10px;padding:8px;border:2px solid #2B2420;}
.rack-slot{grid-column:1;border-bottom:1px dashed rgba(255,255,255,.12);display:flex;align-items:center;cursor:pointer;}
.rack-slot .rack-u{font-size:9px;color:rgba(255,255,255,.45);width:20px;text-align:right;padding-right:6px;user-select:none;}
.rack-slot.over{background:rgba(255,199,44,.3);}
.rack-item{grid-column:1;background:var(--yellow);color:var(--ink);border-radius:5px;margin-left:26px;padding:0 8px;display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;z-index:2;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.35);cursor:grab;}
.rack-item:active{cursor:grabbing;}
.rack-item-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rack-item-u{font-size:10px;opacity:.7;flex-shrink:0;}
.rack-del{background:rgba(0,0,0,.15);border:none;border-radius:50%;width:16px;height:16px;line-height:1;font-size:11px;color:var(--ink);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;}
.rack-del:hover{background:rgba(0,0,0,.3);}
.rack-palet{flex:1 1 220px;min-width:220px;}
.rack-hint{font-size:12.5px;color:var(--gray-600);margin:0 0 10px;line-height:1.5;}
.rack-pal-item{display:inline-flex;gap:5px;align-items:center;margin:0 6px 6px 0;padding:6px 11px;border-radius:999px;border:1.5px solid var(--gray-200);background:var(--white);font-size:12.5px;cursor:grab;font-family:inherit;}
.rack-pal-item:hover{border-color:var(--red);}
.rack-pal-item small{color:var(--gray-400);}
.rack-custom{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;}
.rack-custom input{flex:1 1 130px;padding:8px 10px;border-radius:8px;border:1.5px solid var(--gray-200);background:var(--gray-100);}
.rack-custom select{padding:8px;border-radius:8px;border:1.5px solid var(--gray-200);background:var(--white);}

/* ---- Periodieke afspraak ---- */
.afspraak-box{border:1.5px solid var(--gray-200);border-radius:12px;padding:14px 16px;margin-bottom:6px;}
.afspraak-datum{font-weight:600;font-size:14.5px;margin:0 0 10px;}
.afspraak-acties{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;}
.afspraak-line{font-size:12.5px;color:var(--gray-600);}
.afspraak-line.af-ok{color:var(--ok);font-weight:600;}
.afspraak-line.af-attentie{color:var(--warn);font-weight:600;}

/* ---- 2FA bij inloggen ---- */
.mfa-hint{font-size:13.5px;color:var(--gray-600);margin:6px 0 16px;line-height:1.5;}
.mfa-steps{font-size:13.5px;color:var(--gray-600);padding-left:20px;margin:8px 0 14px;line-height:1.55;}
.mfa-steps li{margin-bottom:5px;}
.mfa-qr{display:block;width:180px;height:180px;margin:0 auto 10px;border:1.5px solid var(--gray-200);border-radius:12px;padding:8px;background:#fff;}
.mfa-secret{font-size:12px;color:var(--gray-600);text-align:center;margin:0 0 14px;word-break:break-all;}
.mfa-secret code{background:var(--gray-100);padding:2px 6px;border-radius:6px;}

/* ---- Overlays ---- */
.overlay{position:fixed;inset:0;background:rgba(30,24,20,.55);display:none;align-items:center;justify-content:center;padding:24px;z-index:2000;}
.overlay.open{display:flex;}
.modal{background:var(--white);border-radius:18px;max-width:720px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-md);position:relative;padding:26px 28px;}
.modal.modal-sm{max-width:460px;}
.modal-close{position:absolute;top:16px;right:16px;background:var(--gray-100);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--gray-600);font-size:16px;}
.modal-close:hover{background:var(--gray-200);}
.modal h2{font-size:20px;margin-bottom:4px;}
.modal .addr{font-size:13px;color:var(--gray-600);margin-bottom:16px;}
.badges-row{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;}
.callout{padding:12px 14px;border-radius:12px;font-size:13.5px;line-height:1.5;margin-bottom:18px;}
.callout.ok{background:var(--ok-bg);color:#175E37;}
.callout.aandacht{background:var(--warn-bg);color:#8A5606;}
.callout.actie{background:var(--crit-bg);color:#9C221B;}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px;}
.info-item .k{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-400);margin-bottom:4px;}
.info-item .v{font-size:13.5px;font-weight:600;}
.modal h3{font-size:14px;margin:18px 0 10px;}
.beheer-box{border:1.5px dashed var(--gray-200);border-radius:12px;padding:16px;margin-top:18px;}
.beheer-box h3{margin-top:0;}
.form-row{display:flex;gap:10px;flex-wrap:wrap;}
.form-row .field{flex:1 1 130px;margin-bottom:10px;}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;flex-wrap:wrap;}
.form-msg{font-size:13px;margin-top:8px;}
.form-msg.ok{color:var(--ok);}
.form-msg.err{color:var(--crit);}
.success-box{text-align:center;padding:18px 6px;}
.success-box .big{font-size:38px;line-height:1;margin-bottom:10px;}

@media (max-width:720px){
  .login-wrap{flex-direction:column;}
  .login-brand{flex:none;padding:32px 22px;}
  .login-form-side{padding:30px 22px;}
  .page-head{flex-direction:column;}
}
@media (max-width:560px){
  .topbar{padding:0 14px;}
  .user-meta{display:none;}
  main{padding:18px 14px;}
  .modal{padding:22px 18px;}
  .modal-footer{flex-direction:column;}
  .modal-footer .btn{width:100%;}
}
