[data-component="icon"] { display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; /* resize: both; */ aspect-ratio: 1/1; color: var(--icon-base); &[data-size="small"] { width: 16px; height: 16px; } &[data-size="normal"] { width: 20px; height: 20px; } &[data-size="large"] { width: 24px; height: 24px; } [data-slot="svg"] { width: 100%; height: auto; } }