/* Base Button Components — BEM
 * Unified button styles using design tokens.
 * Replaces duplicated .btn patterns in dashboard.css, file-management.css, etc.
 */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    height: var(--height-btn);
    padding: 0 var(--space-5);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    font-weight: var(--font-weight-medium);
    line-height: 1;
    border: 1px solid transparent;
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.2s ease;
    white-space: nowrap;
    text-decoration: none;
}

.btn:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

.btn:disabled,
.btn--disabled {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
}

/* --primary: accent-colored action button */
.btn--primary {
    background: var(--color-accent);
    color: white;
    border-color: var(--color-accent);
}

.btn--primary:hover {
    background: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    transform: translateY(-1px);
}

.btn--primary:active {
    background: var(--color-accent-active);
    transform: translateY(0);
}

/* --secondary: subtle bordered button */
.btn--secondary {
    background: var(--color-surface);
    color: var(--color-text-secondary);
    border-color: var(--color-border);
}

.btn--secondary:hover {
    background: var(--color-surface-hover);
    border-color: var(--color-border-strong);
}

.btn--secondary:active {
    background: var(--color-surface-active);
}

/* --danger: destructive action */
.btn--danger {
    background: var(--color-danger);
    color: white;
    border-color: var(--color-danger);
}

.btn--danger:hover {
    background: var(--color-danger-hover);
    border-color: var(--color-danger-hover);
    transform: translateY(-1px);
}

.btn--danger:active {
    transform: translateY(0);
}

/* --ghost: transparent background, text-only */
.btn--ghost {
    background: transparent;
    color: var(--color-text-secondary);
    border-color: transparent;
}

.btn--ghost:hover {
    background: var(--color-surface-hover);
    color: var(--color-text);
}

.btn--ghost:active {
    background: var(--color-surface-active);
}

/* --icon: square icon-only button */
.btn--icon {
    width: var(--height-btn);
    height: var(--height-btn);
    padding: 0;
    background: transparent;
    color: var(--color-text-secondary);
    border-color: transparent;
}

.btn--icon:hover {
    background: var(--color-surface-hover);
    color: var(--color-text);
}

/* --sm: small variant */
.btn--sm {
    height: var(--height-btn-sm);
    padding: 0 var(--space-3);
    font-size: var(--text-sm);
}

.btn--sm.btn--icon {
    width: var(--height-btn-sm);
    height: var(--height-btn-sm);
}

/* --lg: large variant */
.btn--lg {
    height: 2.75rem;
    padding: 0 var(--space-8);
    font-size: var(--text-md);
}
