// ───────────────────────────────────────────────────────────────────────────── // Component: API Surface (.as-* visual) // File: src/scss/components/_api_surface.scss // // VISUAL RULES ONLY — no layout, no dimensions here. // Layout lives in pages/_api_surface.scss. // ───────────────────────────────────────────────────────────────────────────── // ── Stat cards ──────────────────────────────────────────────────────────────── .as-stat-card { background: var(--bg-surface); border: 1px solid var(--border-default); border-radius: 8px; &--function { border-color: color-mix(in srgb, var(--color-accent) 30%, transparent); } &--async-fn { border-color: color-mix(in srgb, var(--color-orange) 30%, transparent); } &--class { border-color: color-mix(in srgb, var(--color-purple) 30%, transparent); } &--method { border-color: color-mix(in srgb, var(--color-teal) 30%, transparent); } &--async-method{ border-color: color-mix(in srgb, var(--color-rose) 30%, transparent); } } .as-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; } .as-stat-lbl { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-muted); } // ── List header ─────────────────────────────────────────────────────────────── .as-hd-addr, .as-hd-kind, .as-hd-ref { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--text-muted); } // ── Symbol rows ─────────────────────────────────────────────────────────────── .as-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); } } // ── Address ─────────────────────────────────────────────────────────────────── .as-file { font-size: 0.78rem; font-family: var(--font-mono); color: var(--text-muted); } .as-sep { font-size: 0.78rem; font-family: var(--font-mono); color: var(--text-muted); margin: 0 0.1rem; } .as-name { font-size: 0.82rem; font-family: var(--font-mono); font-weight: 600; color: var(--text-primary); } // ── Kind badges ─────────────────────────────────────────────────────────────── .as-kind-badge { display: inline-block; font-size: 0.62rem; font-weight: 700; letter-spacing: 0.05em; padding: 2px 7px; 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); } } // ── Dashboard card kind breakdown ───────────────────────────────────────────── .as-kind-list { list-style: none; margin: 0.5rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 0.35rem; } .as-kind-row { display: grid; grid-template-columns: 8.5rem 1fr auto; align-items: center; gap: 0 0.6rem; } .as-kind-bar-wrap { height: 4px; background: var(--border-default); border-radius: 2px; overflow: hidden; } .as-kind-bar { height: 100%; background: var(--gradient-spectral); border-radius: 2px; min-width: 2px; } .as-kind-count { font-size: 0.68rem; font-family: var(--font-mono); color: var(--text-primary); white-space: nowrap; } .as-kind-pct { color: var(--text-muted); font-size: 0.62rem; } // ── Ref chip ────────────────────────────────────────────────────────────────── .as-ref { font-size: 0.68rem; font-family: var(--font-mono); color: var(--text-muted); opacity: 0.7; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }