@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@400;700;900&family=Rajdhani:wght@300;400;600&display=swap');
:root{--bg:#020408;--bg2:#040c14;--bg3:#061220;--panel:rgba(6,18,30,.95);--border:rgba(0,255,136,.18);--green:#00ff88;--cyan:#00e5ff;--red:#ff3b5c;--orange:#ff8c00;--yellow:#ffe600;--text:#c8e6d4;--text2:#7aad8e;--mono:'Share Tech Mono',monospace;--disp:'Orbitron',sans-serif;--ui:'Rajdhani',sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:var(--ui);min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(0,255,136,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,136,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}
body::after{content:'';position:fixed;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.08) 2px,rgba(0,0,0,.08) 4px);pointer-events:none;z-index:1}
header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:rgba(2,4,8,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(12px)}
.logo{font-family:var(--disp);font-size:14px;font-weight:900;color:var(--green);letter-spacing:4px;text-shadow:0 0 20px var(--green)}
.logo span{color:var(--cyan)}
.hdr-status{display:flex;gap:24px;align-items:center;font-family:var(--mono);font-size:11px;color:var(--text2)}
.dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s infinite;margin-right:5px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hdr-time{font-family:var(--mono);font-size:13px;color:var(--cyan)}
.ham{display:none;background:none;border:none;color:var(--green);font-size:22px;cursor:pointer;padding:4px 8px;line-height:1;margin-left:auto;z-index:101}
nav{position:fixed;top:56px;left:0;bottom:0;width:200px;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;overflow-x:hidden;z-index:99;display:flex;flex-direction:column;padding:8px 0 24px}
.nav-group{border-bottom:1px solid rgba(0,255,136,.06)}
.nav-group-head{display:flex;align-items:center;gap:6px;padding:10px 14px;font-family:var(--disp);font-size:9px;letter-spacing:2px;color:var(--text2);cursor:pointer;user-select:none;transition:background .15s;flex-shrink:0}
.nav-group-head:hover{background:rgba(0,255,136,.04)}
.nav-group-arrow{font-size:7px;transition:transform .2s;color:var(--border);flex-shrink:0}
.nav-group.collapsed .nav-group-arrow{transform:rotate(-90deg)}
.nav-group.collapsed .nav-group-body{display:none}
.nav-group-body{display:flex;flex-direction:column}
.tab{padding:7px 14px 7px 22px;font-family:var(--disp);font-size:11px;letter-spacing:0.5px;font-weight:600;color:var(--text2);cursor:pointer;background:none;border:none;border-left:2px solid transparent;transition:all .2s;text-align:left;white-space:nowrap}
.tab:hover{color:var(--green);background:rgba(0,255,136,.04)}
.tab.active{color:var(--green);border-left-color:var(--green);background:rgba(0,255,136,.08);text-shadow:0 0 10px var(--green)}
.badge{display:inline-block;margin-left:6px;background:var(--red);color:#fff;font-size:9px;border-radius:8px;padding:1px 5px;font-family:var(--mono)}
main{margin-left:200px;padding:20px 24px;position:relative;z-index:2}
.page{display:none}.page.active{display:block}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:4px;overflow:hidden;position:relative}
.panel::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent);opacity:.5}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:rgba(0,255,136,.04)}
.panel-title{font-family:var(--disp);font-size:10px;letter-spacing:3px;color:var(--green);display:flex;align-items:center;gap:8px}
.panel-title::before{content:'';width:3px;height:12px;background:var(--green);box-shadow:0 0 6px var(--green)}
.panel-body{padding:16px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.g12{display:grid;grid-template-columns:1fr 2fr;gap:12px}
@media(max-width:1024px){.g4{grid-template-columns:repeat(2,1fr)}.g12{grid-template-columns:1fr 1fr}}
.kpi{background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:14px 16px;position:relative;overflow:hidden}
.kpi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--ac,var(--green));box-shadow:0 0 8px var(--ac,var(--green))}
.kpi-label{font-size:9px;letter-spacing:3px;color:var(--text2);font-family:var(--disp);margin-bottom:6px}
.kpi-val{font-family:var(--mono);font-size:28px;color:var(--ac,var(--green))}
.kpi-sub{font-size:11px;color:var(--text2);margin-top:4px;font-family:var(--mono)}
.kpi-trend{position:absolute;top:14px;right:14px;font-size:11px;font-family:var(--mono)}
.tup{color:var(--green)}.tdn{color:var(--red)}
canvas{display:block;width:100%}
.dt{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12px}
.dt th{text-align:left;padding:8px 12px;font-family:var(--disp);font-size:9px;letter-spacing:2px;color:var(--text2);border-bottom:1px solid var(--border);background:rgba(0,255,136,.04)}
.dt td{padding:8px 12px;border-bottom:1px solid rgba(0,255,136,.06)}
.dt tr:hover td{background:rgba(0,255,136,.04)}
.ok{color:var(--green);background:rgba(0,255,136,.1);padding:2px 8px;border-radius:2px;font-size:10px}
.warn{color:var(--orange);background:rgba(255,140,0,.1);padding:2px 8px;border-radius:2px;font-size:10px}
.err{color:var(--red);background:rgba(255,59,92,.1);padding:2px 8px;border-radius:2px;font-size:10px}
.info{color:var(--cyan);background:rgba(0,229,255,.1);padding:2px 8px;border-radius:2px;font-size:10px}
.inp{background:rgba(0,255,136,.05);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:13px;padding:8px 12px;border-radius:3px;outline:none;transition:border-color .2s}
.inp:focus{border-color:var(--green);box-shadow:0 0 8px rgba(0,255,136,.2)}
.inp::placeholder{color:var(--text2)}
.inp option{background:var(--bg3);color:var(--text)}
.btn{background:transparent;border:1px solid var(--green);color:var(--green);font-family:var(--disp);font-size:10px;letter-spacing:2px;padding:8px 18px;cursor:pointer;border-radius:2px;transition:all .2s}
.btn:hover{background:rgba(0,255,136,.1);box-shadow:0 0 12px rgba(0,255,136,.3)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-r{border-color:var(--red);color:var(--red)}.btn-r:hover{background:rgba(255,59,92,.1)}
.btn-c{border-color:var(--cyan);color:var(--cyan)}.btn-c:hover{background:rgba(0,229,255,.1)}
.irow{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.log{background:rgba(0,0,0,.5);border:1px solid var(--border);border-radius:3px;padding:12px;height:180px;overflow-y:auto;font-family:var(--mono);font-size:11px;line-height:1.7}
.log::-webkit-scrollbar{width:4px}.log::-webkit-scrollbar-thumb{background:var(--border)}
.lok{color:var(--green)}.lwarn{color:var(--orange)}.lerr{color:var(--red)}.linfo{color:var(--cyan)}
.prog{background:rgba(0,255,136,.1);height:4px;border-radius:2px;overflow:hidden}
.prog-f{height:100%;border-radius:2px;transition:width .3s}
.sbar{height:3px;background:rgba(0,255,136,.1);border-radius:2px;overflow:hidden;margin:8px 0}
.sbar-f{height:100%;background:linear-gradient(90deg,var(--green),var(--cyan));box-shadow:0 0 8px var(--green);transition:width .3s linear}
.ip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px}
.ipc{border:1px solid var(--border);border-radius:3px;padding:7px 9px;font-family:var(--mono);font-size:11px;cursor:pointer;transition:all .2s;position:relative}
.ipc:hover{border-color:var(--green);background:rgba(0,255,136,.05)}
.ipc.used{border-color:rgba(0,229,255,.4)}.ipc.reserved{border-color:rgba(255,140,0,.4)}.ipc.conflict{border-color:var(--red);animation:flicker .5s infinite}
.ipc .ipa{color:var(--cyan);font-size:11px}.ipc .iph{color:var(--text2);font-size:10px;margin-top:2px}
.ipc .ipd{position:absolute;top:5px;right:5px;width:5px;height:5px;border-radius:50%}
@keyframes flicker{0%,100%{opacity:1}50%{opacity:.5}}
.svc-group{border:1px solid var(--border);border-radius:3px;margin-bottom:8px;overflow:hidden}
.svc-group-head{display:flex;align-items:center;gap:6px;padding:8px 12px;background:rgba(0,255,136,.04);border-bottom:1px solid var(--border);cursor:pointer;user-select:none;transition:background .15s}
.svc-group-head:hover{background:rgba(0,255,136,.08)}
.svc-group-toggle{font-size:10px;color:var(--text2);transition:transform .2s;flex-shrink:0}
.svc-group-collapsed .svc-group-toggle{transform:rotate(-90deg)}
.svc-group-collapsed .svc-group-body{display:none}
.svc-group-body{padding:2px 12px}
.svc-group-body .svc-row:last-child{border-bottom:none}
.svc-row{display:flex;gap:8px;align-items:center;padding:6px 0;border-bottom:1px solid rgba(0,255,136,.06);font-size:12px;flex-wrap:wrap}
.svc-row:last-child{border-bottom:none}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mb12{margin-bottom:12px}
#toast{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast-item{background:var(--bg3);border:1px solid var(--border);padding:10px 16px;border-radius:3px;font-family:var(--mono);font-size:12px;animation:fadeIn .3s;max-width:320px}
.toast-item.critical{border-color:var(--red);color:var(--red)}
.toast-item.warning{border-color:var(--orange);color:var(--orange)}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── LOGIN FULLSCREEN ────────────────────────────────── */
#loginPage{position:fixed;inset:0;z-index:999999;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:hidden}
#loginPage.hidden{display:none}
.login-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(0,255,136,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,136,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none}
.login-bg::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.1) 2px,rgba(0,0,0,.1) 4px);pointer-events:none}
.login-box{position:relative;width:400px;padding:0}
.login-terminal{padding:12px 16px;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:4px 4px 0 0;font-family:var(--mono);font-size:11px;line-height:1.8;border-bottom:none}
.login-line{opacity:0;animation:typeIn .4s forwards;color:var(--text2)}
@keyframes typeIn{to{opacity:1}}
.login-title{font-family:var(--disp);font-size:22px;font-weight:900;text-align:center;padding:24px 24px 4px;color:var(--green);text-shadow:0 0 30px var(--green),0 0 60px rgba(0,255,136,.3);letter-spacing:6px;background:var(--panel);border:1px solid var(--border);border-bottom:none}
.login-title span{color:var(--cyan);text-shadow:0 0 30px var(--cyan)}
.login-sub{text-align:center;font-size:11px;color:var(--text2);letter-spacing:6px;font-family:var(--mono);padding:0 24px 20px;background:var(--panel);border-left:1px solid var(--border);border-right:1px solid var(--border)}
.login-form{background:var(--panel);padding:0 24px 20px;border-left:1px solid var(--border);border-right:1px solid var(--border)}
.login-field{margin-bottom:14px}
.login-field label{display:block;font-family:var(--disp);font-size:9px;letter-spacing:3px;color:var(--text2);margin-bottom:6px}
.login-field .inp{width:100%;padding:12px 14px;font-size:14px;background:rgba(0,0,0,.4);border-color:rgba(0,255,136,.25)}
.login-field .inp:focus{border-color:var(--green);box-shadow:0 0 12px rgba(0,255,136,.15)}
.login-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 18px;font-family:var(--disp);font-size:11px;letter-spacing:3px;background:transparent;border:1px solid var(--green);color:var(--green);cursor:pointer;transition:all .3s;border-radius:2px;margin-top:4px}
.login-btn:hover{background:rgba(0,255,136,.1);box-shadow:0 0 20px rgba(0,255,136,.2),inset 0 0 20px rgba(0,255,136,.05)}
.login-btn:hover .login-arrow{transform:translateX(6px)}
.login-arrow{transition:transform .3s;font-size:16px}
.login-error{text-align:center;font-family:var(--mono);font-size:11px;color:var(--red);margin-top:10px;min-height:16px;opacity:0;transition:opacity .3s}
.login-error.show{opacity:1}
.login-hint{text-align:center;font-family:var(--mono);font-size:9px;color:var(--text2);margin-top:8px;opacity:.5}
.login-footer{border-top:1px solid var(--border);background:rgba(0,0,0,.3);text-align:center;padding:10px 16px;font-family:var(--mono);font-size:9px;color:var(--text2);border-radius:0 0 4px 4px;border:1px solid var(--border)}

/* ── GLANCES ──────────────────────────────────────────── */
.glances-host-tag{display:inline-flex;align-items:center;padding:3px 10px;border:1px solid var(--border);border-radius:12px;font-family:var(--mono);font-size:9px;cursor:pointer;transition:all .15s;background:rgba(0,0,0,.3);letter-spacing:.5px;color:var(--text2)}
.glances-host-tag:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(0,229,255,.08)}
.glances-net-row{display:flex;gap:6px;align-items:center;padding:6px 0;border-bottom:1px solid rgba(0,255,136,.06);flex-wrap:wrap}
.glances-net-name{font-family:var(--mono);font-size:10px;color:var(--cyan);min-width:80px}
.glances-net-bar{display:flex;align-items:center;gap:4px;flex:1;min-width:100px}
.glances-net-val{font-family:var(--mono);font-size:9px;min-width:70px;text-align:right}
.glances-sensor-row{display:flex;gap:8px;align-items:center;padding:4px 0;border-bottom:1px solid rgba(0,255,136,.06);font-size:11px}
.glances-sensor-label{font-family:var(--mono);font-size:10px;color:var(--text);flex:1}
.glances-sensor-val{font-family:var(--mono);font-size:11px;color:var(--cyan)}
.glances-docker-row{display:flex;gap:8px;align-items:center;padding:4px 0;border-bottom:1px solid rgba(0,255,136,.06);flex-wrap:wrap}
.glances-core-row{display:flex;gap:8px;align-items:center;padding:3px 0}

/* ── HEADER USER ─────────────────────────────────────── */
.hdr-user{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;color:var(--green)}
.hdr-user-icon{font-size:16px;opacity:.6}
.hdr-user-name{color:var(--cyan)}
.hdr-logout{background:rgba(255,59,92,.15);border:1px solid rgba(255,59,92,.4);color:var(--red);width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:9px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.hdr-logout:hover{background:rgba(255,59,92,.3);box-shadow:0 0 8px rgba(255,59,92,.3)}

#topoTooltip{position:absolute;background:rgba(4,6,10,.97);border:1px solid var(--border);border-radius:4px;padding:10px 14px;font-family:var(--mono);pointer-events:none;z-index:50;opacity:0;transition:opacity .15s;min-width:150px;backdrop-filter:blur(4px)}
#topoTooltip.show{opacity:1}
#topoTooltip::before{content:'';position:absolute;top:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent)}
.topo-ctx-item{padding:6px 8px;cursor:pointer;font-size:10px;color:var(--text);border-radius:2px;transition:all .15s;margin:2px 0;pointer-events:auto}
.topo-ctx-item:hover{background:rgba(0,255,136,.1);color:var(--green)}
.topo-panel{flex:1;min-height:calc(100vh - 280px)}
#topoCanvas{width:100%;height:calc(100vh - 280px);cursor:default}
.topo-sep{color:var(--border);font-size:14px;opacity:.4}
.topo-ftag{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border:1px solid var(--border);border-radius:12px;font-family:var(--mono);font-size:9px;cursor:pointer;transition:all .15s;user-select:none;background:rgba(0,0,0,.3);letter-spacing:.5px}
.topo-ftag:hover{border-color:var(--green);background:rgba(0,255,136,.08)}
.topo-ftag.on{opacity:1}
.topo-ftag.off{opacity:.25;border-color:rgba(0,255,136,.08)}
.topo-ftag .ftag-dot{width:6px;height:6px;border-radius:50%;display:inline-block}
#page-topology.fullscreen{position:fixed;inset:0;z-index:9999;background:var(--bg);padding:12px 16px;display:flex;flex-direction:column}
nav.fs-hidden{display:none}
main.fs-full{margin-left:0}
#page-topology.fullscreen .topo-panel{flex:1}
#page-topology.fullscreen .topo-panel canvas{height:100% !important}
#topoLegend{display:block !important}
#topoLegend .lg-row{display:flex;align-items:center;gap:6px;padding:2px 0}
#topoLegend .lg-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
#topoLegend .lg-lbl{color:var(--text2);white-space:nowrap}
.ck{display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:var(--text);font-family:var(--mono)}
.ck input[type=checkbox]{accent-color:var(--green)}

/* ── TABLET / RESPONSIVE ───────────────────────────── */
@media(max-width:1024px){
  header{padding:0 16px}
  .logo{font-size:12px;letter-spacing:2px}
  .hdr-status{gap:12px;font-size:10px}
  .hdr-time{font-size:11px}
  nav{width:180px}
  main{margin-left:180px;padding:14px 14px}
  .panel-head{padding:8px 12px}
  .panel-body{padding:12px}
  .panel-title{font-size:9px}
  .kpi{padding:10px 12px}
  .kpi-val{font-size:22px}
  .dt{font-size:11px}
  .dt th,.dt td{padding:6px 8px}
  .inp{padding:6px 10px;font-size:12px}
  .btn{padding:6px 14px;font-size:9px}
  .irow{gap:6px}
  .login-box{width:90%;max-width:400px}
  .login-title{font-size:18px;letter-spacing:4px;padding:20px 20px 4px}
  .login-form{padding:0 20px 16px}
  .ip-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}
  .svc-group-body{padding:2px 8px}
  .svc-row{gap:6px;font-size:11px}
  .topo-panel{min-height:50vh}
  #topoCanvas{height:50vh}
  #page-topology.fullscreen .topo-panel canvas{height:100%!important}
}
@media(max-width:768px){
  header{padding:0 10px;min-height:48px;flex-wrap:wrap;gap:4px}
  .logo{font-size:10px;letter-spacing:1px}
  .hdr-status{gap:8px;font-size:9px}
  .hdr-status .dot{width:4px;height:4px}
  .hdr-time{font-size:10px}
  nav{width:280px;top:48px;padding:8px 0 24px;transform:translateX(-100%);transition:transform .25s ease;border-right:1px solid var(--border);border-bottom:none;background:#020408;right:auto}
  nav.open{transform:translateX(0)}
  nav .tab{padding:8px 14px 8px 22px;font-size:11px}
  .ham{display:block}
  main{margin-left:0;padding:10px 10px}
  .g4,.g3,.g2,.g12{grid-template-columns:1fr}
  .panel-head{flex-wrap:wrap;gap:6px}
  .panel-title{font-size:8px;letter-spacing:2px}
  .kpi-val{font-size:18px}
  .panel-body{overflow-x:auto}
  .dt{font-size:10px;min-width:500px}
  .dt th,.dt td{padding:5px 6px;white-space:nowrap}
  .inp{padding:5px 8px;font-size:11px}
  .btn{padding:5px 12px;font-size:8px;letter-spacing:1px}
  .inp::placeholder{font-size:10px}
  .irow{gap:4px}
  .log{font-size:10px;padding:8px;height:140px}
  .ip-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:4px}
  .ipc{padding:5px 6px;font-size:10px}
  .ipc .ipa{font-size:10px}
  .ipc .iph{font-size:9px}
  .svc-row{gap:4px;font-size:11px}
  .svc-group-head{font-size:11px;padding:6px 8px}
  .svc-row .info,.svc-row .ok,.svc-row .warn,.svc-row .err{font-size:8px;padding:1px 6px}
  #toast{bottom:12px;right:12px;left:12px}
  .toast-item{font-size:11px;max-width:100%}
  .topo-panel{min-height:40vh}
  #topoCanvas{height:40vh}
  .login-title{font-size:16px;letter-spacing:3px;padding:16px 16px 4px}
  .login-box{width:95%}
  .login-terminal{font-size:10px;padding:8px 12px}
  .login-form{padding:0 16px 14px}
  .login-field .inp{padding:10px 12px;font-size:13px}
}
.cred-label{font-family:var(--disp);font-size:9px;letter-spacing:2px;color:var(--text2);white-space:nowrap}
.cred-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.cred-field{display:flex;flex-direction:column;gap:4px}
.cred-field .inp{width:100%}
.alerts-layout{display:grid;grid-template-columns:3fr 1fr;gap:12px}
@media(max-width:1024px){.cred-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.cred-grid{grid-template-columns:1fr}.alerts-layout{grid-template-columns:1fr}}
.dt-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0}
.dt-scroll table{min-width:max-content}
@media(max-width:480px){
  header{min-height:44px;padding:0 6px}
  .hdr-status{display:none}
  .hdr-time{font-size:9px}
  .logo{font-size:9px}
  nav{top:44px;width:280px;padding:8px 0 24px;transform:translateX(-100%);transition:transform .25s ease;border-right:1px solid var(--border);border-bottom:none;background:#020408;right:auto}
  nav.open{transform:translateX(0)}
  nav .tab{padding:8px 14px 8px 22px;font-size:10px}
  .ham{display:block}
  main{margin-left:0;padding:6px}
  .panel-body{padding:8px;overflow-x:auto}
  .panel-title{font-size:7px;letter-spacing:1px}
  .kpi{padding:8px 10px}
  .kpi-val{font-size:16px}
  .dt{font-size:9px;min-width:400px}
  .dt th,.dt td{padding:4px 5px;white-space:nowrap}
  .inp{padding:4px 6px;font-size:10px}
  .btn{padding:4px 10px;font-size:8px;letter-spacing:1px}
  .ip-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}
  .hdr-user{gap:4px;font-size:9px}
  .hdr-user-name{max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .login-title{font-size:14px}
  .login-field .inp{padding:8px 10px;font-size:12px}
  .login-btn{padding:10px 14px;font-size:10px}
  .topo-panel{min-height:30vh}
  #topoCanvas{height:30vh}
  .svg-group-head{font-size:10px;padding:5px 6px}
  .svc-row{gap:3px;font-size:10px}
  .irow{gap:4px}
  .log{height:120px;font-size:9px}
  .inp::placeholder{font-size:9px}
  .kpi-sub{font-size:9px}
  .ipc{padding:4px 5px;font-size:9px}
  .ipc .ipa{font-size:9px}
  .ipc .iph{font-size:8px}
  .btn{padding:4px 8px;font-size:7px}
}
