/* GestLocauxTech - Styles v2.1.0 */
/* © 2025-2026 ImmoLabs Pro - Développé par Kevin CROUTSCH */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
    --glt-primary: #1e3a5f;
    --glt-primary-dark: #152a45;
    --glt-primary-light: #2d5a87;
    --glt-accent: #00bcd4;
    --glt-accent-light: #4dd0e1;
    --glt-success: #10b981;
    --glt-warning: #f59e0b;
    --glt-danger: #ef4444;
    --glt-info: #3b82f6;
    --glt-grey-50: #f9fafb;
    --glt-grey-100: #f3f4f6;
    --glt-grey-200: #e5e7eb;
    --glt-grey-300: #d1d5db;
    --glt-grey-400: #9ca3af;
    --glt-grey-500: #6b7280;
    --glt-grey-600: #4b5563;
    --glt-grey-700: #374151;
    --glt-grey-800: #1f2937;
    --glt-grey-900: #111827;
    --glt-sidebar-width: 260px;
    --glt-header-height: 65px;
    --glt-content-max-width: 1000px;
    --glt-border-radius: 12px;
    --glt-border-radius-sm: 8px;
    --glt-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --glt-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --glt-font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Mode sombre */
[data-theme="dark"] {
    --glt-primary: #3b82f6;
    --glt-primary-dark: #2563eb;
    --glt-primary-light: #60a5fa;
    --glt-accent: #22d3ee;
    --glt-accent-light: #67e8f9;
    --glt-success: #34d399;
    --glt-warning: #fbbf24;
    --glt-danger: #f87171;
    --glt-info: #60a5fa;
    --glt-grey-50: #1f2937;
    --glt-grey-100: #1f2937;
    --glt-grey-200: #374151;
    --glt-grey-300: #4b5563;
    --glt-grey-400: #6b7280;
    --glt-grey-500: #9ca3af;
    --glt-grey-600: #d1d5db;
    --glt-grey-700: #e5e7eb;
    --glt-grey-800: #f3f4f6;
    --glt-grey-900: #f9fafb;
    --glt-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
    --glt-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] body,
[data-theme="dark"] .glt-app {
    background: #111827;
    color: #f3f4f6;
}

[data-theme="dark"] .glt-sidebar {
    background: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);
    border-right-color: #374151;
}

[data-theme="dark"] .glt-header {
    background: #1f2937;
    border-bottom-color: #374151;
}

[data-theme="dark"] .glt-card {
    background: #1f2937;
    border-color: #374151;
}

[data-theme="dark"] .glt-modal-container {
    background: #1f2937;
    border-color: #374151;
}

[data-theme="dark"] .glt-modal-header-gradient {
    background: linear-gradient(135deg, #1e3a5f 0%, #3b82f6 100%);
}

[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
    background: #374151;
    border-color: #4b5563;
    color: #f3f4f6;
}

[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
    color: #9ca3af;
}

[data-theme="dark"] .glt-table th {
    background: #374151;
}

[data-theme="dark"] .glt-table td {
    border-color: #374151;
}

[data-theme="dark"] .glt-table tbody tr:hover {
    background: #374151;
}

[data-theme="dark"] .glt-btn-outline {
    border-color: #4b5563;
    color: #d1d5db;
}

[data-theme="dark"] .glt-btn-outline:hover {
    background: #374151;
}

[data-theme="dark"] .glt-search-container {
    background: #1f2937;
}

[data-theme="dark"] .glt-search-input-wrapper {
    border-bottom-color: #374151;
}

[data-theme="dark"] .glt-search-result-item:hover,
[data-theme="dark"] .glt-search-result-item.active {
    background: #374151;
}

[data-theme="dark"] .glt-timeline-content {
    background: #374151;
    border-color: #4b5563;
}

[data-theme="dark"] .glt-apercu-notes {
    background: linear-gradient(135deg, #78350f, #92400e);
}

[data-theme="dark"] .glt-apercu-notes h4,
[data-theme="dark"] .glt-apercu-notes p {
    color: #fef3c7;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

/* ===== LOGIN PAGE ===== */
.glt-login-wrapper {
    display: flex;
    min-height: 100vh;
    background: var(--glt-grey-100);
    font-family: var(--glt-font-family);
}

.glt-login-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 40px;
    max-width: 500px;
}

.glt-login-header {
    text-align: center;
    margin-bottom: 40px;
}

.glt-login-logo {
    width: 90px;
    height: 90px;
    margin: 0 auto 20px;
}

.glt-login-logo-img {
    width: 100%;
    height: 100%;
    border-radius: 20px;
    object-fit: cover;
    box-shadow: var(--glt-shadow-lg);
}

.glt-login-logo .dashicons {
    font-size: 40px;
    color: #fff;
}

.glt-login-header h1 {
    font-size: 28px;
    color: var(--glt-grey-800);
    font-weight: 700;
}

.glt-login-header h1 .glt-logo-accent {
    color: #3b82f6;
}

.glt-login-subtitle {
    color: var(--glt-grey-500);
    margin-top: 8px;
}

.glt-login-form {
    width: 100%;
    max-width: 360px;
}

.glt-login-alert {
    padding: 12px 16px;
    border-radius: var(--glt-border-radius);
    margin-bottom: 20px;
    font-size: 14px;
}

.glt-login-alert.error {
    background: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca;
}

.glt-login-alert.success {
    background: #f0fdf4;
    color: #16a34a;
    border: 1px solid #bbf7d0;
}

.glt-login-field {
    margin-bottom: 20px;
}

.glt-login-field label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--glt-grey-700);
    margin-bottom: 8px;
}

.glt-login-field label .dashicons {
    font-size: 18px;
    color: var(--glt-grey-400);
}

.glt-login-field input {
    width: 100%;
    padding: 14px 16px;
    border: 2px solid var(--glt-grey-200);
    border-radius: 10px;
    font-size: 16px;
    transition: all 0.2s ease;
    background: #fff;
    -webkit-appearance: none;
    appearance: none;
}

.glt-login-field input:focus {
    outline: none;
    border-color: #60a5fa;
    box-shadow: 0 0 0 4px rgba(96, 165, 250, 0.15);
}

.glt-login-field input::placeholder {
    color: #94a3b8;
}

/* Supprimer les styles par défaut du navigateur sur tous les boutons */
.glt-login-btn,
.glt-login-btn:focus,
.glt-login-btn:active,
.glt-pwa-install-btn,
.glt-pwa-instructions-close {
    -webkit-appearance: none;
    appearance: none;
    outline: none !important;
    border: none !important;
}

.glt-login-options {
    margin-bottom: 25px;
}

.glt-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 14px;
    color: var(--glt-grey-600);
}

.glt-checkbox input {
    width: 18px;
    height: 18px;
    accent-color: var(--glt-primary);
}

/* Checkboxes membres CSSCT */
/* Chips pour sélection des membres */
.glt-membres-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px;
    background: var(--glt-grey-50);
    border: 1px solid var(--glt-grey-200);
    border-radius: 8px;
    max-height: 140px;
    overflow-y: auto;
}

.glt-membre-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: #fff;
    border: 2px solid var(--glt-grey-200);
    border-radius: 20px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: var(--glt-grey-600);
    transition: all 0.2s ease;
    user-select: none;
}

.glt-membre-chip:hover {
    border-color: #3b82f6;
    background: #eff6ff;
    color: #3b82f6;
}

.glt-membre-chip .glt-chip-check {
    display: none;
    width: 14px;
    height: 14px;
    background: #3b82f6;
    border-radius: 50%;
    color: #fff;
    align-items: center;
    justify-content: center;
}

.glt-membre-chip.selected {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    border-color: #2563eb;
    color: #fff;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.3);
}

.glt-membre-chip.selected .glt-chip-check {
    display: inline-flex;
    background: rgba(255, 255, 255, 0.3);
}

.glt-membre-chip.selected:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
}

/* Ancien style - conservation pour compatibilité */
.glt-membres-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px;
    background: var(--glt-grey-100);
    border-radius: 6px;
    max-height: 150px;
    overflow-y: auto;
}

.glt-checkbox-label {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: #fff;
    border: 1px solid var(--glt-grey-200);
    border-radius: 20px;
    cursor: pointer;
    font-size: 13px;
    transition: all 0.2s;
}

.glt-checkbox-label:hover {
    border-color: var(--glt-primary);
    background: #f0f9ff;
}

.glt-checkbox-label input {
    width: 16px;
    height: 16px;
    accent-color: var(--glt-primary);
    margin: 0;
}

.glt-checkbox-label input:checked + span {
    font-weight: 600;
    color: var(--glt-primary);
}

/* Toggle switch (opt-in) */
.glt-toggle-label {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    user-select: none;
    position: relative;
}

.glt-toggle-label input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.glt-toggle-switch {
    position: relative;
    width: 50px;
    min-width: 50px;
    height: 26px;
    background: var(--glt-grey-300);
    border-radius: 26px;
    transition: all 0.3s ease;
    flex-shrink: 0;
    display: inline-block;
}

.glt-toggle-switch::before {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    width: 20px;
    height: 20px;
    background: #fff;
    border-radius: 50%;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.glt-toggle-label input:checked + .glt-toggle-switch {
    background: var(--glt-primary);
}

.glt-toggle-label input:checked + .glt-toggle-switch::before {
    transform: translateX(24px);
}

.glt-toggle-label input:focus + .glt-toggle-switch {
    box-shadow: 0 0 0 3px rgba(91, 141, 239, 0.3);
}

.glt-toggle-label:hover .glt-toggle-switch {
    background: var(--glt-grey-400);
}

.glt-toggle-label input:checked:hover + .glt-toggle-switch {
    background: var(--glt-primary-dark, #4a7bd9);
}

/* Checkbox inline */
.glt-checkbox-inline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    padding: 6px 12px;
    background: var(--glt-grey-100);
    border-radius: 6px;
    font-size: 13px;
    transition: all 0.2s ease;
}

.glt-checkbox-inline:hover {
    background: var(--glt-grey-200);
}

.glt-checkbox-inline input:checked + span,
.glt-checkbox-inline:has(input:checked) {
    background: var(--glt-primary);
    color: #fff;
}

.glt-login-btn {
    width: 100%;
    padding: 16px 32px;
    background: linear-gradient(135deg, #5b8def 0%, #4a7bd9 100%);
    color: #fff !important;
    border: none !important;
    outline: none !important;
    border-radius: 12px;
    font-size: 17px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    box-shadow: 0 4px 15px rgba(74, 123, 217, 0.35);
    margin-top: 20px;
    min-height: 56px;
    letter-spacing: 0.5px;
    -webkit-tap-highlight-color: transparent;
    -webkit-appearance: none;
    appearance: none;
}

.glt-login-btn .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
    color: #fff !important;
}

.glt-login-btn .glt-btn-text,
.glt-login-btn span {
    color: #fff !important;
    display: inline !important;
}

.glt-login-btn * {
    color: #fff !important;
}

.glt-login-btn:hover {
    background: linear-gradient(135deg, #6b9bef 0%, #5b8def 100%);
    box-shadow: 0 8px 25px rgba(74, 123, 217, 0.45);
    transform: translateY(-2px);
}

.glt-login-btn:active {
    transform: translateY(0);
    box-shadow: 0 4px 15px rgba(74, 123, 217, 0.35);
}

.glt-login-btn:focus {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(91, 141, 239, 0.3), 0 4px 15px rgba(74, 123, 217, 0.35);
}

.glt-login-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* PWA Install Banner on Login */
.glt-pwa-install-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(135deg, #5b8def, #4a7bd9);
    padding: 14px 18px;
    border-radius: 12px;
    margin-top: 20px;
    color: #fff;
    box-shadow: 0 4px 15px rgba(74, 123, 217, 0.35);
}

.glt-pwa-install-content {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 500;
}

.glt-pwa-install-content .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
}

.glt-pwa-install-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: #fff;
    color: #4a7bd9;
    border: none;
    padding: 10px 18px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    -webkit-tap-highlight-color: transparent;
}

.glt-pwa-install-btn:hover,
.glt-pwa-install-btn:active {
    background: #f0f7ff;
    transform: scale(1.05);
}

.glt-pwa-install-btn .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

/* PWA info on login side */
.glt-login-pwa-info {
    margin-top: 30px;
    padding: 15px;
    background: rgba(255,255,255,0.15);
    border-radius: 10px;
    text-align: center;
}

.glt-login-pwa-info p {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 14px;
}

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

@keyframes glt-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.glt-login-footer {
    margin-top: 40px;
    text-align: center;
    color: var(--glt-grey-500);
    font-size: 13px;
}

.glt-login-version {
    margin-top: 5px;
    font-size: 12px;
    color: var(--glt-grey-400);
}

.glt-login-side {
    flex: 1;
    background: linear-gradient(135deg, var(--glt-primary), var(--glt-primary-light));
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
}

.glt-login-side-content {
    max-width: 400px;
    color: #fff;
}

.glt-login-side-content h2 {
    font-size: 36px;
    margin-bottom: 20px;
}

.glt-login-side-content p {
    font-size: 16px;
    opacity: 0.9;
    line-height: 1.6;
    margin-bottom: 30px;
}

.glt-features-list {
    list-style: none;
}

.glt-features-list li {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 0;
    font-size: 15px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

.glt-features-list li:last-child {
    border-bottom: none;
}

.glt-features-list .dashicons {
    color: var(--glt-accent);
}

@media (max-width: 900px) {
    .glt-login-side {
        display: none;
    }
    
    .glt-login-wrapper {
        min-height: 100vh;
        min-height: -webkit-fill-available;
    }
    
    .glt-login-container {
        width: 100%;
        max-width: 100%;
        padding: 30px 20px;
        display: flex;
        flex-direction: column;
        min-height: 100vh;
        min-height: -webkit-fill-available;
    }
    
    .glt-login-header {
        margin-bottom: 25px;
    }
    
    .glt-login-header h1 {
        font-size: 28px;
    }
    
    .glt-login-logo-img {
        max-width: 100px;
        max-height: 100px;
    }
    
    .glt-login-form {
        flex: 1;
        display: flex;
        flex-direction: column;
    }
    
    .glt-login-field {
        margin-bottom: 15px;
    }
    
    .glt-login-field input {
        font-size: 16px;
        padding: 14px 16px;
    }
    
    .glt-login-options {
        margin-bottom: 15px;
    }
    
    .glt-login-btn {
        margin-top: auto;
        padding: 18px 24px;
        font-size: 18px;
        min-height: 60px;
        position: sticky;
        bottom: 20px;
    }
    
    .glt-pwa-install-banner {
        flex-direction: column;
        gap: 12px;
        text-align: center;
        padding: 15px;
    }
    
    .glt-pwa-install-btn {
        width: 100%;
        justify-content: center;
        padding: 12px 20px;
    }
    
    .glt-login-footer {
        margin-top: 20px;
        padding-bottom: 10px;
    }
}

/* ===== APP LAYOUT ===== */
.glt-app {
    display: flex;
    min-height: 100vh;
    background: var(--glt-grey-100);
    font-family: var(--glt-font-family);
    font-size: 14px;
    color: var(--glt-grey-800);
    line-height: 1.6;
}

/* Sidebar */
.glt-sidebar {
    width: var(--glt-sidebar-width);
    background: var(--glt-primary);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 100;
    transition: transform 0.3s ease;
}

.glt-sidebar-header {
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}

.glt-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #fff;
}

.glt-logo-icon {
    font-size: 22px;
    line-height: 1;
}

.glt-logo-img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    border-radius: 6px;
}

.glt-logo-text {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.5px;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

.glt-logo-accent {
    color: #60a5fa;
    font-weight: 800;
}

.glt-sidebar-toggle {
    display: none;
    background: none;
    border: none;
    color: #fff;
    cursor: pointer;
    padding: 5px;
}

.glt-nav {
    flex: 1;
    padding: 20px 12px;
    overflow-y: auto;
}

.glt-nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    border-radius: var(--glt-border-radius);
    margin-bottom: 4px;
    transition: all 0.2s ease;
    position: relative;
}

.glt-nav-item:hover {
    background: rgba(255,255,255,0.1);
    color: #fff;
}

.glt-nav-item.active {
    background: var(--glt-accent);
    color: #fff;
}

.glt-nav-item .dashicons {
    font-size: 20px;
}

.glt-nav-text {
    font-weight: 500;
}

.glt-nav-badge {
    position: absolute;
    right: 12px;
    background: var(--glt-danger);
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
}

.glt-sidebar-footer {
    padding: 15px;
    border-top: 1px solid rgba(255,255,255,0.1);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.glt-user-info {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

/* Sélecteur de langue à côté du nom utilisateur */
.glt-lang-user {
    margin-left: auto;
    position: relative;
}

.glt-lang-user .glt-lang-current {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s;
}

.glt-lang-user .glt-lang-current:hover {
    background: rgba(255,255,255,0.2);
}

.glt-lang-user .glt-lang-flag {
    font-size: 20px;
    line-height: 1;
}

.glt-lang-user .glt-lang-code,
.glt-lang-user .glt-lang-arrow {
    display: none;
}

.glt-lang-user .glt-lang-dropdown {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: transparent;
    border: none;
    display: none;
    flex-direction: column;
    gap: 6px;
    z-index: 1000;
}

.glt-lang-user.open .glt-lang-dropdown {
    display: flex;
}

.glt-lang-user .glt-lang-option {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    background: rgba(30, 41, 59, 0.95);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s;
}

.glt-lang-user .glt-lang-option:hover {
    background: rgba(59, 130, 246, 0.5);
    transform: scale(1.1);
}

.glt-lang-user .glt-lang-option.active {
    display: none;
}

.glt-lang-user .glt-lang-name {
    display: none;
}

.glt-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.glt-user-details {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex: 1;
}

.glt-user-name {
    color: #fff;
    font-weight: 500;
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.glt-user-role {
    color: rgba(255,255,255,0.6);
    font-size: 11px;
}

.glt-sidebar-actions {
    display: flex;
    justify-content: center;
    gap: 8px;
}

.glt-action-btn {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    border: none;
    background: rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.7);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.glt-action-btn:hover {
    background: rgba(255,255,255,0.2);
    color: #fff;
}

.glt-action-btn-danger:hover {
    background: var(--glt-danger);
    color: #fff;
}

.glt-logout-btn {
    background: rgba(255,255,255,0.1);
    border: none;
    color: rgba(255,255,255,0.7);
    padding: 10px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.glt-logout-btn:hover {
    background: var(--glt-danger);
    color: #fff;
}

/* Main Content */
.glt-main {
    flex: 1;
    margin-left: var(--glt-sidebar-width);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.glt-header {
    height: var(--glt-header-height);
    background: #fff;
    border-bottom: 1px solid var(--glt-grey-200);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 30px;
    position: sticky;
    top: 0;
    z-index: 50;
}

.glt-header-left {
    display: flex;
    align-items: center;
    gap: 15px;
}

.glt-mobile-menu-btn {
    display: none;
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: var(--glt-grey-600);
}

.glt-page-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

/* ===== BOUTON RECHERCHE HEADER ===== */
.glt-search-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px !important;
    border-radius: 8px !important;
    background: var(--glt-grey-100) !important;
    border: 1px solid var(--glt-grey-200) !important;
    color: var(--glt-grey-500) !important;
    cursor: pointer;
    transition: all 0.2s;
}

.glt-search-btn:hover {
    background: var(--glt-grey-200) !important;
    color: var(--glt-grey-700) !important;
}

.glt-search-btn .dashicons {
    font-size: 16px;
}

.glt-search-btn-text {
    font-size: 13px;
}

.glt-search-kbd {
    font-size: 10px;
    padding: 2px 6px;
    background: #fff;
    border: 1px solid var(--glt-grey-300);
    border-radius: 4px;
    color: var(--glt-grey-500);
    font-family: monospace;
}

@media (max-width: 768px) {
    .glt-search-btn-text,
    .glt-search-kbd {
        display: none;
    }
    .glt-search-btn {
        padding: 8px !important;
    }
}

/* ===== MODAL RECHERCHE GLOBALE ===== */
.glt-modal-search .glt-modal-backdrop {
    background: rgba(15, 23, 42, 0.7);
    backdrop-filter: blur(4px);
}

.glt-modal-search .glt-search-container {
    position: relative;
    background: #fff;
    border-radius: 16px;
    max-width: 600px;
    width: 90%;
    max-height: 80vh;
    margin: 10vh auto;
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.3);
    overflow: hidden;
    animation: glt-search-appear 0.2s ease-out;
}

@keyframes glt-search-appear {
    from {
        opacity: 0;
        transform: scale(0.95) translateY(-20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.glt-search-header {
    padding: 0;
    border-bottom: 1px solid var(--glt-grey-200);
}

.glt-search-input-wrapper {
    display: flex;
    align-items: center;
    padding: 16px 20px;
    gap: 12px;
}

.glt-search-input-wrapper .dashicons {
    font-size: 22px;
    color: var(--glt-primary);
    flex-shrink: 0;
}

.glt-search-input-wrapper input {
    flex: 1;
    border: none;
    outline: none;
    font-size: 18px;
    background: transparent;
    color: var(--glt-grey-800);
}

.glt-search-input-wrapper input::placeholder {
    color: var(--glt-grey-400);
}

.glt-search-close-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    background: var(--glt-grey-100);
    border: 1px solid var(--glt-grey-300);
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 13px;
    color: var(--glt-grey-600);
    cursor: pointer;
    transition: all 0.2s;
    flex-shrink: 0;
}

.glt-search-close-btn .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

.glt-search-close-btn:hover {
    background: var(--glt-grey-200);
    color: var(--glt-grey-800);
}

.glt-search-body {
    max-height: calc(80vh - 80px);
    overflow-y: auto;
}

.glt-search-empty {
    padding: 60px 20px;
    text-align: center;
    color: var(--glt-grey-400);
}

.glt-search-empty .dashicons {
    font-size: 48px;
    margin-bottom: 15px;
    opacity: 0.5;
}

.glt-search-empty p {
    font-size: 15px;
    margin-bottom: 20px;
}

.glt-search-hints {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.glt-search-hints span {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-search-hints kbd {
    font-size: 10px;
    padding: 2px 6px;
    background: var(--glt-grey-100);
    border: 1px solid var(--glt-grey-200);
    border-radius: 4px;
    font-family: inherit;
}

/* Résultats de recherche dans le modal */
.glt-search-result-group {
    padding: 10px 0;
    border-bottom: 1px solid var(--glt-grey-100);
}

.glt-search-result-group:last-child {
    border-bottom: none;
}

.glt-search-result-group-title {
    padding: 8px 20px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--glt-grey-500);
    letter-spacing: 0.5px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-search-result-group-title .dashicons {
    font-size: 14px;
}

.glt-search-result-item {
    padding: 12px 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: background 0.15s;
}

.glt-search-result-item:hover,
.glt-search-result-item.active {
    background: var(--glt-grey-50);
}

.glt-search-result-item.active {
    background: linear-gradient(90deg, rgba(30, 58, 95, 0.08), transparent);
}

.glt-search-result-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}

.glt-search-result-icon.local {
    background: linear-gradient(135deg, #3b82f6, #1e40af);
    color: #fff;
}

.glt-search-result-icon.controle {
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff;
}

.glt-search-result-icon.action {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
}

.glt-search-result-content {
    flex: 1;
    min-width: 0;
}

.glt-search-result-title {
    font-weight: 500;
    color: var(--glt-grey-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 14px;
}

.glt-search-result-subtitle {
    font-size: 12px;
    color: var(--glt-grey-500);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 2px;
}

.glt-search-no-results {
    padding: 40px 20px;
    text-align: center;
    color: var(--glt-grey-500);
}

.glt-search-no-results .dashicons {
    font-size: 40px;
    margin-bottom: 10px;
    opacity: 0.5;
}

.glt-search-loading {
    padding: 40px 20px;
    text-align: center;
    color: var(--glt-grey-500);
}

.glt-content {
    flex: 1;
    padding: 30px;
}

.glt-page {
    width: 100%;
}

.glt-footer {
    padding: 15px 30px;
    text-align: center;
    color: var(--glt-grey-500);
    font-size: 13px;
    border-top: 1px solid var(--glt-grey-200);
    background: #fff;
}

.glt-footer p {
    margin: 0;
}

.glt-footer a {
    color: var(--glt-primary);
    text-decoration: none;
    transition: color 0.2s;
}

.glt-footer a:hover {
    color: var(--glt-primary-dark);
    text-decoration: underline;
}

.glt-about-copyright a {
    color: var(--glt-primary);
    text-decoration: none;
}

.glt-about-copyright a:hover {
    text-decoration: underline;
}

/* ===== COMPONENTS ===== */

/* Buttons */
.glt-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    border: none;
    border-radius: var(--glt-border-radius-sm);
    font-size: 14px;
    font-weight: 600;
    font-family: var(--glt-font-family);
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
}

.glt-btn-sm {
    padding: 8px 14px;
    font-size: 13px;
}

.glt-btn-lg {
    padding: 14px 28px;
    font-size: 15px;
}

/* Bouton icône rond - utilisé dans le header */
.glt-btn-icon-round {
    width: 40px;
    height: 40px;
    padding: 0 !important;
    border-radius: 50% !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.glt-btn-icon-round .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
    margin: 0;
}

.glt-btn-primary {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
    border: none !important;
}

.glt-btn-primary:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.45) !important;
}

.glt-btn-secondary {
    background: linear-gradient(135deg, #64748b, #475569) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(100, 116, 139, 0.35) !important;
    border: none !important;
}

.glt-btn-secondary:hover {
    background: linear-gradient(135deg, #475569, #334155) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(100, 116, 139, 0.45) !important;
}

.glt-btn-success {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.35) !important;
    border: none !important;
}

.glt-btn-success:hover {
    background: linear-gradient(135deg, #059669, #047857) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.45) !important;
}

.glt-btn-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(239, 68, 68, 0.35) !important;
    border: none !important;
}

.glt-btn-danger:hover {
    background: linear-gradient(135deg, #dc2626, #b91c1c) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.45);
}

.glt-btn-warning {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
    box-shadow: 0 4px 14px rgba(245, 158, 11, 0.35);
    border: none;
}

.glt-btn-warning:hover {
    background: linear-gradient(135deg, #d97706, #b45309);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(245, 158, 11, 0.45);
}

.glt-btn-outline {
    background: #fff;
    color: #3b82f6;
    border: 2px solid #3b82f6;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.15);
}

.glt-btn-outline:hover {
    background: #3b82f6;
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35);
}

.glt-btn-outline-danger {
    background: #fff;
    color: #ef4444;
    border: 2px solid #ef4444;
    box-shadow: 0 2px 8px rgba(239, 68, 68, 0.15);
}

.glt-btn-outline-danger:hover {
    background: #ef4444;
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(239, 68, 68, 0.35);
}

.glt-btn-outline-success {
    background: #fff;
    color: #10b981;
    border: 2px solid #10b981;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.15);
}

.glt-btn-outline-success:hover {
    background: #10b981;
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.35);
}

.glt-btn-outline-primary {
    background: #fff;
    color: var(--glt-primary);
    border: 2px solid var(--glt-primary);
    box-shadow: 0 2px 4px rgba(30, 58, 95, 0.15);
}

.glt-btn-outline-primary:hover {
    background: var(--glt-primary);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(30, 58, 95, 0.4);
}

/* Boutons Confirm/Cancel pour modals - Design moderne avec dégradés */
.glt-btn.glt-btn-confirm {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
    font-size: 14px;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35);
    transition: all 0.2s ease;
}

.glt-btn.glt-btn-confirm:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.45);
    transform: translateY(-1px);
}

.glt-btn.glt-btn-cancel {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px;
    padding: 14px 28px;
    font-weight: 600;
    font-size: 14px;
    box-shadow: 0 4px 14px rgba(239, 68, 68, 0.35);
    transition: all 0.2s ease;
}

.glt-btn.glt-btn-cancel:hover {
    background: linear-gradient(135deg, #dc2626, #b91c1c) !important;
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.45);
    transform: translateY(-1px);
}

/* Boutons icônes */
.glt-btn-icon {
    width: 32px;
    height: 32px;
    border-radius: 6px;
    border: none;
    background: var(--glt-grey-100);
    color: var(--glt-grey-600);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.glt-btn-icon:hover {
    background: var(--glt-primary);
    color: #fff;
}

.glt-btn-icon-danger:hover {
    background: var(--glt-danger);
    color: #fff;
}

/* Cards */
.glt-card {
    background: #fff;
    border-radius: var(--glt-border-radius);
    box-shadow: var(--glt-shadow);
    overflow: hidden;
}

.glt-card-header {
    padding: 18px 24px;
    border-bottom: 1px solid var(--glt-grey-200);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 15px;
}

.glt-card-header h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--glt-grey-800);
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-card-header h3 .dashicons {
    color: var(--glt-primary);
}

.glt-card-body {
    padding: 24px;
}

.glt-card-danger .glt-card-header {
    background: linear-gradient(135deg, #fee2e2, #fecaca);
    border-bottom-color: #fca5a5;
}

.glt-card-danger .glt-card-header h3 {
    color: #991b1b;
}

.glt-card-danger .glt-card-header h3 .dashicons {
    color: #dc2626;
}

.glt-card-success .glt-card-header {
    background: linear-gradient(135deg, #d1fae5, #a7f3d0);
    border-bottom-color: #6ee7b7;
}

.glt-card-success .glt-card-header h3 {
    color: #065f46;
}

.glt-card-success .glt-card-header h3 .dashicons {
    color: #059669;
}

.glt-card-header-warning {
    background: linear-gradient(135deg, #fef3c7, #fde68a) !important;
    border-bottom-color: #fcd34d !important;
}

.glt-card-header-warning h3 {
    color: #92400e !important;
}

.glt-card-header-warning h3 .dashicons {
    color: #d97706 !important;
}

.glt-card-header-success {
    background: linear-gradient(135deg, #d1fae5, #a7f3d0) !important;
    border-bottom-color: #6ee7b7 !important;
}

.glt-card-header-success h3 {
    color: #065f46 !important;
}

.glt-card-header-success h3 .dashicons {
    color: #059669 !important;
}

.glt-table-compact {
    font-size: 13px;
}

.glt-table-compact th,
.glt-table-compact td {
    padding: 8px 12px;
}

.glt-row-past {
    opacity: 0.6;
    background: var(--glt-grey-50);
}

.glt-badge-grey {
    background: var(--glt-grey-200);
    color: var(--glt-grey-600);
}

.glt-help-text {
    display: block;
    margin-top: 5px;
    font-size: 12px;
    color: var(--glt-grey-500);
}

/* Alerts */
.glt-alert {
    padding: 12px 15px;
    border-radius: var(--glt-border-radius);
    font-size: 14px;
}

.glt-alert-success {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}

.glt-alert-warning {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}

.glt-alert-danger {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

/* Diagnostic */
.glt-row-error {
    background: #fee2e2 !important;
}

.glt-row-highlight {
    background: #e0f2fe !important;
}

.glt-text-danger {
    color: var(--glt-danger);
}

.glt-btn-warning {
    background: var(--glt-warning);
    color: #1a1a1a;
}

.glt-btn-warning:hover {
    background: #e6b800;
}

/* Stats */
.glt-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
    margin-bottom: 30px;
}

.glt-stat-card {
    background: #fff;
    border-radius: var(--glt-border-radius);
    padding: 24px;
    display: flex;
    align-items: center;
    gap: 18px;
    box-shadow: var(--glt-shadow);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.glt-stat-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--glt-shadow-lg);
}

.glt-stat-icon {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.glt-stat-icon .dashicons {
    font-size: 28px;
    color: #fff;
}

.glt-stat-blue .glt-stat-icon { background: linear-gradient(135deg, #3b82f6, #60a5fa); }
.glt-stat-green .glt-stat-icon { background: linear-gradient(135deg, #10b981, #34d399); }
.glt-stat-purple .glt-stat-icon { background: linear-gradient(135deg, #8b5cf6, #a78bfa); }
.glt-stat-orange .glt-stat-icon { background: linear-gradient(135deg, #f59e0b, #fbbf24); }

.glt-stat-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--glt-grey-800);
    display: block;
}

.glt-stat-label {
    font-size: 13px;
    color: var(--glt-grey-500);
}

/* Grid */
.glt-row {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.glt-col-6 {
    flex: 1 1 calc(50% - 10px);
    min-width: 0;
}

.glt-col-4 {
    flex: 1 1 calc(33.333% - 14px);
    min-width: 0;
}

.glt-col-8 {
    flex: 1 1 calc(66.666% - 7px);
    min-width: 0;
}

.glt-col-12 {
    flex: 1 1 100%;
    min-width: 0;
}

/* Fix pour les champs date - même apparence que les selects */
.glt-field input[type="date"] {
    width: 100% !important;
    box-sizing: border-box !important;
    height: 44px !important;
    padding: 10px 14px !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Assurer que les inputs et selects ont la même hauteur */
.glt-field input,
.glt-field select {
    height: 44px;
    box-sizing: border-box;
}

.glt-field textarea {
    box-sizing: border-box;
}

/* Colonnes 50/50 sur desktop */
.glt-row > .glt-col-6 {
    flex: 0 0 calc(50% - 10px);
    max-width: calc(50% - 10px);
}

.glt-row > .glt-col-4 {
    flex: 0 0 calc(33.333% - 14px);
    max-width: calc(33.333% - 14px);
}

.glt-row > .glt-col-8 {
    flex: 0 0 calc(66.666% - 7px);
    max-width: calc(66.666% - 7px);
}

.glt-row > .glt-col-12 {
    flex: 0 0 100%;
    max-width: 100%;
}

@media (max-width: 600px) {
    .glt-row {
        flex-direction: column;
        gap: 15px;
    }
    
    .glt-col-4,
    .glt-col-6,
    .glt-col-8,
    .glt-col-12,
    .glt-row > .glt-col-4,
    .glt-row > .glt-col-6,
    .glt-row > .glt-col-8,
    .glt-row > .glt-col-12 {
        flex: 1 1 100%;
        max-width: 100%;
    }
}

/* Tables */
.glt-table-wrapper {
    overflow-x: auto;
}

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

.glt-table th,
.glt-table td {
    padding: 14px 16px;
    text-align: left;
    border-bottom: 1px solid var(--glt-grey-200);
}

.glt-table th {
    background: var(--glt-grey-50);
    font-weight: 600;
    color: var(--glt-grey-600);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.glt-table tr:hover td {
    background: var(--glt-grey-50);
}

.glt-checkbox-col {
    width: 40px;
    text-align: center;
}

.glt-actions {
    display: flex;
    gap: 6px;
}

/* Progress */
.glt-progress {
    height: 8px;
    background: var(--glt-grey-200);
    border-radius: 4px;
    overflow: hidden;
    width: 100px;
    display: inline-block;
    vertical-align: middle;
}

.glt-progress-bar {
    height: 100%;
    border-radius: 4px;
    transition: width 0.3s ease;
}

.glt-progress-green { background: var(--glt-success); }
.glt-progress-orange { background: var(--glt-warning); }
.glt-progress-red { background: var(--glt-danger); }

.glt-progress-text {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin-left: 10px;
}

/* Badges */
.glt-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

.glt-badge-green { background: #d1fae5; color: #065f46; }
.glt-badge-orange { background: #fef3c7; color: #92400e; }
.glt-badge-red { background: #fee2e2; color: #991b1b; }
.glt-badge-grey { background: var(--glt-grey-200); color: var(--glt-grey-600); }
.glt-badge-blue { background: #dbeafe; color: #1e40af; }
.glt-badge-purple { background: #ede9fe; color: #5b21b6; }

/* Référentiels */
.glt-ref-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

@media (max-width: 1200px) {
    .glt-ref-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .glt-ref-grid {
        grid-template-columns: 1fr;
    }
}

.glt-ref-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 400px;
    overflow-y: auto;
}

.glt-ref-item {
    display: flex;
    align-items: center;
    padding: 12px 14px;
    background: var(--glt-grey-50);
    border-radius: var(--glt-border-radius-sm);
    transition: all 0.2s ease;
}

.glt-ref-item:hover {
    background: var(--glt-grey-100);
    transform: translateX(4px);
}

.glt-ref-info {
    flex: 1;
    min-width: 0;
}

.glt-ref-name {
    font-weight: 600;
    color: var(--glt-grey-800);
    display: block;
}

.glt-ref-parent {
    font-size: 11px;
    color: var(--glt-grey-500);
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 2px;
}

.glt-ref-parent .dashicons {
    font-size: 12px;
    width: 12px;
    height: 12px;
}

.glt-ref-count {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin-right: 15px;
    padding: 4px 10px;
    background: var(--glt-grey-200);
    border-radius: 12px;
}

.glt-ref-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
}

/* Cascade Selects */
.glt-cascade-selects {
    display: flex;
    align-items: flex-end;
    gap: 10px;
    padding: 20px;
    background: var(--glt-grey-50);
    border-radius: var(--glt-border-radius);
    margin-bottom: 20px;
}

.glt-cascade-selects .glt-field {
    flex: 1;
    margin-bottom: 0;
}

.glt-cascade-selects label {
    display: flex;
    align-items: center;
    gap: 6px;
}

.glt-cascade-selects label .dashicons {
    font-size: 16px;
    color: var(--glt-primary);
}

.glt-cascade-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 40px;
    color: var(--glt-grey-400);
}

.glt-cascade-arrow .dashicons {
    font-size: 24px;
}

@media (max-width: 900px) {
    .glt-cascade-selects {
        flex-direction: column;
        align-items: stretch;
    }
    
    .glt-cascade-arrow {
        transform: rotate(90deg);
        height: 20px;
    }
}

.glt-info-box {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 20px;
    background: #dbeafe;
    border-radius: var(--glt-border-radius);
    margin-top: 25px;
    border-left: 4px solid #2563eb;
}

.glt-info-box .dashicons {
    color: #2563eb;
    font-size: 20px;
    margin-top: 2px;
}

.glt-info-box p {
    margin: 0;
    color: #1e40af;
    font-size: 14px;
    line-height: 1.5;
}

.required {
    color: var(--glt-danger);
}

/* Toolbar */
.glt-toolbar {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.glt-search-box {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    padding: 10px 16px;
    border-radius: var(--glt-border-radius);
    border: 1px solid var(--glt-grey-200);
    flex: 1;
    min-width: 200px;
    max-width: 350px;
}

.glt-search-box .dashicons {
    color: var(--glt-grey-400);
}

.glt-search-box input {
    border: none;
    outline: none;
    flex: 1;
    font-size: 14px;
}

.glt-filters select {
    padding: 10px 16px;
    border: 1px solid var(--glt-grey-200);
    border-radius: var(--glt-border-radius);
    font-size: 14px;
    background: #fff;
    min-width: 160px;
}

/* Activity List */
.glt-activity-list {
    list-style: none;
}

.glt-activity-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 14px 0;
    border-bottom: 1px solid var(--glt-grey-100);
}

.glt-activity-item:last-child {
    border-bottom: none;
}

.glt-activity-icon {
    width: 40px;
    height: 40px;
    background: var(--glt-grey-100);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--glt-grey-500);
}

.glt-activity-title {
    display: block;
    font-weight: 500;
    color: var(--glt-grey-800);
}

.glt-activity-date {
    font-size: 12px;
    color: var(--glt-grey-500);
}

/* Territoire Blocks */
.glt-territoire-block {
    background: #fff;
    border-radius: var(--glt-border-radius);
    margin-bottom: 15px;
    box-shadow: var(--glt-shadow);
    overflow: hidden;
}

.glt-territoire-header {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    background: var(--glt-grey-50);
    border: none;
    cursor: pointer;
    text-align: left;
    transition: background 0.2s ease;
}

.glt-territoire-header:hover {
    background: var(--glt-grey-100);
}

.glt-territoire-chevron {
    transition: transform 0.2s ease;
    color: var(--glt-grey-400);
}

.glt-territoire-block.collapsed .glt-territoire-chevron {
    transform: rotate(-90deg);
}

.glt-territoire-block.collapsed .glt-territoire-content {
    display: none;
}

.glt-territoire-name {
    flex: 1;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-territoire-count {
    font-size: 12px;
    color: var(--glt-grey-500);
    background: var(--glt-grey-200);
    padding: 4px 10px;
    border-radius: 12px;
}

.glt-territoire-content {
    padding: 0;
}

.glt-secteur-block {
    padding: 0 20px 20px;
}

.glt-secteur-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--glt-primary);
    margin: 15px 0 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--glt-grey-200);
}

/* Empty States */
.glt-empty,
.glt-empty-state {
    text-align: center;
    padding: 40px;
    color: var(--glt-grey-500);
}

.glt-empty-state .dashicons {
    font-size: 48px;
    color: var(--glt-grey-300);
    margin-bottom: 15px;
}

/* Year Selector */
.glt-year-selector {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 20px;
    padding: 15px 20px;
    background: #fff;
    border-radius: var(--glt-border-radius);
    box-shadow: var(--glt-shadow);
    flex-wrap: wrap;
}

.glt-year-selector label {
    font-weight: 600;
    color: var(--glt-grey-700);
}

.glt-year-selector select {
    padding: 8px 16px;
    border: 1px solid var(--glt-grey-300);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    background: #fff;
    cursor: pointer;
}

.glt-year-comparison {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-left: auto;
}

.glt-year-prev,
.glt-year-next {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    padding: 6px 12px;
    border-radius: 20px;
}

.glt-year-prev {
    background: #fef3c7;
    color: #92400e;
}

.glt-year-next {
    background: #dbeafe;
    color: #1e40af;
}

.glt-year-current {
    font-size: 15px;
    font-weight: 700;
    color: var(--glt-primary);
    padding: 6px 16px;
    background: #f0f9ff;
    border-radius: 20px;
}

.glt-trend-up {
    color: var(--glt-success);
}

.glt-trend-down {
    color: var(--glt-danger);
}

/* Widget Config Button */
.glt-widget-config-btn {
    padding: 8px !important;
}

.glt-widget-config-btn .dashicons {
    transition: transform 0.3s ease;
}

.glt-widget-config-btn:hover .dashicons {
    transform: rotate(90deg);
}

.glt-widget-menu-header {
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-widget-menu-header .dashicons {
    color: var(--glt-primary);
}


/* Direction Cards */
.glt-direction-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 20px;
}

.glt-direction-card {
    background: #fff;
    border-radius: var(--glt-border-radius);
    box-shadow: var(--glt-shadow);
    overflow: hidden;
    border-top: 4px solid var(--glt-warning);
}

.glt-direction-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 20px;
    background: linear-gradient(to bottom, #fefce8, #fff);
}

.glt-direction-card-info h4 {
    margin: 0 0 8px 0;
    font-size: 16px;
    color: var(--glt-grey-800);
}

.glt-direction-card-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-direction-card-meta span {
    display: flex;
    align-items: center;
    gap: 5px;
}

.glt-direction-card-meta .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

.glt-direction-card-score {
    flex-shrink: 0;
}

.glt-score-circle {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: bold;
}

.glt-score-circle.green { background: linear-gradient(135deg, #28a745, #20c997); }
.glt-score-circle.orange { background: linear-gradient(135deg, #ffc107, #fd7e14); }
.glt-score-circle.red { background: linear-gradient(135deg, #dc3545, #e83e8c); }

.glt-score-circle .value {
    font-size: 20px;
    line-height: 1;
}

.glt-score-circle .label {
    font-size: 10px;
    opacity: 0.9;
}

.glt-direction-card-resume {
    padding: 12px 20px;
    background: #fef3c7;
    font-size: 13px;
    color: var(--glt-grey-700);
    border-top: 1px solid #fde68a;
}

.glt-direction-card-issues {
    padding: 10px 20px;
    background: #fee2e2;
    font-size: 13px;
    color: #991b1b;
    display: flex;
    align-items: center;
    gap: 8px;
    border-top: 1px solid #fecaca;
}

.glt-direction-card-actions {
    display: flex;
    gap: 10px;
    padding: 15px 20px;
    background: var(--glt-grey-50);
    border-top: 1px solid var(--glt-grey-200);
}

.glt-direction-card-actions .glt-btn {
    flex: 1;
    justify-content: center;
}

/* Direction Modal */
.glt-modal-xlarge .glt-modal-container {
    max-width: 900px;
    max-height: 90vh;
}

.glt-modal-xlarge .glt-modal-body {
    max-height: calc(90vh - 140px);
    overflow-y: auto;
}

.glt-direction-modal-header-info {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 20px;
    background: linear-gradient(135deg, #1e3a5f, #2d5a87);
    border-radius: 10px;
    color: #fff;
    margin-bottom: 20px;
}

.glt-direction-modal-local h3 {
    margin: 0 0 10px 0;
    font-size: 18px;
}

.glt-direction-modal-meta {
    display: flex;
    gap: 15px;
    font-size: 13px;
    opacity: 0.9;
}

.glt-direction-modal-meta span {
    display: flex;
    align-items: center;
    gap: 5px;
}

.glt-direction-modal-score {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: bold;
    flex-shrink: 0;
}

.glt-direction-modal-score.green { background: rgba(40, 167, 69, 0.9); }
.glt-direction-modal-score.orange { background: rgba(255, 193, 7, 0.9); }
.glt-direction-modal-score.red { background: rgba(220, 53, 69, 0.9); }

.glt-direction-modal-score .value {
    font-size: 28px;
    line-height: 1;
}

.glt-direction-modal-score .label {
    font-size: 12px;
    opacity: 0.9;
}

.glt-direction-modal-resume {
    background: #fef3c7;
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 15px;
    font-size: 13px;
    border-left: 4px solid #f59e0b;
}

.glt-direction-modal-comment {
    background: var(--glt-grey-50);
    padding: 15px;
    border-radius: 8px;
    margin-bottom: 20px;
    font-size: 13px;
    border-left: 4px solid var(--glt-grey-400);
}

.glt-direction-modal-checklist {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.glt-direction-modal-item {
    background: var(--glt-grey-50);
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--glt-grey-200);
}

.glt-direction-modal-item.has-issue {
    background: #fef2f2;
    border-color: #fecaca;
}

.glt-direction-modal-item-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 15px;
    background: #fff;
    border-bottom: 1px solid var(--glt-grey-200);
}

.glt-direction-modal-item.has-issue .glt-direction-modal-item-header {
    background: #fee2e2;
    border-color: #fecaca;
}

.glt-direction-modal-item-status {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 14px;
    flex-shrink: 0;
}

.glt-direction-modal-item-status.ok {
    background: var(--glt-success);
    color: #fff;
}

.glt-direction-modal-item-status.nok {
    background: var(--glt-danger);
    color: #fff;
}

.glt-direction-modal-item-status.na {
    background: var(--glt-grey-400);
    color: #fff;
}

.glt-direction-modal-item-label {
    font-weight: 500;
    color: var(--glt-grey-800);
}

.glt-direction-modal-photos {
    display: flex;
    gap: 15px;
    padding: 15px;
    background: #fff;
    border-bottom: 1px solid var(--glt-grey-200);
}

.glt-direction-modal-photo {
    display: block;
    text-decoration: none;
    text-align: center;
}

.glt-direction-modal-photo img {
    width: 150px;
    height: 100px;
    object-fit: cover;
    border-radius: 8px;
    border: 2px solid var(--glt-grey-200);
    transition: border-color 0.2s;
}

.glt-direction-modal-photo:hover img {
    border-color: var(--glt-primary);
}

.glt-direction-modal-photo span {
    display: block;
    font-size: 11px;
    color: var(--glt-grey-500);
    margin-top: 5px;
}

.glt-direction-modal-cssct-comment {
    padding: 12px 15px;
    background: #fff;
    font-size: 13px;
    color: var(--glt-grey-600);
    font-style: italic;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    border-bottom: 1px solid var(--glt-grey-200);
}

.glt-direction-modal-cssct-comment .dashicons {
    color: var(--glt-primary);
    flex-shrink: 0;
}

.glt-direction-modal-response {
    padding: 15px;
}

.glt-direction-modal-response-row {
    margin-bottom: 10px;
}

.glt-direction-modal-response-row:last-child {
    margin-bottom: 0;
}

.glt-direction-modal-response-row label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--glt-grey-500);
    margin-bottom: 5px;
}

.glt-direction-modal-select {
    width: 100%;
    max-width: 250px;
    padding: 8px 12px;
    border: 1px solid var(--glt-grey-300);
    border-radius: 6px;
    font-size: 13px;
}

.glt-direction-modal-textarea {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid var(--glt-grey-300);
    border-radius: 6px;
    font-size: 13px;
    resize: vertical;
}

.glt-direction-modal-global {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 2px solid var(--glt-grey-200);
}

.glt-direction-modal-global label {
    display: block;
    margin-bottom: 10px;
    color: var(--glt-grey-700);
}

.glt-direction-modal-global textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--glt-grey-300);
    border-radius: 8px;
    font-size: 14px;
    resize: vertical;
}

.glt-direction-modal-section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 15px;
    margin: 0;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px 8px 0 0;
    color: #991b1b;
    font-size: 14px;
    font-weight: 600;
}

.glt-direction-modal-section-title.glt-direction-modal-section-ok {
    background: var(--glt-grey-100);
    border-color: var(--glt-grey-300);
    color: var(--glt-grey-600);
    margin-top: 20px;
    border-radius: 8px;
}

.glt-direction-modal-items-ok {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 8px;
    padding: 15px;
    background: var(--glt-grey-50);
    border: 1px solid var(--glt-grey-200);
    border-top: none;
    border-radius: 0 0 8px 8px;
}

.glt-direction-modal-item-compact {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: #fff;
    border-radius: 6px;
    font-size: 13px;
    color: var(--glt-grey-600);
}

.glt-direction-modal-item-compact .glt-direction-modal-item-status {
    width: 20px;
    height: 20px;
    font-size: 11px;
}

/* Locked control indicator */
.glt-controle-locked {
    opacity: 0.7;
}

.glt-locked-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: #fee2e2;
    color: #991b1b;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
    margin-left: 10px;
}

.glt-locked-badge .dashicons {
    font-size: 12px;
    width: 12px;
    height: 12px;
}

/* View Controle Modal */
.glt-view-controle-header h3 {
    display: flex;
    align-items: center;
    font-size: 18px;
    margin: 0 0 15px 0;
}

.glt-view-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    margin-bottom: 15px;
}

.glt-view-meta p {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--glt-grey-600);
}

.glt-view-meta .dashicons {
    font-size: 16px;
    color: var(--glt-primary);
}

.glt-view-resume,
.glt-view-comment {
    background: var(--glt-grey-50);
    padding: 12px;
    border-radius: 8px;
    font-size: 13px;
    margin-bottom: 10px;
}

.glt-direction-response-section {
    margin-top: 20px;
    padding: 20px;
    background: #f0fdf4;
    border: 1px solid #86efac;
    border-radius: 10px;
}

.glt-direction-response-section h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 10px 0;
    font-size: 15px;
    color: #065f46;
}

.glt-direction-by {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin: 0 0 15px 0;
}

.glt-direction-global-response {
    background: #fff;
    padding: 12px;
    border-radius: 8px;
    margin-bottom: 15px;
}

.glt-direction-global-response p {
    margin: 5px 0 0 0;
    color: var(--glt-grey-700);
}

.glt-direction-line-responses {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.glt-direction-line-item {
    background: #fff;
    padding: 10px 12px;
    border-radius: 6px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.glt-direction-line-key {
    font-weight: 600;
    color: var(--glt-grey-700);
    font-size: 13px;
}

.glt-direction-line-comment {
    width: 100%;
    margin: 5px 0 0 0;
    font-size: 12px;
    color: var(--glt-grey-600);
    font-style: italic;
}

/* Direction response display in control view */
.glt-direction-response-display {
    margin-top: 10px;
    padding: 10px;
    background: #f0fdf4;
    border: 1px solid #86efac;
    border-radius: 6px;
}

.glt-direction-response-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
}

.glt-direction-response-status-badge.prise_en_compte {
    background: #d1fae5;
    color: #065f46;
}

.glt-direction-response-status-badge.refus {
    background: #fee2e2;
    color: #991b1b;
}

.glt-direction-response-status-badge.en_attente {
    background: #fef3c7;
    color: #92400e;
}

/* ===== MODALS ===== */
.glt-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10000;
    display: none;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
    overflow-y: auto;
    padding: 20px;
}

.glt-modal.active {
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

/* Style alternatif avec glt-modal-content (nouveaux modals) */
.glt-modal-content {
    position: relative;
    background: #fff;
    border-radius: var(--glt-border-radius);
    max-width: 600px;
    width: 100%;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
    margin: auto;
    box-shadow: var(--glt-shadow-lg);
    animation: glt-modal-appear 0.2s ease-out;
}

.glt-modal-content.glt-modal-sm {
    max-width: 450px;
}

.glt-modal-content.glt-modal-md {
    max-width: 550px;
}

.glt-modal-content.glt-modal-lg {
    max-width: 800px;
}

@keyframes glt-modal-appear {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Style original avec backdrop séparé */
.glt-modal-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
}

.glt-modal-container {
    position: relative;
    background: #fff;
    border-radius: var(--glt-border-radius);
    max-width: 600px;
    width: 95%;
    max-height: 90vh;
    overflow-y: auto;
    margin: 5vh auto;
    box-shadow: var(--glt-shadow-lg);
}

.glt-modal-large .glt-modal-container {
    max-width: 900px;
}

.glt-modal-small .glt-modal-container,
.glt-modal-sm .glt-modal-container {
    max-width: 450px;
}

.glt-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--glt-grey-200);
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 10;
}

.glt-modal-header-danger {
    background: linear-gradient(135deg, #dc2626, #ef4444);
    border-bottom: none;
}

.glt-modal-header-danger h2 {
    color: #fff;
}

.glt-modal-header-danger h2 .dashicons {
    margin-right: 8px;
}

.glt-modal-header-danger .glt-modal-close {
    color: rgba(255,255,255,0.7);
}

.glt-modal-header-danger .glt-modal-close:hover {
    color: #fff;
}

.glt-modal-header h2 {
    font-size: 18px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-modal-close {
    background: none;
    border: none;
    font-size: 24px;
    color: var(--glt-grey-400);
    cursor: pointer;
    padding: 5px;
    line-height: 1;
}

.glt-modal-close:hover {
    color: var(--glt-grey-600);
}

.glt-modal-body {
    padding: 24px;
}

.glt-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 20px 24px;
    border-top: 1px solid var(--glt-grey-200);
    background: #fff;
    border-radius: 0 0 var(--glt-border-radius) var(--glt-border-radius);
}

.glt-modal-footer .glt-btn {
    min-width: 130px;
}

/* Fields */
.glt-field {
    margin-bottom: 18px;
}

.glt-field label {
    display: block;
    font-weight: 500;
    color: var(--glt-primary-dark);
    margin-bottom: 6px;
    font-size: 13px;
}

.glt-field input,
.glt-field select,
.glt-field textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--glt-grey-300);
    border-radius: 8px;
    font-size: 14px;
    transition: all 0.2s ease;
}

.glt-field input:focus,
.glt-field select:focus,
.glt-field textarea:focus {
    outline: none;
    border-color: var(--glt-primary);
    box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.1);
}

.glt-muted {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin-bottom: 15px;
}

/* Checklist */
.glt-checklist-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--glt-grey-800);
    margin: 25px 0 10px;
    padding-top: 20px;
    border-top: 1px solid var(--glt-grey-200);
}

.glt-checklist {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.glt-check-row {
    background: var(--glt-grey-50);
    border-radius: 8px;
    padding: 12px 16px;
    transition: all 0.2s ease;
}

.glt-check-row:hover {
    background: var(--glt-grey-100);
}

.glt-check-main {
    display: flex;
    align-items: center;
    gap: 12px;
}

.glt-check-label {
    flex: 1;
    font-weight: 500;
    color: var(--glt-grey-700);
}

.glt-check-history-badge {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 4px;
}

.glt-check-status {
    display: flex;
    gap: 6px;
}

.glt-status-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid var(--glt-grey-300);
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.glt-status-btn input {
    display: none;
}

.glt-status-btn .dashicons {
    font-size: 18px;
    color: var(--glt-grey-400);
}

.glt-status-btn:hover {
    border-color: var(--glt-grey-400);
}

.glt-status-btn.selected {
    border-width: 2px;
}

.glt-status-btn.selected.glt-status-ok {
    background: var(--glt-success);
    border-color: var(--glt-success);
}

.glt-status-btn.selected.glt-status-nok {
    background: var(--glt-danger);
    border-color: var(--glt-danger);
}

.glt-status-btn.selected.glt-status-na {
    background: var(--glt-grey-500);
    border-color: var(--glt-grey-500);
}

.glt-status-btn.selected .dashicons {
    color: #fff;
}

.glt-check-details {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px dashed var(--glt-grey-300);
    display: none;
}

.glt-check-row.expanded .glt-check-details {
    display: block;
}

.glt-check-details-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.glt-check-new {
    background: #fff;
    padding: 12px;
    border-radius: 8px;
    border: 1px solid var(--glt-grey-200);
}

.glt-check-history {
    background: #e0f2fe;
    padding: 12px;
    border-radius: 8px;
    border: 1px solid #7dd3fc;
}

.glt-history-item-label {
    font-size: 12px;
    font-weight: 600;
    color: #0369a1;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.glt-history-item-content {
    font-size: 12px;
    color: var(--glt-grey-600);
}

/* History Panel */
.glt-history-panel {
    background: #e0f2fe;
    border: 1px solid #7dd3fc;
    border-radius: var(--glt-border-radius);
    padding: 15px;
    margin-bottom: 20px;
}

.glt-history-header {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.glt-history-header .dashicons {
    color: #0369a1;
}

.glt-history-resume {
    margin-top: 10px;
    font-size: 13px;
    color: var(--glt-grey-600);
    font-style: italic;
}

/* ===== PIÈCES JOINTES ===== */
.glt-attachments-section {
    margin-top: 25px;
    padding-top: 20px;
    border-top: 1px solid var(--glt-grey-200);
}

.glt-attachments-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--glt-grey-800);
    margin: 0 0 5px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-attachments-title .dashicons {
    color: var(--glt-primary);
}

.glt-attachments-upload {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 15px 0;
    flex-wrap: wrap;
}

.glt-attachments-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
    margin-top: 15px;
}

.glt-attachment-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--glt-grey-50);
    border: 1px solid var(--glt-grey-200);
    border-radius: 8px;
    transition: all 0.2s ease;
}

.glt-attachment-item:hover {
    background: var(--glt-grey-100);
    border-color: var(--glt-grey-300);
}

.glt-attachment-item.uploading {
    opacity: 0.7;
}

.glt-attachment-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    flex-shrink: 0;
}

.glt-attachment-icon.pdf {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    color: #fff;
}

.glt-attachment-icon.image {
    background: linear-gradient(135deg, #3b82f6, #1d4ed8);
    color: #fff;
}

.glt-attachment-icon .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
}

.glt-attachment-preview {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    object-fit: cover;
    flex-shrink: 0;
}

.glt-attachment-info {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.glt-attachment-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--glt-grey-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.glt-attachment-size {
    font-size: 11px;
    color: var(--glt-grey-500);
}

.glt-attachment-actions {
    display: flex;
    gap: 4px;
}

.glt-attachment-actions button {
    width: 28px;
    height: 28px;
    border: none;
    background: transparent;
    color: var(--glt-grey-400);
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.glt-attachment-actions button:hover {
    background: var(--glt-grey-200);
    color: var(--glt-grey-700);
}

.glt-attachment-actions button.delete:hover {
    background: #fee2e2;
    color: #dc2626;
}

.glt-attachment-progress {
    width: 100%;
    height: 4px;
    background: var(--glt-grey-200);
    border-radius: 2px;
    overflow: hidden;
    margin-top: 6px;
}

.glt-attachment-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--glt-primary), var(--glt-accent));
    border-radius: 2px;
    transition: width 0.3s ease;
}

/* Affichage des pièces jointes dans les détails du contrôle */
.glt-view-attachments {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--glt-grey-200);
}

.glt-view-attachments h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--glt-grey-800);
    margin: 0 0 12px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-view-attachments-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 12px;
}

.glt-view-attachment {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 12px;
    background: var(--glt-grey-50);
    border: 1px solid var(--glt-grey-200);
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
    transition: all 0.2s ease;
}

.glt-view-attachment:hover {
    background: var(--glt-grey-100);
    border-color: var(--glt-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.glt-view-attachment-preview {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.glt-view-attachment-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.glt-view-attachment-preview.pdf {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    color: #fff;
}

.glt-view-attachment-preview .dashicons {
    font-size: 32px;
    width: 32px;
    height: 32px;
}

.glt-view-attachment-name {
    font-size: 12px;
    font-weight: 500;
    text-align: center;
    color: var(--glt-grey-700);
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 768px) {
    .glt-attachments-list {
        grid-template-columns: 1fr;
    }
    
    .glt-view-attachments-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ===== COMPARAISON ANNUELLE ===== */
.glt-comparison-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
}

@media (max-width: 992px) {
    .glt-comparison-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 576px) {
    .glt-comparison-grid {
        grid-template-columns: 1fr;
    }
}

.glt-comparison-card {
    background: var(--glt-grey-50);
    border-radius: 12px;
    padding: 15px;
    text-align: center;
    border: 2px solid var(--glt-grey-200);
    transition: all 0.3s ease;
}

.glt-comparison-card:hover {
    border-color: var(--glt-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.glt-comparison-card.current {
    border-color: var(--glt-primary);
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.05), rgba(37, 99, 235, 0.1));
}

.glt-comparison-year {
    font-size: 24px;
    font-weight: 700;
    color: var(--glt-grey-800);
    margin-bottom: 15px;
}

.glt-comparison-stats {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.glt-comparison-stat {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 12px;
    background: #fff;
    border-radius: 8px;
}

.glt-comparison-stat-label {
    font-size: 13px;
    color: var(--glt-grey-600);
}

.glt-comparison-stat-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-comparison-trend {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid var(--glt-grey-200);
}

.glt-comparison-trend.up {
    color: #22c55e;
}

.glt-comparison-trend.down {
    color: #ef4444;
}

.glt-comparison-trend.neutral {
    color: var(--glt-grey-500);
}

.glt-comparison-trend .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
}

.glt-comparison-diff {
    font-size: 14px;
    font-weight: 600;
}

/* Widget toggle */
.glt-widget {
    transition: all 0.3s ease;
}

.glt-widget.hidden {
    display: none;
}

.glt-dashboard-controls {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 15px;
}

.glt-widget-toggle {
    position: relative;
}

.glt-widget-menu {
    position: absolute;
    top: 100%;
    right: 0;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    padding: 10px 0;
    min-width: 200px;
    z-index: 100;
    display: none;
}

.glt-widget-menu.active {
    display: block;
}

.glt-widget-menu-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 15px;
    cursor: pointer;
    transition: background 0.2s ease;
}

.glt-widget-menu-item:hover {
    background: var(--glt-grey-50);
}

.glt-widget-menu-item input {
    accent-color: var(--glt-primary);
}

/* Widget Menu Mobile - Mode Modal */
.glt-widget-menu-backdrop {
    display: none;
}

@media (max-width: 768px) {
    .glt-comparison-grid {
        grid-template-columns: 1fr;
    }
    
    /* Modal plein écran sur mobile */
    .glt-widget-menu-backdrop {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.5);
        z-index: 999;
    }
    
    .glt-widget-menu-backdrop.active {
        display: block;
    }
    
    .glt-widget-menu {
        position: fixed;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        right: auto;
        width: calc(100% - 40px);
        max-width: 320px;
        border-radius: 16px;
        z-index: 1000;
        padding: 0;
        overflow: hidden;
    }
    
    .glt-widget-menu.active {
        display: block;
        animation: glt-modal-appear 0.2s ease;
    }
    
    .glt-widget-menu .glt-widget-menu-header {
        padding: 15px 20px !important;
        background: linear-gradient(135deg, var(--glt-primary), var(--glt-accent));
        color: #fff;
        border-bottom: none !important;
    }
    
    .glt-widget-menu .glt-widget-menu-header .dashicons {
        color: #fff !important;
    }
    
    .glt-widget-menu-item {
        padding: 15px 20px;
    }
    
    .glt-widget-menu-close {
        display: flex;
        position: absolute;
        top: 12px;
        right: 12px;
        width: 30px;
        height: 30px;
        background: rgba(255, 255, 255, 0.2);
        border: none;
        border-radius: 50%;
        color: #fff;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        font-size: 18px;
    }
    
    .glt-widget-menu > div:last-child {
        padding: 15px 20px !important;
    }
}

@media (min-width: 769px) {
    .glt-widget-menu-close {
        display: none;
    }
}

/* Page Paramètres - Profil */
.glt-user-profile {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 15px;
    background: var(--glt-grey-50);
    border-radius: var(--glt-border-radius);
}

.glt-profile-avatar {
    width: 70px;
    height: 70px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.glt-profile-info h4 {
    margin: 0 0 5px 0;
    font-size: 18px;
    color: var(--glt-grey-800);
}

.glt-profile-email {
    margin: 8px 0 0 0;
    font-size: 13px;
    color: var(--glt-grey-500);
}

.glt-divider {
    border: none;
    border-top: 1px solid var(--glt-grey-200);
    margin: 20px 0;
}

.glt-section-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--glt-grey-700);
    margin: 0 0 15px 0;
}

.glt-form-compact .glt-field {
    margin-bottom: 15px;
}

.glt-about-app {
    text-align: center;
    padding: 20px;
}

.glt-about-logo {
    width: 100px;
    height: 100px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 15px;
    overflow: hidden;
}

.glt-about-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 12px;
}

.glt-about-logo .dashicons {
    font-size: 50px;
    color: var(--glt-primary);
}

.glt-about-app h4 {
    margin: 0 0 5px 0;
    font-size: 20px;
    color: var(--glt-grey-800);
}

.glt-about-version {
    margin: 0 0 15px 0;
    font-size: 13px;
    color: var(--glt-primary);
    font-weight: 600;
}

.glt-about-desc {
    margin: 0;
    font-size: 14px;
    color: var(--glt-grey-600);
    line-height: 1.5;
}

.glt-about-author {
    margin: 0 0 5px 0;
    font-size: 13px;
    color: var(--glt-grey-600);
}

.glt-about-copyright {
    margin: 0;
    font-size: 12px;
    color: var(--glt-grey-400);
}

.glt-text-muted {
    color: var(--glt-grey-500);
    font-size: 14px;
}

.glt-text-center {
    text-align: center;
}

/* Photo Upload */
.glt-photo-upload {
    display: flex;
    gap: 15px;
    margin-top: 10px;
}

.glt-photo-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border: 2px dashed var(--glt-grey-300);
    border-radius: var(--glt-border-radius-sm);
    background: var(--glt-grey-50);
    cursor: pointer;
    transition: all 0.2s ease;
}

.glt-photo-btn:hover {
    border-color: var(--glt-primary);
    background: #f0f9ff;
}

.glt-photo-btn .dashicons {
    font-size: 24px;
    color: var(--glt-grey-400);
}

.glt-photo-btn span {
    font-size: 10px;
    color: var(--glt-grey-500);
    margin-top: 4px;
}

.glt-photo-btn.has-photo {
    border-style: solid;
    border-color: var(--glt-success);
    background-size: cover;
    background-position: center;
}

.glt-photo-btn.has-photo .dashicons,
.glt-photo-btn.has-photo span {
    display: none;
}

/* Aperçu Local */
.glt-apercu-header {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.glt-apercu-photo {
    flex-shrink: 0;
    width: 150px;
    height: 110px;
    border-radius: 10px;
    overflow: hidden;
    border: 2px solid var(--glt-grey-200);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.glt-apercu-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer;
    transition: transform 0.2s;
}

.glt-apercu-photo img:hover {
    transform: scale(1.05);
}

.glt-apercu-info {
    flex: 1;
    min-width: 250px;
}

.glt-apercu-info h3 {
    margin: 0 0 10px 0;
    font-size: 18px;
    color: var(--glt-grey-800);
}

.glt-apercu-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.glt-apercu-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--glt-grey-600);
    background: var(--glt-grey-50);
    padding: 5px 10px;
    border-radius: 6px;
}

.glt-apercu-meta-item .dashicons {
    font-size: 16px;
}

.glt-apercu-scores {
    display: flex;
    gap: 15px;
}

.glt-apercu-score {
    text-align: center;
    padding: 15px 25px;
    background: var(--glt-grey-50);
    border-radius: var(--glt-border-radius);
    min-width: 120px;
}

.glt-apercu-score-secondary {
    background: #f0f9ff;
}

.glt-apercu-score-value {
    font-size: 32px;
    font-weight: 700;
    line-height: 1;
}

.glt-apercu-score-label {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin-top: 5px;
}

.glt-apercu-score-date {
    font-size: 11px;
    color: var(--glt-grey-400);
    margin-top: 3px;
}

.glt-apercu-controls {
    margin-top: 20px;
}

.glt-apercu-controls h4 {
    margin: 0 0 15px 0;
    font-size: 14px;
    color: var(--glt-grey-700);
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-apercu-controls h4 .dashicons {
    color: var(--glt-primary);
}

.glt-apercu-control-list {
    max-height: 300px;
    overflow-y: auto;
}

.glt-apercu-control-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    background: var(--glt-grey-50);
    border-radius: var(--glt-border-radius-sm);
    margin-bottom: 8px;
}

.glt-apercu-control-date {
    font-size: 13px;
    color: var(--glt-grey-600);
    display: flex;
    align-items: center;
    gap: 6px;
}

.glt-apercu-control-date .dashicons {
    font-size: 14px;
    color: var(--glt-grey-400);
}

.glt-apercu-control-score-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
}

.glt-apercu-control-score {
    font-weight: 600;
    min-width: 45px;
    text-align: right;
}

.glt-apercu-notes {
    padding: 18px;
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    border-radius: var(--glt-border-radius);
    margin-bottom: 20px;
    border-left: 4px solid #f59e0b;
}

.glt-apercu-notes h4 {
    font-size: 14px;
    color: #92400e;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-apercu-notes h4 .dashicons {
    color: #f59e0b;
}

.glt-apercu-notes p {
    font-size: 14px;
    color: #78350f;
    line-height: 1.6;
    margin: 0;
}

/* Agence Block */
.glt-agence-block {
    margin-bottom: 20px;
    padding-left: 15px;
    border-left: 3px solid #10b981;
}

.glt-agence-name {
    font-size: 15px;
    font-weight: 600;
    color: var(--glt-grey-700);
    margin: 0 0 10px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-agence-name .dashicons {
    font-size: 18px;
}

.glt-secteur-block {
    margin-bottom: 15px;
    margin-left: 15px;
    padding-left: 12px;
    border-left: 2px solid #8b5cf6;
}

.glt-secteur-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--glt-grey-600);
    margin: 0 0 8px 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

.glt-secteur-name .dashicons {
    font-size: 14px;
}

.glt-local-blocked {
    opacity: 0.6;
}

.glt-local-blocked-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    background: #fef3c7;
    color: #92400e;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 600;
}

/* ===== TEMPLATES DE CHECKLIST ===== */
.glt-template-item-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    padding: 10px 15px;
    background: var(--glt-grey-50);
    border-radius: 8px;
    border: 1px solid var(--glt-grey-200);
}

.glt-template-item-row:hover {
    background: var(--glt-grey-100);
}

.glt-template-item-row .glt-drag-handle {
    cursor: grab;
    color: var(--glt-grey-400);
    padding: 5px;
}

.glt-template-item-row .glt-drag-handle:active {
    cursor: grabbing;
}

.glt-template-item-row input[type="text"] {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 14px;
    padding: 8px;
}

.glt-template-item-row input[type="text"]:focus {
    background: #fff;
    border-radius: 4px;
    outline: 2px solid var(--glt-primary);
}

.glt-template-item-row .glt-key-input {
    width: 150px;
    font-family: monospace;
    font-size: 12px;
    color: var(--glt-grey-600);
}

.glt-template-item-row .glt-label-input {
    flex: 1;
}

.glt-template-item-row .glt-remove-item {
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    color: var(--glt-grey-400);
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.glt-template-item-row .glt-remove-item:hover {
    background: #fee2e2;
    color: #dc2626;
}

.glt-templates-list-items {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.glt-template-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 15px;
    background: var(--glt-grey-50);
    border-radius: 8px;
    border: 1px solid var(--glt-grey-200);
    transition: all 0.2s ease;
}

.glt-template-list-item:hover {
    background: var(--glt-grey-100);
    border-color: var(--glt-grey-300);
}

.glt-template-list-item.default {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.05), rgba(37, 99, 235, 0.1));
    border-color: var(--glt-primary);
}

.glt-template-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.glt-template-name {
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-template-meta {
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-template-actions {
    display: flex;
    gap: 5px;
}

.glt-template-actions button {
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    color: var(--glt-grey-500);
    cursor: pointer;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.glt-template-actions button:hover {
    background: var(--glt-grey-200);
    color: var(--glt-grey-700);
}

.glt-template-actions button.delete:hover {
    background: #fee2e2;
    color: #dc2626;
}

/* Toast Notifications */
.glt-toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.glt-toast {
    background: #fff;
    padding: 16px 20px;
    border-radius: var(--glt-border-radius);
    box-shadow: var(--glt-shadow-lg);
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 300px;
    animation: glt-slide-in 0.3s ease;
}

@keyframes glt-slide-in {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

.glt-toast.success { border-left: 4px solid var(--glt-success); }
.glt-toast.error { border-left: 4px solid var(--glt-danger); }
.glt-toast.warning { border-left: 4px solid var(--glt-warning); }
.glt-toast.info { border-left: 4px solid var(--glt-info); }

.glt-toast .dashicons {
    font-size: 20px;
}

.glt-toast.success .dashicons { color: var(--glt-success); }
.glt-toast.error .dashicons { color: var(--glt-danger); }

/* ===== PRÉVISIONNEL ===== */
.glt-toolbar-previsionnel {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
}

.glt-toolbar-left {
    display: flex;
    align-items: center;
    gap: 20px;
}

.glt-previsionnel-stats {
    display: flex;
    gap: 15px;
}

.glt-mini-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 10px 20px;
    background: linear-gradient(135deg, var(--glt-primary), #2d5a87);
    border-radius: 10px;
    color: #fff;
}

.glt-mini-stat-muted {
    background: linear-gradient(135deg, #6b7280, #4b5563);
}

.glt-mini-stat-value {
    font-size: 24px;
    font-weight: 700;
    line-height: 1;
}

.glt-mini-stat-label {
    font-size: 11px;
    opacity: 0.9;
    margin-top: 3px;
}

.glt-empty-state-large {
    padding: 80px 40px;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9);
    border-radius: 16px;
    text-align: center;
}

.glt-empty-icon {
    width: 100px;
    height: 100px;
    margin: 0 auto 25px;
    background: linear-gradient(135deg, var(--glt-primary), #2d5a87);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.glt-empty-icon .dashicons {
    font-size: 48px;
    color: #fff;
    width: 48px;
    height: 48px;
}

.glt-empty-state-large h3 {
    font-size: 22px;
    color: var(--glt-grey-800);
    margin-bottom: 10px;
}

.glt-empty-state-large p {
    color: var(--glt-grey-500);
    margin-bottom: 25px;
}

.glt-previsionnel-section {
    margin-bottom: 40px;
}

.glt-section-header {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 18px;
    font-weight: 600;
    color: var(--glt-grey-800);
    margin-bottom: 20px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--glt-primary);
}

.glt-section-header .dashicons {
    color: var(--glt-primary);
}

.glt-section-header-muted {
    border-bottom-color: var(--glt-grey-300);
    color: var(--glt-grey-500);
}

.glt-section-header-muted .dashicons {
    color: var(--glt-grey-400);
}

.glt-section-count {
    background: var(--glt-primary);
    color: #fff;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
}

.glt-section-header-muted .glt-section-count {
    background: var(--glt-grey-400);
}

.glt-planning-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 20px;
}

.glt-planning-card {
    display: flex;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08);
    overflow: hidden;
    transition: all 0.3s ease;
    border: 2px solid transparent;
}

.glt-planning-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 25px rgba(0,0,0,0.12);
}

.glt-planning-today {
    border-color: var(--glt-success);
    box-shadow: 0 4px 15px rgba(40, 167, 69, 0.2);
}

.glt-planning-soon {
    border-color: var(--glt-warning);
}

.glt-planning-card-date {
    width: 100px;
    min-width: 100px;
    background: linear-gradient(135deg, var(--glt-primary), #2d5a87);
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px 10px;
    text-align: center;
    position: relative;
}

.glt-planning-today .glt-planning-card-date {
    background: linear-gradient(135deg, var(--glt-success), #20c997);
}

.glt-planning-soon .glt-planning-card-date {
    background: linear-gradient(135deg, var(--glt-warning), #fd7e14);
}

.glt-planning-day {
    font-size: 36px;
    font-weight: 700;
    line-height: 1;
}

.glt-planning-month {
    font-size: 13px;
    font-weight: 500;
    margin-top: 5px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.glt-planning-year {
    font-size: 12px;
    opacity: 0.7;
}

.glt-planning-badge {
    position: absolute;
    bottom: 8px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(255,255,255,0.25);
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 10px;
    font-weight: 600;
    white-space: nowrap;
}

.glt-planning-card-content {
    flex: 1;
    padding: 20px;
    display: flex;
    flex-direction: column;
}

.glt-planning-card-header {
    margin-bottom: 12px;
}

.glt-planning-agence {
    font-size: 16px;
    font-weight: 600;
    color: var(--glt-grey-800);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}

.glt-planning-agence .dashicons {
    color: var(--glt-primary);
    font-size: 18px;
}

.glt-planning-territoire {
    display: inline-block;
    background: var(--glt-grey-100);
    color: var(--glt-grey-600);
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 11px;
    margin-top: 6px;
}

.glt-planning-membres,
.glt-planning-note {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13px;
    color: var(--glt-grey-600);
    margin-bottom: 8px;
}

.glt-planning-membres .dashicons,
.glt-planning-note .dashicons {
    font-size: 16px;
    color: var(--glt-grey-400);
    flex-shrink: 0;
    margin-top: 1px;
}

.glt-planning-note {
    font-style: italic;
    color: var(--glt-grey-500);
}

.glt-planning-card-actions {
    display: flex;
    gap: 8px;
    margin-top: auto;
    padding-top: 15px;
    border-top: 1px solid var(--glt-grey-100);
}

.glt-btn-outline {
    background: transparent;
    border: 1px solid var(--glt-grey-300);
    color: var(--glt-grey-600);
}

.glt-btn-outline:hover {
    background: var(--glt-grey-100);
    border-color: var(--glt-grey-400);
}

.glt-btn-outline-danger {
    border-color: #fca5a5;
    color: var(--glt-danger);
}

.glt-btn-outline-danger:hover {
    background: #fee2e2;
    border-color: var(--glt-danger);
}

.glt-planning-card-past {
    opacity: 0.65;
}

.glt-planning-card-past .glt-planning-card-date {
    background: linear-gradient(135deg, #6b7280, #4b5563);
}

.glt-planning-past-grid {
    opacity: 0.8;
}

.glt-btn-ghost {
    background: transparent;
    color: var(--glt-grey-500);
    padding: 5px;
}

.glt-btn-ghost:hover {
    background: var(--glt-grey-100);
    color: var(--glt-grey-700);
}

/* ===== MODAL PLANNING ===== */
.glt-modal-large .glt-modal-container {
    max-width: 800px;
}

.glt-modal-header-gradient {
    background: linear-gradient(135deg, var(--glt-primary), #2d5a87);
    color: #fff;
}

.glt-modal-header-gradient h2 {
    color: #fff;
}

.glt-modal-header-gradient .glt-modal-close {
    color: #fff;
    opacity: 0.8;
}

.glt-modal-header-gradient .glt-modal-close:hover {
    opacity: 1;
}

.glt-planning-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

.glt-planning-form-left,
.glt-planning-form-right {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.glt-planning-form-right .glt-field {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.glt-input-large {
    padding: 12px 15px;
    font-size: 15px;
}

/* Chips pour sélection des membres dans le planning */
.glt-membres-selection,
.glt-membres-chips-planning {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    border: 1px solid var(--glt-grey-200);
    border-radius: var(--glt-border-radius);
    padding: 12px;
    max-height: 280px;
    overflow-y: auto;
    background: var(--glt-grey-50);
    align-content: flex-start;
}

/* Les chips membres utilisent le même style que dans le modal contrôle */
.glt-membres-selection .glt-membre-chip,
.glt-membres-chips-planning .glt-membre-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: #fff;
    border: 2px solid var(--glt-grey-200);
    border-radius: 20px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: var(--glt-grey-600);
    transition: all 0.2s ease;
    user-select: none;
    height: fit-content;
}

.glt-membres-selection .glt-membre-chip:hover,
.glt-membres-chips-planning .glt-membre-chip:hover {
    border-color: #3b82f6;
    background: #eff6ff;
    color: #3b82f6;
}

.glt-membres-selection .glt-membre-chip .glt-chip-check,
.glt-membres-chips-planning .glt-membre-chip .glt-chip-check {
    display: none;
    width: 14px;
    height: 14px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    color: #fff;
    align-items: center;
    justify-content: center;
}

.glt-membres-selection .glt-membre-chip.selected,
.glt-membres-chips-planning .glt-membre-chip.selected {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    border-color: #2563eb;
    color: #fff;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.3);
}

.glt-membres-selection .glt-membre-chip.selected .glt-chip-check,
.glt-membres-chips-planning .glt-membre-chip.selected .glt-chip-check {
    display: inline-flex;
}

.glt-membres-selection .glt-membre-chip.selected:hover,
.glt-membres-chips-planning .glt-membre-chip.selected:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
}

/* Ancien style checkbox - gardé pour compatibilité si utilisé ailleurs */
.glt-membre-checkbox {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    margin-bottom: 6px;
    background: #fff;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.glt-membre-checkbox:hover {
    border-color: var(--glt-primary);
    background: #f0f7ff;
}

.glt-membre-checkbox:last-child {
    margin-bottom: 0;
}

.glt-membre-checkbox input[type="checkbox"] {
    display: none;
}

.glt-membre-checkbox-box {
    width: 22px;
    height: 22px;
    border: 2px solid var(--glt-grey-300);
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.glt-membre-checkbox-box::after {
    content: '✓';
    color: #fff;
    font-size: 14px;
    font-weight: bold;
    opacity: 0;
    transform: scale(0);
    transition: all 0.2s ease;
}

.glt-membre-checkbox input:checked + .glt-membre-checkbox-box {
    background: var(--glt-primary);
    border-color: var(--glt-primary);
}

.glt-membre-checkbox input:checked + .glt-membre-checkbox-box::after {
    opacity: 1;
    transform: scale(1);
}

.glt-membre-checkbox-info {
    display: flex;
    flex-direction: column;
}

.glt-membre-name {
    font-weight: 600;
    color: var(--glt-grey-800);
    font-size: 14px;
}

.glt-membre-email {
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-modal-footer-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

/* Bouton Enregistrer la tournée - forcer le dégradé bleu */
.glt-modal-footer-actions .glt-btn-primary,
#glt-form-planning .glt-btn-primary {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
}

#glt-form-planning .glt-btn-primary:hover,
.glt-modal-footer-actions .glt-btn-primary:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.45) !important;
}

.glt-btn-large {
    padding: 12px 25px;
    font-size: 15px;
}

/* ===== MODAL CONFIRMATION DIRECTION ===== */
.glt-modal-confirm {
    max-width: 420px;
    text-align: center;
    padding: 40px 30px;
}

.glt-confirm-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 25px;
    background: linear-gradient(135deg, var(--glt-success), #20c997);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.glt-confirm-icon .dashicons {
    font-size: 40px;
    width: 40px;
    height: 40px;
    color: #fff;
}

.glt-modal-confirm h2 {
    font-size: 22px;
    color: var(--glt-grey-800);
    margin-bottom: 10px;
}

.glt-confirm-message {
    color: var(--glt-grey-600);
    margin-bottom: 8px;
}

.glt-confirm-detail {
    font-size: 13px;
    color: var(--glt-grey-500);
    margin-bottom: 25px;
}

.glt-confirm-actions {
    display: flex;
    justify-content: center;
    gap: 12px;
}

/* ===== BOUTON SUCCESS ===== */
.glt-btn-success {
    background: var(--glt-success);
    color: #fff;
}

.glt-btn-success:hover {
    background: #218838;
}

/* ===== NOTIFICATION PREVIEW ===== */
.glt-notification-preview {
    background: var(--glt-grey-50);
    border-radius: var(--glt-border-radius);
    padding: 20px;
}

.glt-notification-info p {
    margin-bottom: 8px;
}

.glt-notification-info p:last-child {
    margin-bottom: 0;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
    .glt-sidebar {
        transform: translateX(-100%);
    }
    
    .glt-sidebar.open {
        transform: translateX(0);
    }
    
    .glt-main {
        margin-left: 0;
    }
    
    .glt-mobile-menu-btn {
        display: block;
    }
    
    .glt-sidebar-toggle {
        display: block;
    }
}

@media (max-width: 768px) {
    .glt-content {
        padding: 20px;
    }
    
    .glt-header {
        padding: 0 20px;
    }
    
    .glt-row {
        flex-direction: column;
    }
    
    .glt-col-6 {
        min-width: 100%;
    }
    
    .glt-toolbar {
        flex-direction: column;
        align-items: stretch;
    }
    
    .glt-search-box {
        max-width: none;
    }
    
    .glt-modal-container {
        width: 98%;
        margin: 1vh auto;
    }
    
    .glt-check-details-grid {
        grid-template-columns: 1fr;
    }
    
    .glt-check-main {
        flex-wrap: wrap;
    }
}

/* Print */
@media print {
    .glt-sidebar,
    .glt-header,
    .glt-footer,
    .glt-toolbar,
    .glt-modal {
        display: none !important;
    }
    
    .glt-main {
        margin-left: 0;
    }
    
    .glt-card {
        box-shadow: none;
        border: 1px solid #ddd;
    }
}

/* ===== PLANNING MODAL IMPROVEMENTS ===== */
.glt-modal-planning-container {
    max-width: 900px;
}

.glt-field-row {
    display: flex;
    gap: 15px;
}

.glt-field-half {
    flex: 1;
}

.glt-field-full-height {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.glt-field-full-height .glt-membres-selection {
    flex: 1;
}

.glt-membre-name-only {
    font-weight: 500;
    color: var(--glt-grey-800);
    font-size: 14px;
}

.glt-secteurs-selection {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px;
    background: #f8fafc;
    border-radius: 10px;
    border: 1px solid var(--glt-grey-200);
    min-height: 60px;
    align-content: flex-start;
}

.glt-secteurs-selection:empty::before {
    content: "Sélectionnez une agence pour voir les secteurs disponibles";
    color: var(--glt-grey-500);
    font-style: italic;
    font-size: 13px;
    width: 100%;
    text-align: center;
    padding: 10px;
}

/* Chips vertes pour les secteurs */
.glt-secteur-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: #fff;
    border: 2px solid #86efac;
    border-radius: 20px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: #166534;
    transition: all 0.2s ease;
    user-select: none;
}

.glt-secteur-chip:hover {
    border-color: #22c55e;
    background: #f0fdf4;
}

.glt-secteur-chip .glt-chip-check {
    display: none;
    width: 14px;
    height: 14px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    color: #fff;
    align-items: center;
    justify-content: center;
}

.glt-secteur-chip.selected {
    background: linear-gradient(135deg, #22c55e, #16a34a);
    border-color: #16a34a;
    color: #fff;
    box-shadow: 0 2px 8px rgba(34, 197, 94, 0.35);
}

.glt-secteur-chip.selected .glt-chip-check {
    display: inline-flex;
}

.glt-secteur-chip.selected:hover {
    background: linear-gradient(135deg, #16a34a, #15803d);
}

/* Ancien style secteur-item - gardé pour compatibilité */
.glt-secteur-item {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: #fff;
    border: 1px solid var(--glt-grey-200);
    border-radius: 10px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    color: var(--glt-grey-700);
    transition: all 0.2s ease;
    user-select: none;
    text-decoration: none;
}

.glt-secteur-item .glt-secteur-check {
    width: 20px;
    height: 20px;
    border: 2px solid var(--glt-grey-300);
    border-radius: 50%;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
    color: transparent;
    text-decoration: none;
}

.glt-secteur-item .glt-secteur-check svg {
    width: 12px;
    height: 12px;
}

.glt-secteur-item .glt-secteur-name {
    white-space: nowrap;
    text-decoration: none;
}

.glt-secteur-item:hover {
    border-color: #86efac;
    background: #f0fdf4;
}

.glt-secteur-item:hover .glt-secteur-check {
    border-color: #22c55e;
}

/* État sélectionné - Vert clair moderne */
.glt-secteur-item.checked {
    background: #dcfce7;
    border-color: #86efac;
    color: #166534;
}

.glt-secteur-item.checked .glt-secteur-check {
    background: #22c55e;
    border-color: #22c55e;
    color: #fff;
}

.glt-secteur-item.checked:hover {
    background: #bbf7d0;
    border-color: #4ade80;
}

/* ===== MODAL CONFIRMATION DANGER ===== */
.glt-modal-confirm-danger .glt-confirm-icon-danger {
    background: linear-gradient(135deg, var(--glt-danger), #dc2626);
}

/* ===== VALIDATION CHOICES ===== */
.glt-validation-choices {
    display: flex;
    gap: 20px;
    justify-content: center;
    margin-bottom: 20px;
}

.glt-validation-choice {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 25px 35px;
    border: none;
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-weight: 600;
    font-size: 14px;
    outline: none;
}

.glt-validation-choice:focus {
    outline: none;
}

.glt-validation-choice .dashicons {
    font-size: 36px;
    width: 36px;
    height: 36px;
}

/* Tournée réalisée - Vert avec dégradé */
.glt-validation-success {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.4) !important;
}

.glt-validation-success:hover {
    background: linear-gradient(135deg, #059669, #047857) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.5) !important;
}

.glt-validation-success.selected {
    background: linear-gradient(135deg, #047857, #065f46) !important;
    transform: translateY(-3px) scale(1.02) !important;
    box-shadow: 0 8px 25px rgba(16, 185, 129, 0.6) !important;
}

/* Tournée annulée - Rouge avec dégradé */
.glt-validation-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(239, 68, 68, 0.4) !important;
}

.glt-validation-danger:hover {
    background: linear-gradient(135deg, #dc2626, #b91c1c) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.5) !important;
}

.glt-validation-danger.selected {
    background: linear-gradient(135deg, #b91c1c, #991b1b) !important;
    transform: translateY(-3px) scale(1.02) !important;
    box-shadow: 0 8px 25px rgba(239, 68, 68, 0.6) !important;
}

/* Bouton Confirmer - Bleu */
#glt-confirm-valider-planning:not(:disabled) {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.4) !important;
}

#glt-confirm-valider-planning:not(:disabled):hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.5) !important;
}

/* ===== PLANNING STATUTS ===== */
.glt-planning-card-avenir {
    border-color: #3b82f6;
}

.glt-planning-card-avenir .glt-planning-card-date {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
}

.glt-planning-card-validee {
    border-color: var(--glt-success);
}

.glt-planning-card-validee .glt-planning-card-date {
    background: linear-gradient(135deg, var(--glt-success), #059669);
}

.glt-planning-card-annulee {
    border-color: #fca5a5;
    opacity: 0.8;
}

.glt-planning-card-annulee .glt-planning-card-date {
    background: linear-gradient(135deg, #f87171, #ef4444);
}

.glt-planning-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    margin-top: 8px;
}

.glt-planning-status-avenir {
    background: #dbeafe;
    color: #1e40af;
}

.glt-planning-status-validee {
    background: #d1fae5;
    color: #065f46;
}

.glt-planning-status-annulee {
    background: #fee2e2;
    color: #991b1b;
}

/* ===== SECTION HEADERS COLORED ===== */
.glt-section-header-blue {
    border-bottom-color: #3b82f6;
}

.glt-section-header-blue .dashicons {
    color: #3b82f6;
}

.glt-section-header-blue .glt-section-count {
    background: #3b82f6;
}

.glt-section-header-green {
    border-bottom-color: var(--glt-success);
}

.glt-section-header-green .dashicons {
    color: var(--glt-success);
}

.glt-section-header-green .glt-section-count {
    background: var(--glt-success);
}

.glt-section-header-red {
    border-bottom-color: var(--glt-danger);
}

.glt-section-header-red .dashicons {
    color: var(--glt-danger);
}

.glt-section-header-red .glt-section-count {
    background: var(--glt-danger);
}

/* ===== YEAR FILTER ===== */
.glt-year-filter {
    display: flex;
    align-items: center;
    gap: 10px;
}

.glt-year-filter label {
    font-weight: 500;
    color: var(--glt-grey-600);
    font-size: 14px;
}

.glt-year-filter select {
    padding: 8px 15px;
    border: 1px solid var(--glt-grey-300);
    border-radius: var(--glt-border-radius);
    font-size: 14px;
    background: #fff;
}

/* ===== BUTTON HOVER COLORS ===== */
.glt-btn-outline:hover.glt-btn-hover-green {
    background: #d1fae5;
    border-color: var(--glt-success);
    color: #065f46;
}

.glt-btn-outline:hover.glt-btn-hover-blue {
    background: #dbeafe;
    border-color: #3b82f6;
    color: #1e40af;
}

.glt-send-notification-btn:hover {
    background: #d1fae5 !important;
    border-color: var(--glt-success) !important;
    color: #065f46 !important;
}

.glt-edit-planning-btn:hover {
    background: #dbeafe !important;
    border-color: #3b82f6 !important;
    color: #1e40af !important;
}

/* ===== GESTION LOCAUX APERCU BTN ===== */
.glt-apercu-gestion-btn {
    background: transparent;
    border: 1px solid var(--glt-grey-300);
    color: var(--glt-grey-600);
}

.glt-apercu-gestion-btn:hover {
    background: #dbeafe;
    border-color: #3b82f6;
    color: #1e40af;
}

/* ===== LOCAUX PAGE FILTERS ===== */
.glt-filters-row {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
    align-items: center;
}

.glt-filter-select {
    padding: 10px 15px;
    border: 1px solid var(--glt-grey-300);
    border-radius: var(--glt-border-radius);
    font-size: 14px;
    background: #fff;
    min-width: 180px;
}

/* ===== EXPORT BUTTONS ===== */
.glt-export-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    background: transparent;
    border: 1px solid var(--glt-grey-300);
    border-radius: var(--glt-border-radius);
    color: var(--glt-grey-600);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.glt-export-btn:hover {
    background: var(--glt-grey-100);
    border-color: var(--glt-grey-400);
}

.glt-card-header-with-action {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* ===== PLANNING DETAILS MODAL ===== */
.glt-planning-details-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.glt-planning-details-list li {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px;
    border-bottom: 1px solid var(--glt-grey-100);
}

.glt-planning-details-list li:last-child {
    border-bottom: none;
}

.glt-planning-details-list .dashicons {
    color: var(--glt-primary);
}

/* ===== MINI STATS COLORS ===== */
.glt-mini-stat-blue {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
}

.glt-mini-stat-green {
    background: linear-gradient(135deg, var(--glt-success), #059669);
}

.glt-mini-stat-red {
    background: linear-gradient(135deg, #f87171, #ef4444);
}

/* ===== PLANNING INFO LINES ===== */
.glt-planning-info-line {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--glt-grey-600);
    margin-bottom: 4px;
}

.glt-planning-info-line .dashicons {
    font-size: 14px;
    color: var(--glt-grey-400);
}

.glt-planning-motif {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    font-size: 12px;
    color: #991b1b;
    font-style: italic;
    margin-top: 8px;
}

.glt-planning-motif .dashicons {
    font-size: 14px;
    color: #ef4444;
}

/* ===== NEEDS VALIDATION ===== */
.glt-planning-needs-validation {
    border-color: var(--glt-warning);
    animation: pulseWarning 2s infinite;
}

@keyframes pulseWarning {
    0%, 100% { box-shadow: 0 4px 15px rgba(245, 158, 11, 0.2); }
    50% { box-shadow: 0 4px 25px rgba(245, 158, 11, 0.4); }
}

.glt-planning-badge-warning {
    background: var(--glt-warning);
    color: #1a1a1a;
}

/* ===== TOOLBAR LEFT ===== */
.glt-toolbar-left {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

/* ===== VALIDER BTN HOVER ===== */
.glt-valider-planning-btn:hover {
    background: #d1fae5 !important;
    border-color: var(--glt-success) !important;
    color: #065f46 !important;
}

/* ===== INFO TEXT ===== */
.glt-info-text {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--glt-grey-500);
    margin-bottom: 15px;
    padding: 10px 12px;
    background: #f0f9ff;
    border-radius: var(--glt-border-radius);
    border-left: 3px solid #3b82f6;
}

.glt-info-text .dashicons {
    font-size: 16px;
    color: #3b82f6;
}

/* ===== EXPORT PDF BTN ===== */
.glt-export-btn .dashicons-pdf {
    color: #dc2626;
}

/* ===== DETAIL TOURNEE MODAL ===== */
.glt-detail-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 20px;
    background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
    border-radius: var(--glt-border-radius);
    margin-bottom: 20px;
}

.glt-detail-info h3 {
    margin: 0 0 8px 0;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--glt-primary);
}

/* Sections du détail */
.glt-detail-rdv,
.glt-detail-membres,
.glt-detail-secteurs,
.glt-detail-note {
    margin-bottom: 20px;
    padding: 15px;
    border-radius: var(--glt-border-radius);
}

.glt-detail-rdv h4,
.glt-detail-membres h4,
.glt-detail-secteurs h4,
.glt-detail-note h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 12px 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--glt-grey-700);
}

.glt-detail-rdv {
    background: #f0f9ff;
    border-left: 3px solid var(--glt-primary);
}

.glt-detail-rdv h4 .dashicons {
    color: var(--glt-primary);
}

.glt-detail-rdv-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.glt-detail-rdv-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--glt-grey-700);
}

.glt-detail-rdv-item .dashicons {
    font-size: 16px;
    color: var(--glt-primary);
}

.glt-detail-membres {
    background: #f0fdf4;
    border-left: 3px solid var(--glt-success);
}

.glt-detail-membres h4 .dashicons {
    color: var(--glt-success);
}

.glt-detail-membres-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.glt-detail-secteurs {
    background: #faf5ff;
    border-left: 3px solid #8b5cf6;
}

.glt-detail-secteurs h4 .dashicons {
    color: #8b5cf6;
}

.glt-detail-secteurs-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.glt-detail-note {
    background: #fffbeb;
    border-left: 3px solid var(--glt-warning);
}

.glt-detail-note h4 .dashicons {
    color: var(--glt-warning);
}

.glt-detail-note p {
    margin: 0;
    font-style: italic;
    color: var(--glt-grey-700);
}

.glt-detail-locaux-section h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 15px 0;
    padding-bottom: 10px;
    border-bottom: 2px solid #e5e7eb;
    color: var(--glt-grey-700);
}

.glt-detail-locaux-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-height: 400px;
    overflow-y: auto;
}

.glt-detail-local-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 15px;
    background: #f9fafb;
    border-radius: var(--glt-border-radius);
    border: 1px solid #e5e7eb;
    transition: all 0.2s ease;
}

.glt-detail-local-item:hover {
    background: #fff;
    border-color: var(--glt-primary);
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.1);
}

.glt-detail-local-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.glt-detail-local-info strong {
    color: var(--glt-grey-800);
}

.glt-detail-local-adresse {
    font-size: 13px;
    color: var(--glt-grey-500);
}

.glt-detail-local-score {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.glt-detail-local-pct {
    font-size: 18px;
    font-weight: 700;
}

.glt-detail-local-date {
    font-size: 11px;
    color: var(--glt-grey-400);
}

.glt-badge-purple-light {
    background: #f3e8ff;
    color: #7c3aed;
}

/* ===== OPTIONAL LABEL ===== */
.glt-optional {
    font-weight: normal;
    font-size: 12px;
    color: var(--glt-grey-400);
}

/* ===== DETAIL BTN HOVER ===== */
.glt-detail-planning-btn:hover {
    background: #dbeafe !important;
    border-color: #3b82f6 !important;
    color: #1d4ed8 !important;
}

/* ===== PLANNING CARD FOOTER ===== */
.glt-planning-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(0,0,0,0.05);
}

/* ===== BUTTON SUCCESS ===== */
.glt-btn-success {
    background: var(--glt-success);
    border-color: var(--glt-success);
    color: #fff;
}

.glt-btn-success:hover {
    background: #059669;
    border-color: #059669;
}

/* ===== BUTTON TEXT ===== */
.glt-btn-text {
    margin-left: 4px;
}

@media (max-width: 768px) {
    .glt-btn-text {
        display: none;
    }
}

/* ===== PLANNING CARD ACTIONS FIX ===== */
.glt-planning-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid rgba(0,0,0,0.08);
}

.glt-planning-card-actions .glt-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    font-size: 13px;
}

.glt-planning-card-actions .glt-btn .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

/* ===== FILTERS CARD ===== */
.glt-filters-card {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: var(--glt-border-radius);
    padding: 15px 20px;
    margin-bottom: 20px;
}

.glt-filters-row-inline {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 15px;
}

.glt-filter-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
    min-width: 180px;
}

.glt-filter-group label {
    font-size: 12px;
    font-weight: 600;
    color: var(--glt-grey-600);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.glt-filter-actions {
    display: flex;
    gap: 10px;
    margin-left: auto;
}

.glt-filter-select:disabled {
    background: #e5e7eb;
    cursor: not-allowed;
    opacity: 0.7;
}

/* ===== TOOLBAR WRAP ===== */
.glt-toolbar-wrap {
    flex-wrap: wrap;
}

/* ===== PLANNING BUTTONS RESPONSIVE ===== */
.glt-planning-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid rgba(0,0,0,0.08);
}

.glt-planning-card-actions .glt-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 8px 14px;
    font-size: 13px;
    white-space: nowrap;
}

.glt-planning-card-actions .glt-btn .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

@media (max-width: 1200px) {
    .glt-planning-card-actions .glt-btn-text {
        display: none;
    }
    
    .glt-planning-card-actions .glt-btn {
        padding: 8px 10px;
    }
}

@media (max-width: 768px) {
    .glt-filters-row-inline {
        flex-direction: column;
        align-items: stretch;
    }
    
    .glt-filter-group {
        min-width: 100%;
    }
    
    .glt-filter-actions {
        margin-left: 0;
        justify-content: stretch;
    }
    
    .glt-filter-actions .glt-btn {
        flex: 1;
    }
}

/* ===== PLANNING RESPONSIVE ===== */
@media (max-width: 600px) {
    .glt-planning-card-actions {
        flex-direction: column;
    }
    
    .glt-planning-card-actions .glt-btn {
        width: 100%;
        justify-content: center;
    }
    
    .glt-planning-card-actions .glt-btn-text {
        display: inline;
    }
}

/* ===== FILTERS CARD ===== */
.glt-filters-card {
    background: #f8fafc;
    border: 1px solid #e5e7eb;
    border-radius: var(--glt-border-radius);
    padding: 15px;
    margin-bottom: 20px;
}

.glt-filters-row-inline {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    align-items: flex-end;
}

.glt-filter-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.glt-filter-group label {
    font-weight: 600;
    font-size: 13px;
    color: var(--glt-grey-600);
}

.glt-filter-actions {
    display: flex;
    gap: 10px;
    margin-left: auto;
}

@media (max-width: 768px) {
    .glt-filters-row-inline {
        flex-direction: column;
        align-items: stretch;
    }
    
    .glt-filter-group {
        width: 100%;
    }
    
    .glt-filter-group .glt-filter-select {
        width: 100%;
    }
    
    .glt-filter-actions {
        margin-left: 0;
        margin-top: 10px;
    }
}

/* ===== STATISTIQUES ===== */
.glt-stat-card {
    display: flex;
    align-items: center;
    gap: 15px;
    background: #fff;
    border-radius: var(--glt-border-radius);
    padding: 20px;
    box-shadow: var(--glt-shadow);
}

.glt-stat-card > .dashicons {
    font-size: 40px;
    width: 40px;
    height: 40px;
    opacity: 0.8;
}

.glt-stat-card-blue { border-left: 4px solid var(--glt-primary); }
.glt-stat-card-blue > .dashicons { color: var(--glt-primary); }

.glt-stat-card-green { border-left: 4px solid var(--glt-success); }
.glt-stat-card-green > .dashicons { color: var(--glt-success); }

.glt-stat-card-purple { border-left: 4px solid #8b5cf6; }
.glt-stat-card-purple > .dashicons { color: #8b5cf6; }

.glt-stat-card-orange { border-left: 4px solid var(--glt-warning); }
.glt-stat-card-orange > .dashicons { color: var(--glt-warning); }

.glt-stat-card-teal { border-left: 4px solid #14b8a6; }
.glt-stat-card-teal > .dashicons { color: #14b8a6; }

.glt-stat-card-red { border-left: 4px solid var(--glt-danger); }
.glt-stat-card-red > .dashicons { color: var(--glt-danger); }

.glt-stat-content {
    display: flex;
    flex-direction: column;
}

.glt-stat-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--glt-grey-800);
    line-height: 1;
}

.glt-stat-label {
    font-size: 13px;
    color: var(--glt-grey-500);
    margin-top: 4px;
}

/* ===== BADGES ADDITIONNELS ===== */
.glt-badge-orange {
    background: #fff3cd;
    color: #856404;
}

.glt-badge-red {
    background: #f8d7da;
    color: #721c24;
}

/* ===== UTILISATEURS ===== */
.glt-field-hint {
    display: block;
    font-size: 12px;
    color: var(--glt-grey-500);
    margin-top: 4px;
}

/* ===== UPLOAD PHOTO LOCAL ===== */
.glt-local-photo-upload {
    display: flex;
    align-items: flex-start;
    gap: 15px;
}

.glt-local-photo-preview {
    position: relative;
    width: 120px;
    height: 90px;
    border-radius: 8px;
    overflow: hidden;
    border: 2px solid var(--glt-grey-200);
}

.glt-local-photo-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.glt-local-photo-preview .glt-photo-remove-btn {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--glt-danger);
    color: #fff;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s;
}

.glt-local-photo-preview:hover .glt-photo-remove-btn {
    opacity: 1;
}

.glt-local-photo-preview .glt-photo-remove-btn .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

.glt-photo-upload-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 20px 30px;
    border: 2px dashed var(--glt-grey-300);
    border-radius: 8px;
    background: var(--glt-grey-50);
    cursor: pointer;
    color: var(--glt-grey-600);
    transition: all 0.2s;
}

.glt-photo-upload-btn:hover {
    border-color: var(--glt-primary);
    background: rgba(59, 130, 246, 0.05);
    color: var(--glt-primary);
}

.glt-photo-upload-btn .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
}

/* Miniature photo dans tableau des locaux */
.glt-local-cell-with-photo {
    display: flex;
    align-items: center;
    gap: 10px;
}

.glt-local-thumb {
    width: 40px;
    height: 30px;
    object-fit: cover;
    border-radius: 4px;
    border: 1px solid var(--glt-grey-200);
    flex-shrink: 0;
}

/* ===== TEXTE UTILITAIRES ===== */
.glt-text-success { color: var(--glt-success); }
.glt-text-warning { color: var(--glt-warning); }
.glt-text-danger { color: var(--glt-danger); }
.glt-text-muted { color: var(--glt-grey-500); }

/* ===== RESPONSIVE COL-4 ===== */
.glt-col-4 {
    width: calc(33.333% - 14px);
}

@media (max-width: 992px) {
    .glt-col-4 {
        width: calc(50% - 10px);
    }
}

@media (max-width: 576px) {
    .glt-col-4 {
        width: 100%;
    }
}

.glt-col-3 {
    width: calc(25% - 15px);
}

@media (max-width: 992px) {
    .glt-col-3 {
        width: calc(50% - 10px);
    }
}

@media (max-width: 576px) {
    .glt-col-3 {
        width: 100%;
    }
}

.glt-col-2 {
    width: calc(16.666% - 17px);
}

@media (max-width: 1200px) {
    .glt-col-2 {
        width: calc(33.333% - 14px);
    }
}

@media (max-width: 768px) {
    .glt-col-2 {
        width: calc(50% - 10px);
    }
}

@media (max-width: 576px) {
    .glt-col-2 {
        width: 100%;
    }
}

/* ===== CHECKBOX DE SELECTION ===== */
.glt-checkbox-container {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    cursor: pointer;
    user-select: none;
}

.glt-checkbox-container input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

.glt-checkbox-checkmark {
    height: 18px;
    width: 18px;
    background-color: #fff;
    border: 2px solid var(--glt-grey-300);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.glt-checkbox-container:hover .glt-checkbox-checkmark {
    border-color: var(--glt-primary);
}

.glt-checkbox-container input:checked ~ .glt-checkbox-checkmark {
    background-color: var(--glt-primary);
    border-color: var(--glt-primary);
}

.glt-checkbox-checkmark:after {
    content: "";
    display: none;
    width: 5px;
    height: 9px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
    margin-bottom: 2px;
}

.glt-checkbox-container input:checked ~ .glt-checkbox-checkmark:after {
    display: block;
}

/* Ligne sélectionnée */
.glt-gestion-local-row.selected {
    background-color: #eff6ff !important;
}

/* ===== BARRE D'ACTIONS EN MASSE ===== */
.glt-bulk-actions-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
    border: 1px solid #93c5fd;
    border-radius: var(--glt-border-radius);
    margin-bottom: 15px;
    animation: slideDown 0.2s ease;
}

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

.glt-bulk-actions-info {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    color: #1e40af;
}

.glt-bulk-actions-info .dashicons {
    color: #3b82f6;
}

.glt-bulk-actions-buttons {
    display: flex;
    gap: 10px;
}

/* ===== MODAL IMPORT CSV ===== */
.glt-import-info {
    margin-bottom: 25px;
}

.glt-import-memo {
    background: #f0f9ff;
    border: 1px solid #bae6fd;
    border-radius: var(--glt-border-radius);
    padding: 20px;
}

.glt-import-memo h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 12px 0;
    color: #0369a1;
}

.glt-import-memo h4 .dashicons {
    color: #0ea5e9;
}

.glt-import-memo p {
    margin: 0 0 12px 0;
    color: var(--glt-grey-700);
}

.glt-import-columns {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 15px;
}

.glt-import-col {
    background: #fff;
    border: 1px solid #e0f2fe;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    color: #0369a1;
}

.glt-import-example {
    background: #fff;
    border: 1px dashed #0ea5e9;
    border-radius: var(--glt-border-radius);
    padding: 12px 15px;
    margin-bottom: 15px;
}

.glt-import-example strong {
    display: block;
    margin-bottom: 5px;
    color: var(--glt-grey-700);
}

.glt-import-example code {
    display: block;
    font-family: 'Monaco', 'Consolas', monospace;
    font-size: 12px;
    color: #0369a1;
    background: transparent;
    padding: 0;
    word-break: break-all;
}

.glt-import-notes {
    border-top: 1px solid #bae6fd;
    padding-top: 15px;
}

.glt-import-notes > p {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
}

.glt-import-notes .dashicons {
    color: #f59e0b;
}

.glt-import-notes ul {
    margin: 0;
    padding-left: 25px;
}

.glt-import-notes li {
    margin-bottom: 5px;
    font-size: 13px;
    color: var(--glt-grey-600);
}

/* Zone de drag & drop */
.glt-file-upload-zone {
    border: 2px dashed var(--glt-grey-300);
    border-radius: var(--glt-border-radius);
    background: #fafafa;
    transition: all 0.2s ease;
    cursor: pointer;
}

.glt-file-upload-zone:hover,
.glt-file-upload-zone.dragover {
    border-color: var(--glt-primary);
    background: #f0f9ff;
}

.glt-file-upload-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    text-align: center;
}

.glt-file-upload-content .dashicons {
    font-size: 48px;
    width: 48px;
    height: 48px;
    color: var(--glt-grey-400);
    margin-bottom: 15px;
}

.glt-file-upload-zone:hover .glt-file-upload-content .dashicons {
    color: var(--glt-primary);
}

.glt-file-upload-content p {
    margin: 0 0 8px 0;
    color: var(--glt-grey-600);
}

.glt-file-upload-content strong {
    color: var(--glt-primary);
}

.glt-file-types {
    font-size: 12px;
    color: var(--glt-grey-400);
}

.glt-file-selected {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 20px;
    background: #d1fae5;
    border-radius: var(--glt-border-radius);
}

.glt-file-selected .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    color: #059669;
}

#glt-file-name {
    font-weight: 600;
    color: #065f46;
}

/* Aperçu import */
.glt-import-preview {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--glt-grey-200);
}

.glt-import-preview h4 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 15px 0;
    color: var(--glt-grey-700);
}

.glt-import-summary {
    margin-top: 15px;
    padding: 12px 15px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: var(--glt-border-radius);
    color: #166534;
    font-weight: 500;
}

.glt-import-summary.has-errors {
    background: #fef2f2;
    border-color: #fecaca;
    color: #991b1b;
}

/* Statut ligne import */
.glt-import-status-ok {
    color: #059669;
}

.glt-import-status-error {
    color: #dc2626;
}

.glt-import-status-warning {
    color: #d97706;
}

/* Toolbar avec plusieurs boutons */
.glt-toolbar-right {
    display: flex;
    gap: 10px;
}

/* ===== BOUTONS OUTLINE INFO ET PURPLE ===== */
.glt-btn-outline-info {
    border-color: #0ea5e9;
    color: #0ea5e9;
}

.glt-btn-outline-info:hover {
    background-color: #0ea5e9;
    color: #fff;
}

.glt-btn-outline-purple {
    border-color: #8b5cf6;
    color: #8b5cf6;
}

.glt-btn-outline-purple:hover {
    background-color: #8b5cf6;
    color: #fff;
}

.glt-btn-purple {
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    color: #fff;
    border: none;
}

.glt-btn-purple:hover {
    background: linear-gradient(135deg, #7c3aed, #6d28d9);
}

/* ===== MODAL HEADERS COLORÉS ===== */
.glt-modal-header-info {
    background: linear-gradient(135deg, #0ea5e9, #0284c7);
    color: #fff;
}

.glt-modal-header-info h2 {
    color: #fff;
}

.glt-modal-header-info .glt-modal-close {
    color: #fff;
}

.glt-modal-header-purple {
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    color: #fff;
}

.glt-modal-header-purple h2 {
    color: #fff;
}

.glt-modal-header-purple .glt-modal-close {
    color: #fff;
}

/* ===== EMAIL PREVIEW ===== */
.glt-email-preview-header,
.glt-ics-preview-header {
    margin-bottom: 20px;
}

.glt-email-info-card,
.glt-ics-info-card {
    background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
    border: 1px solid #bae6fd;
    border-radius: var(--glt-border-radius);
    padding: 15px 20px;
}

.glt-email-info-card h4,
.glt-ics-info-card h4 {
    margin: 0 0 10px 0;
    color: #0369a1;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-email-info-card p,
.glt-ics-info-card p {
    margin: 5px 0;
    color: var(--glt-grey-600);
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-email-info-card .dashicons,
.glt-ics-info-card .dashicons {
    color: #0ea5e9;
    width: 18px;
    height: 18px;
    font-size: 18px;
}

/* ===== ICS MEMBRES LIST ===== */
.glt-ics-membres-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 15px;
    background: #f8fafc;
    border: 1px solid var(--glt-grey-200);
    border-radius: var(--glt-border-radius);
    min-height: 50px;
}

.glt-ics-membre-item {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    padding: 6px 12px;
    font-size: 13px;
}

.glt-ics-membre-item.selected {
    background: #ddd6fe;
    border-color: #8b5cf6;
    color: #5b21b6;
}

.glt-ics-membre-item input {
    margin: 0;
}

.glt-ics-membre-email {
    font-size: 11px;
    color: var(--glt-grey-500);
}

/* ===== FAB NOUVEAU CONTRÔLE ===== */
.glt-fab {
    position: fixed;
    bottom: 30px;
    right: 30px;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    box-shadow: 0 4px 20px rgba(0,0,0,0.25);
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9998;
}

.glt-fab-primary {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
}

.glt-fab-primary:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 30px rgba(59, 130, 246, 0.5);
}

.glt-fab .dashicons {
    font-size: 28px;
    width: 28px;
    height: 28px;
    color: #fff;
}

/* ===== NOTIFICATION HEADER BUTTON ===== */
.glt-header-notification-btn {
    position: relative;
}

.glt-header-notif-badge {
    position: absolute;
    top: -6px;
    right: -6px;
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    min-width: 18px;
    height: 18px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 4px;
    border: 2px solid #fff;
    animation: glt-pulse 2s infinite;
}

@keyframes glt-pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

/* ===== NOTIFICATIONS DROPDOWN ===== */
.glt-notifications-dropdown-wrapper {
    position: fixed;
    top: 60px;
    right: 20px;
    z-index: 9999;
}

.glt-notifications-dropdown-wrapper .glt-notifications-dropdown {
    width: 360px;
    max-height: 450px;
    background: #fff;
    border-radius: var(--glt-border-radius);
    box-shadow: 0 10px 40px rgba(0,0,0,0.2);
    display: none;
    overflow: hidden;
}

.glt-notifications-dropdown-wrapper .glt-notifications-dropdown.active {
    display: block;
    animation: glt-slideDown 0.2s ease-out;
}

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

/* Responsive notifications */
@media (max-width: 768px) {
    .glt-notifications-dropdown-wrapper {
        top: 55px;
        right: 10px;
        left: 10px;
    }
    
    .glt-notifications-dropdown-wrapper .glt-notifications-dropdown {
        width: 100%;
        max-width: none;
        max-height: 70vh;
    }
}

.glt-notifications-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 15px;
    border-bottom: 1px solid var(--glt-grey-200);
    background: linear-gradient(135deg, #f8fafc, #f1f5f9);
}

.glt-notifications-header h4 {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--glt-grey-700);
}

.glt-notifications-list {
    max-height: 380px;
    overflow-y: auto;
}

.glt-notification-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 15px;
    border-bottom: 1px solid var(--glt-grey-100);
    cursor: pointer;
    transition: background 0.2s;
}

.glt-notification-item:hover {
    background: #f8fafc;
}

.glt-notification-item.unread {
    background: #eff6ff;
}

.glt-notification-item.unread:hover {
    background: #dbeafe;
}

.glt-notification-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.glt-notification-icon.message {
    background: #dbeafe;
    color: #2563eb;
}

.glt-notification-icon.controle {
    background: #d1fae5;
    color: #059669;
}

.glt-notification-icon.planning {
    background: #fef3c7;
    color: #d97706;
}

.glt-notification-icon.default {
    background: var(--glt-grey-100);
    color: var(--glt-grey-600);
}

.glt-notification-content {
    flex: 1;
    min-width: 0;
}

.glt-notification-text {
    font-size: 13px;
    color: var(--glt-grey-700);
    line-height: 1.4;
    margin: 0 0 4px 0;
}

.glt-notification-time {
    font-size: 11px;
    color: var(--glt-grey-500);
}

.glt-notification-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--glt-grey-500);
}

.glt-notification-empty .dashicons {
    font-size: 40px;
    width: 40px;
    height: 40px;
    opacity: 0.4;
    margin-bottom: 10px;
}

/* ===== MESSAGERIE ===== */
.glt-messaging-container {
    display: flex;
    gap: 0;
    height: calc(100vh - 250px);
    min-height: 500px;
    border: 1px solid var(--glt-grey-200);
    border-radius: var(--glt-border-radius);
    overflow: hidden;
    background: #fff;
}

.glt-conversations-list {
    width: 320px;
    border-right: 1px solid var(--glt-grey-200);
    display: flex;
    flex-direction: column;
    background: #f8fafc;
    overflow: hidden;
    min-height: 0;
}

.glt-conversations-header {
    padding: 15px 20px;
    border-bottom: 1px solid var(--glt-grey-200);
    background: #fff;
}

.glt-conversations-header h3 {
    margin: 0;
    font-size: 15px;
    font-weight: 600;
    color: var(--glt-grey-700);
}

.glt-conversations-items {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

.glt-conversation-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 15px 20px;
    cursor: pointer;
    border-bottom: 1px solid var(--glt-grey-100);
    transition: background 0.2s;
}

.glt-conversation-item:hover {
    background: #fff;
}

.glt-conversation-item.active {
    background: #fff;
    border-left: 3px solid var(--glt-blue);
}

.glt-conversation-item.has-unread {
    background: #eff6ff;
}

.glt-conversation-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--glt-blue), #6366f1);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 16px;
    flex-shrink: 0;
}

.glt-conversation-info {
    flex: 1;
    min-width: 0;
}

.glt-conversation-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--glt-grey-800);
    margin-bottom: 2px;
}

.glt-conversation-preview {
    font-size: 12px;
    color: var(--glt-grey-500);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.glt-conversation-meta {
    text-align: right;
}

.glt-conversation-time {
    font-size: 11px;
    color: var(--glt-grey-500);
    margin-bottom: 4px;
}

.glt-conversation-unread {
    background: #ef4444;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    display: inline-block;
    margin-left: 8px;
    vertical-align: middle;
}

.glt-conversation-view {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
}

.glt-conversation-placeholder {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--glt-grey-500);
    text-align: center;
    padding: 40px;
}

.glt-conversation-placeholder .dashicons {
    font-size: 64px;
    width: 64px;
    height: 64px;
    opacity: 0.3;
    margin-bottom: 15px;
}

.glt-conversation-placeholder h3 {
    margin: 0 0 10px 0;
    font-size: 18px;
    color: var(--glt-grey-600);
}

.glt-conversation-active {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
}

.glt-conversation-header {
    padding: 15px 20px;
    border-bottom: 1px solid var(--glt-grey-200);
    background: #fff;
}

.glt-conversation-user {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    font-size: 15px;
    color: var(--glt-grey-800);
}

.glt-conversation-user .dashicons {
    color: var(--glt-blue);
}

.glt-messages-container {
    flex: 1;
    overflow-y: auto;
    padding: 15px 20px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: #fff;
    min-height: 0;
}

.glt-message {
    max-width: 75%;
    padding: 10px 14px;
    border-radius: 18px;
    position: relative;
    margin-bottom: 2px;
}

.glt-message.sent {
    align-self: flex-end;
    background: #007AFF;
    color: #fff;
    border-bottom-right-radius: 4px;
    margin-left: 40px;
}

.glt-message.received {
    align-self: flex-start;
    background: #E5E5EA;
    color: #000;
    border-bottom-left-radius: 4px;
    margin-right: 40px;
}

.glt-message-text {
    font-size: 15px;
    line-height: 1.4;
    white-space: pre-wrap;
    word-wrap: break-word;
}

/* Bulles de messages - Messagerie */
.glt-message-bubble {
    max-width: 70%;
    padding: 12px 16px;
    border-radius: 18px;
    margin-bottom: 8px;
    position: relative;
    word-wrap: break-word;
}

.glt-message-bubble.glt-message-sent {
    align-self: flex-end;
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    color: #fff;
    border-bottom-right-radius: 4px;
    margin-left: 60px;
}

.glt-message-bubble.glt-message-received {
    align-self: flex-start;
    background: #f1f5f9;
    color: #1e293b;
    border-bottom-left-radius: 4px;
    margin-right: 60px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

.glt-message-bubble .glt-message-sender {
    font-weight: 600;
    font-size: 12px;
    margin-bottom: 4px;
    color: #64748b;
}

.glt-message-bubble .glt-message-text {
    font-size: 14px;
    line-height: 1.5;
}

.glt-message-bubble .glt-message-time {
    font-size: 11px;
    margin-top: 6px;
    text-align: right;
}

.glt-message-bubble.glt-message-sent .glt-message-time {
    color: rgba(255, 255, 255, 0.7);
}

.glt-message-bubble.glt-message-received .glt-message-time {
    color: #94a3b8;
}

/* Container des messages */
.glt-messages-container {
    display: flex;
    flex-direction: column;
    padding: 20px;
    overflow-y: auto;
    flex: 1;
    background: #fff;
}

/* Pièces jointes dans les messages */
.glt-msg-attachments {
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.glt-msg-attachment {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(255,255,255,0.2);
    border-radius: 8px;
    font-size: 12px;
    text-decoration: none;
    color: inherit;
    transition: background 0.2s;
}

.glt-message-bubble.glt-message-received .glt-msg-attachment {
    background: #e2e8f0;
    color: #1e293b;
}

.glt-msg-attachment:hover {
    background: rgba(255,255,255,0.3);
}

.glt-message-bubble.glt-message-received .glt-msg-attachment:hover {
    background: #cbd5e1;
}

.glt-message-time {
    font-size: 10px;
    margin-top: 4px;
    text-align: right;
}

.glt-message.sent .glt-message-time {
    color: rgba(255, 255, 255, 0.7);
}

.glt-message.received .glt-message-time {
    color: #8E8E93;
}

.glt-message-input-area button {
    align-self: flex-end;
}

/* Responsive */
@media (max-width: 768px) {
    .glt-messaging-container {
        flex-direction: column;
        height: auto;
    }
    
    .glt-conversations-list {
        width: 100%;
        max-height: 300px;
    }
    
    .glt-notifications-dropdown {
        width: 300px;
        right: -50px;
    }
}

/* ===== SUPPRESSION NOTIFICATIONS ET CONVERSATIONS ===== */
.glt-notification-item {
    position: relative;
}

.glt-notification-delete {
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    color: var(--glt-grey-400);
    cursor: pointer;
    padding: 5px;
    border-radius: 50%;
    opacity: 0;
    transition: all 0.2s;
}

.glt-notification-item:hover .glt-notification-delete {
    opacity: 1;
}

.glt-notification-delete:hover {
    background: #fee2e2;
    color: #ef4444;
}

.glt-conversation-item {
    position: relative;
}

.glt-conversation-delete {
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    color: var(--glt-grey-400);
    cursor: pointer;
    padding: 5px;
    border-radius: 50%;
    opacity: 0;
    transition: all 0.2s;
    z-index: 10;
}

.glt-conversation-item:hover .glt-conversation-delete {
    opacity: 1;
}

.glt-conversation-delete:hover {
    background: #fee2e2;
    color: #ef4444;
}

/* ===== BOUTONS D'EXPORT STATISTIQUES ===== */
.glt-export-buttons {
    display: flex;
    gap: 10px;
}

.glt-export-buttons .glt-btn svg {
    vertical-align: middle;
}

/* Force le bouton envoyer du modal message à être bleu */
#glt-btn-send-new-message {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    color: #fff !important;
}

#glt-btn-send-new-message:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
}

/* ===== ACTIONS CORRECTIVES ===== */
.glt-actions-stats {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 15px;
    margin-bottom: 25px;
}

.glt-actions-stats .glt-stat-card {
    background: #fff;
    border-radius: 12px;
    padding: 15px;
    display: flex;
    align-items: center;
    gap: 15px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    border: 1px solid var(--glt-grey-100);
    transition: transform 0.2s, box-shadow 0.2s;
}

.glt-actions-stats .glt-stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.glt-actions-stats .glt-stat-icon {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.glt-actions-stats .glt-stat-icon .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    color: #fff;
}

.glt-actions-stats .stat-total .glt-stat-icon { background: linear-gradient(135deg, #6366f1, #4f46e5); }
.glt-actions-stats .stat-todo .glt-stat-icon { background: linear-gradient(135deg, #ef4444, #dc2626); }
.glt-actions-stats .stat-progress .glt-stat-icon { background: linear-gradient(135deg, #f59e0b, #d97706); }
.glt-actions-stats .stat-done .glt-stat-icon { background: linear-gradient(135deg, #10b981, #059669); }
.glt-actions-stats .stat-overdue .glt-stat-icon { background: linear-gradient(135deg, #1f2937, #111827); }

.glt-actions-stats .glt-stat-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--glt-grey-900);
    line-height: 1;
}

.glt-actions-stats .glt-stat-label {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin-top: 4px;
}

/* Actions Grid */
.glt-actions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 20px;
}

.glt-action-card {
    background: #fff;
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    border: 1px solid var(--glt-grey-100);
    border-left: 4px solid var(--glt-grey-300);
    transition: box-shadow 0.2s, transform 0.2s;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.glt-action-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
    transform: translateY(-2px);
}

.glt-action-card.status-todo { border-left-color: #ef4444; }
.glt-action-card.status-in_progress { border-left-color: #f59e0b; }
.glt-action-card.status-done { border-left-color: #10b981; }
.glt-action-card.status-overdue { border-left-color: #1f2937; background: #fef2f2; }

.glt-action-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.glt-action-status,
.glt-action-priority {
    font-size: 11px;
    font-weight: 600;
    padding: 4px 8px;
    border-radius: 20px;
    background: var(--glt-grey-100);
}

.glt-action-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--glt-grey-900);
    margin: 0;
    line-height: 1.4;
}

.glt-action-desc {
    font-size: 13px;
    color: var(--glt-grey-600);
    margin: 0;
    line-height: 1.5;
}

.glt-action-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-action-meta .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
    margin-right: 4px;
    vertical-align: middle;
}

.glt-action-deadline.overdue {
    color: #ef4444;
    font-weight: 600;
}

.glt-action-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    border-top: 1px solid var(--glt-grey-100);
    margin-top: auto;
    flex-wrap: wrap;
    gap: 10px;
}

.glt-action-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-end;
}

/* Responsive des boutons d'action */
@media (max-width: 1200px) {
    .glt-btn-action {
        padding: 5px 8px;
        font-size: 11px;
    }
    .glt-btn-action .dashicons {
        font-size: 12px;
        width: 12px;
        height: 12px;
    }
}

@media (max-width: 768px) {
    .glt-action-footer {
        flex-direction: column;
        align-items: flex-start;
    }
    .glt-action-actions {
        width: 100%;
        justify-content: flex-start;
        margin-top: 8px;
    }
    .glt-btn-action {
        padding: 6px 10px;
        font-size: 11px;
    }
    /* Masquer le texte sur mobile, garder l'icône */
    .glt-btn-action span:not(.dashicons) {
        display: none;
    }
    .glt-btn-action .dashicons {
        margin: 0;
    }
}

.glt-action-responsable {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--glt-grey-700);
}

.glt-avatar-mini {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--glt-primary), var(--glt-primary-light));
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.glt-action-actions {
    display: flex;
    gap: 5px;
}

.glt-btn-icon {
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 8px;
    background: var(--glt-grey-100);
    color: var(--glt-grey-600);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.glt-btn-icon:hover {
    background: var(--glt-primary);
    color: #fff;
}

.glt-btn-icon .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

.glt-empty-state {
    text-align: center;
    padding: 60px 20px;
    color: var(--glt-grey-500);
}

/* Lien contrôle dans les cartes action */
.glt-action-controle-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--glt-primary);
    text-decoration: none;
    font-weight: 500;
    font-size: 11px;
    padding: 2px 6px;
    border-radius: 4px;
    background: rgba(59, 130, 246, 0.1);
    transition: all 0.2s;
}

.glt-action-controle-link:hover {
    background: var(--glt-primary);
    color: #fff;
}

.glt-action-controle-link .dashicons {
    font-size: 12px;
    width: 12px;
    height: 12px;
}

/* Bouton outline petit */
.glt-btn-sm {
    padding: 6px 12px;
    font-size: 12px;
}

.glt-btn-outline {
    background: transparent;
    border: 1px solid var(--glt-primary);
    color: var(--glt-primary);
}

.glt-btn-outline:hover {
    background: var(--glt-primary);
    color: #fff;
}

/* Toolbar des actions */
.glt-actions-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 15px;
    margin-bottom: 20px;
    padding: 12px 16px;
    background: var(--glt-grey-50);
    border-radius: 10px;
    border: 1px solid var(--glt-grey-100);
}

.glt-actions-filters {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.glt-select-compact {
    padding: 8px 12px;
    border: 1px solid var(--glt-grey-200);
    border-radius: 8px;
    background: #fff;
    font-size: 13px;
    color: var(--glt-grey-700);
    cursor: pointer;
    transition: all 0.2s;
    min-width: 140px;
}

.glt-select-compact:hover {
    border-color: var(--glt-primary);
}

.glt-select-compact:focus {
    outline: none;
    border-color: var(--glt-primary);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

/* Bouton Export PDF stylisé */
.glt-btn-export-pdf {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    background: linear-gradient(135deg, #dc2626, #b91c1c);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    box-shadow: 0 2px 6px rgba(220, 38, 38, 0.3);
}

.glt-btn-export-pdf:hover {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(220, 38, 38, 0.4);
}

.glt-btn-export-pdf svg {
    width: 16px;
    height: 16px;
}

/* Badge Auto-créé */
.glt-badge-auto {
    display: inline-block;
    padding: 2px 8px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    color: #fff;
    border-radius: 4px;
    letter-spacing: 0.5px;
}

/* Badge Type (Transfert/Travaux) */
.glt-badge-type {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 12px;
    margin-left: 8px;
}

.glt-badge-type.transfert {
    background: linear-gradient(135deg, #fef3c7, #fde68a);
    color: #92400e;
}

.glt-badge-type.travaux {
    background: linear-gradient(135deg, #ede9fe, #ddd6fe);
    color: #5b21b6;
}

/* Indicateur email envoyé */
.glt-action-transfer-info {
    background: linear-gradient(135deg, #eff6ff, #dbeafe);
    color: #1d4ed8;
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 12px;
    margin-top: 8px;
    border-left: 3px solid #3b82f6;
}

/* Boutons d'action (Terminer, Modifier) */
.glt-btn-action {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 500;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s;
}

.glt-btn-action .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

/* Bouton Envoyer email */
.glt-btn-email {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    color: #fff;
}

.glt-btn-email:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}

/* Bouton Relancer email */
.glt-btn-remind-email {
    background: linear-gradient(135deg, #6366f1, #4f46e5);
    color: #fff;
}

.glt-btn-remind-email:hover {
    background: linear-gradient(135deg, #4f46e5, #4338ca);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4);
}

/* Bouton Démarrer */
.glt-btn-start {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
}

.glt-btn-start:hover {
    background: linear-gradient(135deg, #d97706, #b45309);
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.4);
}

.glt-btn-done {
    background: #10b981;
    color: #fff;
}

.glt-btn-done:hover {
    background: #059669;
}

.glt-btn-reopen {
    background: #6366f1;
    color: #fff;
}

.glt-btn-reopen:hover {
    background: #4f46e5;
}

.glt-btn-action.glt-btn-edit-action {
    background: var(--glt-grey-100);
    color: var(--glt-grey-700);
}

.glt-btn-action.glt-btn-edit-action:hover {
    background: var(--glt-primary);
    color: #fff;
}

/* Bouton Relancer */
.glt-btn-remind {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
    box-shadow: 0 4px 14px rgba(245, 158, 11, 0.35);
    border: none;
}

.glt-btn-remind:hover {
    background: linear-gradient(135deg, #d97706, #b45309);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(245, 158, 11, 0.45);
}

/* Bouton En cours */
.glt-btn-progress {
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    color: #fff;
}

.glt-btn-progress:hover {
    background: linear-gradient(135deg, #60a5fa, #3b82f6);
}

/* Bouton Annuler */
.glt-btn-cancel {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    color: #fff;
    box-shadow: 0 4px 14px rgba(239, 68, 68, 0.35);
    border: none;
}

.glt-btn-cancel:hover {
    background: linear-gradient(135deg, #dc2626, #b91c1c);
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.45);
}

/* Statut Annulée */
.glt-action-card.status-cancelled { 
    border-left-color: #9ca3af; 
    background: #f9fafb;
    opacity: 0.8;
}

/* Recherche dans les actions */
.glt-search-actions {
    flex-shrink: 0;
    min-width: 200px;
    max-width: 280px;
}

.glt-search-actions input {
    width: 100%;
}

/* Suivi dans carte action */
.glt-action-suivi {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    padding: 8px 10px;
    background: #fef3c7;
    border-radius: 6px;
    font-size: 12px;
    color: #92400e;
}

.glt-action-suivi .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

/* Numéro de contrôle */
.glt-controle-numero {
    display: inline-block;
    padding: 3px 8px;
    background: var(--glt-grey-100);
    color: var(--glt-primary);
    font-family: 'Monaco', 'Consolas', monospace;
    font-size: 12px;
    font-weight: 600;
    border-radius: 4px;
}

/* Lien contrôle dans modal */
.glt-controle-link-box {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 15px;
    background: #eff6ff;
    border-radius: 8px;
    border: 1px solid #bfdbfe;
}

.glt-controle-link-box .dashicons {
    color: var(--glt-primary);
}

.glt-controle-link-box a {
    color: var(--glt-primary);
    text-decoration: none;
}

.glt-controle-link-box a:hover {
    text-decoration: underline;
}

/* Alerte info */
.glt-alert {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 15px;
    border-radius: 8px;
}

.glt-alert-info {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: #1e40af;
}

.glt-alert-warning {
    background: #fffbeb;
    border: 1px solid #fcd34d;
    color: #92400e;
}

.glt-alert .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.glt-alert strong {
    display: block;
    margin-bottom: 4px;
}

.glt-alert p {
    margin: 0;
    font-size: 13px;
    opacity: 0.9;
}

/* Modal header warning */
.glt-modal-header-warning {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
}

.glt-modal-header-warning h2 {
    color: #fff;
}

.glt-modal-header-warning .glt-modal-close {
    color: #fff;
}

/* Modal header danger (annulation) */
.glt-modal-header-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626);
    color: #fff;
}

.glt-modal-header-danger h2 {
    color: #fff;
}

.glt-modal-header-danger .glt-modal-close {
    color: #fff;
}

/* Modal header relance */
.glt-modal-header-remind {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
}

.glt-modal-header-remind h2 {
    color: #fff;
}

.glt-modal-header-remind .glt-modal-close {
    color: #fff;
}

/* Bouton warning */
.glt-btn-warning {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff;
    border: none;
}

.glt-btn-warning:hover {
    background: linear-gradient(135deg, #fbbf24, #f59e0b);
}

/* Cancel warning box */
.glt-cancel-warning {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 15px;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    color: #991b1b;
    margin-bottom: 15px;
}

.glt-cancel-warning .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    color: #dc2626;
}

.glt-cancel-warning p {
    margin: 0;
    font-weight: 500;
}

.glt-cancel-action-title {
    text-align: center;
    padding: 10px;
    background: var(--glt-grey-100);
    border-radius: 6px;
    margin-bottom: 15px;
}

/* Modal relance styles */
.glt-remind-preview {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 20px;
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border: 1px solid #fcd34d;
    border-radius: 12px;
}

.glt-remind-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, #f59e0b, #d97706);
    border-radius: 50%;
    flex-shrink: 0;
}

.glt-remind-icon .dashicons {
    font-size: 28px;
    width: 28px;
    height: 28px;
    color: #fff;
}

.glt-remind-content h3 {
    margin: 0 0 10px 0;
    font-size: 14px;
    color: #92400e;
    font-weight: 600;
}

.glt-remind-action-title {
    margin: 0 0 5px 0;
    font-size: 16px;
    font-weight: 600;
    color: #1f2937;
}

.glt-remind-action-deadline {
    margin: 0;
    font-size: 13px;
    color: #6b7280;
}

.glt-remind-info {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 15px;
    padding: 10px 15px;
    background: #eff6ff;
    border-radius: 8px;
    font-size: 13px;
    color: #1e40af;
}

.glt-remind-info .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
    color: #3b82f6;
}

/* Styles pour relance en masse */
.glt-remind-preview-masse {
    flex-direction: column;
    text-align: center;
}

.glt-remind-preview-masse .glt-remind-icon {
    margin: 0 auto 15px;
}

.glt-remind-preview-masse .glt-remind-content {
    width: 100%;
}

.glt-relance-stats {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 15px;
}

.glt-relance-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 12px 20px;
    background: #fff;
    border-radius: 10px;
    border: 2px solid #e5e7eb;
    min-width: 90px;
}

.glt-relance-stat .glt-relance-count {
    font-size: 28px;
    font-weight: 700;
    color: #1e40af;
}

.glt-relance-stat .glt-relance-label {
    font-size: 12px;
    color: #64748b;
    margin-top: 4px;
}

.glt-relance-stat-overdue {
    border-color: #fca5a5;
    background: #fef2f2;
}

.glt-relance-stat-overdue .glt-relance-count {
    color: #dc2626;
}

/* Date de relance dans les cartes d'action */
.glt-action-relance-date {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 11px;
    color: #f59e0b;
    background: #fffbeb;
    padding: 2px 8px;
    border-radius: 10px;
    margin-left: 8px;
}

.glt-action-relance-date .dashicons {
    font-size: 12px;
    width: 12px;
    height: 12px;
}

/* Conteneur des boutons d'actions */
.glt-actions-buttons {
    display: flex;
    gap: 10px;
    align-items: center;
}

/* Bouton relance style */
.glt-btn.glt-btn-remind {
    background: linear-gradient(135deg, #f59e0b, #d97706);
    color: #fff !important;
    border: none;
    box-shadow: 0 4px 14px rgba(245, 158, 11, 0.35);
}

.glt-btn.glt-btn-remind:hover {
    background: linear-gradient(135deg, #fbbf24, #f59e0b);
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(245, 158, 11, 0.45);
}

/* Bouton view */
.glt-btn-view-action {
    background: var(--glt-grey-100);
    color: var(--glt-grey-600);
}

.glt-btn-view-action:hover {
    background: var(--glt-grey-200);
    color: var(--glt-grey-800);
}

/* Field help */
.glt-field-help {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    color: var(--glt-grey-500);
}

/* Responsive */
@media (max-width: 1200px) {
    .glt-actions-stats {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .glt-actions-toolbar {
        flex-direction: column;
        align-items: stretch;
    }
    
    .glt-actions-filters {
        justify-content: flex-start;
    }
    
    .glt-btn-export-pdf {
        align-self: flex-start;
    }
}

@media (max-width: 768px) {
    .glt-actions-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .glt-actions-grid {
        grid-template-columns: 1fr;
    }
    
    .glt-select-compact {
        min-width: 120px;
    }
}

/* ===== STYLES FORCÉS POUR TOUS LES BOUTONS DES MODALS ===== */
.glt-modal .glt-btn-primary,
.glt-modal-footer .glt-btn-primary,
.glt-confirm-actions .glt-btn-primary {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
}

.glt-modal .glt-btn-primary:hover,
.glt-modal-footer .glt-btn-primary:hover,
.glt-confirm-actions .glt-btn-primary:hover {
    background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(59, 130, 246, 0.45) !important;
}

.glt-modal .glt-btn-danger,
.glt-modal-footer .glt-btn-danger,
.glt-confirm-actions .glt-btn-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(239, 68, 68, 0.35) !important;
}

.glt-modal .glt-btn-danger:hover,
.glt-modal-footer .glt-btn-danger:hover,
.glt-confirm-actions .glt-btn-danger:hover {
    background: linear-gradient(135deg, #dc2626, #b91c1c) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(239, 68, 68, 0.45) !important;
}

.glt-modal .glt-btn-success,
.glt-modal-footer .glt-btn-success,
.glt-confirm-actions .glt-btn-success {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.35) !important;
}

.glt-modal .glt-btn-success:hover,
.glt-modal-footer .glt-btn-success:hover,
.glt-confirm-actions .glt-btn-success:hover {
    background: linear-gradient(135deg, #059669, #047857) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.45) !important;
}

.glt-modal .glt-btn-outline,
.glt-modal-footer .glt-btn-outline,
.glt-confirm-actions .glt-btn-outline {
    background: #fff !important;
    color: #3b82f6 !important;
    border: 2px solid #3b82f6 !important;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.15) !important;
}

.glt-modal .glt-btn-outline:hover,
.glt-modal-footer .glt-btn-outline:hover,
.glt-confirm-actions .glt-btn-outline:hover {
    background: #3b82f6 !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(59, 130, 246, 0.35) !important;
}

/* ============================================
   SECTION RESPONSIVE - ADAPTATION MULTI-APPAREILS
   ============================================ */

/* Overlay quand menu mobile ouvert */
body.glt-menu-open::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 99;
}

/* === TABLETTES PAYSAGE (max 1200px) === */
@media (max-width: 1200px) {
    .glt-content {
        padding: 20px;
    }
    
    .glt-stats-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .glt-top10-container {
        flex-direction: column;
    }
    
    .glt-top10-section {
        width: 100%;
    }
}

/* === TABLETTES ET MOBILE (max 1024px) === */
@media (max-width: 1024px) {
    /* Sidebar devient overlay */
    .glt-sidebar {
        position: fixed;
        left: 0;
        top: 0;
        height: 100vh;
        width: 280px;
        transform: translateX(-100%);
        transition: transform 0.3s ease;
        z-index: 100;
    }
    
    .glt-sidebar.open {
        transform: translateX(0);
    }
    
    .glt-main {
        margin-left: 0;
        width: 100%;
    }
    
    .glt-mobile-menu-btn {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        font-size: 24px;
    }
    
    .glt-sidebar-toggle {
        display: block;
        position: absolute;
        top: 15px;
        right: 15px;
        font-size: 24px;
    }
    
    .glt-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* === MOBILE (max 768px) === */
@media (max-width: 768px) {
    /* Reset taille de base pour meilleure lisibilité */
    html {
        font-size: 16px;
    }
    
    /* Header */
    .glt-header {
        padding: 0 15px;
        height: 60px;
    }
    
    .glt-page-title {
        font-size: 16px;
    }
    
    .glt-header-right {
        gap: 6px;
        display: flex;
        align-items: center;
    }
    
    .glt-header-right .glt-btn-icon-round {
        width: 38px;
        height: 38px;
        padding: 0;
    }
    
    .glt-header-right .glt-btn-icon-round .dashicons {
        font-size: 18px;
        width: 18px;
        height: 18px;
    }
    
    /* FAB responsive */
    .glt-fab {
        bottom: 20px;
        right: 20px;
        width: 56px;
        height: 56px;
    }
    
    .glt-fab .dashicons {
        font-size: 24px;
        width: 24px;
        height: 24px;
    }
    
    /* Notifications dropdown responsive */
    .glt-notifications-dropdown-wrapper {
        right: 10px;
        left: 10px;
    }
    
    .glt-notifications-dropdown-wrapper .glt-notifications-dropdown {
        width: 100%;
        max-width: none;
    }
    
    /* Content */
    .glt-content {
        padding: 15px;
    }
    
    /* Stats */
    .glt-stats-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
    
    .glt-stat-card {
        padding: 15px 12px;
    }
    
    .glt-stat-value {
        font-size: 24px;
    }
    
    .glt-stat-label {
        font-size: 12px;
    }
    
    /* Filtres */
    .glt-filters,
    .glt-actions-filters {
        flex-direction: column;
        gap: 10px;
    }
    
    .glt-filters-row {
        flex-wrap: wrap;
        gap: 8px;
    }
    
    .glt-search-input,
    .glt-select-compact {
        width: 100%;
        min-width: unset;
        font-size: 16px; /* Évite le zoom sur iOS */
        padding: 12px;
    }
    
    /* Cartes actions */
    .glt-actions-grid {
        grid-template-columns: 1fr;
    }
    
    .glt-action-card {
        padding: 15px;
    }
    
    .glt-action-meta {
        flex-direction: column;
        gap: 8px;
    }
    
    .glt-action-footer {
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
    }
    
    .glt-action-actions {
        justify-content: flex-end;
    }
    
    /* Planning */
    .glt-planning-grid {
        grid-template-columns: 1fr;
    }
    
    .glt-planning-controls {
        flex-direction: column;
        gap: 10px;
    }
    
    /* Messagerie */
    .glt-messaging-container {
        flex-direction: column;
        height: calc(100vh - 180px);
        height: calc(100dvh - 180px);
        min-height: 400px;
        max-height: 600px;
    }
    
    .glt-conversations-list {
        width: 100%;
        max-height: 180px;
        min-height: 120px;
        border-right: none;
        border-bottom: 1px solid var(--glt-grey-200);
        flex-shrink: 0;
    }
    
    .glt-conversation-view {
        flex: 1;
        min-height: 0;
        display: flex;
        flex-direction: column;
        overflow: hidden;
    }
    
    .glt-conversation-active {
        flex: 1;
        display: flex;
        flex-direction: column;
        overflow: hidden;
        min-height: 0;
    }
    
    .glt-messages-container {
        flex: 1;
        min-height: 0;
        max-height: 300px;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
    }
    
    .glt-message-input-area {
        flex-shrink: 0;
        padding: 10px 15px;
    }
    
    .glt-message-input-area textarea {
        font-size: 16px; /* Évite le zoom sur iOS */
    }
    
    .glt-message-input-row .glt-btn-icon {
        flex-shrink: 0;
    }
    
    /* Modales */
    .glt-modal-container {
        width: 95%;
        max-width: none;
        margin: 10px auto;
        max-height: calc(100vh - 20px);
        max-height: calc(100dvh - 20px); /* Dynamic viewport height pour iOS */
    }
    
    .glt-modal-header h2 {
        font-size: 16px;
    }
    
    .glt-modal-body {
        padding: 15px;
    }
    
    .glt-modal-footer {
        flex-direction: column;
        gap: 10px;
        padding: 15px;
    }
    
    .glt-modal-footer .glt-btn {
        width: 100%;
        justify-content: center;
    }
    
    /* Formulaires */
    .glt-form-grid,
    .glt-form-row {
        grid-template-columns: 1fr;
    }
    
    .glt-field input,
    .glt-field select,
    .glt-field textarea {
        font-size: 16px; /* Évite le zoom sur iOS */
        padding: 12px;
    }
    
    /* Tableaux scrollables */
    .glt-table-container {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .glt-table {
        min-width: 600px;
    }
    
    /* Notifications */
    .glt-notifications-dropdown {
        position: fixed;
        top: 60px;
        left: 10px;
        right: 10px;
        width: auto;
        max-width: none;
    }
    
    /* Boutons d'action responsive */
    .glt-actions-buttons {
        flex-wrap: wrap;
        gap: 8px;
    }
    
    .glt-actions-buttons .glt-btn {
        flex: 1;
        min-width: 120px;
        justify-content: center;
    }
    
    /* Chips */
    .glt-membres-chips,
    .glt-secteurs-selection {
        gap: 6px;
    }
    
    .glt-membre-chip,
    .glt-secteur-chip {
        padding: 8px 12px;
        font-size: 13px;
    }
    
    /* Relance stats */
    .glt-relance-stats {
        flex-direction: row;
        flex-wrap: wrap;
    }
    
    .glt-relance-stat {
        flex: 1;
        min-width: 80px;
    }
}

/* === PETIT MOBILE (max 480px) === */
@media (max-width: 480px) {
    .glt-header {
        padding: 0 10px;
    }
    
    .glt-page-title {
        font-size: 14px;
    }
    
    .glt-content {
        padding: 10px;
    }
    
    .glt-stats-grid {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    
    .glt-stat-card {
        padding: 12px 10px;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
    
    .glt-stat-icon {
        width: 40px;
        height: 40px;
    }
    
    .glt-stat-value {
        font-size: 22px;
    }
    
    .glt-action-card {
        padding: 12px;
    }
    
    .glt-action-title {
        font-size: 14px;
    }
    
    .glt-action-header {
        flex-wrap: wrap;
        gap: 5px;
    }
    
    .glt-action-status,
    .glt-action-priority {
        font-size: 10px;
        padding: 3px 8px;
    }
    
    /* Sidebar plus étroite */
    .glt-sidebar {
        width: 260px;
    }
    
    .glt-nav-item {
        padding: 12px 14px;
        font-size: 14px;
    }
    
    /* Modales plein écran */
    .glt-modal-container {
        width: 100%;
        height: 100%;
        max-height: 100vh;
        max-height: 100dvh;
        margin: 0;
        border-radius: 0;
    }
    
    .glt-modal-body {
        flex: 1;
        overflow-y: auto;
    }
    
    /* Conversation */
    .glt-conversations-list {
        max-height: 150px;
    }
    
    .glt-conversation-item {
        padding: 10px;
    }
    
    .glt-message {
        max-width: 90%;
    }
}

/* === TRÈS PETIT ÉCRAN (max 360px) === */
@media (max-width: 360px) {
    .glt-sidebar {
        width: 100%;
    }
    
    .glt-stat-value {
        font-size: 20px;
    }
    
    .glt-btn {
        padding: 10px 12px;
        font-size: 13px;
    }
    
    .glt-btn .dashicons {
        font-size: 16px;
    }
}

/* === ÉCRANS HAUTE DENSITÉ (Retina) === */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .glt-btn,
    .glt-nav-item,
    .glt-action-card,
    .glt-stat-card {
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }
}

/* === ORIENTATION PAYSAGE SUR MOBILE === */
@media (max-height: 500px) and (orientation: landscape) {
    .glt-modal-container {
        max-height: 95vh;
    }
    
    .glt-modal-body {
        max-height: 60vh;
        overflow-y: auto;
    }
    
    .glt-sidebar {
        width: 220px;
    }
}

/* === PRÉFÉRENCE MOUVEMENT RÉDUIT === */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* === SAFE AREA (iPhone X et plus récents) === */
@supports (padding: max(0px)) {
    .glt-header {
        padding-top: max(0px, env(safe-area-inset-top));
        padding-left: max(15px, env(safe-area-inset-left));
        padding-right: max(15px, env(safe-area-inset-right));
    }
    
    .glt-sidebar {
        padding-bottom: max(20px, env(safe-area-inset-bottom));
    }
    
    .glt-modal-footer {
        padding-bottom: max(15px, env(safe-area-inset-bottom));
    }
    
    .glt-message-input-area {
        padding-bottom: max(15px, env(safe-area-inset-bottom));
    }
}

/* === IMPRESSION === */
@media print {
    .glt-sidebar,
    .glt-header,
    .glt-footer,
    .glt-btn,
    .glt-modal,
    .glt-notifications-dropdown,
    .glt-message-input-area,
    .glt-mobile-menu-btn {
        display: none !important;
    }
    
    .glt-main {
        margin-left: 0 !important;
        width: 100% !important;
    }
    
    .glt-content {
        padding: 0 !important;
    }
    
    .glt-card,
    .glt-action-card,
    .glt-stat-card {
        break-inside: avoid;
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }
}

/* ===== TIMELINE HISTORIQUE ===== */
.glt-timeline {
    position: relative;
    padding: 20px;
}

.glt-timeline::before {
    content: '';
    position: absolute;
    left: 28px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--glt-grey-200);
}

.glt-timeline-item {
    position: relative;
    padding-left: 60px;
    padding-bottom: 25px;
    margin-bottom: 0;
}

.glt-timeline-item:last-child {
    padding-bottom: 0;
}

.glt-timeline-icon {
    position: absolute;
    left: 8px;
    top: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    z-index: 1;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.glt-timeline-icon .dashicons {
    font-size: 18px;
}

.glt-timeline-content {
    background: var(--glt-grey-50);
    border-radius: var(--glt-border-radius);
    padding: 15px 18px;
    border: 1px solid var(--glt-grey-200);
    transition: all 0.2s;
}

.glt-timeline-content:hover {
    background: #fff;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
}

.glt-timeline-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 8px;
}

.glt-timeline-title {
    font-weight: 500;
    color: var(--glt-grey-800);
    line-height: 1.4;
}

.glt-timeline-type {
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 12px;
    background: var(--glt-grey-200);
    color: var(--glt-grey-600);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-shrink: 0;
    margin-left: 10px;
}

.glt-timeline-meta {
    display: flex;
    gap: 15px;
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-timeline-meta-item {
    display: flex;
    align-items: center;
    gap: 5px;
}

.glt-timeline-meta-item .dashicons {
    font-size: 14px;
}

.glt-card-footer {
    padding: 15px 20px;
    background: var(--glt-grey-50);
    border-top: 1px solid var(--glt-grey-200);
    text-align: center;
}

/* ===== PRÉFÉRENCES ===== */
.glt-preference-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 0;
    border-bottom: 1px solid var(--glt-grey-200);
}

.glt-preference-item:last-child {
    border-bottom: none;
}

.glt-preference-info {
    flex: 1;
}

.glt-preference-info h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--glt-grey-800);
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
}

.glt-preference-info h4 .dashicons {
    font-size: 18px;
    color: var(--glt-primary);
}

.glt-preference-info p {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin: 0;
}

/* API REST Endpoints */
.glt-api-endpoint {
    background: #fff;
    border: 1px solid var(--glt-grey-200);
    border-radius: 8px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.glt-api-endpoint code {
    font-size: 13px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-api-endpoint small {
    font-size: 11px;
    color: var(--glt-grey-500);
}

.glt-api-endpoint .glt-badge {
    align-self: flex-start;
    font-size: 10px;
    padding: 2px 6px;
}

/* API Logs */
.glt-api-log-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: #fff;
    border-radius: 6px;
    margin-bottom: 5px;
    font-size: 12px;
}

.glt-api-log-item:last-child {
    margin-bottom: 0;
}

.glt-api-log-item .log-status {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.glt-api-log-item .log-status.success {
    background: var(--glt-success);
}

.glt-api-log-item .log-status.error {
    background: var(--glt-danger);
}

.glt-api-log-item .log-endpoint {
    flex: 1;
    font-family: monospace;
    color: var(--glt-grey-700);
}

.glt-api-log-item .log-date {
    color: var(--glt-grey-500);
    font-size: 11px;
}

.glt-api-log-item .log-ip {
    color: var(--glt-grey-400);
    font-size: 11px;
}

/* PWA Header Install Button */
.glt-pwa-header-btn {
    background: linear-gradient(135deg, #5b8def, #4a7bd9) !important;
    color: #fff !important;
    border: none !important;
    animation: glt-pulse-blue 2s infinite;
}

.glt-pwa-header-btn:hover {
    background: linear-gradient(135deg, #6b9bef, #5b8def) !important;
    transform: scale(1.05);
}

.glt-pwa-header-btn .dashicons {
    margin-right: 4px;
}

.glt-pwa-btn-text {
    display: none;
}

@media (min-width: 600px) {
    .glt-pwa-btn-text {
        display: inline;
    }
}

@keyframes glt-pulse-blue {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(91, 141, 239, 0.4);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(91, 141, 239, 0);
    }
}

/* PWA Instructions Modal */
.glt-pwa-instructions-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999999;
    padding: 20px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    -webkit-overflow-scrolling: touch;
}

.glt-pwa-instructions-content {
    background: #fff;
    border-radius: 24px;
    padding: 30px;
    max-width: 400px;
    width: 100%;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.4);
    animation: glt-modal-pop 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes glt-modal-pop {
    0% {
        opacity: 0;
        transform: scale(0.8) translateY(30px);
    }
    100% {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.glt-pwa-instructions-header {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 25px;
    padding-bottom: 20px;
    border-bottom: 2px solid #f1f5f9;
}

.glt-pwa-instructions-header .glt-pwa-icon {
    font-size: 40px;
    line-height: 1;
}

.glt-pwa-instructions-header .dashicons {
    font-size: 36px;
    width: 36px;
    height: 36px;
    color: #4a7bd9;
    background: linear-gradient(135deg, #eff6ff, #dbeafe);
    padding: 12px;
    border-radius: 16px;
}

.glt-pwa-instructions-header h3 {
    margin: 0;
    font-size: 22px;
    font-weight: 700;
    color: #1e293b;
}

.glt-pwa-instructions-body {
    margin-bottom: 25px;
}

.glt-pwa-step {
    display: flex;
    align-items: flex-start;
    gap: 15px;
    padding: 15px;
    background: #f8fafc;
    border-radius: 12px;
    margin-bottom: 12px;
    font-size: 15px;
    line-height: 1.5;
    color: #475569;
}

.glt-pwa-step:last-child {
    margin-bottom: 0;
}

.glt-pwa-step-num {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 28px;
    background: linear-gradient(135deg, #5b8def, #4a7bd9);
    color: #fff;
    border-radius: 50%;
    font-size: 14px;
    font-weight: 700;
}

.glt-pwa-step strong {
    color: #1e293b;
}

.glt-pwa-instructions-close {
    width: 100%;
    padding: 16px 24px;
    background: linear-gradient(135deg, #5b8def 0%, #4a7bd9 100%);
    color: #fff !important;
    border: none !important;
    outline: none !important;
    border-radius: 12px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(74, 123, 217, 0.35);
    -webkit-tap-highlight-color: transparent;
}

.glt-pwa-instructions-close:hover,
.glt-pwa-instructions-close:active {
    background: linear-gradient(135deg, #6b9bef 0%, #5b8def 100%);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(74, 123, 217, 0.45);
    color: #fff !important;
}

/* Touch feedback pour mobile */
.glt-pwa-install-btn.touched {
    transform: scale(0.95);
    opacity: 0.9;
}

/* PWA Status */
.glt-pwa-status-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid var(--glt-grey-200);
}

.glt-pwa-status-item:last-child {
    border-bottom: none;
}

.glt-pwa-status-item .dashicons {
    font-size: 18px;
    width: 18px;
    height: 18px;
    color: var(--glt-grey-500);
}

/* Switch toggle */
.glt-switch {
    position: relative;
    display: inline-block;
    width: 52px;
    height: 28px;
    flex-shrink: 0;
}

.glt-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.glt-switch-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--glt-grey-300);
    transition: 0.3s;
    border-radius: 28px;
}

.glt-switch-slider:before {
    position: absolute;
    content: "";
    height: 22px;
    width: 22px;
    left: 3px;
    bottom: 3px;
    background-color: white;
    transition: 0.3s;
    border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.glt-switch input:checked + .glt-switch-slider {
    background: linear-gradient(135deg, var(--glt-primary), var(--glt-primary-light));
}

.glt-switch input:checked + .glt-switch-slider:before {
    transform: translateX(24px);
}

.glt-switch input:focus + .glt-switch-slider {
    box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.2);
}

/* ===== CHECKBOX CARD (pour les options de backup) ===== */
.glt-checkbox-card {
    display: block;
    cursor: pointer;
}

.glt-checkbox-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.glt-checkbox-card-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 15px 10px;
    background: var(--glt-grey-100);
    border: 2px solid var(--glt-grey-200);
    border-radius: 10px;
    transition: all 0.2s ease;
    text-align: center;
    font-size: 13px;
}

.glt-checkbox-card-content .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    color: var(--glt-grey-500);
    transition: color 0.2s ease;
}

.glt-checkbox-card:hover .glt-checkbox-card-content {
    border-color: var(--glt-primary);
    background: var(--glt-grey-50);
}

.glt-checkbox-card input:checked + .glt-checkbox-card-content {
    border-color: var(--glt-primary);
    background: rgba(59, 130, 246, 0.1);
}

.glt-checkbox-card input:checked + .glt-checkbox-card-content .dashicons {
    color: var(--glt-primary);
}

/* Checkbox inline simple */
.glt-checkbox-inline {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 14px;
}

.glt-checkbox-inline input {
    width: 18px;
    height: 18px;
    accent-color: var(--glt-primary);
}

/* ===== UPLOAD ZONE (drag & drop) ===== */
.glt-upload-zone {
    border: 2px dashed var(--glt-grey-300);
    border-radius: 12px;
    padding: 40px;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    background: var(--glt-grey-50);
}

.glt-upload-zone:hover {
    border-color: var(--glt-primary);
    background: rgba(59, 130, 246, 0.05);
}

.glt-upload-zone.dragover {
    border-color: var(--glt-primary);
    background: rgba(59, 130, 246, 0.1);
    transform: scale(1.02);
}

.glt-upload-zone .dashicons {
    font-size: 48px;
    width: 48px;
    height: 48px;
    color: var(--glt-grey-400);
    transition: color 0.3s ease;
}

.glt-upload-zone:hover .dashicons,
.glt-upload-zone.dragover .dashicons {
    color: var(--glt-primary);
}

/* Info box */
.glt-info-box {
    background: var(--glt-grey-100);
    padding: 15px;
    border-radius: 8px;
}

/* ===== SÉLECTION SECTEURS RELECTEUR ===== */
.glt-relecteur-secteurs-field {
    background: var(--glt-grey-50);
    border: 1px solid var(--glt-grey-200);
    border-radius: var(--glt-border-radius);
    padding: 15px;
    margin-top: 10px;
}

.glt-secteurs-filters {
    display: flex;
    gap: 10px;
    margin-bottom: 15px;
}

.glt-secteurs-filters select {
    flex: 1;
}

.glt-secteurs-checkboxes {
    max-height: 250px;
    overflow-y: auto;
    border: 1px solid var(--glt-grey-200);
    border-radius: var(--glt-border-radius-sm);
    background: #fff;
    padding: 10px;
}

.glt-secteur-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 0.2s;
    margin-bottom: 2px;
}

.glt-secteur-checkbox:hover {
    background: var(--glt-grey-100);
}

.glt-secteur-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0;
    cursor: pointer;
}

.glt-secteur-checkbox.hidden {
    display: none;
}

.glt-secteur-label {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.glt-secteur-label strong {
    font-size: 13px;
    color: var(--glt-grey-800);
}

.glt-secteur-label small {
    font-size: 11px;
    color: var(--glt-grey-500);
}

.glt-secteurs-actions {
    display: flex;
    gap: 10px;
    margin-top: 10px;
}

.glt-secteurs-actions .glt-btn {
    flex: 1;
}

/* ===== BANNIÈRE RELECTEUR ===== */
.glt-relecteur-banner {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: linear-gradient(135deg, #3b82f6, #1d4ed8);
    color: #fff;
    border-radius: var(--glt-border-radius);
    margin-bottom: 20px;
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}

.glt-relecteur-banner .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    opacity: 0.9;
}

.glt-relecteur-banner-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.glt-relecteur-banner-content strong {
    font-size: 14px;
    font-weight: 600;
}

.glt-relecteur-banner-content span {
    font-size: 12px;
    opacity: 0.9;
}

@media (max-width: 768px) {
    .glt-relecteur-banner-content {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 5px;
    }
}

/* ============================================================
   MOBILE APP-LIKE DESIGN - Cards System
   Visible uniquement sur mobile (< 768px)
   ============================================================ */

/* === Utilitaires Desktop/Mobile === */
@media (min-width: 769px) {
    .glt-mobile-only { display: none !important; }
}

@media (max-width: 768px) {
    .glt-desktop-only { display: none !important; }
    .glt-mobile-only { display: block !important; }
    
    /* Afficher les cards mobile */
    .glt-mobile-cards {
        display: flex !important;
        flex-direction: column;
        gap: 12px;
    }
    
    /* Cacher les tableaux SEULEMENT quand il y a une alternative mobile à côté */
    .glt-has-mobile-alt .glt-table-wrapper,
    .glt-has-mobile-alt .glt-table {
        display: none !important;
    }
}

/* === Mobile Card Base === */
.glt-mobile-card {
    background: #fff;
    border-radius: 16px;
    padding: 16px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    border: 1px solid var(--glt-grey-100);
    transition: all 0.2s ease;
}

.glt-mobile-card:active {
    transform: scale(0.98);
    box-shadow: 0 1px 4px rgba(0,0,0,0.1);
}

.glt-mobile-card-header {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
}

.glt-mobile-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.glt-mobile-card-icon .dashicons {
    font-size: 22px;
    width: 22px;
    height: 22px;
    color: #fff;
}

.glt-mobile-card-icon.blue { background: linear-gradient(135deg, #3b82f6, #2563eb); }
.glt-mobile-card-icon.green { background: linear-gradient(135deg, #10b981, #059669); }
.glt-mobile-card-icon.purple { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }
.glt-mobile-card-icon.orange { background: linear-gradient(135deg, #f59e0b, #d97706); }
.glt-mobile-card-icon.red { background: linear-gradient(135deg, #ef4444, #dc2626); }
.glt-mobile-card-icon.grey { background: linear-gradient(135deg, #6b7280, #4b5563); }

.glt-mobile-card-title {
    flex: 1;
    min-width: 0;
}

.glt-mobile-card-title h4 {
    margin: 0 0 4px 0;
    font-size: 15px;
    font-weight: 600;
    color: var(--glt-grey-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.glt-mobile-card-title p {
    margin: 0;
    font-size: 13px;
    color: var(--glt-grey-500);
}

.glt-mobile-card-badge {
    flex-shrink: 0;
}

/* === Mobile Card Body === */
.glt-mobile-card-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.glt-mobile-card-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 13px;
}

.glt-mobile-card-row-label {
    color: var(--glt-grey-500);
    display: flex;
    align-items: center;
    gap: 6px;
}

.glt-mobile-card-row-label .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

.glt-mobile-card-row-value {
    color: var(--glt-grey-700);
    font-weight: 500;
    text-align: right;
}

/* === Mobile Card Progress Bar === */
.glt-mobile-progress {
    height: 8px;
    background: var(--glt-grey-100);
    border-radius: 4px;
    overflow: hidden;
    margin: 8px 0;
}

.glt-mobile-progress-bar {
    height: 100%;
    border-radius: 4px;
    transition: width 0.3s ease;
}

.glt-mobile-progress-bar.green { background: linear-gradient(90deg, #10b981, #34d399); }
.glt-mobile-progress-bar.yellow { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.glt-mobile-progress-bar.orange { background: linear-gradient(90deg, #f97316, #fb923c); }
.glt-mobile-progress-bar.red { background: linear-gradient(90deg, #ef4444, #f87171); }

/* === Mobile Card Actions === */
.glt-mobile-card-actions {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--glt-grey-100);
}

.glt-mobile-card-actions .glt-btn {
    flex: 1;
    justify-content: center;
    padding: 10px;
    border-radius: 10px;
    font-size: 13px;
}

/* === Mobile Tags/Chips === */
.glt-mobile-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.glt-mobile-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: var(--glt-grey-100);
    border-radius: 20px;
    font-size: 11px;
    font-weight: 500;
    color: var(--glt-grey-600);
}

.glt-mobile-tag.blue { background: #dbeafe; color: #1d4ed8; }
.glt-mobile-tag.green { background: #d1fae5; color: #059669; }
.glt-mobile-tag.purple { background: #ede9fe; color: #7c3aed; }
.glt-mobile-tag.orange { background: #ffedd5; color: #c2410c; }
.glt-mobile-tag.red { background: #fee2e2; color: #dc2626; }

/* === Dashboard Mobile - Comparatifs === */
@media (max-width: 768px) {
    .glt-year-selector {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }
    
    .glt-year-comparison {
        flex-wrap: wrap;
        justify-content: center;
    }
    
    .glt-stats-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
    }
    
    .glt-stat-card {
        padding: 12px !important;
    }
    
    .glt-stat-value {
        font-size: 24px !important;
    }
    
    .glt-stat-label {
        font-size: 11px !important;
    }
    
    /* Colonnes en pleine largeur */
    .glt-row {
        flex-direction: column !important;
    }
    
    .glt-col-6,
    .glt-col-4,
    .glt-col-8,
    .glt-col-3 {
        width: 100% !important;
        flex: none !important;
    }
    
    /* Cards dashboard */
    .glt-card {
        margin-bottom: 15px;
    }
}

/* === Top 10 Mobile === */
.glt-top10-mobile-list {
    display: none;
}

@media (max-width: 768px) {
    .glt-top10-mobile-list {
        display: flex;
        flex-direction: column;
        gap: 8px;
    }
}

.glt-top10-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: #fff;
    border-radius: 12px;
    border: 1px solid var(--glt-grey-100);
}

.glt-top10-rank {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
    flex-shrink: 0;
}

.glt-top10-rank.gold { background: linear-gradient(135deg, #fbbf24, #f59e0b); color: #fff; }
.glt-top10-rank.silver { background: linear-gradient(135deg, #9ca3af, #6b7280); color: #fff; }
.glt-top10-rank.bronze { background: linear-gradient(135deg, #d97706, #b45309); color: #fff; }
.glt-top10-rank.default { background: var(--glt-grey-100); color: var(--glt-grey-600); }

.glt-top10-info {
    flex: 1;
    min-width: 0;
}

.glt-top10-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--glt-grey-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}

.glt-top10-bar {
    height: 6px;
    background: var(--glt-grey-100);
    border-radius: 3px;
    overflow: hidden;
}

.glt-top10-bar-fill {
    height: 100%;
    border-radius: 3px;
}

.glt-top10-score {
    font-size: 14px;
    font-weight: 600;
    flex-shrink: 0;
}

/* === Locaux Mobile Cards === */
@media (max-width: 768px) {
    .glt-territoire-block,
    .glt-agence-block,
    .glt-secteur-block {
        margin-bottom: 10px;
    }
    
    .glt-territoire-header {
        padding: 12px !important;
        font-size: 14px;
    }
    
    .glt-agence-name,
    .glt-secteur-name {
        font-size: 13px !important;
        padding: 8px 12px !important;
    }
    
    .glt-locaux-mobile-cards {
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding: 10px;
    }
}

.glt-local-mobile-card {
    background: #fff;
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
    border: 1px solid var(--glt-grey-100);
}

.glt-local-mobile-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.glt-local-mobile-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    display: flex;
    align-items: center;
    justify-content: center;
}

.glt-local-mobile-icon .dashicons {
    color: #fff;
    font-size: 20px;
}

.glt-local-mobile-info {
    flex: 1;
    min-width: 0;
}

.glt-local-mobile-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--glt-grey-800);
    margin-bottom: 2px;
}

.glt-local-mobile-address {
    font-size: 12px;
    color: var(--glt-grey-500);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.glt-local-mobile-stats {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    padding: 10px;
    background: var(--glt-grey-50);
    border-radius: 10px;
}

.glt-local-mobile-stats-item {
    flex: 1;
    text-align: center;
}

.glt-local-mobile-stats-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-local-mobile-stats-label {
    font-size: 10px;
    color: var(--glt-grey-500);
    text-transform: uppercase;
}

.glt-local-mobile-actions {
    display: flex;
    gap: 8px;
}

.glt-local-mobile-actions .glt-btn {
    flex: 1;
    padding: 10px;
    border-radius: 10px;
    font-size: 12px;
    justify-content: center;
}

/* === Contrôles Mobile Cards === */
.glt-controle-mobile-card {
    background: #fff;
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
    border: 1px solid var(--glt-grey-100);
    position: relative;
}

.glt-controle-mobile-card.locked {
    border-left: 4px solid #f59e0b;
}

.glt-controle-mobile-header {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 10px;
}

.glt-controle-mobile-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 50px;
    padding: 8px;
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    border-radius: 10px;
    color: #fff;
}

.glt-controle-mobile-date-day {
    font-size: 20px;
    font-weight: 700;
    line-height: 1;
}

.glt-controle-mobile-date-month {
    font-size: 10px;
    text-transform: uppercase;
    opacity: 0.9;
}

.glt-controle-mobile-info {
    flex: 1;
    min-width: 0;
}

.glt-controle-mobile-local {
    font-size: 14px;
    font-weight: 600;
    color: var(--glt-grey-800);
    margin-bottom: 4px;
}

.glt-controle-mobile-numero {
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-controle-mobile-score {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 10px 0;
}

.glt-controle-mobile-score-bar {
    flex: 1;
    height: 8px;
    background: var(--glt-grey-100);
    border-radius: 4px;
    overflow: hidden;
}

.glt-controle-mobile-score-fill {
    height: 100%;
    border-radius: 4px;
}

.glt-controle-mobile-score-value {
    font-size: 14px;
    font-weight: 600;
    min-width: 45px;
    text-align: right;
}

.glt-controle-mobile-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--glt-grey-100);
}

.glt-controle-mobile-status {
    display: flex;
    gap: 6px;
}

.glt-controle-mobile-actions {
    display: flex;
    gap: 6px;
}

.glt-controle-mobile-actions .glt-btn {
    padding: 8px;
    border-radius: 8px;
}

/* === Utilisateurs Mobile Cards === */
.glt-user-mobile-card {
    background: #fff;
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
    border: 1px solid var(--glt-grey-100);
}

.glt-user-mobile-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.glt-user-mobile-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, #8b5cf6, #7c3aed);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 18px;
    font-weight: 600;
}

.glt-user-mobile-info h4 {
    margin: 0 0 4px 0;
    font-size: 15px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-user-mobile-info p {
    margin: 0;
    font-size: 13px;
    color: var(--glt-grey-500);
}

.glt-user-mobile-role {
    margin-left: auto;
}

.glt-user-mobile-details {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 10px;
}

.glt-user-mobile-actions {
    display: flex;
    gap: 8px;
    padding-top: 10px;
    border-top: 1px solid var(--glt-grey-100);
}

.glt-user-mobile-actions .glt-btn {
    flex: 1;
    padding: 10px;
    border-radius: 10px;
    justify-content: center;
}

/* === Statistiques Mobile === */
@media (max-width: 768px) {
    .glt-stats-section {
        margin-bottom: 15px;
    }
    
    .glt-stats-chart-container {
        height: 200px !important;
    }
    
    .glt-accordion-item {
        margin-bottom: 8px;
    }
    
    .glt-accordion-header {
        padding: 14px;
        font-size: 14px;
        background: var(--glt-grey-50);
        border-radius: 10px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        cursor: pointer;
        border: 1px solid var(--glt-grey-100);
    }
    
    .glt-accordion-header .dashicons {
        transition: transform 0.2s ease;
    }
    
    .glt-accordion-header.active .dashicons {
        transform: rotate(180deg);
    }
    
    .glt-accordion-content {
        display: none;
        padding: 10px;
    }
    
    .glt-accordion-content.active {
        display: block;
    }
}

/* === Gestion Locaux Mobile === */
@media (max-width: 768px) {
    .glt-gestion-local-card {
        background: #fff;
        border-radius: 14px;
        padding: 14px;
        box-shadow: 0 2px 6px rgba(0,0,0,0.06);
        border: 1px solid var(--glt-grey-100);
    }
    
    .glt-gestion-local-header {
        display: flex;
        align-items: center;
        gap: 10px;
        margin-bottom: 10px;
    }
    
    .glt-gestion-local-thumb {
        width: 50px;
        height: 50px;
        border-radius: 10px;
        object-fit: cover;
        background: var(--glt-grey-100);
    }
    
    .glt-gestion-local-info {
        flex: 1;
    }
    
    .glt-gestion-local-type {
        font-size: 14px;
        font-weight: 600;
        color: var(--glt-grey-800);
    }
    
    .glt-gestion-local-address {
        font-size: 12px;
        color: var(--glt-grey-500);
    }
    
    .glt-gestion-local-tags {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        margin: 10px 0;
    }
    
    .glt-gestion-local-actions {
        display: flex;
        gap: 8px;
        padding-top: 10px;
        border-top: 1px solid var(--glt-grey-100);
    }
    
    .glt-gestion-local-actions .glt-btn {
        flex: 1;
        padding: 10px;
        border-radius: 10px;
        justify-content: center;
    }
    
    /* Filtres mobile */
    .glt-filters-card {
        padding: 12px !important;
    }
    
    .glt-filters-row-inline {
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    .glt-filter-group {
        width: 100% !important;
    }
    
    /* Toolbar mobile */
    .glt-toolbar {
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    .glt-toolbar-left,
    .glt-toolbar-right {
        width: 100% !important;
    }
    
    .glt-toolbar-right {
        flex-wrap: wrap;
    }
    
    .glt-toolbar-right .glt-btn {
        flex: 1;
        min-width: calc(50% - 5px);
        justify-content: center;
    }
    
    .glt-search-box {
        width: 100% !important;
    }
    
    .glt-search-box input {
        width: 100% !important;
    }
}

/* === Empty States Mobile === */
@media (max-width: 768px) {
    .glt-empty-state {
        padding: 40px 20px;
    }
    
    .glt-empty-state .dashicons {
        font-size: 48px;
        width: 48px;
        height: 48px;
    }
    
    .glt-empty-state p {
        font-size: 14px;
    }
}

/* === Bulk Actions Mobile === */
@media (max-width: 768px) {
    .glt-bulk-actions-bar {
        flex-direction: column !important;
        gap: 10px;
        padding: 12px !important;
    }
    
    .glt-bulk-actions-buttons {
        width: 100%;
        display: flex;
        gap: 8px;
    }
    
    .glt-bulk-actions-buttons .glt-btn {
        flex: 1;
        justify-content: center;
    }
}

/* === FAB position adjustment === */
@media (max-width: 768px) {
    .glt-fab {
        bottom: 80px;
    }
}

/* === Tableaux responsive pour sections sans cards mobile === */
@media (max-width: 768px) {
    /* Les tableaux sont maintenant tous convertis en cards mobile */
    /* Plus besoin de scroll horizontal */
}

/* === Notifications Mobile Centré 90% === */
@media (max-width: 768px) {
    .glt-notifications-dropdown-wrapper {
        top: 55px;
        left: 5%;
        right: 5%;
        width: 90%;
        margin: 0 auto;
    }
    
    .glt-notifications-dropdown-wrapper .glt-notifications-dropdown {
        width: 100%;
        max-width: none;
        max-height: 70vh;
        border-radius: 16px;
        box-shadow: 0 10px 50px rgba(0,0,0,0.25);
    }
    
    .glt-notifications-header {
        padding: 14px 16px;
        border-radius: 16px 16px 0 0;
    }
    
    .glt-notifications-header h4 {
        font-size: 15px;
    }
}

/* === Bouton Tout Supprimer Notifications === */
.glt-notifications-header-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.glt-delete-all-notifs {
    color: #ef4444 !important;
    font-size: 12px !important;
}

.glt-delete-all-notifs:hover {
    background: #fef2f2 !important;
}

/* === Modal Confirmation Petite === */
.glt-modal-sm .glt-modal-container {
    max-width: 380px;
}

.glt-modal-header-danger {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
    color: #fff;
}

.glt-modal-header-danger h2 {
    color: #fff;
    display: flex;
    align-items: center;
    gap: 10px;
}

.glt-modal-header-danger .glt-modal-close {
    color: #fff;
}

.glt-confirm-icon {
    width: 70px;
    height: 70px;
    border-radius: 50%;
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}

.glt-confirm-icon .dashicons {
    font-size: 32px;
    width: 32px;
    height: 32px;
    color: #ef4444;
}

.glt-modal-confirm .glt-modal-body h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-modal-confirm .glt-modal-footer {
    border-top: 1px solid var(--glt-grey-100);
    padding: 20px;
}

/* Animation shake pour l'icône */
@keyframes glt-shake {
    0%, 100% { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-5px); }
    20%, 40%, 60%, 80% { transform: translateX(5px); }
}

.glt-modal-confirm.active .glt-confirm-icon {
    animation: glt-shake 0.5s ease-in-out;
}

/* === QR Code Modal === */
.glt-qrcode-container {
    background: #fff;
    border: 2px solid var(--glt-grey-200);
    border-radius: 16px;
    padding: 20px;
    display: inline-block;
    box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}

.glt-qrcode-container img {
    display: block;
    width: 200px;
    height: 200px;
}

.glt-qrcode-loading {
    width: 200px;
    height: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--glt-grey-400);
}

.glt-qrcode-loading .dashicons {
    font-size: 40px;
    width: 40px;
    height: 40px;
    margin-bottom: 10px;
}

/* QR Code button style */
.glt-btn-qrcode {
    background: linear-gradient(135deg, #8b5cf6, #7c3aed) !important;
    border-color: #8b5cf6 !important;
    color: #fff !important;
}

.glt-btn-qrcode:hover {
    background: linear-gradient(135deg, #7c3aed, #6d28d9) !important;
}

/* Export QR codes options */
.glt-qrcodes-options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
    margin-bottom: 20px;
}

.glt-qrcodes-preview {
    background: var(--glt-grey-50);
    border-radius: 10px;
    padding: 20px;
    margin-top: 15px;
}

.glt-progress-container {
    display: flex;
    align-items: center;
    gap: 15px;
}

.glt-progress-container .glt-progress {
    flex: 1;
}

#glt-qrcodes-progress-text {
    font-weight: 600;
    min-width: 45px;
    text-align: right;
}

/* QR Code dans les actions */
@media (max-width: 768px) {
    .glt-qrcode-container img {
        width: 180px;
        height: 180px;
    }
    
    #glt-modal-qrcode .glt-modal-footer {
        flex-direction: column;
    }
    
    #glt-modal-qrcode .glt-modal-footer .glt-btn {
        width: 100%;
    }
}

/* Print styles for QR Code */
@media print {
    .glt-qrcode-print-page {
        page-break-after: always;
        padding: 20mm;
    }
    
    .glt-qrcode-print-item {
        display: inline-block;
        text-align: center;
        padding: 15px;
        border: 1px solid #ddd;
        margin: 10px;
    }
    
    .glt-qrcode-print-item img {
        width: 150px;
        height: 150px;
    }
    
    .glt-qrcode-print-item h4 {
        margin: 10px 0 5px;
        font-size: 12px;
    }
    
    .glt-qrcode-print-item p {
        margin: 0;
        font-size: 10px;
        color: #666;
    }
}

/* === CARTE DES LOCAUX === */
.glt-carte-container {
    position: relative;
    padding: 0 !important;
    overflow: hidden;
}

.glt-map {
    width: 100%;
    height: 600px;
    border-radius: 12px;
    z-index: 1;
}

.glt-map-legend {
    position: absolute;
    bottom: 20px;
    left: 20px;
    background: rgba(255, 255, 255, 0.95);
    padding: 12px 15px;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
    z-index: 1000;
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.glt-map-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--glt-grey-700);
}

.glt-map-marker-icon {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.3);
}

.glt-map-marker-icon.green { background: #10b981; }
.glt-map-marker-icon.orange { background: #f59e0b; }
.glt-map-marker-icon.red { background: #ef4444; }
.glt-map-marker-icon.grey { background: #9ca3af; }

.glt-map-stats {
    position: absolute;
    top: 20px;
    right: 20px;
    background: rgba(255, 255, 255, 0.95);
    padding: 10px 15px;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
    z-index: 1000;
    font-size: 13px;
    color: var(--glt-grey-700);
}

.glt-map-stats #glt-map-count {
    font-weight: 700;
    color: var(--glt-primary);
}

/* Popup Leaflet personnalisé */
.glt-map-popup {
    min-width: 200px;
}

.glt-map-popup-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--glt-grey-100);
}

.glt-map-popup-photo {
    width: 50px;
    height: 50px;
    border-radius: 8px;
    object-fit: cover;
}

.glt-map-popup-photo-placeholder {
    width: 50px;
    height: 50px;
    border-radius: 8px;
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.glt-map-popup-info h4 {
    margin: 0 0 3px;
    font-size: 14px;
    font-weight: 600;
    color: var(--glt-grey-800);
}

.glt-map-popup-info p {
    margin: 0;
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-map-popup-score {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.glt-map-popup-score-value {
    font-size: 24px;
    font-weight: 700;
}

.glt-map-popup-score-bar {
    flex: 1;
    height: 8px;
    background: var(--glt-grey-100);
    border-radius: 4px;
    overflow: hidden;
}

.glt-map-popup-score-bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.3s ease;
}

.glt-map-popup-date {
    font-size: 11px;
    color: var(--glt-grey-500);
    margin-bottom: 10px;
}

.glt-map-popup-actions {
    display: flex;
    gap: 8px;
}

.glt-map-popup-actions .glt-btn {
    flex: 1;
    justify-content: center;
    font-size: 12px;
    padding: 6px 10px;
}

/* Leaflet overrides */
.leaflet-popup-content-wrapper {
    border-radius: 12px !important;
    padding: 0 !important;
}

.leaflet-popup-content {
    margin: 15px !important;
}

.leaflet-popup-close-button {
    top: 8px !important;
    right: 8px !important;
}

/* Fullscreen */
.glt-map-fullscreen .glt-carte-container {
    position: fixed !important;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    border-radius: 0;
    margin: 0;
}

.glt-map-fullscreen .glt-map {
    height: 100vh;
    border-radius: 0;
}

.glt-map-fullscreen .glt-toolbar {
    display: none;
}

.glt-map-exit-fullscreen {
    position: fixed;
    top: 20px;
    left: 20px;
    z-index: 10000;
    background: #fff;
    border: none;
    padding: 10px 15px;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
}

/* Mobile */
@media (max-width: 768px) {
    .glt-map {
        height: 450px;
    }
    
    .glt-map-legend {
        bottom: 10px;
        left: 10px;
        right: 10px;
        justify-content: center;
        padding: 10px;
    }
    
    .glt-map-stats {
        top: 10px;
        right: 10px;
        padding: 8px 12px;
        font-size: 12px;
    }
    
    #glt-page-carte .glt-toolbar {
        flex-direction: column;
        gap: 10px;
    }
    
    #glt-page-carte .glt-toolbar-left,
    #glt-page-carte .glt-toolbar-right {
        width: 100%;
        flex-wrap: wrap;
    }
    
    #glt-page-carte .glt-filter-group {
        flex: 1;
        min-width: 140px;
    }
}

/* === PANNEAU TOURNÉE === */
.glt-tournee-panel {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    margin-bottom: 15px;
    overflow: hidden;
}

.glt-tournee-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 15px 20px;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    color: #fff;
}

.glt-tournee-header h3 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-tournee-header .glt-btn-outline {
    background: rgba(255,255,255,0.2);
    border-color: rgba(255,255,255,0.5);
    color: #fff;
}

.glt-tournee-stats {
    display: flex;
    gap: 20px;
    padding: 15px 20px;
    background: var(--glt-grey-50);
    border-bottom: 1px solid var(--glt-grey-100);
}

.glt-tournee-stat {
    text-align: center;
    flex: 1;
}

.glt-tournee-stat-value {
    display: block;
    font-size: 20px;
    font-weight: 700;
    color: var(--glt-primary);
}

.glt-tournee-stat-label {
    display: block;
    font-size: 11px;
    color: var(--glt-grey-500);
    text-transform: uppercase;
    margin-top: 2px;
}

.glt-tournee-list {
    max-height: 250px;
    overflow-y: auto;
    padding: 10px 20px;
}

.glt-tournee-step {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--glt-grey-100);
}

.glt-tournee-step:last-child {
    border-bottom: none;
}

.glt-tournee-step-number {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(135deg, #3b82f6, #2563eb);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 13px;
    flex-shrink: 0;
}

.glt-tournee-step-number.start {
    background: linear-gradient(135deg, #10b981, #059669);
}

.glt-tournee-step-number.end {
    background: linear-gradient(135deg, #ef4444, #dc2626);
}

.glt-tournee-step-info {
    flex: 1;
    min-width: 0;
}

.glt-tournee-step-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--glt-grey-800);
    margin-bottom: 2px;
}

.glt-tournee-step-address {
    font-size: 12px;
    color: var(--glt-grey-500);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.glt-tournee-step-distance {
    font-size: 12px;
    color: var(--glt-grey-400);
    white-space: nowrap;
}

.glt-tournee-actions {
    display: flex;
    gap: 10px;
    padding: 15px 20px;
    background: var(--glt-grey-50);
    border-top: 1px solid var(--glt-grey-100);
}

.glt-tournee-actions .glt-btn {
    flex: 1;
    justify-content: center;
}

/* Ligne de route sur la carte */
.glt-route-line {
    stroke: #3b82f6;
    stroke-width: 4;
    stroke-opacity: 0.8;
    fill: none;
}

/* Loading tournée */
.glt-tournee-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px;
    color: var(--glt-grey-500);
}

.glt-tournee-loading .dashicons {
    font-size: 40px;
    width: 40px;
    height: 40px;
    margin-bottom: 10px;
    animation: glt-spin 1s linear infinite;
}

/* Mobile */
@media (max-width: 768px) {
    .glt-tournee-stats {
        flex-wrap: wrap;
        gap: 10px;
    }
    
    .glt-tournee-stat {
        flex: 1 1 30%;
    }
    
    .glt-tournee-stat-value {
        font-size: 18px;
    }
    
    .glt-tournee-actions {
        flex-direction: column;
    }
    
    .glt-tournee-list {
        max-height: 180px;
    }
    
    #glt-page-carte .glt-filter-group {
        flex: 1 1 45%;
    }
}

/* === CONFIGURATION TOURNÉE === */
.glt-tournee-config {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    margin-bottom: 15px;
    overflow: hidden;
}

.glt-tournee-config-body {
    padding: 20px;
}

.glt-tournee-location-row {
    display: flex;
    gap: 10px;
}

.glt-tournee-location-row .glt-input {
    flex: 1;
}

.glt-tournee-location-row .glt-btn {
    flex-shrink: 0;
    padding: 10px 12px;
}

.glt-tournee-geoloc-status {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    font-size: 13px;
    color: #10b981;
}

.glt-tournee-arrivee-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 10px;
}

.glt-radio-option {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 14px;
    color: var(--glt-grey-700);
}

.glt-radio-option input[type="radio"] {
    width: 18px;
    height: 18px;
    accent-color: var(--glt-primary);
}

.glt-tournee-config-summary {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 15px;
    background: var(--glt-grey-50);
    border-radius: 8px;
    margin-top: 15px;
    font-size: 14px;
    color: var(--glt-grey-600);
}

.glt-tournee-config-summary .dashicons {
    color: var(--glt-primary);
}

.glt-tournee-config-footer {
    display: flex;
    gap: 10px;
    padding: 15px 20px;
    background: var(--glt-grey-50);
    border-top: 1px solid var(--glt-grey-100);
    justify-content: flex-end;
}

/* Boutons navigation - 3 colonnes */
.glt-tournee-actions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    padding: 15px 20px;
    background: var(--glt-grey-50);
    border-top: 1px solid var(--glt-grey-100);
}

.glt-tournee-actions .glt-btn {
    justify-content: center;
    font-size: 12px;
    padding: 10px 8px;
}

/* Géolocalisation en cours */
.glt-geoloc-loading {
    animation: glt-pulse 1.5s ease-in-out infinite;
}

@keyframes glt-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

/* Mobile */
@media (max-width: 768px) {
    .glt-tournee-config-footer {
        flex-direction: column;
    }
    
    .glt-tournee-config-footer .glt-btn {
        width: 100%;
    }
    
    .glt-tournee-actions {
        grid-template-columns: 1fr;
    }
    
    .glt-tournee-location-row {
        flex-direction: column;
    }
    
    .glt-tournee-location-row .glt-btn {
        width: 100%;
    }
}

/* === AUTOCOMPLÉTION ADRESSE === */
.glt-field-autocomplete {
    position: relative;
}

.glt-autocomplete-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid var(--glt-grey-200);
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    max-height: 250px;
    overflow-y: auto;
    z-index: 1000;
    display: none;
}

.glt-autocomplete-results.active {
    display: block;
}

.glt-autocomplete-item {
    padding: 12px 15px;
    cursor: pointer;
    border-bottom: 1px solid var(--glt-grey-100);
    transition: background 0.2s;
}

.glt-autocomplete-item:last-child {
    border-bottom: none;
}

.glt-autocomplete-item:hover {
    background: var(--glt-grey-50);
}

.glt-autocomplete-item-main {
    font-weight: 500;
    color: var(--glt-grey-800);
    font-size: 14px;
}

.glt-autocomplete-item-secondary {
    font-size: 12px;
    color: var(--glt-grey-500);
    margin-top: 2px;
}

.glt-autocomplete-loading {
    padding: 15px;
    text-align: center;
    color: var(--glt-grey-400);
}

.glt-autocomplete-loading .dashicons {
    animation: glt-spin 1s linear infinite;
}

.glt-autocomplete-empty {
    padding: 15px;
    text-align: center;
    color: var(--glt-grey-400);
    font-size: 13px;
}

/* === ACTIONS SECONDAIRES TOURNÉE === */
.glt-tournee-actions-secondary {
    display: flex;
    gap: 8px;
    padding: 10px 20px 15px;
    background: var(--glt-grey-50);
    justify-content: center;
    flex-wrap: wrap;
}

.glt-tournee-actions-secondary .glt-btn {
    font-size: 11px;
    padding: 6px 10px;
}

.glt-tournee-actions-secondary .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

/* Modal QR Code itinéraire */
.glt-tournee-qr-modal {
    text-align: center;
    padding: 20px;
}

.glt-tournee-qr-modal img {
    display: block;
    margin: 0 auto 15px;
    border: 2px solid var(--glt-grey-200);
    border-radius: 12px;
    padding: 10px;
    background: #fff;
}

.glt-tournee-qr-modal p {
    font-size: 13px;
    color: var(--glt-grey-500);
    margin: 0;
}

/* === REPOSITIONNEMENT MARQUEUR === */
.glt-reposition-panel {
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    padding: 12px 20px;
    border-radius: 10px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
    z-index: 1001;
    max-width: 90%;
}

.glt-reposition-panel-content {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.glt-reposition-panel-content .dashicons {
    color: #3b82f6;
    font-size: 20px;
}

.glt-reposition-panel-content span {
    font-size: 14px;
    color: var(--glt-grey-700);
}

.glt-btn-block {
    width: 100%;
    justify-content: center;
}

/* Animation pulse pour le marqueur */
@keyframes glt-pulse {
    0%, 100% { 
        box-shadow: 0 0 0 3px #3b82f6, 0 4px 10px rgba(0,0,0,0.4);
    }
    50% { 
        box-shadow: 0 0 0 6px rgba(59, 130, 246, 0.4), 0 4px 15px rgba(0,0,0,0.3);
    }
}

/* Mobile */
@media (max-width: 768px) {
    .glt-reposition-panel {
        top: auto;
        bottom: 80px;
        left: 10px;
        right: 10px;
        transform: none;
    }
    
    .glt-reposition-panel-content {
        justify-content: center;
        text-align: center;
    }
}

/* === PIÈCES JOINTES MESSAGERIE === */
.glt-file-upload-zone {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 15px;
    background: var(--glt-grey-50);
    border: 2px dashed var(--glt-grey-200);
    border-radius: 8px;
}

.glt-file-hint {
    font-size: 12px;
    color: var(--glt-grey-500);
}

.glt-attachments-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.glt-attachment-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--glt-grey-100);
    border-radius: 6px;
    font-size: 13px;
}

.glt-attachment-item .dashicons {
    color: var(--glt-primary);
    font-size: 16px;
}

.glt-attachment-item .glt-attachment-name {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.glt-attachment-item .glt-attachment-size {
    color: var(--glt-grey-500);
    font-size: 11px;
}

.glt-attachment-remove {
    background: none;
    border: none;
    color: var(--glt-danger);
    cursor: pointer;
    padding: 0;
    display: flex;
}

.glt-attachment-remove:hover {
    color: #b91c1c;
}

/* Zone réponse messagerie */
.glt-message-input-area {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 15px 20px;
    border-top: 1px solid var(--glt-grey-200);
    background: #fff;
}

.glt-message-input-row {
    display: flex;
    gap: 10px;
    align-items: flex-end;
}

.glt-message-input-row textarea {
    flex: 1;
    resize: none;
    border: 1px solid var(--glt-grey-200);
    border-radius: var(--glt-border-radius);
    padding: 12px 15px;
    font-size: 14px;
    font-family: inherit;
    min-height: 80px;
    max-height: 200px;
}

.glt-message-input-row textarea:focus {
    outline: none;
    border-color: var(--glt-blue);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.glt-btn-icon {
    padding: 12px 14px;
    min-width: auto;
    height: 44px;
}

.glt-btn-icon .dashicons {
    margin: 0;
    font-size: 18px;
}

.glt-message-attachments-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}

.glt-message-attachments-preview:empty {
    display: none;
}

/* Pièce jointe dans un message */
.glt-msg-attachments {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(0,0,0,0.1);
}

.glt-msg-attachment {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    background: rgba(0,0,0,0.05);
    border-radius: 6px;
    font-size: 12px;
    color: var(--glt-grey-700);
    text-decoration: none;
    margin-right: 8px;
    margin-bottom: 5px;
    transition: background 0.2s;
}

.glt-msg-attachment:hover {
    background: rgba(0,0,0,0.1);
}

.glt-msg-attachment .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

/* Recherche adresse carte */
.glt-search-address {
    position: relative;
    min-width: 250px;
}

.glt-search-address .glt-autocomplete-results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    margin-top: 2px;
}

/* Mobile */
@media (max-width: 768px) {
    .glt-file-upload-zone {
        flex-direction: column;
        text-align: center;
    }
    
    .glt-message-input-row {
        gap: 8px;
    }
    
    .glt-message-input-row textarea {
        min-height: 60px;
    }
    
    .glt-btn-icon {
        padding: 10px 12px;
        height: 40px;
    }
    
    .glt-search-address {
        min-width: 100%;
        margin-bottom: 10px;
    }
}

/* ========================================
   SÉLECTEUR DE LANGUE
   ======================================== */

.glt-lang-selector {
    position: relative;
    display: inline-flex;
}

/* Style pour le sidebar */
.glt-lang-sidebar .glt-lang-current {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    background: rgba(255,255,255,0.1);
    border: none;
    border-radius: 8px;
    color: #fff;
    cursor: pointer;
    transition: all 0.2s;
}

.glt-lang-sidebar .glt-lang-current:hover {
    background: rgba(255,255,255,0.18);
}

.glt-lang-sidebar .glt-lang-flag {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    font-size: 18px;
    line-height: 1;
    background: none;
    box-shadow: none;
}

.glt-lang-sidebar .glt-lang-code,
.glt-lang-sidebar .glt-lang-arrow {
    display: none;
}

.glt-lang-sidebar .glt-lang-dropdown {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    z-index: 1000;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.glt-lang-sidebar.open .glt-lang-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

.glt-lang-option,
.glt-lang-option:link,
.glt-lang-option:visited,
.glt-lang-option:active,
.glt-lang-option:focus {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    cursor: pointer !important;
    transition: transform 0.15s ease !important;
    border-radius: 0 !important;
    outline: none !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    text-decoration: none !important;
}

.glt-lang-option:hover {
    background: transparent !important;
    transform: scale(1.15) !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.glt-lang-option.active {
    background: transparent !important;
}

.glt-lang-option .glt-lang-flag {
    width: 24px !important;
    height: 24px !important;
    font-size: 20px !important;
    background: none !important;
    border-radius: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: none !important;
    border: none !important;
    outline: none !important;
}

/* Cacher le nom de la langue */
.glt-lang-name {
    display: none !important;
}

/* Mode sombre - même style */
.glt-dark-mode .glt-lang-sidebar .glt-lang-current {
    background: rgba(255,255,255,0.08);
}

.glt-dark-mode .glt-lang-sidebar .glt-lang-current:hover {
    background: rgba(255,255,255,0.15);
}

.glt-dark-mode .glt-lang-dropdown {
    background: transparent !important;
    border: none !important;
}

.glt-dark-mode .glt-lang-option,
.glt-dark-mode .glt-lang-option:hover,
.glt-dark-mode .glt-lang-option:focus,
.glt-dark-mode .glt-lang-option:active {
    background: transparent !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.glt-dark-mode .glt-lang-option.active {
    background: transparent !important;
}

.glt-dark-mode .glt-lang-option .glt-lang-flag {
    background: none !important;
}

/* ===== NOUVEAU FORMULAIRE CONTRÔLE STYLE MOBILE ===== */
.glt-modal-mobile-style {
    max-width: 900px;
}

.glt-ctrl-step {
    background: #fff;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 20px;
    border: 1px solid #e2e8f0;
}

.glt-ctrl-step-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid #f1f5f9;
}

.glt-ctrl-step-num {
    width: 28px;
    height: 28px;
    background: linear-gradient(135deg, #3B6FD9, #1e3a5f);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
}

.glt-ctrl-step-title {
    font-size: 16px;
    font-weight: 600;
    color: #1e3a5f;
}

.glt-ctrl-progress-mini {
    margin-left: auto;
    background: #f1f5f9;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    color: #64748b;
}

/* Bloc dernier contrôle dans le modal */
.glt-last-controle-info {
    background: linear-gradient(135deg, #f0f9ff, #e0f2fe);
    border-radius: 10px;
    padding: 12px 14px;
    border: 1px solid #bae6fd;
    min-height: 42px;
    display: flex;
    align-items: center;
}

.glt-last-controle-empty {
    color: #94a3b8;
    font-size: 13px;
    font-style: italic;
}

.glt-last-controle-data {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
}

.glt-last-controle-pct {
    font-size: 20px;
    font-weight: 700;
}

.glt-last-controle-pct.pct-good { color: #16a34a; }
.glt-last-controle-pct.pct-warning { color: #f59e0b; }
.glt-last-controle-pct.pct-bad { color: #dc2626; }

.glt-last-controle-date {
    font-size: 13px;
    color: #1e40af;
}

.glt-last-controle-none {
    color: #64748b;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.glt-last-controle-none .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

/* Historique du local */
.glt-local-history-card {
    background: linear-gradient(135deg, #dbeafe, #e0e7ff);
    border-radius: 12px;
    padding: 16px;
    margin-top: 16px;
    border-left: 4px solid #3B6FD9;
}

.glt-local-history-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    font-size: 14px;
    color: #1e40af;
}

.glt-local-history-date {
    margin-left: auto;
    color: #3730a3;
    font-size: 12px;
}

.glt-local-history-score {
    display: flex;
    align-items: center;
    gap: 20px;
}

.glt-local-history-pct {
    font-size: 32px;
    font-weight: 700;
    color: #1e40af;
}

.glt-local-history-stats {
    display: flex;
    gap: 12px;
}

.glt-local-history-stats span {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

.glt-local-history-stats .stat-ok {
    background: #dcfce7;
    color: #16a34a;
}

.glt-local-history-stats .stat-nok {
    background: #fee2e2;
    color: #dc2626;
}

/* Checklist style mobile */
.glt-checklist-mobile {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.glt-checklist-loading {
    text-align: center;
    padding: 40px;
    color: #94a3b8;
}

.glt-checklist-category {
    background: #f8fafc;
    border-radius: 12px;
    padding: 16px;
}

.glt-checklist-category-title {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid currentColor;
    display: flex;
    align-items: center;
    gap: 8px;
}

.glt-checklist-items {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.glt-checklist-item {
    background: #fff;
    border-radius: 10px;
    border: 1px solid #e2e8f0;
    overflow: hidden;
    transition: all 0.2s;
}

.glt-checklist-item.status-ok {
    background: #f0fdf4;
    border-color: #86efac;
}

.glt-checklist-item.status-nok {
    background: #fef2f2;
    border-color: #fca5a5;
}

.glt-checklist-item-main {
    display: flex;
    align-items: center;
    padding: 12px;
    gap: 12px;
}

.glt-checklist-item-history {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
    background: #f1f5f9;
}

.glt-checklist-item-history.ok {
    background: #dcfce7;
}

.glt-checklist-item-history.nok {
    background: #fee2e2;
}

.glt-checklist-item-icon {
    font-size: 20px;
    flex-shrink: 0;
}

.glt-checklist-item-label {
    flex: 1;
    font-size: 14px;
    font-weight: 500;
    color: #1e3a5f;
    min-width: 0;
}

.glt-checklist-item-actions {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
}

.glt-smiley-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    background: transparent;
    cursor: pointer;
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    outline: none !important;
    box-shadow: none !important;
    opacity: 0.5;
}

.glt-smiley-btn:focus {
    outline: none !important;
    box-shadow: none !important;
}

.glt-smiley-btn:hover {
    transform: scale(1.15);
    opacity: 1;
}

.glt-smiley-btn.ok:hover {
    background: rgba(34, 197, 94, 0.15);
}

.glt-smiley-btn.nok:hover {
    background: rgba(239, 68, 68, 0.15);
}

.glt-smiley-btn.ok.active {
    background: #dcfce7;
    opacity: 1;
    transform: scale(1.1);
}

.glt-smiley-btn.nok.active {
    background: #fee2e2;
    opacity: 1;
    transform: scale(1.1);
}

.glt-checklist-item-remove {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: none;
    background: transparent;
    color: #cbd5e1;
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    outline: none !important;
    box-shadow: none !important;
    margin-left: 4px;
}

.glt-checklist-item-remove:focus {
    outline: none !important;
    box-shadow: none !important;
}

.glt-checklist-item-remove:hover {
    background: #fee2e2;
    color: #ef4444;
    transform: scale(1.1);
}

/* Détails item (commentaire, photos) */
.glt-checklist-item-details {
    display: none;
    padding: 12px;
    background: #f8fafc;
    border-top: 1px solid #e2e8f0;
}

.glt-checklist-item.expanded .glt-checklist-item-details {
    display: block;
}

.glt-checklist-item-details textarea {
    width: 100%;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 10px;
    font-size: 13px;
    resize: vertical;
    min-height: 60px;
}

.glt-checklist-item-photos {
    display: flex;
    gap: 8px;
    margin-top: 10px;
}

.glt-checklist-photo-btn {
    padding: 8px 12px;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    cursor: pointer;
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.15s;
}

.glt-checklist-photo-btn:hover {
    background: #f1f5f9;
    border-color: #3B6FD9;
}

.glt-checklist-photo-btn.has-photo {
    background: #dbeafe;
    border-color: #3B6FD9;
    color: #1e40af;
}

/* Bouton ajouter item */
.glt-checklist-add-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px;
    background: #f8fafc;
    border: 2px dashed #cbd5e1;
    border-radius: 12px;
    color: #64748b;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    margin-top: 16px;
}

.glt-checklist-add-btn:hover {
    background: #f1f5f9;
    border-color: #3B6FD9;
    color: #3B6FD9;
}

/* Footer avec boutons ajouter et réinitialiser */
.glt-checklist-footer-btns {
    display: flex;
    gap: 12px;
    margin-top: 16px;
}

.glt-checklist-footer-btns .glt-checklist-add-btn {
    flex: 1;
    margin-top: 0;
}

.glt-checklist-reset-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    background: #fff;
    border: 2px dashed #e2e8f0;
    border-radius: 12px;
    color: #64748b;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.glt-checklist-reset-btn:hover {
    background: #fef3c7;
    border-color: #f59e0b;
    color: #92400e;
}

/* Modal ajout item */
.glt-add-item-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.5);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 100001;
}

.glt-add-item-modal.active {
    display: flex;
}

.glt-add-item-content {
    background: #fff;
    border-radius: 16px;
    width: 90%;
    max-width: 500px;
    max-height: 80vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.glt-add-item-header {
    padding: 16px 20px;
    background: linear-gradient(135deg, #3B6FD9, #1e3a5f);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.glt-add-item-header h3 {
    margin: 0;
    font-size: 16px;
}

.glt-add-item-close {
    background: none;
    border: none;
    color: #fff;
    font-size: 24px;
    cursor: pointer;
    opacity: 0.8;
}

.glt-add-item-close:hover {
    opacity: 1;
}

.glt-add-item-body {
    padding: 16px;
    overflow-y: auto;
    flex: 1;
}

.glt-add-item-search {
    width: 100%;
    padding: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    font-size: 14px;
    margin-bottom: 16px;
}

.glt-add-item-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.glt-add-item-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: #f8fafc;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.15s;
}

.glt-add-item-row:hover {
    background: #dbeafe;
}

.glt-add-item-row-icon {
    font-size: 20px;
}

.glt-add-item-row-label {
    flex: 1;
    font-size: 14px;
    font-weight: 500;
}

.glt-add-item-row-cat {
    font-size: 11px;
    color: #64748b;
    background: #e2e8f0;
    padding: 2px 8px;
    border-radius: 10px;
}

/* Titre de catégorie dans le modal d'ajout */
.glt-add-item-category {
    font-size: 13px;
    font-weight: 600;
    padding: 8px 4px 4px;
    margin-top: 8px;
}

.glt-add-item-category:first-child {
    margin-top: 0;
}

/* Message quand tous les items sont ajoutés */
.glt-add-item-empty {
    text-align: center;
    color: #64748b;
    padding: 24px;
    font-size: 14px;
}

/* ===== PUSH NOTIFICATIONS TOAST ===== */
.glt-push-toast {
    position: fixed;
    top: 20px;
    right: 20px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2);
    padding: 16px 20px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    max-width: 380px;
    z-index: 10001;
    transform: translateX(120%);
    transition: transform 0.3s ease;
    border-left: 4px solid var(--glt-primary);
}

.glt-push-toast.visible {
    transform: translateX(0);
}

.glt-push-toast-icon {
    font-size: 24px;
    flex-shrink: 0;
}

.glt-push-toast-content {
    flex: 1;
    min-width: 0;
}

.glt-push-toast-title {
    font-weight: 600;
    font-size: 14px;
    color: #1e293b;
    margin-bottom: 4px;
}

.glt-push-toast-body {
    font-size: 13px;
    color: #64748b;
    line-height: 1.4;
}

.glt-push-toast-close {
    position: absolute;
    top: 8px;
    right: 8px;
    background: none;
    border: none;
    font-size: 20px;
    color: #94a3b8;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}

.glt-push-toast-close:hover {
    color: #64748b;
}

@media (max-width: 480px) {
    .glt-push-toast {
        left: 10px;
        right: 10px;
        max-width: none;
    }
}

