/*
 * Plugin: mysis-repas
 * Fichier: assets/css/mysis-repas.css
 * Styles principaux du plugin
 */


/* ===== Variables & Styles de base ===== */
    :root {
      --mysis-primary: #AB0209;
      --mysis-primary-hover: #8A0207;
      --mysis-primary-light: rgba(171, 2, 9, 0.1);
      --mysis-ring: 0 0 0 3px rgba(171, 2, 9, 0.2);
      --mysis-radius: 12px;
      --mysis-transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
      --mysis-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
      --mysis-shadow-md: 0 6px 12px rgba(0, 0, 0, 0.08);
      --mysis-shadow-lg: 0 12px 24px rgba(0, 0, 0, 0.12);
      --mysis-border: #E5E7EB;
      --mysis-bg-card: #FFFFFF;
    }
    
    .mysis-repas-container {
      font-family: system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
      max-width: 800px;
      margin: 0 auto;
      padding: 20px;
    }
    
    .mysis-repas-card {
      background: var(--mysis-bg-card);
      border-radius: var(--mysis-radius);
      box-shadow: var(--mysis-shadow-md);
      overflow: hidden;
      border: 1px solid var(--mysis-border);
    }

    @media (max-width: 640px) {
    .selfsis-content {
padding-top: 150px;
    }
    }
    
    .mysis-repas-header,
    .mysis-gestion-header {
      border-radius: var(--mysis-radius) var(--mysis-radius) 0 0;
      background: linear-gradient(135deg, var(--mysis-primary) 0%, var(--mysis-primary-hover) 100%);
      color: white;
      padding: 24px 30px;
      display: flex;
      align-items: center;
      gap: 12px;
    }
    
    .mysis-repas-header .material-icons,
    .mysis-gestion-header .material-icons {
      font-size: 32px;
    }
    
    .mysis-repas-header h2,
    .mysis-gestion-header h2 {
      margin: 0;
      font-size: 1.5rem;
      font-weight: 700;
      color: white;
    }
    
    .mysis-repas-content {
      padding: 30px;
    }
    
    .mysis-repas-section {
      margin-bottom: 30px;
    }
    
    .mysis-repas-section h3 {
      font-size: 1.1rem;
      font-weight: 700;
      color: #374151;
      margin: 0 0 16px 0;
    }
    
    .mysis-repas-section .required {
      color: var(--mysis-primary);
    }
    
    .mysis-repas-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
      gap: 16px;
    }
    
    .mysis-repas-field label {
      display: block;
      font-weight: 600;
      font-size: 0.9rem;
      color: #374151;
      margin-bottom: 8px;
    }
    
    .mysis-repas-field input[type='text'],
    .mysis-repas-field input[type='date'] {
      width: 100%;
      padding: 12px 14px;
      border: 1px solid var(--mysis-border);
      border-radius: 10px;
      font-size: 1rem;
      transition: var(--mysis-transition);
      box-sizing: border-box;
    }
    
    .mysis-repas-field input[readonly] {
      background: #F9FAFB;
      color: #6B7280;
      cursor: not-allowed;
    }
    
    .mysis-repas-field input:not([readonly]):focus {
      outline: none;
      border-color: var(--mysis-primary);
      box-shadow: var(--mysis-ring);
    }
    
    /* Boutons type de repas */
    .mysis-meal-buttons {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
    }
    
    .mysis-meal-btn {
      flex: 1;
      min-width: 150px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 20px 16px;
      border: 2px solid var(--mysis-border);
      background: var(--mysis-bg-card);
      border-radius: var(--mysis-radius);
      cursor: pointer;
      transition: var(--mysis-transition);
    }
    
    .mysis-meal-btn:hover {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
    }
    
    .mysis-meal-btn:has(input:checked) {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
      box-shadow: var(--mysis-shadow-sm);
    }
    
    .mysis-meal-btn input {
      display: none;
    }
    
    .mysis-meal-icon {
      font-size: 40px !important;
      color: #6B7280;
      transition: var(--mysis-transition);
    }
    
    .mysis-meal-btn:has(input:checked) .mysis-meal-icon {
      color: var(--mysis-primary) !important;
    }
    
    .mysis-meal-label {
      font-weight: 700;
      font-size: 0.95rem;
      color: #374151;
      transition: var(--mysis-transition);
    }
    
    .mysis-meal-btn:has(input:checked) .mysis-meal-label {
      color: var(--mysis-primary) !important;
    }
    
    /* Boutons choix de plat (même style que mysis-interface) */
    .mysis-food-buttons {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
    }
    
    .mysis-food-btn {
      flex: 1;
      min-width: 160px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 20px 16px;
      border: 2px solid var(--mysis-border);
      background: var(--mysis-bg-card);
      border-radius: var(--mysis-radius);
      cursor: pointer;
      transition: var(--mysis-transition);
    }
    
    .mysis-food-btn:hover {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
    }
    
    .mysis-food-btn:has(input:checked) {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
      box-shadow: var(--mysis-shadow-sm);
    }
    
    .mysis-food-btn input {
      display: none;
    }
    
    .mysis-food-icon {
      font-size: 48px !important;
      color: #6B7280;
      transition: var(--mysis-transition);
    }
    
    .mysis-food-btn:has(input:checked) .mysis-food-icon {
      color: var(--mysis-primary) !important;
    }
    
    .mysis-food-label {
      font-weight: 700;
      font-size: 1rem;
      color: #374151;
      transition: var(--mysis-transition);
    }
    
    .mysis-food-btn:has(input:checked) .mysis-food-label {
      color: var(--mysis-primary) !important;
    }
    
    /* Bouton submit */
    .mysis-submit-wrapper {
      display: flex;
      justify-content: flex-end;
      margin-top: 30px;
    }
    
    .mysis-primary {
      background: var(--mysis-primary) !important;
      color: white !important;
      border: none !important;
      border-radius: 10px !important;
      padding: 14px 24px !important;
      font-weight: 700 !important;
      font-size: 1rem !important;
      box-shadow: var(--mysis-shadow-md) !important;
      transition: var(--mysis-transition) !important;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      gap: 8px;
    }
    
    .mysis-primary:hover {
      background: var(--mysis-primary-hover) !important;
      box-shadow: var(--mysis-shadow-lg) !important;
      transform: translateY(-2px);
    }
    
    .mysis-primary:active {
      transform: translateY(0);
    }
    
    .mysis-primary .material-icons {
      font-size: 20px;
    }
    
    /* Messages */
    .mysis-ajax-message {
      display: flex;
      align-items: center;
      gap: 16px;
      padding: 16px 20px;
      margin: 0 0 20px 0;
      border-radius: var(--mysis-radius);
      box-shadow: var(--mysis-shadow-md);
      animation: slideIn 0.4s ease-out;
    }
    
    .mysis-ajax-success {
      background: #D1FAE5;
      border-left: 4px solid #10B981;
    }
    
    .mysis-ajax-success .material-icons {
      color: #10B981;
      font-size: 28px;
    }
    
    .mysis-ajax-success p {
      color: #065F46;
      font-weight: 600;
      margin: 0;
    }
    
    .mysis-ajax-error {
      background: #FEE2E2;
      border-left: 4px solid #EF4444;
    }
    
    .mysis-ajax-error .material-icons {
      color: #EF4444;
      font-size: 28px;
    }
    
    .mysis-ajax-error p {
      color: #991B1B;
      font-weight: 600;
      margin: 0;
    }
    
    @keyframes slideIn {
      from {
        opacity: 0;
        transform: translateY(-20px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    
    /* Styles spécifiques gestion_repas */
    .mysis-gestion-table table {
      font-size: 0.95rem;
    }
    
    .mysis-gestion-table th {
      white-space: nowrap;
    }
    
    .mysis-gestion-date-selector form {
      flex-wrap: wrap;
    }
    
    /* Responsive */
    @media (max-width: 768px) {
      .mysis-repas-container {
        padding: 10px;
      }
      
      .mysis-repas-content {
        padding: 20px;
      }
      
      .mysis-repas-header,
      .mysis-gestion-header {
        padding: 20px;
      }
      
      .mysis-meal-buttons,
      .mysis-food-buttons {
        flex-direction: column;
      }
      
      .mysis-meal-btn,
      .mysis-food-btn {
        width: 100%;
      }
      
      .mysis-stats-grid {
        grid-template-columns: 1fr !important;
      }
      
      .mysis-gestion-date-selector form {
        flex-direction: column;
        align-items: stretch !important;
      }
      
      .mysis-gestion-table {
        font-size: 0.85rem;
      }
    }

/* ===== Interface menu principal ===== */
        /* ========================================
           SÉLECTEUR D'UTILISATEUR (MODE STAFF)
           ======================================== */
        .mysis-staff-selector {
            background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
            border-radius: 12px;
            padding: 1rem 1.25rem;
            margin-bottom: 1.5rem;
            border: 1px solid #f59e0b;
        }
        
        .mysis-staff-toggle {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 1rem;
            flex-wrap: wrap;
        }
        
        .mysis-toggle-label {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            cursor: pointer;
            font-weight: 500;
            color: #92400e;
        }
        
        .mysis-toggle-label input[type="checkbox"] {
            display: none;
        }
        
        .mysis-toggle-switch {
            position: relative;
            width: 48px;
            height: 26px;
            background: #d97706;
            border-radius: 13px;
            transition: background 0.3s;
        }
        
        .mysis-toggle-switch::after {
            content: '';
            position: absolute;
            top: 3px;
            left: 3px;
            width: 20px;
            height: 20px;
            background: white;
            border-radius: 50%;
            transition: transform 0.3s;
            box-shadow: 0 2px 4px rgba(0,0,0,0.2);
        }
        
        .mysis-toggle-label input:checked + .mysis-toggle-switch {
            background: #059669;
        }
        
        .mysis-toggle-label input:checked + .mysis-toggle-switch::after {
            transform: translateX(22px);
        }
        
        .mysis-staff-badge {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem 1rem;
            background: #f59e0b;
            color: white;
            border-radius: 20px;
            font-size: 0.85rem;
            font-weight: 600;
        }
        
        .mysis-staff-badge .material-symbols-outlined {
            font-size: 1.1rem;
        }
        
        .mysis-user-selector-wrapper {
            margin-top: 1rem;
            padding-top: 1rem;
            border-top: 1px solid rgba(245, 158, 11, 0.3);
        }

        /* Onglets Agent / Participant externe */
        .mysis-selector-tabs {
            display: flex;
            gap: 8px;
            margin-bottom: 14px;
        }
        .mysis-selector-tab {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 8px 18px;
            border-radius: 24px;
            border: 2px solid #e5e7eb;
            background: white;
            color: #6b7280;
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.15s;
        }
        .mysis-selector-tab .material-symbols-outlined { font-size: 18px; }
        .mysis-selector-tab:hover { border-color: #f59e0b; color: #92400e; }
        .mysis-selector-tab--active { border-color: #f59e0b !important; background: rgba(245,158,11,0.08) !important; color: #92400e !important; }

        /* Sous-onglets Événement / Formation dans le sélecteur externe */
        .mysis-ext-type-tab {
            display: inline-flex;
            align-items: center;
            gap: 5px;
            padding: 6px 14px;
            border-radius: 20px;
            border: 2px solid #e5e7eb;
            background: white;
            color: #6b7280;
            font-size: 13px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.15s;
        }
        .mysis-ext-type-tab .material-symbols-outlined { font-size: 16px; }
        .mysis-ext-type-tab:hover { border-color: #6366f1; color: #4338ca; }
        .mysis-ext-type-tab--active { border-color: #6366f1 !important; background: rgba(99,102,241,0.08) !important; color: #4338ca !important; }
        html[data-theme="dark"] .mysis-ext-type-tab { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.12); color: #9ca3af; }
        html[data-theme="dark"] .mysis-ext-type-tab--active { border-color: #6366f1 !important; background: rgba(99,102,241,0.12) !important; color: #a5b4fc !important; }

        /* Sélecteur externe */
        .mysis-ext-event-row {
            display: flex;
            align-items: center;
            gap: 12px;
            margin-bottom: 12px;
            flex-wrap: wrap;
        }
        .mysis-ext-label {
            display: flex;
            align-items: center;
            gap: 6px;
            font-size: 13px;
            font-weight: 600;
            color: #6b7280;
            white-space: nowrap;
        }
        .mysis-ext-label .material-symbols-outlined { font-size: 16px; }
        .mysis-ext-select {
            flex: 1;
            min-width: 200px;
            padding: 10px 14px;
            border: 2px solid #e5e7eb;
            border-radius: 10px;
            font-size: 14px;
            background: white;
            color: #374151;
            cursor: pointer;
            transition: border-color 0.2s;
        }
        .mysis-ext-select:focus { outline: none; border-color: #f59e0b; }
        .mysis-ext-participant-item {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 10px 14px;
            cursor: pointer;
            transition: background 0.15s;
            border-bottom: 1px solid #f3f4f6;
        }
        .mysis-ext-participant-item:hover { background: rgba(245,158,11,0.06); }
        .mysis-ext-participant-item .material-symbols-outlined { color: #9ca3af; font-size: 20px; }
        .mysis-ext-groupe-chip {
            display: inline-block;
            padding: 2px 8px;
            border-radius: 12px;
            background: rgba(5,150,105,0.1);
            color: #047857;
            font-size: 11px;
            font-weight: 600;
            margin-left: 4px;
        }
        html[data-theme="dark"] .mysis-selector-tab { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.12); color: #9ca3af; }
        html[data-theme="dark"] .mysis-selector-tab--active { border-color: #f59e0b !important; background: rgba(245,158,11,0.12) !important; color: #fbbf24 !important; }
        html[data-theme="dark"] .mysis-ext-select { background: #1e2937; color: #e5e7eb; border-color: rgba(255,255,255,0.1); }
        html[data-theme="dark"] .mysis-ext-select:focus { border-color: #f59e0b; }
        html[data-theme="dark"] .mysis-ext-participant-item { border-bottom-color: rgba(255,255,255,0.06); }
        html[data-theme="dark"] .mysis-ext-participant-item:hover { background: rgba(245,158,11,0.08); }
        
        .mysis-user-search {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            background: white;
            border: 2px solid #e5e7eb;
            border-radius: 10px;
            padding: 0.75rem 1rem;
            transition: border-color 0.2s;
        }
        
        .mysis-user-search:focus-within {
            border-color: #f59e0b;
        }
        
        .mysis-user-search .material-symbols-outlined {
            color: #9ca3af;
        }
        
        .mysis-user-search input {
            flex: 1;
            border: none;
            outline: none;
            font-size: 1rem;
            background: transparent;
        }
        
        .mysis-user-results {
            margin-top: 0.5rem;
            max-height: 250px;
            overflow-y: auto;
            background: white;
            border-radius: 10px;
            box-shadow: 0 4px 12px rgba(0,0,0,0.1);
        }
        
        .mysis-user-result {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 0.75rem 1rem;
            cursor: pointer;
            transition: background 0.2s;
            border-bottom: 1px solid #f3f4f6;
        }
        
        .mysis-user-result:last-child {
            border-bottom: none;
        }
        
        .mysis-user-result:hover {
            background: #fef3c7;
        }
        
        .mysis-user-result .material-symbols-outlined {
            color: #6b7280;
            font-size: 1.5rem;
        }
        
        .mysis-user-result-info {
            flex: 1;
        }
        
        .mysis-user-result-info strong {
            display: block;
            color: #1f2937;
        }
        
        .mysis-user-result-info small {
            color: #6b7280;
            font-size: 0.85rem;
        }
        
        .mysis-no-results {
            padding: 1rem;
            text-align: center;
            color: #6b7280;
        }
        
        .mysis-selected-user {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 0.75rem 1rem;
            background: #059669;
            color: white;
            border-radius: 10px;
            margin-top: 0.75rem;
        }
        
        .mysis-selected-user .material-symbols-outlined {
            font-size: 1.5rem;
        }
        
        .mysis-selected-user-info {
            flex: 1;
        }
        
        .mysis-selected-user-info strong {
            display: block;
        }
        
        .mysis-selected-user-info small {
            opacity: 0.9;
            font-size: 0.85rem;
        }
        
        .mysis-clear-user {
            background: rgba(255,255,255,0.2);
            border: none;
            border-radius: 50%;
            width: 32px;
            height: 32px;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: background 0.2s;
        }
        
        .mysis-clear-user:hover {
            background: rgba(255,255,255,0.3);
        }
        
        .mysis-clear-user .material-symbols-outlined {
            font-size: 1.25rem;
        }
        
        .mysis-staff-info {
            display: flex;
            align-items: flex-start;
            gap: 0.5rem;
            margin-top: 1rem;
            font-size: 0.85rem;
            color: #92400e;
        }
        
        .mysis-staff-info .material-symbols-outlined {
            font-size: 1.1rem;
            flex-shrink: 0;
            margin-top: 0.1rem;
        }
        
        /* Sélecteur de formations lié à la personne sélectionnée */
        .mysis-user-formations-wrapper {
            margin-top: 1rem;
            padding-top: 1rem;
            border-top: 1px solid rgba(245, 158, 11, 0.3);
        }
        
        .mysis-user-formations-header {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            font-size: 0.9rem;
            font-weight: 600;
            color: #92400e;
            margin-bottom: 0.75rem;
        }
        
        .mysis-user-formations-header em {
            font-weight: 400;
            opacity: 0.8;
        }
        
        .mysis-user-formations-header .material-symbols-outlined {
            font-size: 1.1rem;
            color: #f59e0b;
        }
        
        .mysis-user-formations-loading {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            font-size: 0.9rem;
            color: #92400e;
            opacity: 0.8;
        }
        
        @keyframes mysis-spin {
            from { transform: rotate(0deg); }
            to { transform: rotate(360deg); }
        }
        
        .mysis-spin {
            animation: mysis-spin 1s linear infinite;
        }
        
        .mysis-user-formations-list {
            display: flex;
            flex-direction: column;
            gap: 0.4rem;
        }
        
        .mysis-formation-item {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 0.65rem 1rem;
            background: white;
            border: 2px solid #e5e7eb;
            border-radius: 8px;
            cursor: pointer;
            transition: border-color 0.2s, background 0.2s;
        }
        
        .mysis-formation-item:hover {
            border-color: #3b82f6;
            background: #eff6ff;
        }
        
        .mysis-formation-item-selected {
            border-color: #2563eb !important;
            background: #eff6ff !important;
        }
        
        .mysis-formation-item .material-symbols-outlined:first-child {
            color: #3b82f6;
            font-size: 1.25rem;
            flex-shrink: 0;
        }
        
        .mysis-formation-item-title {
            flex: 1;
            font-size: 0.9rem;
            font-weight: 500;
            color: #1f2937;
        }
        
        .mysis-formations-empty {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            font-size: 0.85rem;
            color: #6b7280;
            padding: 0.5rem 0;
        }
        
        .mysis-formations-empty .material-symbols-outlined {
            font-size: 1rem;
        }
        
        .mysis-selected-formation {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 0.65rem 1rem;
            background: #2563eb;
            color: white;
            border-radius: 8px;
            margin-top: 0.5rem;
        }
        
        .mysis-selected-formation .material-symbols-outlined {
            font-size: 1.25rem;
        }
        
        .mysis-selected-formation-info {
            flex: 1;
        }
        
        .mysis-selected-formation-info strong {
            display: block;
            font-size: 0.9rem;
        }
        
        /* Dark mode pour le sélecteur staff */
        html[data-theme="dark"] .mysis-staff-selector {
            background: linear-gradient(135deg, #78350f 0%, #92400e 100%);
            border-color: #f59e0b;
        }
        
        html[data-theme="dark"] .mysis-toggle-label,
        html[data-theme="dark"] .mysis-staff-info {
            color: #fef3c7;
        }
        
        html[data-theme="dark"] .mysis-user-search {
            background: #1f2937;
            border-color: #374151;
        }
        
        html[data-theme="dark"] .mysis-user-search input {
            color: #f9fafb;
        }
        
        html[data-theme="dark"] .mysis-user-results {
            background: #1f2937;
        }
        
        html[data-theme="dark"] .mysis-user-result {
            border-color: #374151;
        }
        
        html[data-theme="dark"] .mysis-user-result:hover {
            background: #374151;
        }
        
        html[data-theme="dark"] .mysis-user-result-info strong {
            color: #f9fafb;
        }
        
        html[data-theme="dark"] .mysis-user-result-info small {
            color: #9ca3af;
        }
        
        /* ========================================
           FIN SÉLECTEUR D'UTILISATEUR
           ======================================== */
        
        .mysis-repas-step {
            padding: 2rem;
        }
        
        .mysis-repas-step-title {
            font-size: 1.5rem;
            font-weight: 700;
            color: #333;
            display: flex;
            align-items: center;
            gap: 0.75rem;
            margin-bottom: 2rem;
            font-family: 'Outfit', sans-serif;
        }
        
        .mysis-repas-step-title .material-symbols-outlined {
            font-size: 2rem;
            color: #AB0209;
        }
        
        .mysis-repas-date-form {
            max-width: 400px;
        }
        
        .mysis-repas-menu-header {
            margin-bottom: 2rem;
            padding-bottom: 1rem;
            border-bottom: 2px solid #e9ecef;
        }
        
        .mysis-repas-menu-date {
            display: flex;
            align-items: center;
            gap: 1rem;
            font-size: 1.25rem;
            font-weight: 600;
            color: #333;
        }
        
        .mysis-repas-menu-date .material-symbols-outlined {
            color: #AB0209;
            font-size: 1.5rem;
        }
        
        .mysis-repas-change-date {
            margin-left: auto;
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem 1rem;
            background: #f8f9fa;
            border-radius: 8px;
            color: #6B7280;
            text-decoration: none;
            font-size: 0.9rem;
            transition: all 0.2s;
        }
        
        .mysis-repas-change-date:hover {
            background: #e9ecef;
            color: #AB0209;
        }
        
        .mysis-repas-menu-grid {
            display: grid;
            gap: 1rem;
            margin-bottom: 1.5rem;
        }
        
        /* Grille dynamique selon le nombre de plats */
        .mysis-repas-menu-grid[data-plats-count="1"] {
            grid-template-columns: 1fr;
            max-width: 500px;
            margin-left: auto;
            margin-right: auto;
        }
        
        .mysis-repas-menu-grid[data-plats-count="2"] {
            grid-template-columns: repeat(2, 1fr);
            max-width: 900px;
            margin-left: auto;
            margin-right: auto;
        }
        
        .mysis-repas-menu-grid[data-plats-count="3"] {
            grid-template-columns: repeat(3, 1fr);
        }
        
        .mysis-repas-menu-column {
            background: #fff;
            border: 2px solid #e9ecef;
            border-radius: 12px;
            padding: 1rem;
            transition: all 0.3s ease;
            position: relative;
            display: flex;
            flex-direction: column;
            height: auto;
            min-height: auto;
            align-items: stretch;
        }
        
        .mysis-menu-viande {
            border-color: #dc3545;
        }
        
        .mysis-menu-poisson {
            border-color: #0d6efd;
        }
        
        .mysis-menu-vegetarien {
            border-color: #198754;
        }
        
        .mysis-repas-menu-column:hover {
            transform: translateY(-4px);
            box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
        }
        
        .mysis-repas-menu-column-header {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            margin-bottom: 0.75rem;
            padding-bottom: 0.75rem;
            border-bottom: 2px solid #e9ecef;
        }
        
        .mysis-menu-viande .mysis-repas-menu-column-header {
            border-color: #dc3545;
        }
        
        .mysis-menu-poisson .mysis-repas-menu-column-header {
            border-color: #0d6efd;
        }
        
        .mysis-menu-vegetarien .mysis-repas-menu-column-header {
            border-color: #198754;
        }
        
        .mysis-repas-menu-column-header h3 {
            margin: 0;
            font-size: 1.1rem;
            font-weight: 700;
            color: #333;
        }
        
        .mysis-repas-menu-column-header .material-symbols-outlined {
            font-size: 1.5rem;
        }
        
        .mysis-menu-viande .mysis-repas-menu-column-header .material-symbols-outlined {
            color: #dc3545;
        }
        
        .mysis-menu-poisson .mysis-repas-menu-column-header .material-symbols-outlined {
            color: #0d6efd;
        }
        
        .mysis-menu-vegetarien .mysis-repas-menu-column-header .material-symbols-outlined {
            color: #198754;
        }
        
        .mysis-repas-menu-content {
            flex: 0 1 auto;
            margin-bottom: 0.75rem;
            padding: 0.5rem 0;
            color: #374151;
            font-size: 0.95rem;
            line-height: 1.5;
            word-wrap: break-word;
            min-height: auto;
        }
        
        .mysis-repas-menu-column .mysis-repas-menu-content {
            min-height: 0;
        }
        
        .mysis-repas-menu-radio {
            display: block;
            cursor: pointer;
            margin-top: 0.75rem;
            flex-shrink: 0;
        }
        
        .mysis-repas-menu-radio input[type="radio"] {
            display: none;
        }
        
        .mysis-repas-menu-radio-label {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 0.5rem;
            padding: 0.5rem 0.75rem;
            background: #f8f9fa;
            border: 2px solid #e9ecef;
            border-radius: 8px;
            transition: all 0.2s;
            color: #6B7280;
            font-weight: 500;
            font-size: 0.9rem;
        }
        
        .mysis-repas-menu-radio input[type="radio"]:checked + .mysis-repas-menu-radio-label {
            background: #AB0209;
            border-color: #AB0209;
            color: #fff;
        }
        
        .mysis-menu-viande .mysis-repas-menu-radio input[type="radio"]:checked + .mysis-repas-menu-radio-label {
            background: #dc3545;
            border-color: #dc3545;
        }
        
        .mysis-menu-poisson .mysis-repas-menu-radio input[type="radio"]:checked + .mysis-repas-menu-radio-label {
            background: #0d6efd;
            border-color: #0d6efd;
        }
        
        .mysis-menu-vegetarien .mysis-repas-menu-radio input[type="radio"]:checked + .mysis-repas-menu-radio-label {
            background: #198754;
            border-color: #198754;
        }
        
        .mysis-repas-menu-radio:hover .mysis-repas-menu-radio-label {
            border-color: #AB0209;
        }
        
        .mysis-menu-viande .mysis-repas-menu-radio:hover .mysis-repas-menu-radio-label {
            border-color: #dc3545;
        }
        
        .mysis-menu-poisson .mysis-repas-menu-radio:hover .mysis-repas-menu-radio-label {
            border-color: #0d6efd;
        }
        
        .mysis-menu-vegetarien .mysis-repas-menu-radio:hover .mysis-repas-menu-radio-label {
            border-color: #198754;
        }
        
        .mysis-repas-menu-info {
            display: flex;
            align-items: start;
            gap: 0.5rem;
            padding: 0.75rem;
            background: #e7f3ff;
            border-left: 4px solid #0d6efd;
            border-radius: 8px;
            margin-bottom: 1rem;
            color: #0c5460;
            font-size: 0.875rem;
        }
        
        .mysis-repas-menu-info .material-symbols-outlined {
            color: #0d6efd;
            flex-shrink: 0;
            font-size: 1.1rem;
        }
        
        .mysis-repas-menu-info p {
            margin: 0;
            line-height: 1.4;
        }
        
        /* Sections Entrée et Dessert */
        .mysis-repas-menu-full {
            margin-bottom: 1.5rem;
        }
        
        .mysis-repas-menu-section {
            background: #f8f9fa;
            border: 2px solid #e9ecef;
            border-radius: 12px;
            padding: 1rem;
            margin-bottom: 1rem;
            height: auto;
            min-height: auto;
        }
        
        .mysis-repas-menu-section .mysis-repas-menu-content {
            min-height: 0;
            padding: 0;
        }
        
        .mysis-menu-entree {
            border-left: 4px solid #0d6efd;
        }
        
        .mysis-menu-dessert {
            border-left: 4px solid #ffc107;
        }
        
        .mysis-menu-accompagnement {
            border-left: 4px solid #10B981;
        }
        
        .mysis-repas-menu-section-header {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            margin-bottom: 0.75rem;
            padding-bottom: 0.75rem;
            border-bottom: 2px solid #e9ecef;
        }
        
        .mysis-repas-menu-section-header h3 {
            margin: 0;
            font-size: 1.25rem;
            font-weight: 700;
            color: #333;
        }
        
        .mysis-repas-menu-section-header .material-symbols-outlined {
            font-size: 2rem;
            color: #AB0209;
        }
        
        .mysis-menu-entree .mysis-repas-menu-section-header .material-symbols-outlined {
            color: #0d6efd;
        }
        
        .mysis-menu-dessert .mysis-repas-menu-section-header .material-symbols-outlined {
            color: #ffc107;
        }
        
        .mysis-menu-accompagnement .mysis-repas-menu-section-header .material-symbols-outlined {
            color: #10B981;
        }
        
        .mysis-repas-menu-badge {
            margin-left: auto;
            padding: 0.25rem 0.75rem;
            background: #e7f3ff;
            color: #0d6efd;
            border-radius: 12px;
            font-size: 0.85rem;
            font-weight: 600;
        }
        
        .mysis-repas-menu-empty {
            display: flex;
            align-items: start;
            gap: 0.75rem;
            padding: 1.5rem;
            background: #fff3cd;
            border-left: 4px solid #ffc107;
            border-radius: 8px;
            margin-bottom: 1.5rem;
            color: #856404;
        }
        
        .mysis-repas-menu-empty .material-symbols-outlined {
            color: #ffc107;
            flex-shrink: 0;
        }
        
        @media (max-width: 968px) {
            .mysis-repas-menu-grid {
                grid-template-columns: 1fr !important;
                max-width: 100% !important;
            }
            
            .mysis-repas-menu-date {
                flex-direction: column;
                align-items: flex-start;
            }
            
            .mysis-repas-change-date {
                margin-left: 0;
                margin-top: 0.5rem;
            }
        }
        
        /* ============================================
           INTERFACE MULTI-RÉSERVATIONS - DESIGN MODERNE
           ============================================ */
        
        .mysis-repas-multi-container {
            max-width: none;
            padding: 0;
            font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
        }
        
        .mysis-repas-multi-container .mysis-repas-card {
            box-shadow: none;
            border-radius: 0;
            background: transparent;
            overflow: visible;
            border: none;
        }
        
        .mysis-repas-multi-container .mysis-repas-header {
            display: none;
        }
        
        .mysis-repas-multi-container .mysis-repas-content {
            padding: 0;
            overflow: visible;
            position: relative;
        }
        
        .mysis-repas-multi-section {
            margin-bottom: 2rem;
        }
        
        /* Titre de section */
        .mysis-repas-step-title {
            display: flex;
            align-items: center;
            gap: 12px;
            font-size: 1.35rem;
            font-weight: 700;
            color: var(--sdis-text-primary, #1d1d1f);
            margin: 0 0 0.5rem 0;
            letter-spacing: -0.3px;
        }
        
        .mysis-repas-step-title .material-symbols-outlined {
            font-size: 1.5rem;
            color: var(--sdis-primary, #AB0209);
            font-variation-settings: 'FILL' 1;
        }
        
        .mysis-repas-help-text {
            color: var(--sdis-text-secondary, #6e6e73);
            font-size: 0.95rem;
            margin: 0 0 1.5rem 0;
            line-height: 1.6;
        }
        
        /* ============================================
           CALENDRIER - DESIGN APPLE
           ============================================ */
        
        .mysis-calendar-wrapper {
            background: var(--sdis-bg-card, #FFFFFF);
            border: none;
            border-radius: 16px;
            padding: 1rem;
            margin-bottom: 1.5rem;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
            transition: box-shadow 0.3s ease;
        }
        
        .mysis-calendar-wrapper:hover {
            box-shadow: 0 6px 24px rgba(0, 0, 0, 0.1);
        }
        
        /* Layout desktop : 2 colonnes - calendrier à gauche, contenu à droite */
        @media (min-width: 1024px) {
            .mysis-repas-multi-container .mysis-repas-content {
                display: grid;
                grid-template-columns: 420px 1fr;
                gap: 2rem;
                align-items: start;
                overflow: visible;
                padding: 0.5rem;
            }
            
            /* Colonne gauche : calendrier avec titre */
            .mysis-repas-multi-section:first-of-type {
                grid-column: 1;
                grid-row: 1;
                margin-bottom: 0;
                overflow: visible;
            }
            
            /* Titre et instructions visibles */
            .mysis-repas-multi-section:first-of-type .mysis-repas-step-title {
                display: flex;
            }
            
            .mysis-repas-multi-section:first-of-type .mysis-repas-help-text {
                display: block;
            }
            
            /* Liste des dates - visible à droite */
            .mysis-repas-multi-section:first-of-type #mysis-selected-dates-list {
                position: absolute;
                left: calc(420px + 2rem + 0.5rem);
                top: 0;
                width: calc(100% - 420px - 2rem - 1rem);
                max-width: 600px;
            }
            
            .mysis-calendar-wrapper {
                margin-bottom: 0;
                padding: 1rem;
            }
            
            /* Colonne droite : panier des réservations */
            #mysis-reservations-cart {
                grid-column: 2;
                grid-row: 1;
                margin-bottom: 0;
                position: sticky;
                top: 140px;
                max-height: calc(100vh - 180px);
                overflow-y: auto;
                background: var(--sdis-bg-card, #FFFFFF);
                border: none;
                border-radius: 16px;
                padding: 1.25rem;
                box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
            }
            
            #mysis-reservations-cart .mysis-repas-step-title {
                margin-top: 0;
            }
        }
        
        /* Header du calendrier */
        .mysis-calendar-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 1rem;
            padding-bottom: 0.75rem;
            border-bottom: 1px solid var(--sdis-border-color, rgba(0, 0, 0, 0.06));
        }
        
        .mysis-calendar-nav {
            background: var(--sdis-bg-hover, #f5f5f7);
            border: none;
            border-radius: 10px;
            padding: 0.5rem;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
            color: var(--sdis-text-secondary, #6e6e73);
        }
        
        .mysis-calendar-nav:hover {
            background: var(--sdis-primary-light, rgba(171, 2, 9, 0.1));
            color: var(--sdis-primary, #AB0209);
            transform: scale(1.05);
        }
        
        .mysis-calendar-nav:active {
            transform: scale(0.95);
        }
        
        .mysis-calendar-nav .material-symbols-outlined {
            font-size: 1.25rem;
            font-variation-settings: 'wght' 600;
        }
        
        .mysis-calendar-month-year {
            font-size: 1.15rem;
            font-weight: 700;
            color: var(--sdis-text-primary, #1d1d1f);
            letter-spacing: -0.3px;
        }
        
        /* Jours de la semaine */
        .mysis-calendar-weekdays {
            display: grid;
            grid-template-columns: repeat(7, 1fr);
            gap: 6px;
            margin-bottom: 6px;
        }
        
        .mysis-calendar-weekdays > div {
            text-align: center;
            font-weight: 600;
            font-size: 0.7rem;
            color: var(--sdis-text-muted, #86868b);
            padding: 0.35rem 0;
            text-transform: uppercase;
            letter-spacing: 0.3px;
        }
        
        /* Grille des jours */
        .mysis-calendar-days {
            display: grid;
            grid-template-columns: repeat(7, 1fr);
            gap: 6px;
        }
        
        /* Jour du calendrier - Base */
        .mysis-calendar-day {
            aspect-ratio: 1;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 10px;
            font-weight: 600;
            font-size: 0.85rem;
            cursor: pointer;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
            min-height: 40px;
            max-height: 48px;
            background: transparent;
            border: 2px solid transparent;
        }
        
        /* Jour - Autre mois */
        .mysis-calendar-day-other-month {
            color: var(--sdis-text-muted, #d1d5db);
            cursor: default;
            opacity: 0.4;
        }
        
        /* Jour - Passé */
        .mysis-calendar-day-past {
            color: var(--sdis-text-muted, #d1d5db);
            cursor: not-allowed;
            background: var(--sdis-bg-hover, #f5f5f7);
            opacity: 0.5;
        }
        
        /* Jour - Déjà réservé */
        .mysis-calendar-day-reserved {
            background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
            color: #991B1B;
            cursor: not-allowed;
            border: 2px solid #fecaca;
        }
        
        .mysis-calendar-day-reserved::after {
            content: '';
            position: absolute;
            top: 6px;
            right: 6px;
            width: 8px;
            height: 8px;
            background: #ef4444;
            border-radius: 50%;
        }
        
        /* Jour - Pas de repas PeSUD (mode externe) */
        .mysis-calendar-day-no-psud {
            background: #f9fafb;
            color: #d1d5db;
            cursor: not-allowed;
            border: 1px dashed #e5e7eb;
            opacity: 0.55;
        }

        /* Jour - Bloqué (hors délai) */
        .mysis-calendar-day-blocked {
            background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
            color: #92400E;
            cursor: not-allowed;
            border: 2px solid #fde68a;
        }
        
        .mysis-calendar-day-blocked::after {
            content: '';
            position: absolute;
            top: 6px;
            right: 6px;
            width: 8px;
            height: 8px;
            background: #f59e0b;
            border-radius: 50%;
        }
        
        /* Jour - Disponible */
        .mysis-calendar-day-available {
            background: var(--sdis-bg-card, #FFFFFF);
            color: var(--sdis-text-primary, #374151);
            border: 2px solid var(--sdis-border-color, #e5e7eb);
        }
        
        .mysis-calendar-day-available:hover {
            background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
            border-color: #10b981;
            color: #059669;
            transform: scale(1.08);
            box-shadow: 0 4px 12px rgba(16, 185, 129, 0.25);
        }
        
        /* Jour - Sélectionné */
        .mysis-calendar-day-selected {
            background: linear-gradient(135deg, #AB0209 0%, #8B0007 100%);
            color: #FFFFFF;
            border: 2px solid #AB0209;
            box-shadow: 0 4px 16px rgba(171, 2, 9, 0.35);
        }
        
        .mysis-calendar-day-selected:hover {
            background: linear-gradient(135deg, #8B0007 0%, #6B0005 100%);
            border-color: #8B0007;
            transform: scale(1.08);
            box-shadow: 0 6px 20px rgba(171, 2, 9, 0.45);
        }
        
        /* Jour - Aujourd'hui */
        .mysis-calendar-day-today {
            font-weight: 800;
        }
        
        .mysis-calendar-day-today::after {
            content: '';
            position: absolute;
            bottom: 6px;
            left: 50%;
            transform: translateX(-50%);
            width: 6px;
            height: 6px;
            border-radius: 50%;
            background: var(--sdis-primary, #AB0209);
        }
        
        .mysis-calendar-day-today.mysis-calendar-day-selected::after {
            background: #FFFFFF;
        }
        
        /* ============================================
           LISTE DES DATES SÉLECTIONNÉES
           ============================================ */
        
        .mysis-selected-dates-list {
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
        }
        
        /* État vide */
        .mysis-empty-state {
            text-align: center;
            color: var(--sdis-text-muted, #9CA3AF);
            font-size: 0.95rem;
            padding: 2.5rem 1.5rem;
            background: var(--sdis-bg-hover, #f9fafb);
            border-radius: 16px;
            border: 2px dashed var(--sdis-border-color, #e5e7eb);
        }
        
        .mysis-empty-state::before {
            content: '📅';
            display: block;
            font-size: 2.5rem;
            margin-bottom: 0.75rem;
            opacity: 0.6;
        }
        
        /* Header de la liste des dates */
        #mysis-selected-dates-list h4,
        .mysis-selected-dates-list h4 {
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 1rem;
            font-weight: 700;
            color: var(--sdis-text-primary, #1d1d1f);
            margin: 0 0 1rem 0;
            padding-bottom: 0.75rem;
            border-bottom: 1px solid var(--sdis-border-color, rgba(0, 0, 0, 0.08));
        }
        
        /* Boutons */
        .mysis-btn-secondary {
            background: var(--sdis-bg-hover, #f3f4f6);
            color: var(--sdis-text-primary, #374151);
            border: 1px solid var(--sdis-border-color, #e5e7eb);
            border-radius: 12px;
            padding: 12px 20px;
            font-weight: 600;
            font-size: 0.95rem;
            cursor: pointer;
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
        }
        
        .mysis-btn-secondary:hover {
            background: var(--sdis-bg-active, #e5e7eb);
            transform: translateY(-1px);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
        }
        
        .mysis-btn-secondary:active {
            transform: translateY(0);
        }
        
        /* ============================================
           RESPONSIVE - MOBILE
           ============================================ */
        
        @media (max-width: 1023px) {
            .mysis-calendar-wrapper {
                padding: 1rem;
                border-radius: 16px;
            }
            
            .mysis-calendar-day {
                min-height: 42px;
                font-size: 0.9rem;
                border-radius: 10px;
            }
            
            .mysis-calendar-month-year {
                font-size: 1.2rem;
            }
            
            .mysis-repas-step-title {
                font-size: 1.15rem;
            }
        }
        
        @media (max-width: 480px) {
            .mysis-calendar-day {
                min-height: 36px;
                font-size: 0.85rem;
                border-radius: 8px;
            }
            
            .mysis-calendar-days {
                gap: 0.3rem;
            }
            
            .mysis-calendar-weekdays {
                gap: 0.3rem;
            }
        }
        
        /* ============================================
           DARK MODE SUPPORT
           ============================================ */
        
        html[data-theme="dark"] .mysis-calendar-wrapper {
            background: var(--sdis-bg-card, #1a1a24);
            border-color: var(--sdis-border-color, #2f2f40);
        }
        
        html[data-theme="dark"] .mysis-calendar-day-available {
            background: var(--sdis-bg-hover, #22222e);
            border-color: var(--sdis-border-color, #2f2f40);
            color: var(--sdis-text-primary, #f0f0f5);
        }
        
        html[data-theme="dark"] .mysis-calendar-day-available:hover {
            background: rgba(16, 185, 129, 0.15);
            border-color: #10b981;
        }
        
        html[data-theme="dark"] .mysis-calendar-day-past {
            background: var(--sdis-bg-tertiary, #15151d);
        }
        
        html[data-theme="dark"] .mysis-empty-state {
            background: var(--sdis-bg-hover, #22222e);
            border-color: var(--sdis-border-color, #2f2f40);
        }
        
        html[data-theme="dark"] .mysis-calendar-nav {
            background: var(--sdis-bg-hover, #22222e);
            color: var(--sdis-text-secondary, #a0a0b0);
        }
        
        html[data-theme="dark"] .mysis-calendar-nav:hover {
            background: var(--sdis-primary-light, rgba(212, 25, 32, 0.15));
        }
        
        .mysis-selected-date-item {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 1rem;
            background: #F9FAFB;
            border: 2px solid #E5E7EB;
            border-radius: 10px;
            transition: all 0.2s;
        }
        
        .mysis-selected-date-item:hover {
            border-color: #AB0209;
            background: #FFF5F5;
        }
        
        .mysis-selected-date-item .material-symbols-outlined {
            color: #AB0209;
            font-size: 1.5rem;
        }
        
        .mysis-selected-date-item span:not(.material-symbols-outlined) {
            flex: 1;
            font-weight: 600;
            color: #374151;
        }
        
        .mysis-date-remove {
            background: transparent;
            border: none;
            color: #EF4444;
            cursor: pointer;
            padding: 0.25rem;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 6px;
            transition: all 0.2s;
        }
        
        .mysis-date-remove:hover {
            background: #FEE2E2;
        }
        
        /* Panier de réservations */
        #mysis-reservations-cart {
            margin-top: 2rem;
            padding-top: 2rem;
            border-top: 2px solid #E5E7EB;
        }
        
        .mysis-reservation-item {
            background: #FFFFFF;
            border: 2px solid #E5E7EB;
            border-radius: 12px;
            padding: 1.5rem;
            margin-bottom: 1.5rem;
            transition: all 0.3s;
        }
        
        .mysis-reservation-item:hover {
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
        }
        
        .mysis-reservation-item.mysis-reservation-complete {
            border-color: #10B981;
            background: #F0FDF4;
        }
        
        .mysis-reservation-item-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 1rem;
        }
        
        .mysis-reservation-item-date {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            font-size: 1.1rem;
            font-weight: 700;
            color: #374151;
        }
        
        .mysis-reservation-item-date .material-symbols-outlined {
            color: #AB0209;
            font-size: 1.5rem;
        }
        
        .mysis-reservation-item-loading {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            color: #6B7280;
            font-size: 0.9rem;
        }
        
        .mysis-reservation-item-loading .material-symbols-outlined {
            animation: spin 1s linear infinite;
        }
        
        @keyframes spin {
            from { transform: rotate(0deg); }
            to { transform: rotate(360deg); }
        }
        
        .mysis-reservation-item-menu {
            margin-bottom: 1rem;
        }
        
        .mysis-reservation-menu-section {
            margin-bottom: 1rem;
        }
        
        .mysis-reservation-menu-section h4 {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            font-size: 1rem;
            font-weight: 700;
            color: #374151;
            margin: 0 0 0.5rem 0;
        }
        
        .mysis-reservation-menu-section h4 .material-symbols-outlined {
            font-size: 1.25rem;
            color: #AB0209;
        }
        
        .mysis-reservation-menu-section p {
            margin: 0;
            color: #6B7280;
            font-size: 0.95rem;
            line-height: 1.6;
        }
        
        .mysis-reservation-plats-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
            gap: 1rem;
            margin-bottom: 1rem;
        }
        
        .mysis-reservation-plat-option {
            background: #FFFFFF;
            border: 2px solid #E5E7EB;
            border-radius: 10px;
            padding: 1rem;
            transition: all 0.2s;
        }
        
        .mysis-reservation-plat-option:hover {
            border-color: #AB0209;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
        }
        
        .mysis-reservation-plat-header {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            margin-bottom: 0.5rem;
            padding-bottom: 0.5rem;
            border-bottom: 2px solid #E5E7EB;
        }
        
        .mysis-reservation-plat-header h4 {
            margin: 0;
            font-size: 0.95rem;
            font-weight: 700;
            color: #374151;
        }
        
        .mysis-reservation-plat-header .material-symbols-outlined {
            font-size: 1.25rem;
            color: #6B7280;
        }
        
        .mysis-reservation-plat-content {
            font-size: 0.9rem;
            color: #6B7280;
            line-height: 1.5;
            margin-bottom: 0.75rem;
        }
        
        .mysis-reservation-plat-radio {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 0.5rem;
            padding: 0.75rem 1.5rem;
            background: linear-gradient(135deg, #F9FAFB 0%, #F3F4F6 100%);
            border: 2px solid #E5E7EB;
            border-radius: 10px;
            cursor: pointer;
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            font-weight: 600;
            font-size: 0.9rem;
            color: #6B7280;
            position: relative;
            overflow: hidden;
        }
        
        .mysis-reservation-plat-radio::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
            transition: left 0.5s;
        }
        
        .mysis-reservation-plat-radio:hover::before {
            left: 100%;
        }
        
        .mysis-reservation-plat-radio:hover {
            border-color: #AB0209;
            background: linear-gradient(135deg, #FFF5F5 0%, #FEE2E2 100%);
            color: #AB0209;
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(171, 2, 9, 0.15);
        }
        
        .mysis-reservation-plat-radio input[type="radio"] {
            display: none;
        }
        
        .mysis-reservation-plat-radio input[type="radio"]:checked + span {
            color: white;
            font-weight: 700;
        }
        
        .mysis-reservation-plat-option:has(input[type="radio"]:checked) {
            border-color: #AB0209;
            background: linear-gradient(135deg, #FFF5F5 0%, #FEE2E2 100%);
            box-shadow: 0 4px 16px rgba(171, 2, 9, 0.2);
        }
        
        .mysis-reservation-plat-option:has(input[type="radio"]:checked) .mysis-reservation-plat-radio {
            background: linear-gradient(135deg, #AB0209 0%, #8B0108 100%);
            border-color: #AB0209;
            color: white;
            box-shadow: 0 4px 12px rgba(171, 2, 9, 0.4);
            transform: translateY(-2px);
        }
        
        .mysis-reservation-plat-option:has(input[type="radio"]:checked) .mysis-reservation-plat-radio:hover {
            background: linear-gradient(135deg, #8B0108 0%, #6B0006 100%);
            box-shadow: 0 6px 16px rgba(171, 2, 9, 0.5);
        }
        
        .mysis-reservation-no-menu {
            display: flex;
            flex-wrap: wrap;
            align-items: start;
            gap: 0.75rem;
            padding: 1rem;
            background: #FFF3CD;
            border-left: 4px solid #FFC107;
            border-radius: 8px;
            color: #856404;
        }
        
        .mysis-reservation-no-menu .material-symbols-outlined {
            color: #FFC107;
            flex-shrink: 0;
        }
        
        .mysis-reservation-no-menu p {
            margin: 0;
            font-size: 0.9rem;
        }
        
        .mysis-no-menu-pref-label {
            margin-top: 12px;
            width: 100%;
            font-weight: 600;
        }
        
        .mysis-no-menu-pref-choices {
            display: flex;
            flex-wrap: wrap;
            gap: 12px;
            margin-top: 6px;
            width: 100%;
        }
        
        .mysis-no-menu-pref-option {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            cursor: pointer;
            font-size: 0.9rem;
        }
        
        .mysis-no-menu-pref-option .material-symbols-outlined {
            font-size: 1.1rem;
        }
        
        /* Styles pour réservation dernière minute */
        .mysis-reservation-lastminute-warning {
            display: flex;
            align-items: start;
            gap: 0.75rem;
            padding: 1rem;
            background: linear-gradient(135deg, #FEF3C7 0%, #FDE68A 100%);
            border-left: 4px solid #F59E0B;
            border-radius: 8px;
            color: #92400E;
            margin-bottom: 1rem;
        }
        
        .mysis-reservation-lastminute-warning .material-symbols-outlined {
            color: #F59E0B;
            flex-shrink: 0;
            font-size: 1.5rem;
        }
        
        .mysis-reservation-lastminute-warning strong {
            display: block;
            font-weight: 600;
            margin-bottom: 4px;
        }
        
        .mysis-reservation-lastminute-warning p {
            margin: 0;
            font-size: 0.85rem;
        }
        
        /* Contenu de plat masqué pour dernière minute */
        .mysis-plat-hidden-content {
            border-color: #FCD34D !important;
        }
        
        .mysis-reservation-plat-hidden {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            padding: 1rem;
            color: #92400E;
            font-size: 0.85rem;
            font-style: italic;
            background: rgba(251, 191, 36, 0.1);
            border-radius: 6px;
            min-height: 60px;
        }
        
        .mysis-reservation-plat-hidden .material-symbols-outlined {
            font-size: 1.25rem;
            opacity: 0.7;
        }
        
        .mysis-cart-actions {
            display: flex;
            justify-content: flex-end;
            margin-top: 2rem;
            padding-top: 1.5rem;
            border-top: 2px solid #E5E7EB;
        }
        
        .mysis-cart-actions .mysis-primary:disabled {
            opacity: 0.5;
            cursor: not-allowed;
        }
        
        /* Responsive pour l'interface multi-réservations */
        @media (max-width: 768px) {
            .mysis-calendar-wrapper {
                padding: 1rem;
            }
            
            .mysis-calendar-day {
                font-size: 0.85rem;
            }
            
            .mysis-reservation-plats-grid {
                grid-template-columns: 1fr;
            }
            
            .mysis-cart-actions {
                justify-content: stretch;
            }
            
            .mysis-cart-actions .mysis-primary {
                width: 100%;
                justify-content: center;
            }
        }

/* ===== Admin des menus ===== */
        .mysis-gestion-menus-container {
            max-width: 1400px;
            margin: 0 auto;
            padding: 2rem;
            font-family: 'Outfit', sans-serif;
        }
        
        .mysis-gestion-menus-header h2 {
            font-size: 2rem;
            font-weight: 700;
            color: #AB0209;
            display: flex;
            align-items: center;
            gap: 0.75rem;
            margin-bottom: 2rem;
        }
        
        .mysis-gestion-menus-card {
            background: #fff;
            border-radius: 16px;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
            padding: 2rem;
            margin-bottom: 2rem;
        }
        
        .mysis-gestion-menus-card h3 {
            font-size: 1.5rem;
            font-weight: 700;
            margin-bottom: 1.5rem;
            color: #333;
        }
        
        .mysis-menu-admin-form {
            display: flex;
            flex-direction: column;
            gap: 1.5rem;
        }
        
        .mysis-menu-admin-field {
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }
        
        .mysis-menu-admin-field label {
            font-weight: 600;
            color: #374151;
        }
        
        .mysis-menu-admin-field input[type="date"] {
            padding: 0.875rem;
            border: 2px solid #e9ecef;
            border-radius: 8px;
            font-family: 'Outfit', sans-serif;
            font-size: 1rem;
        }
        
        .mysis-menu-admin-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.5rem;
        }
        
        .mysis-menu-admin-column {
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }
        
        .mysis-menu-admin-column label {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            font-weight: 600;
            color: #374151;
        }
        
        .mysis-menu-admin-column textarea {
            width: 100%;
            padding: 1rem;
            border: 2px solid #e9ecef;
            border-radius: 8px;
            font-family: 'Outfit', sans-serif;
            font-size: 0.95rem;
            line-height: 1.6;
            resize: vertical;
        }
        
        /* Réduire la hauteur des textarea pour les plats dans le modal */
        .mysis-menu-modal .mysis-menu-admin-column textarea {
            min-height: 100px;
            max-height: 150px;
            height: 120px;
        }
        
        .mysis-menu-admin-actions {
            display: flex;
            gap: 1rem;
        }
        
        .mysis-secondary {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.875rem 1.5rem;
            background: #f8f9fa;
            border: 2px solid #e9ecef;
            border-radius: 8px;
            color: #6B7280;
            text-decoration: none;
            font-weight: 600;
            transition: all 0.2s;
        }
        
        .mysis-secondary:hover {
            background: #e9ecef;
            color: #374151;
        }
        
        .mysis-gestion-menus-list {
            background: #fff;
            border-radius: 16px;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
            padding: 2rem;
        }
        
        .mysis-gestion-menus-list h3 {
            font-size: 1.5rem;
            font-weight: 700;
            margin-bottom: 1.5rem;
            color: #333;
        }
        
        .mysis-menus-table-container {
            overflow-x: auto;
        }
        
        .mysis-menus-table {
            width: 100%;
            border-collapse: collapse;
        }
        
        .mysis-menus-table th {
            background: #f8f9fa;
            padding: 1rem;
            text-align: left;
            font-weight: 700;
            color: #374151;
            border-bottom: 2px solid #e9ecef;
        }
        
        .mysis-menus-table td {
            padding: 1rem;
            border-bottom: 1px solid #e9ecef;
            color: #6B7280;
        }
        
        .mysis-menus-actions {
            display: flex;
            gap: 0.5rem;
        }
        
        .mysis-action-edit,
        .mysis-action-delete {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 36px;
            height: 36px;
            border-radius: 8px;
            text-decoration: none;
            transition: all 0.2s;
        }
        
        .mysis-action-edit {
            background: #e7f3ff;
            color: #0d6efd;
        }
        
        .mysis-action-edit:hover {
            background: #0d6efd;
            color: #fff;
        }
        
        .mysis-action-delete {
            background: #fee;
            color: #dc3545;
        }
        
        .mysis-action-delete:hover {
            background: #dc3545;
            color: #fff;
        }
        
        /* Vue calendrier 15 jours */
        .mysis-gestion-menus-calendar {
            background: #fff;
            border-radius: 16px;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
            padding: 2rem;
            margin-bottom: 2rem;
        }
        
        .mysis-calendar-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1.5rem;
            flex-wrap: wrap;
            gap: 1rem;
        }
        
        .mysis-calendar-header h3 {
            font-size: 1.5rem;
            font-weight: 700;
            margin: 0;
            color: #333;
        }
        
        .mysis-calendar-navigation {
            display: flex;
            align-items: center;
            gap: 1rem;
        }
        
        .mysis-calendar-nav-btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 40px;
            height: 40px;
            border-radius: 8px;
            background: #f8f9fa;
            border: 2px solid #e9ecef;
            color: #374151;
            text-decoration: none;
            transition: all 0.2s;
            cursor: pointer;
        }
        
        .mysis-calendar-nav-btn:hover:not(.disabled) {
            background: #AB0209;
            border-color: #AB0209;
            color: #fff;
        }
        
        .mysis-calendar-nav-btn.disabled {
            opacity: 0.4;
            cursor: not-allowed;
        }
        
        .mysis-calendar-nav-btn .material-symbols-outlined {
            font-size: 24px;
        }
        
        .mysis-calendar-current-month {
            font-size: 1.1rem;
            font-weight: 600;
            color: #374151;
            min-width: 150px;
            text-align: center;
        }
        
        .mysis-gestion-menus-calendar h3 {
            font-size: 1.5rem;
            font-weight: 700;
            margin-bottom: 1.5rem;
            color: #333;
        }
        
        .mysis-menus-calendar-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
            gap: 1.5rem;
        }
        
        .mysis-menu-day-card {
            background: #fff;
            border: 2px solid #e9ecef;
            border-radius: 12px;
            padding: 1rem;
            transition: all 0.3s ease;
        }
        
        .mysis-menu-day-card.has-menu {
            border-color: #10B981;
            background: linear-gradient(135deg, #f0fdf4 0%, #fff 100%);
        }
        
        .mysis-menu-day-card.no-menu {
            border-color: #e9ecef;
            background: #f8f9fa;
        }
        
        .mysis-menu-day-card:hover {
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
        }
        
        .mysis-menu-day-header {
            display: flex;
            flex-direction: column;
            gap: 0.25rem;
            margin-bottom: 1rem;
            padding-bottom: 0.75rem;
            border-bottom: 2px solid #e9ecef;
        }
        
        .mysis-menu-day-name {
            font-weight: 700;
            font-size: 1.1rem;
            color: #AB0209;
            text-transform: capitalize;
        }
        
        .mysis-menu-day-date {
            font-size: 0.9rem;
            color: #6B7280;
        }
        
        .mysis-menu-today {
            display: inline-block;
            margin-top: 0.25rem;
            padding: 0.25rem 0.5rem;
            background: #AB0209;
            color: #fff;
            border-radius: 6px;
            font-size: 0.75rem;
            font-weight: 600;
        }
        
        .mysis-menu-day-content {
            display: flex;
            flex-direction: column;
            gap: 0.75rem;
        }
        
        .mysis-menu-day-item {
            display: flex;
            align-items: start;
            gap: 0.5rem;
            padding: 0.75rem;
            background: #fff;
            border-radius: 8px;
            border-left: 3px solid #0d6efd;
        }
        
        .mysis-menu-dessert-item {
            border-left-color: #ffc107;
        }
        
        .mysis-menu-accompagnement-item {
            border-left-color: #10B981;
        }
        
        .mysis-menu-day-item .material-symbols-outlined {
            color: #0d6efd;
            flex-shrink: 0;
        }
        
        .mysis-menu-dessert-item .material-symbols-outlined {
            color: #ffc107;
        }
        
        .mysis-menu-accompagnement-item .material-symbols-outlined {
            color: #10B981;
        }
        
        .mysis-menu-day-item strong {
            display: block;
            font-size: 0.9rem;
            color: #374151;
            margin-bottom: 0.25rem;
        }
        
        .mysis-menu-day-item p {
            margin: 0;
            font-size: 0.85rem;
            color: #6B7280;
            line-height: 1.5;
        }
        
        .mysis-menu-day-plats {
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }
        
        .mysis-menu-day-plat {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem;
            background: #fff;
            border-radius: 6px;
            font-size: 0.85rem;
            border-left: 3px solid #6B7280;
        }
        
        .mysis-plat-viande {
            border-left-color: #dc3545;
        }
        
        .mysis-plat-poisson {
            border-left-color: #0d6efd;
        }
        
        .mysis-plat-vegetarien {
            border-left-color: #198754;
        }
        
        .mysis-menu-day-plat .material-symbols-outlined {
            font-size: 1.25rem;
            color: #6B7280;
        }
        
        .mysis-plat-viande .material-symbols-outlined {
            color: #dc3545;
        }
        
        .mysis-plat-poisson .material-symbols-outlined {
            color: #0d6efd;
        }
        
        .mysis-plat-vegetarien .material-symbols-outlined {
            color: #198754;
        }
        
        .mysis-menu-day-actions {
            margin-top: 0.75rem;
            padding-top: 0.75rem;
            border-top: 1px solid #e9ecef;
        }
        
        .mysis-menu-day-edit {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem 1rem;
            background: #e7f3ff;
            color: #0d6efd;
            border-radius: 8px;
            text-decoration: none;
            font-size: 0.9rem;
            font-weight: 600;
            transition: all 0.2s;
        }
        
        .mysis-menu-day-edit:hover {
            background: #0d6efd;
            color: #fff;
        }
        
        .mysis-menu-day-empty {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 2rem 1rem;
            text-align: center;
            color: #6B7280;
        }
        
        .mysis-menu-day-empty .material-symbols-outlined {
            font-size: 3rem;
            color: #d1d5db;
            margin-bottom: 0.5rem;
        }
        
        .mysis-menu-day-empty p {
            margin: 0.5rem 0;
            font-size: 0.9rem;
        }
        
        .mysis-menu-day-add {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem 1rem;
            background: #AB0209;
            color: #fff;
            border-radius: 8px;
            text-decoration: none;
            font-size: 0.9rem;
            font-weight: 600;
            transition: all 0.2s;
            margin-top: 0.5rem;
        }
        
        .mysis-menu-day-add:hover {
            background: #8B0007;
            transform: translateY(-1px);
        }
        
        @media (max-width: 968px) {
            .mysis-menu-admin-grid {
                grid-template-columns: 1fr;
            }
            
            .mysis-gestion-menus-container {
                padding: 1rem;
            }
            
            .mysis-menus-calendar-grid {
                grid-template-columns: 1fr;
            }
        }
        
        /* Modal pour l'édition */
        .mysis-menu-modal {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 100000;
            display: none;
            align-items: center;
            justify-content: center;
        }
        
        .mysis-menu-modal.active {
            display: flex;
        }
        
        .mysis-menu-modal-overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(255, 255, 255, 0.9);
            backdrop-filter: blur(8px);
        }
        
        .mysis-menu-modal-content {
            position: relative;
            background: #fff;
            border-radius: 16px;
            box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
            max-width: 1000px;
            width: 90%;
            max-height: 90vh;
            overflow-y: auto;
            z-index: 100001;
            animation: modalSlideIn 0.3s ease;
        }
        
        @keyframes modalSlideIn {
            from {
                opacity: 0;
                transform: translateY(-20px) scale(0.95);
            }
            to {
                opacity: 1;
                transform: translateY(0) scale(1);
            }
        }
        
        .mysis-menu-modal-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 1.5rem 2rem;
            border-bottom: 2px solid #e9ecef;
            background: linear-gradient(135deg, #f8f9fa 0%, #fff 100%);
            border-radius: 16px 16px 0 0;
        }
        
        .mysis-menu-modal-header h3 {
            margin: 0;
            font-size: 1.5rem;
            font-weight: 700;
            color: #333;
        }
        
        .mysis-menu-modal-close {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 36px;
            height: 36px;
            border: none;
            background: #f8f9fa;
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.2s;
            color: #6B7280;
        }
        
        .mysis-menu-modal-close:hover {
            background: #e9ecef;
            color: #AB0209;
        }
        
        .mysis-menu-modal-content .mysis-menu-admin-form {
            padding: 2rem;
        }
        
        .mysis-menu-day-add,
        .mysis-menu-day-edit {
            border: none;
            background: none;
            cursor: pointer;
            font-family: 'Outfit', sans-serif;
        }
        
        .mysis-menu-day-add {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem 1rem;
            background: #AB0209;
            color: #fff;
            border-radius: 8px;
            text-decoration: none;
            font-size: 0.9rem;
            font-weight: 600;
            transition: all 0.2s;
            margin-top: 0.5rem;
        }
        
        .mysis-menu-day-add:hover {
            background: #8B0007;
            transform: translateY(-1px);
        }
        
        .mysis-menu-day-edit {
            display: inline-flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.5rem 1rem;
            background: #e7f3ff;
            color: #0d6efd;
            border-radius: 8px;
            text-decoration: none;
            font-size: 0.9rem;
            font-weight: 600;
            transition: all 0.2s;
        }
        
        .mysis-menu-day-edit:hover {
            background: #0d6efd;
            color: #fff;
        }
        
        /* Onglets pour Navigation / Calendrier / Réglages */
        .mysis-menu-tabs-wrapper {
            margin-bottom: 2rem;
        }
        
        .mysis-menu-tabs-nav {
            display: flex;
            gap: 0.5rem;
            background: #f8f9fa;
            padding: 0.5rem;
            border-radius: 12px;
            border: 2px solid #e9ecef;
            margin-bottom: 0.75rem;
        }
        
        .mysis-menu-submenu {
            margin-top: 0.5rem;
        }
        
        .mysis-menu-submenu-btn {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.625rem 1rem;
            background: transparent;
            border: 1px solid #e9ecef;
            border-radius: 8px;
            font-family: 'Outfit', sans-serif;
            font-size: 0.9rem;
            font-weight: 600;
            color: #6B7280;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .mysis-menu-submenu-btn:hover {
            color: #AB0209;
            border-color: #AB0209;
            background: #fff;
        }
        
        .mysis-menu-submenu-btn.active {
            background: #AB0209;
            border-color: #AB0209;
            color: #fff;
        }
        
        .mysis-menu-submenu-btn .material-symbols-outlined {
            font-size: 1.1rem;
        }
        
        .mysis-menu-subpanel {
            background: #fff;
            border: 2px solid #e9ecef;
            border-radius: 12px;
            padding: 1.5rem;
            margin-top: 1rem;
            margin-bottom: 2rem;
        }
        
        .mysis-checkbox-field {
            margin-bottom: 0.75rem;
        }
        
        .mysis-checkbox-label {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            cursor: pointer;
            font-weight: 600;
            color: #374151;
        }
        
        .mysis-checkbox-label input[type="checkbox"] {
            width: 18px;
            height: 18px;
            cursor: pointer;
        }
        
        .mysis-menu-tab-btn {
            display: flex;
            align-items: center;
            gap: 0.5rem;
            padding: 0.75rem 1.5rem;
            background: transparent;
            border: none;
            border-radius: 8px;
            font-family: 'Outfit', sans-serif;
            font-size: 1rem;
            font-weight: 600;
            color: #6B7280;
            cursor: pointer;
            transition: all 0.2s;
        }
        
        .mysis-menu-tab-btn:hover {
            color: #AB0209;
            background: #fff;
        }
        
        .mysis-menu-tab-btn.active {
            background: #AB0209;
            color: #fff;
            box-shadow: 0 2px 8px rgba(171, 2, 9, 0.2);
        }
        
        .mysis-menu-tab-btn .material-symbols-outlined {
            font-size: 1.25rem;
        }
        
        .mysis-menu-tab-panel {
            display: none !important;
        }
        
        .mysis-menu-tab-panel.active {
            display: block !important;
        }
        
        .mysis-field-help {
            margin-top: 0.5rem;
            font-size: 0.875rem;
            color: #6B7280;
            font-style: italic;
        }

/* ===== Formulaire réservation groupe ===== */
    .mysis-btn-secondary {
        background: #F3F4F6 !important;
        color: #374151 !important;
        border: 2px solid #E5E7EB !important;
        border-radius: 10px !important;
        padding: 12px 20px !important;
        font-weight: 700 !important;
        font-size: 1rem !important;
        cursor: pointer;
        transition: all 0.2s ease !important;
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-family: inherit !important;
    }
    
    .mysis-btn-secondary:hover {
        background: #E5E7EB !important;
        border-color: #D1D5DB !important;
        transform: translateY(-2px);
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1) !important;
    }
    
    .mysis-btn-secondary .material-icons {
        font-size: 20px;
    }
    
    .mysis-info-message {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 16px 20px;
        background: #EFF6FF;
        border: 2px dashed #BFDBFE;
        border-radius: 12px;
        color: #1E40AF;
    }
    
    .mysis-info-message .material-icons {
        font-size: 24px;
        color: #3B82F6;
    }
    
    .mysis-info-message p {
        margin: 0;
        font-weight: 500;
    }
    
    /* Style pour les champs désactivés */
    input:disabled,
    select:disabled,
    button:disabled {
        opacity: 0.5;
        cursor: not-allowed !important;
    }
    
    .mysis-meal-btn:has(input:disabled) {
        opacity: 0.5;
        cursor: not-allowed;
    }
    
    .mysis-primary:disabled {
        background: #9CA3AF !important;
        cursor: not-allowed;
    }

/* ===== Gestion repas - tableau ===== */
        .mysis-jour-row {
            cursor: pointer;
            transition: background 0.2s;
        }
        .mysis-jour-row:hover {
            background: #F9FAFB !important;
        }
        .mysis-jour-row.active {
            background: #EFF6FF !important;
        }
        .mysis-jour-detail {
            display: none;
            padding: 0;
            background: #FAFBFC;
            border-top: 2px solid #E5E7EB;
        }
        .mysis-jour-detail.active {
            display: table-row;
        }
        .mysis-jour-detail td {
            padding: 0 !important;
        }
        .mysis-jour-detail-content {
            padding: 24px;
            width: 100%;
            box-sizing: border-box;
            max-width: 100%;
        }
        .mysis-jour-detail-content .mysis-stats-grid {
            max-width: none;
        }
        .mysis-chevron {
            transition: transform 0.3s;
        }
        .mysis-jour-row.active .mysis-chevron {
            transform: rotate(180deg);
        }
        .mysis-gestion-table-wrapper {
            overflow-x: visible;
            margin-bottom: 20px;
            border-radius: 12px;
            box-shadow: 0 1px 3px rgba(0,0,0,0.06);
        }
        .mysis-gestion-table-wrapper table {
            width: 100%;
            border-collapse: collapse;
            background: white;
        }
        .mysis-gestion-table-wrapper thead th {
            padding: 16px 14px;
            text-align: left;
            font-weight: 700;
            color: #374151;
            font-size: 0.875rem;
            background: linear-gradient(180deg, #F9FAFB 0%, #F3F4F6 100%);
            border-bottom: 2px solid #E5E7EB;
        }
        .mysis-gestion-table-wrapper thead th:first-child {
            border-radius: 12px 0 0 0;
        }
        .mysis-gestion-table-wrapper thead th:nth-child(n+2):nth-child(-n+6) {
            text-align: center;
        }
        .mysis-gestion-table-wrapper thead th:last-child {
            width: 48px;
            text-align: center;
        }
        .mysis-load-more-wrapper {
            text-align: center;
            margin-top: 24px;
            padding: 24px;
        }
        .mysis-load-more-btn {
            padding: 14px 28px;
            background: linear-gradient(135deg, #3B82F6 0%, #2563EB 100%);
            color: white;
            border: none;
            border-radius: 10px;
            font-size: 1rem;
            font-weight: 600;
            cursor: pointer;
            display: inline-flex;
            align-items: center;
            gap: 10px;
            box-shadow: 0 4px 14px rgba(59, 130, 246, 0.4);
            transition: all 0.25s ease;
        }
        .mysis-load-more-btn:hover:not(:disabled) {
            transform: translateY(-2px);
            box-shadow: 0 6px 20px rgba(59, 130, 246, 0.5);
        }
        .mysis-load-more-btn:disabled {
            opacity: 0.8;
            cursor: wait;
        }
        .mysis-gestion-badge {
            font-size: 0.75rem;
            padding: 4px 10px;
            border-radius: 6px;
            margin-left: 8px;
            font-weight: 600;
        }
        .mysis-gestion-table-wrapper .mysis-jour-row td {
            padding: 16px 14px;
            border-bottom: 1px solid #F3F4F6;
            vertical-align: middle;
        }
        .mysis-gestion-table-wrapper .mysis-jour-row td:nth-child(n+2):nth-child(-n+5) {
            text-align: center;
        }
        .mysis-gestion-table-wrapper .mysis-jour-row td:last-child {
            text-align: center;
        }
        .mysis-short-label { display: none; }
        .mysis-full-label { display: inline; }

        /* ====== RESPONSIVE : TABLEAUX RÉSERVATIONS INDIVIDUELLES (CARD LAYOUT) ====== */
        @media (max-width: 900px) {
            .mysis-jour-detail-content {
                padding: 16px 12px !important;
            }
            .mysis-stats-grid {
                grid-template-columns: 1fr !important;
                gap: 12px !important;
            }
            .mysis-stat-card {
                padding: 14px !important;
            }
            .mysis-resa-indiv-toggle {
                flex-wrap: wrap !important;
                padding: 12px !important;
                font-size: 1rem !important;
            }
            .mysis-badge-progress-wrapper {
                min-width: 150px !important;
                max-width: none !important;
                flex: 1 1 100% !important;
                order: 3;
                margin: 4px 0 0 0 !important;
            }
        }

        @media (max-width: 768px) {
            .mysis-resa-indiv-table {
                overflow-x: visible !important;
                margin: 0 !important;
            }
            .mysis-resa-indiv-table table {
                display: block !important;
                min-width: 0 !important;
                border: none !important;
                background: transparent !important;
            }
            .mysis-resa-indiv-table thead {
                display: none !important;
            }
            .mysis-resa-indiv-table tbody {
                display: block !important;
            }
            .mysis-resa-indiv-table tr.mysis-resa-row {
                display: flex !important;
                flex-wrap: wrap;
                align-items: center;
                padding: 10px 12px !important;
                margin-bottom: 4px;
                background: white !important;
                border: 1px solid #E5E7EB !important;
                border-radius: 8px !important;
                gap: 4px 8px;
            }
            .mysis-resa-indiv-table tr.mysis-resa-row:hover {
                background: #F9FAFB !important;
            }
            .mysis-resa-indiv-table td {
                display: inline !important;
                padding: 0 !important;
                border: none !important;
                font-size: 0.9rem !important;
            }
            .mysis-resa-indiv-table .mysis-col-badge {
                order: 1;
                flex-shrink: 0;
            }
            .mysis-btn-badger-agent {
                display: inline-flex;
                align-items: center;
                justify-content: center;
                padding: 6px;
                border: none;
                border-radius: 8px;
                background: transparent;
                cursor: pointer;
                transition: all 0.2s;
            }
            .mysis-btn-badger-agent:hover {
                background: rgba(99, 102, 241, 0.15);
                transform: scale(1.1);
            }
            .mysis-resa-indiv-table .mysis-col-matricule {
                display: none !important;
            }
            .mysis-resa-indiv-table td:nth-child(3) {
                order: 2;
                font-weight: 600 !important;
            }
            .mysis-resa-indiv-table td:nth-child(4) {
                order: 3;
            }
            .mysis-resa-indiv-table .mysis-col-repas {
                order: 4;
                margin-left: auto;
                color: #6B7280 !important;
                font-size: 0.8rem !important;
            }
            .mysis-resa-indiv-table .mysis-col-plat {
                order: 5;
                color: #9CA3AF !important;
                font-size: 0.8rem !important;
            }
            .mysis-resa-indiv-table .mysis-col-repas .material-icons,
            .mysis-resa-indiv-table .mysis-col-plat .material-icons {
                font-size: 14px !important;
                margin-right: 2px !important;
            }
            .mysis-intolerances-section {
                margin-bottom: 16px !important;
            }
        }

        /* ====== RESPONSIVE : TABLEAU PRINCIPAL JOURS ====== */
        @media (max-width: 640px) {
            .mysis-gestion-table-wrapper {
                overflow-x: visible !important;
                margin: 0 -8px;
                border-radius: 0;
            }
            .mysis-gestion-table-wrapper table {
                min-width: 0 !important;
                table-layout: fixed !important;
                width: 100% !important;
            }
            .mysis-gestion-header {
                padding: 14px 16px !important;
            }
            .mysis-gestion-header h2 {
                font-size: 1.1rem;
            }
            .mysis-gestion-badge {
                display: block;
                margin: 8px 0 0 0;
            }
            .mysis-short-label { display: inline !important; }
            .mysis-full-label { display: none !important; }
            .mysis-th-total-prev,
            .mysis-td-total-prev,
            .mysis-th-chevron,
            .mysis-td-chevron {
                display: none !important;
            }
            .mysis-gestion-table-wrapper thead th {
                padding: 10px 4px !important;
                font-size: 0.75rem !important;
                min-width: 0 !important;
            }
            .mysis-gestion-table-wrapper thead th:first-child {
                min-width: 0 !important;
                width: 40% !important;
            }
            .mysis-gestion-table-wrapper .mysis-jour-row td {
                padding: 10px 4px !important;
                font-size: 0.8rem !important;
            }
            .mysis-td-date {
                width: 40% !important;
                word-break: break-word;
                white-space: normal !important;
                line-height: 1.3;
            }
            .mysis-td-total-reel {
                font-size: 0.95rem !important;
            }
            .mysis-jour-detail-content {
                padding: 12px 8px !important;
            }
            .mysis-stat-card p[style*="font-size: 2rem"] {
                font-size: 1.5rem !important;
            }
            .mysis-resa-indiv-section {
                margin-bottom: 16px !important;
            }
            .mysis-resa-indiv-block {
                margin-bottom: 16px !important;
            }
            .mysis-resa-indiv-block h5 {
                font-size: 0.9rem !important;
            }
            .mysis-load-more-btn {
                padding: 12px 20px !important;
                font-size: 0.9rem !important;
            }
        }

        @media (max-width: 768px) {
            .mysis-groupe-table {
                overflow-x: visible !important;
            }
            .mysis-groupe-table table {
                min-width: 0 !important;
            }
            .mysis-groupe-table th,
            .mysis-groupe-table td {
                padding: 8px 6px !important;
                font-size: 0.8rem !important;
            }
            .mysis-grp-col-resp {
                display: none !important;
            }
            .mysis-gestion-legend {
                padding: 12px 16px 0 16px !important;
            }
        }

        @media (max-width: 420px) {
            .mysis-gestion-table-wrapper thead th {
                padding: 8px 2px !important;
                font-size: 0.7rem !important;
            }
            .mysis-gestion-table-wrapper .mysis-jour-row td {
                padding: 8px 2px !important;
                font-size: 0.75rem !important;
            }
            .mysis-resa-indiv-table td {
                font-size: 0.8rem !important;
            }
            .mysis-resa-indiv-table .mysis-col-repas,
            .mysis-resa-indiv-table .mysis-col-plat {
                font-size: 0.75rem !important;
            }
            .mysis-resa-indiv-table .mysis-col-repas .material-icons,
            .mysis-resa-indiv-table .mysis-col-plat .material-icons {
                display: none !important;
            }
            .mysis-groupe-table th,
            .mysis-groupe-table td {
                padding: 6px 3px !important;
                font-size: 0.72rem !important;
            }
        }

/* ===== Export POS ===== */
    .selfsis-pos-export { font-family: var(--selfsis-font, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif); }
    .selfsis-pos-export .pos-export-header { display: flex; align-items: center; gap: 12px; margin: 0 0 24px 0; padding: 16px 20px; background: #000; border-radius: 14px; color: white; font-size: 18px; font-weight: 700; }
    .selfsis-pos-export .pos-export-header .material-symbols-outlined { font-size: 24px; color: white; }
    /* Formulaire de filtre modernisé */
    .selfsis-pos-export .pos-export-filter-form { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; padding: 20px; background: var(--selfsis-bg, #f5f5f7); border-radius: 14px; border: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .selfsis-pos-export .pos-filter-main-row { display: flex; align-items: flex-end; gap: 16px; flex-wrap: wrap; }
    .selfsis-pos-export .pos-filter-period { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; flex: 1; min-width: 280px; }
    .selfsis-pos-export .pos-filter-period-arrow { color: var(--selfsis-text-secondary, #6e6e73); font-size: 20px; margin-bottom: 10px; flex-shrink: 0; }
    .selfsis-pos-export .pos-export-field-group label { display: flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 600; color: var(--selfsis-text-secondary, #6e6e73); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.4px; }
    .selfsis-pos-export .pos-export-field-group label .material-symbols-outlined { font-size: 14px; }
    .selfsis-pos-export .pos-export-input { padding: 10px 14px; border: 1px solid var(--selfsis-border, rgba(0,0,0,0.1)); border-radius: 10px; font-size: 15px; background: var(--selfsis-surface-solid, #fff); color: var(--selfsis-text, #1d1d1f); }
    .selfsis-pos-export .pos-export-input:focus { outline: none; border-color: var(--selfsis-primary, #AB0209); box-shadow: 0 0 0 3px rgba(171,2,9,0.1); }
    .selfsis-pos-export .pos-filter-actions-col { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; flex-shrink: 0; }
    .selfsis-pos-export .pos-filter-quick-dates { display: flex; gap: 6px; flex-wrap: wrap; }
    .selfsis-pos-export .selfsis-btn-sm { padding: 8px 12px !important; font-size: 13px !important; }
    /* Accès rapide */
    .selfsis-pos-export .pos-filter-shortcuts { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding-top: 10px; border-top: 1px solid var(--selfsis-border, rgba(0,0,0,0.06)); }
    .selfsis-pos-export .pos-filter-shortcuts-label { display: flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 600; color: var(--selfsis-text-secondary, #6e6e73); text-transform: uppercase; letter-spacing: 0.4px; flex-shrink: 0; }
    .selfsis-pos-export .pos-filter-shortcuts-label .material-symbols-outlined { font-size: 14px; }
    .selfsis-pos-export .pos-shortcut-btn { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 20px; border: 1px solid var(--selfsis-border, rgba(0,0,0,0.12)); background: var(--selfsis-surface-solid, #fff); color: var(--selfsis-text-secondary, #6e6e73); font-size: 13px; font-weight: 500; cursor: pointer; transition: all 0.15s; white-space: nowrap; }
    .selfsis-pos-export .pos-shortcut-btn .material-symbols-outlined { font-size: 16px; }
    .selfsis-pos-export .pos-shortcut-btn:hover { border-color: var(--selfsis-primary, #AB0209); color: var(--selfsis-primary, #AB0209); background: rgba(171,2,9,0.04); }
    .selfsis-pos-export .pos-shortcut-btn.pos-shortcut-btn--active { border-color: var(--selfsis-primary, #AB0209); color: var(--selfsis-primary, #AB0209); background: rgba(171,2,9,0.07); font-weight: 700; }
    /* Panneau inline */
    #pos-filter-inline-panel { margin-bottom: 16px; border-radius: 14px; overflow: hidden; border: 1px solid var(--selfsis-border, rgba(0,0,0,0.1)); box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
    #pos-filter-inline-panel > .pos-export-user-history-section,
    #pos-filter-inline-panel > .pos-edit-log-section { margin: 0 !important; border-radius: 0 !important; border: none !important; box-shadow: none !important; }
    /* Badge groupe EXT */
    .selfsis-pos-export .pos-ext-groupe-badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 20px; background: rgba(5,150,105,0.1); color: #047857; font-size: 12px; font-weight: 600; white-space: nowrap; }
    .selfsis-pos-export .pos-ext-event { font-size: 13px; color: var(--selfsis-text-secondary, #6e6e73); max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    html[data-theme="dark"] .selfsis-pos-export .pos-shortcut-btn { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.12); }
    html[data-theme="dark"] .selfsis-pos-export .pos-ext-groupe-badge { background: rgba(5,150,105,0.2); color: #34d399; }
    /* Section XLSX intégrée dans EXT */
    .selfsis-pos-export .pos-ext-xlsx-separator { display: flex; align-items: center; gap: 8px; padding: 14px 20px; background: rgba(5,150,105,0.06); border-top: 1px solid rgba(5,150,105,0.2); font-size: 14px; font-weight: 700; color: #059669; }
    .selfsis-pos-export .pos-ext-xlsx-separator .material-symbols-outlined { font-size: 18px; }
    .selfsis-pos-export .pos-ext-embedded-participants { margin: 0 !important; border: none !important; border-top: none !important; border-radius: 0 !important; border-bottom-left-radius: 14px !important; border-bottom-right-radius: 14px !important; background: var(--selfsis-surface-solid, #fff) !important; }
    .selfsis-pos-export .pos-ext-embedded-participants .rh-export-section__header { display: none !important; }
    html[data-theme="dark"] .selfsis-pos-export .pos-ext-xlsx-separator { background: rgba(5,150,105,0.12); border-top-color: rgba(5,150,105,0.3); }
    html[data-theme="dark"] .selfsis-pos-export .pos-ext-embedded-participants { background: rgba(255,255,255,0.02) !important; }
    
    /* Sélecteur de catégories */
    .selfsis-pos-export .pos-export-cat-selector { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin-bottom: 24px; }
    .selfsis-pos-export .pos-cat-card { display: flex; align-items: center; gap: 16px; padding: 18px 20px; background: var(--selfsis-surface-solid, #fff); border-radius: 14px; border: 2px solid var(--selfsis-border, rgba(0,0,0,0.08)); cursor: pointer; transition: all 0.2s ease; user-select: none; }
    .selfsis-pos-export .pos-cat-card:hover { border-color: var(--selfsis-primary, #AB0209); box-shadow: 0 4px 16px rgba(171,2,9,0.12); transform: translateY(-1px); }
    .selfsis-pos-export .pos-cat-card--active { border-color: var(--selfsis-primary, #AB0209) !important; background: rgba(171,2,9,0.04) !important; box-shadow: 0 4px 16px rgba(171,2,9,0.15) !important; }
    .selfsis-pos-export .pos-cat-card--active .pos-cat-card-chevron { transform: rotate(90deg); color: var(--selfsis-primary, #AB0209); }
    .selfsis-pos-export .pos-cat-card--spv:hover { border-color: #2563eb; box-shadow: 0 4px 16px rgba(37,99,235,0.12); }
    .selfsis-pos-export .pos-cat-card--spv.pos-cat-card--active { border-color: #2563eb !important; background: rgba(37,99,235,0.04) !important; box-shadow: 0 4px 16px rgba(37,99,235,0.15) !important; }
    .selfsis-pos-export .pos-cat-card--spv.pos-cat-card--active .pos-cat-card-chevron { color: #2563eb; }
    .selfsis-pos-export .pos-cat-card--ext:hover { border-color: #059669; box-shadow: 0 4px 16px rgba(5,150,105,0.12); }
    .selfsis-pos-export .pos-cat-card--ext.pos-cat-card--active { border-color: #059669 !important; background: rgba(5,150,105,0.04) !important; box-shadow: 0 4px 16px rgba(5,150,105,0.15) !important; }
    .selfsis-pos-export .pos-cat-card--ext.pos-cat-card--active .pos-cat-card-chevron { color: #059669; }
    .selfsis-pos-export .pos-cat-card-icon { width: 44px; height: 44px; border-radius: 12px; background: rgba(171,2,9,0.1); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .selfsis-pos-export .pos-cat-card-icon .material-symbols-outlined { color: var(--selfsis-primary, #AB0209); font-size: 22px; }
    .selfsis-pos-export .pos-cat-card--spv .pos-cat-card-icon { background: rgba(37,99,235,0.1); }
    .selfsis-pos-export .pos-cat-card--spv .pos-cat-card-icon .material-symbols-outlined { color: #2563eb; }
    .selfsis-pos-export .pos-cat-card--ext .pos-cat-card-icon { background: rgba(5,150,105,0.1); }
    .selfsis-pos-export .pos-cat-card--ext .pos-cat-card-icon .material-symbols-outlined { color: #059669; }
    .selfsis-pos-export .pos-cat-card--gfor:hover { border-color: #7c3aed; box-shadow: 0 4px 16px rgba(124,58,237,0.12); }
    .selfsis-pos-export .pos-cat-card--gfor.pos-cat-card--active { border-color: #7c3aed !important; background: rgba(124,58,237,0.04) !important; box-shadow: 0 4px 16px rgba(124,58,237,0.15) !important; }
    .selfsis-pos-export .pos-cat-card--gfor.pos-cat-card--active .pos-cat-card-chevron { color: #7c3aed; }
    .selfsis-pos-export .pos-cat-card--gfor .pos-cat-card-icon { background: rgba(124,58,237,0.1); }
    .selfsis-pos-export .pos-cat-card--gfor .pos-cat-card-icon .material-symbols-outlined { color: #7c3aed; }
    .selfsis-pos-export .pos-export-cat-section--gfor .pos-export-cat-section-header { background: rgba(124,58,237,0.06); border-bottom-color: rgba(124,58,237,0.15); }
    .selfsis-pos-export .pos-export-cat-section--gfor .pos-export-cat-section-title .material-symbols-outlined { color: #7c3aed; }
    .selfsis-pos-export .pos-gfor-statut-badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 20px; background: rgba(124,58,237,0.1); color: #6d28d9; font-size: 12px; font-weight: 600; white-space: nowrap; }
    .selfsis-pos-export .pos-gfor-formation { font-size: 13px; color: var(--selfsis-text-secondary, #6e6e73); max-width: 280px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    html[data-theme="dark"] .selfsis-pos-export .pos-cat-card--gfor.pos-cat-card--active { background: rgba(124,58,237,0.1) !important; }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-cat-section--gfor .pos-export-cat-section-header { background: rgba(124,58,237,0.12); border-bottom-color: rgba(124,58,237,0.3); }
    html[data-theme="dark"] .selfsis-pos-export .pos-gfor-statut-badge { background: rgba(124,58,237,0.2); color: #a78bfa; }
    .selfsis-pos-export .pos-cat-card-body { flex: 1; min-width: 0; }
    .selfsis-pos-export .pos-cat-card-name { font-size: 16px; font-weight: 700; color: var(--selfsis-text, #1d1d1f); margin-bottom: 2px; }
    .selfsis-pos-export .pos-cat-card-stats { font-size: 14px; color: var(--selfsis-text-secondary, #6e6e73); margin-bottom: 2px; }
    .selfsis-pos-export .pos-cat-card-stats strong { color: var(--selfsis-text, #1d1d1f); font-weight: 700; }
    .selfsis-pos-export .pos-cat-card-sub { font-size: 12px; color: var(--selfsis-text-secondary, #6e6e73); opacity: 0.8; }
    .selfsis-pos-export .pos-cat-card-alert { display: inline-flex; align-items: center; gap: 4px; margin-top: 5px; font-size: 11px; font-weight: 600; color: #b45309; background: rgba(245,158,11,0.12); border: 1px solid rgba(245,158,11,0.3); border-radius: 8px; padding: 2px 8px; }
    .selfsis-pos-export .pos-cat-card-alert .material-symbols-outlined { font-size: 13px; }
    .selfsis-pos-export .pos-row-formation-alert { background: rgba(245,158,11,0.07) !important; }
    .selfsis-pos-export .pos-row-formation-alert:hover td { background: rgba(245,158,11,0.12) !important; }
    .selfsis-pos-export .pos-formation-alert-icon { display: inline-flex; align-items: center; margin-left: 6px; color: #d97706; cursor: help; vertical-align: middle; }
    .selfsis-pos-export .pos-formation-alert-icon .material-symbols-outlined { font-size: 16px; }
    .selfsis-pos-export .pos-cat-card-chevron { color: var(--selfsis-text-secondary, #6e6e73); font-size: 20px; transition: transform 0.2s ease, color 0.2s ease; flex-shrink: 0; }
    /* Bouton GFOR */
    .inc-to-gfor-btn { display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: 8px; border: 1px solid rgba(16,185,129,0.4); background: rgba(16,185,129,0.08); color: #059669; font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: all 0.18s ease; }
    .inc-to-gfor-btn:hover { background: rgba(16,185,129,0.18); border-color: #059669; }
    .inc-to-gfor-btn .material-symbols-outlined { font-size: 15px; }
    .inc-to-gfor-btn:disabled { opacity: 0.5; cursor: not-allowed; }
    .inc-to-gfor-btn.loading { color: #6b7280; border-color: #d1d5db; background: #f9fafb; }
    .rh-incoherence-row.row-done { opacity: 0.5; }
    .rh-incoherence-row.row-done .inc-to-gfor-btn { display: none; }
    .inc-gfor-success { display: inline-flex; align-items: center; gap: 4px; color: #059669; font-size: 12px; font-weight: 600; }
    .inc-gfor-success .material-symbols-outlined { font-size: 15px; }
    
    /* Sections détaillées */
    .selfsis-pos-export .pos-export-cat-section { margin-bottom: 24px; border-radius: 14px; overflow: hidden; border: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .selfsis-pos-export .pos-export-cat-section-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 16px 20px; background: rgba(171,2,9,0.06); border-bottom: 1px solid rgba(171,2,9,0.15); flex-wrap: wrap; }
    .selfsis-pos-export .pos-export-cat-section--spv .pos-export-cat-section-header { background: rgba(37,99,235,0.06); border-bottom-color: rgba(37,99,235,0.15); }
    .selfsis-pos-export .pos-export-cat-section--ext .pos-export-cat-section-header { background: rgba(5,150,105,0.06); border-bottom-color: rgba(5,150,105,0.15); }
    .selfsis-pos-export .pos-export-cat-section-title { display: flex; align-items: center; gap: 10px; font-size: 15px; font-weight: 700; color: var(--selfsis-text, #1d1d1f); }
    .selfsis-pos-export .pos-export-cat-section-title .material-symbols-outlined { color: var(--selfsis-primary, #AB0209); font-size: 20px; }
    .selfsis-pos-export .pos-export-cat-section--spv .pos-export-cat-section-title .material-symbols-outlined { color: #2563eb; }
    .selfsis-pos-export .pos-export-cat-section--ext .pos-export-cat-section-title .material-symbols-outlined { color: #059669; }
    .selfsis-pos-export .pos-export-cat-section > div:last-child { padding: 16px; background: var(--selfsis-surface-solid, #fff); }
    
    .selfsis-pos-export .pos-export-table-card { background: var(--selfsis-surface-solid, #fff); border-radius: 10px; overflow: hidden; border: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .selfsis-pos-export .pos-export-table-header { padding: 16px 20px; background: var(--selfsis-bg, #f5f5f7); border-bottom: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .selfsis-pos-export .pos-export-table-title { margin: 0; font-size: 16px; font-weight: 600; color: var(--selfsis-text, #1d1d1f); display: flex; align-items: center; gap: 10px; }
    .selfsis-pos-export .pos-export-table-title .material-symbols-outlined { color: var(--selfsis-primary, #AB0209); font-size: 22px; }
    .selfsis-pos-export .pos-export-table-scroll { overflow-x: auto; }
    .selfsis-pos-export .pos-export-table { width: 100%; border-collapse: collapse; min-width: 700px; }
    .selfsis-pos-export .pos-export-table th { padding: 14px 16px; text-align: left; font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--selfsis-text-secondary, #6e6e73); background: var(--selfsis-bg, #f5f5f7); border-bottom: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .selfsis-pos-export .pos-export-table td { padding: 14px 16px; border-bottom: 1px solid var(--selfsis-border, rgba(0,0,0,0.05)); font-size: 14px; color: var(--selfsis-text, #1d1d1f); }
    .selfsis-pos-export .pos-export-row-odd { background: var(--selfsis-surface-solid, #fff); }
    .selfsis-pos-export .pos-export-row-even { background: var(--selfsis-bg, #f5f5f7); }
    .selfsis-pos-export .pos-export-row-odd:hover, .selfsis-pos-export .pos-export-row-even:hover { background: var(--selfsis-bg-hover, #e5e7eb); }
    .selfsis-pos-export .pos-export-badge { background: var(--selfsis-primary-light, rgba(171,2,9,0.1)); color: var(--selfsis-primary, #AB0209); padding: 4px 10px; border-radius: 8px; font-size: 13px; font-weight: 600; font-family: monospace; }
    .selfsis-pos-export .pos-export-matricule, .selfsis-pos-export .pos-export-nom { font-weight: 600; }
    .selfsis-pos-export .pos-export-nbre { text-align: center; color: var(--selfsis-primary, #AB0209); font-size: 1.05rem; }
    .selfsis-pos-export .selfsis-empty-message { text-align: center; padding: 48px 24px; background: var(--selfsis-bg, #f5f5f7); border-radius: 14px; border: 1px dashed var(--selfsis-border, rgba(0,0,0,0.15)); color: var(--selfsis-text-secondary, #6e6e73); }
    .selfsis-pos-export .selfsis-empty-message .material-symbols-outlined { font-size: 56px; opacity: 0.4; display: block; margin-bottom: 16px; color: var(--selfsis-primary, #AB0209); }
    .selfsis-pos-export .selfsis-empty-message p { margin: 0; font-size: 15px; }
    .selfsis-pos-export .pos-export-table-spv-section { }
    .selfsis-pos-export .pos-export-user-history-section { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .selfsis-pos-export .pos-export-user-search-form { display: flex; flex-wrap: wrap; gap: 16px; align-items: flex-end; margin-bottom: 16px; }
    .selfsis-pos-export .pos-export-search-group { position: relative; flex: 1; min-width: 200px; }
    .selfsis-pos-export .pos-export-search-wrapper { position: relative; display: flex; align-items: center; }
    .selfsis-pos-export .pos-export-search-wrapper .material-symbols-outlined { position: absolute; left: 12px; color: var(--selfsis-text-secondary, #6e6e73); font-size: 20px; pointer-events: none; }
    .selfsis-pos-export .pos-export-search-wrapper input { padding-left: 40px; width: 100%; }
    .selfsis-pos-export .pos-export-search-results { position: absolute; top: 100%; left: 0; right: 0; background: var(--selfsis-surface-solid, #fff); border: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); border-radius: 10px; margin-top: 4px; max-height: 240px; overflow-y: auto; z-index: 10; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
    .selfsis-pos-export .pos-export-search-results .pos-user-result { display: flex; align-items: center; gap: 12px; padding: 12px 16px; cursor: pointer; border-bottom: 1px solid var(--selfsis-border, rgba(0,0,0,0.05)); transition: background 0.15s; }
    .selfsis-pos-export .pos-export-search-results .pos-user-result:last-child { border-bottom: none; }
    .selfsis-pos-export .pos-export-search-results .pos-user-result:hover { background: var(--selfsis-bg-hover, #e5e7eb); }
    .selfsis-pos-export .pos-export-search-results .pos-user-result .material-symbols-outlined { color: var(--selfsis-primary, #AB0209); }
    .selfsis-pos-export .pos-selected-user-display { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--selfsis-bg, #f5f5f7); border-radius: 10px; margin-bottom: 16px; border: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .selfsis-pos-export .pos-selected-user-display .material-symbols-outlined { color: var(--selfsis-primary, #AB0209); }
    .selfsis-pos-export .pos-selected-user-display small { display: block; color: var(--selfsis-text-secondary, #6e6e73); font-size: 13px; }
    .selfsis-pos-export .pos-history-table th:nth-child(1) { width: 110px; }
    .selfsis-pos-export .pos-history-table th:nth-child(2) { width: 80px; }
    .selfsis-pos-export .pos-history-table th:nth-child(3) { width: 140px; }
    .selfsis-pos-export .pos-history-table th:nth-child(4) { width: 80px; }
    @media print { .selfsis-pos-export .pos-export-filter-form, .selfsis-pos-export .pos-export-actions, .selfsis-pos-export .pos-export-user-history-section { display: none !important; } }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-filter-form { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .pos-cat-card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .pos-cat-card:hover { border-color: var(--selfsis-primary, #AB0209); }
    html[data-theme="dark"] .selfsis-pos-export .pos-cat-card--active { background: rgba(171,2,9,0.1) !important; }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-table-card { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-table-header { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .selfsis-empty-message { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-search-results { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .pos-selected-user-display { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-cat-section { border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-cat-section-header { background: rgba(171,2,9,0.12); border-bottom-color: rgba(171,2,9,0.25); }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-cat-section--spv .pos-export-cat-section-header { background: rgba(37,99,235,0.12); }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-cat-section--ext .pos-export-cat-section-header { background: rgba(5,150,105,0.12); }
    html[data-theme="dark"] .selfsis-pos-export .pos-export-cat-section > div:last-child { background: rgba(255,255,255,0.02); }
    
    /* Lignes cliquables */
    .selfsis-pos-export .pos-export-row-clickable { cursor: pointer; transition: background 0.15s, box-shadow 0.15s; }
    .selfsis-pos-export .pos-export-row-clickable:hover { background: var(--selfsis-bg-hover, rgba(171,2,9,0.06)) !important; }
    .selfsis-pos-export .pos-export-row-clickable:active { background: rgba(171,2,9,0.12) !important; }
    
    /* Recherche inline dans les en-têtes de tableau */
    .selfsis-pos-export .pos-export-table-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
    .selfsis-pos-export .pos-table-search-inline { display: flex; align-items: center; gap: 6px; background: var(--selfsis-surface-solid, #fff); border: 1px solid var(--selfsis-border, rgba(0,0,0,0.1)); border-radius: 10px; padding: 4px 12px; flex-shrink: 0; }
    .selfsis-pos-export .pos-table-search-inline .material-symbols-outlined { font-size: 18px; color: var(--selfsis-text-secondary, #6e6e73); }
    .selfsis-pos-export .pos-table-filter-input { border: none !important; outline: none !important; padding: 6px 4px !important; font-size: 13px !important; background: transparent !important; min-width: 120px; color: var(--selfsis-text, #1d1d1f); }
    
    /* En-têtes triables */
    .selfsis-pos-export .pos-sortable { cursor: pointer; user-select: none; white-space: nowrap; transition: color 0.15s; }
    .selfsis-pos-export .pos-sortable:hover { color: var(--selfsis-primary, #AB0209); }
    .selfsis-pos-export .pos-sort-icon { font-size: 11px; opacity: 0.4; margin-left: 4px; }
    .selfsis-pos-export .pos-sortable.pos-sort-asc .pos-sort-icon { opacity: 1; }
    .selfsis-pos-export .pos-sortable.pos-sort-asc .pos-sort-icon::after { content: '▲'; }
    .selfsis-pos-export .pos-sortable.pos-sort-desc .pos-sort-icon { opacity: 1; }
    .selfsis-pos-export .pos-sortable.pos-sort-desc .pos-sort-icon::after { content: '▼'; }
    .selfsis-pos-export .pos-sortable.pos-sort-asc .pos-sort-icon,
    .selfsis-pos-export .pos-sortable.pos-sort-desc .pos-sort-icon { color: var(--selfsis-primary, #AB0209); }
    
    /* Modal détails utilisateur */
    .pos-detail-modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); z-index: 99999; display: flex; align-items: center; justify-content: center; padding: 24px; backdrop-filter: blur(4px); animation: posModalFadeIn 0.2s ease; }
    @keyframes posModalFadeIn { from { opacity: 0; } to { opacity: 1; } }
    @keyframes posModalSlideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
    .pos-detail-modal { background: var(--selfsis-surface-solid, #fff); border-radius: 18px; width: 100%; max-width: 900px; max-height: 85vh; display: flex; flex-direction: column; box-shadow: 0 24px 48px rgba(0,0,0,0.2); animation: posModalSlideUp 0.25s ease; overflow: hidden; }
    .pos-detail-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); background: var(--selfsis-bg, #f5f5f7); flex-shrink: 0; }
    .pos-detail-modal-user-info { display: flex; align-items: center; gap: 12px; }
    .pos-detail-modal-user-info .material-symbols-outlined { font-size: 32px; color: var(--selfsis-primary, #AB0209); background: rgba(171,2,9,0.1); padding: 8px; border-radius: 12px; }
    .pos-detail-modal-user-info strong { display: block; font-size: 17px; color: var(--selfsis-text, #1d1d1f); }
    .pos-detail-modal-user-info small { display: block; font-size: 13px; color: var(--selfsis-text-secondary, #6e6e73); margin-top: 2px; }
    .pos-detail-modal-body { overflow-y: auto; flex: 1; }
    .pos-detail-modal-toolbar { padding: 16px 24px; border-bottom: 1px solid var(--selfsis-border, rgba(0,0,0,0.05)); background: var(--selfsis-bg, #f5f5f7); }
    .pos-detail-modal .pos-detail-search-wrapper { display: flex; align-items: center; gap: 6px; background: var(--selfsis-surface-solid, #fff); border: 1px solid var(--selfsis-border, rgba(0,0,0,0.1)); border-radius: 10px; padding: 4px 12px; }
    .pos-detail-modal .pos-detail-search-wrapper .material-symbols-outlined { font-size: 18px; color: var(--selfsis-text-secondary, #6e6e73); }
    .pos-detail-modal .pos-detail-search-wrapper input { border: none !important; outline: none !important; padding: 8px 4px !important; font-size: 14px !important; background: transparent !important; flex: 1; color: var(--selfsis-text, #1d1d1f); }
    #pos-detail-modal-content { padding: 0; }
    #pos-detail-modal-content .pos-export-table-card { border-radius: 0; border: none; border-bottom: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    #pos-detail-modal-content .pos-detail-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 12px; padding: 16px 24px; }
    #pos-detail-modal-content .pos-detail-stat { text-align: center; padding: 12px; background: var(--selfsis-bg, #f5f5f7); border-radius: 12px; }
    #pos-detail-modal-content .pos-detail-stat-value { font-size: 1.5rem; font-weight: 700; color: var(--selfsis-primary, #AB0209); }
    #pos-detail-modal-content .pos-detail-stat-label { font-size: 12px; color: var(--selfsis-text-secondary, #6e6e73); margin-top: 2px; }
    .pos-detail-modal .pos-export-table td { font-size: 13px; padding: 10px 16px; }
    .pos-detail-modal .pos-export-table th { padding: 10px 16px; }
    
    /* Dark mode pour le modal */
    html[data-theme="dark"] .pos-detail-modal-overlay { background: rgba(0,0,0,0.7); }
    html[data-theme="dark"] .pos-detail-modal { background: var(--selfsis-surface-solid, #1a1a1a); }
    html[data-theme="dark"] .pos-detail-modal-header { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] .pos-detail-modal-toolbar { background: rgba(255,255,255,0.02); border-color: rgba(255,255,255,0.06); }
    html[data-theme="dark"] .pos-detail-modal .pos-detail-search-wrapper { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }
    html[data-theme="dark"] #pos-detail-modal-content .pos-detail-stat { background: rgba(255,255,255,0.04); }
    html[data-theme="dark"] .pos-table-search-inline { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.1); }
    
    @media (max-width: 640px) {
        .pos-detail-modal-overlay { padding: 8px; }
        .pos-detail-modal { max-height: 95vh; border-radius: 14px; }
        .pos-detail-modal-header { padding: 14px 16px; }
        #pos-detail-modal-content .pos-detail-stats { grid-template-columns: repeat(2, 1fr); padding: 12px 16px; }
    }

    /* Édition inline – cellules modifiables */
    .pos-editable-cell { display: inline-flex; align-items: center; gap: 4px; cursor: pointer; border-radius: 6px; padding: 2px 4px; transition: background 0.15s; }
    .pos-editable-cell:hover { background: rgba(171,2,9,0.08); }
    .pos-edit-icon { font-size: 14px !important; color: var(--selfsis-text-secondary, #6e6e73); opacity: 0; transition: opacity 0.15s; line-height: 1; }
    .pos-editable-cell:hover .pos-edit-icon { opacity: 1; }
    .pos-edit-select { font-size: 13px; border: 1px solid var(--selfsis-primary, #AB0209); border-radius: 6px; padding: 3px 6px; background: var(--selfsis-surface-solid, #fff); color: var(--selfsis-text, #1d1d1f); outline: none; cursor: pointer; }
    .pos-edit-success { animation: posEditFlash 0.6s ease; }
    @keyframes posEditFlash { 0% { background: rgba(34,197,94,0.2); } 100% { background: transparent; } }
    @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
    .pos-edit-spinner { display: inline-block; color: var(--selfsis-primary, #AB0209); }
    html[data-theme="dark"] .pos-edit-select { background: rgba(255,255,255,0.08); color: #f5f5f7; }

    /* Journal des modifications */
    .pos-edit-log-section { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--selfsis-border, rgba(0,0,0,0.08)); }
    .pos-edit-log-card .pos-export-table { min-width: 900px; }
    .pos-log-val { display: inline-block; padding: 3px 8px; border-radius: 6px; font-size: 13px; font-weight: 600; }
    .pos-log-val--old { background: rgba(239,68,68,0.1); color: #dc2626; text-decoration: line-through; }
    .pos-log-val--new { background: rgba(34,197,94,0.12); color: #16a34a; }
    html[data-theme="dark"] .pos-log-val--old { background: rgba(239,68,68,0.2); color: #f87171; }
    html[data-theme="dark"] .pos-log-val--new { background: rgba(34,197,94,0.2); color: #4ade80; }

/* ===== RH Export - accordéon ===== */
        /* ── Accordéon "En attente" ───────────────────────────────────── */
        .rh-export-section--attente { padding: 0 !important; border-radius: 10px; overflow: hidden; border: 1px solid #E5E7EB !important; }
        .rh-attente-accordion { border-bottom: none !important; }
        .rh-attente-trigger {
            display: flex; align-items: center; justify-content: space-between;
            width: 100%; padding: 14px 18px;
            background: #F9FAFB; border: none; cursor: pointer;
            text-align: left; gap: 12px; transition: background 0.15s;
        }
        .rh-attente-trigger:hover { background: #F3F4F6; }
        .rh-attente-trigger[aria-expanded="true"] { background: #FEF2F2; }
        .rh-attente-trigger__left { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
        .rh-attente-trigger__icon { font-size: 20px; color: #DC2626; flex-shrink: 0; }
        .rh-attente-trigger__label { font-size: 0.95rem; font-weight: 600; color: #374151; }
        .rh-attente-trigger__chevron {
            font-size: 20px; color: #6B7280; flex-shrink: 0;
            transition: transform 0.25s ease;
        }
        .rh-attente-trigger[aria-expanded="true"] .rh-attente-trigger__chevron { transform: rotate(180deg); }
        .rh-attente-body {
            padding: 20px 18px;
            animation: rh-attente-open 0.2s ease;
        }
        .rh-attente-body[hidden] { display: none; }
        @keyframes rh-attente-open { from { opacity:0; transform: translateY(-6px); } to { opacity:1; transform: translateY(0); } }
        .rh-attente-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
        .rh-attente-badge--ok { background: #D1FAE5 !important; color: #065f46 !important; font-size: 0.7rem !important; }
        /* ─────────────────────────────────────────────────────────────── */
        .rh-attente__title { font-size: 1.1rem; }
        .rh-attente-header-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
        .rh-attente-badge {
            display: inline-flex; align-items: center; justify-content: center;
            background: #DC2626; color: #fff;
            font-size: 0.75rem; font-weight: 700;
            min-width: 22px; height: 22px; padding: 0 6px;
            border-radius: 99px; margin-left: 8px; vertical-align: middle;
        }
        .rh-attente-export-btn {
            display: inline-flex; align-items: center; gap: 6px;
            padding: 8px 16px; border-radius: 8px;
            background: #1e40af; color: #fff;
            border: none; cursor: pointer; font-size: 0.875rem; font-weight: 600;
            white-space: nowrap; flex-shrink: 0; transition: background 0.15s;
        }
        .rh-attente-export-btn:hover { background: #1d3a9e; }
        .rh-attente-export-btn:disabled { opacity: 0.6; cursor: not-allowed; }
        .rh-attente-export-btn .material-symbols-outlined { font-size: 18px; }
        .rh-attente-empty {
            display: flex; align-items: center; gap: 10px;
            padding: 16px 20px; background: #F0FDF4; border-radius: 10px;
            border: 1px solid #BBF7D0; color: #166534; font-size: 0.95rem;
        }
        .rh-attente-empty .material-symbols-outlined { font-size: 24px; color: #16a34a; }
        .rh-attente-group { margin-bottom: 20px; }
        .rh-attente-group:last-child { margin-bottom: 0; }
        .rh-attente-group__header {
            display: flex; align-items: center; gap: 6px;
            font-size: 0.85rem; font-weight: 600; color: #374151;
            margin-bottom: 8px;
        }
        .rh-attente-group__header .material-symbols-outlined { font-size: 18px; color: #6B7280; }
        .rh-attente-count {
            display: inline-flex; align-items: center; justify-content: center;
            background: #FEE2E2; color: #DC2626;
            font-size: 0.72rem; font-weight: 700;
            min-width: 20px; height: 20px; padding: 0 5px;
            border-radius: 99px; margin-left: 4px;
        }
        .rh-attente-table-wrap { overflow-x: auto; border-radius: 8px; border: 1px solid #E5E7EB; }
        .rh-attente-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
        .rh-attente-table thead tr { background: #F9FAFB; }
        .rh-attente-table th {
            padding: 9px 12px; text-align: left;
            font-weight: 600; color: #6B7280; font-size: 0.75rem;
            text-transform: uppercase; letter-spacing: 0.04em;
            border-bottom: 1px solid #E5E7EB;
        }
        .rh-attente-table td {
            padding: 9px 12px; color: #374151;
            border-bottom: 1px solid #F3F4F6; white-space: nowrap;
        }
        .rh-attente-table tbody tr:last-child td { border-bottom: none; }
        .rh-attente-table tbody tr:hover td { background: #FFF7F7; }
        .rh-attente-table code {
            background: #F3F4F6; padding: 2px 6px;
            border-radius: 4px; font-size: 0.8rem; color: #4B5563;
        }
        .rh-attente-sp {
            display: inline-block; padding: 2px 7px; border-radius: 4px;
            font-size: 0.75rem; font-weight: 700; margin-right: 3px;
        }
        .rh-attente-sp--spp       { background: #DBEAFE; color: #1d4ed8; }
        .rh-attente-sp--spv       { background: #D1FAE5; color: #065f46; }
        .rh-attente-sp--pats      { background: #FEF3C7; color: #92400e; }
        .rh-attente-sp--formation { background: #EDE9FE; color: #5b21b6; max-width: 220px; white-space: normal; line-height: 1.3; }
        .mysis-attente-resa-badge {
            display: inline-flex; align-items: center; gap: 3px;
            padding: 3px 8px; border-radius: 5px;
            font-size: 0.75rem; font-weight: 600; white-space: nowrap;
        }
        .mysis-attente-resa-badge--dec { background: #FEE2E2; color: #DC2626; }
        .mysis-attente-resa-badge--mdc { background: #FEF3C7; color: #D97706; }
        .rh-attente-action-cell { text-align: center; width: 110px; }
        .rh-attente-valider-wrap { display: flex; align-items: center; gap: 4px; }
        .rh-attente-statut-select {
            padding: 4px 6px; border: 1px solid #E5E7EB; border-radius: 6px;
            font-size: 0.78rem; font-weight: 600; background: #fff; color: #374151;
            max-width: 72px;
        }
        .rh-attente-valider-btn {
            display: inline-flex; align-items: center; gap: 4px;
            padding: 5px 10px; border-radius: 7px;
            background: #16a34a; color: #fff;
            border: none; cursor: pointer; font-size: 0.8rem; font-weight: 600;
            white-space: nowrap; transition: background 0.15s;
        }
        .rh-attente-valider-btn:hover:not(:disabled) { background: #15803d; }
        .rh-attente-valider-btn:disabled { opacity: 0.55; cursor: not-allowed; }
        .rh-attente-valider-btn .material-symbols-outlined { font-size: 16px; }
        .rh-attente-row--validating td { opacity: 0.5; pointer-events: none; }
        .rh-attente-count--group { background: #FEE2E2; color: #DC2626; }

/* ===== RH Export center ===== */
    .rh-export-center { max-width: 100%; }
    .rh-export-center__intro { margin-bottom: 28px; }
    .rh-export-center__title { display: flex; align-items: center; gap: 10px; font-size: 1.35rem; font-weight: 700; color: #1d1d1f; margin: 0 0 6px 0; }
    .rh-export-center__title .material-symbols-outlined { color: var(--selfsis-primary, #AB0209); font-size: 28px; }
    .rh-export-center__desc { color: #6e6e73; font-size: 0.95rem; margin: 0; }
    .rh-export-section { margin-bottom: 36px; padding-bottom: 36px; border-bottom: 1px solid rgba(0,0,0,0.08); }
    .rh-export-section:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
    .rh-export-section--participants { padding-top: 24px; }
    .rh-export-section__header { margin-bottom: 20px; }
    .rh-export-section__title { display: flex; align-items: center; gap: 8px; font-size: 1.1rem; font-weight: 600; color: #1d1d1f; margin: 0 0 6px 0; }
    .rh-export-section__title .material-symbols-outlined { color: #1e40af; font-size: 22px; }
    .rh-export-section__desc { color: #6e6e73; font-size: 0.9rem; margin: 0; }
    .rh-export-participants-form { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 16px; }
    .rh-export-field-row { display: flex; flex-wrap: wrap; gap: 16px; flex: 1; min-width: 200px; }
    .rh-export-field { flex: 1; min-width: 180px; }
    .rh-export-field label { display: block; font-size: 0.75rem; font-weight: 600; color: #374151; margin-bottom: 4px; }
    .rh-export-select { width: 100%; padding: 10px 12px; border: 2px solid #e5e7eb; border-radius: 8px; font-size: 0.95rem; background: #fff; }
    .rh-export-preview { margin-top: 12px; padding: 12px; background: #f0fdf4; border-radius: 8px; border: 1px solid #bbf7d0; }
    .rh-export-preview__count { margin: 0; font-size: 0.9rem; color: #166534; }

/* ===== Mes repas - onglets ===== */
    .mes-repas-tab:hover {
        color: #AB0209;
    }
    .mes-repas-tab.active {
        border-bottom-color: #AB0209 !important;
        color: #AB0209 !important;
    }
    .date-option:has(input:checked),
    .plat-option:has(input:checked) {
        border-color: #AB0209 !important;
        background: #fef2f2;
    }
    .date-option:hover:not(:has(input:disabled)),
    .plat-option:hover {
        border-color: #AB0209;
    }
    label:has(input[name="type_repas"]:checked) {
        border-color: #AB0209 !important;
        background: #fef2f2;
    }
    .filter-btn.active {
        background: #AB0209 !important;
        color: white !important;
    }
    #btn-reserver:hover {
        transform: translateY(-2px);
        box-shadow: 0 6px 16px rgba(171,2,9,0.4);
    }
    #btn-reserver:disabled {
        opacity: 0.6;
        cursor: not-allowed;
        transform: none;
    }
    @keyframes spin {
        from { transform: rotate(0deg); }
        to { transform: rotate(360deg); }
    }

/* ===== Décompte - modale statut ===== */
    #mysis-cs-overlay {
        position: fixed; inset: 0;
        background: rgba(0,0,0,0.72);
        z-index: 2147483640;
        backdrop-filter: blur(3px);
        -webkit-backdrop-filter: blur(3px);
    }
    #mysis-cs-modal {
        position: fixed;
        top: 50%; left: 50%;
        transform: translate(-50%, -50%);
        z-index: 2147483646;
        background: #fff;
        border-radius: 18px;
        padding: 32px;
        max-width: 520px;
        width: calc(100% - 32px);
        box-shadow: 0 28px 80px rgba(0,0,0,0.4);
        max-height: 88vh;
        overflow-y: auto;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    }
    .mysis-cs-btn {
        padding: 10px 20px;
        border: 2px solid #e5e7eb;
        border-radius: 9px;
        background: #fff;
        cursor: pointer;
        font-weight: 700;
        color: #374151;
        font-size: 0.9rem;
        transition: border-color 0.18s, background 0.18s, color 0.18s;
        line-height: 1.3;
    }
    .mysis-cs-btn:hover:not(:disabled) {
        border-color: #AB0209;
        background: #fef2f2;
        color: #AB0209;
    }
    .mysis-cs-btn:disabled { opacity: 0.55; cursor: not-allowed; }
    .mysis-cs-btn.done {
        border-color: #22c55e !important;
        background: #dcfce7 !important;
        color: #15803d !important;
    }
