.btn {
    display: inline-block;
    padding: 0.5rem 1.5rem;
    border-radius: 0.5rem;
    text-align: center;
}

.btn.btn-primary {
    background-color: var(--color-primary);
    color: #fff;
    text-align: center;
    transition: all 0.3s ease;
}
.btn.btn-primary:hover {
    background: var(--color-primary-dark);
    color: #FFFFFF;
    box-shadow: var(--shadow-md);
}
.btn.btn-primary-light {
    background-color: #FFFFFF;
    color: var(--color-primary);
    text-align: center;
    transition: all 0.3s ease;
    border: 1px solid #FFFFFF;
}
.btn.btn-primary-light:hover {
    background: var(--color-primary);
    color: #FFFFFF;
}
.btn.btn-outline {
    background: transparent;
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    transition: all 0.3s ease;
}
.btn.btn-outline svg {
    width: 1rem;
    height: 1rem;
    fill: var(--color-primary);
}
.btn.btn-outline:hover {
    background: var(--color-primary);
    color: #FFFFFF;
    gap: 1rem;
}
.btn.btn-outline-light {
    background: transparent;
    color: #FFFFFF;
    border: 1px solid #FFFFFF;
}
.btn.btn-outline-light:hover {
    background: #FFFFFF;
    color: var(--color-primary) !important;
}
.btn.btn-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    text-decoration: none;
    color: var(--link-color);
    padding:0.5rem 0;
    transition: all 0.3s ease;
    width: fit-content;
}
.btn.btn-link:hover {
    gap: 1rem;
}
.btn.btn-link svg {
    width: 1rem;
    height: 1rem;
    fill: var(--color-primary);
}