
:root {
    /* 1. COMPOSANTES RGB */
    --brand-dark-rgb: 12, 58, 92;
    --brand-primary-rgb: 96, 192, 237;
    --brand-light-rgb: 207, 235, 249;
    --surface-rgb: 242, 250, 254;
    --success-rgb: 88, 217, 178;
    --danger-rgb: 239, 89, 89;

    /* 2. VARIABLES POUR LE CSS PUR */
    --brand-dark: rgb(var(--brand-dark-rgb));
    --brand-primary: rgb(var(--brand-primary-rgb));
    --brand-light-op: rgba(var(--brand-dark-rgb), 0.15);
    --surface: rgb(var(--surface-rgb));
    --success: rgb(var(--success-rgb));
    --danger: rgb(var(--danger-rgb));
    
    --radius-xl: 0.75rem;
    --transition-base: all 0.3s ease-in-out;
    --input-height: 42px;
    --font-main: 'Lato', sans-serif;
}

/* --- FORCE FONT & ALIGNEMENT GLOBAL --- */
body, input, button, select, textarea, .select2-container {
    font-family: var(--font-main) !important;
}

/* Alignement chirurgical des boutons avec icônes */
button, .btn, a.inline-flex {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    vertical-align: middle;
}

button i, a i, .inline-flex i {
    flex-shrink: 0;
    margin-top: -1px; /* Correction optique pour le centrage */
}

/* ==========================================================================
   STRUCTURE & LAYOUT
   ========================================================================== */
.dashboard-layout { display: flex; width: 100vw; overflow-x: hidden; }
.submenu-toggle::after { display: none !important; }

header { z-index: 50 !important; position: relative; }

#sidebar {
    width: 17rem;
    transition: transform 0.3s ease-in-out, width 0.3s ease-in-out;
    z-index: 40 !important;
    position: relative;
    overflow-x: hidden; 
    flex-shrink: 0; 
}

#menuToggle .icon-x { display: none; }
#menuToggle .icon-menu { display: block; }
#menuToggle.is-open:hover .icon-menu { display: none; }
#menuToggle.is-open:hover .icon-x { display: block; }

main { flex-grow: 1; width: 100%; min-width: 0; transition: all 0.3s ease-in-out; }



@media (min-width: 768px) {
    #sidebar.collapsed { width: 80px; }
    #sidebar.collapsed span, 
    #sidebar.collapsed a i:not(:first-child), 
    #sidebar.collapsed .submenu-toggle i:not(:first-child),
    #sidebar.collapsed .submenu-container { display: none !important; }
    #sidebar.collapsed a, #sidebar.collapsed .submenu-toggle { justify-content: center; padding: 0; }
    #sidebar.collapsed i { margin: 0 !important; }
    #sidebar.desktop-hidden { width: 0 !important; min-width: 0 !important; border: none !important; }
}
/* Empêche l'animation au chargement de la page */
.no-transition * {
    -webkit-transition: none !important;
    -moz-transition: none !important;
    -ms-transition: none !important;
    -o-transition: none !important;
    transition: none !important;
}
@media (max-width: 1023.98px) {
    #sidebar {
        width: 100% !important;
        top: 4.5rem !important;
        height: calc(100% - 4.5rem) !important;
        position: fixed !important;
        margin-left: 0 !important;
        
    }
    #sidebar .submenu-toggle span {
        font-size: 1.25rem !important; /* Force le 18px (text-lg) partout sur mobile */
    }
    
    #sidebar .submenu-container a {
        font-size: 1.125rem !important; /* Force le 16px pour les sous-menus */
    }
}

/* ==========================================================================
   COMPOSANTS MODERNES (INPUTS, SELECT2)
   ========================================================================== */

/* --- AUTOMATIC FORM STYLING --- */
input[type="text"], input[type="email"], input[type="password"], 
input[type="number"], input[type="tel"], textarea {
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: var(--radius-xl);
    border: 1px solid var(--brand-light-op) !important;
    background-color: #fff !important;
    color: var(--brand-dark) !important;
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.2s ease-in-out;
    outline: none;
}

input:focus, textarea:focus {
    border-color: var(--brand-primary) !important;
    box-shadow: 0 0 0 4px rgba(var(--brand-primary-rgb), 0.15) !important;
}

input[readonly] { background-color: var(--surface); cursor: not-allowed; }

/* --- SELECT2 STANDARD (FORMS) --- */
.select2-container--default .select2-selection--single {
    background-color: #ffffff !important;
    border: 1px solid var(--brand-light-op) !important;
    border-radius: var(--radius-xl) !important;
    height: var(--input-height) !important;
}

.select2-container--default .select2-selection__rendered {
    color: var(--brand-dark) !important;
    font-weight: 700 !important;
    font-size: 0.875rem !important;
    line-height: 40px !important;
    padding-left: 1rem !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b { display: none !important; }
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100% !important;
    right: 12px !important;
    width: 20px !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230C3A5C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: 16px !important;
}

/* ==========================================================================
   TABLES & DATA DISPLAY
   ========================================================================== */

/* --- SELECT2 DANS LES TABLES (HEADER STYLE) --- */
    .table-header-select + .select2-container .select2-selection--single {
        background-color: transparent !important;
        border: none !important;
        height: auto !important;
        display: flex !important;
        align-items: center !important;
        min-width: 160px !important;
    }

    .table-header-select + .select2-container .select2-selection__rendered {
        color: rgba(var(--brand-dark-rgb), 0.4) !important;
        font-size: 10px !important;
        font-weight: 900 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.05em !important;
        padding: 0 !important;
        white-space: nowrap !important;
    }

    /* Cible uniquement la flèche Select2 quand il suit un .table-header-select */
.table-header-select + .select2-container .select2-selection__arrow {
    opacity: 0.4 !important;
    transition: opacity 0.3s ease; /* Optionnel : pour un hover fluide */
}

/* Optionnel : Remet l'opacité à 100% au survol du wrapper */
#select-wrapper:hover .select2-selection__arrow {
    opacity: 1 !important;
}

/* Hover effect sur le parent du dropdown */
#dropdown-parent:hover .table-header-select + .select2-container .select2-selection__rendered {
    color: var(--brand-primary) !important;
}

/* Dropdown Panel design */
.select2-dropdown {
    border: 1px solid #e5e7eb !important;
    padding: 16px;
    border-radius: 12px !important;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1) !important;
    z-index: 9999 !important;
}

/* --- EMPLOYEE TAGS (INTERACTIFS) --- */
.company-tag {
    transition: var(--transition-base);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    background-color: var(--surface);
    border: 1px solid var(--brand-light-op);
    border-radius: 0.5rem;
    font-size: 10px;
    font-weight: 700;
    color: rgba(var(--brand-dark-rgb), 0.6);
}

.company-tag:hover {
    background-color: #ffffff !important;
    border-color: var(--brand-dark) !important;
    color: var(--brand-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

.company-tag i {
    width: 1rem;
    height: 1rem;
    margin-right: 0.375rem;
    opacity: 0.5;
}

/* ==========================================================================
   SPECIFIC FIXES (FILE INPUTS, LOGO)
   ========================================================================== */
.file-clyo-wrapper {
    display: flex;
    align-items: center;
    padding: 0.25rem 0;
    background: #fff;
    min-height: var(--input-height);
}

.file-clyo-wrapper input[type="file"]::file-selector-button {
    margin-right: 1rem;
    padding: 0.35rem 0.5rem;
    border-radius: 0.5rem;
    background-color: rgba(var(--brand-primary-rgb), 0.1);
    color: var(--brand-primary);
    border: 1px solid rgba(var(--brand-primary-rgb), 0.2);
    font-weight: 900;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    cursor: pointer;
    transition: all 0.2s ease;
}

.file-clyo-wrapper input[type="file"]::file-selector-button:hover {
    background-color: var(--brand-primary);
    color: #fff;
}

/* ==========================================================================
   NOUVEAUX COMPOSANTS (DATE & CHECKBOX UI)
   ========================================================================== */

/* --- DATE PICKERS --- */
input[type="date"],
input[type="datetime-local"] {
    width: 100% !important;
    padding: 0.75rem 1rem !important;
    border-radius: var(--radius-xl) !important;
    border: 1px solid var(--brand-light-op) !important;
    background-color: #fff !important;
    color: var(--brand-dark) !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    transition: var(--transition-base) !important;
    outline: none !important;
    height: var(--input-height) !important;
    cursor: pointer !important;
    -webkit-appearance: none !important; /* Force la suppression du style OS */
}

input[type="date"]:focus,
input[type="datetime-local"]:focus {
    border-color: var(--brand-primary) !important;
    box-shadow: 0 0 0 4px rgba(var(--brand-primary-rgb), 0.15) !important;
}

/* Hack Absolu : Tuer l'icône native du navigateur */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator {
    display: none !important;
    -webkit-appearance: none !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* --- CHECKBOX (UI TOGGLE) --- */
input[type="checkbox"] {
    width: 1.5rem !important;
    height: 1.5rem !important;
    border-radius: 0.375rem !important;
    border: 1px solid var(--brand-light-op) !important;
    background-color: var(--surface) !important;
    cursor: pointer !important;
    transition: var(--transition-base) !important;
    margin: 0 !important;
    -webkit-appearance: none !important;
    appearance: none !important; 
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

input[type="checkbox"]:checked {
    background-color: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E") !important;
    background-size: 70% !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}