:root{
  --vema:#1f4e6b;          /* donkerblauw uit logo/koppen */
  --vema-dark:#163a50;
  --band:#e8b96a;          /* lichte oker rij (zoals subkop-rijen) */
  --row-alt:#fbf3e3;       /* lichte rij-achtergrond */
  --line:#9fb3c0;
  --text:#1c2733;
  --muted:#6a7a86;
  --ok:#2e7d4f; --err:#b3261e; --warn:#9a6b00;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:#eef1f4;font-size:14px}
a{color:var(--vema);text-decoration:none}
a:hover{text-decoration:underline}

/* Topbar */
.topbar{background:#fff;border-bottom:3px solid var(--vema)}
.topbar-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;gap:16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--vema)}
.brand img{height:38px;width:auto}
.mainnav{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.mainnav a{font-weight:600;color:var(--vema-dark)}
.mainnav a.on{text-decoration:underline}
.btn-new{background:var(--vema);color:#fff!important;padding:7px 12px;border-radius:6px}
.btn-new:hover{background:var(--vema-dark);text-decoration:none}
.logout{color:var(--muted)!important;font-weight:500!important}

.container{max-width:1180px;margin:18px auto;padding:0 16px}
.sitefoot{max-width:1180px;margin:30px auto;padding:16px;color:var(--muted);font-size:12px}

h1{font-size:22px;color:var(--vema-dark);margin:0 0 14px}
h2{font-size:17px;color:var(--vema-dark);margin:22px 0 10px}

/* Knoppen */
.btn{display:inline-block;background:var(--vema);color:#fff;padding:8px 14px;border-radius:6px;border:0;cursor:pointer;font-size:14px;font-weight:600}
.btn:hover{background:var(--vema-dark);text-decoration:none}
.btn.sec{background:#fff;color:var(--vema);border:1px solid var(--line)}
.btn.sec:hover{background:#f3f6f8}
.btn.danger{background:var(--err)}
.btn.small{padding:5px 9px;font-size:12px}

/* Kaarten / tabellen */
.card{background:#fff;border:1px solid #dbe2e8;border-radius:8px;padding:16px;margin-bottom:16px}
table.data{width:100%;border-collapse:collapse;background:#fff}
table.data th,table.data td{padding:8px 10px;border-bottom:1px solid #e6ebef;text-align:left}
table.data th{background:var(--vema);color:#fff;font-weight:600;font-size:13px}
table.data tr:hover td{background:#f5f9fb}
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;font-weight:600}
.badge.concept{background:#fdebcd;color:var(--warn)}
.badge.definitief{background:#d8efe0;color:var(--ok)}

/* Formulieren */
label{display:block;font-weight:600;margin:0 0 4px;font-size:13px}
input[type=text],input[type=date],input[type=tel],input[type=email],input[type=password],select,textarea{
  width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:6px;font-size:14px;font-family:inherit;background:#fff}
textarea{min-height:90px;resize:vertical}
.field{margin-bottom:12px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
@media(max-width:760px){.grid2,.grid3{grid-template-columns:1fr}}
.actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.help{color:var(--muted);font-size:12px}

/* Flash */
.flash{padding:10px 14px;border-radius:6px;margin-bottom:14px;font-weight:600}
.flash-ok{background:#d8efe0;color:var(--ok)}
.flash-err{background:#f7d9d6;color:var(--err)}
.flash-warn{background:#fdebcd;color:var(--warn)}

/* ---- Checklist (invoer) ---- */
.checklist{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:900px){.checklist{grid-template-columns:1fr}}
table.cl{width:100%;border-collapse:collapse;font-size:12.5px}
table.cl th,table.cl td{border:1px solid var(--line)}
table.cl thead th{background:#fff;color:var(--vema-dark);font-weight:600;padding:4px;vertical-align:bottom;text-align:center;font-size:11px;line-height:1.1}
table.cl thead th.col-item{text-align:left;vertical-align:bottom;padding-left:8px}
table.cl th.rot span{writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;display:inline-block}
table.cl td.item{padding:3px 8px;background:var(--row-alt)}
table.cl tr:nth-child(even) td.item{background:#fff}
table.cl td.chk{width:30px;text-align:center;padding:2px}
table.cl td.chk input{margin:0}
table.cl tr.group td{background:var(--vema);color:#fff;font-weight:700;padding:5px 8px;font-size:12.5px}

/* Schade-tekening */
.schade-wrap{position:relative;display:inline-block;border:1px solid var(--line);background:#fff;max-width:100%}
.schade-wrap img{display:block;max-width:100%;height:auto;cursor:crosshair}
.schade-dot{position:absolute;width:20px;height:20px;margin:-10px 0 0 -10px;border-radius:50%;background:var(--err);color:#fff;
  font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:move;border:2px solid #fff;box-shadow:0 0 0 1px var(--err)}
.schade-list{margin-top:10px}
.schade-list .srow{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.schade-list .srow .num{width:24px;height:24px;border-radius:50%;background:var(--err);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}

/* Zoekbare keuzelijst (combobox) */
.combo-list{position:absolute;left:0;right:0;z-index:30;background:#fff;border:1px solid var(--line);border-top:0;
  border-radius:0 0 6px 6px;max-height:280px;overflow-y:auto;box-shadow:0 6px 16px rgba(0,0,0,.12)}
.combo-item{padding:8px 10px;cursor:pointer;font-size:14px;border-bottom:1px solid #eef2f5}
.combo-item:hover{background:#eef6fb}
.combo-empty{padding:8px 10px;color:var(--muted);font-size:13px}

/* Detail-weergave statuslabels */
.statlist{font-size:13px}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--vema);margin-right:6px}
