.btn-wrap {
    display: flex;
    flex-flow: row wrap;
    gap: 1rem;
}

.btn {
    position: relative;
    z-index: 1;
    background-color: transparent;
    color: var(--on-background);
    text-decoration: none;
    padding: 0.5rem 1rem;
    border-radius: 1rem;
    transition: border-radius 0.2s ease-out;
}
.btn:hover {
    border-radius: 0.5rem;
}
.btn:focus {
    border-radius: 0.25rem;
}

.btn::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background-color: var(--highlight-color);
    opacity: 0.5;
    z-index: -1;
}
.btn.btn-primary::before {
    opacity: 1;
}
