/**
 * SalonSync Theme & Shared Utilities
 * Version: 1.0
 * 
 * Contains shared component variants and high-level theme constructs
 * that are used across multiple applications (Admin, Staff).
 */

/* ========================================
   STAT CARDS
   ======================================== */

.stat-card {
    background: var(--surface-card-muted);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
    transition: var(--transition-all);
    border: 1px solid var(--border-default);
}

.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.stat-card-label {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    margin-bottom: var(--spacing-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: var(--font-weight-semibold);
}

.stat-card-value {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    margin-bottom: var(--spacing-xs);
    line-height: 1.1;
}

.stat-card-change {
    font-size: var(--font-size-sm);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-weight: var(--font-weight-medium);
}

.stat-card-change.positive {
    color: var(--color-success);
}

.stat-card-change.negative {
    color: var(--color-error);
}

/* ========================================
   DATA TABLES
   ======================================== */

.data-table {
    width: 100%;
    background: var(--surface-card);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border-radius: var(--border-radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-default);
}

.data-table table {
    width: 100%;
    border-collapse: collapse;
}

.data-table th {
    background-color: var(--surface-table-header);
    padding: var(--spacing-md) var(--spacing-lg);
    text-align: left;
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    font-size: var(--font-size-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 1px solid var(--border-default);
}

.data-table td {
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--border-subtle);
    color: var(--text-secondary);
    font-size: var(--font-size-sm);
}

.data-table tr:last-child td {
    border-bottom: none;
}

.data-table tr:hover {
    background-color: var(--surface-page);
}

/* ========================================
   TOAST NOTIFICATIONS
   ======================================== */

.toast {
    position: fixed;
    top: 24px;
    right: 24px;
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--border-radius-md);
    box-shadow: var(--shadow-lg);
    font-weight: var(--font-weight-medium);
    z-index: var(--z-index-toast);
    animation: slideIn 0.3s ease-out;
    min-width: 300px;
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    border-left: 4px solid rgba(0, 0, 0, 0.1);
}

.toast-success {
    background-color: var(--color-success);
    color: var(--color-neutral-0);
}

.toast-error {
    background-color: var(--color-error);
    color: var(--color-neutral-0);
}

.toast-info {
    background-color: var(--color-info);
    color: var(--color-neutral-0);
}

.toast-warning {
    background-color: var(--color-warning);
    color: var(--color-warning-text);
}

@keyframes slideIn {
    from {
        transform: translateX(100%);
        opacity: 0;
    }

    to {
        transform: translateX(0);
        opacity: 1;
    }
}
