// ───────────────────────────────────────────────────────────────────────────── // Component: Languages Intel (.ln-* visual) // File: src/scss/components/_languages.scss // // VISUAL RULES ONLY — no layout, no dimensions here. // Layout lives in pages/_languages.scss. // ───────────────────────────────────────────────────────────────────────────── // ── Stat chips ──────────────────────────────────────────────────────────────── .ln-stat-card { background: var(--bg-surface); border: 1px solid var(--border-default); border-radius: 8px; &--files { border-color: color-mix(in srgb, var(--color-teal) 30%, transparent); } &--symbols { border-color: color-mix(in srgb, var(--color-accent) 30%, transparent); } } .ln-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; } .ln-stat-lbl { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); } // ── List header ─────────────────────────────────────────────────────────────── .ln-hd-lang, .ln-hd-bar, .ln-hd-files, .ln-hd-syms { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--text-muted); } // ── Language rows ───────────────────────────────────────────────────────────── .ln-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); } } // ── Language name ───────────────────────────────────────────────────────────── .ln-name { font-size: 0.82rem; font-weight: 600; font-family: var(--font-mono); color: var(--text-primary); } // ── Spectral bar ────────────────────────────────────────────────────────────── .ln-bar-wrap { height: 6px; background: var(--border-default); border-radius: 3px; overflow: hidden; flex: 1; } .ln-bar { height: 100%; background: var(--gradient-spectral); border-radius: 3px; min-width: 2px; transition: width 0.3s ease; } .ln-pct { font-size: 0.68rem; font-family: var(--font-mono); font-weight: 600; color: var(--text-primary); white-space: nowrap; min-width: 3rem; text-align: right; } // ── File / symbol counts ────────────────────────────────────────────────────── .ln-files, .ln-sym-count { font-size: 0.72rem; font-family: var(--font-mono); color: var(--text-secondary); white-space: nowrap; } // ── Kind chips ──────────────────────────────────────────────────────────────── .ln-kinds { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-top: 0.3rem; } .ln-kind-chip { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 0.6rem; font-weight: 700; letter-spacing: 0.04em; padding: 2px 6px; border-radius: 4px; text-transform: lowercase; &--function { background: color-mix(in srgb, var(--color-accent) 15%, transparent); color: var(--color-accent); border: 1px solid color-mix(in srgb, var(--color-accent) 35%, transparent); } &--async-function { background: color-mix(in srgb, var(--color-orange) 15%, transparent); color: var(--color-orange); border: 1px solid color-mix(in srgb, var(--color-orange) 35%, transparent); } &--class { background: color-mix(in srgb, var(--color-purple) 15%, transparent); color: var(--color-purple); border: 1px solid color-mix(in srgb, var(--color-purple) 35%, transparent); } &--method { background: color-mix(in srgb, var(--color-teal) 15%, transparent); color: var(--color-teal); border: 1px solid color-mix(in srgb, var(--color-teal) 35%, transparent); } &--async-method { background: color-mix(in srgb, var(--color-rose) 15%, transparent); color: var(--color-rose); border: 1px solid color-mix(in srgb, var(--color-rose) 35%, transparent); } } .ln-kind-n { color: inherit; opacity: 0.75; font-weight: 600; }