/* ===================================================================
   SINAR MEADOW — Power Management · Hi-fi dashboard
   Dark industrial / SCADA · data-dense · distinct utility colors
   =================================================================== */

/* ---------- theme tokens ---------- */
:root{
  /* surfaces (dark default) */
  --bg:#151310;
  --bg-grad:#1a1813;
  --panel:#201d18;
  --panel-2:#1b1814;
  --inset:#15130f;
  --line:#332f27;
  --line-soft:#272319;
  --hair:#221f18;

  /* text */
  --t1:#f1ede4;
  --t2:#b4ad9d;
  --t3:#827b6b;
  --t4:#5f594c;

  /* brand accent (TWEAKABLE — overridden inline) */
  --accent:#f0a92b;
  --accent-ink:#1a1408;

  /* utility colors (fixed) */
  --u-energy:#f2b23e;
  --u-water:#3e9bff;
  --u-steam:#2fbfa8;
  --u-coal:#e0673b;

  /* semantic */
  --good:#5fc98a;
  --warn:#e8a23d;
  --bad:#e2664f;

  /* type */
  --f-display:'Space Grotesk',sans-serif;
  --f-ui:'IBM Plex Sans',sans-serif;
  --f-mono:'IBM Plex Mono',monospace;

  /* density (TWEAKABLE) */
  --card-pad:14px;
  --grid-gap:12px;
  --radius:10px;
  --radius-sm:7px;

  color-scheme:dark;
}

/* light theme variant (tweak) */
:root[data-theme="light"]{
  --bg:#eef0f3;
  --bg-grad:#f6f7f9;
  --panel:#ffffff;
  --panel-2:#f7f8fa;
  --inset:#eef0f3;
  --line:#dde1e7;
  --line-soft:#e7eaef;
  --hair:#edf0f4;
  --t1:#1c2128;
  --t2:#4d5663;
  --t3:#79828f;
  --t4:#a3abb6;
  --accent-ink:#fff;
  color-scheme:light;
}

/* density variants (tweak) */
:root[data-density="comfortable"]{
  --card-pad:20px;
  --grid-gap:18px;
  --radius:13px;
  --radius-sm:9px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:
    radial-gradient(1200px 600px at 80% -10%, var(--bg-grad), transparent 60%),
    var(--bg);
  color:var(--t1);
  font-family:var(--f-ui);
  font-size:14px;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-0.005em;
  min-height:100vh;
}
::selection{background:color-mix(in srgb,var(--accent) 40%, transparent);}
button{font-family:inherit;color:inherit;cursor:pointer;}
::-webkit-scrollbar{width:11px;height:11px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px;border:3px solid var(--bg);}
::-webkit-scrollbar-thumb:hover{background:var(--t4);}

.app{max-width:1440px;margin:0 auto;}
.mono{font-family:var(--f-mono);}
.tnum{font-variant-numeric:tabular-nums;}

/* ===================================================================
   TOP BAR
   =================================================================== */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:18px;
  height:66px;padding:0 18px;
  background:color-mix(in srgb, var(--panel) 88%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:13px;}
.logo-plaque{display:flex;align-items:center;justify-content:center;background:#fff;
  border:1px solid var(--line);border-radius:10px;padding:7px 13px;height:50px;
  box-shadow:0 1px 0 rgba(0,0,0,.25);}
.logo-plaque img{height:38px;width:auto;display:block;}
.logo-plaque.right{padding:5px 10px;}
.logo-plaque.right img{height:44px;}
.brand-div{width:1px;height:26px;background:var(--line);}
.brand-sub{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--t3);}
.partner{display:flex;align-items:center;gap:9px;}
.partner .plab{font-family:var(--f-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--t4);text-align:right;line-height:1.3;}
.statuschip{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--t2);
  border:1px solid var(--line);border-radius:20px;padding:5px 11px;background:var(--panel-2);}
.led{width:8px;height:8px;border-radius:50%;background:var(--good);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--good) 22%, transparent);}
.led.pulse{animation:led 2.4s ease-in-out infinite;}
@keyframes led{0%,100%{opacity:1;}50%{opacity:.45;}}

.tb-spacer{flex:1;}

.segment{display:inline-flex;background:var(--inset);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px;}
.segment button{border:none;background:transparent;color:var(--t2);font-size:12.5px;font-weight:500;
  padding:6px 12px;border-radius:6px;letter-spacing:.01em;transition:.13s;}
.segment button.on{background:var(--panel);color:var(--t1);box-shadow:0 1px 0 rgba(0,0,0,.25), inset 0 0 0 1px var(--line);}
.segment button:hover:not(.on){color:var(--t1);}

.tb-btn{display:inline-flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);
  border-radius:9px;padding:7px 12px;font-size:12.5px;color:var(--t2);transition:.13s;}
.tb-btn:hover{border-color:var(--t4);color:var(--t1);}
.tb-btn svg{width:14px;height:14px;}
.tb-btn .caret{color:var(--t3);}

.clock{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1;}
.clock .t{font-family:var(--f-mono);font-size:13px;font-weight:500;letter-spacing:.02em;}
.clock .d{font-size:10.5px;color:var(--t3);font-family:var(--f-mono);letter-spacing:.04em;}
.refresh{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:var(--t3);}
.refresh .spin{width:13px;height:13px;color:var(--accent);animation:spin 5s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.avatar{width:32px;height:32px;border-radius:9px;flex:none;border:1px solid var(--line);
  background:linear-gradient(145deg,var(--panel-2),var(--inset));display:grid;place-items:center;
  font-family:var(--f-mono);font-size:12px;color:var(--t2);font-weight:500;}

/* ===================================================================
   LAYOUT
   =================================================================== */
.body{display:grid;grid-template-columns:1fr 414px;gap:var(--grid-gap);padding:var(--grid-gap) 18px 40px;align-items:start;}
.col{display:flex;flex-direction:column;gap:var(--grid-gap);min-width:0;}
.section-label{display:flex;align-items:center;gap:9px;font-family:var(--f-mono);font-size:10.5px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--t3);margin:2px 0 -2px 2px;}
.section-label::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent);}

.panel{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:var(--radius);position:relative;}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:13px var(--card-pad);border-bottom:1px solid var(--hair);flex-wrap:wrap;}
.panel-title{font-family:var(--f-display);font-weight:600;font-size:15px;letter-spacing:.01em;display:flex;align-items:center;gap:9px;}
.panel-title .tt{font-family:var(--f-mono);font-size:10px;color:var(--t3);letter-spacing:.1em;
  border:1px solid var(--line);border-radius:5px;padding:2px 6px;font-weight:400;}

/* ===================================================================
   KPI CARDS
   =================================================================== */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--grid-gap);}
.kpi{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--card-pad);position:relative;overflow:hidden;display:flex;flex-direction:column;gap:9px;}
.kpi::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--uc,var(--accent));opacity:.9;}
.kpi::after{content:"";position:absolute;top:-30px;right:-30px;width:90px;height:90px;border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb,var(--uc,var(--accent)) 16%, transparent), transparent 70%);}
.kpi .k-top{display:flex;align-items:center;justify-content:space-between;gap:8px;position:relative;}
.kpi .k-name{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--t2);font-weight:500;}
.kpi .k-ico{width:23px;height:23px;border-radius:7px;display:grid;place-items:center;flex:none;
  background:color-mix(in srgb,var(--uc,var(--accent)) 18%, var(--panel));
  border:1px solid color-mix(in srgb,var(--uc,var(--accent)) 35%, var(--line));color:var(--uc,var(--accent));}
.kpi .k-ico svg{width:13px;height:13px;}
.delta{display:inline-flex;align-items:center;gap:3px;font-family:var(--f-mono);font-size:11px;font-weight:500;
  padding:3px 7px;border-radius:6px;letter-spacing:.01em;}
.delta.up{color:var(--warn);background:color-mix(in srgb,var(--warn) 14%, transparent);}
.delta.down{color:var(--good);background:color-mix(in srgb,var(--good) 14%, transparent);}
.kpi .k-num{font-family:var(--f-display);font-weight:600;font-size:33px;line-height:1;letter-spacing:-.01em;position:relative;}
.kpi .k-num .u{font-family:var(--f-mono);font-size:12px;color:var(--t3);font-weight:400;margin-left:6px;letter-spacing:.02em;}
.kpi .k-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;position:relative;margin-top:auto;}
.kpi .k-spark{width:96px;height:30px;}
.kpi .k-cost{text-align:right;line-height:1.2;}
.kpi .k-cost .lab{font-size:9.5px;color:var(--t4);font-family:var(--f-mono);letter-spacing:.1em;text-transform:uppercase;}
.kpi .k-cost .val{font-family:var(--f-mono);font-size:12.5px;color:var(--t2);font-weight:500;}

/* ===================================================================
   CONSUMPTION CHART
   =================================================================== */
.series-tabs{display:inline-flex;gap:4px;background:var(--inset);border:1px solid var(--line);border-radius:9px;padding:3px;}
.series-tabs button{border:none;background:transparent;color:var(--t2);font-size:12px;font-weight:500;
  padding:6px 12px;border-radius:6px;display:inline-flex;align-items:center;gap:7px;transition:.13s;}
.series-tabs button .sw{width:9px;height:9px;border-radius:3px;background:var(--uc);}
.series-tabs button.on{background:var(--panel);color:var(--t1);box-shadow:inset 0 0 0 1px var(--uc), 0 0 14px -4px var(--uc);}
.series-tabs button:hover:not(.on){color:var(--t1);}

.chart-wrap{padding:10px var(--card-pad) var(--card-pad);position:relative;}
.chart-meta{display:flex;align-items:center;gap:18px;margin-bottom:8px;padding-left:2px;flex-wrap:wrap;}
.chart-stat .lab{font-size:10px;color:var(--t3);font-family:var(--f-mono);letter-spacing:.08em;text-transform:uppercase;}
.chart-stat .val{font-family:var(--f-display);font-weight:600;font-size:17px;}
.chart-stat .val small{font-family:var(--f-mono);font-size:11px;color:var(--t3);font-weight:400;}
.legend-inline{margin-left:auto;display:flex;gap:14px;font-size:11px;color:var(--t3);}
.legend-inline .li{display:flex;align-items:center;gap:6px;}
.legend-inline .bar{width:13px;height:8px;border-radius:2px;}
.legend-inline .ln{width:14px;height:0;border-top:2px solid var(--accent);}
#timeChart{display:block;width:100%;height:248px;overflow:visible;}
.chart-tip{position:absolute;pointer-events:none;z-index:20;background:color-mix(in srgb,var(--panel) 96%, #000);
  border:1px solid var(--line);border-radius:8px;padding:9px 11px;min-width:140px;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6);opacity:0;transition:opacity .1s;transform:translate(-50%,-12px);}
.chart-tip .tt-x{font-family:var(--f-mono);font-size:10px;color:var(--t3);letter-spacing:.08em;margin-bottom:6px;text-transform:uppercase;}
.chart-tip .tt-row{display:flex;align-items:center;gap:8px;font-size:12px;}
.chart-tip .tt-row .sw{width:8px;height:8px;border-radius:2px;}
.chart-tip .tt-row .v{margin-left:auto;font-family:var(--f-mono);font-weight:600;color:var(--t1);}
.chart-tip .tt-row .c{color:var(--t3);font-family:var(--f-mono);font-size:11px;}

/* ===================================================================
   PRODUCTION
   =================================================================== */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--grid-gap);padding:var(--card-pad);}
.prod{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px;display:flex;flex-direction:column;gap:12px;}
.prod .p-head{display:flex;align-items:center;justify-content:space-between;}
.prod .p-name{font-family:var(--f-display);font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;}
.prod .p-name .ld{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 3px color-mix(in srgb,var(--good) 20%,transparent);}
.prod .p-tag{font-family:var(--f-mono);font-size:9.5px;color:var(--t3);letter-spacing:.1em;border:1px solid var(--line);border-radius:5px;padding:2px 6px;}
.prod .p-body{display:flex;gap:13px;align-items:center;}
.ppie{position:relative;flex:none;}
.ppie svg{display:block;width:82px;height:82px;transform:rotate(-90deg);}
.ppie .ctr{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;}
.ppie .ctr .pv{font-family:var(--f-display);font-weight:600;font-size:15px;line-height:1;}
.ppie .ctr .pl{font-size:8px;color:var(--t3);font-family:var(--f-mono);letter-spacing:.08em;margin-top:2px;}
.prod .p-stat{flex:1;display:flex;flex-direction:column;gap:7px;min-width:0;}
.prod .p-units{line-height:1;}
.prod .p-units b{font-family:var(--f-display);font-weight:600;font-size:22px;}
.prod .p-units span{font-family:var(--f-mono);font-size:10.5px;color:var(--t3);margin-left:4px;}
.prod .p-cost{display:flex;align-items:baseline;gap:6px;}
.prod .p-cost .lab{font-size:9.5px;color:var(--t4);font-family:var(--f-mono);letter-spacing:.08em;text-transform:uppercase;}
.prod .p-cost .val{font-family:var(--f-mono);font-size:14px;color:var(--t1);font-weight:600;}
.prod-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin:0 var(--card-pad) var(--card-pad);padding-top:11px;border-top:1px dashed var(--line);
  font-size:11.5px;color:var(--t3);}
/* shared pie hover tooltip */
.pie-tip{position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%) scale(.96);transform-origin:bottom center;
  width:178px;background:color-mix(in srgb,var(--panel) 96%, #000);border:1px solid var(--line);border-radius:8px;padding:9px 10px;z-index:30;
  box-shadow:0 12px 28px -8px rgba(0,0,0,.6);opacity:0;visibility:hidden;transition:.12s;pointer-events:none;}
.ppie:hover .pie-tip{opacity:1;visibility:visible;transform:translateX(-50%) scale(1);}
.pie-tip::after{content:"";position:absolute;left:50%;top:100%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--line);}
.pie-tip .h{font-family:var(--f-mono);font-size:9.5px;color:var(--t3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;}
.pie-tip .li{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--t2);padding:2px 0;}
.pie-tip .li .sw{width:9px;height:9px;border-radius:2px;flex:none;}
.pie-tip .li .pc{margin-left:auto;font-family:var(--f-mono);color:var(--t1);font-weight:500;}
.pie-tip .li .rp{font-family:var(--f-mono);color:var(--t3);font-size:10.5px;min-width:48px;text-align:right;}

/* ===================================================================
   RIGHT COLUMN — spend card + donuts
   =================================================================== */
.spend{background:linear-gradient(165deg, color-mix(in srgb,var(--accent) 12%, var(--panel)), var(--panel-2));
  border:1px solid color-mix(in srgb,var(--accent) 26%, var(--line));border-radius:var(--radius);padding:var(--card-pad);}
.spend .s-top{display:flex;align-items:flex-start;justify-content:space-between;}
.spend .s-lab{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--t2);}
.spend .s-val{font-family:var(--f-display);font-weight:600;font-size:30px;line-height:1.1;margin-top:3px;}
.spend .s-val .cur{font-family:var(--f-mono);font-size:14px;color:var(--t3);font-weight:400;margin-right:5px;}
.spend .s-bar{display:flex;height:11px;border-radius:6px;overflow:hidden;margin-top:13px;border:1px solid var(--line);}
.spend .s-bar i{height:100%;}
.spend .s-leg{display:grid;grid-template-columns:1fr 1fr;gap:6px 16px;margin-top:11px;}
.spend .s-leg .li{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--t2);}
.spend .s-leg .sw{width:9px;height:9px;border-radius:2px;flex:none;}
.spend .s-leg .v{margin-left:auto;font-family:var(--f-mono);color:var(--t1);font-weight:500;}

.donut-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--card-pad);cursor:pointer;transition:.14s;position:relative;}
.donut-card:hover{border-color:color-mix(in srgb,var(--uc) 50%, var(--line));
  box-shadow:0 8px 26px -12px var(--uc);transform:translateY(-1px);}
.donut-card.sel{border-color:var(--uc);box-shadow:0 0 0 1px var(--uc), 0 8px 26px -12px var(--uc);}
.dc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px;}
.dc-title{display:flex;align-items:center;gap:9px;font-family:var(--f-display);font-weight:600;font-size:14.5px;}
.dc-title .dot{width:9px;height:9px;border-radius:3px;background:var(--uc);}
.dc-meters{font-family:var(--f-mono);font-size:10px;color:var(--t3);letter-spacing:.06em;border:1px solid var(--line);border-radius:5px;padding:2px 7px;}
.dc-body{display:flex;align-items:center;gap:14px;}
.ddonut{position:relative;flex:none;}
.ddonut svg{display:block;width:96px;height:96px;transform:rotate(-90deg);}
.ddonut .ctr{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;}
.ddonut .ctr .v{font-family:var(--f-display);font-weight:600;font-size:16px;line-height:1;}
.ddonut .ctr .l{font-size:8px;color:var(--t3);font-family:var(--f-mono);letter-spacing:.06em;margin-top:2px;}
.dc-aside{flex:1;display:flex;flex-direction:column;gap:10px;min-width:0;}
.dc-total{line-height:1.15;}
.dc-total .v{font-family:var(--f-mono);font-size:15px;font-weight:600;color:var(--t1);}
.dc-total .l{font-size:10px;color:var(--t3);font-family:var(--f-mono);letter-spacing:.04em;}
.dc-link{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;
  font-size:11.5px;color:var(--uc);font-weight:600;border-top:1px solid var(--hair);padding-top:9px;}
.dc-link .arr{width:20px;height:20px;border-radius:6px;display:grid;place-items:center;
  border:1px solid color-mix(in srgb,var(--uc) 45%,var(--line));background:color-mix(in srgb,var(--uc) 12%,transparent);}
.donut-card .pie-tip{left:auto;right:6px;bottom:auto;top:42px;transform:translateX(0) scale(.96);}
.donut-card:hover .pie-tip,.ddonut:hover ~ .pie-tip{opacity:0;}
.ddonut:hover .pie-tip{opacity:1;visibility:visible;transform:none;}
.ddonut .pie-tip{left:calc(100% + 12px);bottom:auto;top:50%;transform:translateY(-50%) scale(.96);}
.ddonut:hover .pie-tip{transform:translateY(-50%) scale(1);}
.ddonut .pie-tip::after{left:auto;right:100%;top:50%;transform:translateY(-50%);border-top-color:transparent;border-right-color:var(--line);}

/* slice hover */
.slice{transition:opacity .12s, transform .12s;transform-origin:center;cursor:pointer;}
.ddonut.dim .slice:not(.hot),.ppie.dim .slice:not(.hot){opacity:.32;}

/* ===================================================================
   DRILL-DOWN MODAL (Frame 2)
   =================================================================== */
.overlay{position:fixed;inset:0;z-index:200;background:rgba(8,7,5,.66);backdrop-filter:blur(3px);
  display:none;align-items:center;justify-content:center;padding:34px;}
.overlay.open{display:flex;animation:fade .18s ease;}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
.modal{width:980px;max-width:100%;max-height:90vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:14px;box-shadow:0 40px 100px -30px rgba(0,0,0,.8);overflow:hidden;animation:rise .22s cubic-bezier(.2,.8,.2,1);}
@keyframes rise{from{transform:translateY(14px) scale(.99);opacity:0;}to{transform:none;opacity:1;}}
.m-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:17px 18px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg, color-mix(in srgb,var(--uc) 10%, var(--panel)), transparent);}
.m-crumb{font-family:var(--f-mono);font-size:10.5px;color:var(--t3);letter-spacing:.04em;margin-bottom:5px;display:flex;align-items:center;gap:7px;}
.m-crumb b{color:var(--uc);}
.m-title{font-family:var(--f-display);font-weight:600;font-size:22px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.m-title .ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
  background:color-mix(in srgb,var(--uc) 18%,var(--panel));border:1px solid color-mix(in srgb,var(--uc) 38%,var(--line));color:var(--uc);}
.m-title .ic svg{width:16px;height:16px;}
.m-chip{font-family:var(--f-mono);font-size:11px;color:var(--t2);border:1px solid var(--line);border-radius:20px;padding:3px 10px;background:var(--panel-2);}
.x-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);color:var(--t2);
  font-size:16px;display:grid;place-items:center;flex:none;transition:.13s;}
.x-btn:hover{color:var(--t1);border-color:var(--t4);background:var(--inset);}
.m-tools{display:flex;align-items:center;gap:10px;padding:13px 18px;border-bottom:1px solid var(--hair);flex-wrap:wrap;}
.m-search{flex:1;min-width:230px;display:flex;align-items:center;gap:9px;background:var(--inset);border:1px solid var(--line);
  border-radius:9px;padding:8px 13px;transition:.13s;}
.m-search:focus-within{border-color:var(--uc);box-shadow:0 0 0 3px color-mix(in srgb,var(--uc) 16%,transparent);}
.m-search svg{width:15px;height:15px;color:var(--t3);flex:none;}
.m-search input{flex:1;border:none;background:transparent;color:var(--t1);font-family:var(--f-ui);font-size:13px;outline:none;}
.m-search input::placeholder{color:var(--t4);}
.m-filter{display:inline-flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--line);
  border-radius:9px;padding:8px 12px;font-size:12.5px;color:var(--t2);transition:.13s;}
.m-filter:hover{color:var(--t1);border-color:var(--t4);}
.m-filter svg{width:13px;height:13px;}
.m-count{font-family:var(--f-mono);font-size:11.5px;color:var(--t3);margin-left:2px;}
.m-count b{color:var(--t1);}

.table-scroll{overflow:auto;flex:1;}
table.meters{width:100%;border-collapse:collapse;font-size:13px;}
table.meters thead th{position:sticky;top:0;z-index:2;background:var(--inset);text-align:left;
  padding:10px 16px;font-family:var(--f-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--t3);
  border-bottom:1px solid var(--line);font-weight:500;cursor:pointer;user-select:none;white-space:nowrap;}
table.meters thead th:hover{color:var(--t1);}
table.meters thead th .ar{opacity:.4;margin-left:5px;font-size:9px;}
table.meters thead th.sorted .ar{opacity:1;color:var(--uc);}
table.meters td{padding:10px 16px;border-bottom:1px solid var(--hair);color:var(--t2);vertical-align:middle;white-space:nowrap;}
table.meters tbody tr{transition:background .1s;}
table.meters tbody tr:hover td{background:color-mix(in srgb,var(--uc) 7%, transparent);}
.mt-name{display:flex;align-items:center;gap:10px;}
.mt-name .mdot{width:7px;height:7px;border-radius:50%;flex:none;}
.mt-name .nm{color:var(--t1);font-weight:500;}
.mt-name .sub{color:var(--t3);font-family:var(--f-mono);font-size:11px;}
.mt-id{font-family:var(--f-mono);font-size:12px;color:var(--t2);}
.mt-loc{color:var(--t2);}
.mt-read{font-family:var(--f-mono);font-size:13.5px;color:var(--t1);font-weight:600;}
.mt-read .u{color:var(--t3);font-weight:400;font-size:11px;margin-left:3px;}
.mt-trend{display:flex;align-items:center;gap:9px;}
.mt-trend svg{width:64px;height:22px;}
.mt-trend .pc{font-family:var(--f-mono);font-size:11px;}
.mt-empty{padding:40px;text-align:center;color:var(--t3);font-size:13px;}
.m-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 18px;border-top:1px solid var(--line);
  font-family:var(--f-mono);font-size:11px;color:var(--t3);}
.m-foot .exp{display:inline-flex;align-items:center;gap:7px;background:var(--panel-2);border:1px solid var(--line);
  border-radius:8px;padding:7px 12px;color:var(--t2);font-family:var(--f-ui);font-size:12px;transition:.13s;}
.m-foot .exp:hover{color:var(--t1);border-color:var(--t4);}

/* status dot colors */
.s-ok{background:var(--good);}
.s-warn{background:var(--warn);}
.s-hi{background:var(--bad);}
