/* ── MITMonitor — MITSign-aligned dark theme ───────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
    --bg:#000;
    --card:#0d1117;
    --card-2:#161b22;
    --border:#30363d;
    --border-soft:#21262d;
    --text:#f0f6fc;
    --muted:#8b949e;
    --dim:#484f58;
    --accent:#00a8ff;
    --accent-hi:#60c8ff;
    --accent-lo:#0077b6;
    --ok:#4ade80;
    --warn:#facc15;
    --bad:#f87171;
}

html,body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;min-height:100vh}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}

.app{display:flex;flex-direction:column;min-height:100vh}
.main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:32px 24px 60px}

/* ── Header ── */
.hdr{background:rgba(13,17,23,.95);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;gap:20px;position:sticky;top:0;z-index:20;backdrop-filter:blur(12px)}
.logo{font-size:20px;font-weight:700;letter-spacing:-.3px}
.logo span{color:var(--accent)}
.logo-lg{font-size:32px}
.hdr-nav{display:flex;gap:6px;align-items:center;flex:1}
.hdr-spacer{flex:1}
.hdr-user{font-size:13px;color:var(--muted)}
.nav-link{padding:7px 14px;font-size:13px;color:var(--muted);border-radius:8px;transition:all .15s}
.nav-link:hover{background:var(--card);color:var(--text)}

/* ── Buttons ── */
.btn-primary{padding:14px;width:100%;font-size:15px;font-weight:700;border:none;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-lo));color:#fff;transition:opacity .15s}
.btn-primary:hover:not(:disabled){opacity:.88}
.btn-primary:disabled{opacity:.4;cursor:not-allowed}
.btn-ghost{padding:7px 14px;font-size:13px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--muted)}
.btn-ghost:hover{background:var(--card);color:var(--text)}

.chip{padding:6px 12px;font-size:12px;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--muted)}
.chip:hover{color:var(--text);border-color:var(--accent)}
.chip.active{background:rgba(0,168,255,.12);color:var(--accent);border-color:var(--accent)}

/* ── Page header ── */
.page-hd{margin-bottom:28px}
.page-hd h1{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}
.page-hd .muted{font-size:14px}
.page-hd-row{display:flex;justify-content:space-between;align-items:start;gap:16px}

.muted{color:var(--muted)}
.ok{color:var(--ok)}
.bad{color:var(--bad)}
.warn{color:var(--warn)}

/* ── Login ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at top,rgba(0,168,255,.08),transparent 50%)}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:36px 32px;width:100%;max-width:380px}
.login-brand{text-align:center;margin-bottom:24px}
.login-brand .muted{margin-top:6px;font-size:13px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:500}
.inp{width:100%;padding:11px 13px;font-size:14px;border:1px solid var(--border);border-radius:9px;background:var(--card-2);color:var(--text);outline:none;transition:border-color .15s}
.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,168,255,.08)}
.inp::placeholder{color:var(--dim)}

.msg-err{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:10px 13px;border-radius:8px;font-size:13px;margin-bottom:14px}
.msg-info{background:rgba(0,168,255,.08);border:1px solid rgba(0,168,255,.2);color:var(--accent-hi);padding:10px 13px;border-radius:8px;font-size:13px;margin-bottom:14px}

/* ── Tenant grid (Dashboard) ── */
.tenant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.tenant-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;transition:all .15s;position:relative;overflow:hidden}
.tenant-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.tenant-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ok)}
.tenant-card.is-warning::before{background:var(--warn)}
.tenant-card.is-critical::before{background:var(--bad)}
.tc-head{display:flex;justify-content:space-between;align-items:center}
.tc-name{font-size:16px;font-weight:700}
.tc-dot{width:10px;height:10px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok)}
.tenant-card.is-warning .tc-dot{background:var(--warn);box-shadow:0 0 8px var(--warn)}
.tenant-card.is-critical .tc-dot{background:var(--bad);box-shadow:0 0 8px var(--bad)}
.tc-stats{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--muted)}
.tc-stats strong{color:var(--text);font-weight:600}

/* ── Probe grid (Tenant detail) ── */
.probe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.probe-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:5px;transition:all .15s;position:relative;overflow:hidden}
.probe-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.probe-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ok)}
.probe-card.is-critical::before{background:var(--bad)}
.probe-card.is-disabled{opacity:.55}
.probe-card.is-disabled::before{background:var(--dim)}
.pc-head{display:flex;justify-content:space-between;align-items:center}
.pc-kind{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px}
.pc-dot{width:8px;height:8px;border-radius:50%;background:var(--ok)}
.probe-card.is-critical .pc-dot{background:var(--bad)}
.pc-name{font-size:15px;font-weight:600}
.pc-host{font-size:12px}
.pc-last{font-size:11px}
.pc-err{margin-top:6px;font-size:11px;color:#fca5a5;background:rgba(239,68,68,.08);padding:5px 8px;border-radius:6px;word-break:break-word}

/* ── Probe detail (metric cards) ── */
.ctrl-row{display:flex;gap:8px;align-items:center;margin-bottom:20px}
.ctrl-row label{font-size:12px;color:var(--muted);margin-right:4px}
.metric-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.metric-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.mc-head{display:flex;justify-content:space-between;align-items:start;margin-bottom:10px;gap:12px}
.mc-label{font-size:14px;font-weight:600;color:var(--text)}
.mc-meta{font-size:11px;margin-top:2px}
.mc-value{font-size:24px;font-weight:700;color:var(--accent-hi);white-space:nowrap;text-align:right}
.mc-unit{font-size:13px;color:var(--muted);font-weight:500;margin-left:3px}
.mc-chart{width:100%!important;height:120px!important;max-height:120px}

.section-hd{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin:32px 0 12px}
.section-hd .muted{text-transform:none;letter-spacing:0;font-weight:500}

.info-box{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:8px}
.info-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 16px;display:flex;flex-direction:column;gap:5px;min-height:60px;transition:border-color .15s}
.info-card:hover{border-color:var(--border-soft)}
.info-key{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px}
.info-val{font-size:15px;color:var(--text);font-weight:600;line-height:1.3;word-break:break-word}

.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}

.vm-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:16px;margin-bottom:8px}
.vm-panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.vm-panel-hd{margin-bottom:10px}

.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{text-align:left;color:var(--muted);font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.5px;padding:8px 12px;border-bottom:1px solid var(--border-soft)}
.data-table td{padding:9px 12px;border-bottom:1px solid var(--border-soft)}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:var(--card-2)}

.small{font-size:12px}

.pill{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;padding:4px 12px;border-radius:20px;border:1px solid;white-space:nowrap}
.pill::before{content:'';width:8px;height:8px;border-radius:50%;display:inline-block}
.pill-ok{color:var(--ok);border-color:rgba(74,222,128,.4);background:rgba(74,222,128,.08)}
.pill-ok::before{background:var(--ok);box-shadow:0 0 6px var(--ok)}
.pill-bad{color:var(--bad);border-color:rgba(248,113,113,.4);background:rgba(248,113,113,.08)}
.pill-bad::before{background:var(--bad);box-shadow:0 0 6px var(--bad)}
.pill-warn{color:var(--warn);border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.pill-warn::before{background:var(--warn);box-shadow:0 0 6px var(--warn)}
.activity-log td.nowrap{white-space:nowrap}

/* ── Diebstahl-Schutz ── */
.theft-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin:16px 0;display:flex;flex-direction:column;gap:12px}
.theft-box.theft-active{border-color:var(--bad);box-shadow:0 0 0 2px rgba(248,113,113,.08)}
.theft-box .section-hd{margin:0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.theft-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn-warn{padding:10px 18px;background:rgba(251,191,36,.12);color:var(--warn);border:1px solid rgba(251,191,36,.4);border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}
.btn-warn:hover:not(:disabled){background:rgba(251,191,36,.2)}
.btn-warn:disabled{opacity:.4;cursor:not-allowed}
.theft-actions .btn-bad{padding:10px 18px;background:rgba(248,113,113,.12);color:var(--bad);border:1px solid rgba(248,113,113,.4);border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;text-decoration:none}
.theft-actions .btn-bad:hover:not(:disabled){background:rgba(248,113,113,.2)}
.theft-actions .btn-bad:disabled{opacity:.4;cursor:not-allowed}
.cat-theft{color:var(--bad);border-color:rgba(248,113,113,.4);background:rgba(248,113,113,.1)}
.cat-theft::before{background:var(--bad);box-shadow:0 0 8px var(--bad)}
.msg-info{color:var(--accent);font-size:13px;margin-top:6px}
.msg-err{color:var(--bad);font-size:13px;background:rgba(248,113,113,.08);padding:8px 12px;border-radius:6px;margin-top:6px}
.cat-agent{color:#a78bfa;border-color:rgba(167,139,250,.4);background:rgba(167,139,250,.08)}
.cat-agent::before{background:#a78bfa;box-shadow:0 0 6px #a78bfa}
.cat-remote{color:var(--accent);border-color:rgba(0,168,255,.4);background:rgba(0,168,255,.08)}
.cat-remote::before{background:var(--accent);box-shadow:0 0 6px var(--accent)}
.cat-config{color:#fbbf24;border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.cat-config::before{background:#fbbf24}
.cat-task{color:#34d399;border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.08)}
.cat-task::before{background:#34d399}
.cat-auth,.cat-system{color:var(--dim);border-color:var(--border);background:transparent}

.empty-card{grid-column:1/-1;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:40px;text-align:center}
.empty-card p{color:var(--muted);margin-bottom:16px}
.empty-card .btn-primary{display:inline-block;width:auto;padding:10px 20px}

/* ────────────────────────────────────────────────────
   TV-Mode: Vollbild-Dashboard für Display im Dauerbetrieb.
   Responsive via clamp() — skaliert 1080p (1920) bis 4K (3840).
   ──────────────────────────────────────────────────── */
.tv{display:grid;grid-template-rows:auto auto auto 1fr auto;gap:clamp(12px,1.2vw,28px);padding:clamp(16px,2vw,40px);min-height:100vh;background:radial-gradient(ellipse at top,rgba(0,168,255,.05),transparent 60%),#000;color:var(--text)}
.tv-hdr{display:flex;justify-content:space-between;align-items:baseline}
.tv-title{font-size:clamp(18px,1.8vw,40px);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.tv-clock{font-size:clamp(20px,2.2vw,48px);font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums}

.tv-hero{display:flex;justify-content:center;align-items:center}
.tv-ampel{background:var(--card);border:1px solid var(--border);border-radius:clamp(14px,1.4vw,28px);padding:clamp(14px,1.8vw,38px) clamp(28px,3vw,72px);display:flex;flex-direction:column;align-items:center;gap:clamp(6px,.7vw,14px);width:100%;max-width:1400px;position:relative;overflow:hidden;transition:all .4s}
.tv-ampel::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(74,222,128,.06));pointer-events:none;transition:background .4s}
.tv-ampel[data-status="warn"]::before{background:linear-gradient(135deg,transparent 60%,rgba(250,204,21,.08))}
.tv-ampel[data-status="critical"]::before{background:linear-gradient(135deg,transparent 60%,rgba(248,113,113,.12))}

.tv-dot{width:clamp(28px,3vw,64px);height:clamp(28px,3vw,64px);border-radius:50%;background:var(--ok);box-shadow:0 0 clamp(16px,2vw,48px) var(--ok);transition:all .4s}
.tv-ampel[data-status="warn"] .tv-dot{background:var(--warn);box-shadow:0 0 clamp(16px,2vw,48px) var(--warn)}
.tv-ampel[data-status="critical"] .tv-dot{background:var(--bad);box-shadow:0 0 clamp(24px,3vw,72px) var(--bad);animation:tv-pulse 1.2s infinite}
@keyframes tv-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

.tv-ampel-label{font-size:clamp(22px,2.5vw,56px);font-weight:800;letter-spacing:-.5px}
.tv-ampel[data-status="warn"] .tv-ampel-label{color:var(--warn)}
.tv-ampel[data-status="critical"] .tv-ampel-label{color:var(--bad)}
.tv-ampel-sub{font-size:clamp(13px,1.3vw,26px);color:var(--muted)}

.tv-temps{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(160px,16vw,360px),1fr));gap:clamp(10px,1.2vw,22px)}
.tv-temp{background:var(--card);border:1px solid var(--border);border-radius:clamp(10px,1vw,20px);padding:clamp(12px,1.4vw,28px);display:flex;flex-direction:column;gap:clamp(4px,.6vw,12px);transition:all .3s;position:relative;overflow:hidden}
.tv-temp::before{content:'';position:absolute;left:0;top:0;bottom:0;width:clamp(4px,.4vw,8px);background:var(--ok);transition:all .3s}
.tv-temp.tv-warn::before{background:var(--warn)}
.tv-temp.tv-critical::before{background:var(--bad);animation:tv-pulse 1.5s infinite}
.tv-temp-label{font-size:clamp(11px,1vw,20px);color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.tv-temp-value{font-size:clamp(28px,3.5vw,80px);font-weight:800;color:var(--text);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-1.2px}
.tv-temp.tv-warn .tv-temp-value{color:var(--warn)}
.tv-temp.tv-critical .tv-temp-value{color:var(--bad)}
.tv-temp-unit{font-size:.5em;color:var(--muted);font-weight:500;margin-left:.15em}

.tv-tunnels{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(150px,12vw,260px),1fr));gap:clamp(6px,.7vw,14px)}
.tv-tun{background:var(--card);border:1px solid var(--border);border-radius:clamp(8px,.8vw,16px);padding:clamp(10px,1vw,20px) clamp(12px,1.2vw,24px);display:flex;align-items:center;gap:clamp(8px,.8vw,18px);position:relative;overflow:hidden;min-height:clamp(64px,5vw,100px)}
.tv-tun::before{content:'';position:absolute;left:0;top:0;bottom:0;width:clamp(3px,.3vw,6px);background:var(--ok)}
.tv-tun.tv-bad::before{background:var(--bad);animation:tv-pulse 1.5s infinite}
.tv-tun-dot{width:clamp(10px,.9vw,16px);height:clamp(10px,.9vw,16px);border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);flex-shrink:0}
.tv-tun.tv-bad .tv-tun-dot{background:var(--bad);box-shadow:0 0 8px var(--bad)}
.tv-tun-label{font-size:clamp(12px,1.1vw,20px);font-weight:600;color:var(--text);line-height:1.25;flex:1;min-width:0}
.tv-tun-sub{font-size:clamp(10px,.85vw,15px);color:var(--muted);margin-top:2px;font-variant-numeric:tabular-nums}

.tv-servers{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(220px,20vw,440px),1fr));gap:clamp(10px,1vw,20px)}
.tv-srv{background:var(--card);border:1px solid var(--border);border-radius:clamp(10px,1vw,20px);padding:clamp(12px,1.2vw,24px);display:flex;flex-direction:column;gap:clamp(8px,.9vw,18px);position:relative;overflow:hidden;transition:all .3s}
.tv-srv::before{content:'';position:absolute;left:0;top:0;bottom:0;width:clamp(4px,.4vw,8px);background:var(--ok);transition:all .3s}
.tv-srv.tv-warn::before{background:var(--warn)}
.tv-srv.tv-critical::before{background:var(--bad);animation:tv-pulse 1.5s infinite}
.tv-srv-name{font-size:clamp(13px,1.2vw,24px);font-weight:700;color:var(--text);letter-spacing:-.2px}
.tv-srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(8px,.8vw,16px)}
.tv-srv-cell{display:flex;flex-direction:column;gap:clamp(2px,.3vw,6px)}
.tv-srv-key{font-size:clamp(9px,.8vw,16px);color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.tv-srv-val{font-size:clamp(20px,2.2vw,52px);font-weight:800;color:var(--text);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.8px}
.tv-srv.tv-warn .tv-srv-val{color:var(--warn)}
.tv-srv.tv-critical .tv-srv-val{color:var(--bad)}
.tv-srv-unit{font-size:.45em;color:var(--muted);font-weight:500;margin-left:.15em}

.tv-tenants{display:grid;grid-template-columns:repeat(auto-fit,minmax(clamp(160px,14vw,300px),1fr));gap:clamp(10px,1vw,20px);align-content:start}
.tv-tile{background:var(--card);border:1px solid var(--border);border-radius:clamp(8px,.8vw,16px);padding:clamp(12px,1.2vw,24px);display:flex;flex-direction:column;gap:clamp(4px,.6vw,10px);position:relative;overflow:hidden}
.tv-tile::before{content:'';position:absolute;left:0;top:0;bottom:0;width:clamp(3px,.3vw,6px);background:var(--ok)}
.tv-tile.tv-critical::before{background:var(--bad)}
.tv-tile.tv-idle::before{background:var(--dim)}
.tv-tile-name{font-size:clamp(14px,1.3vw,28px);font-weight:700}
.tv-tile-stats{font-size:clamp(12px,1.1vw,22px);color:var(--muted)}
.tv-tile.tv-critical .tv-tile-stats{color:var(--bad)}

.tv-foot{display:flex;justify-content:center;gap:8px;font-size:clamp(11px,.9vw,18px);color:var(--dim);padding-top:clamp(8px,1vw,20px);border-top:1px solid var(--card)}
.tv-foot-sep{color:var(--dim)}

body.tv-lost .tv::after{content:'Verbindung zum Server unterbrochen';position:fixed;inset:0;background:rgba(0,0,0,.92);color:var(--bad);display:flex;align-items:center;justify-content:center;font-size:clamp(28px,3vw,72px);font-weight:800;z-index:100;letter-spacing:-.5px}

.tv-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;color:var(--muted);text-align:center;background:#000;padding:24px}

/* ── Footer ── */
.footer{text-align:center;padding:24px;font-size:12px;color:var(--dim);border-top:1px solid var(--card)}
.footer span{margin:0 6px}

/* ── Installer-Box ── */
.installer-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin:16px 0;display:flex;flex-direction:column;gap:10px}
.installer-box .section-hd{margin:0 0 4px 0}
.installer-box code{font-family:'SFMono-Regular','Menlo','Monaco',monospace;background:rgba(255,255,255,.04);padding:4px 8px;border-radius:6px;font-size:13px;color:var(--text);word-break:break-all}
.installer-url{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.installer-url code{flex:1;min-width:200px}
.installer-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:6px}

/* Edit-Icon in data-table */
.edit-icon{background:transparent;border:none;color:var(--dim);cursor:pointer;padding:2px 6px;margin-left:6px;font-size:13px;border-radius:4px;opacity:.5;transition:opacity .1s,color .1s}
.data-table tr:hover .edit-icon{opacity:.85}
.edit-icon:hover{opacity:1;color:var(--accent);background:rgba(0,168,255,.08)}
.user-manual{color:var(--accent)}
.page-hd-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.pc-remote{position:absolute;top:8px;right:36px;font-size:18px;cursor:pointer;padding:4px 6px;border-radius:6px;opacity:.6;transition:all .15s;line-height:1}
.pc-remote:hover{opacity:1;background:rgba(0,168,255,.15);transform:scale(1.1)}
.probe-card{position:relative}
.col-remote{width:32px;text-align:center;padding-left:0;padding-right:0}
.row-remote{font-size:16px;opacity:.65;text-decoration:none;transition:opacity .15s;display:inline-block;padding:2px 4px;border-radius:6px}
.row-remote:hover{opacity:1;background:rgba(0,168,255,.12)}

/* Agent-Version-Indicator */
.pc-ver{font-size:11px;font-family:'SFMono-Regular','Menlo','Monaco',monospace;letter-spacing:.5px;margin-top:4px}
.ver-ok{color:var(--ok);opacity:.7}
.ver-stale{color:var(--warn);opacity:.85;font-weight:600}
.ver-ok::before{content:"● ";font-size:9px}
.ver-stale::before{content:"⚠ ";font-size:11px}

/* Modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:24px;min-width:420px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 16px 48px rgba(0,0,0,.5)}
.modal-title{margin:0 0 6px 0;font-size:17px;font-weight:600}
.modal-input{width:100%;padding:11px 14px;font-size:15px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;margin-top:14px;margin-bottom:18px}
.modal-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(0,168,255,.25)}
.modal-actions{display:flex;justify-content:flex-end;gap:10px}
.btn{padding:10px 18px;font-size:14px;font-weight:600;border:none;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer;transition:opacity .15s;align-self:flex-start}
.btn:hover:not(:disabled){opacity:.88}
.btn:disabled{opacity:.4;cursor:not-allowed}
.error{color:var(--bad);font-size:13px;margin:4px 0 0 0}
.small{font-size:12px}

/* ── KI-Diagnose ───────────────────────────────────────────── */
.aidiag-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin:16px 0;display:flex;flex-direction:column;gap:12px}
.aidiag-input{display:flex;flex-direction:column;gap:10px}
.aidiag-ta{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-family:inherit;font-size:14px;resize:vertical}
.aidiag-ta:focus{outline:none;border-color:var(--accent)}
.aidiag-ctrls{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.aidiag-ctrls select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font-size:13px;margin-left:6px}
.aidiag-ctrls .btn-primary{width:auto;padding:9px 18px;font-size:14px}
.aidiag-history{margin-top:8px}
.aidiag-history summary{cursor:pointer;padding:4px 0}
.aidiag-hist-list{list-style:none;padding:0;margin:6px 0 0;display:flex;flex-direction:column;gap:4px}
.aidiag-hist-list li{font-size:13px}
.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:0;text-decoration:underline}
.aidiag-conv{display:flex;flex-direction:column;gap:10px;max-height:600px;overflow-y:auto;padding:8px;background:var(--bg);border-radius:8px;border:1px solid var(--border)}
.aidiag-msg{padding:8px 12px;border-radius:8px;font-size:13px;line-height:1.45}
.aidiag-user-text{background:rgba(59,130,246,.08);border-left:3px solid #3b82f6}
.aidiag-assistant-text{background:rgba(34,197,94,.06);border-left:3px solid #22c55e;white-space:pre-wrap}
.aidiag-assistant-tool_use{background:rgba(168,85,247,.07);border-left:3px solid #a855f7}
.aidiag-user-tool_result{background:rgba(115,115,115,.07);border-left:3px solid #737373}
.aidiag-role{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:3px}
.aidiag-body{white-space:pre-wrap;word-break:break-word}
.aidiag-mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}
.aidiag-result{max-height:280px;overflow:auto;margin:0;padding:6px 8px;background:rgba(0,0,0,.15);border-radius:4px}
.aidiag-spinner{font-style:italic;color:var(--muted);text-align:center;padding:12px}
.aidiag-actions{display:flex;justify-content:flex-end;gap:8px;align-items:center}

/* ── KI-Findings / Scanner ─────────────────────────────────── */
.findings-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 12px;background:var(--bg);border-radius:8px;border:1px solid var(--border)}
.findings-bar-info{display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-size:13px}
.findings-list{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.finding-item{border:1px solid var(--border);border-radius:8px;background:var(--bg);overflow:hidden;border-left-width:4px}
.finding-item summary{cursor:pointer;padding:9px 12px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px;list-style:none}
.finding-item summary::-webkit-details-marker{display:none}
.finding-item summary::before{content:"▸";color:var(--muted);font-size:11px;transition:transform .12s}
.finding-item[open] summary::before{transform:rotate(90deg)}
.finding-title{font-weight:600;color:var(--text)}
.finding-cat{text-transform:uppercase;letter-spacing:.4px;font-weight:600;font-size:10px}
.finding-sev{font-size:10px;font-weight:700;letter-spacing:.4px;padding:2px 8px;border-radius:4px}
.sev-pill-critical{background:rgba(239,68,68,.16);color:#fca5a5}
.sev-pill-high{background:rgba(249,115,22,.16);color:#fdba74}
.sev-pill-medium{background:rgba(234,179,8,.16);color:#fde047}
.sev-pill-low,.sev-pill-info{background:rgba(115,115,115,.18);color:#a3a3a3}
.finding-item.sev-critical{border-left-color:#ef4444}
.finding-item.sev-high{border-left-color:#f97316}
.finding-item.sev-medium{border-left-color:#eab308}
.finding-item.sev-low,.finding-item.sev-info{border-left-color:#737373}
.sev-critical{color:#fca5a5;font-weight:600}
.sev-high{color:#fdba74;font-weight:600}
.sev-medium{color:#fde047;font-weight:600}
.finding-body{padding:0 14px 12px;border-top:1px solid var(--border);background:rgba(0,0,0,.07)}
.finding-desc{white-space:pre-wrap;font-family:inherit;font-size:13px;margin:10px 0;padding:0;background:transparent;color:var(--text)}
.finding-meta{margin-top:8px}
.finding-meta code{background:rgba(0,0,0,.2);padding:1px 6px;border-radius:3px;font-size:11px}
.finding-actions{margin-top:10px;display:flex;gap:6px}
.aidiag-fix-btn{width:auto;padding:7px 14px;font-size:13px;font-weight:600}

/* ── Probe-Tags ─────────────────────────────────────────────────── */
.tag-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:12px}
.pill-tag{background:rgba(99,102,241,.18);color:#a5b4fc;border:1px solid rgba(99,102,241,.35)}
.pill-sandbox{background:rgba(234,179,8,.18);color:#fde047;border:1px solid rgba(234,179,8,.45)}
.pill-x{margin-left:6px;background:none;border:none;color:inherit;cursor:pointer;opacity:.6;padding:0 2px;font-size:13px;line-height:1}
.pill-x:hover{opacity:1}
.tag-input{background:transparent;border:1px dashed var(--border);border-radius:14px;padding:4px 12px;color:var(--text);font-size:12px;min-width:180px;outline:none;height:28px;box-sizing:border-box;line-height:18px}
.tag-input:focus{border-style:solid;border-color:var(--accent);background:rgba(99,102,241,.06)}
.tag-add-btn{padding:0 14px;height:28px;border:1px solid rgba(99,102,241,.45);border-radius:14px;background:rgba(99,102,241,.12);color:#a5b4fc;font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}
.tag-add-btn:hover:not(:disabled){background:rgba(99,102,241,.28);border-color:rgba(99,102,241,.75);color:#c7d2fe}
.tag-add-btn:disabled{opacity:.25;cursor:not-allowed}

/* ── Software-Katalog ─────────────────────────────────────────── */
.pkg-modal{width:760px;max-width:95vw;max-height:90vh;overflow-y:auto}
.pkg-step{padding:20px 0}
.pkg-uploadbox{display:flex;flex-direction:column;justify-content:center;align-items:center;border:2px dashed var(--border);border-radius:12px;padding:40px 20px;text-align:center;background:var(--bg)}
.pkg-uploadbox:hover{border-color:var(--accent);background:rgba(0,168,255,.04)}
.pkg-filepicker{font-size:13px;color:var(--text);padding:6px}
.pkg-filepicker::file-selector-button{padding:8px 18px;font-size:13px;font-weight:600;border:1px solid var(--accent);border-radius:8px;background:linear-gradient(135deg,var(--accent),var(--accent-lo));color:#fff;cursor:pointer;margin-right:12px}
.pkg-filepicker::file-selector-button:hover{opacity:.85}
.pkg-uploadbox-text{display:flex;flex-direction:column;align-items:center;gap:6px}
.pkg-meta{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 14px;margin-bottom:14px;font-size:13px}
.pkg-meta code{background:rgba(0,0,0,.25);padding:1px 6px;border-radius:3px;font-size:11px}
.pkg-form{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.pkg-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
.pkg-grid label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.pkg-grid label.full{grid-column:1/-1}
.pkg-grid input,.pkg-grid textarea{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text);font-size:13px;font-family:inherit;outline:none}
.pkg-grid input:focus,.pkg-grid textarea:focus{border-color:var(--accent)}
.pkg-grid textarea{resize:vertical;font-family:ui-monospace,Menlo,monospace;font-size:12px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.modal-actions .btn-primary{width:auto;padding:9px 20px}
.modal-hd{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.modal-hd h2{margin:0;font-size:18px}
.modal-x{background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;line-height:1;padding:0 4px}
.modal-x:hover{color:var(--text)}
.empty{padding:60px;text-align:center;color:var(--muted)}

/* ── Sandbox-Run-Panel ─────────────────────────────────────────── */
.sandbox-run-panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:18px}
.sandbox-run-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:12px;flex-wrap:wrap}
.sandbox-run-log{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;font-size:13px;max-height:260px;overflow-y:auto}
.sandbox-run-log li{display:grid;grid-template-columns:80px 160px 1fr;gap:10px;padding:4px 0;border-top:1px solid var(--border-soft)}
.sandbox-run-log li:first-child{border-top:none}
.sandbox-run-log strong{color:var(--accent-hi);font-size:12px}

/* ── Deploy-Modal ─────────────────────────────────────────────── */
.deploy-targets{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.deploy-target-row{display:flex;gap:12px;align-items:flex-start;padding:10px 14px;border:1px solid var(--border);border-radius:8px;cursor:pointer;background:var(--bg)}
.deploy-target-row:hover{border-color:var(--accent)}
.deploy-target-row input[type=radio]{margin-top:3px}
.deploy-target-row strong{display:block;font-size:14px}
.deploy-target-row .muted{margin-top:2px}
.deploy-preview{padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-size:13px}
.deploy-preview-names{margin-top:8px;display:flex;flex-wrap:wrap;gap:4px}
.deploy-picker{border:1px solid var(--border);border-radius:8px;background:var(--bg);max-height:340px;display:flex;flex-direction:column;overflow:hidden}
.deploy-picker-hd{padding:8px 12px;display:flex;gap:10px;align-items:center;border-bottom:1px solid var(--border-soft);flex-wrap:wrap}
.deploy-picker-list{flex:1;overflow-y:auto;padding:4px 0}
.deploy-picker-tenant{padding:6px 12px}
.deploy-picker-tenant > strong{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.5px}
.deploy-picker-row{display:flex;gap:8px;align-items:center;padding:4px 6px;border-radius:4px;cursor:pointer;font-size:13px}
.deploy-picker-row:hover{background:rgba(0,168,255,.08)}
.deploy-picker-row.picked{background:rgba(0,168,255,.12)}
.deploy-picker-kind{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;min-width:60px}

/* ── Rollout-Dashboard ─────────────────────────────────────────── */
.rollout-list{display:flex;flex-direction:column;gap:10px}
.rollout-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;transition:border-color .15s}
.rollout-card.running{border-color:rgba(234,179,8,.4)}
.rollout-hd{display:flex;justify-content:space-between;align-items:start;cursor:pointer;gap:14px;flex-wrap:wrap}
.rollout-hd:hover{opacity:.92}
.rollout-title{font-size:14px}
.rollout-meta{font-size:11px;text-align:right}
.rollout-progress{margin-top:10px}
.rollout-bar{display:flex;height:8px;background:#1f2228;border-radius:4px;overflow:hidden}
.rollout-bar-ok{background:#4ade80}
.rollout-bar-fail{background:#f87171}
.rollout-bar-detfail{background:#fbbf24}
.rollout-bar-running{background:#3b82f6}
.rollout-counts{display:flex;gap:14px;font-size:12px;margin-top:6px;align-items:baseline}
.rollout-counts .ok{color:#86efac}
.rollout-counts .bad{color:#fca5a5}
.rollout-counts .warn{color:#fde047}
.rollout-jobs{margin-top:14px;border-top:1px solid var(--border-soft);padding-top:10px}

/* ── Learning-Banner ─────────────────────────────────────────────── */
.learning-banner{display:flex;gap:10px;align-items:center;padding:10px 14px;border-radius:8px;margin-bottom:12px;font-size:13px;flex-wrap:wrap}
.learning-banner.ok{background:rgba(168,85,247,.12);border:1px solid rgba(168,85,247,.35);color:#ddd6fe}
.learning-banner.fail{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35);color:#fca5a5}
.learning-banner strong{color:inherit}
