:root{--bg: #f5f6f8;--card: #ffffff;--panel: #f7f8fa;--border: #eceef1;--text: #1f2329;--muted: #8a9099;--green: #16b364;--red: #f5483b;--amber: #f59e0b;--grey: #9aa4af;color:var(--text);background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Roboto,Helvetica,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button{cursor:pointer}.app{width:min(1608px,calc(100% - 48px));min-height:100vh;margin:0 auto;padding:40px 0 56px}.stickytop{position:sticky;top:0;z-index:10;padding-top:20px;background:color-mix(in srgb,var(--bg) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:24px}h1{margin:0 0 8px;font-size:24px;line-height:1.2}.subtitle,.summary,.refresh,.toolbar,.cat-tabs,.badges,.records-head,.records-axis{display:flex;align-items:center}.subtitle{flex-wrap:wrap;gap:8px;color:var(--muted);font-size:13px}.env-badge{border-radius:6px;padding:3px 7px;background:#eef1f5;color:#89919e}.summary{flex-wrap:wrap;justify-content:flex-end;gap:12px;color:#1f2937;font-size:13px}.chip,.cat-tab{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;background:#fff;padding:7px 12px;font-weight:700}.dot{width:7px;height:7px;border-radius:50%}.dot-grey{background:var(--grey)}.dot-green{background:var(--green)}.dot-red{background:var(--red)}.dot-amber{background:var(--amber)}.refresh{gap:10px;color:var(--muted);font-weight:500}.refresh button{border:1px solid var(--border);border-radius:8px;background:#fff;padding:8px 14px;color:#111827}.refresh button:disabled{color:var(--muted);cursor:wait}.error,.empty{border:1px solid #fed7d2;border-radius:10px;background:#fff4f2;padding:12px 14px;color:#c24135;font-size:14px}.toolbar{justify-content:space-between;gap:24px;border-bottom:1px solid var(--border);padding:24px 0 14px}.gsearch{position:relative;width:min(380px,100%)}.gs-icon{position:absolute;left:14px;color:var(--muted)}.gs-input{width:100%;height:36px;border:1px solid var(--border);border-radius:10px;outline:0;padding:0 42px 0 40px;color:#1f2937;background:#fff}.gs-input::placeholder{color:#8a93a2}.clear-search{position:absolute;right:7px;width:24px;height:24px;border:0;border-radius:50%;background:#eef1f5;color:var(--muted)}.cat-tabs{flex-wrap:wrap;justify-content:flex-end;gap:10px}.cat-tab{min-width:72px;border:0;padding:8px 14px;color:var(--muted)}.cat-tab.on{background:var(--green);color:#fff}.cat-count{min-width:20px;border-radius:999px;padding:1px 6px;background:#94a3b82e;font-size:12px}.cat-tab.on .cat-count{background:#ffffff38}.group-section{margin-top:20px}.group-section h2{margin:0 0 12px;font-size:17px;line-height:1.2}.group-section h2 span{display:inline-flex;align-items:center;min-width:22px;height:20px;margin-left:6px;border-radius:999px;padding:0 8px;background:#eef1f5;color:#8a93a2;font-size:12px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:18px}.card{border:1px solid var(--border);border-radius:16px;background:var(--card);padding:18px;box-shadow:0 1px 2px #141e320a;transition:box-shadow .15s ease}.card:hover{box-shadow:0 6px 20px #141e3214}.card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.head-left{display:flex;align-items:center;gap:10px;min-width:0}.logo{display:grid;flex:none;width:34px;height:34px;place-items:center;border-radius:9px;color:#fff;font-size:16px;font-weight:800}.card h3{overflow:hidden;margin:0;font-size:18px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.status-pill{flex:none;border-radius:8px;padding:5px 12px;font-size:13px;font-weight:800}.badges{flex-wrap:wrap;gap:7px;margin-top:14px}.badge{border-radius:7px;padding:4px 9px;font-size:12px}.provider{background:#e9f9f0;color:var(--green)}.model{background:#f1f3f6;color:#8490a2}.group-name{background:#fff2df;color:#d97706}.metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.metrics div{min-height:82px;border-radius:12px;background:var(--panel);padding:13px 14px}.metrics span,.availability span,.records-head,.records-axis{color:#718096;font-size:13px}.metrics strong{display:block;margin-top:8px;color:#111827;font-size:24px;line-height:1.1}small{margin-left:3px;font-size:11px;font-weight:600}.availability{display:flex;align-items:flex-end;justify-content:space-between;border-bottom:1px solid var(--border);padding:18px 0 14px}.availability div{text-align:right}.availability strong{display:block;font-size:26px;line-height:1}.availability small{display:block;margin-top:4px;color:#8a93a2}.records-head{justify-content:space-between;margin-top:14px;font-weight:700}.bars{display:flex;align-items:stretch;gap:2px;height:34px;margin-top:10px}.bar{min-width:2px;flex:1 1 0;border-radius:2px}.b-green,.s-up.logo{background:var(--green)}.b-red,.s-down.logo{background:var(--red)}.b-amber,.s-degraded.logo{background:var(--amber)}.s-grey.logo{background:var(--grey)}.b-empty{background:#e7eaee}.s-up.status-pill{color:var(--green)}.s-down.status-pill{color:var(--red)}.s-degraded.status-pill{color:var(--amber)}.s-grey.status-pill{color:var(--grey)}.av-green{color:var(--green)}.av-amber{color:var(--amber)}.av-red{color:var(--red)}.av-grey{color:var(--grey)}.s-up.status-pill{background:#e9f9f0}.s-down.status-pill{background:#fff0ef}.s-degraded.status-pill{background:#fff4df}.s-grey.status-pill{background:#f0f2f5}.records-axis{justify-content:space-between;margin-top:8px;color:#b3bbc7;font-size:11px}.empty{margin-top:24px;border-color:var(--border);background:#fff;color:var(--muted)}@media(max-width:900px){.app{width:min(100% - 28px,720px);padding-top:24px}.topbar,.toolbar{align-items:stretch;flex-direction:column}.summary,.cat-tabs{justify-content:flex-start}}@media(max-width:480px){.grid{grid-template-columns:1fr}.card{padding:16px}.metrics{grid-template-columns:1fr}}
