/* =========================================================================
   cult-visuals.css
   Pictogram + employee-tier visual treatments.
   Uses design tokens from css/design-system.css only.
   ========================================================================= */

/* ---- Pictogram (select-field icon + label) ------------------------------ */

.cult-pictogram {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    line-height: var(--leading-snug);
}

.cult-pictogram__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    color: var(--pic-color);
}

.cult-pictogram__label {
    font-size: var(--text-sm);
    color: var(--color-text);
}

/* ---- Employee tier (icon + name + count) -------------------------------- */

.cult-tier {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius);
    background: color-mix(in srgb, var(--tier-color) 8%, var(--color-surface));
    border: 1px solid color-mix(in srgb, var(--tier-color) 20%, transparent);
    line-height: var(--leading-snug);
}

.cult-tier__icon {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    color: var(--tier-color);
}

.cult-tier__text {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0;
}

.cult-tier__name {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--color-text);
}

.cult-tier__count {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

/* Fallback for browsers without color-mix support */
@supports not (background: color-mix(in srgb, red 50%, blue)) {
    .cult-tier {
        background: var(--color-surface-sunken);
        border-color: var(--color-border);
    }
}

/* ---- Responsive: ensure graceful wrapping in narrow grid columns -------- */

.cult-pictogram,
.cult-tier {
    max-width: 100%;
}

.cult-pictogram__label,
.cult-tier__name,
.cult-tier__count {
    overflow-wrap: break-word;
    word-break: break-word;
}
