:root{
  --bg:#0f1419; --card:#1a212b; --card2:#141b24; --line:#2a333f; --line2:#1c242f;
  --text:#e6edf3; --muted:#8b97a7; --accent:#3b82f6; --green:#22c55e; --red:#ef4444;
  --amber:#f59e0b; --purple:#8b5cf6; --teal:#14b8a6;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted);font-size:13px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-variant-numeric:tabular-nums}

.brand{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text)}
.brand:hover{text-decoration:none}
.brand-icon{color:var(--accent)}

/* ---- app-shell met zijbalk ---- */
.app{display:flex;min-height:100vh}
.sidebar{width:212px;flex-shrink:0;background:var(--card);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:60}
.side-brand{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text);
  padding:16px 16px 14px;border-bottom:1px solid var(--line)}
.side-brand:hover{text-decoration:none}
.side-nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.side-nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;
  color:var(--muted);font-size:14px}
.side-nav a:hover{background:var(--card2);color:var(--text);text-decoration:none}
.side-nav a.active{background:var(--card2);color:var(--text);box-shadow:inset 2px 0 0 var(--accent)}
.side-nav .ni{width:18px;text-align:center;color:var(--muted);font-size:14px}
.side-nav a.active .ni{color:var(--accent)}
.side-sep{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);
  opacity:.6;padding:14px 12px 5px}
.side-user{border-top:1px solid var(--line);padding:11px 12px}
.su-name{display:block;font-size:13px;color:var(--text);margin-bottom:8px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-badge{font-size:10px;background:rgba(59,130,246,.16);color:#93c5fd;border-radius:99px;padding:1px 7px}
.su-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.su-logout{display:block}
.lang-switch{display:flex;border:1px solid var(--line);border-radius:7px;overflow:hidden;flex-shrink:0}
.lang-switch button{background:transparent;border:none;color:var(--muted);font-size:11px;font-weight:600;
  padding:4px 9px;cursor:pointer;border-radius:0}
.lang-switch button:hover{color:var(--text);filter:none;background:var(--card2)}
.lang-switch button.active{background:var(--accent);color:#fff}
.btn-xs{padding:5px 11px;font-size:13px}
.main-wrap{flex:1;min-width:0;display:flex;flex-direction:column}
.sidebar-backdrop{display:none}
.topbar{display:none;align-items:center;gap:12px;padding:11px 16px;
  border-bottom:1px solid var(--line);background:var(--card);position:sticky;top:0;z-index:40}
.menu-toggle{background:transparent;border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:5px 11px;font-size:16px;line-height:1;cursor:pointer}
.menu-toggle:hover{border-color:var(--accent);filter:none}

/* ---- layout / cards ---- */
main{max-width:1100px;width:100%;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:16px}

@media(max-width:820px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;height:100vh;transform:translateX(-100%);
    transition:transform .2s ease}
  .sidebar.open{transform:none}
  .sidebar-backdrop.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55}
  .topbar{display:flex}
}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px}
.card h2{margin:0 0 14px;font-size:15px}
.card.empty{text-align:center;padding:40px}
.card.danger{border-color:rgba(239,68,68,.35)}
.cardhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.cardhead h2{margin:0}
.hint{margin-top:12px}

/* ---- paginakop ---- */
.pagehdr{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  flex-wrap:wrap;margin:2px 0 4px}
.pagehdr h1{font-size:22px;font-weight:600;margin:0;line-height:1.2}
.pagehdr .sub{color:var(--muted);font-size:13px;margin-top:4px;max-width:60ch}
.pagehdr-actions{display:flex;gap:8px;align-items:center}

/* ---- platte kopbalk (titel + inline stats + actie op één regel) ---- */
.pagebar{display:flex;align-items:center;gap:8px 14px;flex-wrap:wrap;
  margin:2px 0 16px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.pagebar h1{font-size:19px;font-weight:600;margin:0;line-height:1.1}
.pagebar .istats{font-size:12.5px;color:var(--muted)}
.pagebar .istats b{font-weight:600;color:var(--text)}
.pagebar .istats .g{color:var(--green);font-weight:600}
.pagebar .istats .a{color:var(--accent);font-weight:600}
.pagebar .spacer{margin-left:auto}

/* ---- platte sectie (geen kaart, alleen kop + scheidslijn) ---- */
.section{margin:0 0 24px}
.section:last-child{margin-bottom:0}
.section-h{font-size:14px;font-weight:600;margin:0 0 3px}
.section-d{font-size:12px;color:var(--muted);margin:0 0 13px}
.section > .tbl{margin-top:2px}
.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:14px}
.lang-inline button{font-size:14px;padding:8px 18px}

/* platte tabel net iets compacter */
.tbl.flat th{padding:7px 10px}
.tbl.flat td{padding:9px 10px}
.tbl.flat td:first-child,.tbl.flat th:first-child{padding-left:2px}
.tbl.flat td:last-child,.tbl.flat th:last-child{padding-right:2px}

/* platte tab-container (zonder kaartrand) voor de settingspagina */
.tabwrap .tabbar{margin:0 0 16px;padding:0}

/* ---- metric-tegels ---- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.stat{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:13px 15px}
.stat .v{font-size:23px;font-weight:600;font-variant-numeric:tabular-nums;line-height:1}
.stat .l{font-size:12px;color:var(--muted);margin-top:5px}
.stat .v.green{color:var(--green)} .stat .v.red{color:var(--red)} .stat .v.accent{color:var(--accent)}

/* ---- sectiekop in een kaart ---- */
.secthead{display:flex;align-items:center;gap:9px;margin:0 0 6px}
.secthead .ic{width:30px;height:30px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  border-radius:8px;background:rgba(59,130,246,.12);color:var(--accent);font-size:15px}
.secthead h2{margin:0}
.secthead .desc{font-size:12px;color:var(--muted);margin-top:1px}
.card > .secthead + .hint{margin-top:0;margin-bottom:12px}

/* ---- inklapbaar 'toevoegen'-blok ---- */
.addbox{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.addbox > summary{cursor:pointer;padding:14px 18px;font-weight:600;font-size:14px;color:var(--text);
  display:flex;align-items:center;gap:8px;list-style:none}
.addbox > summary::-webkit-details-marker{display:none}
.addbox > summary .plus{color:var(--accent);font-size:17px;line-height:1}
.addbox[open] > summary{border-bottom:1px solid var(--line)}
.addbox .addbody{padding:18px}

/* ---- naam met statusbolletje in tabel ---- */
.rname{display:inline-flex;align-items:center;gap:8px;font-weight:500}
.rname .dot{width:8px;height:8px;border-radius:50%;background:#9ca3af;flex-shrink:0}
.rname .dot.online{background:var(--green);box-shadow:0 0 6px var(--green)}
.rname .dot.offline{background:var(--red)}
.role-badge{font-size:11px;font-weight:600;padding:2px 9px;border-radius:99px}
.role-badge.admin{background:rgba(59,130,246,.16);color:#93c5fd}
.role-badge.user{background:rgba(139,151,167,.16);color:var(--muted)}
.mini-chip{display:inline-block;font-size:11px;background:var(--card2);border:1px solid var(--line);
  color:var(--text);border-radius:99px;padding:2px 9px;margin:2px 2px 0 0}

/* ---- forms ---- */
form.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;align-items:end}
form.grid .wide{grid-column:1/-1}
label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
label.check{flex-direction:row;align-items:center;gap:8px;color:var(--text);font-size:14px}
.lbl{font-size:13px;color:var(--muted);display:block;margin-bottom:6px}
input,select{background:#0b0f14;border:1px solid var(--line);color:var(--text);
  padding:9px 10px;border-radius:8px;font-size:14px;font-family:inherit}
input:focus,select:focus{outline:none;border-color:var(--accent)}
input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}
button{background:var(--accent);color:#fff;border:none;padding:10px 16px;border-radius:8px;
  font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
button:hover{filter:brightness(1.1)}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--text);
  padding:7px 12px;font-weight:500}
.btn-ghost:hover{border-color:var(--accent);filter:none}
.btn-sm{background:var(--card2);border:1px solid var(--line);color:var(--text);
  padding:5px 11px;font-size:13px;font-weight:500;border-radius:7px;display:inline-block}
.btn-sm:hover{border-color:var(--accent);text-decoration:none;filter:none}
.btn-danger{background:transparent;border:1px solid rgba(239,68,68,.5);color:#f87171}
.btn-danger:hover{background:rgba(239,68,68,.12);filter:none}
form.inline{display:inline-block}
.nowrap{white-space:nowrap}
.right{text-align:right}

/* ---- tables ---- */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;padding:8px 12px;color:var(--muted);font-weight:500;font-size:11px;
  text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--line)}
.tbl td{padding:10px 12px;border-bottom:1px solid var(--line2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.roomchecks{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.chip-check{flex-direction:row;align-items:center;gap:5px;background:var(--card2);
  border:1px solid var(--line);border-radius:99px;padding:4px 10px;font-size:13px;color:var(--text)}
.roomsform .btn-sm{margin-top:2px}

.badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px}
.badge.on{background:rgba(34,197,94,.15);color:var(--green)}
.badge.off{background:rgba(139,151,167,.15);color:var(--muted)}

/* ---- flash / messages ---- */
.flashwrap{max-width:1100px;width:100%;margin:14px auto 0;padding:0 20px;display:flex;flex-direction:column;gap:8px}
.flash{padding:10px 14px;border-radius:8px;font-size:14px;border:1px solid}
.flash.ok{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.4);color:#86efac}
.flash.error{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.4);color:#fca5a5}
.formmsg{font-size:14px;margin-bottom:10px}
.formmsg.ok{color:#86efac}.formmsg.error{color:#fca5a5}

/* ---- login ---- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:30px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px}
.login-card h1{margin:0;font-size:20px;display:flex;align-items:center;gap:8px}
.login-card p{margin:0}
.login-card button{margin-top:6px}

/* ---- modal ---- */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;
  align-items:center;justify-content:center;z-index:60;padding:20px}
.modal-backdrop[hidden]{display:none}
.modal{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:24px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}
.modal h2{margin:0}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}

/* ============ TIJDLIJN (dashboard) ============ */
#esc-dag{font-size:12px}
#esc-dag .nav{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
#esc-dag .nav button{background:var(--card2);border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:4px 12px;font-size:13px;cursor:pointer;font-weight:500}
#esc-dag .nav button:hover{border-color:var(--accent);filter:none}
#esc-dag .nav button:disabled{opacity:.3;cursor:default}
#esc-dag .nav .datum{font-weight:600;font-size:14px;min-width:210px;text-align:center}
#esc-dag .nav input[type=date]{padding:4px 8px;font-size:12px}
#esc-dag .upd{margin-left:4px}
#esc-dag .testchip{font-size:10px;background:rgba(245,158,11,.18);color:var(--amber);
  border-radius:99px;padding:2px 9px;font-weight:700}
#esc-dag .zoomgrp{display:flex;align-items:center;gap:4px;margin-left:auto}
#esc-dag .zoompct{font-size:11px;color:var(--muted);min-width:40px;text-align:center}

#esc-dag .layout{display:flex}
#esc-dag .kkolom{width:140px;flex-shrink:0}
#esc-dag .asspacer{height:31px}
#esc-dag .kaart{height:90px;background:var(--card2);border:1px solid var(--line);border-right:none;
  border-radius:10px 0 0 10px;padding:8px 10px;margin-bottom:9px}
#esc-dag .kconn{display:flex;align-items:center;gap:5px;margin-top:4px;font-size:9px;color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#esc-dag .kconn .cdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:#9ca3af}
#esc-dag .kconn.ok .cdot{background:var(--green);box-shadow:0 0 5px var(--green)}
#esc-dag .kconn.down{color:#f87171}
#esc-dag .kconn.down .cdot{background:var(--red)}
#esc-dag .krij{display:flex;align-items:center;gap:6px}
#esc-dag .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;background:#9ca3af}
#esc-dag .dot.online{background:var(--green);box-shadow:0 0 7px var(--green)}
#esc-dag .dot.offline{background:var(--red)}
#esc-dag .knaam{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#esc-dag .krij2{display:flex;align-items:center;justify-content:space-between;margin-top:3px}
#esc-dag .kstatus{font-size:14px;font-weight:700}
#esc-dag .kstatus.online{color:var(--green)}#esc-dag .kstatus.offline{color:var(--red)}
#esc-dag .kstatus.onbekend{color:var(--muted)}
#esc-dag .ktijd{font-size:9px;color:var(--muted)}
#esc-dag .krij3{display:flex;align-items:center;gap:6px;margin-top:5px}
#esc-dag .maillbl{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
#esc-dag .switch{position:relative;width:28px;height:15px;cursor:pointer;flex-shrink:0;display:inline-block}
#esc-dag .switch input{opacity:0;width:0;height:0;position:absolute}
#esc-dag .track{position:absolute;inset:0;border-radius:99px;background:rgba(139,151,167,.4);transition:background .2s}
#esc-dag .track:before{content:'';position:absolute;width:11px;height:11px;border-radius:50%;
  background:#fff;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 2px rgba(0,0,0,.3)}
#esc-dag .switch input:checked + .track{background:var(--green)}
#esc-dag .switch input:checked + .track:before{transform:translateX(13px)}

#esc-dag .scrollwrap{flex:1;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain}
#esc-dag .binnen{min-width:100%}
#esc-dag .uren{display:flex;height:22px;margin-bottom:9px;border-bottom:1px solid var(--line)}
#esc-dag .uur{flex:1;font-size:10px;color:var(--muted);border-left:1px solid var(--line2);padding-left:3px;min-width:0;
  font-family:ui-monospace,Menlo,monospace}
#esc-dag .sporenwrap{position:relative}
#esc-dag .spoorrij{height:90px;background:var(--card2);border:1px solid var(--line);border-left:none;
  border-radius:0 10px 10px 0;margin-bottom:9px;padding:6px 10px 6px 0}
#esc-dag .spoor{position:relative;height:100%}
#esc-dag .blok{position:absolute;top:16px;height:23px;border-radius:99px;padding:3px 9px;font-size:10px;
  line-height:1.3;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;border:1px solid;box-sizing:border-box}
#esc-dag .blok.k0{background:rgba(139,92,246,.2);border-color:var(--purple);color:#c4b5fd}
#esc-dag .blok.k1{background:rgba(59,130,246,.2);border-color:var(--accent);color:#93c5fd}
#esc-dag .blok.k2{background:rgba(20,184,166,.2);border-color:var(--teal);color:#5eead4}
#esc-dag .blok.k3{background:rgba(236,72,153,.2);border-color:#ec4899;color:#f9a8d4}
#esc-dag .blok.k4{background:rgba(245,158,11,.2);border-color:var(--amber);color:#fcd34d}
#esc-dag .blok.klikbaar{cursor:pointer}
#esc-dag .blok.klikbaar:hover{filter:brightness(1.15);box-shadow:0 0 0 2px rgba(59,130,246,.4)}
#esc-dag .blok.voorbij{opacity:.5}
#esc-dag .blok.bezig{box-shadow:0 0 0 2px rgba(34,197,94,.6)}
#esc-dag .statusstrip{position:absolute;left:0;right:0;bottom:3px;height:8px;border-radius:99px;
  background:rgba(139,151,167,.12);overflow:hidden}
#esc-dag .statusseg{position:absolute;top:0;bottom:0}
#esc-dag .statusseg.online{background:var(--green)}
#esc-dag .statusseg.offline{background:var(--red)}
#esc-dag .statusseg.onbekend{background:rgba(139,151,167,.45)}
#esc-dag .maillijn{position:absolute;top:12px;bottom:1px;width:2px;border-radius:2px;background:var(--amber);z-index:4}
#esc-dag .maillijn.herstel{background:var(--green)}
#esc-dag .mailicoon{position:absolute;top:-1px;transform:translateX(-50%);font-size:13px;line-height:1;
  color:var(--amber);z-index:5}
#esc-dag .mailicoon.herstel{color:var(--green)}
#esc-dag .ktimer{position:absolute;top:6px;right:8px;font-family:ui-monospace,Menlo,monospace;
  font-size:17px;font-weight:700;color:var(--accent);background:rgba(59,130,246,.12);
  border:1px solid rgba(59,130,246,.4);border-radius:7px;padding:2px 10px;z-index:7;
  font-variant-numeric:tabular-nums;letter-spacing:.02em}
#esc-dag .ktimer.ending{color:var(--amber);background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.5)}
#esc-dag .ktimer.done{color:var(--red);background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.5)}
#esc-dag .nuoverlay{position:absolute;inset:0;pointer-events:none;z-index:6}
#esc-dag .nulijn{position:absolute;top:0;bottom:9px;width:2px;border-radius:2px;background:var(--red)}
#esc-dag .nulbl{position:absolute;top:2px;transform:translateX(-50%);font-size:9px;font-weight:700;color:#fff;
  background:var(--red);border-radius:99px;padding:1px 7px;white-space:nowrap}

#esc-dag .legenda{display:flex;gap:14px;margin-top:8px;font-size:10px;color:var(--muted);flex-wrap:wrap}
#esc-dag .legenda span{display:inline-flex;align-items:center;gap:4px}
#esc-dag .lb{display:inline-block;width:10px;height:10px;border-radius:3px}
#esc-dag .lb.online{background:var(--green)}#esc-dag .lb.offline{background:var(--red)}
#esc-dag .lb.onbekend{background:rgba(139,151,167,.45)}
#esc-dag .lb.mail{background:var(--amber)}#esc-dag .lb.herstel{background:var(--green)}
#esc-dag .geen{text-align:center;padding:14px;color:var(--muted);font-style:italic;font-size:12px}

/* ---- alertlog ---- */
.logbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.logbar h2{margin:0}
#esc-log table{width:100%;border-collapse:collapse;font-size:13px}
#esc-log th{text-align:left;padding:8px 12px;color:var(--muted);font-weight:500;font-size:11px;
  text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--line)}
#esc-log td{padding:9px 12px;border-bottom:1px solid var(--line2);vertical-align:top}
#esc-log tr:last-child td{border-bottom:none}
#esc-log .tijd{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--muted);white-space:nowrap}
#esc-log .lbadge{display:inline-block;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:600}
#esc-log .badge-alert{background:rgba(239,68,68,.16);color:#f87171}
#esc-log .badge-test{background:rgba(245,158,11,.16);color:var(--amber)}
#esc-log .badge-herstel{background:rgba(34,197,94,.16);color:#86efac}
#esc-log .lkamer{font-size:12px;color:var(--muted)}
#esc-log .lgeen{text-align:center;padding:30px;color:var(--muted);font-style:italic}

#esc-log .badge-mqtt{background:rgba(20,184,166,.16);color:#5eead4}
#esc-log .badge-vpn{background:rgba(139,92,246,.16);color:#c4b5fd}

/* klikbare kamerkaart in de rail */
#esc-dag a.kaart{display:block;color:inherit;text-decoration:none;cursor:pointer}
#esc-dag a.kaart:hover{border-color:var(--accent)}
#esc-dag .hint-open{font-size:9px;color:var(--muted);margin-top:5px;letter-spacing:.03em}
#esc-dag a.kaart:hover .hint-open{color:var(--accent)}
#esc-dag .mqtt-dot{color:var(--teal);font-size:9px;margin-left:auto}

/* uitleg-sectie */
.help{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:4px 18px}
.help summary{cursor:pointer;padding:12px 0;font-weight:600;font-size:14px;color:var(--text)}
.help summary::marker{color:var(--muted)}
.help-body{padding:0 0 14px}
.help-body ul{margin:6px 0;padding-left:20px}
.help-body li{font-size:13px;color:var(--muted);margin:5px 0}
.help-body b{color:var(--text);font-weight:600}
.ink-green{color:var(--green)} .ink-red{color:var(--red)}

/* kamer-instellingen */
.pagehead{margin:0 0 12px}
.pagehead .ph-title{display:flex;align-items:center;gap:10px}
.pagehead h2{font-size:18px;margin:0}
.pagehead .dot{width:10px;height:10px;border-radius:50%;background:#9ca3af;display:inline-block;flex-shrink:0}
.pagehead .dot.online{background:var(--green);box-shadow:0 0 7px var(--green)}
.pagehead .dot.offline{background:var(--red)}
.ph-status{font-size:12px;font-weight:600}
.ph-status.online{color:var(--green)} .ph-status.offline{color:var(--red)} .ph-status.onbekend{color:var(--muted)}
.adminonly{font-size:10px;font-weight:600;background:rgba(59,130,246,.16);color:#93c5fd;
  border-radius:99px;padding:2px 9px;margin-left:6px;vertical-align:middle}
.resblock{margin:6px 0 12px;padding:12px;background:var(--card2);border:1px solid var(--line);border-radius:10px}
.resbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.card .check{margin-top:4px}

/* tabbladen op de settingspagina */
.tabcard{padding-top:0}
.tabbar{display:flex;gap:2px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin:0 -18px 16px;padding:0 12px}
.tabbar button{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);
  padding:12px 14px;font-size:14px;font-weight:500;cursor:pointer;border-radius:0}
.tabbar button:hover{color:var(--text);filter:none;background:transparent}
.tabbar button.active{color:var(--text);border-bottom-color:var(--accent)}
.tabbar button.danger-tab{margin-left:auto;color:#9a6b6b}
.tabbar button.danger-tab.active{color:#f87171;border-bottom-color:var(--red)}
.tabpanel{animation:fadein .15s ease}
.tabpanel .grid{margin-top:4px}
.tabpanel > label.wide{display:block;margin-bottom:12px}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.savebar{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}

@media(max-width:640px){
  #esc-dag .kkolom{width:104px}
  #esc-dag .knaam{font-size:10px}
  main{padding:14px}
}
