/* 
 * Button Styles for BookIt
 * Consistent styling for all buttons across the application
 * Using standard CSS variables for theming
 */

/* Base button styles */
button,
.btn {
    display: inline-block;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    cursor: pointer;
    user-select: none;
    padding: 0.5rem 1rem;
    font-size: 1rem;
    border-radius: var(--border-radius-sm);
    transition: color 0.15s ease-in-out, 
                background-color 0.15s ease-in-out, 
                border-color 0.15s ease-in-out, 
                box-shadow 0.15s ease-in-out;
    border: 1px solid transparent;
}

/* Primary button */
.btn-primary {
    color: var(--light-text-color);
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.btn-primary:hover {
    background-color: color-mix(in srgb, var(--primary-color) 90%, black);
    border-color: color-mix(in srgb, var(--primary-color) 85%, black);
}

.btn-primary:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--primary-color) 25%, transparent);
}

/* Secondary button */
.btn-secondary {
    color: var(--light-text-color);
    background-color: var(--secondary-color);
    border-color: var(--secondary-color);
}

.btn-secondary:hover {
    background-color: color-mix(in srgb, var(--secondary-color) 90%, black);
    border-color: color-mix(in srgb, var(--secondary-color) 85%, black);
}

.btn-secondary:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--secondary-color) 25%, transparent);
}

/* Success button */
.btn-success {
    color: var(--light-text-color);
    background-color: var(--success-color);
    border-color: var(--success-color);
}

.btn-success:hover {
    background-color: var(--success-hover);
    border-color: color-mix(in srgb, var(--success-color) 85%, black);
}

.btn-success:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--success-color) 25%, transparent);
}

/* Danger button */
.btn-danger,
.delete-btn {
    color: var(--light-text-color);
    background-color: var(--error-color);
    border-color: var(--error-color);
}

.btn-danger:hover,
.delete-btn:hover {
    background-color: color-mix(in srgb, var(--error-color) 90%, black);
    border-color: color-mix(in srgb, var(--error-color) 85%, black);
}

.btn-danger:focus,
.delete-btn:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--error-color) 25%, transparent);
}

/* Info button */
.btn-info {
    color: var(--light-text-color);
    background-color: var(--info-color);
    border-color: var(--info-color);
}

.btn-info:hover {
    background-color: color-mix(in srgb, var(--info-color) 90%, white);
    border-color: color-mix(in srgb, var(--info-color) 85%, white);
}

.btn-info:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--info-color) 25%, transparent);
}

/* Warning button */
.btn-warning {
    color: var(--light-text-color);
    background-color: var(--warning-color);
    border-color: var(--warning-color);
}

.btn-warning:hover {
    background-color: color-mix(in srgb, var(--warning-color) 90%, white);
    border-color: color-mix(in srgb, var(--warning-color) 85%, white);
}

.btn-warning:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--warning-color) 25%, transparent);
}

/* Light button */
.btn-light {
    color: var(--text-color);
    background-color: var(--background-color);
    border-color: var(--border-color);
}

.btn-light:hover {
    background-color: color-mix(in srgb, var(--background-color) 90%, black);
    border-color: color-mix(in srgb, var(--border-color) 90%, black);
}

.btn-light:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--background-color) 25%, transparent);
}

/* Dark button */
.btn-dark {
    color: var(--light-text-color);
    background-color: var(--secondary-color);
    border-color: var(--secondary-color);
}

.btn-dark:hover {
    background-color: color-mix(in srgb, var(--secondary-color) 80%, black);
    border-color: color-mix(in srgb, var(--secondary-color) 75%, black);
}

.btn-dark:focus {
    box-shadow: 0 0 0 0.25rem color-mix(in srgb, var(--secondary-color) 25%, transparent);
}

/* Outline buttons */
.btn-outline-primary {
    color: var(--primary-color);
    border-color: var(--primary-color);
    background-color: transparent;
}

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

.btn-outline-secondary {
    color: var(--secondary-color);
    border-color: var(--secondary-color);
    background-color: transparent;
}

.btn-outline-secondary:hover {
    color: var(--light-text-color);
    background-color: var(--secondary-color);
    border-color: var(--secondary-color);
}

/* Specific button styles */
.cancel-btn {
    color: var(--text-color);
    background-color: var(--background-color);
    border-color: var(--border-color);
}

.cancel-btn:hover {
    background-color: color-mix(in srgb, var(--background-color) 90%, black);
}

.save-btn {
    color: var(--light-text-color);
    background-color: var(--primary-color);
    border-color: var(--primary-color);
}

.save-btn:hover {
    background-color: color-mix(in srgb, var(--primary-color) 90%, black);
    border-color: color-mix(in srgb, var(--primary-color) 85%, black);
}

.edit-btn {
    color: var(--text-color);
    background-color: var(--info-color);
    border-color: var(--info-color);
}

.edit-btn:hover {
    background-color: color-mix(in srgb, var(--info-color) 90%, white);
    border-color: color-mix(in srgb, var(--info-color) 85%, white);
}

.add-new-btn {
    color: var(--light-text-color);
    background-color: var(--success-color);
    border-color: var(--success-color);
    margin-bottom: var(--spacing-md);
}

.add-new-btn:hover {
    background-color: var(--success-hover);
    border-color: color-mix(in srgb, var(--success-color) 85%, black);
}

/* Button sizes */
.btn-sm {
    padding: var(--spacing-sm) var(--spacing-sm);
    font-size: 0.875rem;
    border-radius: calc(var(--border-radius-sm) * 0.75);
}

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

/* Disabled state */
button:disabled,
.btn:disabled {
    opacity: 0.65;
    pointer-events: none;
}

/* Button group - for side-by-side buttons */
.btn-group {
    display: flex;
    gap: var(--spacing-sm);
}

/* Action buttons in tables */
.action-buttons {
    display: flex;
    gap: var(--spacing-sm);
}

/* Search bar button styling */
.search-bar button {
    margin-left: var(--spacing-sm);
}

/* Button group */
.button-group {
    display: flex;
    gap: 1rem;
    margin-top: 1rem;
}
