/*
 * Dashboard styles for the extracted admin frontend.
 * Keeps the original visual system while living outside sr-service source.
 */
*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0f1117;--card:#1a1d27;--border:#2a2d3a;--text:#e1e4ed;--dim:#6b7280;
--green:#22c55e;--yellow:#eab308;--red:#ef4444;--blue:#3b82f6;--purple:#a855f7;--cyan:#06b6d4}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
background:var(--bg);color:var(--text);line-height:1.5;padding:16px}
.header{display:flex;align-items:center;justify-content:space-between;padding:12px 0;margin-bottom:16px;border-bottom:1px solid var(--border)}
.header h1{font-size:20px;font-weight:600}
.header .meta{font-size:13px;color:var(--dim);display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle}
.status-ok{background:var(--green)}.status-degraded{background:var(--yellow)}.status-error{background:var(--red)}
.status-pulse{animation:pulse 1.2s ease-in-out infinite}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;margin-bottom:16px}
.card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:16px}
.card.collapsed{padding-bottom:12px}
.card h2{font-size:14px;font-weight:600;color:var(--dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;cursor:pointer;display:flex;align-items:center;flex-wrap:wrap;gap:4px 8px}
.h2-sub{color:var(--dim);font-size:11px;text-transform:none;letter-spacing:0;font-weight:500}
.subsection-label{font-size:12px;color:var(--dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}
.metric-row-wrap{display:flex;gap:18px;margin-bottom:12px;flex-wrap:wrap;align-items:center}
.metric-divider{border-left:1px solid var(--border);height:24px;margin:0 4px;flex-shrink:0}
.metric-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2px 14px;align-items:center}
.subcard{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px}
.subcard-title{font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--dim);margin:0 0 8px;font-weight:600}
.memory-split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.indexer-three-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.kv-chip{font-size:11px;padding:2px 8px;border-radius:4px;background:rgba(255,255,255,.06);color:var(--text);display:inline-flex;align-items:center;gap:4px}
.card-quiet{border-style:dashed}
.card-body-tight{padding:12px 16px}
.lede-muted{font-size:12px;line-height:1.45;margin:0}
.code-inline{font-family:'SF Mono',Monaco,Consolas,monospace;font-size:11px;background:rgba(255,255,255,.06);padding:1px 5px;border-radius:3px;color:var(--dim)}
.chain-sync-table{font-size:12px}
.chain-sync-table th{vertical-align:bottom}
.chain-sync-table td{vertical-align:top}
.chain-sync-stack{font-size:12px;line-height:1.4}
.chain-sync-stack .dim{font-size:11px}
.card h2::before{content:'▾';margin-right:6px;font-size:10px}
.card.collapsed h2::before{content:'▸'}
.card-body{min-width:0}
.stats-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.stat-chip{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border);border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));font-size:13px;font-variant-numeric:tabular-nums}
.stat-chip .label{color:var(--dim);text-transform:uppercase;letter-spacing:.3px;font-size:11px}
.stat-chip .value{font-weight:600;color:var(--text)}
.metric{display:flex;justify-content:space-between;padding:4px 0;font-size:14px}
.metric .label{color:var(--dim)}.metric .value{font-weight:500;font-variant-numeric:tabular-nums}
.metric .value.large{font-size:24px;font-weight:700;color:var(--text)}
.bar-row{display:flex;align-items:center;gap:8px;padding:3px 0;font-size:13px}
.bar-label{width:90px;text-align:right;color:var(--dim);flex-shrink:0}
.bar-track{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.bar-fill{height:100%;border-radius:3px;transition:width .5s}
.bar-value{width:50px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:8px 6px;border-bottom:2px solid var(--border);color:var(--dim);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.3px}
td{padding:6px;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums}
tr:hover td{background:rgba(255,255,255,.02)}
.tag{display:inline-block;padding:1px 6px;border-radius:3px;font-size:11px;font-weight:500}
.tag-local{background:rgba(34,197,94,.15);color:var(--green)}
.tag-hint{background:rgba(168,85,247,.15);color:var(--purple)}
.tag-rpc{background:rgba(234,179,8,.15);color:var(--yellow)}
.tag-nf{background:rgba(239,68,68,.15);color:var(--red)}
.chain-tag{display:inline-block;padding:1px 6px;border-radius:3px;font-size:11px;font-weight:500;background:rgba(59,130,246,.15);color:var(--blue)}
.tabs{display:flex;gap:4px}
.tab{padding:6px 14px;border-radius:6px;font-size:13px;cursor:pointer;border:none;background:transparent;color:var(--dim);font-weight:500}
.tab.active{background:var(--border);color:var(--text)}
.refresh-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:-1px;margin-bottom:16px;flex-wrap:wrap}
.refresh-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--dim);font-variant-numeric:tabular-nums}
.refresh-bar{flex:1 1 240px;height:2px;background:var(--border);border-radius:1px;overflow:hidden}
.refresh-fill{height:100%;background:var(--blue);transition:width linear}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.pair-cell{font-family:'SF Mono',Monaco,Consolas,monospace;font-size:12px;white-space:nowrap}
.pair-cell .token{color:var(--blue);cursor:default}
.pair-cell .token.known{color:var(--cyan);font-weight:500}
.pair-cell .arrow{color:var(--dim);margin:0 4px;font-size:11px}
.filter-input{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:5px 10px;color:var(--text);font-size:13px;width:160px;outline:none}
.filter-input:focus{border-color:var(--blue)}
.chain-select{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:5px 8px;color:var(--text);font-size:13px;outline:none;cursor:pointer}
.sort-group{display:flex;gap:2px}
.sort-btn{padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer;border:none;background:transparent;color:var(--dim);font-weight:500}
.sort-btn.active{background:var(--border);color:var(--text)}
.sort-btn:hover{color:var(--text)}
.controls-row{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.qps-badge{font-variant-numeric:tabular-nums;color:var(--cyan);font-weight:600}
.dim{color:var(--dim);font-size:12px}
.error-banner{background:rgba(239,68,68,.15);border:1px solid var(--red);border-radius:6px;padding:8px 12px;margin-bottom:12px;font-size:13px;color:var(--red)}
.chain-section{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.chain-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.chip-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.chip{font-size:11px;padding:1px 6px;border-radius:3px;background:rgba(255,255,255,.05);color:var(--dim)}
.coverage-table{font-size:12px}
.coverage-table th{text-align:right;white-space:nowrap}
.coverage-table th:first-child,.coverage-table td:first-child{text-align:left}
.coverage-table td{text-align:right;vertical-align:middle}
.coverage-cell{display:inline-flex;align-items:center;justify-content:flex-end;gap:6px;min-width:52px}
.coverage-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.coverage-dot.ok{background:var(--green)}
.coverage-dot.warn{background:var(--yellow)}
.coverage-dot.bad{background:var(--red)}
.coverage-dot.empty{background:var(--dim);opacity:.45}
.coverage-empty{color:var(--dim)}
.coverage-total td{font-weight:600;border-bottom:none;padding-top:10px}
.section{margin-bottom:24px}
.section-header{display:flex;align-items:center;gap:8px;padding:8px 0;cursor:pointer;border-bottom:1px solid var(--border);margin-bottom:16px}
.section-header h2{font-size:16px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin:0}
.section-header .status-dot{margin-right:0}
.section-toggle{color:var(--dim);font-size:12px;margin-left:auto}
.section.collapsed .section-body{display:none}
.section .grid{margin-bottom:0}
@keyframes pulse{0%,100%{opacity:.35;transform:scale(.9)}50%{opacity:1;transform:scale(1)}}
@media(max-width:768px){
  .metric-grid-2{grid-template-columns:1fr}
  .memory-split{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  body{padding:8px}
  .header{align-items:flex-start;gap:12px;flex-direction:column}
  .header .meta{justify-content:flex-start}
  .refresh-meta{align-items:flex-start}
  .refresh-bar{width:100%;flex-basis:100%}
  .controls-row{flex-direction:column;align-items:stretch}
  .tabs,.sort-group{flex-wrap:wrap}
  .filter-input,.chain-select{width:100%}
  .status-bar{flex-wrap:wrap;gap:8px 12px;padding:8px 12px;align-items:flex-start}
  .status-bar .sb-item{white-space:normal}
  .status-bar .sb-sep{display:none}
}
body{padding-bottom:44px}
.status-bar{position:fixed;bottom:0;left:0;right:0;height:auto;min-height:36px;padding:6px 16px;background:#12141c;border-top:1px solid var(--border);display:flex;align-items:center;gap:20px;font-size:12px;color:var(--dim);z-index:100;font-variant-numeric:tabular-nums}
.status-bar .sb-item{display:flex;align-items:center;gap:4px;white-space:nowrap}
.status-bar .sb-label{color:var(--dim)}
.status-bar .sb-value{color:var(--text);font-weight:500}
.status-bar .sb-sep{width:1px;height:16px;background:var(--border);flex-shrink:0}
.load-ok{color:var(--green)}.load-warn{color:var(--yellow)}.load-high{color:var(--red)}
.trend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.trend-item{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px}
.trend-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;font-size:12px}
.trend-label{color:var(--dim);font-weight:500}.trend-current{font-weight:600;font-variant-numeric:tabular-nums}
.trend-item canvas{width:100%;height:56px;display:block}
.nd-legend{display:inline-flex;gap:10px;font-size:10px;color:var(--dim)}
.nd-legend i{display:inline-block;width:8px;height:2px;border-radius:1px;vertical-align:middle;margin-right:2px}
.liq-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.liq-grid canvas{width:100%;display:block}
.liq-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.liq-grid-2col canvas{width:100%;display:block}
.sync-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px 16px}
.sync-health-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.sync-health-chain{padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:6px}
@media(max-width:900px){.liq-grid{grid-template-columns:1fr}.liq-grid-2col{grid-template-columns:1fr}.sync-detail-grid{grid-template-columns:1fr}}
/* eRPC health card */
.erpc-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;flex-wrap:wrap}
.erpc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.erpc-id{width:160px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}
.erpc-score{display:flex;align-items:center;gap:8px;min-width:150px;flex:1}
.erpc-metric{width:70px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}
@media(max-width:768px){.erpc-id,.erpc-metric{width:auto}.erpc-score{min-width:120px}}
