/* ============================================================
   FundrayzerGlobal Bank — login.css v2
   ============================================================ */
*,*::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;}

/* ══════════════════════════════════════
   GOOGLE TRANSLATE — HIDE BAR, KEEP WORKING
   Collapse to 0 height (not display:none) so the iframe
   stays in DOM and translation continues to function.
   JS cancels the body top offset Google injects.
   ══════════════════════════════════════ */
.goog-te-banner-frame,
.goog-te-banner-frame.skiptranslate {
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  overflow: hidden !important;
  border: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Cancel body top shift Google injects */
body { top: 0 !important; }
body.translated-ltr,
body.translated-rtl { top: 0 !important; margin-top: 0 !important; }

/* Hide "Powered by Google" text */
.goog-te-gadget > span,
.goog-te-gadget > a { display: none !important; }

/* Widget wrapper — sits below the subheading, centred */
.login-gt-wrap {
  margin-top: 0.9rem;
  display: flex;
  justify-content: center;
}
.login-gt-wrap .goog-te-gadget,
.login-gt-wrap .goog-te-gadget-simple {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  font-size: 0 !important;
}
.login-gt-wrap select,
.login-gt-wrap .goog-te-combo {
  font-family: var(--font) !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  color: var(--primary) !important;
  background-color: var(--white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 8px !important;
  padding: 0.45rem 2.2rem 0.45rem 0.85rem !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  cursor: pointer !important;
  outline: none !important;
  min-width: 160px !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%230a2e6e' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.55rem center !important;
  background-size: 16px !important;
}
.login-gt-wrap select:hover,
.login-gt-wrap .goog-te-combo:hover {
  border-color: var(--primary-light) !important;
  box-shadow: 0 0 0 3px rgba(26,85,200,0.1) !important;
}
.login-gt-wrap select:focus,
.login-gt-wrap .goog-te-combo:focus {
  border-color: var(--teal) !important;
  box-shadow: 0 0 0 3px rgba(26,127,212,0.15) !important;
}
.login-gt-wrap select option,
.login-gt-wrap .goog-te-combo option {
  background: var(--white) !important;
  color: var(--text) !important;
}

/* ── 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);}

.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{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{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{font-size:1.6rem;letter-spacing:0.5em;text-align:center;font-weight:700;font-family:'Courier New',monospace;padding-left:1.5rem;}

.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;}

.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);}

.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{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;}

.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-icon{font-size:3rem;text-align:center;margin-bottom:1rem;display:block;}

/* ══════════════════════════════════════════════════════════
   RTL SUPPORT
   ══════════════════════════════════════════════════════════ */
[dir="rtl"] body                { direction: rtl; }
[dir="rtl"] .bank-logo          { flex-direction: row-reverse; }
[dir="rtl"] .bank-header        { text-align: right; }
[dir="rtl"] .login-gt-wrap      { justify-content: flex-end; }
[dir="rtl"] .field-group label  { text-align: right; }
[dir="rtl"] .field-group input,
[dir="rtl"] .modal-input        { text-align: right; direction: rtl; }
[dir="rtl"] .input-wrapper      { flex-direction: row-reverse; }
[dir="rtl"] .input-wrapper input{ padding-right: 1rem; padding-left: 2.7rem; }
[dir="rtl"] .toggle-pw          { right: auto; left: 0.85rem; }
[dir="rtl"] .forgot-link        { justify-content: flex-start; }
[dir="rtl"] .register-link      { text-align: right; }
[dir="rtl"] .modal-close        { right: auto; left: 1.1rem; }
[dir="rtl"] .modal-box          { direction: rtl; }
[dir="rtl"] .modal-progress     { flex-direction: row-reverse; }
[dir="rtl"] .dev-alert          { flex-direction: row-reverse; }
[dir="rtl"] .dev-alert-body     { text-align: right; }
[dir="rtl"] .modal-note         { text-align: right; }
[dir="rtl"] .modal-desc         { text-align: right; }
[dir="rtl"] .otp-input          { direction: ltr; }
[dir="rtl"] .toast              { right: auto; left: 1.5rem; transform: translateX(-140%); }
[dir="rtl"] .toast.show         { transform: translateX(0); }

/* ── Script fonts ── */
[lang="ar"],[lang="ur"],[lang="fa"] { font-family:'Segoe UI','Arabic Typesetting',Tahoma,sans-serif;line-height:1.8; }
[lang="zh"],[lang="zh-tw"],[lang="ja"],[lang="ko"] { font-family:'Segoe UI','Noto Sans CJK','Microsoft YaHei',sans-serif; }
[lang="hi"],[lang="bn"] { font-family:'Segoe UI','Noto Sans Devanagari',sans-serif;line-height:1.8; }
[lang="th"] { font-family:'Segoe UI','Noto Sans Thai',Tahoma,sans-serif;line-height:2; }
[lang="am"] { font-family:'Segoe UI','Nyala','Ebrima',sans-serif;line-height:1.9; }

/* ── 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;}
  .login-gt-wrap select,
  .login-gt-wrap .goog-te-combo { min-width: 100% !important; }
}
@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;}
}