// ───────────────────────────────────────────────────────────────────────────── // Component: Breakage Intel (.bk-* visual) // File: src/scss/components/_breakage.scss // // VISUAL RULES ONLY — no layout, no dimensions here. // Layout lives in pages/_breakage.scss. // ───────────────────────────────────────────────────────────────────────────── // ── Stat chips ──────────────────────────────────────────────────────────────── .bk-stat-card { background: var(--bg-surface); border: 1px solid var(--border-default); border-radius: 8px; &--total { border-color: color-mix(in srgb, var(--color-accent) 30%, transparent); } &--warning { border-color: color-mix(in srgb, var(--color-orange) 30%, transparent); } &--error { border-color: color-mix(in srgb, var(--color-rose) 30%, transparent); } &--files { border-color: color-mix(in srgb, var(--color-purple) 30%, transparent); } } .bk-stat-val { font-size: 1.35rem; font-weight: 700; font-family: var(--font-mono); background: var(--gradient-spectral); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } .bk-stat-lbl { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); } // ── List header ─────────────────────────────────────────────────────────────── .bk-hd-sev, .bk-hd-file, .bk-hd-desc { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--text-muted); } // ── Issue rows ──────────────────────────────────────────────────────────────── .bk-row { background: var(--bg-page); border-left: 1px solid var(--border-default); border-right: 1px solid var(--border-default); border-bottom: 1px solid var(--border-default); transition: background 0.12s ease; &:first-of-type { border-top: 1px solid var(--border-default); border-radius: 6px 6px 0 0; } &:last-child { border-radius: 0 0 6px 6px; } &:only-child { border-radius: 6px; border-top: 1px solid var(--border-default); } &:hover { background: var(--bg-surface); } } // ── Severity badge ──────────────────────────────────────────────────────────── .bk-sev-badge { display: inline-flex; align-items: center; font-size: 0.6rem; font-weight: 700; letter-spacing: 0.04em; padding: 2px 6px; border-radius: 4px; text-transform: lowercase; white-space: nowrap; // Default (fallback) background: color-mix(in srgb, var(--color-accent) 12%, transparent); color: var(--color-accent); border: 1px solid color-mix(in srgb, var(--color-accent) 30%, transparent); &--warning { background: color-mix(in srgb, var(--color-orange) 12%, transparent); color: var(--color-orange); border-color: color-mix(in srgb, var(--color-orange) 30%, transparent); } &--error { background: color-mix(in srgb, var(--color-rose) 12%, transparent); color: var(--color-rose); border-color: color-mix(in srgb, var(--color-rose) 30%, transparent); } } // ── File path cell ──────────────────────────────────────────────────────────── .bk-file-path { font-size: 0.7rem; font-family: var(--font-mono); color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 600; } // ── Description cell ────────────────────────────────────────────────────────── .bk-description { font-size: 0.68rem; font-family: var(--font-mono); color: var(--text-secondary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }