/**
 * CORPORATE BLUE THEME - Système de Gestion d'Achats
 * Design moderne et professionnel
 * Version 1.0 - Novembre 2025
 */

/* ============================================
   VARIABLES CSS - CORPORATE BLUE
   ============================================ */

:root {
    /* === COULEURS PRIMAIRES === */
    --primary-50:  #EEF2FF;
    --primary-100: #E0E7FF;
    --primary-200: #C7D2FE;
    --primary-300: #A5B4FC;
    --primary-400: #818CF8;
    --primary-500: #6366F1;   /* Base - Indigo moderne */
    --primary-600: #4F46E5;
    --primary-700: #4338CA;
    --primary-800: #3730A3;
    --primary-900: #312E81;

    /* === COULEURS SUCCÈS === */
    --success-50:  #ECFDF5;
    --success-100: #D1FAE5;
    --success-200: #A7F3D0;
    --success-300: #6EE7B7;
    --success-400: #34D399;
    --success-500: #10B981;
    --success-600: #059669;
    --success-700: #047857;
    --success-800: #065F46;
    --success-900: #064E3B;

    /* === COULEURS AVERTISSEMENT === */
    --warning-50:  #FFF7ED;
    --warning-100: #FFEDD5;
    --warning-200: #FED7AA;
    --warning-300: #FDBA74;
    --warning-400: #FB923C;
    --warning-500: #F59E0B;
    --warning-600: #D97706;
    --warning-700: #B45309;
    --warning-800: #92400E;
    --warning-900: #78350F;

    /* === COULEURS DANGER === */
    --danger-50:   #FEF2F2;
    --danger-100:  #FEE2E2;
    --danger-200:  #FECACA;
    --danger-300:  #FCA5A5;
    --danger-400:  #F87171;
    --danger-500:  #EF4444;
    --danger-600:  #DC2626;
    --danger-700:  #B91C1C;
    --danger-800:  #991B1B;
    --danger-900:  #7F1D1D;

    /* === COULEURS INFO === */
    --info-50:   #EFF6FF;
    --info-100:  #DBEAFE;
    --info-200:  #BFDBFE;
    --info-300:  #93C5FD;
    --info-400:  #60A5FA;
    --info-500:  #3B82F6;
    --info-600:  #2563EB;
    --info-700:  #1D4ED8;
    --info-800:  #1E40AF;
    --info-900:  #1E3A8A;

    /* === COULEURS ACCENT === */
    --accent-500:  #8B5CF6;
    --accent-600:  #7C3AED;
    --accent-700:  #6D28D9;

    /* === GRIS NEUTRES === */
    --gray-50:     #F9FAFB;
    --gray-100:    #F3F4F6;
    --gray-200:    #E5E7EB;
    --gray-300:    #D1D5DB;
    --gray-400:    #9CA3AF;
    --gray-500:    #6B7280;
    --gray-600:    #4B5563;
    --gray-700:    #374151;
    --gray-800:    #1F2937;
    --gray-900:    #111827;

    /* === DARK MODE === */
    --dark-bg-primary:   #0F172A;
    --dark-bg-secondary: #1E293B;
    --dark-bg-tertiary:  #334155;
    --dark-text-primary:   #F1F5F9;
    --dark-text-secondary: #CBD5E1;
    --dark-text-tertiary:  #94A3B8;
    --dark-border: #334155;

    /* === TYPOGRAPHIE === */
    --font-heading: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-mono: 'JetBrains Mono', 'SF Mono', 'Monaco', 'Consolas', monospace;

    /* Tailles */
    --text-xs:     0.75rem;   /* 12px */
    --text-sm:     0.875rem;  /* 14px */
    --text-base:   1rem;      /* 16px */
    --text-lg:     1.125rem;  /* 18px */
    --text-xl:     1.25rem;   /* 20px */
    --text-2xl:    1.5rem;    /* 24px */
    --text-3xl:    1.875rem;  /* 30px */
    --text-4xl:    2.25rem;   /* 36px */
    --text-5xl:    3rem;      /* 48px */

    /* Poids */
    --font-light:   300;
    --font-normal:  400;
    --font-medium:  500;
    --font-semibold: 600;
    --font-bold:    700;
    --font-extrabold: 800;

    /* === ESPACEMENTS === */
    --space-0:  0;
    --space-1:  0.25rem;
    --space-2:  0.5rem;
    --space-3:  0.75rem;
    --space-4:  1rem;
    --space-5:  1.25rem;
    --space-6:  1.5rem;
    --space-8:  2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;

    /* === BORDURES & RADIUS === */
    --radius-sm:   0.375rem;  /* 6px */
    --radius-base: 0.5rem;    /* 8px */
    --radius-md:   0.75rem;   /* 12px */
    --radius-lg:   1rem;      /* 16px */
    --radius-xl:   1.5rem;    /* 24px */
    --radius-2xl:  2rem;      /* 32px */
    --radius-full: 9999px;

    /* === OMBRES === */
    --shadow-sm:    0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-base:  0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md:    0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg:    0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl:    0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-2xl:   0 25px 50px -12px rgb(0 0 0 / 0.25);
    
    --shadow-primary: 0 10px 30px -5px rgba(99, 102, 241, 0.3);
    --shadow-success: 0 10px 30px -5px rgba(16, 185, 129, 0.3);
    --shadow-danger:  0 10px 30px -5px rgba(239, 68, 68, 0.3);

    /* === TRANSITIONS === */
    --duration-fast:   150ms;
    --duration-base:   300ms;
    --duration-slow:   500ms;
    --ease-out: cubic-bezier(0.4, 0, 0.2, 1);

    /* === DÉGRADÉS === */
    --gradient-primary: linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%);
    --gradient-success: linear-gradient(135deg, #10B981 0%, #06B6D4 100%);
    --gradient-sunset:  linear-gradient(135deg, #F59E0B 0%, #EF4444 100%);
    --gradient-ocean:   linear-gradient(135deg, #3B82F6 0%, #06B6D4 100%);
}

/* ============================================
   STYLES DE BASE
   ============================================ */

/* body {
    font-family: var(--font-body);
    color: var(--gray-900);
    background-color: var(--gray-50);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: var(--font-bold);
    line-height: 1.2;
    color: var(--gray-900);
} */

/* ============================================
   BOUTONS MODERNES
   ============================================ */

.btn-modern {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: 0.75rem 1.5rem;
    border-radius: var(--radius-lg);
    font-weight: var(--font-semibold);
    font-size: var(--text-sm);
    transition: all var(--duration-base) var(--ease-out);
    cursor: pointer;
    border: none;
    position: relative;
    overflow: hidden;
}

.btn-modern:active {
    transform: translateY(1px);
}

/* Bouton Principal */
.btn-primary-modern {
    background: var(--gradient-primary);
    color: white;
    box-shadow: var(--shadow-primary);
}

.btn-primary-modern:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 35px -5px rgba(99, 102, 241, 0.45);
}

/* Bouton Secondaire */
.btn-secondary-modern {
    background: white;
    color: var(--primary-600);
    border: 2px solid var(--primary-500);
    box-shadow: var(--shadow-sm);
}

.btn-secondary-modern:hover {
    background: var(--primary-50);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

/* Bouton Succès */
.btn-success-modern {
    background: var(--gradient-success);
    color: white;
    box-shadow: var(--shadow-success);
}

.btn-success-modern:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 35px -5px rgba(16, 185, 129, 0.45);
}

/* Bouton Danger */
.btn-danger-modern {
    background: linear-gradient(135deg, var(--danger-500) 0%, var(--danger-600) 100%);
    color: white;
    box-shadow: var(--shadow-danger);
}

.btn-danger-modern:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 35px -5px rgba(239, 68, 68, 0.45);
}

/* Bouton Ghost */
.btn-ghost-modern {
    background: transparent;
    color: var(--gray-700);
    border: none;
}

.btn-ghost-modern:hover {
    background: var(--gray-100);
    color: var(--gray-900);
}

/* Tailles de boutons */
.btn-sm {
    padding: 0.5rem 1rem;
    font-size: var(--text-xs);
}

.btn-lg {
    padding: 1rem 2rem;
    font-size: var(--text-base);
}

/* ============================================
   CARDS MODERNES
   ============================================ */

.card-modern {
    background: white;
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-base);
    border: 1px solid var(--gray-200);
    transition: all var(--duration-base) var(--ease-out);
}

.card-modern:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-4px);
    border-color: var(--primary-200);
}

/* Card avec header gradient */
.card-gradient-header {
    background: white;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    border: none;
}

.card-gradient-header .card-header {
    background: var(--gradient-primary);
    color: white;
    padding: 1.5rem;
    font-weight: var(--font-bold);
    font-size: var(--text-lg);
}

.card-gradient-header .card-body {
    padding: var(--space-6);
}

/* Card Glass Effect */
.card-glass {
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(12px) saturate(180%);
    -webkit-backdrop-filter: blur(12px) saturate(180%);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.15);
}

/* Card Stat (pour dashboard) */
.card-stat {
    background: white;
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-md);
    border-left: 4px solid var(--primary-500);
    transition: all var(--duration-base) var(--ease-out);
}

.card-stat:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-xl);
    border-left-width: 6px;
}

.card-stat .stat-value {
    font-size: var(--text-4xl);
    font-weight: var(--font-extrabold);
    color: var(--gray-900);
    line-height: 1;
}

.card-stat .stat-label {
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--gray-600);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--space-2);
}

.card-stat .stat-trend {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    margin-top: var(--space-2);
}

.stat-trend.positive {
    color: var(--success-600);
}

.stat-trend.negative {
    color: var(--danger-600);
}

/* ============================================
   INPUTS & FORMS
   ============================================ */

.input-modern {
    width: 100%;
    padding: 0.875rem 1rem;
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-lg);
    font-size: var(--text-sm);
    font-family: var(--font-body);
    color: var(--gray-900);
    background: white;
    transition: all var(--duration-base) var(--ease-out);
}

.input-modern:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1);
}

.input-modern:hover:not(:focus) {
    border-color: var(--gray-400);
}

.input-modern::placeholder {
    color: var(--gray-400);
}

/* Label moderne */
.label-modern {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--gray-700);
    margin-bottom: var(--space-2);
    letter-spacing: 0.025em;
}

/* Select moderne */
.select-modern {
    width: 100%;
    padding: 0.875rem 1rem;
    padding-right: 2.5rem;
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-lg);
    font-size: var(--text-sm);
    color: var(--gray-900);
    background: white;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.75rem center;
    background-repeat: no-repeat;
    background-size: 1.25rem;
    appearance: none;
    transition: all var(--duration-base) var(--ease-out);
}

.select-modern:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1);
}

/* Textarea moderne */
.textarea-modern {
    width: 100%;
    padding: 0.875rem 1rem;
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-lg);
    font-size: var(--text-sm);
    font-family: var(--font-body);
    color: var(--gray-900);
    background: white;
    resize: vertical;
    min-height: 120px;
    transition: all var(--duration-base) var(--ease-out);
}

.textarea-modern:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1);
}

/* Checkbox & Radio modernes */
.checkbox-modern,
.radio-modern {
    width: 1.25rem;
    height: 1.25rem;
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration-base) var(--ease-out);
}

.checkbox-modern:checked,
.radio-modern:checked {
    background-color: var(--primary-500);
    border-color: var(--primary-500);
}

.radio-modern {
    border-radius: var(--radius-full);
}

/* ============================================
   BADGES & TAGS
   ============================================ */

.badge-modern {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 0.375rem 0.875rem;
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    letter-spacing: 0.025em;
    white-space: nowrap;
}

.badge-primary {
    background: var(--primary-100);
    color: var(--primary-700);
    border: 1px solid var(--primary-200);
}

.badge-success {
    background: var(--success-100);
    color: var(--success-700);
    border: 1px solid var(--success-200);
}

.badge-warning {
    background: var(--warning-100);
    color: var(--warning-700);
    border: 1px solid var(--warning-200);
}

.badge-danger {
    background: var(--danger-100);
    color: var(--danger-700);
    border: 1px solid var(--danger-200);
}

.badge-info {
    background: var(--info-100);
    color: var(--info-700);
    border: 1px solid var(--info-200);
}

.badge-gray {
    background: var(--gray-100);
    color: var(--gray-700);
    border: 1px solid var(--gray-200);
}

/* Badge avec point */
.badge-with-dot::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: var(--radius-full);
    background: currentColor;
}

/* ============================================
   TABLES MODERNES
   ============================================ */

.table-modern-wrapper {
    background: white;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--gray-200);
}

.table-modern {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.table-modern thead {
    background: linear-gradient(135deg, var(--gray-50) 0%, var(--gray-100) 100%);
}

.table-modern th {
    padding: 1rem 1.5rem;
    text-align: left;
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    color: var(--gray-600);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--gray-200);
    white-space: nowrap;
}

.table-modern td {
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--gray-100);
    font-size: var(--text-sm);
    color: var(--gray-700);
}

.table-modern tbody tr {
    transition: background-color var(--duration-fast) ease;
}

.table-modern tbody tr:hover {
    background: var(--gray-50);
}

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

/* ============================================
   ALERTES & NOTIFICATIONS
   ============================================ */

.alert-modern {
    padding: 1rem 1.25rem;
    border-radius: var(--radius-lg);
    border-left: 4px solid;
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    font-size: var(--text-sm);
    margin-bottom: var(--space-4);
}

.alert-success {
    background: var(--success-50);
    border-color: var(--success-500);
    color: var(--success-900);
}

.alert-warning {
    background: var(--warning-50);
    border-color: var(--warning-500);
    color: var(--warning-900);
}

.alert-danger {
    background: var(--danger-50);
    border-color: var(--danger-500);
    color: var(--danger-900);
}

.alert-info {
    background: var(--info-50);
    border-color: var(--info-500);
    color: var(--info-900);
}

/* ============================================
   ANIMATIONS
   ============================================ */

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

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

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

.animate-fade-in {
    animation: fadeIn 400ms var(--ease-out);
}

.animate-slide-in {
    animation: slideIn 300ms var(--ease-out);
}

.animate-pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

.animate-spin {
    animation: spin 1s linear infinite;
}

/* ============================================
   UTILITAIRES
   ============================================ */

.transition-smooth {
    transition: all var(--duration-base) var(--ease-out);
}

.shadow-hover:hover {
    box-shadow: var(--shadow-xl);
}

.gradient-text {
    background: var(--gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Conteneur principal */
.main-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: var(--space-6);
}

/* Grid moderne */
.grid-modern {
    display: grid;
    gap: var(--space-6);
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

/* ============================================
   DARK MODE
   ============================================ */

.dark .card-modern {
    background: var(--dark-bg-secondary);
    border-color: var(--dark-border);
    color: var(--dark-text-primary);
}

.dark .input-modern,
.dark .select-modern,
.dark .textarea-modern {
    background: var(--dark-bg-primary);
    border-color: var(--dark-border);
    color: var(--dark-text-primary);
}

.dark .input-modern:focus,
.dark .select-modern:focus,
.dark .textarea-modern:focus {
    border-color: var(--primary-400);
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.2);
}

.dark .table-modern thead {
    background: var(--dark-bg-tertiary);
}

.dark .table-modern th {
    color: var(--dark-text-secondary);
    border-color: var(--dark-border);
}

.dark .table-modern td {
    color: var(--dark-text-primary);
    border-color: var(--dark-border);
}

.dark .table-modern tbody tr:hover {
    background: var(--dark-bg-tertiary);
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 768px) {
    .main-container {
        padding: var(--space-4);
    }
    
    .card-modern {
        padding: var(--space-4);
    }
    
    .btn-modern {
        padding: 0.625rem 1.25rem;
        font-size: var(--text-xs);
    }
    
    .table-modern th,
    .table-modern td {
        padding: 0.75rem 1rem;
    }
}

/* Masquer sur mobile */
@media (max-width: 640px) {
    .hidden-mobile {
        display: none !important;
    }
}

/* Masquer sur desktop */
@media (min-width: 1024px) {
    .hidden-desktop {
        display: none !important;
    }
}

