/* Smooth show/hide password animation
.password-animate {
  transition: opacity 0.16s ease, transform 0.16s ease;
}

.password-hidden {
  opacity: 0.25;
  transform: scale(0.98);
}

.password-visible {
  opacity: 1;
  transform: scale(1);
}
 */
 
/* Shake animation */
.shake {
  animation: shakeAnim 0.6s ease;
}

@keyframes shakeAnim {
  0%   { transform: translateX(0); }
  20%  { transform: translateX(-6px); }
  40%  { transform: translateX(6px); }
  60%  { transform: translateX(-6px); }
  80%  { transform: translateX(6px); }
  100% { transform: translateX(0); }
}

/* Glow merah */
.input-error {
  border-color: #dc3545 !important;
  box-shadow: 0 0 6px rgba(220,53,69,0.45);
  transition: box-shadow 0.25s ease;
}

.caps-hint.fade-in {
  opacity: 1;
  transition: opacity .3s ease;
}

.caps-hint {
  opacity: 0.7;
  transition: opacity .2s ease;
}

@keyframes fadeCaps {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Wrap untuk menahan posisi ikon */
.password-wrapper {
  position: relative;
}

/* Tombol show/hide */
.toggle-pass-btn {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  color: var(--bs-body-color);
  opacity: 0.75;
}

.toggle-pass-btn:hover {
  opacity: 1;
}

/* Untuk gelap/terang */
.dark .toggle-pass-btn {
  color: #e0e0e0;
}

.fade-in {
  animation: fadeIn 0.25s ease forwards;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-3px); }
  to   { opacity: 1; transform: translateY(0); }
}
