:root,
html[data-theme="dark"] {
    --bg: #0f172a;
    --panel: #111827;
    --panel-light: #1f2937;
    --field-bg: #020617;
    --topbar-bg: #020617;
    --sidebar-bg: #020617;
    --text: #e5e7eb;
    --muted: #9ca3af;
    --pre-text: #d1d5db;
    --accent: #38bdf8;
    --accent-strong: #7dd3fc;
    --danger: #f87171;
    --ok: #34d399;
    --warn: #f59e0b;
    --border: #263244;
    --border-soft: #1e293b;
    --field-border: #334155;
    --layout-border: #1e293b;
    --subtle-bg: rgba(255,255,255,.03);
    --button-text: #001018;
    --card-shadow: rgba(0,0,0,.25);
}

html[data-theme="light"] {
    --bg: #f4f8fb;
    --panel: #ffffff;
    --panel-light: #e7eef5;
    --field-bg: #f8fbfd;
    --topbar-bg: #ffffff;
    --sidebar-bg: #eef5f8;
    --text: #102033;
    --muted: #5d6a75;
    --pre-text: #25364a;
    --accent: #0369a1;
    --accent-strong: #075985;
    --danger: #b42318;
    --ok: #007f66;
    --warn: #a15c00;
    --border: #d3dee8;
    --border-soft: #dbe5ec;
    --field-border: #b9c5cf;
    --layout-border: #d3dee8;
    --subtle-bg: rgba(15,23,42,.035);
    --button-text: #ffffff;
    --card-shadow: rgba(15,23,42,.08);
}

* { box-sizing: border-box; }
body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    background: var(--bg);
    color: var(--text);
}
a { color: var(--accent); }
.topbar {
    height: 58px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    background: var(--field-bg);
    border-bottom: 1px solid var(--layout-border);
}
.version { color: var(--muted); font-size: 13px; margin-left: 8px; }
.layout { display: grid; grid-template-columns: 240px 1fr; min-height: calc(100vh - 58px); }
.sidebar { background: var(--field-bg); border-right: 1px solid var(--layout-border); padding: 16px; }
.sidebar button { width: 100%; margin-bottom: 8px; text-align: left; }
.content { padding: 24px; max-width: none; }
.card, .login-card, .setup-card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 20px;
    margin: 16px 0;
    box-shadow: 0 12px 30px var(--card-shadow);
}
.login-page { display: grid; place-items: center; min-height: 100vh; }
.login-card, .setup-card { width: min(760px, calc(100vw - 32px)); }
label { display: block; margin: 12px 0; color: var(--muted); }
input {
    width: 100%; padding: 12px; margin-top: 6px;
    border-radius: 10px; border: 1px solid var(--field-border);
    background: var(--field-bg); color: var(--text);
}
button {
    border: 0; border-radius: 10px; padding: 11px 15px;
    background: var(--accent); color: #001018; cursor: pointer; font-weight: 700;
}
button.secondary { background: var(--panel-light); color: var(--text); }
.button-row { display: flex; gap: 10px; margin-top: 14px; }
.message { min-height: 22px; color: var(--muted); }
.message.error { color: var(--danger); }
.message.ok { color: var(--ok); }
pre { background: var(--field-bg); color: var(--pre-text); padding: 14px; border-radius: 10px; overflow: auto; }
.grid-form h2 { margin-top: 24px; }
@media (max-width: 800px) {
    .layout { grid-template-columns: 1fr; }
    .sidebar { display: flex; overflow-x: auto; gap: 8px; }
    .sidebar button { width: auto; white-space: nowrap; }
}
.status-line {
    border-left: 3px solid var(--field-border);
    padding: 8px 10px;
    background: var(--field-bg);
    border-radius: 8px;
    overflow-wrap: anywhere;
}
.status-line.error { border-left-color: var(--danger); }
.status-line.ok { border-left-color: var(--ok); }
.hidden { display: none !important; }
.button-link {
    display: inline-block;
    border-radius: 10px;
    padding: 11px 15px;
    background: var(--accent);
    color: #001018;
    font-weight: 700;
    text-decoration: none;
}
.topbar-actions { display: flex; align-items: center; gap: 14px; }
.muted { color: var(--muted); }
.sidebar button.active { outline: 2px solid var(--accent); background: #0f2433; }
select, textarea {
    width: 100%; padding: 12px; margin-top: 6px;
    border-radius: 10px; border: 1px solid var(--field-border);
    background: var(--field-bg); color: var(--text);
}
input:disabled { opacity: .65; cursor: not-allowed; }
button.small { padding: 7px 10px; font-size: 12px; }
button:disabled { opacity: .55; cursor: not-allowed; }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; min-width: 720px; }
th, td { border-bottom: 1px solid var(--border); padding: 10px; text-align: left; vertical-align: top; }
th { color: var(--muted); font-size: 13px; font-weight: 700; }
tr:hover td { background: rgba(255,255,255,.025); }
.two-column { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.grid-form { display: grid; gap: 10px; }
.compact-form { margin-top: 24px; padding-top: 18px; border-top: 1px solid var(--border); }
.check { display: flex; align-items: flex-start; gap: 10px; color: var(--text); }
.check input { width: auto; margin-top: 2px; }
.permission-grid { display: grid; grid-template-columns: repeat(2, minmax(240px, 1fr)); gap: 10px; margin: 12px 0 16px; }
.permission-item { background: var(--field-bg); border: 1px solid var(--border); border-radius: 10px; padding: 10px; }
.pill { display: inline-block; padding: 3px 8px; border-radius: 999px; background: #0f2433; color: var(--accent); font-size: 12px; margin-top: 4px; }
.ok-text { color: var(--ok); font-weight: 700; }
.danger-text { color: var(--danger); font-weight: 700; }
code { color: var(--pre-text); word-break: break-word; }
@media (max-width: 1000px) {
    .two-column { grid-template-columns: 1fr; }
    .permission-grid { grid-template-columns: 1fr; }
    .topbar { height: auto; align-items: flex-start; gap: 10px; padding: 12px 16px; flex-direction: column; }
    .topbar-actions { width: 100%; justify-content: space-between; }
}

.status-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 12px;
}

.status-grid div {
    border: 1px solid #273449;
    border-radius: 12px;
    padding: 12px;
    background: rgba(255,255,255,0.03);
}

.status-grid strong {
    display: block;
    margin-bottom: 6px;
}

.button-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 12px;
}

.danger-zone {
    margin-top: 18px;
    border: 1px solid #7f1d1d;
    border-radius: 12px;
    padding: 12px;
    background: rgba(127, 29, 29, 0.12);
}

button.danger {
    background: #7f1d1d;
    border-color: #991b1b;
    color: #fff;
}

code {
    background: rgba(255,255,255,0.08);
    border-radius: 5px;
    padding: 2px 5px;
}

.realtime-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border: 1px solid var(--field-border);
    border-radius: 999px;
    background: rgba(255,255,255,0.04);
    font-size: 12px;
    white-space: nowrap;
}
.realtime-status-pill.ok {
    border-color: rgba(34,197,94,0.55);
    color: var(--ok);
}
.realtime-status-pill.warn {
    border-color: rgba(245,158,11,0.65);
    color: #f59e0b;
}
.realtime-status-pill.error {
    border-color: rgba(239,68,68,0.65);
    color: var(--danger);
}
.realtime-control-note {
    margin-top: 8px;
    color: var(--muted);
    font-size: 13px;
}

.diagnostics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
    margin: 16px 0;
}
.diagnostic-panel {
    border: 1px solid #273449;
    border-radius: 12px;
    padding: 14px;
    background: rgba(255,255,255,0.03);
}
.diagnostic-panel h3 {
    margin-top: 0;
}
.diagnostic-list {
    margin: 0;
}
.diagnostic-list div {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 8px;
    padding: 6px 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.diagnostic-list dt {
    color: var(--muted);
}
.diagnostic-list dd {
    margin: 0;
    overflow-wrap: anywhere;
}
.warn-text {
    color: #f59e0b;
    font-weight: 700;
}

/* v80.4 live map / device UI */
.live-monitor-card { max-width: none; }
.live-monitor-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.live-monitor-actions { justify-content: flex-end; }
.live-status-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
    margin: 14px 0;
}
.live-status-strip div {
    background: var(--field-bg);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 10px;
}
.live-status-strip strong { display: block; color: var(--muted); font-size: 12px; margin-bottom: 4px; }
.live-map-layout {
    display: grid;
    grid-template-columns: minmax(420px, .78fr) minmax(520px, 1.22fr);
    gap: 14px;
    min-height: 560px;
}
.live-device-list {
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 14px;
    background: var(--panel);
    overflow: auto;
    max-height: 560px;
}
.live-device-list h3 { margin-top: 0; }
.live-tracker-list {
    display: grid;
    gap: 12px;
    padding-right: 4px;
}
.live-tracker-card {
    width: 100%;
}
.live-map-panel {
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 12px;
    background: var(--field-bg);
    min-width: 0;
}
.live-map {
    width: 100%;
    height: 510px;
    border-radius: 12px;
    overflow: hidden;
    background: var(--panel);
}
.active-device-panel {
    margin-top: 14px;
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 14px;
    background: var(--subtle-bg);
}
.active-device-panel h3 { margin-top: 0; }
.active-device-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 10px;
}
.active-device-grid div {
    background: var(--field-bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px;
}
.active-device-grid strong { display: block; color: var(--muted); font-size: 12px; margin-bottom: 4px; }
.selected-row td { background: rgba(56, 189, 248, .08); }
.warn-text { color: #f59e0b; font-weight: 700; }
.leaflet-container { color: var(--panel); }
.leaflet-popup-content { color: var(--panel); }
@media (max-width: 1180px) {
    .live-map-layout { grid-template-columns: 1fr; }
    .live-device-list { max-height: 420px; }
    .live-map { height: 430px; }
}

/* v80.5 device config / A1-A10 */
.config-toolbar{display:grid;grid-template-columns:minmax(260px,1fr) auto auto auto;gap:10px;align-items:end;margin-top:12px}
.config-toolbar label{margin:0}
.config-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;margin-top:16px}
.status-grid.mini{grid-template-columns:repeat(2,minmax(120px,1fr));margin:10px 0}
#rawConfigImport{width:100%;box-sizing:border-box;background:var(--bg);color:var(--text);border:1px solid var(--field-border);border-radius:10px;padding:10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}
#configRawOutput{max-height:320px;overflow:auto}
@media(max-width:1000px){.config-toolbar{grid-template-columns:1fr}.config-layout{grid-template-columns:1fr}}

/* v80.6 Debug & Diagnose */
.debug-filter-form {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    align-items: end;
    margin-top: 16px;
}
.debug-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
    margin-top: 16px;
}
.debug-summary-grid div {
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 10px;
    background: var(--field-bg);
}
.debug-summary-grid strong { display: block; color: var(--muted); margin-bottom: 4px; }
.debug-terminal-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
    gap: 16px;
    align-items: start;
}
.debug-terminal-card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 16px;
    box-shadow: 0 12px 30px rgba(0,0,0,.22);
}
.debug-terminal {
    height: 360px;
    overflow: auto;
    background: var(--field-bg);
    border: 1px solid var(--layout-border);
    border-radius: 12px;
    padding: 10px;
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 12px;
    line-height: 1.45;
}
.terminal-line {
    border-left: 3px solid var(--field-border);
    padding: 7px 8px;
    margin-bottom: 7px;
    background: rgba(255,255,255,.025);
    border-radius: 8px;
}
.terminal-line details { margin-top: 5px; }
.terminal-line pre { margin: 6px 0 0; max-height: 220px; }
.terminal-debug { border-left-color: #64748b; }
.terminal-info { border-left-color: var(--accent); }
.terminal-warn { border-left-color: #f59e0b; }
.terminal-error, .terminal-critical { border-left-color: var(--danger); }
.terminal-time { color: var(--muted); }
.terminal-level { color: var(--accent); font-weight: 700; text-transform: uppercase; }
.terminal-warn .terminal-level { color: #f59e0b; }
.terminal-error .terminal-level, .terminal-critical .terminal-level { color: var(--danger); }
.terminal-channel { color: #c4b5fd; }
.terminal-direction { color: #86efac; }
.terminal-type { color: #fcd34d; }
.terminal-device { color: var(--muted); }
.terminal-message { color: var(--text); }
.terminal-empty { color: var(--muted); padding: 12px; }
@media (max-width: 900px) {
    .debug-terminal-grid { grid-template-columns: 1fr; }
    .debug-terminal { height: 300px; }
}

/* v80.6.1 Debug Command Center - visuele workbench */
.debug-hero {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    background: radial-gradient(circle at top left, rgba(56,189,248,.16), transparent 38%), var(--panel);
}
.debug-hero h2 { margin-top: 0; }
.debug-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; max-width: 720px; }
.debug-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 12px;
    margin: 14px 0 18px;
}
.debug-kpi {
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 14px;
    background: linear-gradient(180deg, var(--panel), var(--field-bg));
    box-shadow: 0 12px 26px var(--card-shadow);
}
.debug-kpi span { display:block; color: var(--muted); font-size: 13px; }
.debug-kpi strong { display:block; font-size: 28px; margin: 7px 0 3px; color: var(--text); }
.debug-kpi small { color: var(--muted); word-break: break-word; }
.debug-kpi.ok strong { color: #86efac; }
.debug-kpi.warn strong { color: #fbbf24; }
.debug-filter-card { margin-top: 8px; }
.debug-filter-notice { margin-top: 12px; }
.notice { border-radius: 12px; padding: 10px 12px; border: 1px solid var(--border); }
.notice.ok { background: rgba(34,197,94,.09); color: #bbf7d0; border-color: rgba(34,197,94,.28); }
.notice.warn { background: rgba(245,158,11,.10); color: #fde68a; border-color: rgba(245,158,11,.35); }
.debug-workbench-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(360px, .75fr);
    gap: 16px;
    align-items: start;
    margin-bottom: 16px;
}
.debug-workbench-card {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 16px;
    box-shadow: 0 12px 30px rgba(0,0,0,.22);
}
.debug-workbench-card.wide { min-width: 0; }
.debug-card-title { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom: 10px; }
.debug-card-title h2 { margin: 0; }
.debug-pill,
.debug-stream-chip {
    display:inline-flex; align-items:center; gap:6px;
    border-radius:999px; padding:5px 9px;
    background:var(--field-bg); border:1px solid var(--field-border); color:#bfdbfe;
    font-size:12px; font-weight:700;
}
.debug-timeline {
    height: 360px;
    overflow:auto;
    border:1px solid var(--layout-border);
    border-radius:14px;
    background:var(--field-bg);
    padding:10px;
}
.debug-timeline-item {
    display:grid;
    grid-template-columns: 150px 70px 130px minmax(150px,260px) 1fr;
    gap:8px;
    align-items:start;
    border-left:3px solid var(--field-border);
    background:rgba(255,255,255,.025);
    border-radius:10px;
    padding:8px 10px;
    margin-bottom:8px;
    font-size:12px;
}
.debug-timeline-item.warn { border-left-color:#f59e0b; }
.debug-timeline-item.error,
.debug-timeline-item.critical { border-left-color:var(--danger); }
.debug-time { color:var(--muted); }
.debug-badge { text-transform:uppercase; font-weight:800; color:#38bdf8; }
.debug-badge.warn { color:#fbbf24; }
.debug-badge.error,
.debug-badge.critical { color:#fb7185; }
.debug-channel-mini { color:#c4b5fd; }
.debug-timeline-item strong { color:#fcd34d; font-weight:700; }
.debug-timeline-item em { color:var(--text); font-style:normal; overflow-wrap:anywhere; }
.debug-analysis-box,
.debug-packet-stream {
    min-height: 220px;
    max-height: 360px;
    overflow:auto;
    border:1px solid var(--layout-border);
    border-radius:14px;
    background:var(--field-bg);
    padding:10px;
}
.debug-flow-row {
    display:flex; justify-content:space-between; gap:10px;
    padding:9px 10px; margin-bottom:7px;
    border-radius:10px; background:rgba(255,255,255,.035);
}
.debug-flow-row span { color:var(--muted); }
.debug-flow-row strong { color:var(--text); }
.debug-mini-list { margin-top:12px; color:#cbd5e1; font-size:12px; }
.debug-mini-list div { padding:6px 0; border-top:1px solid var(--layout-border); }
.debug-packet-item {
    border-left:4px solid #64748b;
    background:rgba(255,255,255,.035);
    border-radius:10px;
    padding:9px 10px;
    margin-bottom:9px;
    display:grid;
    grid-template-columns: 44px 150px 1fr;
    gap:8px;
    align-items:start;
}
.debug-packet-item.in { border-left-color:#22c55e; }
.debug-packet-item.out { border-left-color:#38bdf8; }
.debug-packet-item strong { color:var(--text); }
.debug-packet-item span { color:var(--muted); font-size:12px; }
.debug-packet-item em { color:#fcd34d; font-style:normal; font-size:12px; }
.debug-packet-item code { grid-column:1 / -1; white-space:pre-wrap; overflow-wrap:anywhere; color:#bfdbfe; }
.debug-pattern-grid {
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap:8px;
}
.debug-pattern {
    border:1px solid var(--layout-border);
    border-radius:12px;
    padding:10px;
    background:rgba(255,255,255,.025);
}
.debug-pattern.hit { border-color: rgba(56,189,248,.45); background:rgba(56,189,248,.09); }
.debug-pattern span { display:block; color:var(--muted); font-size:12px; }
.debug-pattern strong { display:block; color:var(--text); font-size:22px; margin-top:4px; }
.debug-terminal-grid.enhanced { grid-template-columns: repeat(2, minmax(360px, 1fr)); }
@media (max-width: 1100px) {
    .debug-hero { flex-direction: column; }
    .debug-hero-actions { justify-content:flex-start; }
    .debug-workbench-grid { grid-template-columns: 1fr; }
    .debug-terminal-grid.enhanced { grid-template-columns: 1fr; }
    .debug-timeline-item { grid-template-columns: 1fr; }
}

/* v80.7 Alarm log / notifications */
.alarm-hero {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    background: radial-gradient(circle at top left, rgba(248,113,113,.16), transparent 36%), var(--panel);
}
.alarm-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 12px;
    margin: 14px 0;
}
.alarm-kpi {
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 14px;
    background: linear-gradient(180deg, var(--panel), var(--field-bg));
}
.alarm-kpi span { display:block; color: var(--muted); font-size: 13px; }
.alarm-kpi strong { display:block; font-size: 24px; margin: 6px 0; color: var(--text); }
.alarm-kpi.ok strong { color: var(--ok); }
.alarm-kpi.warn strong { color: #fbbf24; }
.alarm-kpi small { color: var(--muted); }
.alarm-row {
    border: 1px solid var(--border);
    border-left: 4px solid #64748b;
    border-radius: 14px;
    padding: 14px;
    margin-bottom: 12px;
    background: var(--subtle-bg);
}
.alarm-row.new { border-left-color: #f59e0b; }
.alarm-row.critical { box-shadow: 0 0 0 1px rgba(248,113,113,.25); }
.alarm-row-main {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 8px;
}
.alarm-row-main strong { color: #fee2e2; font-size: 18px; }
.alarm-row-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 8px;
    color: var(--muted);
    font-size: 13px;
    margin: 10px 0;
}
.alarm-raw { max-height: 280px; margin-top: 10px; }
.alarm-toast-container {
    position: fixed;
    right: 18px;
    top: 76px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: min(420px, calc(100vw - 36px));
}
.alarm-toast {
    border: 1px solid rgba(245,158,11,.55);
    border-left: 5px solid #f59e0b;
    border-radius: 16px;
    padding: 14px;
    background: var(--panel);
    box-shadow: 0 18px 45px rgba(0,0,0,.45);
}
.alarm-toast.critical {
    border-color: rgba(248,113,113,.65);
    border-left-color: var(--danger);
}
.alarm-toast-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}
.alarm-toast-title strong { color: #fee2e2; }
.alarm-toast-body {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
    font-size: 13px;
}
.alarm-toast-body div {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 8px;
}
.alarm-toast-body span { color: var(--muted); }
.alarm-toast-body b { color: var(--text); overflow-wrap: anywhere; }
@media(max-width: 900px) {
    .alarm-hero { flex-direction: column; }
    .alarm-toast-container { top: 112px; right: 12px; width: calc(100vw - 24px); }
}


/* v80.7.1 Browser notification diagnostics */
.notification-diagnostics-card {
    border-color: rgba(56,189,248,.25);
}
.notification-diagnostics {
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 14px;
    background: var(--subtle-bg);
}
.notification-diagnostics.ok { border-color: rgba(34,197,94,.45); background: rgba(34,197,94,.07); }
.notification-diagnostics.warn { border-color: rgba(245,158,11,.45); background: rgba(245,158,11,.07); }
.notification-diagnostics.error { border-color: rgba(248,113,113,.45); background: rgba(248,113,113,.07); }
.notification-diagnostics-head {
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:12px;
}
.notification-diagnostics-grid {
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap:10px;
    margin:12px 0;
}
.notification-diagnostics-grid div {
    border:1px solid var(--layout-border);
    border-radius:12px;
    padding:10px;
    background:rgba(15,23,42,.55);
}
.notification-diagnostics-grid span { display:block; color:var(--muted); font-size:12px; }
.notification-diagnostics-grid b { display:block; color:var(--text); margin-top:4px; }
.notification-help {
    margin: 10px 0 12px 20px;
    color: var(--text);
}
.notification-help li { margin: 4px 0; }

/* v80.8 SMS fallback instellingen */
.sms-settings-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:12px;margin:14px 0}
.sms-settings-grid label span{display:block;font-size:.88rem;color:#5d6a75;margin-bottom:4px}
.sms-status-grid{margin:10px 0 14px}
.actions-cell{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.tiny{font-size:.82rem;padding:6px 9px;min-height:auto}
.button-link{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid #b9c5cf;background:#eef5f8;color:#124452;text-decoration:none;font-weight:600}
.button-link:hover{background:#ddeff5}
@media(max-width:1100px){.sms-settings-grid{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.sms-settings-grid{grid-template-columns:1fr}.actions-cell{display:grid;grid-template-columns:1fr}.button-link{width:100%}}

/* v80.9 Eview Settings UI foundation */
.eview-settings-hero { border-color: rgba(56,189,248,.28); }
.eview-settings-title-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: start;
}
.settings-rights-card {
    min-width: 220px;
    border: 1px solid #273449;
    border-radius: 14px;
    padding: 12px;
    background: var(--subtle-bg);
}
.settings-rights-card strong { display: block; margin-bottom: 8px; }
.ok-pill { border: 1px solid rgba(34,197,94,.35); color: var(--ok); background: rgba(34,197,94,.08); }
.muted-pill { opacity: .7; }
.eview-config-toolbar {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto auto auto;
    gap: 10px;
    align-items: end;
    margin: 14px 0;
}
.settings-tabbar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 16px 0 4px;
    padding: 8px;
    border: 1px solid var(--layout-border);
    border-radius: 16px;
    background: rgba(2,6,23,.55);
    position: sticky;
    top: 0;
    z-index: 15;
}
.settings-tab {
    background: var(--panel-light);
    color: var(--text);
    border: 1px solid var(--field-border);
    padding: 9px 12px;
}
.settings-tab.active {
    background: #0f2433;
    color: var(--accent);
    border-color: rgba(56,189,248,.55);
    box-shadow: 0 0 0 1px rgba(56,189,248,.15) inset;
}
.settings-panel { display: none; }
.settings-panel.active { display: block; }
.settings-field-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 12px;
    margin-top: 14px;
}
.settings-field-grid div,
.snapshot-step,
.settings-warning-card {
    border: 1px solid #273449;
    border-radius: 14px;
    padding: 13px;
    background: var(--subtle-bg);
}
.settings-field-grid strong,
.snapshot-step strong,
.settings-warning-card strong { display: block; margin-bottom: 6px; }
.settings-field-grid span,
.snapshot-step span,
.settings-warning-card span { color: var(--muted); font-size: 13px; line-height: 1.4; }
.settings-warning-card { border-color: rgba(245,158,11,.45); background: rgba(245,158,11,.06); }
.snapshot-flow {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 10px;
    margin: 12px 0;
}
.snapshot-step.active { border-color: rgba(34,197,94,.45); background: rgba(34,197,94,.06); }
.status-grid.mini { margin-top: 12px; }
.status-grid.mini div { min-height: 72px; }
@media(max-width: 1180px) {
    .eview-config-toolbar { grid-template-columns: 1fr 1fr; }
}
@media(max-width: 800px) {
    .eview-settings-title-row { grid-template-columns: 1fr; }
    .eview-config-toolbar { grid-template-columns: 1fr; }
    .settings-tabbar { position: static; }
}

.password-policy-status span {
    color: var(--text);
}

.forced-password-card {
    max-width: 760px;
    margin: 40px auto;
}

/* v80.11/v80.12 Eview command mapping */
.contact-command-builder {
    margin-top: 18px;
    padding-top: 14px;
    border-top: 1px solid #273449;
}
.contact-command-grid,
.sos-command-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 12px;
    margin: 12px 0;
}
.contact-command-grid label span,
.sos-command-grid label span {
    display: block;
    font-size: .88rem;
    color: var(--muted);
    margin-bottom: 4px;
}
.command-preview-output {
    margin-top: 12px;
    border: 1px solid #273449;
    border-radius: 14px;
    padding: 12px;
    background: var(--subtle-bg);
}
.command-preview-grid { margin: 10px 0; }
.command-preview-block {
    margin-top: 10px;
    padding: 12px;
    border: 1px solid var(--layout-border);
    border-radius: 12px;
    background: rgba(15,23,42,.55);
}
.command-preview-block strong {
    display: block;
    margin-bottom: 8px;
}
.command-preview-block code {
    display: block;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    margin: 8px 0;
}

/* v80.13 Emulator Lab + action feedback */
.action-toast {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 9999;
    display: none;
    align-items: center;
    gap: 10px;
    max-width: min(520px, calc(100vw - 32px));
    padding: 12px 14px;
    border: 1px solid var(--field-border);
    border-left: 4px solid var(--accent);
    border-radius: 12px;
    background: rgba(2, 6, 23, .96);
    box-shadow: 0 18px 45px rgba(0,0,0,.45);
    color: var(--text);
    font-weight: 700;
}
.action-toast.show { display: flex; }
.action-toast.ok { border-left-color: var(--ok); }
.action-toast.error { border-left-color: var(--danger); }
.action-toast-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 4px rgba(56, 189, 248, .12);
    flex: 0 0 auto;
}
.action-toast.ok .action-toast-dot { background: var(--ok); box-shadow: 0 0 0 4px rgba(52, 211, 153, .12); }
.action-toast.error .action-toast-dot { background: var(--danger); box-shadow: 0 0 0 4px rgba(248, 113, 113, .12); }
.button-row.wrap { flex-wrap: wrap; }
.emulator-command-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(95px, 1fr));
    gap: 8px;
    margin: 12px 0;
}
.emulator-terminal {
    min-height: 420px;
    max-height: 62vh;
    overflow: auto;
    font-family: Consolas, Monaco, 'Courier New', monospace;
    line-height: 1.45;
}
.ok-pill { color: var(--ok); border-color: rgba(52, 211, 153, .3); }
.danger-pill { color: var(--danger); border-color: rgba(248, 113, 113, .3); }
hr { border: 0; border-top: 1px solid var(--border); margin: 18px 0; }

/* v80.13.1 - klikbare debug KPI's en emulator processtatus */
.debug-kpi[data-debug-filter] {
    cursor: pointer;
    transition: border-color .15s ease, transform .15s ease, background .15s ease;
}
.debug-kpi[data-debug-filter]:hover,
.debug-kpi[data-debug-filter]:focus {
    transform: translateY(-1px);
    border-color: rgba(56, 189, 248, .75);
    outline: none;
}
button[disabled],
button[disabled]:hover {
    opacity: .45;
    cursor: not-allowed;
    transform: none;
}
.debug-kpi[role="button"] { cursor: pointer; transition: transform .12s ease, border-color .12s ease, background .12s ease; }
.debug-kpi[role="button"]:hover,
.debug-kpi[role="button"]:focus-visible { transform: translateY(-1px); border-color: rgba(56,189,248,.65); outline: none; }
.danger-zone .muted { margin-top: 10px; }

/* v80.13.3 - rollenbeheer en logbeheer UX herstructurering */
.role-permission-card {
    border-color: rgba(56, 189, 248, .18);
}
.role-permission-header {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) minmax(260px, 520px);
    gap: 18px;
    align-items: end;
}
.permission-tools {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.permission-group-stack {
    display: grid;
    gap: 16px;
    margin-top: 16px;
}
.permission-group {
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 14px;
    background: rgba(2, 6, 23, .38);
}
.permission-group-header {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border);
}
.permission-group-header h3 { margin: 0 0 4px; }
.permission-group-header p { margin: 0; color: var(--muted); }
.permission-group-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.permission-switch-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 10px;
    margin-top: 12px;
}
.permission-switch-card {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 12px;
    align-items: center;
    margin: 0;
    padding: 13px;
    min-height: 86px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: var(--field-bg);
    color: var(--text);
    cursor: pointer;
}
.permission-switch-card:has(.permission-switch-input:checked) {
    border-color: rgba(52, 211, 153, .45);
    background: rgba(16, 185, 129, .06);
}
.permission-switch-card:has(.permission-switch-input:focus-visible) {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
}
.permission-switch-card:has(.permission-switch-input:disabled) {
    cursor: default;
    opacity: .9;
}
.permission-switch-input {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    margin: 0;
}
.permission-switch-ui {
    width: 54px;
    height: 30px;
    border: 1px solid #475569;
    border-radius: 999px;
    padding: 3px;
    background: var(--panel);
    transition: background .16s ease, border-color .16s ease;
}
.permission-switch-ui span {
    display: block;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: var(--muted);
    transform: translateX(0);
    transition: transform .16s ease, background .16s ease;
}
.permission-switch-input:checked + .permission-switch-ui {
    background: rgba(52, 211, 153, .22);
    border-color: rgba(52, 211, 153, .85);
}
.permission-switch-input:checked + .permission-switch-ui span {
    background: var(--ok);
    transform: translateX(24px);
}
.permission-switch-copy strong,
.permission-switch-copy span,
.permission-switch-copy em { display: block; }
.permission-switch-copy strong { font-size: 14px; margin-bottom: 2px; }
.permission-switch-copy span { color: var(--text); }
.permission-switch-copy em {
    color: var(--muted);
    font-style: normal;
    font-size: 12px;
    line-height: 1.35;
    margin-top: 5px;
}
.permission-state {
    min-width: 44px;
    text-align: center;
    padding: 5px 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    border: 1px solid var(--field-border);
}
.permission-state-on { color: var(--ok); display: none; border-color: rgba(52, 211, 153, .45); }
.permission-state-off { color: var(--muted); display: inline-block; }
.permission-switch-input:checked ~ .permission-state-on { display: inline-block; }
.permission-switch-input:checked ~ .permission-state-off { display: none; }
.permission-save-row {
    border-top: 1px solid var(--border);
    padding-top: 14px;
    flex-wrap: wrap;
}
.log-management-card {
    border-color: rgba(245, 158, 11, .24);
    background: linear-gradient(180deg, rgba(245, 158, 11, .045), rgba(17, 24, 39, 1));
}
.log-management-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
    flex-wrap: wrap;
}
.cleanup-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 10px;
    margin: 14px 0;
}
.cleanup-summary-item {
    border: 1px solid var(--border);
    border-radius: 13px;
    padding: 11px;
    background: rgba(2, 6, 23, .52);
}
.cleanup-summary-item.warn { border-color: rgba(245, 158, 11, .5); }
.cleanup-summary-item span,
.cleanup-summary-item small { display: block; color: var(--muted); }
.cleanup-summary-item strong { display: block; font-size: 24px; margin: 3px 0; }
.cleanup-action-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
    margin: 12px 0;
}
.cleanup-action { text-align: center; }
.advanced-cleanup {
    margin-top: 12px;
    border-top: 1px solid var(--border);
    padding-top: 12px;
}
.advanced-cleanup summary { cursor: pointer; font-weight: 800; color: var(--accent); }
button.danger { background: rgba(248, 113, 113, .18); color: #fecaca; border: 1px solid rgba(248, 113, 113, .42); }
@media (max-width: 950px) {
    .role-permission-header,
    .permission-tools { grid-template-columns: 1fr; }
    .permission-group-header { flex-direction: column; }
    .permission-switch-card { grid-template-columns: auto 1fr; }
    .permission-state { justify-self: start; }
}

/* v80.14 Tracker Overzicht & Routehistorie */

/* v80.18 gecombineerde Tracker Overzicht werkpagina */
.overview-workspace {
    display: grid;
    gap: 16px;
}
.overview-window {
    display: grid;
    gap: 14px;
}
.overview-window-title {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.overview-window-title h2,
.overview-window-title h3 { margin-top: 0; }
.overview-window-title.compact { margin-bottom: 4px; }
.overview-live-window {
    border-top: 1px solid rgba(56, 189, 248, .20);
    padding-top: 4px;
}
.overview-route-window {
    border-top: 1px solid rgba(148, 163, 184, .22);
    padding-top: 8px;
}
.overview-route-window .route-history-card {
    border-color: rgba(56, 189, 248, .28);
}
.muted-card code {
    background: rgba(15, 23, 42, .88);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 2px 5px;
    color: var(--accent);
}
.overview-hero-card {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.overview-hero-card h2 { margin-top: 0; }
.overview-user-filter { min-width: min(420px, 100%); margin: 0; }
.overview-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 12px;
    margin: 16px 0;
}
.overview-kpi {
    text-align: left;
    background: var(--field-bg);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 16px;
}
.overview-kpi strong {
    display: block;
    font-size: 30px;
    color: var(--accent);
    line-height: 1;
    margin-bottom: 8px;
}
.overview-kpi span { color: var(--muted); }
.overview-layout {
    display: grid;
    grid-template-columns: minmax(340px, .86fr) minmax(520px, 1.14fr);
    gap: 16px;
    align-items: start;
}
.overview-map { height: 560px; border-radius: 12px; background: var(--field-bg); overflow: hidden; }
.overview-tracker-list {
    display: grid;
    gap: 12px;
    max-height: 640px;
    overflow: auto;
    padding-right: 4px;
}
.overview-tracker-card {
    border: 1px solid var(--border);
    border-radius: 14px;
    background: var(--field-bg);
    padding: 14px;
    cursor: pointer;
    transition: border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
}
.overview-tracker-card:hover,
.overview-tracker-card:focus-visible {
    border-color: rgba(56, 189, 248, .62);
    background: var(--panel);
    outline: none;
    transform: translateY(-1px);
}
.overview-tracker-card.selected {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px rgba(56, 189, 248, .38), 0 12px 28px rgba(2, 6, 23, .34);
    background: var(--active-bg, rgba(56,189,248,.12));
}
.overview-tracker-card h3 { margin: 0 0 4px; }
.overview-tracker-card p { margin: 8px 0 0; }
.overview-tracker-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px 10px;
    margin: 12px 0;
    color: var(--muted);
    font-size: 13px;
}
.overview-tracker-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.overview-alarm-list { display: grid; gap: 8px; }
.overview-alarm-row {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(160px, .8fr) minmax(160px, .8fr) 90px;
    gap: 10px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--field-bg);
    padding: 10px;
}
.route-history-form {
    display: grid;
    grid-template-columns: minmax(260px, 1.2fr) minmax(180px, .8fr) minmax(180px, .8fr) minmax(180px, .8fr) auto;
    gap: 12px;
    align-items: end;
}
.route-history-form label { margin: 0; }
.route-history-layout {
    display: grid;
    grid-template-columns: minmax(420px, 1.25fr) minmax(320px, .75fr);
    gap: 16px;
    align-items: start;
}
.route-history-map { height: 560px; border-radius: 12px; background: var(--field-bg); overflow: hidden; }
.route-point-list { display: grid; gap: 8px; max-height: 560px; overflow: auto; padding-right: 4px; }
.route-point-row {
    display: grid;
    grid-template-columns: minmax(150px, 1fr) minmax(170px, 1fr) minmax(90px, .6fr) minmax(90px, .6fr);
    gap: 10px;
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px;
    background: var(--field-bg);
    font-size: 13px;
}
@media (max-width: 1150px) {
    .overview-layout,
    .route-history-layout { grid-template-columns: 1fr; }
    .route-history-form { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
    .route-history-form,
    .overview-alarm-row,
    .route-point-row,
    .overview-tracker-metrics { grid-template-columns: 1fr; }
    .overview-map,
    .route-history-map { height: 420px; }
}

/* v80.15 Route playback */
.route-playback-card {
    border-color: rgba(56, 189, 248, .32);
}
.route-playback-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.route-playback-header h2 { margin-top: 0; }
.route-playback-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.route-playback-grid {
    display: grid;
    grid-template-columns: minmax(260px, 1.2fr) minmax(220px, .8fr) minmax(220px, .8fr);
    gap: 12px;
    align-items: center;
    margin-top: 12px;
}
.route-playback-grid label { margin: 0; }
.route-playback-grid input[type="range"] { margin-top: 10px; }
.route-follow-check {
    align-self: end;
    background: var(--field-bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 11px 12px;
}
.route-playback-status {
    margin-top: 12px;
    border-left: 3px solid var(--accent);
    background: var(--field-bg);
    border-radius: 8px;
    padding: 10px 12px;
    color: var(--muted);
}
.route-playback-status strong { color: var(--text); }
.route-point-row.active {
    outline: 2px solid var(--accent);
    background: rgba(56, 189, 248, .08);
}

/* v80.16 automatische responsive app layout */
html, body { min-width: 0; }
body { min-height: 100svh; }
.app-shell { min-height: 100svh; }
.content, .card, .live-map-panel, .overview-map-card, .overview-list-card { min-width: 0; }
@media (max-width: 1120px) {
    .content { padding: 18px; }
    .layout { grid-template-columns: 210px minmax(0, 1fr); }
    .sidebar { padding: 12px; }
    .sidebar button { font-size: 13px; padding: 10px 12px; }
    .overview-layout,
    .route-history-layout,
    .live-map-layout,
    .config-layout { grid-template-columns: 1fr; }
    .overview-list-card { order: 1; }
    .overview-map-card { order: 2; }
    .overview-tracker-list { max-height: none; overflow: visible; }
    .overview-map,
    .route-history-map { height: 440px; }
    .live-map { height: 420px; }
    .route-history-form,
    .eview-config-toolbar,
    .config-toolbar { grid-template-columns: 1fr 1fr; }
    .permission-switch-grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
    body { font-size: 14px; }
    .topbar {
        position: static;
        z-index: 1000;
        height: auto;
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
        align-items: start;
        padding: 10px 12px;
    }
    .topbar > div:first-child {
        display: grid;
        gap: 3px;
    }
    .version {
        margin-left: 0;
        font-size: 11px;
        line-height: 1.25;
        overflow-wrap: anywhere;
    }
    .topbar-actions {
        width: 100%;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        align-items: stretch;
    }
    .topbar-actions #welcome {
        grid-column: 1 / -1;
        font-size: 12px;
        overflow-wrap: anywhere;
    }
    .topbar-actions #logoutBtn {
        grid-column: 1 / -1;
        width: 100%;
    }
    .realtime-status-pill {
        justify-content: center;
        white-space: normal;
        text-align: center;
        min-height: 36px;
    }
    .layout {
        display: block;
        min-height: auto;
    }
    .sidebar {
        position: sticky;
        top: 0;
        z-index: 900;
        display: flex;
        gap: 8px;
        overflow-x: auto;
        border-right: 0;
        border-bottom: 1px solid var(--layout-border);
        padding: 10px 12px;
        scrollbar-width: thin;
    }
    .sidebar button {
        flex: 0 0 auto;
        width: auto;
        min-width: max-content;
        margin: 0;
        white-space: nowrap;
    }
    .content {
        padding: 12px;
    }
    h1 { font-size: 24px; line-height: 1.15; margin: 12px 0; }
    h2 { font-size: 19px; line-height: 1.2; }
    h3 { font-size: 16px; line-height: 1.25; }
    .card, .login-card, .setup-card {
        padding: 14px;
        margin: 12px 0;
        border-radius: 12px;
    }
    input, select, textarea, button, .button-link {
        min-height: 42px;
        font-size: 14px;
    }
    .button-row,
    .permission-group-actions,
    .route-playback-actions,
    .overview-tracker-actions,
    .live-monitor-actions {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
        width: 100%;
    }
    .button-row button,
    .button-row .button-link,
    .route-playback-actions button,
    .overview-tracker-actions button,
    .live-monitor-actions button,
    .permission-group-actions button {
        width: 100%;
    }
    .two-column,
    .status-grid,
    .debug-filter-form,
    .debug-summary-grid,
    .diagnostics-grid,
    .settings-field-grid,
    .snapshot-flow,
    .cleanup-summary-grid,
    .cleanup-action-grid,
    .permission-tools,
    .role-permission-header,
    .permission-switch-grid,
    .overview-kpi-grid,
    .overview-tracker-metrics,
    .overview-alarm-row,
    .route-history-form,
    .route-playback-grid,
    .route-point-row,
    .active-device-grid,
    .live-status-strip,
    .eview-config-toolbar,
    .config-toolbar,
    .config-layout,
    .settings-title-row,
    .eview-settings-title-row {
        grid-template-columns: 1fr !important;
    }
    .overview-hero-card,
    .overview-window-title,
    .live-monitor-header,
    .route-playback-header,
    .log-management-header,
    .permission-group-header {
        display: grid;
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .overview-hero-tools,
    .overview-user-filter { width: 100%; min-width: 0; }
    .overview-map,
    .route-history-map,
    .live-map {
        height: 340px;
        min-height: 320px;
    }
    .live-device-list,
    .route-point-list {
        max-height: 360px;
    }
    .emulator-terminal,
    pre {
        max-height: 55svh;
        font-size: 12px;
        white-space: pre-wrap;
        overflow-wrap: anywhere;
    }
    .table-wrap {
        margin-left: -2px;
        margin-right: -2px;
        padding-bottom: 6px;
    }
    table { min-width: 640px; }
    th, td { padding: 8px; }
    .settings-tabbar {
        position: static;
        flex-wrap: nowrap;
        overflow-x: auto;
        padding: 6px;
        gap: 6px;
    }
    .settings-tab {
        flex: 0 0 auto;
        white-space: nowrap;
        padding: 9px 10px;
    }
    .permission-switch-card {
        grid-template-columns: auto 1fr;
        gap: 10px;
        align-items: start;
    }
    .permission-state {
        grid-column: 2;
        justify-self: start;
    }
    .action-toast {
        left: 12px;
        right: 12px;
        bottom: 12px;
        max-width: none;
        width: auto;
    }
}

@media (max-width: 420px) {
    .topbar-actions { grid-template-columns: 1fr; }
    .overview-map,
    .route-history-map,
    .live-map { height: 300px; min-height: 280px; }
    .overview-kpi strong { font-size: 24px; }
    table { min-width: 560px; }
}

/* v80.20 - routehistorie positie wissel + Eview Settings programmeeromgeving */
.route-history-layout-swapped {
    grid-template-columns: minmax(320px, .78fr) minmax(520px, 1.22fr);
}
.route-point-card .route-point-list { max-height: 560px; }
.warn-pill {
    color: #fbbf24;
    border-color: rgba(251, 191, 36, .35);
    background: rgba(251, 191, 36, .08);
}
.eview-settings-workbench {
    overflow: hidden;
}
.eview-safe-flow {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 10px;
    margin-top: 14px;
}
.eview-safe-flow div {
    border: 1px solid #273449;
    border-radius: 14px;
    padding: 12px;
    background: rgba(2, 6, 23, .42);
}
.eview-safe-flow strong { display: block; margin-bottom: 5px; }
.eview-safe-flow span { color: var(--muted); font-size: 13px; line-height: 1.35; }
.eview-programmer-tabbar .settings-tab {
    min-height: 40px;
}
.eview-overview-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(360px, .85fr);
    gap: 16px;
    align-items: start;
}
.eview-quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}
.eview-section-intro {
    border-color: rgba(56, 189, 248, .22);
}
.eview-key-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}
.eview-key-badges span {
    border: 1px solid var(--field-border);
    border-radius: 999px;
    padding: 6px 9px;
    background: rgba(2, 6, 23, .55);
    color: var(--muted);
    font-weight: 700;
    font-size: 12px;
}
.eview-category-grid,
.eview-protocol-matrix {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 12px;
    margin-top: 14px;
}
.eview-protocol-card {
    border-color: rgba(56, 189, 248, .28);
}
.eview-protocol-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
    gap: 16px;
    align-items: end;
}
.eview-key-readbar {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto;
    gap: 12px;
    align-items: end;
    margin: 14px 0;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: rgba(2, 6, 23, .42);
}
.eview-key-card {
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 14px;
    background: rgba(2, 6, 23, .5);
    min-height: 185px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.eview-key-card-head,
.eview-key-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
}
.eview-key-number {
    font-family: Consolas, Monaco, 'Courier New', monospace;
    font-weight: 900;
    color: var(--accent);
    border: 1px solid rgba(56, 189, 248, .32);
    background: rgba(56, 189, 248, .08);
    border-radius: 999px;
    padding: 5px 8px;
}
.eview-key-card h3 {
    margin: 3px 0 0;
    font-size: 1rem;
}
.eview-key-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.42;
    flex: 1;
}
.eview-key-meta span:first-child {
    color: var(--text);
    font-weight: 700;
    font-size: 13px;
}
@media (max-width: 1120px) {
    .route-history-layout-swapped,
    .eview-overview-grid,
    .eview-protocol-header,
    .eview-key-readbar {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 760px) {
    .eview-category-grid,
    .eview-protocol-matrix { grid-template-columns: 1fr; }
    .eview-key-card { min-height: auto; }
}

/* v80.21 Eview Settings Auto Readback & Snapshot Manager */
.eview-readback-panel {
    border: 1px solid rgba(148, 163, 184, .25);
    border-radius: 14px;
    padding: 12px;
    margin: 12px 0;
    background: rgba(15, 23, 42, .35);
}
.readback-progress-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 10px;
}
.readback-progress-head strong,
.readback-progress-head span {
    display: block;
}
.readback-progress-stats {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    color: var(--muted, var(--muted));
    font-size: .85rem;
}
.readback-progress-bar {
    height: 10px;
    border-radius: 999px;
    background: rgba(148, 163, 184, .22);
    overflow: hidden;
    margin-bottom: 10px;
}
.readback-progress-bar span {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, rgba(59, 130, 246, .9), rgba(34, 197, 94, .9));
    transition: width .25s ease;
}
.readback-key-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    max-height: 145px;
    overflow: auto;
}
.readback-key-chip {
    border-radius: 999px;
    padding: 4px 8px;
    font-size: .78rem;
    border: 1px solid rgba(148, 163, 184, .25);
}
.snapshot-manager-form label {
    display: block;
    margin: 0 0 10px;
}
.snapshot-manager-form input,
.snapshot-manager-form textarea {
    width: 100%;
}
.hidden { display: none !important; }
@media (max-width: 760px) {
    .readback-progress-head {
        flex-direction: column;
    }
    .readback-key-grid {
        max-height: 180px;
    }
}

/* v80.21.3 - emulator stateful trackerconfig */
.compact-status.status-grid {
  margin-top: 0.75rem;
}
.mini-terminal {
  max-height: 260px;
  white-space: pre-wrap;
  overflow: auto;
}

/* v80.21.4 - emulator demo state editor */
.emulator-state-editor {
  margin-top: 1rem;
  border-top: 1px solid rgba(148, 163, 184, .18);
  padding-top: 1rem;
}
.emulator-state-editor h3,
.emulator-state-editor .full-width {
  grid-column: 1 / -1;
}
.emulator-state-subgrid {
  border: 1px solid rgba(148, 163, 184, .18);
  border-radius: 14px;
  padding: .9rem;
  background: rgba(15, 23, 42, .18);
}
.state-contact-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: .7rem;
}
@media (max-width: 900px) {
  .state-contact-grid {
    grid-template-columns: repeat(2, minmax(120px, 1fr));
  }
}
@media (max-width: 560px) {
  .state-contact-grid {
    grid-template-columns: 1fr;
  }
}

/* v80.22 - Menu & workspace layout cleanup */
.nav-group {
    display: grid;
    gap: 6px;
    margin-bottom: 18px;
}
.nav-group-title {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: 4px 4px 2px;
}
.sidebar .nav-group button {
    margin-bottom: 0;
}
.sidebar .nav-group button.active {
    box-shadow: inset 3px 0 0 var(--accent);
}
.workspace-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-top: 14px;
}
.workspace-card-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.workspace-card-grid > div {
    border: 1px solid #273449;
    border-radius: 12px;
    background: var(--subtle-bg);
    padding: 12px;
}
.workspace-card-grid strong,
.workspace-flow strong {
    display: block;
    margin-bottom: 4px;
}
.workspace-card-grid span,
.workspace-flow span {
    color: var(--muted);
    font-size: 13px;
}
.platform-settings-overview {
    border-color: rgba(56,189,248,.28);
}
@media (max-width: 800px) {
    .sidebar {
        align-items: flex-start;
    }
    .nav-group {
        min-width: max-content;
        margin-bottom: 0;
    }
    .nav-group-title {
        padding-left: 0;
    }
}

/* v80.22.1 - Unified Debug Terminal & complete log export */
.debug-terminal-hero {
    align-items: center;
}
.debug-kpi-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    margin-bottom: 14px;
}
.debug-kpi-grid.compact .debug-kpi {
    padding: 11px 12px;
}
.debug-kpi-grid.compact .debug-kpi strong {
    font-size: 22px;
}
.debug-unified-card {
    margin-top: 12px;
}
.terminal-title-row {
    align-items: flex-start;
}
.terminal-title-row p {
    margin: 6px 0 0;
}
.debug-quickbar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 12px 0;
}
.debug-quickbar button {
    padding: 8px 11px;
    border-radius: 999px;
    background: var(--field-bg);
    border: 1px solid var(--field-border);
    color: #cbd5e1;
    font-weight: 800;
}
.debug-quickbar button.active,
.debug-quickbar button:hover,
.debug-quickbar button:focus-visible {
    border-color: rgba(56, 189, 248, .78);
    color: #e0f2fe;
    background: rgba(56, 189, 248, .11);
    outline: none;
}
.terminal-filter-form {
    grid-template-columns: minmax(180px, .7fr) minmax(170px, .6fr) minmax(140px, .45fr) minmax(220px, 1.1fr) auto auto auto;
    align-items: end;
}
.terminal-checkbox {
    min-height: 42px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--muted);
}
.debug-terminal.unified {
    height: min(68vh, 760px);
    min-height: 520px;
    margin-top: 12px;
    padding: 12px;
}
.debug-terminal.unified .terminal-line {
    display: block;
    margin-bottom: 7px;
    padding: 0;
    overflow: hidden;
}
.debug-terminal.unified .terminal-line summary {
    cursor: pointer;
    list-style: none;
    padding: 8px 10px;
    display: grid;
    grid-template-columns: 120px 160px 82px 92px minmax(220px, 1fr);
    gap: 8px;
    align-items: start;
}
.debug-terminal.unified .terminal-line summary::-webkit-details-marker {
    display: none;
}
.debug-terminal.unified .terminal-line[open] summary {
    border-bottom: 1px solid var(--layout-border);
    background: rgba(255,255,255,.035);
}
.terminal-source {
    color: #c4b5fd;
    font-weight: 900;
}
.debug-terminal.unified .terminal-message {
    overflow-wrap: anywhere;
}
.terminal-meta {
    padding: 8px 10px 0;
    color: var(--muted);
    font-size: 12px;
}
.debug-terminal.unified pre {
    margin: 8px 10px 10px;
    max-height: 340px;
    white-space: pre-wrap;
    overflow: auto;
}
.debug-details-block {
    margin-top: 16px;
    border: 1px solid var(--border);
    border-radius: 16px;
    background: rgba(15, 23, 42, .58);
    box-shadow: 0 12px 30px rgba(0,0,0,.16);
}
.debug-details-block > summary {
    cursor: pointer;
    padding: 14px 16px;
    color: var(--text);
    font-weight: 900;
}
.debug-details-block[open] > summary {
    border-bottom: 1px solid var(--border);
}
.debug-details-block > .card,
.debug-details-block > .debug-summary-grid,
.debug-details-block > .debug-workbench-grid,
.debug-details-block > .debug-workbench-card {
    margin: 16px;
}
.debug-workbench-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}
.raw-inspector-card {
    margin-top: 16px !important;
}
@media (max-width: 1150px) {
    .terminal-filter-form {
        grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    }
    .debug-terminal.unified .terminal-line summary {
        grid-template-columns: 1fr;
        gap: 4px;
    }
    .debug-terminal.unified {
        min-height: 420px;
    }
}

/* v80.22.2 - Raw Data Inspector & complete support package */
.terminal-raw-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 8px;
    padding: 2px 7px;
    border-radius: 999px;
    border: 1px solid rgba(56, 189, 248, .55);
    background: rgba(56, 189, 248, .12);
    color: #bae6fd;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .04em;
}
.terminal-raw-badge.tx {
    border-color: rgba(251, 191, 36, .62);
    background: rgba(251, 191, 36, .12);
    color: #fde68a;
}
.terminal-raw-badge.rx {
    border-color: rgba(34, 197, 94, .55);
    background: rgba(34, 197, 94, .12);
    color: #bbf7d0;
}
.terminal-line.has-raw summary {
    box-shadow: inset 3px 0 0 rgba(56, 189, 248, .72);
}
.terminal-raw-panel {
    margin: 10px;
    padding: 10px;
    border: 1px solid rgba(56, 189, 248, .2);
    border-radius: 12px;
    background: rgba(2, 6, 23, .55);
}
.terminal-raw-header {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
    color: #e0f2fe;
    margin-bottom: 8px;
}
.terminal-raw-header span {
    color: var(--muted);
    font-size: 12px;
}
.terminal-raw-item {
    border-top: 1px solid rgba(148, 163, 184, .18);
    padding-top: 8px;
    margin-top: 8px;
}
.terminal-raw-item:first-of-type {
    border-top: 0;
    padding-top: 0;
    margin-top: 0;
}
.terminal-raw-item-title {
    color: #cbd5e1;
    font-size: 12px;
    font-weight: 900;
    margin-bottom: 6px;
}
.debug-terminal.unified pre.terminal-raw-value,
.debug-terminal.unified pre.terminal-raw-decode {
    margin: 6px 0;
    max-height: 260px;
    border-radius: 10px;
    border: 1px solid rgba(51, 65, 85, .75);
    background: var(--field-bg);
}
.debug-terminal.unified pre.terminal-raw-value {
    color: #93c5fd;
}
.debug-terminal.unified pre.terminal-raw-decode {
    color: #bbf7d0;
}
.terminal-raw-empty {
    padding: 8px 10px 0;
    color: #64748b;
    font-size: 12px;
}


/* v80.23-clean – logo en eenvoudige licht/donker thema's */
.card,
.login-card,
.setup-card {
    box-shadow: 0 12px 30px var(--card-shadow);
}
.topbar {
    background: var(--topbar-bg);
    border-bottom-color: var(--layout-border);
}
.sidebar {
    background: var(--sidebar-bg);
    border-right-color: var(--layout-border);
}
input,
select,
textarea,
pre,
.status-line {
    background: var(--field-bg);
    border-color: var(--field-border);
    color: var(--text);
}
pre,
code {
    color: var(--pre-text);
}
button:not(.secondary):not(.danger):not(.small):not(.tiny):not(.settings-tab):not(.overview-kpi):not(.debug-kpi):not(.alarm-kpi),
.button-link {
    background: var(--accent);
    color: var(--button-text);
}
button.secondary {
    background: var(--panel-light);
    color: var(--text);
    border: 1px solid var(--border-soft);
}
button.secondary:hover,
button.secondary:focus-visible {
    border-color: var(--accent);
    outline: none;
}
.sidebar .nav-group button.active,
.sidebar button.active {
    background: rgba(56, 189, 248, .12);
    outline-color: var(--accent);
}
html[data-theme="light"] .sidebar .nav-group button.active,
html[data-theme="light"] .sidebar button.active {
    background: rgba(3, 105, 161, .10);
}
.brand-lockup {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}
.brand-logo {
    display: block;
    height: 40px;
    width: auto;
    object-fit: contain;
}
.brand-logo-full {
    max-width: 315px;
}
.brand-logo-mark {
    display: none;
    height: 38px;
}
.brand-version {
    white-space: nowrap;
    margin-left: 2px;
}
.login-brand {
    display: grid;
    justify-items: center;
    gap: 8px;
    margin-bottom: 18px;
}
.login-brand img {
    width: min(420px, 100%);
    height: auto;
    display: block;
}
html[data-theme="light"] .topbar,
html[data-theme="light"] .sidebar {
    box-shadow: 0 1px 0 rgba(15,23,42,.04);
}
html[data-theme="light"] .brand-logo {
    filter: drop-shadow(0 4px 10px rgba(0,0,0,.10));
}
.theme-settings-grid {
    display: grid;
    grid-template-columns: minmax(260px, 420px) 1fr;
    gap: 18px;
    align-items: start;
}
.theme-choice-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(145px, 1fr));
    gap: 10px;
    margin-top: 12px;
}
.theme-choice {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 12px;
    min-height: 62px;
    border: 1px solid var(--border-soft);
    border-radius: 12px;
    background: var(--subtle-bg);
    color: var(--text);
}
.theme-choice input {
    width: auto;
    margin: 0;
}
.theme-choice strong {
    display: block;
    color: var(--text);
}
.theme-choice small {
    display: block;
    margin-top: 2px;
    color: var(--muted);
}
.theme-choice:has(input:checked) {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px rgba(56,189,248,.18) inset;
}
html[data-theme="light"] .theme-choice:has(input:checked) {
    box-shadow: 0 0 0 1px rgba(3,105,161,.16) inset;
}
.theme-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}
.theme-current-line {
    margin-top: 10px;
    color: var(--muted);
}
.theme-preview {
    border: 1px solid var(--border-soft);
    border-radius: 16px;
    overflow: hidden;
    background: var(--panel);
}
.theme-preview-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    background: var(--topbar-bg);
    border-bottom: 1px solid var(--layout-border);
}
.theme-preview-header img {
    height: 28px;
    width: auto;
}
.theme-preview-body {
    display: grid;
    grid-template-columns: 145px 1fr;
    gap: 12px;
    padding: 14px;
}
.theme-preview-menu div,
.theme-preview-card {
    border: 1px solid var(--border-soft);
    background: var(--subtle-bg);
    border-radius: 10px;
    padding: 9px 10px;
    margin-bottom: 8px;
}
.theme-preview-menu .active {
    background: rgba(56, 189, 248, .12);
    border-color: var(--accent);
}
html[data-theme="light"] .theme-preview-menu .active {
    background: rgba(3, 105, 161, .10);
}
.theme-preview-button {
    display: inline-block;
    padding: 8px 11px;
    border-radius: 9px;
    color: var(--button-text);
    background: var(--accent);
    font-weight: 700;
    margin-top: 8px;
}
@media (max-width: 1120px) {
    .brand-logo-full { max-width: 250px; }
    .brand-logo { height: 36px; }
    .theme-settings-grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
    .brand-logo-full { display: none; }
    .brand-logo-mark { display: block; }
    .brand-version { font-size: 12px; max-width: 55vw; overflow: hidden; text-overflow: ellipsis; }
    .theme-preview-body { grid-template-columns: 1fr; }
    .theme-choice-grid { grid-template-columns: 1fr; }
}

/* v80.24 Eview Settings programmeeromgeving */
.eview-program-card { border-color: rgba(56, 189, 248, .26); }
.eview-program-card-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: start;
}
.eview-program-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin: 14px 0;
}
.eview-program-grid label span {
    display: block;
    color: var(--muted);
    font-size: .88rem;
    margin-bottom: 5px;
}
.eview-program-grid .wide { grid-column: 1 / -1; }
.eview-program-grid textarea {
    min-height: 170px;
    font-family: Consolas, Monaco, 'Courier New', monospace;
    resize: vertical;
}
.command-preview-output pre {
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    max-height: 360px;
    overflow: auto;
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 10px;
    background: rgba(2, 6, 23, .45);
}
html[data-theme="light"] .command-preview-output pre,
html[data-theme="light"] .eview-key-card,
html[data-theme="light"] .eview-program-grid textarea {
    background: rgba(241, 245, 249, .86);
}
@media(max-width:900px){
    .eview-program-card-head { grid-template-columns: 1fr; }
}

/* v80.24.4 centrale debuglog */
.terminal-line summary { line-height: 1.55; }
.terminal-channel, .terminal-device, .terminal-protocol, .terminal-cmd, .terminal-key, .terminal-status {
    color: var(--muted, #9aa4b2);
    margin-right: .25rem;
    white-space: nowrap;
}
.terminal-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: .75rem;
    margin-top: .75rem;
}
.terminal-detail-grid section {
    border: 1px solid var(--border, rgba(148,163,184,.25));
    border-radius: 12px;
    padding: .75rem;
    background: rgba(15, 23, 42, .18);
    min-width: 0;
}
.terminal-detail-grid h4 {
    margin: 0 0 .45rem;
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--muted, #9aa4b2);
}
.terminal-detail-grid pre {
    max-height: 340px;
    overflow: auto;
    white-space: pre-wrap;
    word-break: break-word;
}
.terminal-cmd, .terminal-key { color: var(--accent, #38bdf8); }
.terminal-status { color: var(--success, #22c55e); }
.terminal-line.terminal-warn .terminal-status,
.terminal-line.terminal-error .terminal-status,
.terminal-line.terminal-critical .terminal-status { color: var(--warning, #f59e0b); }

/* v80.24.4.1 - bevestigen/annuleren dialoog voor debugbeheer */
.eview-confirm-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(2, 6, 23, .66);
    backdrop-filter: blur(8px);
}
.eview-confirm-dialog {
    width: min(560px, 100%);
    border: 1px solid var(--line);
    border-radius: 22px;
    background: var(--panel);
    color: var(--text);
    box-shadow: 0 24px 80px rgba(0,0,0,.36);
    padding: 22px;
}
.eview-confirm-dialog.danger { border-color: rgba(248, 113, 113, .45); }
.eview-confirm-dialog h2 { margin: 0 0 10px; }
.eview-confirm-dialog p { margin: 0 0 14px; color: var(--muted); }
.eview-confirm-dialog ul { margin: 0 0 18px; padding-left: 20px; color: var(--muted); }
.eview-confirm-dialog .confirm-actions { justify-content: flex-end; margin-top: 14px; }

.viewer-config-readonly {
    margin-top: 12px;
    padding: 10px 12px;
    border: 1px solid var(--border, rgba(148, 163, 184, .22));
    border-radius: 12px;
    background: rgba(15, 23, 42, .28);
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.viewer-config-readonly strong { color: var(--text, #e5e7eb); }
.viewer-config-readonly span { color: var(--muted, #94a3b8); }


.eview-shared-toast {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 10000;
    max-width: min(420px, calc(100vw - 2rem));
    padding: .85rem 1rem;
    border-radius: 14px;
    box-shadow: 0 18px 40px rgba(0,0,0,.28);
    background: var(--panel-bg, #172033);
    color: var(--text-color, #fff);
    border: 1px solid rgba(255,255,255,.16);
}
.eview-shared-toast.warn { border-color: rgba(245,158,11,.45); }
.eview-shared-toast.error { border-color: rgba(239,68,68,.55); }
.eview-shared-toast.success { border-color: rgba(34,197,94,.50); }
