/* ============ Page-specific styles: forgot-password.html ============ */

body { background:#F4F5F7; min-height:100vh; display:flex; flex-direction:column; }

/* full page center layout */
.fp-page { flex:1; display:flex; align-items:center; justify-content:center; padding:40px 20px; }
.fp-card { background:#fff; border:1px solid var(--border); border-radius:18px; padding:0; overflow:hidden; width:100%; max-width:440px; box-shadow:0 8px 40px rgba(0,0,0,.08); }

/* card header strip */
.fp-card-top { background:linear-gradient(135deg,#111 0%,#1c1c1c 100%); padding:32px 36px 28px; text-align:center; position:relative; overflow:hidden; }
.fp-card-top::before { content:''; position:absolute; width:300px; height:300px; border-radius:50%; background:radial-gradient(circle,rgba(255,106,0,.18) 0%,transparent 70%); top:-80px; right:-80px; }
.fp-logo { height:36px; margin:0 auto 20px; display:block; filter:brightness(0) invert(1); }
.fp-ico-wrap { width:60px; height:60px; border-radius:50%; background:rgba(255,106,0,.15); border:2px solid rgba(255,106,0,.3); display:flex; align-items:center; justify-content:center; margin:0 auto 14px; }
.fp-card-top h2 { font-family:var(--font-heading); font-size:1.25rem; font-weight:700; color:#fff; margin-bottom:6px; }
.fp-card-top p { font-size:.8rem; color:rgba(255,255,255,.5); line-height:1.6; }

/* card body */
.fp-card-body { padding:28px 32px 32px; }

/* step panels */
.fp-step { display:none; animation:fadeIn .3s ease; }
.fp-step.active { display:block; }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);} }

/* progress dots */
.fp-dots { display:flex; align-items:center; justify-content:center; gap:6px; margin-bottom:24px; }
.fp-dot { width:8px; height:8px; border-radius:50%; background:#E5E7EB; transition:all .3s; }
.fp-dot.active { background:var(--accent); width:24px; border-radius:4px; }
.fp-dot.done { background:#16a34a; }

/* field */
.f-group { margin-bottom:18px; }
.f-label { display:block; font-size:.75rem; font-weight:600; color:var(--heading); margin-bottom:6px; }
.f-inp-wrap { position:relative; }
.f-ico { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:#C0C0C0; display:flex; align-items:center; }
.f-ico-r { position:absolute; right:13px; top:50%; transform:translateY(-50%); color:#C0C0C0; cursor:pointer; display:flex; align-items:center; transition:color .2s; }
.f-ico-r:hover { color:var(--heading); }
.f-inp { width:100%; padding:12px 14px 12px 42px; border:1.5px solid var(--border); border-radius:9px; font-family:var(--font-body); font-size:.875rem; color:var(--heading); outline:none; transition:all .2s; background:#fff; }
.f-inp:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(255,106,0,.08); }
.f-inp::placeholder { color:#C0C0C0; }
.f-inp.err { border-color:#ef4444; }
.f-err { font-size:.7rem; color:#ef4444; margin-top:4px; display:none; }
.f-hint { font-size:.7rem; color:var(--body); margin-top:4px; line-height:1.5; }

/* primary button */
.fp-btn { width:100%; padding:13px 20px; background:var(--accent); color:#fff; border:none; border-radius:10px; font-family:var(--font-body); font-size:.9rem; font-weight:700; cursor:pointer; transition:all .3s; display:flex; align-items:center; justify-content:center; gap:7px; box-shadow:0 4px 16px rgba(255,106,0,.25); }
.fp-btn:hover { background:var(--accent-hover); transform:translateY(-1px); }
.fp-btn:disabled { opacity:.5; pointer-events:none; }
.fp-back { display:flex; align-items:center; justify-content:center; gap:5px; font-size:.78rem; color:var(--body); margin-top:14px; cursor:pointer; background:none; border:none; transition:color .2s; width:100%; }
.fp-back:hover { color:var(--accent); }

/* OTP boxes */
.otp-row { display:flex; gap:8px; justify-content:center; margin:16px 0; }
.otp-box { width:46px; height:52px; text-align:center; border:1.5px solid var(--border); border-radius:9px; font-family:var(--font-heading); font-size:1.3rem; font-weight:700; color:var(--heading); outline:none; transition:border-color .2s; }
.otp-box:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(255,106,0,.08); }

/* resend */
.fp-resend { text-align:center; font-size:.78rem; color:var(--body); margin-bottom:16px; }
.fp-resend button { color:var(--accent); font-weight:600; background:none; border:none; cursor:pointer; font-size:.78rem; }

/* password strength */
.pwd-str { margin-top:7px; }
.pwd-bars { display:flex; gap:3px; margin-bottom:3px; }
.pwd-bar { flex:1; height:3px; border-radius:2px; background:#E5E7EB; transition:background .3s; }
.pwd-bar.w { background:#ef4444; } .pwd-bar.f { background:#f59e0b; } .pwd-bar.g { background:#16a34a; }
.pwd-lbl { font-size:.68rem; color:var(--body); }

/* success state */
.fp-success { text-align:center; padding:8px 0 4px; }
.fp-success-ico { width:64px; height:64px; border-radius:50%; background:#F0FDF4; border:2px solid #16a34a; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.fp-success h3 { font-family:var(--font-heading); font-size:1.15rem; color:var(--heading); margin-bottom:8px; }
.fp-success p { font-size:.82rem; color:var(--body); line-height:1.65; margin-bottom:20px; }
.fp-success a { display:flex; align-items:center; justify-content:center; gap:7px; }

/* method toggle */
.fp-method-tabs { display:flex; border:1.5px solid var(--border); border-radius:9px; overflow:hidden; margin-bottom:18px; }
.fp-method-tab { flex:1; padding:9px 12px; font-size:.8rem; font-weight:600; color:var(--body); background:#fff; border:none; cursor:pointer; transition:.2s; }
.fp-method-tab.active { background:var(--accent); color:#fff; }

/* links */
.fp-links { display:flex; align-items:center; justify-content:space-between; margin-top:18px; font-size:.75rem; }
.fp-links a { color:var(--accent); font-weight:600; }

@media(max-width:480px) { .fp-card-body { padding:24px 20px 26px; } .otp-box { width:38px; height:46px; font-size:1.1rem; } }
