/* static/css/components/button.css */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: var(--border-radius-sm); /* Sharp corners for luxury */
    font-family: var(--font-primary);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    border: 1px solid transparent;
    text-align: center;
    text-decoration: none;
}
.btn-large {
    padding: 1.25rem 2.5rem;
    font-size: 0.95rem;
}
.btn.w-full { width: 100%; }

.btn-primary {
    background-color: var(--color-secondary); /* Gold */
    color: var(--color-primary); /* Black text */
    border-color: var(--color-secondary);
}
.btn-primary:hover {
    background-color: transparent;
    color: var(--color-secondary); /* Gold text */
}

.btn-outline {
    background-color: transparent;
    border-color: var(--color-border);
    color: var(--color-text);
}
.btn-outline:hover {
    border-color: var(--color-primary);
    background-color: var(--color-primary);
    color: var(--color-accent);
}

.btn-outline-gold {
    background-color: transparent;
    border-color: var(--color-secondary);
    color: var(--color-secondary);
}
.btn-outline-gold:hover {
    background-color: var(--color-secondary);
    color: var(--color-primary);
}
.mt-2 { margin-top: var(--spacing-md); }
