/* ================================================================
   Finantra — Auth (login / sign up) screens
   Design tokens from the handoff; reuses the :root vars in app.css.
   ================================================================ */

#auth-root{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:32px 20px;
  background:
    radial-gradient(120% 90% at 85% 5%, rgba(197,124,249,.10), transparent 55%),
    var(--bg);
}

.auth-card{
  width:100%;
  max-width:420px;
  background:var(--card2);
  border:1px solid var(--bd);
  border-radius:22px;
  padding:38px 36px;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  display:flex;
  flex-direction:column;
  gap:22px;
}

/* ── Inline logo lockup ─────────────────────────────────────── */
.auth-logo{display:flex;align-items:center;gap:10px}
.auth-logo-mark{
  width:32px;height:32px;border-radius:9px;
  background:linear-gradient(135deg,#C57CF9,#3869D2);
}
.auth-logo-text{font-size:15px;font-weight:700;letter-spacing:-.01em}

/* ── Heading ─────────────────────────────────────────────────── */
.auth-head{display:flex;flex-direction:column;gap:6px}
.auth-title{font-size:26px;font-weight:800;letter-spacing:-.02em}
.auth-sub{font-size:13.5px;color:var(--mut);line-height:1.5}

/* ── Fields ──────────────────────────────────────────────────── */
.auth-fields{display:flex;flex-direction:column;gap:14px}
.auth-field{display:flex;flex-direction:column;gap:6px}
.auth-label{font-size:12px;font-weight:500;color:var(--mut)}
.auth-input-wrap{position:relative;display:flex;align-items:center}
.auth-input-wrap .lead-icon{
  position:absolute;left:14px;color:var(--mut);pointer-events:none;
  display:flex;align-items:center;
}
.auth-input{
  width:100%;
  background:var(--card);
  border:1px solid var(--bd);
  border-radius:12px;
  padding:13px 14px 13px 42px;
  font-size:14px;color:var(--txt);
  outline:none;
  transition:border-color .15s;
}
.auth-input:focus{border-color:rgba(197,124,249,.55)}
.auth-input.invalid{border-color:var(--red)}
.auth-input::placeholder{color:#5c5c66}
.auth-eye{
  position:absolute;right:8px;
  background:transparent;border:none;color:var(--mut);
  padding:6px;display:flex;align-items:center;border-radius:8px;
}
.auth-eye:hover{color:var(--txt)}
.auth-error{font-size:11.5px;color:var(--red)}

/* ── Buttons ─────────────────────────────────────────────────── */
.auth-btn-primary{
  width:100%;
  background:linear-gradient(135deg,#C57CF9,#8f63e8);
  border:none;border-radius:12px;
  padding:14px;color:#fff;font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:opacity .15s,transform .05s;
}
.auth-btn-primary:hover{opacity:.94}
.auth-btn-primary:active{transform:translateY(1px)}
.auth-btn-primary:disabled{opacity:.6;cursor:default}

.auth-btn-secondary{
  width:100%;
  background:rgba(255,255,255,.05);
  border:1px solid var(--bd);border-radius:12px;
  padding:13px;color:var(--txt);font-weight:600;font-size:13.5px;
  display:flex;align-items:center;justify-content:center;gap:9px;
  transition:background .15s;
}
.auth-btn-secondary:hover{background:rgba(255,255,255,.08)}

/* ── Divider ─────────────────────────────────────────────────── */
.auth-divider{display:flex;align-items:center;gap:12px;color:var(--mut);font-size:12px}
.auth-divider::before,.auth-divider::after{
  content:"";flex:1;height:1px;background:var(--bd);
}

/* ── Footer + inline banners ─────────────────────────────────── */
.auth-footer{font-size:13px;color:var(--mut);text-align:center}
.auth-link{color:var(--pur);font-weight:600;background:none;border:none;font-size:inherit}
.auth-link:hover{text-decoration:underline}
.auth-legal{font-size:11.5px;color:var(--mut);text-align:center;line-height:1.5}

.auth-banner{
  font-size:12.5px;border-radius:10px;padding:10px 12px;line-height:1.45;
}
.auth-banner.error{background:rgba(242,85,90,.10);border:1px solid rgba(242,85,90,.30);color:#ff8a8e}
.auth-banner.info{background:rgba(56,105,210,.12);border:1px solid rgba(56,105,210,.32);color:#9db8ff}

/* ── Spinner ─────────────────────────────────────────────────── */
.auth-spinner{
  width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(255,255,255,.35);border-top-color:#fff;
  animation:auth-spin .7s linear infinite;
}
@keyframes auth-spin{to{transform:rotate(360deg)}}

/* ── Success screen ──────────────────────────────────────────── */
.auth-success{align-items:center;text-align:center}
.auth-badge{
  width:64px;height:64px;border-radius:50%;
  background:rgba(70,201,154,.14);color:var(--grn);
  display:flex;align-items:center;justify-content:center;
}
.auth-success .auth-title{font-size:22px}

/* ── Full-page loader ────────────────────────────────────────── */
.auth-loading{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--mut)}
.auth-loading .auth-spinner{width:26px;height:26px;border-width:3px}
