/* Button Components */

.btn {
    display: inline-block;
    padding: var(--spacing-sm) var(--spacing-md);
    font-family: var(--font-family-base);
    font-size: var(--font-size-base);
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    border: none;
    background: none;
    box-shadow: none;
    color: var(--color-button-text);
    cursor: pointer;
    transition: color var(--transition-fast);
    user-select: none;
    vertical-align: middle;
}

.btn:hover {
    color: var(--color-link-hover);
}

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

.btn:focus {
    outline: none;
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Button Sizes */
.btn-sm {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.btn-lg {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-md);
}

/* Button Variants */
.btn-primary {
    background-color: var(--color-primary);
    color: var(--color-background);
    border: none;
    box-shadow: none;
}

.btn-primary:hover {
    background-color: var(--color-link-hover);
    color: var(--color-background);
}

.btn-secondary {
    background-color: var(--color-secondary);
    color: var(--color-text-secondary);
    border: none;
    box-shadow: none;
}

.btn-secondary:hover {
    background-color: var(--color-button-hover);
    color: var(--color-text-secondary);
}

.btn-danger {
    background-color: var(--color-error);
    color: var(--color-text-secondary);
    border: none;
    box-shadow: none;
}

.btn-danger:hover {
    background-color: var(--color-error);
    color: var(--color-background);
}

.btn-success {
    background-color: var(--color-success);
    color: var(--color-background);
    border: none;
    box-shadow: none;
}

.btn-success:hover {
    background-color: var(--color-link-hover);
    color: var(--color-background);
}

/* Button Groups */
.btn-group {
    display: inline-flex;
    gap: var(--spacing-sm);
}

.btn-group .btn {
    margin: 0;
}

/* Icon Buttons */
.btn-icon {
    padding: var(--spacing-sm);
    width: auto;
    height: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-icon i {
    font-size: var(--font-size-base);
}
