feat(health): Little Blue health band — avatar, grouped service tiles, local icons
This commit is contained in:
@@ -212,3 +212,31 @@ ul.plain li:last-child { border-bottom: none; }
|
||||
.sv-card:hover .sv-bar > i { box-shadow: 0 0 9px rgba(255,79,46,.55); }
|
||||
.sv-search-input{width:100%;background:#0d0d13;border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);font-family:var(--font-mono);font-size:12px}
|
||||
.sv-run{background:var(--accent-soft);border:1px solid var(--accent-dim);color:var(--accent);border-radius:5px;padding:3px 10px;font-family:var(--font-ui);font-size:11px;cursor:pointer}
|
||||
|
||||
/* ===== Little Blue health band (Task 22) ===== */
|
||||
#sv-health { margin-top: 28px; }
|
||||
.lbwrap { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
|
||||
.lb-av { width: 46px; height: 46px; filter: drop-shadow(0 0 10px rgba(125,211,216,.4)); animation: lb-bob 4s ease-in-out infinite; }
|
||||
@keyframes lb-bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
|
||||
.lb-name { font-family: var(--font-display); letter-spacing: .08em; font-size: 15px; color: var(--text); }
|
||||
.lb-sub { font-family: var(--font-body); font-style: italic; color: var(--lb); font-size: 14px; }
|
||||
.lb-group { margin: 14px 0 8px; display: flex; align-items: center; gap: 10px; }
|
||||
.lb-group .gname { font-family: var(--font-display); text-transform: uppercase; letter-spacing: .14em; font-size: 11px; color: var(--muted); }
|
||||
.lb-group .gcount { font-family: var(--font-mono); font-size: 10px; color: var(--lb); }
|
||||
.lb-group .line { flex: 1; height: 1px; background: linear-gradient(90deg, rgba(125,211,216,.25), transparent); }
|
||||
.tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
|
||||
.tile { display: flex; align-items: center; gap: 10px; border: 1px solid var(--border); border-radius: 8px; padding: 10px 12px;
|
||||
background: linear-gradient(160deg, #14141c, #101017); text-decoration: none; color: var(--text); transition: border-color .25s, transform .25s; }
|
||||
.tile:hover { transform: translateY(-2px); border-color: #37404a; }
|
||||
.tile-icon, .tile-icon-fb { width: 26px; height: 26px; border-radius: 6px; flex: none; }
|
||||
.tile-icon-fb { display: grid; place-items: center; background: #20202a; color: var(--muted); font-family: var(--font-mono); font-size: 13px; }
|
||||
.tile-main { flex: 1; min-width: 0; }
|
||||
.tile-nm { font-family: var(--font-mono); font-size: 12px; display: flex; align-items: center; gap: 7px; }
|
||||
.tile-host { font-family: var(--font-mono); font-size: 10px; color: var(--muted); margin-top: 4px; }
|
||||
.tile .dot { width: 8px; height: 8px; border-radius: 50%; }
|
||||
.tile.status-ok .dot { background: var(--ok); box-shadow: 0 0 7px var(--ok); }
|
||||
.tile.status-warn .dot { background: var(--warn); box-shadow: 0 0 7px var(--warn); }
|
||||
.tile.status-down .dot { background: var(--bad); box-shadow: 0 0 7px var(--bad); }
|
||||
.tile.status-unknown .dot { background: var(--muted); }
|
||||
.tile-go { color: var(--lb); font-size: 11px; opacity: 0; transition: opacity .25s; }
|
||||
.tile:hover .tile-go { opacity: 1; }
|
||||
|
||||
Reference in New Issue
Block a user