: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 — clip ne crée pas de BFC et laisse overflow-y: visible */
    .mysis-tabs-panels {
      width: 100%;
      max-width: 100%;
      overflow-x: clip;
    }
    /* Éviter le débordement du contenu — clip au lieu de hidden */
    .mysis-tab-panel {
      max-width: 100%;
      overflow-x: clip;
      box-sizing: border-box;
    }
    /* Wrappers ACF de l'onglet sécurité : clip horizontal sans scroll interne */
    #tab-security .acf-fields {
      overflow-x: clip !important;
      max-width: 100% !important;
      box-sizing: border-box !important;
    }
    .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: clip;
    }
    /* 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: clip;
    }
    /* 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: clip;
    }
    .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: clip;
    }
    .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;
      }
      
      /* 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: clip;
        box-sizing: border-box;
        padding: 0 10px;
        margin-left: auto;
        margin-right: auto;
      }
      
      /* Éviter débordement global sur mobile */
      body {
        overflow-x: clip;
        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 : navigation dans le header uniquement (mysis-header-tabs), pas de sidebar */
      .mysis-tabs {
        display: block;
      }
      /* Header tabs visibles sur desktop et mobile */
      .mysis-profil-sticky-header .mysis-header-tabs {
        display: flex !important;
      }
    }
    /* 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);
      }
    }

/* =========================================================
   CENTRE DE SÉCURITÉ — Security Center
   ========================================================= */

/* Annule le grid du tab-infos sur l'onglet sécurité */
.mysis-tab-panel#tab-security .acf-fields {
    display: block !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
}

.mysis-security-center {
    font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    overflow-x: clip;
}

/* Bandeau d'en-tête */
.mysis-security-center-header {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 28px 32px;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 60%, #8A0207 100%);
    border-radius: 20px;
    margin-bottom: 24px;
    color: #fff;
    position: relative;
    overflow: hidden;
}
.mysis-security-center-header::after {
    content: '';
    position: absolute;
    top: -40px;
    right: -20px;
    width: 180px;
    height: 180px;
    background: rgba(255,255,255,0.04);
    border-radius: 50%;
    pointer-events: none;
}
.mysis-security-center-header-icon {
    width: 56px;
    height: 56px;
    background: rgba(255,255,255,0.12);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.mysis-security-center-header-icon .material-symbols-outlined {
    font-size: 30px;
    color: #fff;
}
.mysis-security-center-header-text h2 {
    font-size: 22px;
    font-weight: 800;
    margin: 0 0 4px;
    color: #fff;
    font-family: 'Outfit', sans-serif;
}
.mysis-security-center-header-text p {
    font-size: 13px;
    color: rgba(255,255,255,0.72);
    margin: 0;
}

/* Grille 2 colonnes */
.mysis-security-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-width: 0;
    gap: 20px;
}

/* ——— Cartes ——— */
.mysis-sec-card {
    min-width: 0;
    overflow: hidden;
    background: var(--mysis-bg-card, #fff);
    border: 2px solid var(--mysis-border, #E5E7EB);
    border-radius: 16px;
    overflow: hidden;
    transition: box-shadow 0.3s ease, border-color 0.3s ease;
    font-family: 'Outfit', sans-serif;
}
.mysis-sec-card:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
    border-color: #D1D5DB;
}
/* Passkeys : pleine largeur */
.mysis-sec-card--passkeys {
    grid-column: 1 / -1;
}

/* En-tête de carte */
.mysis-sec-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 2px solid var(--mysis-border, #F3F4F6);
    background: var(--mysis-bg-secondary, #F9FAFB);
    gap: 12px;
}
.mysis-sec-card-title-group {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
}
.mysis-sec-card-icon {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.mysis-sec-icon--password  { background: linear-gradient(135deg, #1a1a2e, #16213e); }
.mysis-sec-icon--pin       { background: linear-gradient(135deg, #F59E0B, #D97706); }
.mysis-sec-icon--passkeys  { background: linear-gradient(135deg, #AB0209, #7f0107); }

.mysis-sec-card-icon .material-symbols-outlined {
    font-size: 20px;
    color: #fff;
}
.mysis-sec-card-title {
    font-size: 15px;
    font-weight: 700;
    color: var(--mysis-text-primary, #1F2937);
    margin: 0 0 2px;
}
.mysis-sec-card-subtitle {
    font-size: 12px;
    color: var(--mysis-text-tertiary, #6B7280);
    margin: 0;
}

/* Badges statut */
.mysis-sec-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
    flex-shrink: 0;
}
.mysis-sec-badge .material-symbols-outlined { font-size: 13px; }
.mysis-sec-badge--success { background: #ECFDF5; color: #065F46; }
.mysis-sec-badge--warning { background: #FFFBEB; color: #92400E; }
.mysis-sec-badge--info    { background: #EFF6FF; color: #1E40AF; }

/* Corps de carte */
.mysis-sec-card-body {
    padding: 20px 22px;
}
.mysis-sec-card-desc {
    font-size: 13px;
    color: var(--mysis-text-secondary, #374151);
    margin: 0 0 14px;
    line-height: 1.55;
}
.mysis-sec-card-info {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--mysis-text-tertiary, #6B7280);
    margin: 0 0 16px;
    padding: 10px 14px;
    background: var(--mysis-bg-secondary, #F9FAFB);
    border-radius: 10px;
}
.mysis-sec-card-info .material-symbols-outlined {
    font-size: 16px;
    color: #AB0209;
    flex-shrink: 0;
}

/* ——— Boutons ——— */
.mysis-sec-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 16px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s ease;
    font-family: 'Outfit', sans-serif;
    text-decoration: none;
    line-height: 1.3;
}
.mysis-sec-btn .material-symbols-outlined,
.mysis-sec-btn .material-icons { font-size: 16px; }

.mysis-sec-btn--primary {
    background: #AB0209;
    color: #fff;
    border-color: #AB0209;
}
.mysis-sec-btn--primary:hover {
    background: #8A0207;
    border-color: #8A0207;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(171,2,9,0.28);
}
.mysis-sec-btn--outline {
    background: transparent;
    color: var(--mysis-text-primary, #1F2937);
    border-color: var(--mysis-border, #E5E7EB);
}
.mysis-sec-btn--outline:hover {
    border-color: #AB0209;
    color: #AB0209;
    background: rgba(171,2,9,0.05);
}
.mysis-sec-btn--outline.mysis-sec-btn--danger {
    color: #991B1B;
    border-color: #FECACA;
}
.mysis-sec-btn--outline.mysis-sec-btn--danger:hover {
    background: #FEF2F2;
    border-color: #F87171;
}
.mysis-sec-btn--ghost {
    background: transparent;
    color: var(--mysis-text-tertiary, #6B7280);
    border-color: transparent;
}
.mysis-sec-btn--ghost:hover {
    background: var(--mysis-bg-secondary, #F3F4F6);
    color: var(--mysis-text-primary, #1F2937);
}

/* ——— Formulaires collapsibles ——— */
.mysis-sec-form-wrap {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 2px solid var(--mysis-border, #F3F4F6);
    animation: secFadeIn 0.25s ease;
}
@keyframes secFadeIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.mysis-sec-field-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 14px;
}
.mysis-sec-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.mysis-sec-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--mysis-text-secondary, #374151);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.mysis-sec-input {
    width: 100%;
    padding: 10px 14px;
    border: 2px solid var(--mysis-border, #E5E7EB);
    border-radius: 10px;
    font-size: 14px;
    font-family: 'Outfit', sans-serif;
    background: var(--mysis-bg-card, #fff);
    color: var(--mysis-text-primary, #1F2937);
    box-sizing: border-box;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    -webkit-appearance: none;
    appearance: none;
}
.mysis-sec-input:focus {
    outline: none;
    border-color: #AB0209;
    box-shadow: 0 0 0 3px rgba(171,2,9,0.12);
}
/* PIN : champ centré compact */
.mysis-sec-pin-input {
    max-width: 110px;
    text-align: center;
    font-size: 22px;
    letter-spacing: 8px;
    font-weight: 700;
    padding: 10px 10px;
}
/* Password : bouton œil */
.mysis-sec-pass-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.mysis-sec-pass-wrap .mysis-sec-input { padding-right: 46px; }
.mysis-sec-eye-btn {
    position: absolute;
    right: 8px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    color: var(--mysis-text-tertiary, #6B7280);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    transition: color 0.2s;
}
.mysis-sec-eye-btn:hover { color: var(--mysis-text-primary, #1F2937); }
.mysis-sec-eye-btn .material-symbols-outlined { font-size: 18px; }

/* Indicateur de force */
.mysis-sec-strength {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 5px;
}
.mysis-sec-strength-bar {
    flex: 1;
    height: 5px;
    background: #E5E7EB;
    border-radius: 10px;
    overflow: hidden;
}
.mysis-sec-strength-fill {
    height: 100%;
    border-radius: 10px;
    transition: width 0.35s ease, background 0.35s ease;
    width: 0;
}
.mysis-sec-strength-label {
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
}

/* Messages inline */
.mysis-sec-msg {
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 500;
    margin-bottom: 12px;
}
.mysis-sec-msg--success { background: #ECFDF5; color: #065F46; }
.mysis-sec-msg--error   { background: #FEF2F2; color: #991B1B; }

/* Actions */
.mysis-sec-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* ——— Section Passkeys ——— */
.mysis-sec-passkeys-benefits {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 18px;
}
.mysis-sec-passkeys-benefit {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    background: var(--mysis-bg-secondary, #F9FAFB);
    border-radius: 10px;
}
.mysis-sec-passkeys-benefit .material-icons {
    font-size: 20px;
    color: #AB0209;
    flex-shrink: 0;
    margin-top: 1px;
}
.mysis-sec-benefit-title {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--mysis-text-primary, #1F2937);
    margin-bottom: 2px;
}
.mysis-sec-benefit-desc {
    font-size: 12px;
    color: var(--mysis-text-tertiary, #6B7280);
    margin: 0;
}

/* Items de clés */
.mysis-sec-passkey-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    background: var(--mysis-bg-card, #fff);
    border: 2px solid var(--mysis-border, #E5E7EB);
    border-radius: 12px;
    margin-bottom: 10px;
    transition: border-color 0.2s;
}
.mysis-sec-passkey-item:last-child { margin-bottom: 0; }
.mysis-sec-passkey-item:hover { border-color: #D1D5DB; }

.mysis-sec-passkey-info {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}
.mysis-sec-passkey-icon {
    width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #1a1a2e, #16213e);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.mysis-sec-passkey-icon .material-icons {
    font-size: 18px;
    color: #fff;
}
.mysis-sec-passkey-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--mysis-text-primary, #1F2937);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mysis-sec-passkey-meta {
    font-size: 12px;
    color: var(--mysis-text-tertiary, #6B7280);
    margin-top: 2px;
}

/* État vide */
.mysis-sec-passkey-empty {
    text-align: center;
    padding: 28px 20px;
    background: var(--mysis-bg-secondary, #F9FAFB);
    border-radius: 12px;
    border: 2px dashed var(--mysis-border, #E5E7EB);
    color: var(--mysis-text-tertiary, #6B7280);
    margin-bottom: 0;
}
.mysis-sec-passkey-empty .material-icons {
    font-size: 40px;
    color: #D1D5DB;
    display: block;
    margin-bottom: 8px;
}
.mysis-sec-passkey-empty p {
    font-size: 14px;
    margin: 0;
}

/* Pied de section passkeys */
.mysis-sec-passkeys-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-top: 16px;
    border-top: 2px solid var(--mysis-border, #F3F4F6);
    margin-top: 14px;
}
.mysis-sec-passkeys-hint {
    font-size: 13px;
    color: var(--mysis-text-tertiary, #6B7280);
    margin: 0;
}

/* Animation spin */
@keyframes mysisSpin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}
.mysis-spin {
    display: inline-block;
    animation: mysisSpin 0.9s linear infinite;
}

/* ——— Mode sombre ——— */
html[data-theme="dark"] .mysis-sec-card {
    background: var(--mysis-bg-card);
    border-color: var(--mysis-border);
}
html[data-theme="dark"] .mysis-sec-card-header {
    background: var(--mysis-bg-secondary);
    border-color: var(--mysis-border);
}
html[data-theme="dark"] .mysis-sec-input {
    background: var(--mysis-bg-secondary);
    border-color: var(--mysis-border);
    color: var(--mysis-text-primary);
}
html[data-theme="dark"] .mysis-sec-badge--success {
    background: rgba(6,95,70,0.2);
    color: #34D399;
}
html[data-theme="dark"] .mysis-sec-badge--warning {
    background: rgba(146,64,14,0.2);
    color: #FCD34D;
}
html[data-theme="dark"] .mysis-sec-badge--info {
    background: rgba(30,64,175,0.2);
    color: #93C5FD;
}
html[data-theme="dark"] .mysis-sec-card-info,
html[data-theme="dark"] .mysis-sec-passkeys-benefit,
html[data-theme="dark"] .mysis-sec-passkey-empty {
    background: var(--mysis-bg-secondary);
}
html[data-theme="dark"] .mysis-sec-form-wrap,
html[data-theme="dark"] .mysis-sec-passkeys-footer {
    border-color: var(--mysis-border);
}
html[data-theme="dark"] .mysis-sec-passkey-item {
    background: var(--mysis-bg-card);
    border-color: var(--mysis-border);
}
html[data-theme="dark"] .mysis-sec-msg--success { background: rgba(6,95,70,0.15); color: #34D399; }
html[data-theme="dark"] .mysis-sec-msg--error   { background: rgba(153,27,27,0.15); color: #FCA5A5; }
html[data-theme="dark"] .mysis-sec-btn--outline {
    color: var(--mysis-text-primary);
    border-color: var(--mysis-border);
}
html[data-theme="dark"] .mysis-sec-btn--ghost:hover { background: var(--mysis-bg-secondary); }

/* Mode auto (suit les préférences système) */
@media (prefers-color-scheme: dark) {
    html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-sec-card {
        background: var(--mysis-bg-card);
        border-color: var(--mysis-border);
    }
    html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-sec-card-header {
        background: var(--mysis-bg-secondary);
        border-color: var(--mysis-border);
    }
    html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-sec-input {
        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-sec-card-info,
    html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-sec-passkeys-benefit,
    html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-sec-passkey-empty {
        background: var(--mysis-bg-secondary);
    }
    html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-sec-passkey-item {
        background: var(--mysis-bg-card);
        border-color: var(--mysis-border);
    }
    html:not([data-theme="light"]):not([data-theme="dark"]) .mysis-sec-btn--outline {
        color: var(--mysis-text-primary);
        border-color: var(--mysis-border);
    }
}

/* ——— Responsive mobile ——— */
@media (max-width: 768px) {
    .mysis-security-grid {
        grid-template-columns: 1fr;
    }
    .mysis-sec-card--passkeys {
        grid-column: 1;
    }
    .mysis-sec-passkeys-benefits {
        grid-template-columns: 1fr;
    }
    .mysis-security-center-header {
        padding: 20px;
        gap: 14px;
    }
    .mysis-security-center-header-text h2 { font-size: 18px; }
    .mysis-sec-passkeys-footer {
        flex-direction: column;
        align-items: flex-start;
    }
    .mysis-sec-form-actions {
        flex-wrap: wrap;
    }
    .mysis-sec-btn {
        font-size: 13px;
        padding: 9px 14px;
    }
}
