.btn,
.public-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;

    border: 0;
    border-radius: 999px;

    padding: 10px 16px;

    font-size: 14px;
    font-weight: 700;
    line-height: 1;

    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;

    transition:
            transform 160ms ease,
            opacity 160ms ease,
            background 160ms ease,
            color 160ms ease;
}

.btn:hover,
.public-btn:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.btn-sm {
    padding: 8px 12px;
    font-size: 13px;
}

.btn-primary,
.public-btn-primary {
    background: var(--color-primary);
    color: #fff;
}

.btn-primary:hover,
.public-btn-primary:hover {
    background: var(--color-primary-hover);
}

.btn-secondary,
.public-btn-secondary {
    background: var(--color-bg-soft);
    color: var(--color-text);
}

.btn-secondary:hover,
.public-btn-secondary:hover {
    opacity: .9;
}

.btn-danger {
    background: #ef4444;
    color: #fff;
}

.btn-danger:hover {
    background: #dc2626;
}

.btn-warning {
    background: #f59e0b;
    color: #fff;
}

.btn-success {
    background: #22c55e;
    color: #fff;
}