/* ===== Upgrade CSS (color-safe): NO cambia tu paleta ===== */
/* No definimos :root ni variables de color aquí para respetar tu dorado. */

html{scroll-behavior:smooth}
img{max-width:100%; height:auto; display:block}

/* ---- Cards (solo estructura/sombras; sin colores nuevos) ---- */
.card, .auth-card{
  border-radius:16px;
  box-shadow:0 6px 24px rgba(0,0,0,.25);
}

/* ---- Inputs con íconos centrados verticalmente ---- */
.input-wrap{ position:relative; height:46px; }
.input-wrap .form-control{
  height:46px; line-height:46px;
  padding-left:44px !important;  /* espacio icono izq */
  padding-right:44px !important; /* espacio icono der */
}
.input-icon-left,
.input-icon-right{
  position:absolute; top:50%; transform:translateY(-50%);
  width:18px; height:18px; line-height:1;
}
.input-icon-left{ left:14px; pointer-events:none; }
.input-icon-right{ right:12px; cursor:pointer; }

/* ---- Toast superior (solo layout/anim; hereda tus colores) ---- */
.top-alert{position:fixed; left:0; right:0; top:16px; display:none;
  justify-content:center; z-index:1050; pointer-events:none}
.top-alert .inner{
  display:flex; align-items:center; gap:10px;
  border-radius:12px; box-shadow:0 8px 30px rgba(0,0,0,.35);
  transform:translateY(-20px); opacity:0; animation:slideDown .45s ease forwards;
  pointer-events:auto;
}
@keyframes slideDown{ to{ transform:translateY(0); opacity:1 } }
.alert-info-icon{ width:18px; height:18px; flex-shrink:0; position:relative; top:-2px; }

/* ---- Overlay de envío (loader + barra) — neutro (no cambia tu acento) ---- */
.sending-overlay{position:fixed; inset:0;
  background:rgba(0,0,0,.45); backdrop-filter:blur(1.5px);
  display:none; align-items:center; justify-content:center; z-index:2000;
}
.sending-overlay.show{ display:flex; }
.sending-box{
  display:flex; flex-direction:column; align-items:center; gap:12px;
  padding:14px 18px; border-radius:12px;
  /* sin colores: hereda de tu tema si usas variables; si no, usa neutros */
  background:rgba(17,19,24,.97); border:1px solid rgba(255,255,255,.08);
  box-shadow:0 6px 24px rgba(0,0,0,.35); min-width:280px;
}
.sending-head{ display:flex; align-items:center; gap:12px; min-height:32px; }
.sending-spinner{
  display:block; width:32px; height:32px; border-radius:50%;
  border:4px solid rgba(255,255,255,.25); border-top-color:#fff;
  animation:spin-rot 1s linear infinite;
}
@keyframes spin-rot{ to{ transform:rotate(360deg) } }
.sending-progress{
  width:240px; height:6px; border-radius:999px; overflow:hidden;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 0 8px rgba(0,0,0,.35);
}
.sending-progress .bar{
  width:40%; height:100%;
  /* Deja el color de la barra a tu CSS actual si tienes acento dorado.
     Si quieres atarlo a tu acento, puedes sobreescribir este gradiente en tu hoja principal. */
  background:linear-gradient(90deg, rgba(255,255,255,.15), rgba(255,255,255,.9), rgba(255,255,255,.15));
  animation:indet 1.1s ease-in-out infinite;
}
@keyframes indet{ 0%{transform:translateX(-120%)} 100%{transform:translateX(260%)} }

/* ---- Utilidades ---- */
@keyframes pop-in{
  0%{ transform:scale(0); opacity:0 }
  60%{ transform:scale(1.05); opacity:1 }
  100%{ transform:scale(1); opacity:1 }
}

/* Mantengo tus botones/colores existentes. Este archivo NO redefine .btn-primary. */
