: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-bg-secondary: #f8f9fa;
      --mysis-text-primary: #1a1a1a;
      --mysis-text-secondary: #374151;
      --mysis-text-tertiary: #6B7280;
    }
    /* Mode Dark pour mysis-interface */
    html[data-theme="dark"] {
      --mysis-primary-light: rgba(171, 2, 9, 0.2);
      --mysis-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
      --mysis-shadow-md: 0 6px 12px rgba(0, 0, 0, 0.4);
      --mysis-shadow-lg: 0 12px 24px rgba(0, 0, 0, 0.5);
      --mysis-border: #374151;
      --mysis-bg-card: #1a1a1a;
      --mysis-bg-secondary: #252525;
      --mysis-text-primary: #f5f5f5;
      --mysis-text-secondary: #d1d5db;
      --mysis-text-tertiary: #9ca3af;
    }
    /* Mode Auto qui suit les préférences système */
    @media (prefers-color-scheme: dark) {
      html:not([data-theme="light"]):not([data-theme="dark"]) {
        --mysis-primary-light: rgba(171, 2, 9, 0.2);
        --mysis-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);
        --mysis-shadow-md: 0 6px 12px rgba(0, 0, 0, 0.4);
        --mysis-shadow-lg: 0 12px 24px rgba(0, 0, 0, 0.5);
        --mysis-border: #374151;
        --mysis-bg-card: #1a1a1a;
        --mysis-bg-secondary: #252525;
        --mysis-text-primary: #f5f5f5;
        --mysis-text-secondary: #d1d5db;
        --mysis-text-tertiary: #9ca3af;
      }
    }
    /* ========= OPTIMISATIONS PWA ========= */
    
    /* Support des safe areas pour iOS (notch, barres système) */
    /* IMPORTANT: Ne PAS appliquer padding-top au body - chaque header gère sa propre safe-area */
    /* Cela évite le double padding (body + header) qui créait un espace blanc */
    
    /* Styles de base - paddings latéraux uniquement */
    @supports (padding: max(0px)) {
      .mysis-profil-tabs-nav,
      .mysis-tabs-nav {
        padding-left: max(12px, env(safe-area-inset-left));
        padding-right: max(12px, env(safe-area-inset-right));
      }
    }
    
    /* Styles spécifiques pour le mode standalone PWA uniquement */
    @media (display-mode: standalone) {
      /* Safe areas latéraux et bottom uniquement - PAS de padding-top sur body */
      body {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
        /* padding-top géré par chaque header individuellement */
        padding-bottom: env(safe-area-inset-bottom);
      }
      
      .mysis-modal-overlay {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
        padding-top: env(safe-area-inset-top);
        padding-bottom: env(safe-area-inset-bottom);
      }
      
      /* Ajustements pour l'interface sans barre d'adresse */
      .mysis-tabs-nav {
        top: env(safe-area-inset-top, 0px);
      }
    }
    
    /* Support via classes JS pour iOS PWA */
    body.pwa-standalone,
    body.ios-pwa-standalone {
      padding-left: env(safe-area-inset-left);
      padding-right: env(safe-area-inset-right);
      /* padding-top géré par chaque header individuellement */
      padding-bottom: env(safe-area-inset-bottom);
    }
    
    body.pwa-standalone .mysis-modal-overlay,
    body.ios-pwa-standalone .mysis-modal-overlay {
      padding-left: env(safe-area-inset-left);
      padding-right: env(safe-area-inset-right);
      padding-top: env(safe-area-inset-top);
      padding-bottom: env(safe-area-inset-bottom);
    }
    
    /* Headers sticky avec support safe areas pour PWA */
    /* S'applique uniquement en mode standalone PWA pour éviter les conflits */
    @media (display-mode: standalone) {
      .mysis-formation-sticky-header,
      .dycast-messagerie-sticky-header,
      .mysis-profil-sticky-header {
        padding-top: max(10px, env(safe-area-inset-top, 10px)) !important;
        padding-bottom: env(safe-area-inset-bottom, 0) !important;
      }
      
      /* Ajustement du top uniquement en mode standalone */
      @supports (padding: max(0px)) {
        .mysis-formation-sticky-header,
        .dycast-messagerie-sticky-header,
        .mysis-profil-sticky-header {
          top: env(safe-area-inset-top, 0px) !important;
        }
      }
    }
    
    /* Support pour les classes body ajoutées par JavaScript */
    body.pwa-standalone .mysis-formation-sticky-header,
    body.pwa-standalone .dycast-messagerie-sticky-header,
    body.pwa-standalone .mysis-profil-sticky-header,
    body.ios-pwa-standalone .mysis-formation-sticky-header,
    body.ios-pwa-standalone .dycast-messagerie-sticky-header,
    body.ios-pwa-standalone .mysis-profil-sticky-header {
      padding-top: max(10px, env(safe-area-inset-top, 10px)) !important;
      padding-bottom: env(safe-area-inset-bottom, 0) !important;
    }
    
    @supports (padding: max(0px)) {
      body.pwa-standalone .mysis-formation-sticky-header,
      body.pwa-standalone .dycast-messagerie-sticky-header,
      body.pwa-standalone .mysis-profil-sticky-header,
      body.ios-pwa-standalone .mysis-formation-sticky-header,
      body.ios-pwa-standalone .dycast-messagerie-sticky-header,
      body.ios-pwa-standalone .mysis-profil-sticky-header {
        top: env(safe-area-inset-top, 0px) !important;
      }
    }
    
    /* Éviter les débordements horizontaux */
    .mysis-tabs,
    .mysis-tabs-profil,
    .mysis-tab-panel,
    .mysis-infos-container,
    .mysis-info-cards-grid,
    .mysis-info-card {
      box-sizing: border-box;
    }
    .info-utilisateur {
      font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
      line-height: 1.5;
    }
    .info-utilisateur .grade-texte {
      font-weight: 700;
      color: #2C2C2C;
      font-size: 1.1rem;
    }
    .info-utilisateur .nom-texte {
      font-weight: 800;
      color: var(--mysis-primary);
      font-size: 1.3rem;
    }

    /* Cache tous les boutons submit ACF par défaut (on utilise notre bouton custom) */
    .mysis-profile-form .acf-form-submit {
      display: none !important;
    }
    /* Masquer TOUS les boutons submit ACF (on garde uniquement .mysis-primary) */
    .mysis-profile-form input[type="submit"],
    .mysis-profile-form .acf-form-submit,
    .mysis-profile-form button[type="submit"]:not(.mysis-primary),
    .acf-form .acf-form-submit,
    .acf-form .acf-form-submit input,
    .acf-form .acf-form-submit button:not(.mysis-primary),
    form.acf-form input[type="submit"]:not(.mysis-primary),
    form.acf-form button[type="submit"]:not(.mysis-primary),
    .acf-button.button.button-primary.button-large,
    input.acf-button.button.button-primary.button-large,
    .acf-form input.acf-button,
    .acf-form button.acf-button:not(.mysis-primary) {
      display: none !important;
      visibility: hidden !important;
      opacity: 0 !important;
      position: absolute !important;
      left: -9999px !important;
      pointer-events: none !important;
      width: 0 !important;
      height: 0 !important;
      overflow: hidden !important;
    }
    /* Styles du wrapper du bouton submit */
    .mysis-submit-wrapper {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 12px;
    }
    .mysis-submit-wrapper button.mysis-primary {
      -webkit-tap-highlight-color: rgba(171, 2, 9, 0.3);
      touch-action: manipulation;
      user-select: none;
      -webkit-user-select: none;
      position: relative;
    }
    .mysis-submit-wrapper button.mysis-primary * {
      pointer-events: none;
    }
    .mysis-submit-wrapper .acf-spinner {
      float: none !important;
      margin: 0 !important;
      visibility: visible !important;
      background: none !important;
    }
    .mysis-submit-wrapper .acf-spinner::before {
      border-color: var(--mysis-primary) transparent transparent transparent !important;
    }
    /* Etat du bouton pendant enregistrement */
    .mysis-primary:disabled {
      opacity: 0.7 !important;
      cursor: wait !important;
    }
    /* Messages de confirmation/erreur AJAX (sans rechargement) */
    .mysis-ajax-message {
      display: flex;
      align-items: center;
      gap: 16px;
      padding: 16px 20px;
      margin: 20px 0;
      border-radius: var(--mysis-radius);
      box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
      animation: mysis-message-slide-in 0.4s cubic-bezier(0.16, 1, 0.3, 1);
      transition: opacity 0.3s ease-out, transform 0.3s 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;
      font-size: 1rem;
      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;
      font-size: 1rem;
      margin: 0;
    }
    .mysis-ajax-message-fade {
      opacity: 0;
      transform: translateY(-10px);
    }
    @keyframes mysis-message-slide-in {
      from {
        opacity: 0;
        transform: translateY(-20px) scale(0.95);
      }
      to {
        opacity: 1;
        transform: translateY(0) scale(1);
      }
    }
    /* Message WordPress natif (si rechargement) */
    #message.updated {
      background: #D1FAE5 !important;
      border-left: 4px solid #10B981 !important;
      border-radius: 10px !important;
      padding: 16px 20px 16px 56px !important;
      margin: 20px 0 !important;
      box-shadow: 0 4px 12px rgba(16, 185, 129, 0.15) !important;
      position: relative !important;
    }
    #message.updated::before {
      content: "check_circle";
      font-family: "Material Icons" !important;
      font-size: 24px !important;
      color: #10B981 !important;
      position: absolute;
      left: 20px;
      top: 50%;
      transform: translateY(-50%);
    }
    #message.updated p {
      color: #065F46 !important;
      font-weight: 600 !important;
      font-size: 1rem !important;
      margin: 0 !important;
    }

    /* Boutons charte modernisés */
    .button, .acf-button, .mysis-primary {
      background: var(--mysis-primary) !important;
      color: #fff !important;
      border: none !important;
      border-radius: 10px !important;
      padding: 12px 18px !important;
      font-weight: 700 !important;
      box-shadow: var(--mysis-shadow-md) !important;
      transition: var(--mysis-transition) !important;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
    }
    .button:hover, .acf-button:hover, .mysis-primary:hover {
      background: var(--mysis-primary-hover) !important;
      box-shadow: var(--mysis-shadow-lg) !important;
      transform: translateY(-2px);
    }
    .button:focus, .acf-button:focus, .mysis-primary:focus {
      outline: none !important;
      box-shadow: var(--mysis-ring) !important;
    }
    .button:active, .acf-button:active, .mysis-primary:active {
      transform: translateY(0);
    }
    /* Boutons noirs (secondaires) */
    .button[style*="background: #000"] {
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
    }
    .button[style*="background: #000"]:hover {
      background: #1a1a1a !important;
      box-shadow: 0 6px 16px rgba(0, 0, 0, 0.4) !important;
    }

    /* Inputs ACF modernisés */
    .mysis-tab-panel .acf-input input[type=text],
    .mysis-tab-panel .acf-input input[type=email],
    .mysis-tab-panel .acf-input input[type=number],
    .mysis-tab-panel .acf-input input[type=tel],
    .mysis-tab-panel .acf-input input[type=password],
    .mysis-tab-panel .acf-input textarea,
    .mysis-tab-panel .acf-input select {
      width: 100%;
      border: 2px solid #e9ecef;
      border-radius: 10px;
      padding: 14px 16px;
      box-shadow: none;
      outline: none;
      transition: all 0.3s ease;
      font-size: 15px;
      font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      font-weight: 500;
      color: #333;
      background: #fff;
    }
    .mysis-tab-panel .acf-input input::placeholder,
    .mysis-tab-panel .acf-input textarea::placeholder {
      color: #9CA3AF;
      font-weight: 400;
    }
    .mysis-tab-panel .acf-input input:focus,
    .mysis-tab-panel .acf-input textarea:focus,
    .mysis-tab-panel .acf-input select:focus {
      outline: none;
      border-color: var(--mysis-primary);
      box-shadow: 0 0 0 3px var(--mysis-primary-light);
      background: #fff;
    }
    .mysis-tab-panel .acf-input input:hover,
    .mysis-tab-panel .acf-input textarea:hover,
    .mysis-tab-panel .acf-input select:hover {
      border-color: #dee2e6;
    }
    /* Inputs en lecture seule */
    .mysis-tab-panel .acf-input input:disabled,
    .mysis-tab-panel .acf-input input:read-only {
      background: #f8f9fa;
      color: #6B7280;
      cursor: not-allowed;
    }

    /* Reset complet des styles ACF - Style moderne personnalisé */
    .mysis-tab-panel .acf-fields,
    .mysis-tab-panel .acf-field,
    .mysis-tab-panel .acf-label,
    .mysis-tab-panel .acf-input,
    .mysis-tab-panel .acf-field-group {
      all: unset !important;
      display: block !important;
    }
    .mysis-tab-panel .acf-fields {
      background: transparent;
      border: none;
      border-radius: 0;
      padding: 0;
      box-shadow: none;
    }
    .mysis-tab-panel .acf-field {
      background: #fff;
      border: 2px solid #e9ecef;
      border-radius: var(--mysis-radius);
      padding: 20px;
      margin-bottom: 20px;
      box-shadow: 0 2px 8px rgba(0,0,0,0.05);
      transition: all 0.3s ease;
    }
    .mysis-tab-panel .acf-field:hover {
      box-shadow: 0 4px 12px rgba(0,0,0,0.08);
      border-color: #dee2e6;
    }

    .mysis-tab-panel .acf-field .acf-label {
      margin-bottom: 12px;
      padding-bottom: 12px;
      border-bottom: 2px solid #f0f0f0;
    }
    .mysis-tab-panel .acf-field .acf-label label {
      font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      font-size: 16px;
      font-weight: 700;
      color: #333;
      display: flex;
      align-items: center;
      gap: 8px;
      margin: 0;
    }
    .mysis-tab-panel .acf-field .acf-label label::before {
      content: '';
      font-family: 'Material Symbols Outlined';
      font-size: 22px;
      color: var(--mysis-primary);
      display: inline-block;
      vertical-align: middle;
    }
    /* Icônes personnalisées par type de champ */
    .mysis-tab-panel .acf-field[data-name="first_name"] .acf-label label::before {
      content: 'badge';
      font-size: 24px;
    }
    .mysis-tab-panel .acf-field[data-name="last_name"] .acf-label label::before {
      content: 'person';
      font-size: 24px;
    }
    .mysis-tab-panel .acf-field[data-name="user_email"] .acf-label label::before {
      content: 'email';
    }
    /* Icônes dynamiques pour les champs ACF - gérées via CSS inline dans PHP */
    /* Instructions des champs */
    .mysis-tab-panel .acf-field .acf-label .description {
      font-size: 13px;
      color: #6B7280;
      font-weight: 400;
      margin-top: 4px;
      line-height: 1.5;
    }
    /* Textarea spécifique */
    .mysis-tab-panel .acf-input textarea {
      min-height: 100px;
      resize: vertical;
      line-height: 1.6;
    }
    /* Select spécifique */
    .mysis-tab-panel .acf-input select {
      cursor: pointer;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23AB0209' d='M10.293 3.293L6 7.586 1.707 3.293A1 1 0 00.293 4.707l5 5a1 1 0 001.414 0l5-5a1 1 0 10-1.414-1.414z'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 12px center;
      padding-right: 40px;
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
    }
    /* Checkboxes et radios modernes */
    .mysis-tab-panel .acf-checkbox-list label,
    .mysis-tab-panel .acf-radio-list label {
      display: flex !important;
      align-items: center;
      gap: 12px;
      padding: 14px 16px;
      background: #fff;
      border: 2px solid #e9ecef;
      border-radius: 10px;
      cursor: pointer;
      transition: all 0.2s ease;
      margin-bottom: 10px;
      font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
      font-weight: 600 !important;
      color: #374151 !important;
      font-size: 14px !important;
    }
    .mysis-tab-panel .acf-checkbox-list label:hover,
    .mysis-tab-panel .acf-radio-list label:hover {
      border-color: var(--mysis-primary);
      background: rgba(171, 2, 9, 0.05);
    }
    .mysis-tab-panel .acf-checkbox-list label:has(input:checked),
    .mysis-tab-panel .acf-radio-list label:has(input:checked) {
      border-color: var(--mysis-primary) !important;
      background: var(--mysis-primary-light) !important;
      color: var(--mysis-primary) !important;
      box-shadow: 0 2px 8px rgba(171, 2, 9, 0.15);
    }
    .mysis-tab-panel .acf-checkbox-list input[type="checkbox"],
    .mysis-tab-panel .acf-radio-list input[type="radio"] {
      width: 22px !important;
      height: 22px !important;
      margin: 0 !important;
      flex-shrink: 0;
      cursor: pointer;
      accent-color: var(--mysis-primary);
    }
    /* Listes ACF */
    .mysis-tab-panel .acf-checkbox-list,
    .mysis-tab-panel .acf-radio-list {
      display: flex;
      flex-direction: column;
      gap: 0;
    }
    .mysis-tab-panel .acf-checkbox-list li,
    .mysis-tab-panel .acf-radio-list li {
      margin: 0 !important;
      list-style: none !important;
    }
    .mysis-tab-panel .acf-checkbox-list ul,
    .mysis-tab-panel .acf-radio-list ul {
      margin: 0 !important;
      padding: 0 !important;
    }
    /* Image uploader ACF */
    .mysis-tab-panel .acf-image-uploader {
      text-align: center;
    }
    .mysis-tab-panel .acf-image-uploader .image-wrap {
      border: 2px solid #e9ecef;
      border-radius: var(--mysis-radius);
      overflow: hidden;
      display: inline-block;
      box-shadow: 0 2px 8px rgba(0,0,0,0.1);
      transition: all 0.3s ease;
    }
    .mysis-tab-panel .acf-image-uploader .image-wrap:hover {
      box-shadow: 0 4px 16px rgba(0,0,0,0.15);
      border-color: var(--mysis-primary);
    }
    .mysis-tab-panel .acf-image-uploader img {
      display: block;
      max-width: 200px;
      height: auto;
    }
    .mysis-tab-panel .acf-image-uploader .acf-button {
      margin-top: 12px !important;
      background: var(--mysis-primary) !important;
      color: white !important;
      border: none !important;
      padding: 10px 20px !important;
      border-radius: 8px !important;
      font-weight: 600 !important;
      font-family: 'Outfit', sans-serif !important;
      cursor: pointer;
      transition: all 0.2s ease;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .mysis-tab-panel .acf-image-uploader .acf-button:hover {
      background: var(--mysis-primary-hover) !important;
      transform: translateY(-2px);
      box-shadow: 0 4px 12px rgba(171, 2, 9, 0.3) !important;
    }

    /* Onglets – mobile: nav dans header ; desktop: nav à gauche */
    .mysis-tabs {
      margin: 0;
      padding-top: 16px;
    }
    /* Navigation des onglets du profil intégrée dans le header */
    .mysis-profil-tabs-nav {
      display: flex;
      gap: 8px;
      background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
      padding: 12px;
      border-radius: 0;
      border-bottom: 3px solid var(--mysis-primary);
      overflow-x: auto;
      overflow-y: hidden;
      scrollbar-width: thin;
      scrollbar-color: var(--mysis-primary) #f1f1f1;
      transition: all 0.3s ease;
    }
    /* Styles scrollbar communs pour les navigations d'onglets */
    .mysis-profil-tabs-nav::-webkit-scrollbar,
    .mysis-tabs-nav::-webkit-scrollbar {
      height: 6px;
    }
    
    .mysis-profil-tabs-nav::-webkit-scrollbar-track,
    .mysis-tabs-nav::-webkit-scrollbar-track {
      background: #f1f1f1;
      border-radius: 10px;
    }
    
    .mysis-profil-tabs-nav::-webkit-scrollbar-thumb,
    .mysis-tabs-nav::-webkit-scrollbar-thumb {
      background: var(--mysis-primary);
      border-radius: 10px;
    }
    .mysis-profil-tabs-nav .mysis-tab-btn {
      flex: 0 0 auto;
      white-space: nowrap;
    }
    /* Conteneur des panels */
    .mysis-tabs-panels {
      width: 100%;
      max-width: 100%;
      overflow-x: hidden;
    }
    /* Éviter le débordement du contenu */
    .mysis-tab-panel {
      max-width: 100%;
      overflow-x: hidden;
    }
    .mysis-tabs-nav {
      display: flex;
      gap: 10px;
      flex-wrap: nowrap;
      overflow-x: auto;
      overflow-y: hidden;
      scrollbar-width: thin;
      scrollbar-color: var(--mysis-primary) #f1f1f1;
      position: sticky;
      top: 0;
      z-index: 1000;
    }
    
    .mysis-tab-btn {
      appearance: none;
      border: 2px solid #e9ecef;
      background: #fff;
      border-radius: var(--mysis-radius);
      padding: 14px 20px;
      cursor: pointer;
      font-weight: 700;
      transition: all 0.3s ease;
      font-size: 15px;
      font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      color: #374151;
      box-shadow: 0 2px 5px rgba(0,0,0,0.05);
      position: relative;
      overflow: hidden;
      display: flex;
      align-items: center;
      gap: 8px;
      justify-content: flex-start;
      flex: 0 0 auto;
      white-space: nowrap;
    }
    .mysis-tab-btn .material-icons,
    .mysis-tab-btn .material-symbols-outlined {
      color: #6B7280;
      transition: all 0.3s ease;
      flex-shrink: 0;
    }
    .mysis-tab-btn::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: linear-gradient(135deg, var(--mysis-primary) 0%, var(--mysis-primary-hover) 100%);
      opacity: 0;
      transition: opacity 0.3s ease;
      z-index: 0;
    }
    .mysis-tab-btn span {
      position: relative;
      z-index: 1;
    }
    .mysis-tab-btn:hover {
      border-color: var(--mysis-primary);
      transform: translateY(-2px);
      box-shadow: 0 4px 12px var(--mysis-ring);
    }
    .mysis-tab-btn[aria-selected=true] {
      border-color: var(--mysis-primary);
      color: #fff;
      background: linear-gradient(135deg, var(--mysis-primary) 0%, var(--mysis-primary-hover) 100%);
      box-shadow: 0 4px 15px rgba(171, 2, 9, 0.3);
      transform: translateY(-2px);
    }
    .mysis-tab-btn[aria-selected=true] .material-icons,
    .mysis-tab-btn[aria-selected=true] .material-symbols-outlined {
      color: #fff;
    }
    .mysis-tab-btn[aria-selected=true]::before {
      opacity: 1;
    }
    .mysis-tab-btn:hover .material-icons,
    .mysis-tab-btn:hover .material-symbols-outlined {
      color: var(--mysis-primary);
      transform: scale(1.1);
    }
    .mysis-tab-btn[aria-selected=true]:hover .material-icons,
    .mysis-tab-btn[aria-selected=true]:hover .material-symbols-outlined {
      color: #fff;
    }

    /* Contenu des panels */
    .mysis-tab-panel {
      animation: fadeInTab 0.4s ease-in-out;
    }
    @keyframes fadeInTab {
      from {
        opacity: 0;
        transform: translateY(10px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    /* Grille pour Mes infos */
    .mysis-tab-panel#tab-infos .acf-fields {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
      gap: 20px;
    }
    /* ========= NOUVELLE PRÉSENTATION MODE LECTURE/ÉDITION ========= */
    /* Container principal 30% / 70% */
    .mysis-infos-container {
      display: grid;
      grid-template-columns: 30% 70%;
      gap: 32px;
      align-items: start;
      max-width: 100%;
      overflow-x: hidden;
    }
    /* Colonne photo (30%) - sticky */
    .mysis-infos-photo-column {
      position: sticky;
      top: 20px;
      align-self: start;
    }
    .mysis-photo-card {
      background: linear-gradient(135deg, #fff 0%, #f8f9fa 100%);
      border: 3px solid #e9ecef;
      border-radius: 16px;
      padding: 24px;
      text-align: center;
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
      transition: all 0.3s ease;
    }
    .mysis-photo-card:hover {
      box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
      transform: translateY(-2px);
    }
    /* Mode lecture */
    .mysis-infos-read-mode {
      max-width: 100%;
      overflow-x: hidden;
    }
    /* Cartes d'information en mode lecture */
    .mysis-info-cards-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 16px;
      max-width: 100%;
    }
    .mysis-info-card {
      background: white;
      border: 2px solid #e9ecef;
      border-radius: var(--mysis-radius);
      padding: 20px;
      transition: all 0.2s ease;
      max-width: 100%;
      overflow-x: hidden;
    }
    .mysis-info-card:hover {
      border-color: #d1d5db;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
      transform: translateY(-2px);
    }
    /* Mode édition - styles ACF */
    .mysis-infos-edit-mode {
      max-width: 100%;
      overflow-x: hidden;
    }
    .mysis-infos-edit-mode .acf-fields {
      display: block;
      max-width: 100%;
    }
    .mysis-infos-edit-mode .acf-field {
      margin-bottom: 20px;
      max-width: 100%;
      box-sizing: border-box;
    }
    /* Image du grade dans la carte */
    .mysis-info-card img {
      max-width: 60px;
      height: auto;
      flex-shrink: 0;
    }
    /* Photo de profil ne doit jamais dépasser */
    .mysis-photo-card img {
      max-width: 100%;
      height: auto;
      display: block;
    }
    /* Badges statuts et affectations */
    .mysis-badge-statut {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 14px;
      background: linear-gradient(135deg, var(--mysis-primary) 0%, var(--mysis-primary-hover) 100%);
      color: white;
      border-radius: 8px;
      font-size: 0.9rem;
      font-weight: 600;
      box-shadow: 0 2px 8px var(--mysis-ring);
      transition: all 0.2s ease;
    }
    .mysis-badge-statut:hover {
      transform: translateY(-2px);
      box-shadow: 0 4px 12px rgba(171, 2, 9, 0.3);
    }
    .mysis-badge-affectation {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 14px;
      background: #F3F4F6;
      color: #1F2937;
      border-radius: 8px;
      font-size: 0.9rem;
      font-weight: 600;
      border: 2px solid #E5E7EB;
      transition: all 0.2s ease;
    }
    .mysis-badge-affectation:hover {
      border-color: var(--mysis-primary);
      background: #FEF2F2;
      transform: translateY(-2px);
    }
    /* Responsive : 1 colonne sur mobile et tablette */
    @media (max-width: 1023px) {
      .mysis-infos-container {
        grid-template-columns: 1fr;
        gap: 20px;
        width: 100%;
        max-width: 100%;
        padding: 0;
        margin: 0;
      }
      .mysis-infos-photo-column {
        position: relative;
        top: auto;
        width: 100%;
        max-width: 100%;
      }
      .mysis-infos-data-column {
        width: 100%;
        max-width: 100%;
      }
      .mysis-photo-card {
        padding: 20px;
        width: 100%;
        box-sizing: border-box;
      }
      .mysis-photo-card h4 {
        font-size: 1.1rem !important;
        word-break: break-word;
      }
      .mysis-photo-card p {
        font-size: 0.9rem !important;
        word-break: break-word;
      }
      .mysis-info-cards-grid {
        grid-template-columns: 1fr;
        gap: 12px;
        width: 100%;
        max-width: 100%;
      }
      .mysis-info-card {
        padding: 16px;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
      }
      .mysis-info-card h5 {
        font-size: 0.75rem !important;
      }
      .mysis-info-card p {
        font-size: 1rem !important;
        word-break: break-word;
      }
      /* Header avec bouton en colonne sur mobile */
      .mysis-section-header {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 12px;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
      }
      #mysis-toggle-edit-mode {
        width: 100%;
        justify-content: center;
      }
      /* Badges statuts/affectations plus compacts sur mobile */
      .mysis-info-card span[style*="inline-flex"] {
        font-size: 0.85rem !important;
        padding: 6px 12px !important;
      }
      .mysis-info-card span[style*="inline-flex"] .material-icons,
      .mysis-info-card span[style*="inline-flex"] .material-symbols-outlined {
        font-size: 16px !important;
      }
      /* Image du grade plus petite sur mobile */
      .mysis-info-card img {
        max-width: 50px !important;
      }
      
      /* Sur mobile : les onglets sont dans le header, pas dans .mysis-tabs */
      .mysis-tabs {
        display: block !important;
        grid-template-columns: 1fr !important;
      }
      
      /* Cacher le menu vertical desktop sur mobile */
      .mysis-tabs-nav-desktop {
        display: none !important;
      }
      
      /* Afficher le menu horizontal du header sur mobile */
      .mysis-profil-sticky-header .mysis-profil-tabs-nav {
        display: flex !important;
      }
      
      .mysis-profil-tabs-nav .mysis-tab-btn {
        flex: 0 0 auto !important;
        width: auto !important;
        font-size: 14px;
        padding: 12px 20px;
        gap: 6px;
        white-space: nowrap;
      }
      
      .mysis-profil-tabs-nav .mysis-tab-btn .material-icons,
      .mysis-profil-tabs-nav .mysis-tab-btn .material-symbols-outlined {
        font-size: 18px;
      }
      
      .mysis-tab-panel .acf-field {
        padding: 16px;
      }
      
      .mysis-tab-panel#tab-infos .acf-fields {
        grid-template-columns: 1fr;
      }
      
      /* Conteneur des panels pleine largeur */
      .mysis-tabs-panels {
        width: 100%;
        max-width: 100%;
        padding: 5px;
        margin: 0;
        box-sizing: border-box;
      }
      
      /* Assurer que le conteneur principal des tabs ne dépasse pas */
      .mysis-tabs-profil {
        width: calc(100vw - 20px);
        max-width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
        padding: 0 10px;
        margin-left: auto;
        margin-right: auto;
      }
      
      /* Éviter débordement global sur mobile */
      body {
        overflow-x: hidden;
        max-width: 100vw;
        /* Support safe areas en mode mobile */
        padding-left: env(safe-area-inset-left, 0px);
        padding-right: env(safe-area-inset-right, 0px);
      }
      
      /* Toutes les cartes d'info doivent rester dans la largeur */
      .mysis-info-card > * {
        max-width: 100%;
        word-wrap: break-word;
        overflow-wrap: break-word;
      }
      
      /* Les badges doivent wrapper si trop longs */
      .mysis-info-card > div > div {
        flex-wrap: wrap;
      }
    }
    /* Responsive tablette */
    @media (min-width: 768px) and (max-width: 1023px) {
      .mysis-infos-container {
        grid-template-columns: 40% 60%;
        gap: 24px;
      }
      .mysis-info-cards-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }
    /* Extra small mobile (< 400px) */
    @media (max-width: 400px) {
      .mysis-tabs-profil {
        padding: 0 5px;
      }
      .mysis-photo-card {
        padding: 16px;
      }
      .mysis-photo-card h4 {
        font-size: 1rem !important;
      }
      .mysis-info-card {
        padding: 12px;
      }
      .mysis-info-card h5 {
        font-size: 0.7rem !important;
      }
      .mysis-info-card p {
        font-size: 0.95rem !important;
      }
      /* Badges encore plus compacts sur très petit écran */
      .mysis-info-card span[style*="inline-flex"] {
        font-size: 0.8rem !important;
        padding: 5px 10px !important;
      }
      /* Image du grade encore plus petite sur très petit écran */
      .mysis-info-card img {
        max-width: 40px !important;
      }
    }
    /* Messages d'aide visuels */
    .mysis-field-help {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      background: linear-gradient(135deg, #e7f3ff 0%, #d4e9ff 100%);
      border-left: 4px solid #2196F3;
      padding: 12px 16px;
      border-radius: 8px;
      margin-top: 12px;
      font-size: 13px;
      color: #0d47a1;
      line-height: 1.5;
    }
    .mysis-field-help .material-symbols-outlined {
      font-size: 20px;
      color: #2196F3;
      flex-shrink: 0;
    }
    /* En-têtes de section dans les onglets */
    .mysis-section-header {
      padding: 20px 24px;
      background: linear-gradient(135deg, #fff 0%, #f8f9fa 100%);
      border-radius: var(--mysis-radius);
      border-left: 4px solid var(--mysis-primary);
      box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    }
    .mysis-section-header h3 {
      font-family: 'Outfit', sans-serif;
      font-size: 22px;
      font-weight: 700;
      color: #333;
      margin: 0;
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .mysis-section-header h3 .material-symbols-outlined {
      color: var(--mysis-primary);
      font-size: 28px;
    }
    .mysis-section-header p {
      margin: 8px 0 0;
      color: #6B7280;
      font-size: 14px;
      line-height: 1.5;
    }

    @media (min-width: 1024px) {
      /* Sur desktop : les onglets restent à gauche dans un menu vertical */
      .mysis-tabs {
        display: grid;
        grid-template-columns: 300px 1fr;
        gap: 24px;
        align-items: start;
      }
      /* Cacher le menu horizontal du header sur desktop */
      .mysis-profil-sticky-header .mysis-profil-tabs-nav {
        display: none !important;
      }
      /* Afficher le menu vertical à gauche */
      .mysis-tabs-profil > .mysis-tabs-nav {
        display: flex !important;
        flex-direction: column;
        position: sticky;
        top: 20px;
        align-self: start;
        background: #fff;
        border: 2px solid #e9ecef;
        border-radius: 16px;
        padding: 16px 20px;
        box-shadow: 0 4px 20px rgba(0,0,0,0.08);
        gap: 8px;
      }
      .mysis-tabs-profil > .mysis-tabs-nav .mysis-tab-btn {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
        text-align: left;
        justify-content: flex-start;
        padding: 16px 20px;
        gap: 12px;
      }
      .mysis-tabs-profil > .mysis-tabs-nav .mysis-tab-btn .material-icons,
      .mysis-tabs-profil > .mysis-tabs-nav .mysis-tab-btn .material-symbols-outlined {
        font-size: 22px;
      }
      .mysis-tabs-profil > .mysis-tabs-nav .mysis-tab-btn span:not(.material-icons):not(.material-symbols-outlined) {
        flex: 1;
      }
    }
    /* Mobile très petit : boutons plus compacts mais toujours en horizontal */
    @media (max-width: 480px) {
      .mysis-profil-tabs-nav .mysis-tab-btn {
        padding: 10px 16px;
        min-width: auto;
        gap: 4px;
        font-size: 13px;
      }
      .mysis-profil-tabs-nav .mysis-tab-btn span:not(.material-icons):not(.material-symbols-outlined) {
        font-size: 13px;
        line-height: 1.2;
      }
      .mysis-profil-tabs-nav .mysis-tab-btn .material-icons,
      .mysis-profil-tabs-nav .mysis-tab-btn .material-symbols-outlined {
        font-size: 18px;
      }
      .mysis-profil-tabs-nav {
        padding: 10px;
        gap: 6px;
      }
    }

    /* Picker Affectations */
    .mysis-ap-open, .mysis-ap-save {
      background: var(--mysis-primary) !important;
    }
    .mysis-ap-item input[type=checkbox] {
      accent-color: var(--mysis-primary);
    }
    /* Préférences alimentaires - Style personnalisé (pas ACF) */
    .mysis-food-prefs-custom {
      margin-bottom: 20px;
    }
    .mysis-food-prefs-custom .acf-label {
      margin-bottom: 12px;
    }
    .mysis-food-prefs-custom .acf-label label {
      font-weight: 700;
      font-size: 0.95rem;
      color: #374151;
    }
    .mysis-food-buttons {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
    }
    /* Bouton style IDENTIQUE à mysis-tab-btn */
    .mysis-food-btn {
      appearance: none;
      flex: 1;
      min-width: 160px;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 10px;
      padding: 20px 16px;
      /* Exactement comme mysis-tab-btn */
      border: 2px solid var(--mysis-border);
      background: var(--mysis-bg-card);
      border-radius: var(--mysis-radius);
      cursor: pointer;
      font-weight: 700;
      transition: var(--mysis-transition);
      font-size: 0.95rem;
    }
    .mysis-food-btn:hover {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
    }
    /* État actif - IDENTIQUE à mysis-tab-btn[aria-selected=true] */
    .mysis-food-btn-active,
    .mysis-food-btn:has(input:checked) {
      border-color: var(--mysis-primary);
      color: var(--mysis-primary);
      background: var(--mysis-primary-light);
      box-shadow: var(--mysis-shadow-sm);
    }
    .mysis-food-btn input[type="radio"] {
      display: none;
    }
    .mysis-food-icon {
      font-size: 48px !important;
      color: #6B7280;
      transition: var(--mysis-transition);
    }
    .mysis-food-btn-active .mysis-food-icon,
    .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);
      margin-top: 4px;
    }
    .mysis-food-btn-active .mysis-food-label,
    .mysis-food-btn:has(input:checked) .mysis-food-label {
      color: var(--mysis-primary) !important;
    }

    /* Image preview */
    .photo-profil-custom {
      display: inline-block;
      border-radius: var(--mysis-radius);
      max-width: 100%;
      height: auto;
      box-shadow: var(--mysis-shadow-sm);
    }
    /* ========= ONBOARDING MODAL ========= */
    .mysis-modal-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(255, 255, 255, 0.95);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      z-index: 999999;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 16px;
      overflow-y: auto;
      animation: mysis-modal-fade-in 0.3s ease-out;
    }
    @keyframes mysis-modal-fade-in {
      from {
        opacity: 0;
      }
      to {
        opacity: 1;
      }
    }
    .mysis-modal-container {
      width: 100%;
      max-width: 650px;
      min-height: 550px;
      max-height: 90vh;
      overflow-y: auto;
      background: #FFFFFF;
      border-radius: 16px;
      box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
      animation: mysis-modal-slide-up 0.4s cubic-bezier(0.16, 1, 0.3, 1);
      display: flex;
      flex-direction: column;
    }
    @keyframes mysis-modal-slide-up {
      from {
        opacity: 0;
        transform: translateY(20px) scale(0.95);
      }
      to {
        opacity: 1;
        transform: translateY(0) scale(1);
      }
    }
    @keyframes mysis-modal-shake {
      0%, 100% { transform: translateX(0); }
      10%, 30%, 50%, 70%, 90% { transform: translateX(-10px); }
      20%, 40%, 60%, 80% { transform: translateX(10px); }
    }
    /* Bloquer le scroll du body quand le modal est ouvert */
    body.mysis-modal-open {
      overflow: hidden !important;
      position: relative;
    }
    /* Scrollbar personnalisée pour le modal container */
    .mysis-modal-container::-webkit-scrollbar {
      width: 8px;
    }
    .mysis-modal-container::-webkit-scrollbar-track {
      background: rgba(0, 0, 0, 0.1);
      border-radius: 10px;
    }
    .mysis-modal-container::-webkit-scrollbar-thumb {
      background: var(--mysis-primary);
      border-radius: 10px;
    }
    .mysis-modal-container::-webkit-scrollbar-thumb:hover {
      background: var(--mysis-primary-hover);
    }
    /* ========= ONBOARDING ========= */
    .mysis-onboarding-wrapper {
      max-width: 700px;
      margin: 0 auto;
      padding: 32px;
      min-height: 550px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }
    .mysis-onboarding-header {
      text-align: center;
      margin-bottom: 40px;
    }
    .mysis-onboarding-header h1 {
      font-size: 1.75rem;
      font-weight: 800;
      color: var(--mysis-primary);
      margin: 0 0 12px 0;
    }
    .mysis-onboarding-header p {
      font-size: 1rem;
      color: #6B7280;
      margin: 0;
      line-height: 1.5;
    }
    .mysis-onboarding-progress {
      width: 100%;
      height: 8px;
      background: #E5E7EB;
      border-radius: 999px;
      overflow: hidden;
      margin-bottom: 12px;
    }
    .mysis-onboarding-progress-bar {
      height: 100%;
      background: linear-gradient(90deg, var(--mysis-primary) 0%, #D81B1B 100%);
      border-radius: 999px;
      transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    }
    .mysis-onboarding-step-indicator {
      text-align: center;
      color: #6B7280;
      font-size: 0.95rem;
      font-weight: 600;
      margin: 0 0 40px 0;
    }
    .mysis-onboarding-step {
      background: white;
      border: 2px solid #E5E7EB;
      border-radius: 16px;
      padding: 40px 32px;
      margin-bottom: 24px;
      box-shadow: var(--mysis-shadow-md);
      min-height: 300px;
      display: flex;
      flex-direction: column;
      justify-content: center;
    }
    .mysis-onboarding-steps {
      flex: 1;
      display: flex;
      flex-direction: column;
      justify-content: center;
    }
    .mysis-step-icon {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      background: var(--mysis-primary-light);
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 0 auto 24px;
    }
    .mysis-step-icon .material-icons {
      font-size: 48px;
      color: var(--mysis-primary);
    }
    .mysis-onboarding-step h2 {
      text-align: center;
      font-size: 1.5rem;
      font-weight: 700;
      color: #111827;
      margin: 0 0 12px 0;
    }
    .mysis-step-description {
      text-align: center;
      color: #6B7280;
      font-size: 0.95rem;
      margin: 0 0 32px 0;
      line-height: 1.5;
    }
    /* Messages erreur et succes - style PIN modal */
    .mysis-onboarding-error {
      padding: 12px 16px;
      background: #FEE2E2;
      border: 1px solid #FCA5A5;
      border-radius: 10px;
      color: #991B1B;
      font-size: 0.9rem;
      margin-bottom: 16px;
      font-weight: 600;
      display: none;
    }
    .mysis-onboarding-success {
      padding: 12px 16px;
      background: #D1FAE5;
      border: 1px solid #6EE7B7;
      border-radius: 10px;
      color: #065F46;
      font-size: 0.9rem;
      margin-bottom: 16px;
      font-weight: 600;
      display: none;
    }
    .mysis-field-wrapper {
      max-width: 500px;
      margin: 0 auto;
    }
    .mysis-field-wrapper input[type="text"],
    .mysis-field-wrapper input[type="tel"],
    .mysis-field-wrapper input[type="email"] {
      font-family: inherit;
      width: 100%;
      padding: 14px 16px;
      font-size: 1rem;
      border: 2px solid #E5E7EB;
      border-radius: var(--mysis-radius);
      transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
      background: #F9FAFB;
      box-shadow: none;
      outline: none;
    }
    .mysis-field-wrapper input:focus {
      border-color: var(--mysis-primary);
      box-shadow: 0 0 0 3px var(--mysis-ring);
      background: #fff;
    }
    .mysis-field-wrapper input::placeholder {
      color: #D1D5DB;
    }
    .mysis-onboarding-actions {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 16px;
      margin-top: 32px;
      flex-wrap: wrap;
    }
    .mysis-onboarding-submit {
      width: 100%;
      display: inline-flex !important;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 16px 24px !important;
      font-size: 1.05rem !important;
      font-weight: 700 !important;
      background: var(--mysis-primary) !important;
      color: white !important;
      border: none !important;
      border-radius: var(--mysis-radius) !important;
      cursor: pointer;
      transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
      box-shadow: 0 6px 12px rgba(171, 2, 9, 0.25);
    }
    .mysis-onboarding-submit:hover:not(:disabled) {
      background: var(--mysis-primary-hover) !important;
      box-shadow: 0 10px 20px rgba(171, 2, 9, 0.35);
      transform: translateY(-2px);
    }
    .mysis-onboarding-submit:active:not(:disabled) {
      transform: translateY(0);
    }
    .mysis-onboarding-submit .material-icons {
      font-size: 20px;
    }
    .mysis-submit-content {
      display: inline-flex;
      align-items: center;
      gap: 8px;
    }
    .mysis-submit-spinner {
      display: inline-flex;
      align-items: center;
    }
    .mysis-submit-spinner .material-icons {
      font-size: 20px;
    }
    .mysis-onboarding-submit:disabled {
      cursor: not-allowed;
      opacity: 0.6 !important;
    }
    /* Bouton Retour */
    .mysis-back-btn {
      display: inline-flex !important;
      align-items: center;
      gap: 8px;
      padding: 14px 24px !important;
      font-size: 1rem !important;
      font-weight: 600 !important;
      background: #E5E7EB !important;
      color: #374151 !important;
      border: none !important;
      border-radius: 10px !important;
      box-shadow: var(--mysis-shadow-sm) !important;
      transition: var(--mysis-transition) !important;
      cursor: pointer;
      font-family: inherit;
    }
    .mysis-back-btn:hover {
      background: #D1D5DB !important;
      box-shadow: var(--mysis-shadow-md) !important;
      transform: translateY(-2px);
    }
    .mysis-back-btn:focus {
      outline: none !important;
      box-shadow: 0 0 0 3px rgba(107, 114, 128, 0.2) !important;
    }
    .mysis-back-btn:active {
      transform: translateY(0);
    }
    .mysis-back-btn .material-icons {
      font-size: 20px;
    }
    @keyframes mysis-spin {
      from { transform: rotate(0deg); }
      to { transform: rotate(360deg); }
    }
    .mysis-spin {
      animation: mysis-spin 1s linear infinite;
      display: inline-block;
    }
    .mysis-onboarding-complete {
      text-align: center;
      padding: 80px 20px;
      background: white;
      border-radius: 16px;
      box-shadow: var(--mysis-shadow-md);
      max-width: 600px;
      margin: 40px auto;
    }
    .mysis-onboarding-complete .material-icons {
      display: block;
      margin: 0 auto 24px;
    }
    .mysis-onboarding-complete h2 {
      font-size: 2rem;
      font-weight: 700;
      color: #1F2937;
      margin: 0 0 12px 0;
    }
    .mysis-onboarding-complete p {
      font-size: 1.1rem;
      color: #6B7280;
      margin: 0;
    }
    /* ========= CHAMPS PERSONNALISÉS ONBOARDING (sans ACF) ========= */
    /* Checkboxes custom */
    .mysis-custom-checkboxes {
      display: flex;
      flex-direction: column;
      gap: 12px;
      max-width: 550px;
      margin: 0 auto;
    }
    .mysis-checkbox-label {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 14px;
      padding: 16px 20px;
      background: white;
      border: 2px solid #E5E7EB;
      border-radius: var(--mysis-radius);
      cursor: pointer;
      transition: var(--mysis-transition);
      font-size: 1.05rem;
      font-weight: 600;
      color: #374151;
    }
    .mysis-checkbox-label:hover {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
    }
    .mysis-checkbox-label.mysis-checkbox-checked,
    .mysis-checkbox-label:has(input:checked) {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
      color: var(--mysis-primary);
    }
    .mysis-checkbox-label input[type="checkbox"] {
      accent-color: var(--mysis-primary);
      width: 20px;
      height: 20px;
      margin: 0;
      flex-shrink: 0;
      cursor: pointer;
    }
    .mysis-checkbox-text {
      flex: 1;
      text-align: left;
    }
    /* Radios custom */
    .mysis-custom-radios {
      display: flex;
      flex-direction: column;
      gap: 12px;
      max-width: 550px;
      margin: 0 auto;
    }
    .mysis-radio-label {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 14px;
      padding: 16px 20px;
      background: white;
      border: 2px solid #E5E7EB;
      border-radius: var(--mysis-radius);
      cursor: pointer;
      transition: var(--mysis-transition);
      font-size: 1.05rem;
      font-weight: 600;
      color: #374151;
    }
    .mysis-radio-label:hover {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
    }
    .mysis-radio-label.mysis-radio-checked,
    .mysis-radio-label:has(input:checked) {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
      color: var(--mysis-primary);
    }
    .mysis-radio-label input[type="radio"] {
      accent-color: var(--mysis-primary);
      width: 20px;
      height: 20px;
      margin: 0;
      flex-shrink: 0;
      cursor: pointer;
    }
    .mysis-radio-text {
      flex: 1;
      text-align: left;
    }
    /* Select custom */
    .mysis-custom-select {
      width: 100%;
      max-width: 400px;
      margin: 0 auto;
      display: block;
      padding: 14px 16px;
      font-size: 1.05rem;
      border: 2px solid #E5E7EB;
      border-radius: var(--mysis-radius);
      background: white;
      color: #374151;
      font-weight: 600;
      cursor: pointer;
      transition: var(--mysis-transition);
    }
    .mysis-custom-select:focus {
      outline: none;
      border-color: var(--mysis-primary);
      box-shadow: var(--mysis-ring);
    }
    .mysis-custom-select:hover {
      border-color: var(--mysis-primary);
      background: var(--mysis-primary-light);
    }
    /* Textarea custom */
    .mysis-onboarding-step textarea {
      width: 100%;
      max-width: 500px;
      margin: 0 auto;
      display: block;
      padding: 14px 16px;
      font-size: 1rem;
      border: 2px solid #E5E7EB;
      border-radius: var(--mysis-radius);
      background: white;
      color: #374151;
      transition: var(--mysis-transition);
      resize: vertical;
      min-height: 100px;
      font-family: inherit;
    }
    .mysis-onboarding-step textarea:focus {
      outline: none;
      border-color: var(--mysis-primary);
      box-shadow: var(--mysis-ring);
    }
    /* Champ photo ACF dans onboarding */
    .mysis-custom-photo-field {
      max-width: 400px;
      margin: 0 auto;
      text-align: center;
    }
    .mysis-custom-photo-field .acf-field {
      margin: 0 !important;
      padding: 0 !important;
      border: none !important;
    }
    .mysis-custom-photo-field .acf-label {
      display: none !important;
    }
    .mysis-custom-photo-field .acf-image-uploader {
      text-align: center !important;
      margin: 0 !important;
    }
    .mysis-custom-photo-field .image-wrap {
      margin: 0 auto !important;
      display: inline-block !important;
    }
    .mysis-custom-photo-field .acf-button {
      margin: 8px auto 0 !important;
      display: inline-block !important;
    }
    /* Responsive onboarding */
    @media (max-width: 768px) {
      .mysis-modal-overlay {
        padding: 8px;
        align-items: center;
      }
      .mysis-modal-container {
        max-height: 95vh;
        border-radius: 16px;
        min-height: auto !important;
        max-width: 100%;
      }
      .mysis-onboarding-wrapper {
        min-height: auto;
        padding: 24px;
      }
      .mysis-onboarding-header {
        margin-bottom: 20px;
      }
      .mysis-onboarding-header h1 {
        font-size: 1.5rem;
        margin-bottom: 8px;
      }
      .mysis-onboarding-header p {
        font-size: 0.9rem;
      }
      .mysis-onboarding-step {
        padding: 24px 16px;
        min-height: auto;
      }
      .mysis-onboarding-step h2 {
        font-size: 1.3rem;
        margin-bottom: 8px;
      }
      .mysis-step-description {
        font-size: 0.85rem;
        margin-bottom: 20px;
      }
      .mysis-step-icon {
        width: 56px;
        height: 56px;
        margin-bottom: 16px;
      }
      .mysis-step-icon .material-icons {
        font-size: 32px;
      }
      .mysis-onboarding-step-indicator {
        font-size: 0.85rem;
        margin-bottom: 20px;
      }
      /* Champs inputs */
      .mysis-field-wrapper input {
        padding: 12px 16px;
        font-size: 1rem;
      }
      /* Cases à cocher et radio custom - plus compacts */
      .mysis-custom-checkboxes,
      .mysis-custom-radios {
        max-width: 100%;
        padding: 0 8px;
      }
      .mysis-checkbox-label,
      .mysis-radio-label {
        padding: 12px 14px;
        font-size: 0.9rem;
        gap: 10px;
      }
      .mysis-checkbox-label input[type="checkbox"],
      .mysis-radio-label input[type="radio"] {
        width: 18px;
        height: 18px;
      }
      .mysis-checkbox-text,
      .mysis-radio-text {
        font-size: 0.9rem;
      }
      /* Boutons alimentation */
      .mysis-food-buttons {
        flex-direction: column;
        gap: 10px;
      }
      .mysis-food-btn {
        min-width: 100%;
        padding: 16px 12px;
      }
      .mysis-food-icon {
        font-size: 40px !important;
      }
      .mysis-food-label {
        font-size: 0.95rem;
      }
      /* Boutons action - plus compacts */
      .mysis-onboarding-actions {
        gap: 10px;
        margin-top: 20px;
      }
      .mysis-onboarding-submit {
        padding: 12px 20px !important;
        font-size: 0.95rem !important;
        flex: 1;
      }
      .mysis-onboarding-submit .material-icons {
        font-size: 20px;
      }
      .mysis-back-btn {
        padding: 12px 16px !important;
        font-size: 0.9rem !important;
        font-family: inherit;
      }
      .mysis-back-btn .material-icons {
        font-size: 18px;
      }
      /* Select et textarea */
      .mysis-custom-select {
        max-width: 100%;
        font-size: 0.95rem;
        padding: 12px 14px;
      }
      .mysis-onboarding-step textarea {
        max-width: 100%;
        font-size: 0.9rem;
        padding: 12px 14px;
      }
      /* Photo field */
      .mysis-custom-photo-field {
        max-width: 100%;
      }
    }
    /* ========= MODE DARK - SURCHARGES ========= */
    /* Dark mode styles pour tous les composants */
    html[data-theme="dark"] .info-utilisateur .grade-texte,
    html[data-theme="dark"] .info-utilisateur .nom-texte {
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .info-utilisateur .nom-texte {
      color: var(--mysis-primary);
    }
    /* Onglets en mode dark */
    html[data-theme="dark"] .mysis-tab-btn {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
      color: var(--mysis-text-secondary);
    }
    html[data-theme="dark"] .mysis-tab-btn .material-icons,
    html[data-theme="dark"] .mysis-tab-btn .material-symbols-outlined {
      color: var(--mysis-text-tertiary);
    }
    html[data-theme="dark"] .mysis-tab-btn:hover {
      border-color: var(--mysis-primary);
    }
    /* Champs ACF en mode dark */
    html[data-theme="dark"] .mysis-tab-panel .acf-field {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
    }
    html[data-theme="dark"] .mysis-tab-panel .acf-field .acf-label label {
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .mysis-tab-panel .acf-field .acf-label .description {
      color: var(--mysis-text-tertiary);
    }
    /* Inputs en mode dark */
    html[data-theme="dark"] .mysis-tab-panel .acf-input input[type=text],
    html[data-theme="dark"] .mysis-tab-panel .acf-input input[type=email],
    html[data-theme="dark"] .mysis-tab-panel .acf-input input[type=number],
    html[data-theme="dark"] .mysis-tab-panel .acf-input input[type=tel],
    html[data-theme="dark"] .mysis-tab-panel .acf-input input[type=password],
    html[data-theme="dark"] .mysis-tab-panel .acf-input textarea,
    html[data-theme="dark"] .mysis-tab-panel .acf-input select {
      background: var(--mysis-bg-secondary);
      border-color: var(--mysis-border);
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .mysis-tab-panel .acf-input input::placeholder,
    html[data-theme="dark"] .mysis-tab-panel .acf-input textarea::placeholder {
      color: var(--mysis-text-tertiary);
    }
    html[data-theme="dark"] .mysis-tab-panel .acf-input input:disabled,
    html[data-theme="dark"] .mysis-tab-panel .acf-input input:read-only {
      background: var(--mysis-bg-secondary);
      color: var(--mysis-text-tertiary);
    }
    /* Checkboxes et radios en mode dark */
    html[data-theme="dark"] .mysis-tab-panel .acf-checkbox-list label,
    html[data-theme="dark"] .mysis-tab-panel .acf-radio-list label {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
      color: var(--mysis-text-secondary) !important;
    }
    html[data-theme="dark"] .mysis-tab-panel .acf-checkbox-list label:hover,
    html[data-theme="dark"] .mysis-tab-panel .acf-radio-list label:hover {
      background: var(--mysis-primary-light);
    }
    /* Cartes info en mode dark */
    html[data-theme="dark"] .mysis-info-card {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
    }
    html[data-theme="dark"] .mysis-info-card h5 {
      color: var(--mysis-text-tertiary);
    }
    html[data-theme="dark"] .mysis-info-card p {
      color: var(--mysis-text-primary);
    }
    /* Photo card en mode dark */
    html[data-theme="dark"] .mysis-photo-card {
      background: linear-gradient(135deg, var(--mysis-bg-card) 0%, var(--mysis-bg-secondary) 100%);
      border-color: var(--mysis-border);
    }
    html[data-theme="dark"] .mysis-photo-card h4 {
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .mysis-photo-card p {
      color: var(--mysis-text-secondary);
    }
    /* Navigation tabs profil en mode dark */
    html[data-theme="dark"] .mysis-profil-tabs-nav {
      background: linear-gradient(135deg, var(--mysis-bg-secondary) 0%, var(--mysis-bg-card) 100%);
    }
    html[data-theme="dark"] .mysis-tabs-profil > .mysis-tabs-nav {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
    }
    /* Section header en mode dark */
    html[data-theme="dark"] .mysis-section-header {
      background: linear-gradient(135deg, var(--mysis-bg-card) 0%, var(--mysis-bg-secondary) 100%);
    }
    html[data-theme="dark"] .mysis-section-header h3 {
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .mysis-section-header p {
      color: var(--mysis-text-tertiary);
    }
    /* Badge affectation en mode dark */
    html[data-theme="dark"] .mysis-badge-affectation {
      background: var(--mysis-bg-secondary);
      color: var(--mysis-text-primary);
      border-color: var(--mysis-border);
    }
    html[data-theme="dark"] .mysis-badge-affectation:hover {
      background: var(--mysis-primary-light);
    }
    /* Boutons food preferences en mode dark */
    html[data-theme="dark"] .mysis-food-btn {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
    }
    html[data-theme="dark"] .mysis-food-btn:hover {
      background: var(--mysis-primary-light);
    }
    html[data-theme="dark"] .mysis-food-label {
      color: var(--mysis-text-secondary);
    }
    html[data-theme="dark"] .mysis-food-icon {
      color: var(--mysis-text-tertiary);
    }
    /* Messages AJAX en mode dark */
    html[data-theme="dark"] .mysis-ajax-success {
      background: rgba(16, 185, 129, 0.15);
    }
    html[data-theme="dark"] .mysis-ajax-success p {
      color: #6ee7b7;
    }
    html[data-theme="dark"] .mysis-ajax-error {
      background: rgba(239, 68, 68, 0.15);
    }
    html[data-theme="dark"] .mysis-ajax-error p {
      color: #fca5a5;
    }
    /* Field help en mode dark */
    html[data-theme="dark"] .mysis-field-help {
      background: linear-gradient(135deg, rgba(59, 130, 246, 0.15) 0%, rgba(59, 130, 246, 0.1) 100%);
      color: #93c5fd;
    }
    /* Modal overlay en mode dark */
    html[data-theme="dark"] .mysis-modal-overlay {
      background: rgba(0, 0, 0, 0.95);
    }
    html[data-theme="dark"] .mysis-modal-container {
      background: var(--mysis-bg-card);
      box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5), 0 0 0 1px var(--mysis-border);
    }
    /* Onboarding en mode dark */
    html[data-theme="dark"] .mysis-onboarding-header h1 {
      color: var(--mysis-primary);
    }
    html[data-theme="dark"] .mysis-onboarding-header p {
      color: var(--mysis-text-tertiary);
    }
    html[data-theme="dark"] .mysis-onboarding-step {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
    }
    html[data-theme="dark"] .mysis-onboarding-step h2 {
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .mysis-step-description {
      color: var(--mysis-text-tertiary);
    }
    html[data-theme="dark"] .mysis-step-icon {
      background: var(--mysis-primary-light);
    }
    html[data-theme="dark"] .mysis-onboarding-step-indicator {
      color: var(--mysis-text-tertiary);
    }
    html[data-theme="dark"] .mysis-onboarding-progress {
      background: var(--mysis-border);
    }
    html[data-theme="dark"] .mysis-field-wrapper input {
      background: var(--mysis-bg-secondary);
      border-color: var(--mysis-border);
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .mysis-field-wrapper input:focus {
      background: var(--mysis-bg-card);
    }
    html[data-theme="dark"] .mysis-field-wrapper input::placeholder {
      color: var(--mysis-text-tertiary);
    }
    /* Checkboxes et radios custom en mode dark */
    html[data-theme="dark"] .mysis-checkbox-label,
    html[data-theme="dark"] .mysis-radio-label {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
      color: var(--mysis-text-secondary);
    }
    html[data-theme="dark"] .mysis-checkbox-label:hover,
    html[data-theme="dark"] .mysis-radio-label:hover {
      background: var(--mysis-primary-light);
    }
    html[data-theme="dark"] .mysis-custom-select {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
      color: var(--mysis-text-secondary);
    }
    html[data-theme="dark"] .mysis-custom-select:hover {
      background: var(--mysis-primary-light);
    }
    html[data-theme="dark"] .mysis-onboarding-step textarea {
      background: var(--mysis-bg-card);
      border-color: var(--mysis-border);
      color: var(--mysis-text-secondary);
    }
    html[data-theme="dark"] .mysis-onboarding-error {
      background: rgba(239, 68, 68, 0.15);
      border-color: rgba(252, 165, 165, 0.5);
      color: #fca5a5;
    }
    html[data-theme="dark"] .mysis-onboarding-success {
      background: rgba(16, 185, 129, 0.15);
      border-color: rgba(110, 231, 183, 0.5);
      color: #6ee7b7;
    }
    html[data-theme="dark"] .mysis-onboarding-complete {
      background: var(--mysis-bg-card);
    }
    html[data-theme="dark"] .mysis-onboarding-complete h2 {
      color: var(--mysis-text-primary);
    }
    html[data-theme="dark"] .mysis-onboarding-complete p {
      color: var(--mysis-text-tertiary);
    }
    html[data-theme="dark"] .mysis-back-btn {
      background: var(--mysis-bg-secondary) !important;
      color: var(--mysis-text-secondary) !important;
    }
    html[data-theme="dark"] .mysis-back-btn:hover {
      background: var(--mysis-border) !important;
    }
    /* Même styles pour mode auto avec préférence dark */
    @media (prefers-color-scheme: dark) {
      html:not([data-theme="light"]):not([data-theme="dark"]) .info-utilisateur .grade-texte,
      html:not([data-theme="light"]):not([data-theme="dark"]) .info-utilisateur .nom-texte {
        color: var(--mysis-text-primary);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .info-utilisateur .nom-texte {
        color: var(--mysis-primary);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-tab-btn {
        background: var(--mysis-bg-card);
        border-color: var(--mysis-border);
        color: var(--mysis-text-secondary);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-tab-panel .acf-field {
        background: var(--mysis-bg-card);
        border-color: var(--mysis-border);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-tab-panel .acf-field .acf-label label {
        color: var(--mysis-text-primary);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-tab-panel .acf-input input,
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-tab-panel .acf-input textarea,
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-tab-panel .acf-input select {
        background: var(--mysis-bg-secondary);
        border-color: var(--mysis-border);
        color: var(--mysis-text-primary);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-info-card,
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-photo-card {
        background: var(--mysis-bg-card);
        border-color: var(--mysis-border);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-profil-tabs-nav {
        background: linear-gradient(135deg, var(--mysis-bg-secondary) 0%, var(--mysis-bg-card) 100%);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-section-header {
        background: linear-gradient(135deg, var(--mysis-bg-card) 0%, var(--mysis-bg-secondary) 100%);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-section-header h3 {
        color: var(--mysis-text-primary);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-modal-overlay {
        background: rgba(0, 0, 0, 0.95);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-modal-container {
        background: var(--mysis-bg-card);
      }
      html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-onboarding-step {
        background: var(--mysis-bg-card);
        border-color: var(--mysis-border);
      }
    }
