/* Tellor Layer dashboard — design system */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --accent:#4ade80;
  --radius:14px;
  --mono:"Geist Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:"Geist",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
body[data-theme="cobalt"]{
  --bg:#080b11; --bg2:#0c1018; --card:#0f141d; --card2:#131a25;
  --line:#1d2533; --line2:#28323f;
  --txt:#eef2f7; --mut:#8b97a8; --dim:#5d6675;
  --accent-soft:rgba(74,222,128,.10); --grid:#1a2230; --danger:#f87171;
}
body[data-theme="carbon"]{
  --bg:#0a0a0a; --bg2:#101010; --card:#141414; --card2:#1a1a1a;
  --line:#242424; --line2:#303030;
  --txt:#f4f4f4; --mut:#9a9a9a; --dim:#6a6a6a;
  --accent-soft:rgba(74,222,128,.10); --grid:#1f1f1f; --danger:#f87171;
}
body[data-theme="daylight"]{
  --bg:#f3f5f8; --bg2:#eef1f5; --card:#ffffff; --card2:#f7f9fc;
  --line:#e2e7ee; --line2:#d3dae3;
  --txt:#10151c; --mut:#5a6675; --dim:#8a94a3;
  --accent-soft:rgba(34,160,90,.12); --grid:#e8ecf2; --danger:#dc2626;
}
body{
  background:var(--bg);color:var(--txt);font-family:var(--sans);
  font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(900px 480px at 80% -10%,var(--accent-soft),transparent 60%);
}
.mono{font-family:var(--mono)}
.muted{color:var(--mut)}
.small{font-size:.78rem}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.unit{color:var(--mut);font-size:.72em;font-weight:500}

/* ---------- App / layout ---------- */
.app{max-width:1320px;margin:0 auto;padding:0 22px 60px}
.boot{height:100vh;display:flex;align-items:center;justify-content:center;color:var(--mut);
  gap:12px;font-size:.9rem;letter-spacing:.3px}
.boot .spin{width:18px;height:18px;border:2px solid var(--line2);border-top-color:var(--accent);
  border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Header ---------- */
.hdr{padding-top:18px;background:linear-gradient(180deg,var(--bg) 70%,transparent)}
.hdr-top{display:flex;align-items:center;gap:18px}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer;flex:none}
.brand-mark{flex:none;width:32px!important;height:32px!important;max-width:32px;max-height:32px;border-radius:50%;object-fit:contain;display:block}
.brand-name{font-weight:700;font-size:1.02rem;letter-spacing:-.2px}
.brand-sub{font-size:.68rem;text-transform:uppercase;letter-spacing:1.4px}
.hdr-search{flex:1;position:relative;display:flex;align-items:center;gap:9px;
  background:var(--card);border:1px solid var(--line);border-radius:11px;
  padding:0 13px;height:42px;max-width:560px;color:var(--mut)}
.hdr-search:focus-within{border-color:var(--line2);box-shadow:0 0 0 3px var(--accent-soft)}
.hdr-search input{flex:1;background:none;border:none;outline:none;color:var(--txt);
  font-size:.9rem;font-family:inherit}
.hdr-search input::placeholder{color:var(--dim)}
.hdr-search kbd{font-family:var(--mono);font-size:.66rem;color:var(--mut);
  border:1px solid var(--line2);border-radius:6px;padding:2px 6px;background:var(--bg2)}
.search-results{position:absolute;top:50px;left:0;right:0;background:var(--card2);
  border:1px solid var(--line2);border-radius:12px;overflow:hidden;
  box-shadow:0 18px 50px rgba(0,0,0,.55);z-index:40}
.sr-row{display:flex;align-items:center;gap:11px;width:100%;padding:10px 14px;
  background:none;border:none;border-bottom:1px solid var(--line);text-align:left;color:var(--txt)}
.sr-row:last-child{border-bottom:none}
.sr-row:hover{background:var(--accent-soft)}
.sr-tag{font-size:.6rem;text-transform:uppercase;letter-spacing:.6px;padding:3px 7px;
  border-radius:6px;font-weight:600;flex:none}
.tag-reporter{background:rgba(74,222,128,.15);color:var(--accent)}
.tag-selector{background:rgba(56,189,248,.15);color:#38bdf8}
.tag-tx{background:rgba(167,139,250,.15);color:#a78bfa}
.tag-validator{background:rgba(167,139,250,.18);color:#c4b5fd}
.sr-glyph{width:22px;text-align:center;color:var(--mut)}
.sr-text{display:flex;flex-direction:column;min-width:0}
.sr-l{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-s{font-size:.72rem}
.hdr-right{display:flex;align-items:center;gap:10px;flex:none}
.live-pill{display:flex;align-items:center;gap:8px;background:var(--card);
  border:1px solid var(--line);border-radius:10px;padding:8px 13px}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 0 var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
.theme-btn{display:flex;align-items:center;gap:7px;background:var(--card);
  border:1px solid var(--line);border-radius:10px;padding:8px 13px;color:var(--mut);
  font-size:.82rem}

/* ---------- Stat row ---------- */
.stat-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:18px 0 4px}
.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:15px 17px;min-height:104px;display:flex;flex-direction:column;gap:6px;
  transition:border-color .2s}
.stat-card:hover{border-color:var(--line2)}
.stat-label{font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--mut)}
.stat-value{font-size:1.7rem;font-weight:700;letter-spacing:-.5px;line-height:1.1}
.stat-bottom{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:8px}
.stat-sub{white-space:nowrap}
body[data-sparks="off"] .sparkline{display:none}
@media(max-width:1080px){.stat-row{grid-template-columns:repeat(2,1fr)}}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:4px;margin:18px 0 0;border-bottom:1px solid var(--line)}
.tab{background:none;border:none;color:var(--mut);padding:11px 16px;font-size:.92rem;
  font-weight:500;display:flex;align-items:center;gap:8px;border-bottom:2px solid transparent;
  margin-bottom:-1px}
.tab:hover{color:var(--txt)}
.tab.active{color:var(--txt);border-bottom-color:var(--accent)}
.tab-count{font-size:.7rem;background:var(--card2);border:1px solid var(--line);
  color:var(--mut);padding:1px 7px;border-radius:8px}
.tab.active .tab-count{color:var(--accent);border-color:var(--accent)}

/* ---------- Screen ---------- */
.main{padding-top:22px}
.screen-head{display:flex;align-items:flex-end;justify-content:space-between;
  gap:16px;margin-bottom:16px;flex-wrap:wrap}
.screen-title{font-size:1.35rem;font-weight:700;letter-spacing:-.4px}
.screen-sub{font-size:.84rem;margin-top:2px}
.seg{display:flex;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:3px}
.seg-btn{background:none;border:none;color:var(--mut);padding:6px 14px;border-radius:7px;
  font-size:.82rem;font-weight:500}
.seg-btn.active{background:var(--card2);color:var(--txt);box-shadow:0 1px 2px rgba(0,0,0,.3)}

/* Prominent sub-tabs (Reporters page: Performance / Stake).
   Larger than .seg, accent underline + glow on the active one. */
.subtabs{display:flex;gap:18px;margin:6px 0 22px;padding:0 2px;
  border-bottom:1px solid var(--line)}
.subtabs-btn{background:none;border:none;color:var(--mut);
  padding:12px 4px;font-size:1.05rem;font-weight:600;letter-spacing:.1px;
  border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;transition:color .15s}
.subtabs-btn:hover{color:var(--txt)}
.subtabs-btn.active{color:var(--accent);border-bottom-color:var(--accent);
  text-shadow:0 0 18px rgba(74,222,128,.25)}
.subtabs-pill{font-size:.66rem;letter-spacing:.5px;
  background:var(--accent-soft);color:var(--accent);
  padding:2px 8px;border-radius:8px;border:1px solid rgba(74,222,128,.35);
  text-transform:uppercase;font-weight:700}
.subtabs-btn.active .subtabs-pill{background:var(--accent);color:var(--bg)}
.search-inline{display:flex;align-items:center;gap:8px;background:var(--card);
  border:1px solid var(--line);border-radius:10px;padding:0 12px;height:38px;color:var(--mut)}
.search-inline.grow{flex:1;max-width:560px}
.search-inline input{background:none;border:none;outline:none;color:var(--txt);
  font-family:inherit;font-size:.86rem;width:100%}
.search-inline input::placeholder{color:var(--dim)}

/* ---------- Card / table ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden}
.table-card{overflow-x:auto}
.card-head{display:flex;align-items:center;justify-content:space-between;
  padding:15px 18px;border-bottom:1px solid var(--line)}
.card-title{font-weight:600;font-size:.95rem}
.t{width:100%;border-collapse:collapse;font-size:.86rem}
.t thead th{text-align:left;font-size:.66rem;text-transform:uppercase;letter-spacing:.7px;
  color:var(--mut);font-weight:600;padding:12px 14px;border-bottom:1px solid var(--line);
  background:var(--bg2);position:sticky;top:0}
.t td{padding:9px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.t tbody tr:last-child td{border-bottom:none}
.t .right{text-align:right}
.row-clickable{cursor:pointer;transition:background .12s}
.row-clickable:hover{background:var(--card2)}
.rank{color:var(--dim);font-variant-numeric:tabular-nums;width:44px}
body[data-density="compact"] .t td{padding:5px 12px}
body[data-density="compact"] .t thead th{padding:8px 12px}
.share-bar{position:relative;height:8px;background:var(--bg2);border-radius:5px;
  width:150px;margin-left:auto}
.share-bar i{position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--accent),var(--accent));
  border-radius:5px;opacity:.85}
.share-pct{position:absolute;right:-46px;top:-5px;font-size:.74rem;color:var(--mut);
  font-variant-numeric:tabular-nums}

/* ---------- Address block ---------- */
.identicon{display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden;flex:none}
.identicon span{display:block}
.addr-block{display:flex;align-items:center;gap:10px;background:none;border:none;
  text-align:left;color:var(--txt);max-width:100%}
.addr-block:hover .addr-name{color:var(--accent)}
.addr-text{display:flex;flex-direction:column;min-width:0;line-height:1.3}
.addr-name{font-weight:600;font-size:.85rem;white-space:nowrap}
/* Validator-namespace monikers are tinted so a name that's used for
   both a reporter and its validator entity reads as two distinct
   things at a glance. */
.addr-name-validator{color:#a78bfa}
.addr-block:hover .addr-name-validator{color:#c4b5fd}
.addr-hash{font-family:var(--mono);font-size:.78rem;color:var(--txt)}
.addr-hash-sub{font-size:.68rem;color:var(--mut)}
.parties{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.arrow{color:var(--dim);font-size:1rem}

/* ---------- Pills / badges ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;
  padding:3px 9px;border-radius:20px}
.pill-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.pill-ok{background:rgba(74,222,128,.13);color:var(--accent)}
.pill-bad{background:rgba(248,113,113,.14);color:var(--danger)}
.pill-warn{background:rgba(251,191,36,.14);color:#fbbf24}
.pill-idle{background:var(--card2);color:var(--mut);border:1px solid var(--line)}
.tx-badge{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:600;
  padding:4px 10px;border-radius:8px;border:1px solid transparent;white-space:nowrap}
.tx-glyph{font-style:normal;font-size:.82rem}
.tone-mint{background:rgba(74,222,128,.12);color:var(--accent);border-color:rgba(74,222,128,.25)}
.tone-sky{background:rgba(56,189,248,.12);color:#38bdf8;border-color:rgba(56,189,248,.25)}
.tone-amber{background:rgba(251,191,36,.12);color:#fbbf24;border-color:rgba(251,191,36,.25)}
.tone-violet{background:rgba(167,139,250,.12);color:#a78bfa;border-color:rgba(167,139,250,.25)}
.tone-red{background:rgba(248,113,113,.12);color:var(--danger);border-color:rgba(248,113,113,.25)}
.tone-mut{background:var(--card2);color:var(--mut);border-color:var(--line2)}

/* ---------- Sparkline / chart ---------- */
.sparkline{display:block}
.chart{position:relative;padding:18px}
.chart-label{font-size:.8rem;color:var(--mut);margin-bottom:6px;font-weight:500}
.chart-svg{display:block;overflow:visible}
.chart-axis{fill:var(--dim);font-size:10px;font-family:var(--mono)}
.chart-tip{position:absolute;transform:translate(-50%,-130%);background:var(--bg2);
  border:1px solid var(--line2);border-radius:8px;padding:6px 10px;pointer-events:none;
  white-space:nowrap;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.chart-tip-v{font-weight:700;font-size:.85rem}
.chart-card{padding:4px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
@media(max-width:920px){.grid-2{grid-template-columns:1fr}}

/* ---------- Detail hero ---------- */
.back{display:inline-flex;align-items:center;gap:7px;background:none;border:1px solid var(--line);
  color:var(--mut);padding:7px 13px;border-radius:9px;font-size:.83rem;margin-bottom:16px}
.back:hover{color:var(--txt);border-color:var(--line2)}
.hero{display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:22px 24px;flex-wrap:wrap}
.hero-main{display:flex;align-items:center;gap:16px;min-width:0}
.hero-name{display:flex;align-items:center;gap:12px;font-size:1.3rem;font-weight:700}
.hero-addr{font-size:.8rem;color:var(--mut);margin-top:4px;word-break:break-all}
.hero-stats{display:flex;gap:30px;flex-wrap:wrap}
.hero-stat-l{font-size:.68rem;text-transform:uppercase;letter-spacing:.8px;color:var(--mut)}
.hero-stat-v{font-size:1.15rem;font-weight:700;margin-top:3px}
.hero-stat-v.small{font-size:.92rem;font-weight:600}
.link{background:none;border:none;color:var(--accent);font:inherit;font-weight:600;cursor:pointer}
.link:hover{text-decoration:underline}
.section-gap{margin-top:16px}

/* ---------- Toolbar / dropdown / pager ---------- */
.toolbar{display:flex;align-items:center;gap:10px;padding:14px 16px;
  border-bottom:1px solid var(--line);flex-wrap:wrap}
.toolbar-chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{background:var(--card2);border:1px solid var(--line2);color:var(--mut);
  padding:5px 11px;border-radius:16px;font-size:.76rem}
.chip:hover{color:var(--txt)}
.dd{position:relative}
.dd-btn{display:flex;align-items:center;gap:8px;background:var(--card);
  border:1px solid var(--line);color:var(--txt);padding:8px 13px;border-radius:10px;
  font-size:.84rem}
.dd-count{background:var(--accent);color:#04210f;font-weight:700;font-size:.7rem;
  padding:0 6px;border-radius:8px}
.dd-panel{position:absolute;top:44px;right:0;width:250px;background:var(--card2);
  border:1px solid var(--line2);border-radius:12px;padding:10px;z-index:30;
  box-shadow:0 18px 50px rgba(0,0,0,.55)}
.dd-search{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--txt);
  padding:7px 10px;border-radius:8px;font:inherit;font-size:.82rem;margin-bottom:8px;outline:none}
.dd-list{max-height:240px;overflow:auto}
.dd-opt{display:flex;align-items:center;gap:9px;padding:7px 6px;border-radius:7px;
  font-size:.84rem}
.dd-opt:hover{background:var(--card)}
.dd-opt input{accent-color:var(--accent);width:15px;height:15px}
.dd-foot{display:flex;gap:8px;margin-top:8px}
.dd-foot button{flex:1;padding:8px;border-radius:8px;border:1px solid var(--line2);
  background:var(--card);color:var(--txt);font-size:.8rem}
.dd-foot .primary{background:var(--accent);color:#04210f;font-weight:700;border-color:var(--accent)}
.pager{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;
  border-top:1px solid var(--line)}
.pager-btns{display:flex;gap:8px}
.pager-btns button{background:var(--card2);border:1px solid var(--line2);color:var(--txt);
  padding:7px 14px;border-radius:8px;font-size:.82rem}
.pager-btns button:disabled{opacity:.4;cursor:default}

/* sortable / filterable column headers */
.th-sort{cursor:pointer;user-select:none;white-space:nowrap}
.th-sort:hover{color:var(--txt)}
.th-sort.on{color:var(--accent)}
.colf{position:relative;display:inline-flex}
.colf-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;
  cursor:pointer;color:var(--mut);font:inherit;font-size:.66rem;text-transform:uppercase;
  letter-spacing:.7px;font-weight:600;padding:0}
.colf-btn:hover{color:var(--txt)}
.colf-btn.on{color:var(--accent)}
.colf-n{background:var(--accent);color:#04210f;font-weight:700;font-size:.6rem;
  padding:0 5px;border-radius:7px;letter-spacing:0}
.colf-panel{top:24px;left:0;right:auto;width:210px;text-transform:none;
  letter-spacing:normal;font-weight:400}

/* tx table extras */
.block-cell{display:flex;flex-direction:column;line-height:1.35}
.day-row td{padding:7px 14px;background:var(--bg2);border-bottom:1px solid var(--line)}
.day-chip{font-size:.72rem;color:var(--mut);font-weight:600;text-transform:uppercase;
  letter-spacing:.6px}
.tx-link{display:inline-flex;align-items:center;color:var(--mut);font-size:.8rem}
.tx-link:hover{color:var(--accent)}
.lock-pill{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;
  color:#fbbf24;font-weight:600}

/* ---------- Footer ---------- */
.foot{display:flex;justify-content:center;padding:26px 4px 0;
  border-top:1px solid var(--line);margin-top:30px;font-size:.82rem}
.foot-attrib{display:inline-flex;align-items:center;gap:8px;color:var(--txt)}
.foot-attrib b{font-weight:700}
.foot-logo{width:22px;height:22px;border-radius:50%;object-fit:contain;
  background:var(--card2);flex:none}

/* ---------- Tweaks panel ---------- */
.tw-fab{position:fixed;right:20px;bottom:20px;z-index:50;width:42px;height:42px;
  border-radius:50%;background:var(--card2);border:1px solid var(--line2);color:var(--mut);
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.tw-fab:hover{color:var(--accent)}
.tw-panel{position:fixed;right:20px;bottom:74px;z-index:50;width:250px;background:var(--card2);
  border:1px solid var(--line2);border-radius:14px;padding:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.6)}
.tw-h{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
  color:var(--mut);margin-bottom:14px}
.tw-sec{margin-bottom:16px}
.tw-sec:last-child{margin-bottom:0}
.tw-l{font-size:.74rem;color:var(--mut);margin-bottom:7px;font-weight:600}
.tw-radio{display:flex;gap:6px}
.tw-radio button{flex:1;background:var(--card);border:1px solid var(--line);color:var(--mut);
  padding:6px;border-radius:8px;font-size:.78rem}
.tw-radio button.on{border-color:var(--accent);color:var(--txt);background:var(--accent-soft)}
.tw-colors{display:flex;gap:8px}
.tw-sw{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer}
.tw-sw.on{border-color:var(--txt)}
.tw-toggle{display:flex;align-items:center;justify-content:space-between;font-size:.82rem}
.tw-switch{width:38px;height:22px;border-radius:12px;background:var(--line2);position:relative;
  border:none;transition:background .2s}
.tw-switch.on{background:var(--accent)}
.tw-switch i{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;
  background:#fff;transition:left .2s}
.tw-switch.on i{left:19px}

/* --- live reports: asset chips + compact grid --- */
.coin-chip{display:flex;align-items:center;gap:6px;min-width:0;
  line-height:1;text-align:left}
.coin-img{width:16px;height:16px;flex:none;border-radius:50%;
  object-fit:cover;background:var(--card2);display:block}
.coin-dot{display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;font-weight:700;letter-spacing:.2px;flex:none}
.coin-sym{font-size:.7rem;color:var(--txt);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;min-width:0}
.rtag{font-size:.7rem;max-width:96px;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;display:inline-block;vertical-align:middle;text-align:left}
/* table-layout:fixed + equal columns => ~12 reporters fit, no h-scroll */
.rgrid-wrap{overflow-x:auto;padding:0}
.rgrid{font-size:.72rem;width:100%;table-layout:fixed}
.rgrid th,.rgrid td{white-space:nowrap;overflow:hidden;
  padding:5px 8px;vertical-align:middle;text-align:left}
.rgrid thead th{padding:7px 8px}
.rgrid-stick{position:sticky;left:0;z-index:1;width:78px;
  background:var(--card);border-right:1px solid var(--line)}
.rgrid thead .rgrid-stick{background:var(--card2)}
body[data-density="compact"] .rgrid th,
body[data-density="compact"] .rgrid td{padding:3px 6px}
.dev{display:block;font-size:.58rem;font-weight:600;line-height:1.1;margin-top:1px;
  letter-spacing:.2px}
.dev-ok{color:#4ade80}
.dev-warn{color:#fbbf24}
.dev-bad{color:#fb7185}
/* TRB->USD sub-line under stake / power cells */
.usd-sub{font-size:.66rem;line-height:1.1;margin-top:1px;font-weight:500}

/* missed matrix: assets x reporters, ticks/counts, sticky asset col + sticky thead */
.m-grid-wrap{overflow-x:auto}
.m-grid{font-size:.78rem;width:auto;min-width:100%;table-layout:auto}
.m-grid th,.m-grid td{padding:6px 10px;text-align:center;white-space:nowrap;
  vertical-align:middle}
.m-grid th:first-child,.m-grid td:first-child{text-align:left;position:sticky;
  left:0;background:var(--card);border-right:1px solid var(--line);min-width:120px}
.m-grid thead th:first-child{background:var(--card2);z-index:3}
.m-grid tfoot td{background:var(--card2);font-weight:700;
  border-top:1px solid var(--line)}
.m-grid tfoot td:first-child{background:var(--card2)}
.m-grid .miss{color:#fb7185;font-weight:700}
.m-grid .ok{color:var(--accent)}
.m-grid .na{color:var(--mut);opacity:.55}

/* --- disputes: expanded detail row --- */
.dispute-detail td{background:var(--card2);padding:14px 18px !important}
.dispute-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 32px}
.dispute-other{list-style:none;padding:0;margin:6px 0 0;font-size:.85rem}
.dispute-other li{padding:3px 0;color:var(--mut)}
.dispute-other .mono{color:var(--txt);word-break:break-all}

/* --- bridge: reporter sub-lists in expanded row --- */
.bridge-reporter-list{list-style:none;padding:0;margin:6px 0 0;font-size:.85rem}
.bridge-reporter-list li{padding:4px 0;display:flex;align-items:center;gap:8px}

/* Reporter list rows in the bridge deposit detail — plain text with
   tone-coloured name + power. tone-ok = green (voted), tone-bad = red. */
.rep-list{margin-top:6px;font-size:.85rem;display:flex;flex-direction:column;gap:2px}
.rep-row{display:flex;align-items:baseline;gap:8px;padding:2px 0}
.rep-row a{text-decoration:none}
.rep-row a:hover .rep-name{text-decoration:underline}
.rep-name{font-weight:600}
.rep-power{font-family:var(--mono);font-size:.74rem;opacity:.8}
.rep-ok .rep-name,.rep-ok .rep-power{color:var(--accent)}
.rep-bad .rep-name,.rep-bad .rep-power{color:#fb7185}
