/* ============================================================
   FundrayzerGlobal Bank — login.css
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  --primary:#0a2e6e;--primary-mid:#1040a0;--primary-light:#1a55c8;
  --accent:#f5a623;--accent-light:#ffc94a;--teal:#1a7fd4;
  --white:#ffffff;--off-white:#f4f7fc;--text:#1a1e2e;--text-muted:#5a6480;
  --border:#d4daea;--danger:#d93535;--success:#1a7a45;--warning:#b87a0a;
  --font:'Poppins',sans-serif;
}

html{scroll-behavior:smooth;}
body{
  font-family:var(--font);background:var(--off-white);color:var(--text);
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:2.5rem 1rem;
}
a{text-decoration:none;color:inherit;}

/* ── Bank header ── */
.bank-header{text-align:center;margin-bottom:1.8rem;}
.bank-logo{display:inline-flex;align-items:center;gap:0.65rem;margin-bottom:1.1rem;}
.bank-logo-mark{width:44px;height:44px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;}
.bank-logo-name{font-size:1.25rem;font-weight:700;color:var(--primary);letter-spacing:-0.01em;}
.bank-logo-name span{color:var(--accent);}
.bank-logo-sub{font-size:0.6rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);}
.bank-header h3{font-size:clamp(1.15rem,3vw,1.55rem);font-weight:700;color:var(--primary);line-height:1.25;margin-bottom:0.3rem;}
.bank-header .sub{font-size:0.87rem;color:var(--text-muted);line-height:1.65;display:block;}

/* ── Login form card ── */
.form-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:2.2rem 2rem;width:100%;max-width:420px;box-shadow:0 4px 20px rgba(10,46,110,0.07);}

/* ── Field groups ── */
.field-group{display:flex;flex-direction:column;margin-bottom:1.1rem;}
.field-group label{font-size:0.8rem;font-weight:600;color:var(--text);margin-bottom:0.38rem;}
.field-group input{width:100%;padding:0.76rem 1rem;font-family:var(--font);font-size:0.875rem;color:var(--text);background:var(--off-white);border:1.5px solid var(--border);border-radius:8px;outline:none;transition:border-color 0.22s,box-shadow 0.22s,background 0.22s;}
.field-group input::placeholder{color:#aab2c8;}
.field-group input:focus{border-color:var(--primary-light);background:var(--white);box-shadow:0 0 0 3px rgba(26,85,200,0.12);}
.field-group input.input-error{border-color:var(--danger);box-shadow:0 0 0 3px rgba(217,53,53,0.1);}
.field-group input.input-success{border-color:var(--success);box-shadow:0 0 0 3px rgba(26,122,69,0.1);}

.field-error{font-size:0.74rem;color:var(--danger);margin-top:0.28rem;display:none;align-items:center;gap:0.25rem;}
.field-error.visible{display:flex;}

.input-wrapper{position:relative;display:flex;align-items:center;}
.input-wrapper input{padding-right:2.7rem;}
.toggle-pw{position:absolute;right:0.85rem;background:none;border:none;cursor:pointer;font-size:0.95rem;color:var(--text-muted);padding:0;line-height:1;transition:color 0.2s;}
.toggle-pw:hover{color:var(--primary);}

.forgot-link{display:flex;justify-content:flex-end;margin-top:0.35rem;margin-bottom:1.3rem;}
.forgot-link a{font-size:0.78rem;font-weight:600;color:var(--primary-light);text-decoration:underline;transition:color 0.2s;}
.forgot-link a:hover{color:var(--accent);}

/* ── Submit button ── */
.btn-submit{width:100%;background:var(--primary);color:var(--white);font-family:var(--font);font-size:0.9rem;font-weight:600;padding:0.88rem;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:0.5rem;transition:background 0.2s,transform 0.15s,box-shadow 0.2s;margin-bottom:1.2rem;}
.btn-submit:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:0 6px 18px rgba(10,46,110,0.22);}
.btn-submit.loading{background:var(--primary-mid);pointer-events:none;opacity:0.8;}

.register-link{text-align:center;font-size:0.84rem;color:var(--text-muted);}
.register-link a{color:var(--primary-light);font-weight:600;text-decoration:underline;}
.register-link a:hover{color:var(--accent);}

/* ── Spinner ── */
.spinner{display:none;width:15px;height:15px;border:2px solid rgba(255,255,255,0.3);border-top-color:var(--white);border-radius:50%;animation:spin 0.7s linear infinite;flex-shrink:0;}
.btn-submit.loading .spinner,
.modal-btn.loading .spinner{display:inline-block;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── Toast ── */
.toast{position:fixed;top:1.5rem;right:1.5rem;max-width:calc(100vw - 3rem);padding:0.85rem 1.4rem;border-radius:10px;font-size:0.84rem;font-weight:500;box-shadow:0 6px 20px rgba(0,0,0,0.14);display:flex;align-items:center;gap:0.55rem;z-index:10000;transform:translateX(140%);transition:transform 0.35s ease;color:var(--white);}
.toast.show{transform:translateX(0);}

/* ══════════════════════════════════════════════════════════
   FORGOT PASSWORD MODAL
   ══════════════════════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(10,20,50,0.6);
  z-index:9000;display:none;align-items:center;justify-content:center;
  padding:1rem;backdrop-filter:blur(4px);
}
.modal-overlay.open{display:flex;}

.modal-box{
  background:var(--white);border-radius:20px;
  padding:2rem;width:100%;max-width:440px;
  position:relative;box-shadow:0 24px 80px rgba(10,46,110,0.22);
  animation:modalIn 0.25s ease;
}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(0.97);}to{opacity:1;transform:translateY(0) scale(1);}}

.modal-close{
  position:absolute;top:1.1rem;right:1.1rem;
  background:var(--off-white);border:1px solid var(--border);
  width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:0.85rem;cursor:pointer;color:var(--text-muted);
  transition:background 0.2s,color 0.2s;
}
.modal-close:hover{background:var(--danger);color:var(--white);border-color:var(--danger);}

/* Progress dots */
.modal-progress{display:flex;align-items:center;gap:0;margin-bottom:1.6rem;}
.progress-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:background 0.3s,transform 0.3s;}
.progress-dot.active{background:var(--primary-light);transform:scale(1.25);}
.progress-dot.done{background:var(--success);}
.progress-line{flex:1;height:2px;background:var(--border);margin:0 4px;transition:background 0.4s;}
.progress-line.done{background:var(--success);}

/* Step tag */
.step-tag{font-size:0.68rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--primary-light);background:rgba(26,85,200,0.09);border:1px solid rgba(26,85,200,0.18);padding:0.22rem 0.8rem;border-radius:20px;display:inline-block;margin-bottom:0.9rem;}

.modal-title{font-size:1.1rem;font-weight:700;color:var(--primary);margin-bottom:0.45rem;line-height:1.3;}
.modal-desc{font-size:0.84rem;color:var(--text-muted);line-height:1.65;margin-bottom:1.3rem;}
.modal-desc strong{color:var(--text);}

/* Modal input */
.modal-input{width:100%;padding:0.76rem 1rem;font-family:var(--font);font-size:0.875rem;color:var(--text);background:var(--off-white);border:1.5px solid var(--border);border-radius:8px;outline:none;transition:border-color 0.22s,box-shadow 0.22s;display:block;}
.modal-input:focus{border-color:var(--primary-light);background:var(--white);box-shadow:0 0 0 3px rgba(26,85,200,0.12);}
.modal-input.input-error{border-color:var(--danger);box-shadow:0 0 0 3px rgba(217,53,53,0.1);}

/* OTP input — big digits */
.otp-input{font-size:1.6rem;letter-spacing:0.5em;text-align:center;font-weight:700;font-family:'Courier New',monospace;padding-left:1.5rem;}

/* Modal primary button */
.modal-btn{
  width:100%;background:var(--primary);color:var(--white);
  font-family:var(--font);font-size:0.9rem;font-weight:600;
  padding:0.86rem;border:none;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:0.5rem;
  transition:background 0.2s,transform 0.15s,box-shadow 0.2s;
  margin-top:0.3rem;
}
.modal-btn:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:0 6px 18px rgba(10,46,110,0.22);}
.modal-btn.loading{background:var(--primary-mid);pointer-events:none;opacity:0.8;}
.modal-btn.btn-success{background:var(--success);}
.modal-btn.btn-success:hover{background:#15693a;}

/* Resend link button */
.modal-link-btn{background:none;border:none;color:var(--primary-light);font-family:var(--font);font-size:0.8rem;font-weight:600;cursor:pointer;margin-top:0.9rem;display:block;width:100%;text-align:center;padding:0.4rem;text-decoration:underline;transition:color 0.2s;}
.modal-link-btn:hover{color:var(--accent);}

/* Note below button */
.modal-note{font-size:0.76rem;color:var(--text-muted);line-height:1.6;margin-top:1rem;padding:0.8rem 1rem;background:var(--off-white);border-radius:8px;border:1px solid var(--border);}

/* Dev alert box */
.dev-alert{display:flex;gap:0.8rem;background:#fff8e6;border:1px solid rgba(184,122,10,0.3);border-radius:10px;padding:1rem;margin-bottom:1.2rem;align-items:flex-start;}
.dev-alert-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px;}
.dev-alert-body{flex:1;font-size:0.8rem;color:#7a5200;line-height:1.6;}
.dev-alert-body strong{display:block;font-size:0.82rem;margin-bottom:0.3rem;color:#6b4300;}
.dev-alert-body code{background:rgba(0,0,0,0.08);padding:0.1rem 0.35rem;border-radius:4px;font-family:'Courier New',monospace;font-size:0.76rem;}
.dev-code-display{font-size:1.8rem;font-weight:800;letter-spacing:0.5em;color:var(--primary);font-family:'Courier New',monospace;background:var(--white);border:2px dashed var(--border);border-radius:8px;padding:0.6rem;text-align:center;margin-top:0.6rem;}

/* Password strength */
.strength-wrap{margin-top:0.5rem;display:flex;align-items:center;gap:0.6rem;}
.strength-track{flex:1;height:5px;background:var(--border);border-radius:99px;overflow:hidden;}
.strength-fill{height:100%;width:0%;border-radius:99px;transition:width 0.4s ease,background 0.4s ease;}
.strength-label{font-size:0.72rem;font-weight:600;color:var(--text-muted);white-space:nowrap;}

/* Success step */
.success-icon{font-size:3rem;text-align:center;margin-bottom:1rem;display:block;}

/* Responsive */
@media(max-width:480px){
  .form-card{padding:1.8rem 1.3rem;}
  .modal-box{padding:1.6rem;}
  .bank-header h3{font-size:1.1rem;}
  .otp-input{font-size:1.3rem;letter-spacing:0.4em;}
}

/* ── Additional mobile fixes ── */
@media(max-width:380px) {
  body { padding: 1.5rem 0.75rem; }
  .form-card { padding: 1.5rem 1rem; }
  .modal-box { padding: 1.4rem 1.1rem; }
  .bank-logo-name { font-size: 1.05rem; }
  .bank-header h3 { font-size: 1rem; }
  .otp-input { font-size: 1.35rem; letter-spacing: 0.35em; padding-left: 0.8rem; }
  .toast { right: 0.5rem; left: 0.5rem; max-width: none; }
  .dev-code-display { font-size: 1.4rem; letter-spacing: 0.3em; }
}
