.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 12px;
    border: 1px solid transparent;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    transition: background-color 0.18s ease, color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
    white-space: nowrap;
}

.button:hover {
    text-decoration: none;
}

.button-primary {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}

.button-primary:hover {
    background: #fff;
    color: var(--primary);
    border-color: var(--primary);
}

.button-secondary {
    background: #fff;
    color: var(--heading);
    border-color: var(--border);
}

.button-secondary:hover {
    background: var(--surface-muted);
    color: var(--heading);
    border-color: var(--border);
}

.button-outline-primary {
    background: #fff;
    color: var(--primary);
    border-color: var(--primary);
}

.button-outline-primary:hover {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}

.button-danger {
    background: var(--danger);
    color: #fff;
    border-color: var(--danger);
}

.button-danger:hover {
    background: #fff;
    color: var(--danger);
    border-color: var(--danger);
}

.button-outline-danger {
    background: #fff;
    color: var(--danger);
    border-color: var(--danger);
}

.button-outline-danger:hover {
    background: var(--danger);
    color: #fff;
    border-color: var(--danger);
}