/* SudoRadius NOC — network operations dashboard.
   Aesthetic: near-black operations console, signal-green/amber on graphite,
   IBM Plex Mono data type, grid texture + scanline. */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600&display=swap');

:root{
  --bg:#07090a; --bg-1:#0b0f10; --bg-2:#0f1517; --panel:#0c1112;
  --line:#121a1c; --line-2:#1b2629;
  --text:#eef4f2; --muted:#a6b8b2; --dim:#56655f;
  --signal:#2bf5a0; --signal-dim:#157a55;
  --amber:#ffb13b; --cyan:#3ad9ff; --egress:#ff6486; --violet:#9d8cff;
  --grid:rgba(43,245,160,.018);
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --sans:'IBM Plex Sans',system-ui,sans-serif;
  --r:3px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(43,245,160,.06), transparent 60%),
    radial-gradient(900px 500px at 0% 110%, rgba(255,177,59,.04), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text); font-family:var(--sans); font-size:13px; line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
/* grid + scanline atmosphere */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:44px 44px;mask-image:radial-gradient(120% 120% at 50% 0%,#000 40%,transparent 100%);}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.35;
  background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(0,0,0,.18) 2px 3px);mix-blend-mode:overlay}

a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono)}
.muted{color:var(--muted)}

/* ---- shell ---- */
.app{position:relative;z-index:1;display:grid;grid-template-columns:212px 1fr;grid-template-rows:54px 1fr;height:100vh}
header{grid-column:1/3;display:flex;align-items:center;gap:18px;padding:0 18px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent)}
.brand{display:flex;align-items:baseline;gap:10px;font-family:var(--mono);font-weight:700;letter-spacing:.5px}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal);align-self:center;animation:pulse 2.4s infinite}
.brand b{color:var(--signal)}
.brand span{color:var(--muted);font-weight:500;font-size:11px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.spacer{flex:1}
.clock{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.5px}
.livechip{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;color:var(--signal);
  border:1px solid var(--line-2);border-radius:999px;padding:4px 10px}
.livechip .bz{width:6px;height:6px;border-radius:50%;background:var(--signal);box-shadow:0 0 8px var(--signal);animation:pulse 1.4s infinite}

/* tenant switcher */
.tenant{position:relative}
.tenant>button{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--line-2);
  color:var(--text);font-family:var(--mono);font-size:12px;padding:6px 12px;border-radius:var(--r);cursor:pointer}
.tenant>button:hover{border-color:var(--signal)}
.tenant .tag{width:8px;height:8px;border-radius:2px;background:var(--accent,var(--signal))}
.tenant .car{color:var(--muted)}
.tenant ul{position:absolute;top:110%;right:0;min-width:220px;background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:var(--r);padding:5px;z-index:50;display:none;box-shadow:0 16px 40px rgba(0,0,0,.6)}
.tenant.open ul{display:block}
.tenant li{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r);cursor:pointer;font-family:var(--mono);font-size:12px}
.tenant li:hover{background:var(--bg-1)}
.tenant li small{margin-left:auto;color:var(--muted)}

/* nav rail */
nav{border-right:1px solid var(--line);padding:14px 10px;display:flex;flex-direction:column;gap:3px}
nav .nlabel{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--dim);padding:8px 10px 4px}
nav a{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r);color:var(--muted);
  font-family:var(--mono);font-size:12.5px;cursor:pointer;border:1px solid transparent}
nav a .ic{width:7px;height:7px;border-radius:50%;background:var(--dim)}
nav a:hover{color:var(--text);background:var(--bg-1)}
nav a.active{color:var(--signal);background:linear-gradient(90deg,rgba(43,245,160,.08),transparent);border-color:var(--line-2)}
nav a.active .ic{background:var(--signal);box-shadow:0 0 8px var(--signal)}
nav .foot{margin-top:auto;font-family:var(--mono);font-size:10px;color:var(--dim);padding:10px;line-height:1.6}

/* main */
main{overflow-y:auto;padding:20px 22px 60px}
.view{display:none;animation:fade .4s ease both}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.vhead{display:flex;align-items:flex-end;gap:14px;margin-bottom:18px}
.vhead h1{font-family:var(--mono);font-size:18px;font-weight:600;letter-spacing:.5px;margin:0}
.vhead .crumb{font-family:var(--mono);font-size:11px;color:var(--muted)}
.vhead .crumb b{color:var(--accent,var(--signal))}

/* kpi grid */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px}
.kpi{position:relative;background:linear-gradient(180deg,var(--bg-1),var(--panel));border:1px solid var(--line);
  border-radius:var(--r);padding:14px 14px 12px;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent,var(--signal));opacity:.7}
.kpi .k{font-family:var(--mono);font-size:10px;letter-spacing:1px;color:var(--muted);text-transform:uppercase}
.kpi .v{font-family:var(--mono);font-size:25px;font-weight:600;margin-top:8px;letter-spacing:-.5px}
.kpi .v small{font-size:12px;color:var(--muted);font-weight:400}
.kpi .sub{font-family:var(--mono);font-size:10.5px;color:var(--dim);margin-top:3px}

/* panels */
.grid{display:grid;gap:12px}
/* let grid tracks honour fr ratios instead of inflating to canvas min-width */
.grid>*{min-width:0;min-height:0}
.cols-2{grid-template-columns:1fr 1fr}
.cols-3{grid-template-columns:1.6fr 1fr 1fr}
.panel{background:linear-gradient(180deg,var(--bg-1),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:14px}
.panel h3{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin:0 0 12px;
  display:flex;align-items:center;gap:8px}
.panel h3 .b{width:6px;height:6px;background:var(--accent,var(--signal));border-radius:1px}
.panel h3 .r{margin-left:auto;color:var(--dim);font-size:10px;letter-spacing:.5px}
.chartwrap{position:relative;height:230px}
.chartwrap.sm{height:200px}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:11.5px}
.tbl th{text-align:left;color:var(--dim);font-weight:500;text-transform:uppercase;letter-spacing:.8px;font-size:9.5px;
  padding:8px 10px;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:var(--panel)}
.tbl td{padding:8px 10px;border-bottom:1px solid var(--line);color:var(--text);white-space:nowrap}
.tbl tr:hover td{background:rgba(43,245,160,.03)}
.tbl .num{text-align:right}
.tbl .u{color:var(--text)}
.tbl tr.click{cursor:pointer}
.tbl th.sortable{cursor:pointer;user-select:none}.tbl th.sortable:hover{color:var(--text)}
.tbl th.sortable .ar{color:var(--signal);margin-left:3px}
.searchbox{font-family:var(--mono);font-size:11.5px;background:var(--bg-2);border:1px solid var(--line-2);
  color:var(--text);border-radius:5px;padding:7px 10px;width:200px;max-width:46vw}
.searchbox:focus{outline:none;border-color:var(--signal)}
/* compact in-cell usage bar (subscribers table) */
.mbar{height:5px;max-width:200px;background:var(--bg-2);border:1px solid var(--line);border-radius:4px;overflow:hidden;margin-bottom:3px}
.mbar i{display:block;height:100%;background:var(--signal)}
.mbar.warn i{background:var(--amber)}
.tscroll{max-height:62vh;overflow:auto;border:1px solid var(--line);border-radius:var(--r)}

/* pills + bars */
.pill{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:999px;border:1px solid;letter-spacing:.5px;text-transform:uppercase}
.pill.live{color:var(--signal);border-color:rgba(43,245,160,.4);background:rgba(43,245,160,.08)}
.pill.active{color:var(--signal);border-color:rgba(43,245,160,.35)}
.pill.suspended{color:var(--amber);border-color:rgba(255,177,59,.4);background:rgba(255,177,59,.08)}
.pill.terminated,.pill.expired{color:var(--egress);border-color:rgba(255,100,134,.4)}
.pill.pending{color:var(--violet);border-color:rgba(157,140,255,.4)}
.bar{height:6px;border-radius:3px;background:var(--bg-2);overflow:hidden;min-width:90px}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--signal),var(--cyan))}
.bar.warn i{background:linear-gradient(90deg,var(--amber),var(--egress))}

.btn{font-family:var(--mono);font-size:10.5px;color:var(--egress);background:transparent;border:1px solid rgba(255,100,134,.35);
  padding:3px 9px;border-radius:var(--r);cursor:pointer;text-transform:uppercase;letter-spacing:.5px}
.btn:hover{background:rgba(255,100,134,.12)}
.btn[disabled]{opacity:.35;cursor:default}

/* subscriber cards */
.subs{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.sub{background:linear-gradient(180deg,var(--bg-1),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:14px}
.sub .top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.sub .av{width:30px;height:30px;border-radius:var(--r);display:grid;place-items:center;font-family:var(--mono);font-weight:700;
  background:var(--bg-2);border:1px solid var(--line-2);color:var(--accent,var(--signal))}
.sub .nm{font-family:var(--mono);font-weight:600}
.sub .meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:8px}
.sub .meta b{color:var(--text);font-weight:600}

/* products */
.prods{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.prod{background:linear-gradient(180deg,var(--bg-1),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:16px;position:relative}
.prod h4{font-family:var(--mono);margin:0 0 4px;font-size:14px}
.prod .cap{font-family:var(--mono);font-size:22px;color:var(--signal);margin:12px 0 2px}
.prod .cap.unl{color:var(--cyan)}
.prod .ra{font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-top:10px;border-top:1px dashed var(--line-2);padding-top:8px}

/* add buttons + interactive cards */
.vhead .spacer{flex:1}
.addbtn{font-family:var(--mono);font-size:11.5px;color:var(--bg);background:var(--accent,var(--signal));border:none;
  padding:8px 14px;border-radius:var(--r);cursor:pointer;font-weight:600;letter-spacing:.3px}
.addbtn:hover{filter:brightness(1.12);box-shadow:0 0 14px rgba(43,245,160,.3)}
.sub.click{cursor:pointer;transition:border-color .15s,transform .15s}
.sub.click:hover{border-color:var(--accent,var(--signal));transform:translateY(-2px)}
.sub .burstchip{font-family:var(--mono);font-size:9px;color:var(--amber);border:1px solid rgba(255,177,59,.4);
  border-radius:999px;padding:1px 7px;margin-left:6px;animation:pulse 1.8s infinite}

/* modal */
.modal-overlay{position:fixed;inset:0;z-index:10001;background:rgba(2,5,6,.72);backdrop-filter:blur(3px);
  display:flex;align-items:flex-start;justify-content:center;padding:6vh 16px;overflow-y:auto;animation:fade .2s both}
.modal{width:100%;max-width:520px;background:linear-gradient(180deg,var(--bg-1),var(--panel));border:1px solid var(--line-2);
  border-radius:5px;box-shadow:0 30px 80px rgba(0,0,0,.7);animation:pop .22s cubic-bezier(.2,.9,.3,1.2) both}
.modal.lg{max-width:600px}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
.modal .mh{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line)}
.modal .mh h2{font-family:var(--mono);font-size:14px;margin:0;letter-spacing:.4px}
.modal .mh .x{margin-left:auto;color:var(--muted);cursor:pointer;font-family:var(--mono);font-size:16px;line-height:1}
.modal .mh .x:hover{color:var(--egress)}
.modal .mb{padding:16px 18px;max-height:62vh;overflow-y:auto}
.modal .mf{display:flex;gap:10px;justify-content:flex-end;padding:13px 18px;border-top:1px solid var(--line)}
.field{margin-bottom:13px}
.field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;background:var(--bg-2);border:1px solid var(--line-2);color:var(--text);
  font-family:var(--mono);font-size:12.5px;padding:9px 11px;border-radius:var(--r);outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent,var(--signal))}
.field .hint{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:4px}
.field.row{display:flex;gap:10px}.field.row>div{flex:1}
.checks{display:flex;flex-wrap:wrap;gap:8px}
.checks label{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11.5px;color:var(--text);
  background:var(--bg-2);border:1px solid var(--line-2);padding:5px 10px;border-radius:var(--r);cursor:pointer;text-transform:none;letter-spacing:0;margin:0}
.checks input{width:auto}
.mbtn{font-family:var(--mono);font-size:12px;padding:8px 16px;border-radius:var(--r);cursor:pointer;border:1px solid var(--line-2);background:var(--bg-2);color:var(--text)}
.mbtn:hover{border-color:var(--muted)}
.mbtn.go{background:var(--accent,var(--signal));color:var(--bg);border:none;font-weight:600}
.mbtn.go:hover{filter:brightness(1.1)}
.mbtn.danger{color:var(--egress);border-color:rgba(255,100,134,.4)}
.mbtn.danger:hover{background:rgba(255,100,134,.12)}

/* manage drawer sections */
.msec{border:1px solid var(--line);border-radius:var(--r);padding:13px;margin-bottom:12px;background:var(--bg-2)}
.msec h4{font-family:var(--mono);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin:0 0 10px;display:flex;align-items:center;gap:8px}
.msec h4 .b{width:5px;height:5px;background:var(--accent,var(--signal))}
.statline{display:flex;gap:18px;font-family:var(--mono);font-size:12px;flex-wrap:wrap}
.statline div span{color:var(--muted);font-size:10px;display:block;text-transform:uppercase;letter-spacing:.5px}
.statline div b{font-size:15px}
.acts{display:flex;flex-wrap:wrap;gap:8px}
.alloc-list{font-family:var(--mono);font-size:11px;max-height:130px;overflow:auto}
.alloc-list .a{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--line)}
.alloc-list .a .exp{color:var(--dim)}
.alloc-list .a.dead{opacity:.4;text-decoration:line-through}
.certbox{font-family:var(--mono);font-size:10px;background:#05080a;border:1px solid var(--line-2);border-radius:var(--r);
  padding:10px;white-space:pre-wrap;word-break:break-all;max-height:160px;overflow:auto;color:var(--signal)}
.codeblk{font-family:var(--mono);font-size:11px;line-height:1.55;background:#05080a;border:1px solid var(--line-2);
  border-radius:var(--r);padding:11px 12px;margin:0;white-space:pre-wrap;word-break:break-word;
  max-height:300px;overflow:auto;color:var(--text)}
.msec .hint{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:6px}
.msec .hint code{color:var(--muted)}

/* Overview crumb selectors (timespan + refresh) */
.crumbsel{display:inline-flex;align-items:center;gap:5px;color:var(--dim);
  text-transform:uppercase;letter-spacing:.5px;font-size:9.5px;margin:0 4px}
.crumbsel select{font-family:var(--mono);font-size:11px;color:var(--text);
  background:var(--bg-2);border:1px solid var(--line);border-radius:4px;
  padding:2px 6px;cursor:pointer;outline:none;text-transform:none;letter-spacing:0}
.crumbsel select:hover{border-color:var(--signal)}

/* live auto-refresh badge (Overview crumb) */
.livebadge{display:inline-flex;align-items:center;gap:5px;color:var(--signal);
  letter-spacing:.5px;font-size:10px}
.livebadge .ld{width:6px;height:6px;border-radius:50%;background:var(--signal);
  box-shadow:0 0 0 0 var(--signal);animation:lpulse 2s infinite}
.livebadge .ld.on{animation:lflash .6s ease-out}
@keyframes lpulse{0%{box-shadow:0 0 0 0 rgba(43,245,160,.5)}70%{box-shadow:0 0 0 6px rgba(43,245,160,0)}100%{box-shadow:0 0 0 0 rgba(43,245,160,0)}}
@keyframes lflash{0%{transform:scale(2.4);background:#eafff5}100%{transform:scale(1);background:var(--signal)}}

/* api docs */
.apidoc-head{background:linear-gradient(180deg,var(--bg-1),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;margin-bottom:14px;font-family:var(--mono);font-size:12px;line-height:1.7}
.apidoc-head code{color:var(--signal);background:var(--bg-2);padding:1px 6px;border-radius:3px}
.apidoc-head .muted{color:var(--muted)}
.epgroup{margin-bottom:14px}
.epgroup>h3{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin:0 0 8px;display:flex;align-items:center;gap:8px}
.epgroup>h3 .b{width:6px;height:6px;background:var(--accent,var(--signal))}
.ep{display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:baseline;padding:9px 12px;border:1px solid var(--line);border-radius:var(--r);margin-bottom:6px;background:var(--bg-1)}
.ep:hover{border-color:var(--line-2)}
.ep .m{font-family:var(--mono);font-size:10px;font-weight:700;text-align:center;padding:3px 0;border-radius:3px;letter-spacing:.5px}
.m.GET{color:var(--cyan);border:1px solid rgba(58,217,255,.4)}
.m.POST{color:var(--signal);border:1px solid rgba(43,245,160,.4)}
.m.DELETE{color:var(--egress);border:1px solid rgba(255,100,134,.4)}
.ep .p{font-family:var(--mono);font-size:12.5px;color:var(--text)}
.ep .p .d{display:block;color:var(--muted);font-size:11px;margin-top:3px;font-family:var(--sans)}
.ep .p .bd{display:block;color:var(--dim);font-size:10.5px;margin-top:3px;font-family:var(--mono)}
.ep .cp{font-family:var(--mono);font-size:10px;color:var(--muted);border:1px solid var(--line-2);background:var(--bg-2);padding:3px 9px;border-radius:var(--r);cursor:pointer;white-space:nowrap}
.ep .cp:hover{color:var(--signal);border-color:var(--signal)}

/* toast */
#toast{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:8px}
.toast{font-family:var(--mono);font-size:12px;background:var(--bg-2);border:1px solid var(--line-2);border-left:3px solid var(--signal);
  padding:10px 14px;border-radius:var(--r);box-shadow:0 12px 30px rgba(0,0,0,.5);animation:slidein .3s ease both;min-width:240px}
.toast.err{border-left-color:var(--egress)}
@keyframes slidein{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.loading{font-family:var(--mono);color:var(--muted);font-size:12px;padding:20px;text-align:center}
/* pager */
.pager{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:10px 2px;font-family:var(--mono);font-size:11px}
.pager .pinfo{color:var(--muted);letter-spacing:.5px}
.pager .pbtn{font-family:var(--mono);font-size:11px;color:var(--text);background:var(--bg-2);border:1px solid var(--line-2);padding:5px 12px;border-radius:var(--r);cursor:pointer}
.pager .pbtn:hover:not([disabled]){border-color:var(--accent,var(--signal));color:var(--accent,var(--signal))}
.pager .pbtn[disabled]{opacity:.3;cursor:default}
.spark{font-family:var(--mono);color:var(--dim);letter-spacing:-1px}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:9px}
::-webkit-scrollbar-track{background:transparent}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.cols-3,.cols-2,.subs,.prods{grid-template-columns:1fr}}

/* hamburger (mobile nav toggle) — hidden on desktop */
.hamburger{display:none;background:transparent;border:1px solid var(--line-2);color:var(--text);
  border-radius:6px;width:34px;height:30px;font-size:15px;line-height:1;cursor:pointer;flex:0 0 auto}
.nav-backdrop{display:none}

/* ---------- mobile ---------- */
@media(max-width:820px){
  .hamburger{display:inline-flex;align-items:center;justify-content:center}
  /* single-column shell; nav becomes an off-canvas drawer */
  .app{grid-template-columns:1fr;grid-template-rows:54px 1fr}
  header{grid-column:1/2;gap:10px;padding:0 12px}
  .brand .brand-sub,.clock{display:none}
  #whoami{display:none}
  header .spacer{flex:1}
  nav{position:fixed;top:54px;left:0;bottom:0;width:236px;z-index:60;background:var(--bg);
      border-right:1px solid var(--line-2);overflow-y:auto;
      transform:translateX(-100%);transition:transform .22s ease;box-shadow:6px 0 24px rgba(0,0,0,.4)}
  .app.navopen nav{transform:translateX(0)}
  .app.navopen .nav-backdrop{display:block;position:fixed;inset:54px 0 0 0;z-index:55;background:rgba(2,5,6,.55)}
  main{padding:14px 12px}
  .kpis{grid-template-columns:1fr 1fr;gap:8px}
  .vhead{flex-wrap:wrap;align-items:flex-start;gap:6px}
  .vhead h1{font-size:16px}
  .tscroll{max-height:none}
  .tbl td,.tbl th{padding:7px 8px}
  .modal{max-width:94vw}
  .modal .mb{max-height:70vh}
  .tenant #tenantName{max-width:84px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}
@media(max-width:480px){
  .kpis{grid-template-columns:1fr}
  .livechip{display:none}
  .brand span:nth-child(2){font-size:13px}
}
