/* En-tête de page */
.page-header {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  padding: 32px;
  margin-bottom: 24px;
  box-shadow: var(--shadow-md);
}

.page-header-content {
  display: flex;
  align-items: center;
  gap: 20px;
}

.page-icon {
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, var(--color-primary) 0%, #10b981 100%);
  border-radius: var(--border-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  font-size: 28px;
  flex-shrink: 0;
  box-shadow: var(--shadow-green);
}

.page-title-wrapper h1 {
  font-size: 28px;
  font-weight: 700;
  color: var(--color-text-dark);
  margin: 0 0 8px 0;
}

.page-subtitle {
  color: var(--color-text-medium);
  font-size: 15px;
  margin: 0;
}

/* Carte formulaire */
.credential-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  animation: slideUp 0.5s ease-out;
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.card-body {
  padding: 40px;
}

/* Formulaire */
.form-group {
  margin-bottom: 28px;
  animation: fadeIn 0.6s ease-out backwards;
}

.form-group:nth-child(1) { animation-delay: 0.1s; }
.form-group:nth-child(2) { animation-delay: 0.2s; }
.form-group:nth-child(3) { animation-delay: 0.3s; }
.form-group:nth-child(4) { animation-delay: 0.4s; }

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateX(-10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.form-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--color-text-dark);
  margin-bottom: 10px;
  font-size: 15px;
}

.form-label::before {
  content: '';
  width: 3px;
  height: 16px;
  background: var(--color-primary);
  border-radius: 2px;
}

.form-control {
  width: 100%;
  padding: 14px 16px;
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius-sm);
  font-size: 15px;
  color: var(--color-text-dark);
  transition: var(--transition-smooth);
  background: var(--color-white);
}

.form-control:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px var(--color-primary-hover);
  background: var(--color-white);
}

.form-control:hover {
  border-color: var(--color-text-light);
}

.form-control::placeholder {
  color: var(--color-text-light);
}

/* Input group (pour le mot de passe) */
.input-group {
  display: flex;
  gap: 0;
  position: relative;
}

.input-group .form-control {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}

.input-group .btn-outline-secondary {
  border: 2px solid var(--color-border);
  border-left: none;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-top-right-radius: var(--border-radius-sm);
  border-bottom-right-radius: var(--border-radius-sm);
  background: var(--color-white);
  color: var(--color-text-medium);
  padding: 14px 20px;
  cursor: pointer;
  transition: var(--transition-smooth);
}

.input-group .btn-outline-secondary:hover {
  background: var(--color-bg-hover);
  color: var(--color-primary);
}

.input-group:focus-within .form-control {
  border-color: var(--color-primary);
}

.input-group:focus-within .btn-outline-secondary {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* Indicateur de force du mot de passe */
.progress {
  height: 6px;
  background: var(--color-border);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 8px;
  margin-top: 10px;
}

.progress-bar {
  height: 100%;
  transition: var(--transition-smooth);
  border-radius: 3px;
}

.progress-bar[data-strength="weak"] {
  background: var(--color-danger-start);
  width: 10%;
}

.progress-bar[data-strength="medium"] {
  background: var(--color-warning);
  width: 40%;
}

.progress-bar[data-strength="strong"] {
  background: var(--color-success);
  width: 100%;
}

/* Messages d'aide et d'erreur */
.form-hint {
  font-size: 13px;
  color: var(--color-text-muted);
  margin-top: 8px;
  display: flex;
  align-items: flex-start;
  gap: 6px;
}

.form-hint::before {
  content: 'ℹ';
  color: var(--color-primary);
  font-weight: 600;
  flex-shrink: 0;
}

.form-error,
.invalid-feedback {
  color: var(--color-danger-start);
  font-size: 13px;
  margin-top: 8px;
  display: flex;
  align-items: flex-start;
  gap: 6px;
  font-weight: 500;
}

.form-error::before,
.invalid-feedback::before {
  content: '⚠';
  flex-shrink: 0;
}

/* Actions du formulaire */
.form-actions {
  margin-top: 40px;
  padding-top: 32px;
  border-top: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  animation: fadeIn 0.6s ease-out backwards;
  animation-delay: 0.5s;
}

.btn {
  padding: 14px 28px;
  border-radius: var(--border-radius-sm);
  font-weight: 600;
  font-size: 15px;
  cursor: pointer;
  transition: var(--transition-smooth);
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  justify-content: center;
}

.btn i {
  font-size: 14px;
}

.btn-primary {
  background: var(--color-primary);
  color: var(--color-white);
  box-shadow: var(--shadow-green);
  min-width: 160px;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px var(--color-primary-hover);
  background: #047857;
}

.btn-primary:active {
  transform: translateY(0);
}

.btn-outline-secondary {
  background: var(--color-white);
  color: var(--color-text-dark);
  border: 2px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}

.btn-outline-secondary:hover {
  background: var(--color-bg-hover);
  border-color: var(--color-text-medium);
  transform: translateX(-4px);
}

/* Info box */
.info-box {
  background: linear-gradient(135deg, var(--color-bg-light) 0%, var(--color-primary-hover) 100%);
  border: 1px solid var(--color-primary);
  border-left: 4px solid var(--color-primary);
  padding: 20px;
  border-radius: var(--border-radius-sm);
  margin-bottom: 24px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.info-box-icon {
  width: 40px;
  height: 40px;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 18px;
}

.info-box-content h4 {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-dark);
  margin: 0 0 8px 0;
}

.info-box-content p {
  font-size: 14px;
  color: var(--color-text-medium);
  margin: 0;
  line-height: 1.6;
}

/* Responsive Design */
@media (max-width: 768px) {
  .breadcrumb-nav {
    padding: 12px 16px;
  }

  .breadcrumb-list {
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }

  .breadcrumb-item a,
  .breadcrumb-item.active {
    white-space: nowrap;
    font-size: 13px;
  }



  .page-header {
    padding: 24px;
  }

  .page-header-content {
    flex-direction: column;
    text-align: center;
  }

  .page-icon {
    width: 56px;
    height: 56px;
    font-size: 24px;
  }

  .page-title-wrapper h1 {
    font-size: 24px;
  }

  .card-body {
    padding: 24px;
  }

  .form-actions {
    flex-direction: column-reverse;
  }

  .btn {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .page-title-wrapper h1 {
    font-size: 22px;
  }

  .page-subtitle {
    font-size: 14px;
  }

  .card-body {
    padding: 20px;
  }

  .form-group {
    margin-bottom: 24px;
  }
}

/* États de chargement */
.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none !important;
}

/* Accessibilité */
:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

/* Selection */
::selection {
  background: var(--color-primary);
  color: var(--color-white);
}

/* Smooth scroll */
html {
  scroll-behavior: smooth;
}

/* Tooltip d'aide */
.form-label-wrapper {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  justify-content: space-between;
}

.form-label-wrapper .form-label {
  margin-bottom: 0;
}

.help-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: 50%;
  font-size: 11px;
  font-weight: 600;
  cursor: help;
  transition: var(--transition-smooth);
}

.help-icon:hover {
  transform: scale(1.1);
  background: #047857;
}

.help-tooltip {
  position: absolute;
  right: -10px;
  top: 100%;
  margin-top: 8px;
  background: var(--color-text-dark);
  color: var(--color-white);
  padding: 12px 16px;
  border-radius: var(--border-radius-sm);
  font-size: 13px;
  line-height: 1.5;
  width: 280px;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: var(--transition-smooth);
  z-index: 100;
  pointer-events: none;
}

.help-tooltip::before {
  content: '';
  position: absolute;
  bottom: 100%;
  right: 15px;
  border: 6px solid transparent;
  border-bottom-color: var(--color-text-dark);
}

.help-icon:hover .help-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  z-index:100;
}
/* --- Correction finale pour le tooltip caché --- */
.credential-card,
.card-body,
.form-group,
.input-group {
  overflow: visible !important;
  position: relative !important;
  z-index: auto !important;
}

.help-tooltip {
  z-index: 99999 !important;
  overflow: visible !important;
}

.help-icon {
  z-index: 10000 !important;
}

.help-tooltip {
    z-index: 2000 !important;
}
.my-error ul li{
  color: #e68a01ff;
  font-weight: 600;
  margin-top: 5px;
  list-style: none;

}


/* Responsive tooltip */
@media (max-width: 768px) {
  

  .help-tooltip {
    position: fixed;
    left: -290px;
    z-index: 999999;
    width:320px;
    padding: 14px 18px;
    font-size: 14px;
    line-height: 1.5;
    text-align: center;
  }



  /* Sur mobile, on n'affiche pas le tooltip au survol */
  .help-icon:hover .help-tooltip {
    opacity: 0;
    visibility: hidden;

  }

  /* Classe "active" pour l'affichage au clic */
  .help-icon.active .help-tooltip {
    opacity: 1 !important;
    visibility: visible !important;
  }
}