.button{
    max-width: fit-content;
    width: 100%;
    padding: var(--sp-s) var(--sp-md);
    border-radius: var(--radius-md);
    background-color: var(--action-default);
    text-decoration: none;
    border: var(--width-1) solid var(--action-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-sm);
    transition: 0.1s ease;
    cursor: pointer;
}

.button .text{
    color: var(--base-white);
}

.button.btn-primary{
    background-color: var(--action-primary);
    color: var(--base-white);
}
.button.btn-primary:hover{
    background-color: var(--action-primary-hover);
}
.button.btn-primary .text{
    color: var(--base-white);
}
.button.btn-primary .icon{
    color: var(--base-white);
    fill: var(--base-white);
}

.button.btn-secondary{
    background-color: var(--base-transparent);
    border-color: var(--action-primary);
}
.button.btn-secondary:hover{
    background-color: var(--action-primary-hover);
}
.button.btn-secondary .text{
    color: var(--action-primary);
}
.button.btn-secondary:hover .text{
    color: var(--base-white);
}
.button.btn-secondary .icon{
    color: var(--action-primary);
    fill: var(--icon-primary);
}
.button.btn-secondary:hover .icon{
    color: var(--base-white);
    fill: var(--base-white);
}

.button.btn-disabled{
    background-color: var(--action-ghost);
    border-color: var(--action-ghost);
}
.button.btn-disabled:hover{
    background-color: var(--action-ghost-hover);
}
.button.btn-disabled .text{
    color: var(--base-white);
}
.button.btn-disabled .icon{
    color: var(--action-ghost);
    fill: var(--icon-muted);
}

