/* ================================================================
   ENHANCED BUTTON STYLES - Consistent with Cosmo Theme
   ================================================================ */

/* Hover lift effect for interactive cards */
.hover-lift {
    transition: transform var(--transition-smooth), box-shadow var(--transition-smooth);
}

.hover-lift:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-heavy) !important;
}

/* ===== PRIMARY BUTTONS ===== */
.btn-primary {
    background: var(--gradient-primary);
    border: none;
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-smooth);
    position: relative;
    overflow: hidden;
}

.btn-primary:hover,
.btn-primary:focus {
    transform: translateY(-2px);
    box-shadow: var(--shadow-medium);
    background: var(--gradient-primary);
    filter: brightness(1.1);
}

.btn-primary:active {
    transform: translateY(0);
}

/* ===== SUCCESS BUTTONS ===== */
.btn-success {
    background: var(--gradient-success);
    border: none;
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-smooth);
}

.btn-success:hover,
.btn-success:focus {
    transform: translateY(-2px);
    box-shadow: var(--shadow-medium);
    background: var(--gradient-success);
    filter: brightness(1.1);
}

/* ===== WARNING BUTTONS ===== */
.btn-warning {
    background: var(--gradient-warning);
    border: none;
    color: white;
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-smooth);
}

.btn-warning:hover,
.btn-warning:focus {
    transform: translateY(-2px);
    box-shadow: var(--shadow-medium);
    background: var(--gradient-warning);
    filter: brightness(1.1);
    color: white;
}

/* ===== DANGER BUTTONS ===== */
.btn-danger {
    background: var(--gradient-danger);
    border: none;
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-smooth);
}

.btn-danger:hover,
.btn-danger:focus {
    transform: translateY(-2px);
    box-shadow: var(--shadow-medium);
    background: var(--gradient-danger);
    filter: brightness(1.1);
}

/* ===== OUTLINE BUTTONS ===== */
.btn-outline-primary {
    border-color: var(--primary-purple);
    color: var(--primary-purple);
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-smooth);
}

.btn-outline-primary:hover {
    background: var(--gradient-primary);
    border-color: transparent;
    color: white;
    transform: translateY(-2px);
    box-shadow: var(--shadow-medium);
}

.btn-outline-secondary {
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-smooth);
}

.btn-outline-secondary:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-light);
}

.btn-outline-danger {
    font-weight: var(--font-weight-semibold);
    transition: all var(--transition-smooth);
}

.btn-outline-danger:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-light);
}

/* ===== CARD ENHANCEMENTS ===== */
.card {
    border-radius: var(--card-border-radius);
    border: 1px solid var(--border-subtle);
    transition: all var(--transition-smooth);
}

.card-header {
    border-radius: var(--card-border-radius) var(--card-border-radius) 0 0;
    font-weight: var(--font-weight-semibold);
}

/* Cards with gradient headers */
.card-header.gradient-primary {
    background: var(--gradient-primary);
    color: white;
    border: none;
}

.card-header.gradient-success {
    background: var(--gradient-success);
    color: white;
    border: none;
}

.card-header.gradient-warning {
    background: var(--gradient-warning);
    color: white;
    border: none;
}

/* ===== ENHANCED ALERTS ===== */
.alert {
    border-radius: var(--alert-border-radius);
    border: none;
    border-left: var(--alert-border-width) solid;
    padding: var(--alert-padding);
    box-shadow: var(--shadow-light);
}

.alert-primary {
    background-color: rgba(91, 62, 144, 0.1);
    border-left-color: var(--primary-purple);
    color: var(--primary-purple);
}

.alert-success {
    background-color: rgba(63, 182, 24, 0.1);
    border-left-color: var(--cosmo-success);
    color: #2d8a11;
}

.alert-info {
    background-color: rgba(153, 84, 187, 0.1);
    border-left-color: var(--cosmo-info);
    color: #7a3d94;
}

.alert-warning {
    background-color: rgba(255, 117, 24, 0.1);
    border-left-color: var(--cosmo-warning);
    color: #cc5e00;
}

.alert-danger {
    background-color: rgba(255, 0, 57, 0.1);
    border-left-color: var(--cosmo-danger);
    color: #cc002e;
}

.alert-heading {
    font-weight: var(--font-weight-semibold);
}

/* ===== FORM CONTROLS ===== */
.form-control,
.form-select {
    border-radius: var(--input-border-radius);
    border: 1px solid var(--border-subtle);
    transition: all var(--transition-fast);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--input-focus-border);
    box-shadow: 0 0 0 0.25rem rgba(39, 128, 227, 0.15);
}

.form-control-lg {
    padding: var(--btn-padding-lg-y) var(--btn-padding-lg-x);
    font-size: var(--font-size-lg);
}

/* ===== BADGES ===== */
.badge {
    font-weight: var(--font-weight-semibold);
    padding: 0.5em 0.75em;
    border-radius: var(--radius-sm);
}

.badge.bg-primary {
    background: var(--gradient-primary) !important;
}

.badge.bg-success {
    background: var(--gradient-success) !important;
}

.badge.bg-warning {
    background: var(--gradient-warning) !important;
    color: white !important;
}

.badge.bg-danger {
    background: var(--gradient-danger) !important;
}

/* ===== GRADIENT TEXT ===== */
.text-gradient-primary {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ===== UTILITY CLASSES ===== */
.shadow-light {
    box-shadow: var(--shadow-light) !important;
}

.shadow-medium {
    box-shadow: var(--shadow-medium) !important;
}

.shadow-heavy {
    box-shadow: var(--shadow-heavy) !important;
}

/* Rounded corners */
.rounded-card {
    border-radius: var(--card-border-radius) !important;
}

/* ===== RESPONSIVE ADJUSTMENTS ===== */
@media (max-width: 767.98px) {
    .btn-lg {
        padding: var(--btn-padding-y) var(--btn-padding-x);
        font-size: var(--font-size-base);
    }
    
    .card-body {
        padding: 1.25rem !important;
    }
    
    .display-5 {
        font-size: 2rem;
    }
}

/* ===== ACCESSIBILITY ENHANCEMENTS ===== */
.btn:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible {
    outline: 2px solid var(--cosmo-primary);
    outline-offset: 2px;
}

/* ===== LOADING STATES ===== */
.btn.loading {
    position: relative;
    color: transparent;
    pointer-events: none;
}

.btn.loading::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin-left: -8px;
    margin-top: -8px;
    border: 2px solid currentColor;
    border-radius: 50%;
    border-right-color: transparent;
    animation: spinner 0.75s linear infinite;
}

@keyframes spinner {
    to { transform: rotate(360deg); }
}
