:root{
  --bg:#0a0d12; --bg2:#12171f; --bg3:#1a212b; --line:#28303b; --line2:#333d4a;
  --txt:#e6edf3; --txt2:#9aa7b4; --txt3:#6b7684;
  --acc:#3b82f6; --acc2:#2563eb; --cyan:#22d3ee;
  --ok:#22c55e; --okbg:#0f2a1a; --warn:#f59e0b; --warnbg:#2a2110; --err:#ef4444; --errbg:#2a1414;
  --stop:#64748b; --stopbg:#1a2029;
  --radius:10px; --shadow:0 20px 60px rgba(0,0,0,.5);
}
:root[data-theme="light"]{
  --bg:#eef1f6; --bg2:#ffffff; --bg3:#f1f4f8; --line:#e2e7ee; --line2:#d5dbe4;
  --txt:#111827; --txt2:#4b5563; --txt3:#8a94a2;
  --okbg:#e7f7ec; --warnbg:#fdf3e0; --errbg:#fdeaea; --stopbg:#eef1f5;
  --shadow:0 20px 60px rgba(20,30,50,.15);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{overflow-x:hidden}
body{background:var(--bg);color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Ubuntu,sans-serif;font-size:14px;line-height:1.5}
a{color:var(--acc);text-decoration:none}
.hidden{display:none!important}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px}
.muted{color:var(--txt3)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;vertical-align:middle}
button{font-family:inherit}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line2);
  background:var(--bg2);color:var(--txt);padding:8px 13px;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer;transition:.12s}
.btn:hover{border-color:var(--txt3)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn svg{width:15px;height:15px}
.btn.pri{background:var(--acc);border-color:var(--acc);color:#fff}
.btn.pri:hover{background:var(--acc2)}
.btn.dgr{background:var(--errbg);border-color:var(--err);color:var(--err)}
.btn.sm{padding:5px 9px;font-size:12px}
.btn.full{width:100%;padding:12px}
.ico{width:32px;height:32px;border:1px solid var(--line);border-radius:8px;background:var(--bg2);
  display:grid;place-items:center;cursor:pointer;color:var(--txt2)}
.ico:hover{color:var(--txt)}
.ico svg{width:15px;height:15px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;border:1px solid transparent}
.pill.run{background:var(--okbg);color:var(--ok);border-color:rgba(34,197,94,.25)}
.pill.stop{background:var(--stopbg);color:var(--stop);border-color:var(--line2)}
.pill.err{background:var(--errbg);color:var(--err);border-color:rgba(239,68,68,.25)}
.pill.warn{background:var(--warnbg);color:var(--warn);border-color:rgba(245,158,11,.25)}

/* ---------- app shell ---------- */
.app{display:flex;min-height:100vh}
.side{width:230px;flex:0 0 230px;background:var(--bg2);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:16px 12px;gap:4px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;padding:8px 10px 16px}
.brand .logo{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#22d3ee);
  display:grid;place-items:center;color:#fff;font-weight:800}
.brand b{font-size:15px}.brand span{display:block;font-size:11px;color:var(--txt3);font-weight:500}
.navsec{font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--txt3);padding:14px 12px 5px}
.navsec:first-of-type{padding-top:4px}
.nav{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:8px;color:var(--txt2);cursor:pointer;font-weight:500;transition:.12s}
.nav:hover{background:var(--bg3);color:var(--txt)}
.nav.active{background:var(--acc);color:#fff}
.nav svg{width:17px;height:17px;flex:0 0 17px}
.nav .badge{margin-left:auto;font-size:11px;background:var(--bg3);color:var(--txt2);padding:1px 7px;border-radius:20px;font-weight:600}
.nav.active .badge{background:rgba(255,255,255,.2);color:#fff}
.side .sp{flex:1}
.side .foot{border-top:1px solid var(--line);padding-top:10px;font-size:12px;color:var(--txt3);display:flex;align-items:center;gap:9px}
.side .foot .ava{width:26px;height:26px;border-radius:50%;background:var(--bg3);display:grid;place-items:center;color:var(--txt);font-weight:700;font-size:12px}
.side .foot svg{cursor:pointer;width:16px;height:16px}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.top{min-height:60px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:12px 26px;background:var(--bg)}
.top h1{font-size:17px;margin:0;font-weight:650}
.top .grow{flex:1}
.content{flex:1;overflow:auto;padding:24px 26px}

/* ---------- stats + table ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:15px 17px}
.stat .k{font-size:12px;color:var(--txt3);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.stat .v{font-size:26px;font-weight:750;margin-top:6px;letter-spacing:-.5px}
.stat .v small{font-size:13px;color:var(--txt3);font-weight:600}
.stat .d{font-size:12px;color:var(--txt3);margin-top:2px}
.panel{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel .ph{display:flex;align-items:center;gap:12px;padding:14px 17px;border-bottom:1px solid var(--line)}
.panel .ph h2{font-size:14px;margin:0;font-weight:650}
.panel .ph .grow{flex:1}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;padding:10px 17px;color:var(--txt3);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--line);white-space:nowrap}
tbody td{padding:12px 17px;border-bottom:1px solid var(--line)}
tbody tr:last-child td{border-bottom:0}
tbody tr.clk{cursor:pointer;transition:.1s}
tbody tr.clk:hover{background:var(--bg3)}
.iname{display:flex;align-items:center;gap:11px}
.iname .av{width:30px;height:30px;border-radius:7px;background:var(--bg3);display:grid;place-items:center;font-weight:750;color:var(--txt2);flex:0 0 30px;text-transform:uppercase}
.iname b{font-weight:650}
.iname .mac{font-size:11.5px;color:var(--txt3);font-family:ui-monospace,monospace}
.url{font-family:ui-monospace,monospace;font-size:12.5px;color:var(--acc)}
.rowact{display:flex;gap:6px;justify-content:flex-end}
.rowact .ico{width:28px;height:28px}.rowact .ico svg{width:14px;height:14px}
.empty{text-align:center;padding:50px 20px;color:var(--txt3)}

/* ---------- modal ---------- */
.scrim{position:fixed;inset:0;background:rgba(4,7,12,.6);backdrop-filter:blur(2px);display:none;align-items:flex-start;justify-content:center;padding:60px 20px;z-index:50;overflow:auto}
.scrim.show{display:flex}
.modal{background:var(--bg2);border:1px solid var(--line2);border-radius:14px;box-shadow:var(--shadow);width:560px;max-width:100%;overflow:hidden}
.modal .mh{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.modal .mh svg{width:20px;height:20px;flex:0 0 20px}
.modal .mh h3{margin:0;font-size:16px;font-weight:700}
.modal .mh .x{margin-left:auto;cursor:pointer;color:var(--txt3);font-size:18px}
.modal .mb{padding:20px 22px;display:flex;flex-direction:column;gap:16px;max-height:66vh;overflow:auto}
.modal .mf{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--txt2);margin-bottom:6px}
.field .hint{font-size:11.5px;color:var(--txt3);margin-top:5px}
.inp{width:100%;background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:9px 12px;color:var(--txt);font-size:13.5px;outline:none}
.inp:focus{border-color:var(--acc)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.igrp{display:flex}.igrp .inp{border-radius:8px 0 0 8px;border-right:0}
.igrp .suf{display:flex;align-items:center;padding:0 12px;background:var(--bg3);border:1px solid var(--line2);border-radius:0 8px 8px 0;color:var(--txt3);font-family:ui-monospace,monospace;font-size:12.5px}
.proto{display:flex;flex-direction:column;gap:8px}
.protorow{display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--line2);border-radius:9px;padding:9px 11px}
.protorow .pl{display:flex;align-items:center;gap:10px;flex:1}
.protorow .pico{width:34px;height:26px;flex:0 0 34px;border-radius:6px;background:var(--bg3);display:grid;place-items:center;font-size:10px;font-weight:800;letter-spacing:.3px}
.protorow .pl b{font-size:13px}.protorow .pl span{display:block;font-size:11px;color:var(--txt3)}
.seg{display:flex;background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:3px;gap:3px}
.seg.sm{padding:2px;flex:0 0 210px}
.seg .opt{flex:1;text-align:center;padding:7px;border-radius:6px;font-size:12.5px;font-weight:600;color:var(--txt2);cursor:pointer}
.seg.sm .opt{padding:5px 8px;font-size:11.5px}
.seg .opt.on{background:var(--acc);color:#fff}

/* ---------- detail ---------- */
.dhead{display:flex;align-items:center;gap:16px;margin:6px 0 20px}
.dhead .big{width:52px;height:52px;border-radius:12px;background:var(--bg3);display:grid;place-items:center;font-weight:800;font-size:20px;color:var(--txt2);text-transform:uppercase}
.dhead h1{margin:0;font-size:21px}
.dhead .m{color:var(--txt3);font-size:12.5px;font-family:ui-monospace,monospace}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:17px}
.card h4{margin:0 0 14px;font-size:13px;font-weight:650}
.kv{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.kv:last-child{border-bottom:0}
.kv .kk{color:var(--txt3)}
.kv .vv{font-weight:600;font-family:ui-monospace,monospace;font-size:12.5px}
.danger{border-color:rgba(239,68,68,.3)}
.danger h4{color:var(--err)}
.drow{display:flex;align-items:center;gap:14px;padding:11px 0;border-bottom:1px solid var(--line)}
.drow:last-child{border-bottom:0}.drow .grow{flex:1}
.drow b{font-size:13px}.drow p{margin:2px 0 0;font-size:12px;color:var(--txt3)}

/* ---------- login ---------- */
.loginwrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;
  background-image:radial-gradient(1200px 500px at 15% -10%,rgba(59,130,246,.12),transparent 60%),radial-gradient(900px 500px at 110% 110%,rgba(34,211,238,.08),transparent 55%)}
.shell{width:940px;max-width:100%;display:grid;grid-template-columns:1fr 1fr;background:var(--bg2);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.brandpane{padding:38px 34px;background:linear-gradient(160deg,#0d1420,#0a0f18);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:24px}
:root[data-theme="light"] .brandpane{background:linear-gradient(160deg,#f7f9fc,#eef2f8)}
.lead{font-size:22px;font-weight:750;line-height:1.3;letter-spacing:-.4px}
.lead .hl{background:linear-gradient(90deg,#3b82f6,#22d3ee);-webkit-background-clip:text;background-clip:text;color:transparent}
.feat{display:flex;flex-direction:column;gap:14px}
.fitem{display:flex;gap:12px;align-items:flex-start}
.fitem .fi{width:30px;height:30px;flex:0 0 30px;border-radius:8px;background:var(--bg3);display:grid;place-items:center;color:var(--cyan)}
.fitem .fi svg{width:16px;height:16px}
.fitem b{font-size:13px;font-weight:650}.fitem p{margin:2px 0 0;font-size:12px;color:var(--txt3)}
.authpane{padding:38px 40px;display:flex;flex-direction:column;justify-content:center;min-height:520px}
.authpane h2{margin:0 0 5px;font-size:20px;font-weight:750}
.authpane .sub{color:var(--txt3);font-size:13px;margin-bottom:22px}
.field.big{margin-bottom:16px}
.ibox{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:11px 13px}
.ibox:focus-within{border-color:var(--acc);box-shadow:0 0 0 3px rgba(59,130,246,.15)}
.ibox svg{width:16px;height:16px;color:var(--txt3);flex:0 0 16px}
.ibox input{border:0;background:transparent;color:var(--txt);outline:none;width:100%;font-size:14px}
.divider{display:flex;align-items:center;gap:12px;color:var(--txt3);font-size:11.5px;margin:16px 0}
.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}
.otp{display:flex;gap:9px;justify-content:center;margin:6px 0 18px}
.otp input{width:46px;height:56px;text-align:center;font-size:22px;font-weight:700;background:var(--bg);border:1px solid var(--line2);border-radius:10px;color:var(--txt);outline:none}
.otp input:focus{border-color:var(--acc)}
.note{display:flex;align-items:center;gap:9px;font-size:12px;padding:10px 12px;border-radius:9px;margin-top:12px}
.note svg{width:16px;height:16px;flex:0 0 16px}
.note.warn{background:var(--warnbg);color:var(--warn);border:1px solid rgba(245,158,11,.25)}
.note.err{background:var(--errbg);color:var(--err);border:1px solid rgba(239,68,68,.25)}
.note.ok{background:var(--okbg);color:var(--ok);border:1px solid rgba(34,197,94,.25)}
.qrbox{background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:14px;text-align:center;margin-bottom:14px}
.qrbox .qrimg{display:block;margin:0 auto 12px;border-radius:8px;background:#fff;padding:8px}
.qrbox .secret{font-family:ui-monospace,monospace;font-size:14px;letter-spacing:1px;color:var(--txt);word-break:break-all}
.steps{display:flex;align-items:center;gap:8px;margin-bottom:22px;font-size:12px;color:var(--txt3)}
.steps .s{display:flex;align-items:center;gap:7px}
.steps .n{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;background:var(--bg3);color:var(--txt3);border:1px solid var(--line2)}
.steps .s.on .n{background:var(--acc);color:#fff;border-color:var(--acc)}
.steps .bar{flex:1;height:1px;background:var(--line2)}
.backlink{display:inline-flex;align-items:center;gap:6px;color:var(--txt3);font-size:12.5px;cursor:pointer;margin-top:16px}
.backlink:hover{color:var(--txt)}
.backlink svg{width:14px;height:14px;flex:0 0 14px}
.bcodes{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:8px 0 12px}
.bcode{background:var(--bg);border:1px solid var(--line2);border-radius:8px;padding:9px 8px;text-align:center;font-family:ui-monospace,monospace;font-size:14px;letter-spacing:1px;color:var(--txt);user-select:all}
.brow{display:flex;gap:8px}
.themebtn{position:fixed;top:16px;right:16px;cursor:pointer;color:var(--txt3);width:18px;height:18px;z-index:5}
/* im Portal gibt es den Theme-Toggle in der Sidebar-Fußzeile → fixen ausblenden (überlappt sonst "Neue Instanz") */
body:has(.app) .themebtn{display:none}

/* ---------- responsive ---------- */
.hamb{display:none;width:38px;height:38px;border:1px solid var(--line);border-radius:8px;background:var(--bg2);
  place-items:center;cursor:pointer;color:var(--txt2);flex:0 0 38px}
.hamb svg{width:18px;height:18px}
.sidebackdrop{display:none;position:fixed;inset:0;background:rgba(4,7,12,.55);z-index:55}
.tscroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

@media(max-width:900px){
  .side{position:fixed;top:0;left:0;transform:translateX(-100%);transition:transform .2s ease;z-index:60;box-shadow:var(--shadow)}
  .side.open{transform:none}
  .sidebackdrop.show{display:block}
  .hamb{display:grid}
  .stats{grid-template-columns:1fr 1fr}
  .grid2{grid-template-columns:1fr}
  .brandpane{display:none}
  .shell{grid-template-columns:1fr}
  .top{padding:12px 16px}
  .content{padding:16px}
  .authpane{padding:30px 22px;min-height:auto}
  .loginwrap{padding:16px}
  .dhead{flex-wrap:wrap}
}
@media(max-width:560px){
  .stats{grid-template-columns:1fr 1fr;gap:10px}
  .stat{padding:12px 13px}
  .stat .v{font-size:22px}
  .top h1{font-size:16px}
  .top .btn.pri{padding:8px 11px}
  thead th.col-proto,tbody td.col-proto,thead th.col-created,tbody td.col-created{display:none}
  tbody td{padding:10px 12px}
  thead th{padding:9px 12px}
  .modal .mb{padding:16px 16px}
  .otp{gap:6px}
  .otp input{width:40px;height:50px;font-size:19px}
  .row2{grid-template-columns:1fr}
}
