/* Jong NWBA — beheeromgeving (huisstijl) */

body.admin { background: var(--paper); }

.adm-shell { display: grid; grid-template-columns: 256px 1fr; min-height: 100vh; }

/* sidebar */
.adm-side {
  background: var(--ink); color: #cfc6b8; padding: 22px 16px; display: flex; flex-direction: column; gap: 4px;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.adm-side .brand { display: flex; align-items: center; gap: 10px; padding: 4px 8px 18px; }
.adm-side .brand img { height: 34px; }
.adm-side a.item {
  display: flex; align-items: center; gap: 12px; padding: 11px 12px; border-radius: 12px;
  color: #cfc6b8; font-family: var(--display); font-weight: 600; font-size: .95rem; cursor: pointer; transition: .15s;
}
.adm-side a.item:hover { background: rgba(255,255,255,.07); color: #fff; }
.adm-side a.item.active { background: var(--orange); color: #fff; }
.adm-side a.item .ic { width: 20px; text-align: center; }
.adm-side a.item .badge { margin-left: auto; background: var(--lime); color: var(--ink); border-radius: 999px; font-size: .72rem; padding: 1px 8px; font-weight: 800; }
.adm-side a.item .lock { margin-left: auto; opacity: .8; }
.adm-side .spacer { flex: 1; }
.adm-side .me { border-top: 1px solid rgba(255,255,255,.12); padding-top: 14px; margin-top: 8px; font-size: .82rem; line-height: 1.5; }
.adm-side .me strong { color: #fff; font-family: var(--display); }
.adm-side .me .role { display: inline-block; margin-top: 6px; padding: 2px 10px; border-radius: 999px; font-size: .72rem; font-weight: 700; }
.adm-side .me .role.adm { background: var(--orange); color: #fff; }
.adm-side .me .role.beh { background: var(--cobalt); color: #fff; }
.adm-side .me a.logout { color: var(--lime); display: inline-block; margin-top: 8px; }

/* main */
.adm-main { padding: 26px clamp(18px, 3vw, 40px) 60px; max-width: 1180px; }
.adm-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; flex-wrap: wrap; margin-bottom: 24px; }
.adm-head h1 { font-size: clamp(1.6rem, 3vw, 2.2rem); }
.adm-head .sub { color: var(--muted); margin-top: 4px; }

/* statkaarten */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 16px; }
.stat { background: #fff; border: 2px solid var(--ink); border-radius: var(--r); padding: 18px; box-shadow: var(--pop); position: relative; overflow: hidden; }
.stat .ic-bg { position: absolute; right: 10px; top: 8px; font-size: 1.6rem; opacity: .25; }
.stat .lbl { color: var(--muted); font-size: .85rem; font-family: var(--display); font-weight: 600; }
.stat .num { display: block; font-family: var(--display); font-weight: 800; font-size: 2.1rem; line-height: 1.1; margin-top: 4px; }
.stat .delta { font-size: .8rem; color: var(--muted); }
.stat .delta.up { color: #1f8a5b; } .stat .delta.warn { color: var(--orange-700); }
.stat.hi { background: color-mix(in srgb, var(--orange) 10%, #fff); }
.stat.action { background: color-mix(in srgb, var(--lime) 22%, #fff); }
.stat.alt { background: color-mix(in srgb, var(--cobalt) 8%, #fff); }

/* panelen / boxen */
.panel { background: #fff; border: 2px solid var(--ink); border-radius: var(--r); padding: 20px; box-shadow: var(--pop); margin-bottom: 18px; }
.panel.alt { background: var(--paper-2); }
.panel h3 { margin: 0 0 14px; }
.cols { display: grid; gap: 18px; align-items: start; }
.cols.c2 { grid-template-columns: 1.3fr 1fr; }
@media (max-width: 900px) { .cols.c2 { grid-template-columns: 1fr; } }

/* feed */
.feed-item { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1.5px dashed var(--line); font-size: .92rem; }
.feed-item:last-child { border-bottom: 0; }
.feed-item .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--cobalt); flex: none; }
.feed-item time { color: var(--muted-2); font-size: .8rem; }
.feed-item .ago { margin-left: auto; color: var(--muted-2); font-size: .78rem; white-space: nowrap; }

/* pills/status */
.pill { font-family: var(--display); font-weight: 700; font-size: .72rem; padding: 3px 10px; border-radius: 999px; border: 1.5px solid var(--ink); }
.pill.ok { background: color-mix(in srgb, #1f8a5b 18%, #fff); border-color: #1f8a5b; color: #155e3f; }
.pill.wait { background: color-mix(in srgb, var(--lime) 40%, #fff); border-color: #b9d12f; color: var(--lime-ink); }
.pill.off { background: var(--line); color: var(--muted); border-color: var(--muted-2); }

/* tabellen */
.tbl { width: 100%; border-collapse: collapse; font-size: .92rem; }
.tbl th { text-align: left; font-family: var(--display); font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); padding: 12px 16px; border-bottom: 2px solid var(--ink); }
.tbl td { padding: 12px 16px; border-bottom: 1.5px solid var(--line); }
.tbl tr:last-child td { border-bottom: 0; }
.tbl tr:hover td { background: var(--paper); }
.tbl .actions { text-align: right; white-space: nowrap; }
.panel.flush { padding: 0; overflow: hidden; }

/* toolbar */
.toolbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: 16px 0; }
.toolbar .search { flex: 1; min-width: 200px; }

/* capaciteitsbalk */
.capbar { height: 12px; border-radius: 999px; background: var(--line); border: 2px solid var(--ink); overflow: hidden; }
.capbar > i { display: block; height: 100%; background: var(--orange); }

/* toggle-rijen */
.toggle-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 0; border-bottom: 1.5px dashed var(--line); }
.toggle-row:last-child { border-bottom: 0; }
.toggle-row small { display: block; color: var(--muted); font-size: .82rem; margin-top: 2px; }
.switch2 { width: 48px; height: 27px; border-radius: 999px; border: 2px solid var(--ink); background: #fff; position: relative; cursor: pointer; flex: none; display: inline-block; }
.switch2::after { content: ""; position: absolute; top: 2px; left: 2px; width: 19px; height: 19px; border-radius: 50%; background: var(--ink); transition: .15s; }
.switch2.on { background: var(--orange); } .switch2.on::after { left: 23px; background: #fff; }
.switch2 input { position: absolute; opacity: 0; pointer-events: none; }

/* rol-badges */
.role { display: inline-block; padding: 3px 11px; border-radius: 999px; font-family: var(--display); font-weight: 700; font-size: .74rem; }
.role.adm { background: var(--orange); color: #fff; }
.role.beh { background: var(--cobalt); color: #fff; }

/* lock-scherm */
.lock-screen { text-align: center; padding: 70px 20px; }
.lock-screen .big { font-size: 3rem; }

/* login */
.adm-login { display: grid; place-items: center; min-height: 100vh; padding: 20px; background:
  radial-gradient(900px 500px at 80% -10%, color-mix(in srgb, var(--orange) 30%, var(--ink)), var(--ink)); }
.adm-login .card { width: min(420px, 94vw); }

.note { background: color-mix(in srgb, var(--lime) 20%, #fff); border: 1.5px solid #b9d12f; border-radius: 12px; padding: 12px 14px; font-size: .85rem; color: var(--lime-ink); }
.amt { font-family: var(--display); font-weight: 800; }

.adm-flash { border: 2px solid var(--ink); border-radius: 12px; padding: 12px 16px; margin-bottom: 16px; box-shadow: 3px 3px 0 var(--ink); font-weight: 600; }
.adm-flash.success { background: color-mix(in srgb, var(--lime) 35%, #fff); }
.adm-flash.error { background: color-mix(in srgb, var(--orange) 14%, #fff); border-color: var(--orange-700); color: var(--orange-700); }

/* paginatie */
.pager { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 14px; }
.pager .pglink {
  font-family: var(--display); font-weight: 600; font-size: .85rem;
  padding: .4em .8em; border-radius: 10px; border: 2px solid var(--ink); background: #fff; color: var(--ink); cursor: pointer;
}
.pager a.pglink:hover { background: var(--lime); }
.pager .pglink.on { background: var(--ink); color: #fff; }
.pager .pglink.disabled { opacity: .4; cursor: default; border-color: var(--line); }

/* admin: tabellen netjes scrollbaar op smal scherm */
@media (max-width: 720px) {
  .panel.flush { overflow-x: auto; }
  .panel.flush .tbl { min-width: 560px; }
  .adm-head { flex-direction: column; align-items: stretch; }
  .toolbar { flex-direction: column; align-items: stretch; }
  .toolbar form { width: 100%; }
  .toolbar .input { width: 100% !important; min-width: 0 !important; }
}

@media (max-width: 820px) {
  .adm-shell { grid-template-columns: 1fr; }
  .adm-side { position: static; height: auto; flex-direction: row; flex-wrap: wrap; gap: 4px; }
  .adm-side .brand { width: 100%; }
  .adm-side .spacer, .adm-side .me { display: none; }
}
