a.link, a.link:active, a.link:visited { position: relative; color: var(--gray900); text-decoration: none; display: inline-flex; align-items: center; } a.link:before { content: ''; position: absolute; bottom: -2px; width: 0; height: 2px; background: var(--primary400); opacity: 0.5; transition: width 100ms; } a.link:hover:before { width: 100%; transition: width 100ms; } a.link.large { font-size: var(--font-size-large); } a.link.small { font-size: var(--font-size-small); } a.link.xsmall { font-size: var(--font-size-xsmall); } a.link .icon + * { margin-left: 10px; } a.link.iconRight .icon { order: 1; margin-left: 10px; } a.link.iconRight .icon + * { margin: 0; }